:root{
    --paper:#FEFBF0;
    --paper-2:#F6F1E1;
    --ink:#1A1A18;
    --ink-soft:#9A978E;
    --ink-mid:#5C5A53;
    --accent:#1A1A18;
    --accent-deep:#000;
    --amber:#9A7B3F;
    --blue:#1A3A7E;
    --gold:#C28E1B;
    --gold-bright:#E0A52C;
    --line:#EAE8E1;
    --line-soft:#F1EFE9;
    --max:760px;
    --serif:"Newsreader",Georgia,serif;
    --sans:"Hanken Grotesk",system-ui,sans-serif;
    --mono:"IBM Plex Mono",ui-monospace,monospace;
  }
  *{box-sizing:border-box;}
  body{
    margin:0;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;
    background:var(--paper);color:var(--ink);
    font-family:var(--serif);font-size:19px;line-height:1.72;font-weight:400;
    -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  }
  a{color:var(--ink);text-decoration:none;cursor:pointer;}
  a:hover{color:var(--blue);}

  .eyebrow{
    font-family:var(--sans);font-size:11.5px;font-weight:600;letter-spacing:.26em;
    text-transform:uppercase;color:var(--gold);display:block;margin:0 0 2rem;
  }

  /* ---------- NAV (modern top bar) ---------- */
  .nav{
    position:sticky;top:0;z-index:50;
    background:color-mix(in srgb, var(--paper) 86%, transparent);
    backdrop-filter:saturate(120%) blur(10px);
  }
  .nav-inner{
    position:relative;max-width:1180px;margin:0 auto;padding:30px 56px;
    display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:24px 40px;flex-wrap:wrap;
  }
  .brand{
    font-family:var(--sans);font-style:normal;font-size:19px;color:var(--blue);
    font-weight:400;letter-spacing:.16em;text-transform:uppercase;white-space:nowrap;line-height:1;
  }
  .brand:hover{color:var(--blue);}
  body:not([data-view="book"]) .brand:hover{color:var(--gold-bright);}
  .nav-links{display:flex;align-items:center;flex-wrap:wrap;gap:34px;}
  .nav-link{
    font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
    color:var(--ink-soft);transition:color .2s;white-space:nowrap;
    border-bottom:2px solid transparent;padding-bottom:4px;
  }
  .nav-link:hover{color:var(--blue);}
  .nav-link.current{color:var(--blue);border-bottom-color:var(--gold-bright);}
  .nav-cta,.nav-rule{display:none;}
  /* hamburger — hidden on desktop, shown on narrow screens */
  .nav-toggle{
    display:none;flex-direction:column;justify-content:center;gap:5px;
    width:40px;height:40px;padding:0;background:none;border:0;cursor:pointer;
  }
  .nav-toggle span{display:block;width:22px;height:2px;background:var(--ink);
    border-radius:2px;transition:transform .22s,opacity .22s;}
  .nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  .nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;}
  .nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

  /* ---------- STAGE / VIEWS ---------- */
  #stage{flex:1;max-width:var(--max);width:100%;margin:0 auto;padding:0 40px;}
  .view{display:none;padding:56px 0 80px;}
  .view.active{display:block;}
  @keyframes fadeView{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
  .view.active{animation:fadeView .6s ease;}
  .view h2{
    font-family:var(--serif);font-weight:400;font-style:normal;font-size:clamp(1.5rem,2.7vw,1.8rem);
    line-height:1.18;margin:0 0 2rem;letter-spacing:-.006em;text-transform:none;text-align:center;
  }
  #view-writing h2{
    font-size:clamp(1.5rem,2.7vw,1.8rem);text-align:left;letter-spacing:-.006em;
    max-width:640px;margin-left:auto;margin-right:auto;
  }

  /* ---------- BOOK HERO ---------- */
  .book-hero{text-align:center;max-width:760px;margin:0 auto;padding:0;}
  .book-hero .eyebrow{margin:0 0 2.4rem;}
  .book-title{
    font-family:var(--serif);font-style:normal;font-weight:400;color:var(--blue);
    font-optical-sizing:auto;text-transform:none;
    font-size:clamp(2.4rem,5.6vw,3.9rem);line-height:1.12;letter-spacing:-.005em;margin:0 0 1.8rem;
  }
  .book-by{font-family:var(--sans);font-size:.9rem;font-weight:500;letter-spacing:.04em;color:var(--ink-soft);margin:0;text-transform:none;}
  .book-by span{color:var(--ink-mid);}
  .hero-epigraph{display:none;}

  /* ---------- BOOK FEATURE ---------- */
  .book-feature{
    display:grid;grid-template-columns:0.86fr 0.70fr;gap:64px;align-items:start;
    margin-top:84px;padding-top:0;border:0;
    --fw:min(914px, 94vw);
    width:var(--fw);max-width:none;
    margin-left:calc((100% - var(--fw)) / 2);margin-right:calc((100% - var(--fw)) / 2);
  }
  .cover-wrap{max-width:none;width:100%;margin:0;}
  .book-meta{display:none;}
  .cover-img{
    width:100%;height:auto;display:block;border-radius:1px;
    box-shadow:0 30px 60px -34px rgba(26,26,24,.45);
  }
  .feature-blurbs{align-self:start;display:flex;flex-direction:column;gap:30px;}
  .feature-lede{align-self:start;}
  .feature-lede p{
    font-family:var(--serif);font-weight:400;font-size:1.08rem;line-height:1.72;
    margin:0 0 1.3rem;color:var(--ink);text-wrap:pretty;text-align:left;
  }
  .feature-lede p:last-child{margin-bottom:0;}
  .feature-lede em{font-style:italic;}
  .fblurb p{
    font-family:var(--serif);font-weight:400;font-size:1rem;line-height:1.62;
    margin:0 0 8px;color:var(--ink);text-wrap:pretty;
  }
  .fblurb em{font-style:italic;}
  .fblurb .attr{
    font-family:var(--sans);font-size:10.5px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
    color:var(--ink-soft);line-height:1.5;margin:0;
  }
  .synopsis{max-width:56ch;margin:80px auto 0;text-align:left;font-size:1.02rem;line-height:1.74;}

  /* ---------- PREORDER ---------- */
  .preorder{margin:92px auto 0;padding-top:64px;border-top:1px solid color-mix(in srgb, var(--gold) 42%, var(--paper));max-width:none;text-align:center;}
  .preorder h3{
    font-family:var(--sans);font-style:normal;font-weight:600;font-size:14px;letter-spacing:.2em;text-transform:uppercase;
    color:var(--ink);margin:0 0 40px;
  }
  .preorder-sub{display:none;}
  .preorder-date{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);margin:-24px 0 40px;}
  .order-region{margin:0 0 30px;}
  .order-region:last-of-type{margin-bottom:0;}
  .region-label{
    font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
    color:var(--ink-soft);margin:0 0 16px;
  }
  .retailer-row{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;}
  .retailer{
    font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;
    padding:14px 26px;border-radius:1px;border:1.5px solid var(--ink);
    background:transparent;color:var(--ink);
    display:inline-flex;align-items:baseline;gap:5px;transition:color .2s,border-color .2s,background .2s;
  }
  .retailer .rg{font-size:.82em;color:var(--ink-soft);letter-spacing:.1em;}
  .retailer:hover{border-color:var(--blue);color:#fff;background:var(--blue);transform:none;box-shadow:none;}
  .retailer:hover .rg{color:rgba(255,255,255,.75);}
  .local{margin:34px 0 0;font-size:.96rem;color:var(--ink-soft);font-style:italic;}

  .synopsis p{margin:0 0 1.4rem;}
  .synopsis p:last-child{margin-bottom:0;}

  /* ---------- PRAISE ---------- */
  .praise{margin:104px auto 0;padding-top:72px;border-top:1px solid color-mix(in srgb, var(--gold) 42%, var(--paper));max-width:720px;text-align:center;}
  .resources{margin:104px auto 0;padding-top:72px;border-top:1px solid color-mix(in srgb, var(--gold) 42%, var(--paper));max-width:720px;text-align:center;}
  .resources > .eyebrow{margin:0 0 2.4rem;}
  .resources p{font-family:var(--serif);font-size:clamp(1.02rem,1.6vw,1.16rem);line-height:1.62;font-weight:400;margin:0 0 1.3rem;color:var(--ink);letter-spacing:-.002em;text-wrap:pretty;text-align:left;}
  .resources p:last-child{margin-bottom:0;}
  .resources a{border-bottom:1px solid var(--line);}
  .resources a:hover{color:var(--blue);border-color:var(--blue);}
  body.rhythm-airy .resources{margin-top:140px;padding-top:96px;}
  .praise > .eyebrow{margin:0 0 3.4rem;}
  .blurb{margin:0 0 4.6rem;padding:0;border:0;max-width:none;}
  .blurb:last-child{margin-bottom:0;}
  .blurb p{
    font-family:var(--serif);font-size:clamp(1.02rem,1.6vw,1.16rem);line-height:1.62;font-weight:400;
    margin:0 0 1.3rem;color:var(--ink);letter-spacing:-.002em;text-wrap:pretty;text-align:left;
  }
  .blurb .attr{
    font-family:var(--sans);font-size:11.5px;font-weight:500;letter-spacing:.04em;text-transform:none;
    color:var(--blue);line-height:1.6;font-style:normal;text-align:left;
  }
  .blurb .attr em{font-style:italic;}
  .blurb .attr .cap,.blurb .attr em.cap{text-transform:uppercase;letter-spacing:.14em;}
  .blurb .attr em.cap{font-style:italic;}

  /* ---------- ABOUT ---------- */
  .about-grid{display:grid;grid-template-columns:315px 380px;gap:72px;align-items:start;text-align:left;
    width:767px;max-width:none;margin-left:calc((100% - 767px) / 2);margin-right:calc((100% - 767px) / 2);}
  .about-grid .bio p{margin:0 0 1.4rem;text-align:left;font-size:1.08rem;line-height:1.72;}
  .about-grid .bio p:last-child{margin-bottom:0;}
  .portrait-img{width:100%;height:auto;display:block;border:0;border-radius:1px;box-shadow:0 26px 54px -34px rgba(26,26,24,.4);}
  .photo-credit{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.06em;color:var(--blue);margin:12px 0 0;text-align:left;}

  /* ---------- OTHER WRITING ---------- */
  .writing-list{list-style:none;margin:0 auto;padding:0;max-width:640px;text-align:left;}
  .writing-list li{
    padding:24px 0;border-bottom:1px solid color-mix(in srgb, var(--gold) 42%, var(--paper));
    display:flex;justify-content:space-between;gap:52px;align-items:baseline;flex-wrap:nowrap;
  }
  .writing-list li:first-child{border-top:1px solid color-mix(in srgb, var(--gold) 42%, var(--paper));}
  .writing-list .title{font-size:1.12rem;color:var(--ink);flex:1 1 auto;line-height:1.4;min-width:0;max-width:290px;}
  .writing-list a.title:hover{color:var(--blue);}
  .writing-list .venue{
    font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
    color:var(--ink-soft);text-align:right;flex:0 0 auto;max-width:230px;line-height:1.7;
  }

  /* ---------- EVENTS ---------- */
  .events-line{font-family:var(--serif);font-style:normal;font-weight:400;font-size:clamp(1.5rem,2.7vw,1.8rem);
    margin:0 0 1.4rem;letter-spacing:-.006em;color:var(--ink);text-align:center;}
  .events-sub{text-align:center;}
  .events-sub a{font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);}
  .events-sub a:hover{color:var(--blue);}
  .events-signup{display:flex;flex-direction:column;align-items:center;gap:14px;margin:36px auto 0;max-width:420px;}

  /* ---------- CONTACT ---------- */
  .contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:stretch;text-align:left;}
  .contact-meta{margin-top:0;order:1;display:flex;flex-direction:column;}
  .contact-form-block{order:2;display:flex;flex-direction:column;}
  .contact-form{display:flex;flex-direction:column;flex:1;}
  .contact-form .btn-primary{margin-top:auto;align-self:flex-start;}
  .contact-meta .stay{margin-top:auto;}
  .sub-label{
    font-family:var(--serif);font-size:clamp(1.3rem,2.4vw,1.55rem);font-weight:400;letter-spacing:-.006em;text-transform:none;
    color:var(--ink);margin:0 0 24px;
  }
  .nl-block p{margin:0 0 16px;}
  .signup{display:flex;gap:28px;flex-wrap:wrap;align-items:stretch;}
  .signup input{
    flex:1 1 200px;font-family:var(--serif);font-size:1rem;padding:0 16px;height:46px;
    border:1px solid var(--line);border-radius:1px;background:#fff;color:var(--ink);
  }
  .signup input:focus{outline:1px solid var(--blue);outline-offset:1px;border-color:var(--blue);}
  .btn{
    font-family:var(--sans);font-size:11.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
    padding:0 28px;height:46px;border-radius:1px;display:inline-flex;align-items:center;justify-content:center;transition:.2s;border:none;cursor:pointer;
  }
  .btn-primary{background:var(--blue);color:var(--paper);}
  .btn-primary:hover{background:#13295C;color:var(--paper);}
  .fineprint{margin-top:13px;font-size:.9rem;color:var(--ink-soft);font-style:italic;}
  .lane{margin-bottom:34px;}
  .lane:last-child{margin-bottom:0;}
  .lane .role{
    font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;
    color:var(--ink-soft);margin:0 0 10px;
  }
  .lane .who{font-family:var(--serif);font-size:1.02rem;line-height:1.6;color:var(--ink-mid);margin:0 0 2px;}
  .lane .org{font-family:var(--serif);font-size:1.02rem;line-height:1.6;color:var(--ink-mid);font-style:normal;margin:0 0 2px;}
  .lane .addr{font-family:var(--serif);font-size:1.02rem;line-height:1.6;color:var(--ink-mid);margin:0 0 10px;}
  .lane .email{font-family:var(--serif);font-size:1.02rem;line-height:1.6;color:var(--ink-mid);border-bottom:1px solid var(--line);
    display:inline-block;max-width:100%;overflow-wrap:anywhere;}
  .lane .email:hover{border-color:var(--blue);color:var(--blue);}
  .field{margin-bottom:16px;}
  .field label{display:block;font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.14em;
    text-transform:uppercase;color:var(--ink-soft);margin-bottom:8px;}
  .field input,.field textarea{width:100%;font-family:var(--serif);font-size:1rem;padding:13px 15px;
    border:1px solid var(--line);border-radius:1px;background:#fff;color:var(--ink);resize:vertical;}
  .field input:focus,.field textarea:focus{outline:1px solid var(--blue);outline-offset:1px;border-color:var(--blue);}
  .stay{margin-top:44px;}
  .stay-note{font-size:.95rem;line-height:1.6;color:var(--ink-soft);font-style:italic;margin:0 0 18px;max-width:42ch;}
  .inbox-note{font-size:.9rem;line-height:1.5;color:var(--ink-soft);font-style:italic;margin:-8px 0 20px;}
  /* ---------- FORM VALIDATION ---------- */
  .blurb .attr a{color:inherit;border-bottom:1px solid color-mix(in srgb, var(--blue) 30%, transparent);transition:color .2s,border-color .2s;}
  .blurb .attr a:hover{color:var(--blue);border-color:var(--blue);}
  .form-alert{display:none;font-family:var(--sans);font-size:.9rem;line-height:1.55;
    color:#8A2E2E;background:color-mix(in srgb,#8A2E2E 8%,var(--paper));
    border:1px solid color-mix(in srgb,#8A2E2E 34%,var(--paper));border-radius:1px;
    padding:14px 16px;margin:0 0 22px;}
  .form-alert.show{display:block;}
  .form-alert strong{display:block;font-family:var(--sans);font-size:11px;font-weight:600;
    letter-spacing:.1em;text-transform:uppercase;margin:0 0 8px;}
  .form-alert ul{margin:0;padding-left:20px;}
  .form-alert li{margin:2px 0;}
  .form-success{display:none;font-family:var(--serif);font-size:1rem;line-height:1.6;
    color:var(--blue);background:color-mix(in srgb,var(--blue) 7%,var(--paper));
    border:1px solid color-mix(in srgb,var(--blue) 28%,var(--paper));border-radius:1px;
    padding:15px 17px;margin:0 0 22px;}
  .form-success.show{display:block;}
  .field .err{display:none;font-family:var(--sans);font-size:11px;font-weight:500;
    letter-spacing:.04em;color:#8A2E2E;margin-top:8px;}
  .field.invalid .err{display:block;}
  .field.invalid input,.field.invalid textarea{border-color:#8A2E2E;}
  .field .rate-msg{display:none;font-family:var(--sans);font-size:11px;font-weight:600;
    letter-spacing:.04em;color:#8A2E2E;margin-top:8px;}
  .field.rate-limited .rate-msg{display:block;}
  .field.rate-limited textarea{border-color:#8A2E2E;}
  .insta{margin:46px 0 0;font-size:.95rem;color:var(--ink-soft);white-space:nowrap;text-align:center;}
  .insta a{border-bottom:1px solid var(--line);}
  .insta a:hover{border-color:var(--blue);color:var(--blue);}
  .writing-list .venue a{color:var(--ink-soft);border-bottom:0;}
  .writing-list .venue a:hover{color:var(--blue);}
  .placeholder{color:var(--ink-soft);font-family:var(--mono);font-size:12px;
    border:1px dashed var(--line);padding:6px 10px;border-radius:2px;display:inline-block;}

  /* ---------- FOOTER ---------- */
  footer{border:0;padding:8px 0 60px;margin-top:20px;}
  .foot-mark{display:flex;align-items:center;justify-content:center;gap:18px;}
  .foot-mark .line{width:46px;height:1px;background:color-mix(in srgb, var(--blue) 32%, var(--paper));}
  .foot-mark .gem{width:8px;height:8px;background:var(--gold-bright);transform:rotate(45deg);}
  .copyright{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);text-align:center;margin:18px 0 0;}
  .foot-connect{display:flex;flex-direction:column;align-items:center;gap:14px;margin:30px auto 0;max-width:420px;}
  .foot-label{font-family:var(--sans);font-size:11.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin:0;}
  .foot-signup{display:flex;gap:12px;align-items:center;width:100%;justify-content:center;flex-wrap:wrap;}
  .foot-signup input{
    font-family:var(--serif);font-size:1rem;color:var(--ink);background:transparent;
    border:0;border-bottom:1px solid color-mix(in srgb, var(--blue) 32%, var(--paper));
    padding:8px 4px;min-width:220px;flex:1;
  }
  .foot-signup input:focus{outline:none;border-color:var(--blue);}
  .foot-signup input::placeholder{color:var(--ink-soft);}
  .foot-insta{font-family:var(--serif);font-size:.95rem;color:var(--ink-soft);margin:2px 0 0;}
  .foot-insta a{display:inline-flex;align-items:center;gap:7px;border-bottom:0;}
  .foot-insta svg{width:17px;height:17px;flex:none;}
  .foot-insta a:hover{color:var(--blue);}
  .events-signup .foot-insta{margin-top:18px;}
  .page-connect{display:flex;flex-direction:column;align-items:center;gap:14px;margin:80px auto 0;max-width:420px;}
  .community-rule{height:1px;background:color-mix(in srgb, var(--gold) 42%, var(--paper));max-width:720px;margin:96px auto 0;}
  #view-book .page-connect{margin-top:64px;}
  .nl-msg{font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.02em;margin:14px 0 0;text-align:center;line-height:1.5;}
  .nl-msg.nl-ok{color:var(--blue);}
  .nl-msg.nl-error{color:#8A2E2E;}
  .contact-meta .nl-msg,.stay .nl-msg{text-align:left;}

  .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
    clip:rect(0,0,0,0);border:0;}
  .skip-link{position:absolute;left:-999px;top:0;z-index:100;background:var(--blue);color:var(--paper);
    font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.08em;padding:12px 18px;
    border-radius:0 0 4px 0;text-decoration:none;}
  .skip-link:focus{left:0;color:var(--paper);}
  .view h1[tabindex],.view h2[tabindex]{outline:none;}

  /* ---------- Section headings ---------- */
  .praise > .eyebrow,
  .resources > .eyebrow,
  .preorder h3,
  .foot-label,
  .sub-label,
  #view-writing h2{
    font-family:var(--serif);
    font-weight:400;
    font-size:clamp(1.4rem,2.4vw,1.6rem);
    line-height:1.2;
    letter-spacing:-.006em;
    text-transform:none;
    color:var(--ink);
    margin:0 0 2rem;
  }

  /* ---------- RESPONSIVE ---------- */
  @media (max-width:820px){
    body{font-size:18px;}
    .nav-inner{padding:24px 28px;justify-content:center;gap:14px;}
    .brand{font-size:21px;}
    .nav-links{justify-content:center;gap:20px 24px;}
    .nav-link{font-size:11px;}
    .view{padding:80px 0 96px;}
    .book-feature{grid-template-columns:1fr;justify-items:center;gap:36px;margin-top:64px;width:auto;margin-left:0;margin-right:0;}
    .cover-wrap{max-width:300px;margin:0 auto;}
    .feature-lede{text-align:center;}
    .synopsis{margin-top:48px;}
    .preorder{margin-top:72px;padding-top:52px;}
    .praise{margin-top:80px;padding-top:60px;}
    .about-grid{display:flex;flex-direction:column-reverse;gap:32px;text-align:center;width:auto;margin-left:0;margin-right:0;}
    .about-grid .portrait{max-width:260px;margin:0 auto;}
    .contact-grid{grid-template-columns:1fr;gap:48px;}
    .writing-list li{flex-direction:column;gap:6px;}
    .writing-list .venue{text-align:left;}
  }
  /* ---------- PHONES: collapse nav into a tap menu ---------- */
  @media (max-width:640px){
    .nav-inner{justify-content:space-between;padding:18px 22px;gap:12px;}
    .brand{font-size:19px;}
    .nav-toggle{display:flex;}
    .nav-links{display:none;order:3;flex-basis:100%;width:100%;flex-direction:column;align-items:stretch;gap:0;padding-top:6px;}
    .nav-links.open{display:flex;}
    .nav-link{font-size:13px;letter-spacing:.14em;width:100%;padding:14px 2px;border-bottom:1px solid var(--line-soft);}
    .nav-link.current{border-bottom-color:var(--line-soft);}
    .nav-link:last-child{border-bottom:0;}
    .signup,.foot-signup{flex-direction:column;align-items:stretch;gap:12px;}
    .signup .btn,.foot-signup .btn{width:100%;}
  }
  @media (prefers-reduced-motion:reduce){
    .view.active{animation:none;}
  }



  /* ===== BOOK FEATURE: cover left, title + synopsis stacked left ===== */
  #view-book .book-feature-A{
    grid-template-columns:380px minmax(0, 410px);gap:56px;align-items:start;
    justify-content:center;
    --fwA:min(866px, 94vw);
    width:var(--fwA);max-width:none;
    margin-left:calc((100% - var(--fwA)) / 2);margin-right:calc((100% - var(--fwA)) / 2);
    margin-top:0;
    padding-top:0;
  }
  #view-book .book-feature-A .cover-wrap{width:380px;}
  #view-book .book-feature-A .feature-lede{align-self:start;}
  #view-book .book-feature-A .feature-lede .eyebrow{display:block;margin:0 0 20px;}
  #view-book .book-feature-A .feature-lede .book-title{
    font-size:clamp(2.1rem,3.4vw,2.9rem);line-height:1.12;margin:0 0 26px;text-align:left;
  }
  #view-book .book-feature-A .feature-lede p{font-size:1.02rem;}

  /* ===== Lower sections: centered column, narrower dividers, left-aligned copy ===== */
  #view-book .preorder,
  #view-book .praise,
  #view-book .resources{
    --secW:min(660px, 92vw);
    width:var(--secW);max-width:none;
    margin-left:calc((100% - var(--secW)) / 2);
    margin-right:calc((100% - var(--secW)) / 2);
    text-align:center;
  }
  #view-book .preorder{margin-top:92px;}
  #view-book .praise,#view-book .resources{margin-top:104px;}
  #view-book .resources{margin-bottom:-7px;}
  /* content blocks: centered on the page, but with a straight left edge */
  #view-book .preorder .order-region{max-width:none;margin-left:auto;margin-right:auto;}
  #view-book .retailer-row{justify-content:center;}
  #view-book .praise .blurb{max-width:none;margin-left:auto;margin-right:auto;text-align:left;}
  #view-book .praise .blurb p:not(.attr){font-size:18px;line-height:1.62;}
  #view-book .resources p{max-width:none;margin-left:auto;margin-right:auto;text-align:left;font-size:18px;line-height:1.62;}

  /* keep the section headings centered as before */
  #view-book .preorder h3,
  #view-book .praise > .eyebrow,
  #view-book .resources > .eyebrow{display:block;width:100%;text-align:center;}

  /* ===== Narrow screens: stack the synopsis below the cover ===== */
  @media (max-width: 820px){
    #view-book .book-feature-A{
      grid-template-columns:1fr;gap:32px;
      --fwA:min(560px, 90vw);
    }
    #view-book .book-feature-A .cover-wrap{width:min(300px, 62vw);}
    #view-book .book-feature-A .feature-lede .book-title{font-size:clamp(1.9rem,7vw,2.6rem);}
  }
