/* ============================================================
   AVOX COMMUNITY — 108 Days
   Editorial · soft ritual · quiet transformation
   ============================================================ */

:root{
  /* Palette — drawn only from the AVOX logo */
  --cream:        #FBF8F2;
  --cream-warm:   #F4EEE3;
  --cream-deep:   #F2EBDD;
  --paper:        #FDFBF7;

  --forest:       #203A29;
  --forest-deep:  #15291C;

  --terracotta:   #C06A3D;
  --terracotta-2: #B25E32;

  --lavender:     #C5B2D2;
  --lavender-bg:  #E6DCE7;

  --plum:         #43273F;
  --plum-deep:    #361F33;

  --ink:          #2B2823;
  --muted:        #756E61;
  --muted-soft:   #908877;
  --hair:         rgba(43,40,35,.12);
  --hair-soft:    rgba(43,40,35,.08);

  --serif: "Playfair Display", Georgia, "Times New Roman", serif;
  --sans:  "Inter", system-ui, -apple-system, sans-serif;
  --mono:  "Geist Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --shell: 1200px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
html{
  scroll-behavior:smooth; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  /* overflow-x on html (not body) is the reliable way to prevent horizontal
     scroll while keeping section backgrounds full-width on mobile. */
  overflow-x:hidden;
  width:100%;
}
body{
  margin:0;
  width:100%;
  font-family:var(--sans);
  background:var(--cream);
  color:var(--ink);
  font-size:16px;
  line-height:1.65;
  font-weight:400;
}
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }

.shell{
  width:100%;
  max-width:var(--shell);
  margin:0 auto;
  padding-inline:clamp(1.4rem, 5vw, 4rem);
}

/* ---------- Shared type helpers ---------- */
.eyebrow{
  display:flex;
  align-items:center;
  gap:.85rem;
  font-family:var(--sans);
  font-size:.72rem;
  font-weight:500;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--terracotta);
  margin:0 0 1.4rem;
}
.eyebrow.center{ justify-content:center; }

.section-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(2.2rem, 4vw, 3.2rem);
  line-height:1.08;
  letter-spacing:-.01em;
  color:var(--forest);
  margin:0;
}
.section-title em{ font-style:italic; font-weight:400; }
.section-title.sm{ font-size:clamp(1.9rem, 3vw, 2.5rem); }

.lead{
  font-size:1.12rem;
  color:var(--ink);
  line-height:1.6;
  max-width:30ch;
}
.body{
  font-size:1rem;
  color:var(--muted);
  font-weight:400;
  line-height:1.75;
  max-width:42ch;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-family:var(--sans);
  font-size:.92rem;
  font-weight:500;
  letter-spacing:.01em;
  padding:.95rem 1.9rem;
  border-radius:40px;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .4s var(--ease), background-color .4s var(--ease), box-shadow .4s var(--ease);
}
.btn-forest{ background:var(--forest); color:var(--cream); }
.btn-forest:hover{ background:var(--forest-deep); transform:translateY(-2px); }
.btn-terracotta{
  background:var(--terracotta); color:#fdf4ea;
  box-shadow:0 10px 30px -16px rgba(176,94,50,.7);
}
.btn-terracotta:hover{ background:var(--terracotta-2); transform:translateY(-2px); }

.btn-text{
  display:inline-flex; align-items:center; gap:.5rem;
  font-size:.95rem; font-weight:500; color:var(--ink);
  transition:gap .35s var(--ease), color .35s var(--ease);
}
.btn-text .chev,.btn-text .arrow{ width:18px; height:18px; fill:none; stroke:currentColor; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; transition:transform .35s var(--ease); }
.btn-text:hover{ gap:.8rem; color:var(--terracotta); }
.btn-text.dark{ color:var(--forest); }
.btn-text.dark:hover{ color:var(--terracotta); }
.btn-text.dark:hover .arrow{ transform:translateX(4px); }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(251,248,242,.82);
  backdrop-filter:saturate(120%) blur(10px);
  border-bottom:1px solid transparent;
  transition:border-color .4s var(--ease), background-color .4s var(--ease);
}
.site-header.scrolled{ border-color:var(--hair-soft); }
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:2rem; min-height:84px;
}

/* Brand mark */
.brand{ display:flex; align-items:center; }
.brand-logo{ height:60px; width:auto; display:block; }

.nav{ display:flex; gap:2rem; }
.nav a{
  font-size:.88rem; color:var(--ink); position:relative; padding-block:.3rem;
  transition:color .35s var(--ease);
}
.nav a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0;
  background:var(--terracotta); transition:width .4s var(--ease);
}
.nav a:hover{ color:var(--terracotta); }
.nav a:hover::after{ width:100%; }

.nav-cta{ flex:none; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ padding-top:clamp(2.5rem, 6vw, 5rem); padding-bottom:clamp(3rem, 7vw, 6rem); overflow:hidden; }
.hero-grid{
  display:grid; grid-template-columns:1.02fr 1.1fr;
  gap:clamp(2rem, 5vw, 5rem); align-items:center;
}
/* min-width:0 prevents grid items from overflowing their track */
.hero-copy{ padding-block:1rem; min-width:0; }
.hero-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(2.2rem, 4vw, 3.6rem);
  line-height:1.08;
  letter-spacing:-.018em;
  color:var(--forest);
  margin:0;
  text-wrap:balance;
  max-width:100%;
  word-break:break-word;
  overflow-wrap:break-word;
}
.hero-title em{ font-style:italic; font-weight:400; }
.rule{ display:block; width:54px; height:2px; background:var(--terracotta); margin:2rem 0 1.8rem; }
.hero-copy .lead{ margin:0 0 1.5rem; }
.hero-copy .body{ margin:0 0 2.4rem; }
.hero-actions{ display:flex; align-items:center; gap:1.8rem; flex-wrap:wrap; }
.hero-avail{
  display:flex; align-items:center; gap:.65rem;
  margin:2rem 0 0; font-size:.82rem; letter-spacing:.03em; color:var(--muted);
}
.avail-dot{
  width:8px; height:8px; border-radius:50%; background:var(--terracotta); flex:none;
  animation:availPulse 3.2s ease-in-out infinite;
}
@keyframes availPulse{
  0%,100%{ box-shadow:0 0 0 0 rgba(192,106,61,.22); }
  50%{ box-shadow:0 0 0 6px rgba(192,106,61,0); }
}

/* Hero media composition — a clean, contained circular photo.
   max-width keeps it tasteful on wide screens; it never bleeds. */
.hero-media{
  position:relative;
  aspect-ratio:1/1;
  min-width:0;
  width:100%;
  max-width:460px;
  margin-inline:auto;
}
.scene{
  margin:0;
  position:absolute; inset:0;
  border-radius:50%;
  overflow:hidden;
  box-shadow:0 34px 70px -34px rgba(43,40,35,.5);
}
/* Subtle edge definition + gentle bottom vignette for depth.
   Deliberately NOT trying to blend into the page background. */
.scene::after{
  content:'';
  position:absolute; inset:0; border-radius:50%;
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.28),
    inset 0 -40px 70px -40px rgba(21,41,28,.45);
  pointer-events:none;
}
.hero-photo{
  width:100%; height:100%;
  object-fit:cover;
  object-position:center 58%;
  display:block;
}

/* ============================================================
   EXPERIENCE / WHAT THIS IS
   ============================================================ */
.experience{
  background:var(--cream-deep);
  padding-block:clamp(2.8rem, 6vw, 4rem);
  text-align:center;
}

.anchors{
  display:flex; align-items:center; justify-content:center;
  gap:clamp(1.6rem, 5vw, 4rem);
  margin-top:0;
  flex-wrap:wrap;
}
.anchor{ display:flex; flex-direction:column; align-items:center; }
.anchor-num{ font-family:var(--serif); font-weight:400; font-size:clamp(2.4rem,5vw,3.4rem); color:var(--forest); line-height:1; }
.anchor-label{ font-family:var(--sans); font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin-top:.7rem; }
.anchor-orb{ width:10px; height:10px; border-radius:50%; border:1.4px solid var(--terracotta); }

/* ============================================================
   INSIDE THE COMMUNITY
   ============================================================ */
.inside{ padding-block:clamp(5rem, 11vw, 9rem); }
.inside-grid{
  display:grid; grid-template-columns:.9fr 1.55fr; gap:clamp(2.5rem, 6vw, 5rem);
  align-items:start;
}
.inside-head{ position:relative; }
.inside-head .leaf{ width:150px; height:auto; color:#bda77f; margin-top:3.2rem; opacity:.85; }

.feature-grid{
  display:grid; grid-template-columns:repeat(3,1fr);
  column-gap:clamp(1.8rem, 3.5vw, 3.4rem);
  row-gap:0;
}
.feature{
  text-align:left;
  padding:clamp(1.6rem, 2.6vw, 2.2rem) 0;
  border-top:1px solid var(--hair-soft);
}
.f-icon{
  display:block; color:var(--terracotta); margin-bottom:1.1rem;
  transition:transform .45s var(--ease);
}
.f-icon svg{ width:26px; height:26px; }
.feature:hover .f-icon{ transform:translateY(-2px); }
.feature h3{
  font-family:var(--serif); font-weight:500; font-size:1.18rem;
  line-height:1.25; color:var(--forest); margin:0 0 .5rem; letter-spacing:-.005em;
}
.f-desc{
  font-family:var(--sans); font-size:.9rem; font-weight:400;
  line-height:1.6; color:var(--muted); margin:0; max-width:30ch;
}

/* ============================================================
   QUOTE
   ============================================================ */
.quote{
  background:var(--forest-deep);
  color:var(--cream);
  padding-block:clamp(4.5rem, 9vw, 7.5rem);
  position:relative; overflow:hidden;
}
.quote-grid{
  display:grid; grid-template-columns:1.3fr .9fr; gap:3rem; align-items:center;
}
.quote-mark{
  display:block; font-family:var(--serif); font-style:italic;
  font-size:4.5rem; line-height:0; color:var(--terracotta); margin-bottom:2.2rem;
}
.quote blockquote{
  margin:0;
  font-family:var(--serif); font-weight:400; font-style:normal;
  font-size:clamp(1.8rem, 4vw, 3rem); line-height:1.22; letter-spacing:-.01em;
  color:#f3ecdd;
}
.quote-foot{
  margin:2.2rem 0 0;
  font-size:.76rem; letter-spacing:.26em; text-transform:uppercase;
  color:rgba(243,236,221,.62);
}

.quote-atmos{ position:relative; height:230px; }
.candle{ position:absolute; right:6%; top:18%; width:78px; }
.candle .holder{
  display:block; width:78px; height:54px; border-radius:10px 10px 16px 16px;
  background:linear-gradient(180deg,#cdb597 0%,#9c8765 100%);
  box-shadow:0 22px 40px -22px rgba(0,0,0,.6);
}
.candle .flame{
  position:absolute; left:50%; top:-26px; transform:translateX(-50%);
  width:11px; height:24px; border-radius:50% 50% 50% 50%/60% 60% 40% 40%;
  background:linear-gradient(180deg,#f7e2b0,#e08a3c);
  animation:flicker 3.4s ease-in-out infinite;
}
.candle .glow{
  position:absolute; left:50%; top:-46px; transform:translateX(-50%);
  width:150px; height:150px; border-radius:50%;
  background:radial-gradient(circle, rgba(232,160,80,.34) 0%, rgba(232,160,80,0) 62%);
}
@keyframes flicker{ 0%,100%{ transform:translateX(-50%) scaleY(1); opacity:.95; } 50%{ transform:translateX(-50%) scaleY(1.08); opacity:1; } }
.quote-sprig{ position:absolute; left:0; bottom:8%; width:62%; color:rgba(155,178,140,.6); }

/* ============================================================
   BOOK + CIRCLE
   ============================================================ */
.book-circle{ padding-block:clamp(5rem, 11vw, 9rem); }
.bc-grid{
  display:grid;
  grid-template-columns:1fr .82fr 1fr;
  gap:clamp(2.5rem, 5vw, 4.5rem);
  align-items:center;
}
.bc-book{ padding-right:1rem; }
.bc-book .section-title{ margin-bottom:1.4rem; }
.bc-book .body{ margin:0 0 1.8rem; }
.bc-book-cta{ margin-top:1.8rem; }

/* Plum book cover */
.bc-cover{ display:flex; justify-content:center; }
.book-plum{
  /* Definite width (no percentage) — a percentage here is circular against
     a shrink-wrapped flex parent and collapses to 0 on mobile. */
  position:relative; width:min(230px, 64vw); aspect-ratio:1/1.42;
  filter:drop-shadow(0 40px 50px rgba(67,39,63,.35));
}
.book-plum-face{
  position:absolute; inset:0; left:4%;
  background:linear-gradient(120deg,#4c2e47 0%,#3a2236 100%);
  border-radius:4px 8px 8px 4px;
  border-left:4px solid #2f1c2c;
  display:flex; flex-direction:column; align-items:center; padding-top:22%;
}
.book-plum-pages{
  position:absolute; right:0; top:2.5%; height:95%; width:5%;
  background:repeating-linear-gradient(180deg,#efe6d3 0 2px,#dccdb1 2px 3px);
  border-radius:0 4px 4px 0;
}
.sun{ display:flex; align-items:center; justify-content:center; }
.sun svg{ width:100%; height:100%; }
.book-num{ font-family:var(--mono); font-weight:500; font-size:clamp(1.4rem,3vw,2.3rem); letter-spacing:.08em; line-height:1; }
.book-word{ font-family:var(--serif); font-weight:400; font-size:clamp(1.4rem,3vw,2.3rem); letter-spacing:.16em; line-height:1.1; }
.book-tag{ font-family:var(--sans); font-size:.5rem; letter-spacing:.3em; text-align:center; margin-top:14%; line-height:1.8; }
.book-plum .sun{ color:#c98f55; margin-bottom:9%; width:28px; height:28px; }
.book-plum .book-num,.book-plum .book-word{ color:#cda36f; }
.book-plum .book-tag{ color:rgba(205,163,111,.8); }
.plum-sun{ width:28px; height:28px; }

/* Seat / circle visualisation */
.bc-circle .section-title{ margin-bottom:1.4rem; }
.bc-circle .body{ margin:0 0 2.2rem; }
.seats{ position:relative; width:200px; height:200px; margin:0 0 1.6rem; }
.seat-ring{ position:absolute; inset:0; }
.seat-ring .seat{ position:absolute; width:13px; height:13px; border-radius:50%; transform:translate(-50%,-50%); }
.seat.taken{ background:var(--terracotta); }
.seat.open{ background:transparent; border:1.5px solid rgba(43,40,35,.32); }
.seat-center{
  position:absolute; inset:0; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center;
}
.seat-num{ font-family:var(--serif); font-weight:400; font-size:2.4rem; color:var(--forest); line-height:1; }
.seat-label{ font-family:var(--sans); font-size:.66rem; letter-spacing:.26em; text-transform:uppercase; color:var(--muted); margin-top:.3rem; }

.legend{ display:flex; gap:1.6rem; margin-bottom:2rem; }
.leg{ display:flex; align-items:center; gap:.5rem; font-size:.82rem; color:var(--muted); }
.leg-dot{ width:11px; height:11px; border-radius:50%; }
.leg-dot.taken{ background:var(--terracotta); }
.leg-dot.open{ border:1.5px solid rgba(43,40,35,.32); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:var(--lavender-bg); padding-top:clamp(3.5rem, 7vw, 5.5rem); }
.footer-cols{
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:clamp(1.8rem, 4vw, 3.5rem);
  padding-bottom:clamp(3rem, 6vw, 4.5rem);
}
.fcol{ position:relative; padding-left:1.6rem; display:flex; flex-direction:column; }
.fcol::before{ content:""; position:absolute; left:0; top:.2rem; bottom:.2rem; width:1px; background:rgba(67,39,63,.16); }
.fcol-icon{ display:block; color:var(--plum); margin-bottom:1rem; }
.fcol-icon svg{ width:24px; height:24px; }
.fcol-title{ font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--plum); font-weight:600; margin:0 0 .8rem; }
.fcol-text{ font-size:.92rem; color:#5f5560; line-height:1.6; margin:0 0 1.1rem; }
/* margin-top:auto pushes every column's link to the same bottom baseline */
.fcol-link{ font-size:.9rem; font-weight:500; color:var(--terracotta); transition:opacity .3s var(--ease); margin-top:auto; align-self:flex-start; }
.fcol-link:hover{ opacity:.7; }

.footer-bottom{
  display:flex; align-items:center; justify-content:space-between; gap:1.5rem; flex-wrap:wrap;
  border-top:1px solid rgba(67,39,63,.14);
  padding-block:1.6rem;
}
.brand-logo-sm{ height:38px; }
.copy{ font-size:.84rem; color:#6b6168; margin:0; }
.legal{ display:flex; gap:1.6rem; margin:0; }
.legal a{ font-size:.84rem; color:#6b6168; transition:color .3s var(--ease); }
.legal a:hover{ color:var(--plum); }

/* Footer social row */
.footer-social{ display:flex; gap:1.4rem; align-items:center; flex-wrap:wrap; }
.social-link{
  display:flex; align-items:center; gap:.45rem;
  font-size:.8rem; font-weight:500; color:var(--plum);
  opacity:.62; transition:opacity .3s var(--ease);
  letter-spacing:.01em;
}
.social-link svg{ width:16px; height:16px; flex:none; }
.social-link:hover{ opacity:1; }

/* ============================================================
   SEATS STRIP
   ============================================================ */
.seats-strip{
  background:var(--cream-deep);
  border-top:1px solid var(--hair-soft);
  border-bottom:1px solid var(--hair-soft);
  padding:clamp(.85rem, 1.6vw, 1.15rem) clamp(1.4rem, 5vw, 4rem);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1.5rem;
}
.seats-strip-label{
  font-family:var(--serif);
  font-weight:400;
  font-style:italic;
  font-size:1rem;
  color:var(--ink);
  letter-spacing:0;
  white-space:nowrap;
}
.strip-dots{ display:flex; gap:8px; flex-wrap:wrap; justify-content:center; }
.strip-dot{ width:9px; height:9px; border-radius:50%; flex-shrink:0; }
.strip-dot.taken{ background:var(--terracotta); }
.strip-dot.open{ background:transparent; border:1px solid rgba(43,40,35,.28); }
.seats-strip-count{
  font-family:var(--mono);
  font-size:.78rem;
  font-weight:500;
  color:var(--terracotta);
  letter-spacing:.02em;
  white-space:nowrap;
}

/* ============================================================
   BOOK — 2-col layout
   ============================================================ */
.bc-grid-2{
  display:grid;
  grid-template-columns:.72fr 1fr;
  gap:clamp(3rem, 6vw, 5.5rem);
  align-items:center;
}
.bc-grid-2 .bc-cover{ display:flex; justify-content:center; }
.bc-book .section-title{ margin-bottom:1.2rem; }
.bc-book .body{ margin:0; }

.detail-list{ list-style:none; padding:0; margin:1.6rem 0 0; }
.detail-list li{
  display:flex;
  gap:.8rem;
  align-items:baseline;
  padding:.7rem 0;
  border-bottom:1px solid var(--hair-soft);
  font-size:.93rem;
  color:var(--muted);
  line-height:1.65;
}
.detail-list li::before{ content:"—"; color:var(--terracotta); flex-shrink:0; font-family:var(--serif); }

/* ============================================================
   JOURNEY STEPS
   ============================================================ */
.journey{
  background:var(--cream-warm);
  padding-block:clamp(5rem, 11vw, 9rem);
}
.journey-head{ max-width:32ch; margin-bottom:clamp(2.5rem, 5vw, 4rem); }
.journey-head .section-title{ margin-top:.4rem; }

.journey-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  column-gap:clamp(1.8rem, 3.5vw, 3.4rem);
  row-gap:0;
}
.step{
  padding:clamp(1.8rem, 3vw, 2.4rem) 0 0;
  border-top:1px solid var(--hair-soft);
}
.step-num-tag{
  display:inline-flex; align-items:center; gap:.7rem;
  font-family:var(--sans);
  font-size:.7rem; font-weight:500;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--terracotta);
  margin:0 0 1.1rem;
}
.step-num-tag::after{
  content:""; display:block; width:24px; height:1px; background:currentColor; opacity:.55;
}
.step-h{
  font-family:var(--serif);
  font-weight:500;
  font-size:1.22rem;
  line-height:1.25;
  color:var(--forest);
  margin:0 0 .65rem;
  letter-spacing:-.005em;
}
.step-desc{
  font-family:var(--sans);
  font-size:.92rem;
  color:var(--muted);
  line-height:1.7;
  margin:0 0 .8rem;
  max-width:30ch;
}
.step-note{
  font-family:var(--sans);
  font-size:.74rem;
  color:var(--terracotta);
  letter-spacing:.04em;
  margin:0;
}

/* ============================================================
   FOR WHOM
   ============================================================ */
.for-section{ padding-block:clamp(5rem, 11vw, 9rem); }
.for-head{ max-width:32ch; margin-bottom:clamp(2.5rem, 5vw, 4rem); }
.for-head .section-title{ margin-top:.4rem; }

.for-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  column-gap:clamp(2.5rem, 5vw, 4.5rem);
  row-gap:0;
}
.for-item{
  display:flex;
  gap:1rem;
  align-items:flex-start;
  padding:clamp(1.6rem, 2.6vw, 2.2rem) 0;
  border-top:1px solid var(--hair-soft);
}
.for-item .for-mark{
  flex:none;
  font-family:var(--serif);
  font-size:1.1rem;
  font-weight:400;
  font-style:italic;
  color:var(--terracotta);
  line-height:1;
  margin-top:.2rem;
}
.for-item p{
  font-family:var(--serif);
  font-weight:400;
  font-size:1.08rem;
  line-height:1.5;
  color:var(--ink);
  margin:0;
  max-width:34ch;
  letter-spacing:-.003em;
}

/* ============================================================
   COLLABORATORS
   ============================================================ */
.collab{ background:var(--cream-deep); padding-block:clamp(5rem, 11vw, 9rem); }
.collab-head{ max-width:32ch; margin-bottom:clamp(2.5rem, 5vw, 4rem); }
.collab-head .section-title{ margin-top:.4rem; }
.collab-head .body{ margin-top:1.4rem; }

.collab-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(1.4rem, 2.8vw, 2.2rem);
}
.collab-card{
  background:rgba(253,251,247,.55);
  border:none;
  border-radius:6px;
  padding:clamp(1.8rem, 3vw, 2.4rem);
  transition:background .5s var(--ease), transform .5s var(--ease);
}
.collab-card:hover{ background:var(--cream); transform:translateY(-3px); }
.collab-name{
  font-family:var(--serif); font-weight:500;
  font-size:1.16rem; line-height:1.3;
  color:var(--forest); margin:0 0 .3rem;
}
.collab-role{
  font-family:var(--sans); font-size:.7rem; font-weight:500;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--muted-soft); margin:0 0 1.1rem;
}
.collab-desc{
  font-family:var(--sans); font-size:.9rem;
  color:var(--muted); line-height:1.7;
  margin:0 0 1.3rem;
}
.collab-link{
  font-family:var(--sans); font-size:.88rem; font-weight:500;
  color:var(--terracotta);
  transition:gap .35s var(--ease), opacity .3s var(--ease);
}
.collab-link:hover{ opacity:.75; }

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band{
  background:var(--cream);
  padding-block:clamp(5.5rem, 12vw, 9rem);
  text-align:center;
}
.cta-inner{ max-width:580px; margin-inline:auto; }
.cta-h{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(2rem, 4.2vw, 3rem);
  line-height:1.12;
  letter-spacing:-.01em;
  color:var(--forest);
  margin:0 0 .8rem;
}
.cta-h em{ font-style:italic; font-weight:400; }
.cta-sub{ font-family:var(--sans); font-size:1rem; color:var(--muted); margin:0 0 .5rem; }
.cta-note{
  font-family:var(--sans);
  font-size:.74rem;
  color:var(--terracotta);
  letter-spacing:.22em;
  text-transform:uppercase;
  margin:0 0 2.6rem;
}
.cta-actions{
  display:flex; align-items:center; gap:1.8rem;
  justify-content:center; flex-wrap:wrap;
}

/* ============================================================
   ABOUT
   ============================================================ */
.about{ padding-block:clamp(5rem, 11vw, 9rem); background:var(--cream); }
.about-grid{
  display:grid; grid-template-columns:1fr 1.3fr;
  gap:clamp(3rem, 7vw, 6rem); align-items:start;
}
.about-head .section-title{ margin-top:.4rem; }
.about-body-2{ margin-top:1.4rem; }
.about-body-2 em{ font-style:italic; }
.about-book-link{ margin-top:2rem; }

/* ============================================================
   VISION
   ============================================================ */
.vision{ background:var(--cream-warm); padding-block:clamp(5rem, 11vw, 9rem); }
.vision-head{ max-width:32ch; margin-bottom:clamp(2.5rem, 5vw, 4rem); }
.vision-head .section-title{ margin-top:.4rem; }
.vision-grid{
  display:grid; grid-template-columns:repeat(3,1fr);
  column-gap:clamp(1.8rem, 3.5vw, 3.4rem); row-gap:0;
}
.vision-item{
  padding:clamp(1.8rem, 3vw, 2.4rem) 0 0;
  border-top:1px solid var(--hair-soft);
}
.vision-num{
  display:inline-flex; align-items:center; gap:.7rem;
  font-family:var(--sans); font-size:.7rem; font-weight:500;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--terracotta); margin:0 0 1.1rem;
}
.vision-num::after{ content:""; display:block; width:24px; height:1px; background:currentColor; opacity:.55; }
.vision-h{
  font-family:var(--serif); font-weight:500; font-size:1.22rem;
  line-height:1.25; color:var(--forest); margin:0 0 .65rem; letter-spacing:-.005em;
}
.vision-desc{
  font-family:var(--sans); font-size:.92rem; color:var(--muted);
  line-height:1.7; margin:0; max-width:30ch;
}

/* ============================================================
   SESSIONS
   ============================================================ */
.sessions{ background:var(--cream-deep); padding-block:clamp(5rem, 11vw, 9rem); }
.sessions-head{ max-width:38ch; margin-bottom:clamp(2.5rem, 5vw, 4rem); }
.sessions-head .section-title{ margin-top:.4rem; }
.sessions-head .body{ margin-top:1.2rem; max-width:46ch; }

.sessions-widget{
  border-radius:10px; overflow:hidden;
  border:1px solid var(--hair);
  margin-bottom:2.8rem;
  background:var(--paper);
}
.sessions-placeholder{
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:.9rem; padding:clamp(3rem, 7vw, 5rem);
  text-align:center; color:var(--muted);
}
.sessions-cal-icon{ color:var(--terracotta); }
.sessions-cal-icon svg{ width:36px; height:36px; }
.sessions-placeholder strong{
  font-family:var(--serif); font-weight:400; font-size:1.22rem;
  color:var(--forest); display:block; letter-spacing:-.005em;
}
.sessions-placeholder p{
  font-size:.92rem; line-height:1.6; margin:0; color:var(--muted);
}
.luma-iframe{ display:block; width:100%; height:520px; border:none; }

.sessions-access{ display:flex; align-items:center; gap:2.4rem; flex-wrap:wrap; }
.sessions-note{
  font-size:.86rem; color:var(--muted); max-width:38ch; line-height:1.65; margin:0;
}

/* ============================================================
   LISTEN & WATCH
   ============================================================ */
.listen{ padding-block:clamp(5rem, 11vw, 9rem); background:var(--cream); }
.listen-head{ max-width:32ch; margin-bottom:clamp(2.5rem, 5vw, 4rem); }
.listen-head .section-title{ margin-top:.4rem; }
.listen-grid{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:clamp(1.2rem, 2.5vw, 2rem);
}
.listen-card{
  display:flex; flex-direction:column; gap:.7rem;
  padding:.4rem 0;
  background:transparent; border:none; border-radius:0;
  transition:transform .4s var(--ease), opacity .4s var(--ease);
  text-decoration:none;
}
.listen-card:hover{ background:transparent; transform:translateY(-3px); }
.listen-icon{ color:var(--terracotta); }
.listen-icon svg{ width:38px; height:38px; }
.listen-platform{
  font-family:var(--sans); font-size:.7rem; font-weight:500;
  letter-spacing:.2em; text-transform:uppercase; color:var(--muted-soft); margin:0;
}
.listen-handle{
  font-family:var(--serif); font-weight:400; font-size:1.16rem;
  color:var(--forest); margin:0; line-height:1.3;
}
.listen-cta{
  display:flex; align-items:center; gap:.4rem;
  font-size:.86rem; font-weight:500; color:var(--terracotta);
  margin-top:auto; padding-top:.4rem;
  transition:gap .3s var(--ease);
}
.listen-card:hover .listen-cta{ gap:.7rem; }
.listen-arrow{ width:16px; height:16px; fill:none; stroke:currentColor; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; }

/* Cards whose URL isn't configured yet — visually softer */
.listen-card.not-configured{ opacity:.55; cursor:default; }
.listen-card.not-configured:hover{ transform:none; }

/* Honeypot — visually hidden but still in tab order skipped */
.hp-field{
  position:absolute !important;
  left:-9999px !important;
  width:1px; height:1px;
  overflow:hidden;
  opacity:0;
  pointer-events:none;
}

/* ============================================================
   SESSIONS LIST (replaces Luma embed)
   ============================================================ */
.sessions-list{
  background:var(--paper);
  border:1px solid var(--hair);
  border-radius:14px;
  padding:clamp(1.6rem, 3vw, 2.2rem);
  max-width:680px;
  margin:0 auto;
}
.sessions-list-head{
  display:flex; flex-wrap:wrap; align-items:center;
  gap:.7rem 1rem; margin-bottom:1.2rem;
  padding-bottom:1rem; border-bottom:1px solid var(--hair-soft);
}
.sessions-list-head .sessions-cal-icon{
  width:24px; height:24px; color:var(--terracotta); flex:none;
}
.sessions-list-head .sessions-cal-icon svg{ width:100%; height:100%; }
.sessions-list-head strong{
  font-family:var(--serif); font-weight:500;
  font-size:1.08rem; color:var(--forest);
}
.sessions-list-sub{
  font-family:var(--sans); font-size:.78rem;
  letter-spacing:.16em; text-transform:uppercase;
  color:var(--muted); margin-left:auto;
}
.sessions-items{
  list-style:none; margin:0; padding:0;
  display:flex; flex-direction:column; gap:.55rem;
  max-height:340px; overflow-y:auto;
}
.sessions-item{
  display:flex; align-items:baseline; gap:.9rem;
  padding:.55rem 0;
  border-bottom:1px dashed var(--hair-soft);
  font-size:.95rem;
}
.sessions-item:last-child{ border-bottom:none; }
.sessions-item-num{
  font-family:var(--mono); font-size:.78rem;
  color:var(--muted-soft); min-width:2.5ch;
}
.sessions-item-date{
  font-family:var(--mono); font-size:.92rem;
  color:var(--forest); flex:none;
}
.sessions-item-title{
  color:var(--ink); flex:1;
  font-size:.92rem;
}
.sessions-item-time{
  font-family:var(--mono); font-size:.82rem;
  color:var(--terracotta); flex:none;
}
.sessions-item.first .sessions-item-title,
.sessions-item.first .sessions-item-date{ font-weight:600; }
.sessions-list-foot{
  margin:1.1rem 0 0; font-size:.78rem; color:var(--muted); line-height:1.55;
}
.js-sessions-loading{ color:var(--muted); border:none; }

/* ============================================================
   REGISTER
   ============================================================ */
.register-section{
  background:var(--cream-deep);
  padding-block:clamp(5rem, 11vw, 9rem);
}
.register-grid{
  display:grid; grid-template-columns:1fr 1.1fr;
  gap:clamp(3rem, 7vw, 6rem); align-items:start;
}
.register-head .section-title{ margin-top:.4rem; }
.register-head .body{ margin-top:1.4rem; }
.register-spots{
  display:flex; align-items:center; gap:.6rem;
  margin:1.8rem 0 0; font-family:var(--mono);
  font-size:.82rem; letter-spacing:.02em; color:var(--terracotta); font-weight:500;
}
.register-spots-dot{
  width:8px; height:8px; border-radius:50%; background:var(--terracotta); flex:none;
}
.register-spots.full{ color:var(--muted); }
.register-spots.full .register-spots-dot{ background:var(--muted); }

.register-form{
  display:flex; flex-direction:column;
  background:var(--paper);
  border:1px solid var(--hair);
  border-radius:14px;
  padding:clamp(1.6rem, 3vw, 2.4rem);
}
.register-form .form-field label{ color:var(--muted); }
.register-form .form-field input{
  font-family:var(--sans); font-size:.96rem; color:var(--ink);
  background:var(--cream); border:1px solid var(--hair);
  border-radius:6px; padding:.85rem 1.1rem; outline:none;
  transition:border-color .35s var(--ease), background .35s var(--ease);
}
.register-form .form-field input::placeholder{ color:var(--muted-soft); }
.register-form .form-field input:focus{
  border-color:var(--terracotta); background:var(--paper);
}
.form-check{
  display:flex; align-items:flex-start; gap:.7rem;
  margin-bottom:1.1rem; cursor:pointer;
}
.form-check input[type="checkbox"]{
  margin-top:.2rem; width:18px; height:18px; flex:none;
  accent-color:var(--terracotta); cursor:pointer;
}
.form-check-text{
  font-size:.92rem; color:var(--ink); line-height:1.55;
}
.form-check-text a{
  display:inline-block; margin-top:.2rem;
  color:var(--terracotta); text-decoration:underline;
  text-underline-offset:3px; text-decoration-thickness:1px;
}
.form-check-text a:hover{ opacity:.75; }
.register-form .btn-terracotta{ align-self:flex-start; margin-top:.6rem; }
.register-form .form-note{
  font-size:.82rem; color:var(--muted); margin:.9rem 0 0; line-height:1.55;
}
.register-form.is-success{
  align-items:flex-start; justify-content:center;
}
.register-msg{
  font-family:var(--serif); font-weight:400; font-size:1.3rem;
  color:var(--forest); line-height:1.4; margin:0;
}
.register-error{
  font-size:.88rem; color:var(--terracotta-2); margin:.6rem 0 0; line-height:1.5;
}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-section{
  background:var(--plum);
  padding-block:clamp(5rem, 11vw, 9rem);
}
.contact-grid{
  display:grid; grid-template-columns:1fr 1.2fr;
  gap:clamp(3rem, 7vw, 6rem); align-items:start;
}
.contact-head .eyebrow{ color:var(--lavender); }
.contact-head .section-title{ color:var(--cream); margin-top:.4rem; }
.contact-head .body{
  color:rgba(251,248,242,.65); margin-top:1.4rem; max-width:38ch;
}
.contact-head .body a{
  color:var(--lavender); text-decoration:underline;
  text-underline-offset:3px; text-decoration-thickness:1px;
}
.contact-head .body a:hover{ opacity:.8; }

.contact-form{ display:flex; flex-direction:column; }
.form-field{ display:flex; flex-direction:column; gap:.5rem; margin-bottom:1.4rem; }
.form-field label{
  font-family:var(--sans); font-size:.72rem; font-weight:500;
  letter-spacing:.16em; text-transform:uppercase; color:rgba(251,248,242,.5);
}
.form-field input,
.form-field textarea{
  font-family:var(--sans); font-size:.96rem; color:var(--cream);
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12);
  border-radius:6px; padding:.85rem 1.1rem;
  transition:border-color .35s var(--ease), background .35s var(--ease);
  outline:none;
}
.form-field textarea{ resize:vertical; line-height:1.6; }
.form-field input::placeholder,
.form-field textarea::placeholder{ color:rgba(251,248,242,.28); }
.form-field input:focus,
.form-field textarea:focus{
  border-color:rgba(197,178,210,.55); background:rgba(255,255,255,.09);
}
.contact-form .btn-terracotta{ align-self:flex-start; margin-top:.4rem; }
.form-note{
  font-size:.8rem; color:rgba(251,248,242,.38); margin:.9rem 0 0; line-height:1.5;
}
.form-note a{ color:var(--lavender); }

/* ============================================================
   HAMBURGER BUTTON
   ============================================================ */
.menu-toggle{
  display:none;
  flex-direction:column; justify-content:center; align-items:center; gap:5px;
  width:40px; height:40px; padding:0;
  background:none; border:none; cursor:pointer;
  border-radius:6px;
  transition:background .3s var(--ease);
  flex:none;
}
.menu-toggle:hover{ background:var(--cream-deep); }
.burger-bar{
  display:block; width:22px; height:1.5px;
  background:var(--forest); border-radius:2px;
  transition:transform .35s var(--ease), opacity .25s var(--ease);
}
.menu-toggle.active .burger-bar:nth-child(1){ transform:translateY(6.5px) rotate(45deg); }
.menu-toggle.active .burger-bar:nth-child(2){ opacity:0; }
.menu-toggle.active .burger-bar:nth-child(3){ transform:translateY(-6.5px) rotate(-45deg); }

/* ============================================================
   MOBILE MENU
   ============================================================ */
.mobile-menu{
  display:none;
  position:fixed; inset:0; z-index:49;
  background:rgba(43,40,35,.18);
  backdrop-filter:blur(2px);
  opacity:0;
  transition:opacity .3s var(--ease);
  pointer-events:none;
}
.mobile-menu.open{
  opacity:1;
  pointer-events:all;
}
.mobile-menu-nav{
  position:absolute;
  top:0; right:0;
  width:min(82vw, 320px);
  height:100%;
  background:var(--cream);
  padding:6rem 2rem 2.4rem;
  display:flex; flex-direction:column; gap:.2rem;
  box-shadow:-8px 0 40px rgba(43,40,35,.12);
  transform:translateX(100%);
  transition:transform .38s var(--ease);
  overflow-y:auto;
}
.mobile-menu.open .mobile-menu-nav{
  transform:translateX(0);
}
.mobile-menu-nav a{
  font-family:var(--sans); font-size:1rem; font-weight:500;
  color:var(--ink); padding:.9rem 0;
  border-bottom:1px solid var(--hair-soft);
  transition:color .25s var(--ease);
}
.mobile-menu-nav a:hover{ color:var(--terracotta); }
.mobile-menu-cta{
  margin-top:1.4rem; align-self:flex-start;
  border:none !important;
}

/* ============================================================
   108 DAYS ACADEMY WORDMARK
   CSS recreation of the screenshot logo lockup.
   Swap for an <img> tag if the official file is provided.
   ============================================================ */
.academy-logo{
  display:flex; flex-direction:column; align-items:flex-start;
  line-height:1; margin-bottom:2rem;
  user-select:none;
}
.academy-logo-main{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(2.2rem, 4vw, 3.4rem);
  color:var(--forest);
  letter-spacing:-.01em;
  line-height:1;
}
.academy-logo-sub{
  font-family:var(--serif);
  font-style:italic;
  font-weight:400;
  font-size:clamp(1.4rem, 2.5vw, 2.1rem);
  color:var(--terracotta);
  letter-spacing:.02em;
  line-height:1.15;
  margin-top:.15em;
}

/* ============================================================
   HOST SECTION
   ============================================================ */
.host-section{
  background:var(--cream-warm);
  padding-block:clamp(5rem, 11vw, 9rem);
}
.host-grid{
  display:grid;
  grid-template-columns:220px 1fr;
  gap:clamp(3rem, 7vw, 6rem);
  align-items:start;
}

/* Photo column */
.host-photo-col{ display:flex; flex-direction:column; align-items:center; }
.host-figure{
  margin:0;
  width:190px; height:190px;
  border-radius:50%;
  overflow:hidden;
  flex:none;
  box-shadow:0 8px 32px -12px rgba(43,40,35,.22);
}
.host-photo{
  width:100%; height:100%;
  object-fit:cover;
  object-position:center top;
  display:block;
  filter:grayscale(1) contrast(1.04);
}
.host-caption{
  display:flex; flex-direction:column; align-items:center;
  text-align:center; margin-top:1.1rem; gap:.25rem;
}
.host-caption-name{
  font-family:var(--serif); font-weight:500; font-size:1.08rem;
  color:var(--forest); letter-spacing:-.005em;
}
.host-caption-role{
  font-family:var(--sans); font-size:.72rem; font-weight:500;
  letter-spacing:.18em; text-transform:uppercase; color:var(--muted-soft);
}

/* Copy column */
.host-intro{
  font-family:var(--serif); font-weight:400; font-style:italic;
  font-size:clamp(1.1rem, 2vw, 1.3rem); line-height:1.5;
  color:var(--forest); margin:0 0 1.4rem; max-width:44ch;
  letter-spacing:-.005em;
}
.host-copy .body{ margin-bottom:2rem; }
.host-actions{ display:flex; align-items:center; gap:1.8rem; flex-wrap:wrap; }
.host-spots{
  font-family:var(--sans); font-size:.82rem; font-weight:500;
  color:var(--terracotta); letter-spacing:.04em; margin:0;
}

/* ============================================================
   REVEAL ANIMATION
   JS adds `js-reveal` to <html> so we only hide elements when JS
   is actually running — prevents a permanently blank page on JS failure.
   ============================================================ */
html.js-reveal .reveal{ opacity:0; transform:translateY(26px); transition:opacity 1s var(--ease), transform 1s var(--ease); }
html.js-reveal .reveal.in{ opacity:1; transform:none; }
/* Fallback when JS is not active */
.reveal{ opacity:1; transform:none; }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){
  html.js-reveal .reveal{ opacity:1; transform:none; transition:none; }
  .candle .flame{ animation:none; }
  .avail-dot{ animation:none; }
  html{ scroll-behavior:auto; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

/* Tablet — collapse the wider multi-column grids first */
@media (max-width:1024px){
  .inside-grid{ grid-template-columns:1fr; gap:clamp(2rem,5vw,3rem); }
  .feature-grid{ grid-template-columns:repeat(2,1fr); }
  .inside-head .leaf{ display:none; }
}

@media (max-width:900px){
  /* Hide desktop nav + CTA; show hamburger */
  .nav{ display:none; }
  .nav-cta{ display:none; }
  .menu-toggle{ display:flex; }
  /* Mobile menu overlay is always in the DOM but hidden by default */
  .mobile-menu{ display:block; }

  .hero-grid{ grid-template-columns:1fr; gap:clamp(2rem,6vw,2.8rem); }
  .hero-title{ max-width:none; }
  .hero-media{ max-width:380px; }
  .quote-grid{ grid-template-columns:1fr; }
  .quote-atmos{ height:180px; order:-1; }
  .footer-cols{ grid-template-columns:1fr 1fr; row-gap:2.6rem; }
  .footer-bottom{ justify-content:flex-start; }
  .footer-social{ width:100%; order:4; padding-top:1rem; border-top:1px solid rgba(67,39,63,.1); }
  .seats-strip{ flex-wrap:wrap; justify-content:center; gap:1rem; }
  .bc-grid-2{ grid-template-columns:1fr; row-gap:clamp(2.5rem,6vw,3.5rem); }
  .journey-grid{ grid-template-columns:1fr; }
  .step{ max-width:46ch; }
  .collab-grid{ grid-template-columns:1fr 1fr; }
  .about-grid{ grid-template-columns:1fr; gap:clamp(2rem,5vw,3rem); }
  .vision-grid{ grid-template-columns:1fr; }
  .vision-item{ max-width:46ch; }
  .listen-grid{ grid-template-columns:1fr 1fr; }
  .register-grid{ grid-template-columns:1fr; gap:clamp(2rem,5vw,3rem); }
  .contact-grid{ grid-template-columns:1fr; }
  .sessions-access{ flex-direction:column; align-items:flex-start; gap:1.4rem; }
  .host-grid{ grid-template-columns:1fr; }
  .host-photo-col{ flex-direction:row; align-items:center; gap:1.8rem; }
  .host-figure{ width:140px; height:140px; flex:none; }
  .host-caption{ align-items:flex-start; text-align:left; }
}

@media (max-width:640px){
  .footer-cols{ grid-template-columns:1fr; }
  .footer-bottom{ flex-direction:column; align-items:flex-start; gap:1rem; }
  .header-inner{ min-height:72px; }
  .brand-logo{ height:48px; }
  /* Feature cards stack one-per-row on phones */
  .feature-grid{ grid-template-columns:1fr; }
  /* Compact, tasteful hero photo — an accent, not a full screen */
  .hero-media{ max-width:clamp(220px, 72vw, 300px); }
  .hero-actions{ gap:1.2rem; }
  .for-grid{ grid-template-columns:1fr; }
  .collab-grid{ grid-template-columns:1fr; }
  .seats-strip-label{ display:none; }
  .listen-grid{ grid-template-columns:1fr; }
  .footer-social{ gap:1rem; }
  .host-photo-col{ flex-direction:column; align-items:center; }
  .host-caption{ align-items:center; text-align:center; }
  .host-actions{ flex-direction:column; align-items:flex-start; gap:1rem; }
}
