.admin-shell{height:100vh;overflow:hidden;display:grid;grid-template-columns:240px 1fr;grid-template-rows:56px 1fr;background:var(--pine-deep)}.admin-header{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:var(--pine);border-bottom:1px solid rgba(239,231,216,.1);z-index:10}.admin-header .brand{display:flex;align-items:center;gap:12px;color:var(--on-dark-1);text-decoration:none}.admin-header .brand img{height:28px;filter:invert(1) brightness(1.8)}.admin-header .brand-text{font-family:var(--font-body);font-weight:700;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase}.admin-header .user-actions{display:flex;gap:14px;align-items:center}.admin-header .user-actions a,.admin-header .user-actions button{font-family:var(--font-body);font-size:.78rem;color:var(--on-dark-2);text-decoration:none;background:transparent;border:1px solid rgba(239,231,216,.18);padding:7px 14px;border-radius:3px;cursor:pointer}.admin-header .user-actions a:hover,.admin-header .user-actions button:hover{color:var(--sunset);border-color:var(--sunset)}.admin-sidebar{background:var(--pine);border-right:1px solid rgba(239,231,216,.08);padding:24px 0;overflow-y:auto;height:100%}.admin-sidebar h4{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mist);padding:0 24px 8px;margin-top:18px}.admin-sidebar h4:first-child{margin-top:0}.admin-sidebar a{display:block;padding:10px 24px;color:var(--on-dark-2);text-decoration:none;font-family:var(--font-body);font-size:.88rem;border-left:3px solid transparent}.admin-sidebar a:hover{background:#efe7d80a;color:var(--on-dark-1)}.admin-sidebar a.active{color:var(--sunset);border-left-color:var(--sunset);background:#e685420f}.admin-main{padding:32px 36px;overflow-y:auto;background:var(--pine-deep);height:100%}.admin-main h1{font-family:var(--font-display);font-size:1.8rem;color:var(--on-dark-1);margin-bottom:6px;line-height:1}.admin-main .page-sub{color:var(--mist);font-style:italic;margin-bottom:28px}.admin-card{background:var(--surface);padding:24px;border-radius:6px;border:1px solid rgba(239,231,216,.08);margin-bottom:18px}.admin-card h2{font-family:var(--font-display);font-size:1.2rem;color:var(--on-dark-1);margin-bottom:4px;line-height:1.1}.admin-card .help{color:var(--mist);font-size:.85rem;margin-bottom:14px;line-height:1.5}.admin-card label{display:block;font-family:var(--font-body);font-weight:600;font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mist);margin-bottom:6px}.admin-card input,.admin-card textarea,.admin-card select{width:100%;background:var(--pine-deep);border:1px solid rgba(239,231,216,.18);color:var(--on-dark-1);padding:12px 14px;border-radius:4px;font-family:var(--font-body);font-size:1rem;outline:none;margin-bottom:14px}.admin-card input:focus,.admin-card textarea:focus,.admin-card select:focus{border-color:var(--sunset)}.admin-card textarea{min-height:180px;resize:vertical;line-height:1.55}.amber-warning{background:#e6854214;border-left:4px solid var(--sunset);padding:14px 18px;border-radius:4px;margin-bottom:22px;color:var(--on-dark-1);font-size:.92rem;line-height:1.55}.amber-warning strong{color:var(--sunset)}.admin-btn{display:inline-block;padding:10px 22px;border-radius:4px;font-family:var(--font-body);font-weight:700;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;border:2px solid transparent;text-decoration:none;transition:all .15s}.admin-btn-primary{background:var(--sunset);color:var(--pine-deep);border-color:var(--sunset)}.admin-btn-primary:hover{background:var(--sunset-deep);color:var(--on-dark-1)}.admin-btn-secondary{background:transparent;color:var(--on-dark-1);border-color:#efe7d84d}.admin-btn-secondary:hover{border-color:var(--on-dark-1)}.admin-btn-danger{background:transparent;color:#ff6b6b;border-color:#ff6b6b40}.admin-btn-danger:hover{background:#ff6b6b1a;border-color:#ff6b6b}.admin-btn-group{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}.admin-list{display:grid;gap:10px;margin-top:14px}.admin-list-item{background:var(--pine-deep);padding:16px 20px;border-radius:4px;display:flex;justify-content:space-between;align-items:center;border:1px solid rgba(239,231,216,.08);gap:16px}.admin-list-item .meta{flex:1}.admin-list-item .meta h3{font-family:var(--font-body);font-size:1rem;color:var(--on-dark-1);margin-bottom:4px}.admin-list-item .meta p{color:var(--mist);font-size:.82rem}.admin-list-item .actions{display:flex;gap:8px}.admin-toast{position:fixed;bottom:24px;right:24px;background:var(--sunset);color:var(--pine-deep);padding:14px 22px;border-radius:4px;font-family:var(--font-body);font-weight:700;font-size:.85rem;box-shadow:0 8px 24px #0006;z-index:1000}.admin-grid-tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}.admin-tile{display:block;padding:24px;background:var(--surface);border-radius:6px;border:1px solid rgba(239,231,216,.08);text-decoration:none;transition:transform .15s,border-color .15s}.admin-tile:hover{transform:translateY(-2px);border-color:var(--sunset)}.admin-tile .tile-icon{font-size:1.6rem;margin-bottom:10px;color:var(--sunset)}.admin-tile h3{font-family:var(--font-display);font-size:1.1rem;color:var(--on-dark-1);margin-bottom:6px}.admin-tile p{color:var(--mist);font-size:.85rem;line-height:1.4}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-top:16px}.image-tile{position:relative;aspect-ratio:1;background:var(--pine-deep);border-radius:4px;overflow:hidden;border:1px solid rgba(239,231,216,.08)}.image-tile img{width:100%;height:100%;object-fit:cover}.image-tile .delete-btn{position:absolute;top:6px;right:6px;background:#000000b3;color:#fff;border:none;width:26px;height:26px;border-radius:4px;cursor:pointer;font-size:12px}.image-tile .delete-btn:hover{background:#ff6b6b}@media (max-width: 760px){.admin-shell{grid-template-columns:1fr;height:auto;min-height:100vh;overflow:visible}.admin-sidebar{display:none}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--pine-deep);background-image:radial-gradient(ellipse at 70% 100%,rgba(230,133,66,.12),transparent 60%);padding:24px}.auth-card{background:var(--pine);padding:40px 36px;border-radius:8px;border:1px solid rgba(239,231,216,.1);max-width:420px;width:100%}.auth-card .logo{text-align:center;margin-bottom:28px}.auth-card .logo img{height:44px;filter:invert(1) brightness(1.6);margin-bottom:12px}.auth-card .logo h1{font-family:var(--font-display);font-size:1.3rem;color:var(--on-dark-1);letter-spacing:.04em}.auth-card .logo p{color:var(--mist);font-size:.82rem;margin-top:4px}.auth-card .error{background:#ff6b6b1a;border:1px solid rgba(255,107,107,.4);color:#ff8e8e;padding:10px 14px;border-radius:4px;font-size:.85rem;margin-bottom:16px}.auth-card .field{margin-bottom:18px}.auth-card .field label{display:block;font-family:var(--font-body);font-weight:600;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mist);margin-bottom:6px}.auth-card .field input{width:100%;background:var(--pine-deep);border:1px solid rgba(239,231,216,.18);color:var(--on-dark-1);padding:12px 14px;border-radius:4px;font-family:var(--font-mono);font-size:1rem;outline:none}.auth-card .field input:focus{border-color:var(--sunset)}.auth-card .submit{width:100%;padding:14px;background:var(--sunset);color:var(--pine-deep);border:none;border-radius:4px;font-family:var(--font-body);font-weight:700;font-size:.9rem;letter-spacing:.12em;text-transform:uppercase;cursor:pointer}.auth-card .submit:hover{background:var(--sunset-deep);color:var(--on-dark-1)}.auth-card .forgot-link{display:block;text-align:center;margin-top:16px;color:var(--mist);font-size:.82rem;text-decoration:none}.auth-card .forgot-link:hover{color:var(--sunset)}.auth-card .info-note{margin-top:20px;padding-top:16px;border-top:1px solid rgba(239,231,216,.08);font-family:var(--font-mono);font-size:.68rem;color:var(--mist);text-align:center;line-height:1.5}:root{--pine-deep: #082023;--pine: #0C272B;--pine-2: #0F2E33;--surface: #163840;--surface-2: #1F4853;--teal: #2C7375;--mist: #7AB5AE;--mist-2: #9CCAC4;--cream: #EFE7D8;--cream-warm: #E5DAC6;--cream-rule: #D2C5A8;--ink: #0A1F22;--ink-muted: #4A6063;--sunset: #E68542;--sunset-deep: #BF3F22;--on-dark-1: #EFE7D8;--on-dark-2: rgba(239,231,216,.72);--on-dark-3: rgba(239,231,216,.46);--on-dark-4: rgba(239,231,216,.22);--font-display: "Archivo Black", sans-serif;--font-body: "Source Sans 3", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace;--container-max: 1100px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{}body{background:var(--pine);color:var(--on-dark-1);font-family:var(--font-body);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased}img{display:block;max-width:100%;height:auto}a{color:var(--sunset);text-decoration:none;transition:color .15s}a:hover{color:var(--mist-2)}.container{max-width:var(--container-max);margin:0 auto;padding:0 28px}.rule{border:none;border-top:1px solid rgba(239,231,216,.08);margin:0}.h-display,h1.display,h2.display{font-family:var(--font-display);font-weight:400;line-height:.98;letter-spacing:-.015em;text-wrap:balance}.eyebrow{font-family:var(--font-body);font-size:.78rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--sunset)}.eyebrow--mist{color:var(--mist)}.eyebrow--sunset-deep{color:var(--sunset-deep)}.mono{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mist)}.btn{display:inline-block;font-family:var(--font-body);font-weight:700;font-size:.85rem;letter-spacing:.14em;text-transform:uppercase;padding:14px 32px;border-radius:3px;text-decoration:none;cursor:pointer;border:2px solid transparent;transition:background .2s,color .2s,border-color .2s,transform .2s}.btn-primary{background:var(--sunset);color:var(--pine-deep);border-color:var(--sunset)}.btn-primary:hover{background:var(--sunset-deep);border-color:var(--sunset-deep);color:var(--on-dark-1);transform:translateY(-2px)}.btn-ghost{background:transparent;color:var(--on-dark-1);border-color:#efe7d859}.btn-ghost:hover{border-color:var(--on-dark-1);transform:translateY(-2px);color:var(--on-dark-1)}.btn-dark{background:var(--pine-deep);color:var(--on-dark-1);border-color:var(--pine-deep)}.btn-dark:hover{background:var(--sunset);border-color:var(--sunset);color:var(--pine-deep);transform:translateY(-2px)}.cta-group{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.fade-in{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}.fade-in.is-visible{opacity:1;transform:none}.section{padding:96px 0}.section-tight{padding:72px 0}.cream-bg{background:var(--cream);color:var(--ink)}.cream-bg a{color:var(--sunset-deep)}.cream-bg a:hover{color:var(--pine)}

/* === Public-site polish for Kyle's QR landing — added 2026-05-19 ========== */

/* AtC hero: 3 CTAs all same width on desktop */
.book-hero .cta-group .btn{flex:0 0 240px;text-align:center;box-sizing:border-box}

/* Books index — card cover fills width on mobile (was max-width:200px) */
@media (max-width:700px){
  .book-card .card-cover{max-width:none !important;width:100% !important}
}

/* AtC hero on mobile — image fills width + CTAs centered + each CTA fills row */
@media (max-width:800px){
  .book-hero .cover{max-width:none !important;width:100% !important}
  .book-hero .cta-group{justify-content:center !important}
  .book-hero .cta-group .btn{flex:0 0 100%;max-width:340px}
  /* Companion Visual Library callout — center the dark CTA button on mobile */
  .vl-callout .vl-grid>div:first-child .btn-dark{
    display:block;width:fit-content;margin-left:auto;margin-right:auto;
  }
}

/* === Polish v2 (2026-05-19): single-row desktop CTAs + Open btn full-width === */
.book-hero .cta-group{
  display:grid !important;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  width:100%;
  flex-wrap:initial;
}
.book-hero .cta-group .btn{
  padding:14px 14px !important;
  flex:initial !important;
  min-width:0;
  max-width:none !important;
  text-align:center;
  white-space:nowrap;
  letter-spacing:.10em;
  box-sizing:border-box;
}
@media (max-width:800px){
  .book-hero .cta-group{
    grid-template-columns:1fr;
    justify-items:center;
  }
  .book-hero .cta-group .btn{
    width:100% !important;
    max-width:340px !important;
  }
  /* Open the Visual Library — full width on mobile (was fit-content) */
  .vl-callout .vl-grid>div:first-child .btn-dark{
    display:block;
    width:100% !important;
    max-width:340px !important;
    margin-left:auto;
    margin-right:auto;
  }
}

/* === Polish v3 (2026-05-19) ============================================== */

/* Breakpoint align: book hero collapses at 900px to match nav hamburger
   (was 800px in source — moved up so the buttons stack at the same moment
   the nav becomes a hamburger, avoiding the in-between text-bleed range) */
@media (max-width:900px){
  /* Collapse the 2-col book hero earlier */
  .book-hero .hero-grid{
    grid-template-columns:1fr !important;
    gap:36px !important;
  }
  /* Stack the CTAs and re-center, full-row up to 340px */
  .book-hero .cta-group{
    grid-template-columns:1fr !important;
    justify-items:center;
    justify-content:center !important;
  }
  .book-hero .cta-group .btn{
    width:100% !important;
    max-width:340px !important;
  }
  /* Cover image fills width at this breakpoint too */
  .book-hero .cover{
    max-width:none !important;
    width:100% !important;
  }
  /* Open the Visual Library button — full-width at this breakpoint */
  .vl-callout .vl-grid>div:first-child .btn-dark{
    display:block;
    width:100% !important;
    max-width:340px !important;
    margin-left:auto;
    margin-right:auto;
  }
}

/* Visual Library — symmetric gap between last exhibit and Reader Submissions
   Source: .exhibits padding 96 0, .exhibit margin-bottom 80, .reader-submissions padding 80 0
   Before: 80 (orphan margin) + 96 + 80 = 256px below content, 80px above title — asymmetric.
   After:  0 (no orphan)    + 80 + 80 = 160px below content, 80px above title — closer. */
.exhibits{padding:96px 0 80px !important}
.exhibits .exhibit:last-child{margin-bottom:0 !important}

/* === Top-gap consistency across public pages — 2026-05-19 =================
   Desktop: About page bumped 40→80 to match Books (and the other main pages
   which already sit at .page-section padding 80).
   Mobile (≤700px): every public page drops its top padding to a consistent
   48px so the narrow viewport doesn't waste vertical real estate.
   Home hero (#hero) intentionally left alone — Joe approved it as-is. */

/* Desktop bump — About hero matches Books spacing */
.about-hero{padding-top:80px !important}

@media (max-width:700px){
  /* About hero — slight increase from 40 (was too tight) */
  .about-hero{padding-top:48px !important}
  /* All other public pages — drop from 80 (was too generous on narrow screens) */
  .page-section{padding-top:48px !important}
  .blog-hub{padding-top:48px !important}
  .contact-page{padding-top:48px !important}
  .legal-page{padding-top:48px !important}
  .blog-post{padding-top:48px !important}
  .subblog-index{padding-top:48px !important}
}

/* === Top-gap consistency v2 (2026-05-19) =================================
   Bigger desktop bump on About + add the 3 missed nested-page classes
   for mobile (vl-header, book-hero). Maximum specificity via attribute
   selector trick + !important so this wins over the bundle's runtime style. */
.about-hero[class]{padding-top:100px !important}

@media (max-width:700px){
  /* The 3 nested pages on /books/* that I missed in v1 */
  .vl-header[class]{padding-top:48px !important;padding-bottom:48px !important}
  .book-hero[class]{padding-top:48px !important;padding-bottom:48px !important}
  /* Belt-and-suspenders on .about-hero too (was 40 → bumped to 48 on mobile) */
  .about-hero[class]{padding-top:48px !important}
}

/* === Visual Library closer mobile — equal-width CTAs + 32px gap === */
@media (max-width:700px){
  .vl-closer .cta-group{
    flex-direction:column !important;
    gap:32px !important;
    align-items:center !important;
  }
  .vl-closer .cta-group .btn{
    width:100% !important;
    max-width:340px !important;
    box-sizing:border-box;
    text-align:center;
  }
}

/* === Social icons — mobile auto-fit (CSS-only, beats inline styles) === */
@media (max-width:700px){
  [data-up-social-row]{
    display:flex !important;
    flex-wrap:nowrap !important;
    justify-content:space-evenly !important;
    align-items:center !important;
    gap:8px !important;
    padding:24px 12px 8px !important;
    width:100% !important;
    box-sizing:border-box !important;
  }
  [data-up-social-row] a{
    flex:1 1 0 !important;
    min-width:0 !important;
    max-width:60px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    line-height:0 !important;
  }
  [data-up-social-row] a img{
    width:100% !important;
    height:auto !important;
    aspect-ratio:1 !important;
    max-width:56px !important;
    display:block !important;
  }
}

/* === Chapter 1 closer buttons — mobile stack + desktop equal width === */
@media (max-width:700px){
  .closer-actions{
    flex-direction:column !important;
    gap:32px !important;
    align-items:center !important;
  }
  .closer-actions .btn{
    width:100% !important;
    max-width:340px !important;
    box-sizing:border-box;
    text-align:center;
  }
}
@media (min-width:701px){
  .closer-actions{
    gap:14px !important;
    justify-content:center !important;
  }
  .closer-actions .btn{
    min-width:280px;
    max-width:280px;
    padding:14px 18px !important;
    text-align:center;
    box-sizing:border-box;
    white-space:nowrap;
  }
}

/* === Contact form required asterisks + error helper === */
.up-req{
  color:#E68542 !important;
  font-weight:700;
  margin-left:4px;
  font-size:1.05em;
  user-select:none;
}
/* When asterisk sits inside the opt-in checkbox label (text uses dangerouslySetInnerHTML),
   the label's inherited color can win over .up-req's; force the override. */
.contact-form label.opt-in span .up-req,
.contact-form label.copy-checkbox.opt-in .up-req{
  color:#E68542 !important;
}
.up-required-note{
  font-size:.82rem;
  color:#7AB5AE;
  font-style:italic;
  margin:-14px 0 18px;
  padding:0;
  border:0;
  background:transparent;
  text-align:left;
}
/* Send button row — button on left, helper-error to the right, vertically centered. */
.up-btn-row{
  display:flex;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
  margin-top:18px;
}
.up-btn-row button[type="submit"]{
  margin:0 !important;
  flex:0 0 auto;
}
.up-helper-host{
  flex:1 1 auto;
  min-width:0;
}
.up-form-error{
  display:inline-block;
  color:#ff6b6b !important;
  font-size:.92rem;
  font-weight:600;
  line-height:1.4;
}
.up-form-error .up-form-error-star{
  color:#ff3030 !important;
  font-weight:900;
  font-size:1.1em;
  margin-right:4px;
}
@media (max-width:600px){
  /* On very narrow viewports drop the helper UNDER the button so neither shrinks */
  .up-btn-row{flex-direction:column;align-items:flex-start;gap:10px}
}

/* === Contact form attachments — custom thumb grid === */
.up-attach-list{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(110px, 1fr));
  gap:12px;
  margin-top:12px;
}
.up-attach-item{
  position:relative;
  background:rgba(8,32,35,.4);
  border:1px solid rgba(239,231,216,.10);
  border-radius:6px;
  padding:10px;
  text-align:center;
  font-size:.72rem;
  color:rgba(239,231,216,.85);
  overflow:hidden;
}
.up-attach-thumb{
  width:100%;
  aspect-ratio:1;
  object-fit:cover;
  border-radius:4px;
  background:rgba(239,231,216,.04);
  margin-bottom:6px;
}
.up-attach-icon{
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:2.2rem;
  width:100%;
  aspect-ratio:1;
  background:rgba(239,231,216,.04);
  border-radius:4px;
  margin-bottom:6px;
  color:#7AB5AE;
}
.up-attach-name{
  display:block;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.up-attach-remove{
  position:absolute;
  top:4px; right:4px;
  width:22px; height:22px;
  border-radius:50%;
  background:rgba(191,63,34,.95);
  color:#fff;
  border:0;
  font-size:.85rem;
  font-weight:700;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  line-height:1;
  padding:0;
}
.up-attach-remove:hover{background:#BF3F22}
