/*
 * home-page.css — page-scoped styles for /index.html (s6 home).
 * Source: dev/from_kate/donors/home-v2.html (lines 10-191).
 * Strips: box-sizing (base inline), :root (tokens.css), html scroll-behavior (base), body (base).
 * Rename: .site-footer → .home-newsletter (avoids collision with base chrome).
 * Adds:   .home-events.is-empty rule (events visibility wired off pages.home.events_enabled).
 * Remainder is verbatim from home-v2.
 *
 * Note: file is large (~660 KB) because two rules carry base64 background
 * images (.hero, .preorder-cta). Externalizing/optimizing those PNGs is a
 * follow-up bead post-s10. For s6 they ride inline; page-scoped, cacheable.
 */

/* events visibility wired off pages.home.events_enabled (Jinja flag) */
.home-events.is-empty { display: none; }

.container{max-width:820px;margin:0 auto;}
.container-wide{max-width:1100px;margin:0 auto;}
.container-narrow{max-width:640px;margin:0 auto;}
.section-label{font-family:var(--sans);font-size:0.7rem;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem;display:block;}

/* HERO */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:6rem 2rem 5rem;position:relative;overflow:hidden;
  background-image:url(/img/hero-bg.png);background-size:cover;background-position:center;}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(60,21,96,0.10) 0%,rgba(60,21,96,0.05) 50%,rgba(60,21,96,0.18) 100%);pointer-events:none;}
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;max-width:1060px;margin:0 auto;width:100%;}
.hero-book{display:flex;justify-content:center;align-items:center;}
.hero-cover{width:100%;max-width:340px;filter:drop-shadow(0 24px 60px rgba(60,21,96,0.35)) drop-shadow(0 8px 20px rgba(0,0,0,0.25));transition:transform 0.4s ease;}
.hero-cover:hover{transform:translateY(-6px) rotate(0.5deg);}
.hero-eyebrow{font-family:var(--sans);font-size:0.68rem;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--purple-deep);background:rgba(255,255,255,0.6);display:inline-block;padding:0.3rem 1rem;margin-bottom:1.5rem;}
.hero-title{font-family:var(--serif);font-size:clamp(2.4rem,5vw,4rem);font-weight:700;line-height:1.0;color:var(--purple-deep);letter-spacing:-0.01em;margin-bottom:0.5rem;text-shadow:0 1px 0 rgba(255,255,255,0.4);}
.hero-title .comma{color:var(--gold);}
.hero-subtitle{font-family:var(--serif);font-size:clamp(1rem,2vw,1.3rem);font-style:italic;font-weight:400;color:var(--purple-mid);line-height:1.4;margin-bottom:1.6rem;}
.hero-authors{font-family:var(--sans);font-size:0.78rem;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-mid);margin-bottom:0.5rem;}
.hero-publisher{font-family:var(--sans);font-size:0.72rem;letter-spacing:0.08em;color:var(--ink-light);margin-bottom:2.2rem;}
.hero-tagline{font-family:var(--body);font-size:clamp(1.05rem,2vw,1.25rem);font-style:italic;color:var(--ink);line-height:1.6;max-width:440px;margin-bottom:2.5rem;padding:1rem 1.4rem;background:rgba(255,255,255,0.55);border-left:3px solid var(--gold-bright);}
.btn-preorder{display:inline-flex;align-items:center;gap:0.6rem;font-family:var(--sans);font-size:0.85rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--purple-deep);background:var(--gold-bright);border:none;padding:1.15rem 2.8rem;border-radius:2px;cursor:pointer;text-decoration:none;transition:background 0.2s,transform 0.15s,box-shadow 0.2s;box-shadow:0 4px 20px rgba(232,168,32,0.35);}
.btn-preorder:hover{background:var(--gold);transform:translateY(-2px);box-shadow:0 8px 28px rgba(200,144,10,0.4);}
.hero-launch{margin-top:1rem;font-family:var(--sans);font-size:0.74rem;color:var(--ink-mid);letter-spacing:0.06em;}
.hero-launch strong{color:var(--purple-deep);}

/* ═══════════════════════════════════════════════════════════════
   TESTIMONIALS CAROUSEL — PLACEHOLDER
   Populate by replacing placeholder objects in the JS carouselData array.
   Add real quotes, names, and optional titles as they arrive.
   ═══════════════════════════════════════════════════════════════ */
.testimonials-carousel{background:var(--purple-deep);padding:5rem 2rem;position:relative;overflow:hidden;}
.testimonials-carousel::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(232,168,32,0.06) 0%,transparent 70%);pointer-events:none;}
.carousel-inner{position:relative;z-index:1;max-width:720px;margin:0 auto;text-align:center;}
.carousel-label{font-family:var(--sans);font-size:0.68rem;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--lavender);margin-bottom:2rem;display:block;}
.carousel-mark{font-family:var(--serif);font-size:4.5rem;color:var(--gold-bright);opacity:0.3;line-height:0.8;margin-bottom:1.2rem;display:block;}
.carousel-quote{font-family:var(--serif);font-size:clamp(1.15rem,2.5vw,1.55rem);font-style:italic;color:rgba(255,255,255,0.92);line-height:1.65;min-height:120px;display:flex;align-items:center;justify-content:center;transition:opacity 0.5s ease;}
.carousel-attribution{margin-top:1.8rem;font-family:var(--sans);font-size:0.8rem;font-weight:500;letter-spacing:0.08em;color:var(--gold-bright);text-transform:uppercase;}
.carousel-title{font-family:var(--sans);font-size:0.72rem;color:rgba(255,255,255,0.45);letter-spacing:0.05em;margin-top:0.3rem;}
.carousel-dots{display:flex;justify-content:center;gap:0.6rem;margin-top:2.2rem;}
.carousel-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.22);border:none;cursor:pointer;transition:background 0.25s,transform 0.2s;padding:0;}
.carousel-dot.active{background:var(--gold-bright);transform:scale(1.25);}
.carousel-nav{display:flex;justify-content:center;gap:1rem;margin-top:1.5rem;}
.carousel-btn{background:none;border:1px solid rgba(255,255,255,0.2);color:rgba(255,255,255,0.5);width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:1rem;transition:border-color 0.2s,color 0.2s;display:flex;align-items:center;justify-content:center;}
.carousel-btn:hover{border-color:var(--gold-bright);color:var(--gold-bright);}
.carousel-placeholder-note{margin-top:2rem;font-family:var(--sans);font-size:0.68rem;color:rgba(255,255,255,0.2);letter-spacing:0.06em;font-style:italic;}

/* FOR YOU */
.for-you{background:var(--purple-deep);padding:6rem 2rem;}
.for-you h2{font-family:var(--serif);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:400;color:var(--white);line-height:1.2;margin-bottom:1rem;}
.for-you h2 em{font-style:italic;color:var(--gold-bright);}
.for-you-intro{font-size:1.15rem;color:rgba(255,255,255,0.92);max-width:620px;margin-bottom:3rem;line-height:1.75;}
.reader-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2px;margin-bottom:3.5rem;}
.reader-card{padding:2rem 1.8rem;background:rgba(255,255,255,0.05);border:1px solid rgba(196,174,216,0.12);transition:background 0.25s;}
.reader-card:hover{background:rgba(255,255,255,0.09);}
.reader-icon{font-size:1.5rem;margin-bottom:1rem;display:block;}
.reader-card h3{font-family:var(--serif);font-size:1.1rem;font-weight:500;color:var(--white);margin-bottom:0.5rem;line-height:1.3;}
.reader-card p{font-size:0.97rem;color:rgba(255,255,255,0.88);line-height:1.7;}
.for-you-close{font-family:var(--serif);font-size:clamp(1.1rem,2.5vw,1.4rem);font-style:italic;color:#fff;max-width:640px;line-height:1.65;padding-top:1rem;border-top:1px solid rgba(196,174,216,0.15);}

/* ABOUT */
.about-book{background:var(--parchment);padding:6rem 2rem;}
.about-book h2{font-family:var(--serif);font-size:clamp(1.8rem,4vw,2.6rem);font-weight:400;color:var(--ink);line-height:1.2;margin-bottom:2rem;}
.about-book h2 em{font-style:italic;color:var(--purple-mid);}
.about-body{font-size:1.18rem;color:var(--ink);line-height:1.8;max-width:680px;margin-bottom:1.5rem;}
.about-body strong{color:var(--ink);font-weight:500;}
.about-pull{margin:3rem 0;padding:2rem 2.5rem;background:var(--lavender-pale);border-left:4px solid var(--purple-mid);font-family:var(--serif);font-size:clamp(1.15rem,2.5vw,1.45rem);font-style:italic;color:var(--purple-deep);line-height:1.6;max-width:680px;}
.themes-list{margin:2.5rem 0 0;display:flex;flex-wrap:wrap;gap:0.6rem;max-width:680px;}
.theme-pill{display:inline-block;font-family:var(--sans);font-size:0.75rem;font-weight:500;letter-spacing:0.08em;color:var(--purple-mid);background:var(--lavender-pale);border:1px solid rgba(155,114,187,0.3);padding:0.4rem 1rem;border-radius:20px;}

/* INSIDE */
.inside-book{background:var(--cream);padding:6rem 2rem;}
.inside-book h2{font-family:var(--serif);font-size:clamp(1.8rem,4vw,2.6rem);font-weight:400;color:var(--ink);line-height:1.2;margin-bottom:0.8rem;}
.inside-intro{font-size:1.1rem;color:var(--ink-light);max-width:580px;margin-bottom:3rem;line-height:1.7;}
.parts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;margin-bottom:3rem;}
.part-card{padding:2.2rem 2rem;border:1px solid rgba(155,114,187,0.2);background:var(--parchment);}
.part-number{font-family:var(--sans);font-size:0.65rem;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);margin-bottom:0.6rem;}
.part-card h3{font-family:var(--serif);font-size:1.2rem;font-weight:500;color:var(--purple-deep);margin-bottom:0.6rem;font-style:italic;}
.part-card p{font-size:0.97rem;color:var(--ink-mid);line-height:1.7;}
.authors-note{padding:2rem 2.5rem;background:var(--purple-deep);display:flex;align-items:center;gap:2rem;flex-wrap:wrap;}
.authors-note p{font-family:var(--body);font-size:1.05rem;color:rgba(255,255,255,0.92);line-height:1.7;flex:1;min-width:220px;}
.authors-note p strong{color:var(--gold-bright);font-style:italic;font-weight:400;}

/* READER CONTEXT */
.reader-context{background:var(--purple-mid);padding:4rem 2rem;text-align:center;}
.reader-context p{font-family:var(--body);font-size:1.1rem;color:rgba(255,255,255,0.92);line-height:1.7;max-width:640px;margin:0 auto;}
.reader-context p strong{color:var(--white);font-weight:400;font-style:italic;}

/* PREORDER CTA */
.preorder-cta{background-image:url(/img/hero-bg.png);background-size:cover;background-position:center top;padding:7rem 2rem;text-align:center;position:relative;overflow:hidden;}
.preorder-cta::after{content:"";position:absolute;inset:0;background:rgba(60,21,96,0.08);pointer-events:none;}
.preorder-cta-inner{position:relative;z-index:1;max-width:640px;margin:0 auto;}
.preorder-cta h2{font-family:var(--serif);font-size:clamp(2rem,5vw,3.5rem);font-weight:400;color:var(--purple-deep);line-height:1.15;margin-bottom:1rem;text-shadow:0 1px 0 rgba(255,255,255,0.3);}
.preorder-cta h2 em{font-style:italic;}
.preorder-cta p{font-family:var(--body);font-size:1.2rem;color:var(--ink-mid);margin-bottom:2.8rem;line-height:1.65;background:rgba(255,255,255,0.5);padding:0.8rem 1.2rem;display:inline-block;}
.preorder-formats{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:1.5rem;}
.format-tag{font-family:var(--sans);font-size:0.72rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;color:var(--purple-deep);background:rgba(255,255,255,0.7);padding:0.4rem 1rem;border:1px solid rgba(60,21,96,0.15);}
.preorder-note{margin-top:1.2rem;font-family:var(--sans);font-size:0.74rem;color:var(--ink-mid);letter-spacing:0.06em;}

/* FOOTER */
.home-newsletter{background:var(--lavender-mid);}
.footer-community{background:var(--purple-deep);padding:5rem 2rem;text-align:center;}
.footer-community h2{font-family:var(--serif);font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:400;color:var(--white);line-height:1.25;margin-bottom:0.8rem;}
.footer-community h2 em{font-style:italic;color:var(--gold-bright);}
.footer-community>p{font-family:var(--body);font-size:1.1rem;color:rgba(255,255,255,0.92);max-width:480px;margin:0 auto 2.5rem;line-height:1.65;}
.community-form{display:flex;max-width:460px;margin:0 auto 1rem;flex-wrap:wrap;justify-content:center;}
.community-form input{flex:1;min-width:180px;padding:0.95rem 1.2rem;font-family:var(--body);font-size:1rem;color:var(--white);background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.2);border-right:none;outline:none;transition:background 0.2s;}
.community-form input::placeholder{color:rgba(255,255,255,0.4);}
.community-form input:focus{background:rgba(255,255,255,0.18);}
.community-form button{font-family:var(--sans);font-size:0.75rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--purple-deep);background:var(--gold-bright);border:none;padding:0.95rem 1.8rem;cursor:pointer;transition:background 0.2s;white-space:nowrap;}
.community-form button:hover{background:var(--gold);}
.footer-form-note{font-family:var(--sans);font-size:0.72rem;color:rgba(255,255,255,0.35);letter-spacing:0.05em;}
.footer-bottom{background:var(--lavender-mid);padding:1.8rem 2rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;}
.footer-logo{font-family:var(--serif);font-size:0.95rem;font-style:italic;color:var(--purple-deep);text-decoration:none;}
.footer-links{display:flex;gap:2rem;flex-wrap:wrap;}
.footer-links a{font-family:var(--sans);font-size:0.72rem;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;color:var(--purple-deep);text-decoration:none;opacity:0.65;transition:opacity 0.2s;}
.footer-links a:hover{opacity:1;}
.footer-copy{font-family:var(--sans);font-size:0.72rem;color:var(--purple-deep);opacity:0.5;letter-spacing:0.05em;}

@media(max-width:800px){
  .hero-inner{grid-template-columns:1fr;gap:2.5rem;text-align:center;}
  .hero-cover{max-width:240px;}
  .hero-tagline{margin:0 auto 2.5rem;}
  .hero-book{order:-1;}
  .btn-preorder{width:100%;justify-content:center;}
}
@media(max-width:600px){
  .hero,.preorder-cta,.for-you,.about-book,.inside-book{padding:4rem 1.5rem;}
  .testimonials-carousel{padding:4rem 1.5rem;}
  .footer-community{padding:4rem 1.5rem;}
  .community-form{flex-direction:column;}
  .community-form input{border-right:1px solid rgba(255,255,255,0.2);border-bottom:none;}
  .community-form button{width:100%;}
  .footer-bottom{flex-direction:column;text-align:center;}
  .footer-links{justify-content:center;}
  .authors-note{flex-direction:column;gap:1rem;}
}

/* ═══ PRE-ORDER BONUS ═══════════════════════════════════════════════ */
.preorder-bonus{background:var(--lavender-pale);padding:6rem 2rem;}
.bonus-wrap{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;max-width:960px;margin:0 auto;}
.bonus-text h2{font-family:var(--serif);font-size:clamp(1.8rem,4vw,2.6rem);font-weight:400;color:var(--purple-deep);line-height:1.2;margin-bottom:1.2rem;}
.bonus-text h2 em{font-style:italic;}
.bonus-body{font-size:1.05rem;color:var(--ink);line-height:1.8;margin-bottom:1rem;max-width:420px;}
.bonus-steps{margin-top:1.8rem;display:flex;flex-direction:column;gap:1rem;}
.bonus-step{display:flex;align-items:flex-start;gap:1rem;}
.bonus-step-num{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:var(--purple-mid);color:var(--white);font-family:var(--sans);font-size:0.72rem;font-weight:600;display:flex;align-items:center;justify-content:center;}
.bonus-step-text{font-family:var(--body);font-size:1rem;color:var(--ink-mid);line-height:1.6;padding-top:0.1rem;}
.bonus-step-text em{font-style:italic;color:var(--purple-mid);}
.bonus-actions{display:flex;flex-direction:column;gap:0.8rem;padding-top:0.5rem;}
.btn-bonus{display:flex;align-items:center;justify-content:center;gap:0.5rem;font-family:var(--sans);font-size:0.78rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;padding:1rem 1.8rem;border-radius:2px;cursor:pointer;text-decoration:none;transition:all 0.2s;text-align:center;}
.btn-bonus--primary{color:var(--purple-deep);background:var(--gold-bright);box-shadow:0 4px 16px rgba(232,168,32,0.3);}
.btn-bonus--primary:hover{background:var(--gold);transform:translateY(-1px);}
.btn-bonus--secondary{color:var(--white);background:var(--purple-mid);}
.btn-bonus--secondary:hover{background:var(--purple-deep);}
.btn-bonus--ghost{color:var(--purple-mid);background:transparent;border:1px solid rgba(92,42,144,0.3);}
.btn-bonus--ghost:hover{background:rgba(92,42,144,0.06);border-color:var(--purple-mid);}
.bonus-post-launch{margin-top:0.4rem;}
.bonus-post-note{font-family:var(--sans);font-size:0.72rem;color:var(--ink-light);margin-bottom:0.6rem;letter-spacing:0.04em;}
.bonus-note{font-family:var(--sans);font-size:0.7rem;color:var(--ink-light);letter-spacing:0.04em;margin-top:0.4rem;text-align:center;}
/* Short version — home page */
.preorder-bonus-sm{background:var(--lavender-pale);padding:5rem 2rem;}
.bonus-sm-headline{font-family:var(--serif);font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:400;color:var(--purple-deep);line-height:1.2;margin-bottom:1rem;}
.bonus-sm-headline em{font-style:italic;}
.bonus-sm-body{font-size:1.05rem;color:var(--ink);max-width:520px;margin:0 auto 2rem;line-height:1.75;}
.bonus-sm-btns{display:flex;flex-direction:column;gap:0.7rem;max-width:360px;margin:0 auto;}
@media(max-width:700px){
  .bonus-wrap{grid-template-columns:1fr;gap:2.5rem;}
  .preorder-bonus{padding:4rem 1.5rem;}
}
