
/* ───────────────────────── tokens ───────────────────────── */
:root{
  --paper:#f9f2e3;
  --paper-deep:#f3e9d2;
  --ink:#251f19;
  --ink-soft:rgba(37,31,25,.72);
  --cream:#f6eedd;
  --cream-soft:rgba(246,238,221,.78);
  --night:#131124;
  --night-2:#1d1a33;
  --saffron:#df8a3a;
  --ember:#c96f4a;
  --rose:#ef9168;
  --gold:#f2c178;
  --dusk-a:#4f3b66;
  --dusk-b:#7d4f63;
  --line:rgba(37,31,25,.16);
  --line-dark:rgba(246,238,221,.16);
  --serif:"Instrument Serif", Georgia, serif;
  --sans:"Instrument Sans", -apple-system, "Helvetica Neue", sans-serif;
  --mono:"Spline Sans Mono", "SF Mono", Menlo, monospace;
  --fs-hero:clamp(3.2rem, 10vw, 8rem);
  --fs-h2:clamp(2.3rem, 5.6vw, 4.6rem);
  --fs-h3:clamp(1.35rem, 2.6vw, 1.9rem);
  --ease-breath:cubic-bezier(.37,0,.63,1);
  --ease-out:cubic-bezier(.22,.7,.3,1);
  --pad-x:clamp(1.25rem, 4.5vw, 4rem);
  --pad-y:clamp(4.5rem, 11vw, 9rem);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--sans);
  font-size:1.05rem;
  line-height:1.68;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--saffron);color:var(--night)}
img{max-width:100%;display:block}
a{color:inherit}
h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:1.04;letter-spacing:-.01em}
em{font-style:italic}
.skip-link{
  position:fixed;top:-4rem;left:1rem;z-index:200;padding:.7rem 1.2rem;
  background:var(--ink);color:var(--cream);border-radius:999px;
  font-size:.85rem;text-decoration:none;transition:top .25s var(--ease-out);
}
.skip-link:focus{top:1rem}
:focus-visible{outline:2px solid var(--saffron);outline-offset:3px;border-radius:4px}

/* ───────────────────── sky engine layers ───────────────────── */
.sky-canvas{
  position:fixed;inset:0;z-index:-2;
  background:linear-gradient(180deg,#2c2754 0%,#ef9168 100%);
}
.grain{
  position:fixed;inset:-50%;z-index:90;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='220' height='220' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");
}
/* section fallback colours: visible when JS is off; the engine makes them
   transparent and paints the fixed canvas instead, so colours can blend. */
.sect{position:relative;padding:var(--pad-y) var(--pad-x)}
.bg-dawn{background:linear-gradient(180deg,#2c2754 0%,#a05a72 62%,#ef9168 100%)}
.bg-dawnpage{background:linear-gradient(180deg,#2b2550,#8d5570)}
.bg-morning{background:linear-gradient(180deg,#f3e9d2,#f9f2e3)}
.bg-day{background:linear-gradient(180deg,#f9f2e3,#faf4e6)}
.bg-golden{background:linear-gradient(180deg,#f4cf8f,#e9a45c)}
.bg-dusk{background:linear-gradient(180deg,#4f3b66,#7d4f63)}
.bg-night{background:linear-gradient(180deg,#131124,#1d1a33)}
.sky-live .sect{background:transparent}
[data-theme="dark"]{color:var(--cream)}
[data-theme="dark"] .muted{color:var(--cream-soft)}
[data-theme="light"] .muted{color:var(--ink-soft)}

.wrap{max-width:1180px;margin-inline:auto}
.kicker{
  font-family:var(--mono);font-size:.74rem;letter-spacing:.22em;
  text-transform:uppercase;display:flex;align-items:center;gap:.9rem;
  margin-bottom:clamp(1.6rem,4vw,3rem);
}
.kicker::after{content:"";height:1px;flex:0 0 56px;background:currentColor;opacity:.45}
.sect h2{font-size:var(--fs-h2);max-width:14em;margin-bottom:clamp(1.2rem,3vw,2.2rem)}
.lede{max-width:34em;font-size:clamp(1.05rem,1.5vw,1.22rem)}

/* ───────────────────── companion sun ───────────────────── */
.sun-companion{
  position:fixed;right:clamp(.9rem,2.6vw,2.4rem);top:18vh;z-index:80;
  width:20px;height:20px;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle at 38% 35%,#ffd9a0,var(--saffron) 58%,var(--ember));
  box-shadow:0 0 18px 6px rgba(223,138,58,.45);
  opacity:0;transition:opacity .8s ease;
}
.sun-companion.is-on{opacity:.95}
.sun-companion.is-moon{
  background:radial-gradient(circle at 62% 38%,#fdf6e4,#cfc4b0 70%,#9d93847d);
  box-shadow:0 0 16px 5px rgba(246,238,221,.22);
}
.sun-companion .sun-label{
  position:absolute;right:160%;top:50%;transform:translateY(-50%);
  font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;white-space:nowrap;
  text-transform:uppercase;color:var(--cream);opacity:0;transition:opacity .6s ease;
  text-shadow:0 1px 8px rgba(19,17,36,.5);
}
.sun-companion.show-label .sun-label{opacity:.92}
@media (max-width:720px){.sun-companion{width:12px;height:12px}.sun-companion .sun-label{display:none}}

/* ───────────────────── header ───────────────────── */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem var(--pad-x);
  color:var(--cream);
  transition:color .45s ease;
}
/* glass lives on a pseudo so the fixed mobile nav isn't trapped by
   the header's backdrop-filter containing block */
.site-header::before{
  content:"";position:absolute;inset:0;z-index:-1;opacity:0;
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  background:rgba(249,242,227,.78);
  box-shadow:0 1px 0 rgba(37,31,25,.08);
  transition:opacity .45s ease,background .45s ease;
}
.site-header.scrolled{color:var(--ink)}
.site-header.scrolled::before{opacity:1}
.site-header.scrolled.on-dark{color:var(--cream)}
.site-header.scrolled.on-dark::before{
  background:rgba(19,17,36,.66);
  box-shadow:0 1px 0 rgba(246,238,221,.08);
}
.wordmark{
  font-family:var(--serif);font-size:1.65rem;text-decoration:none;line-height:1;
  letter-spacing:.01em;
}
.wordmark .o{
  background:radial-gradient(circle at 40% 32%,#ffce8f,var(--saffron) 62%,var(--ember));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.main-nav{display:flex;align-items:center;gap:clamp(1.1rem,2.2vw,2rem)}
.main-nav a{
  text-decoration:none;font-size:.95rem;font-weight:500;opacity:.92;
  border-bottom:1px solid transparent;padding-bottom:2px;
  transition:border-color .25s ease,opacity .25s ease;
}
.main-nav a:hover{border-color:currentColor;opacity:1}
.nav-cta{
  font-family:var(--mono);font-size:.78rem !important;letter-spacing:.06em;
  background:var(--saffron);color:var(--night) !important;border:none !important;
  padding:.55rem 1.05rem !important;border-radius:999px;font-weight:500;
  transition:transform .25s var(--ease-out),box-shadow .25s ease !important;
}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(223,138,58,.4)}
.menu-toggle{
  display:none;background:none;border:1px solid currentColor;color:inherit;
  font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  padding:.5rem 1rem;border-radius:999px;cursor:pointer;
}
@media (max-width:880px){
  .main-nav{display:none}
  .main-nav.is-open{
    display:flex;position:fixed;inset:0;flex-direction:column;justify-content:center;
    align-items:center;gap:2.2rem;background:rgba(19,17,36,.96);
    backdrop-filter:blur(10px);color:var(--cream);
  }
  .main-nav.is-open a{font-family:var(--serif);font-size:2rem}
  .main-nav.is-open .nav-cta{font-family:var(--mono);font-size:.9rem !important}
  .menu-toggle{display:block;position:relative;z-index:110}
  .site-header:has(.main-nav.is-open) .menu-toggle{color:var(--cream)}
}

/* ───────────────────── hero · first light ───────────────────── */
.hero{
  min-height:100svh;display:flex;flex-direction:column;justify-content:center;
  overflow:hidden;padding-top:7rem;padding-bottom:0;
}
.hero-inner{position:relative;z-index:3;max-width:1180px;margin-inline:auto;width:100%}
.hero-status{
  font-family:var(--mono);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--cream-soft);display:flex;align-items:center;gap:.7rem;margin-bottom:2.2rem;
}
.hero-status::before{
  content:"";width:7px;height:7px;border-radius:50%;background:var(--rose);
  box-shadow:0 0 10px 2px rgba(239,145,104,.7);
  animation:status-pulse 3.4s var(--ease-breath) infinite;
}
@keyframes status-pulse{0%,100%{opacity:.6}50%{opacity:1}}
.hero h1{
  font-size:var(--fs-hero);color:var(--cream);max-width:9.5em;
  text-wrap:balance;margin-bottom:1.6rem;
}
.hero h1 em{
  background:linear-gradient(100deg,#ffd9a0 10%,var(--rose) 55%,var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero .lede{color:var(--cream);opacity:.94;margin-bottom:2.6rem}
.hero-ctas{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}
.btn{
  display:inline-block;text-decoration:none;border-radius:999px;font-weight:600;
  font-size:1rem;padding:1rem 1.9rem;transition:transform .3s var(--ease-out),box-shadow .3s ease,background .3s ease;
}
.btn-sun{background:var(--saffron);color:var(--night)}
.btn-sun:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(223,138,58,.45)}
.btn-ghost{border:1px solid rgba(246,238,221,.55);color:var(--cream);font-weight:500}
.btn-ghost:hover{transform:translateY(-3px);background:rgba(246,238,221,.1)}
[data-theme="light"] .btn-ghost{border-color:rgba(37,31,25,.4);color:var(--ink)}
[data-theme="light"] .btn-ghost:hover{background:rgba(37,31,25,.06)}

/* horizon + breathing sun */
.horizon{position:relative;z-index:1;margin-top:clamp(2.5rem,7vh,5.5rem);height:clamp(150px,24vh,220px)}
.horizon-line{
  position:absolute;left:0;right:0;bottom:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(246,238,221,.65) 18%,rgba(246,238,221,.65) 82%,transparent);
}
/* the glow is a free gradient with no box to clip, so no corners;
   the disc lives in a slightly oversized clip box that only cuts the horizon */
.sun-glow{
  position:absolute;left:50%;bottom:0;transform:translateX(-50%);z-index:0;
  width:min(920px,160vw);height:clamp(260px,42vh,460px);pointer-events:none;
  background:radial-gradient(55% 100% at 50% 100%,rgba(255,226,174,.5),rgba(239,145,104,.22) 45%,transparent 72%);
  animation:glow-breathe 9.5s var(--ease-breath) infinite;
}
@keyframes glow-breathe{0%,100%{opacity:.8}50%{opacity:1}}
.breath-sun{
  position:absolute;left:50%;bottom:0;transform:translateX(-50%);z-index:1;
  width:calc(clamp(130px,17vw,190px)*1.14);height:clamp(65px,8.5vw,95px);
  overflow:hidden;pointer-events:none;
}
.breath-sun::before{
  content:"";position:absolute;left:50%;top:0;
  width:clamp(130px,17vw,190px);height:clamp(130px,17vw,190px);
  border-radius:50%;
  background:radial-gradient(circle at 50% 38%,#ffe2ae,var(--rose) 52%,var(--ember) 88%);
  animation:breathe 9.5s var(--ease-breath) infinite;
}
@keyframes breathe{
  0%,100%{transform:translateX(-50%) scale(1)}
  50%{transform:translateX(-50%) scale(1.06)}
}
.breath-caption{
  position:absolute;left:50%;bottom:clamp(72px,9.5vw,104px);transform:translateX(-50%);
  font-family:var(--mono);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--cream);opacity:.85;white-space:nowrap;z-index:2;
}
.scroll-cue{
  position:relative;z-index:2;text-align:center;padding:1.1rem 0 1.4rem;
  font-family:var(--mono);font-size:.68rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--cream-soft);
}
.scroll-cue span{display:inline-block;animation:cue-drift 3.2s var(--ease-breath) infinite}
@keyframes cue-drift{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* ───────────────────── breath marquee ───────────────────── */
.marquee{padding:1.6rem 0;border-block:1px solid var(--line);overflow:hidden}
.marquee-track{
  display:flex;gap:3.4rem;width:max-content;
  animation:marquee-drift 46s linear infinite;
}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{
  display:flex;align-items:center;gap:3.4rem;white-space:nowrap;
  font-family:var(--serif);font-size:clamp(1.3rem,2.4vw,1.9rem);
}
.marquee-item .verb{font-style:italic;opacity:.7;font-size:.8em}
.marquee-item .dot{
  width:9px;height:9px;border-radius:50%;flex:none;
  background:radial-gradient(circle at 40% 35%,#ffd9a0,var(--saffron));
}
@keyframes marquee-drift{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ───────────────────── no.01 · the day ───────────────────── */
.day-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:0;position:relative;max-width:860px}
.day-rail{
  position:absolute;left:9px;top:14px;bottom:14px;width:2px;
  background:var(--line);border-radius:2px;
}
.day-rail-fill{
  position:absolute;left:0;top:0;width:100%;height:0%;
  background:linear-gradient(180deg,var(--rose),var(--saffron),var(--ember));
  border-radius:2px;
}
.day-item{
  position:relative;padding:1.6rem 0 1.6rem 3.4rem;
  border-bottom:1px solid var(--line);
}
.day-item:last-child{border-bottom:none}
.day-item::before{
  content:"";position:absolute;left:3px;top:2.25rem;width:14px;height:14px;border-radius:50%;
  background:var(--paper);border:2px solid var(--ink);opacity:.4;
  transition:all .5s var(--ease-out);
}
.day-item.lit::before{
  background:radial-gradient(circle at 40% 35%,#ffd9a0,var(--saffron));
  border-color:var(--saffron);opacity:1;
  box-shadow:0 0 12px 3px rgba(223,138,58,.35);
}
.day-time{
  font-family:var(--mono);font-size:.92rem;letter-spacing:.1em;
  color:var(--ember);margin-bottom:.35rem;display:block;
}
.day-item h3{font-size:var(--fs-h3);margin-bottom:.4rem}
.day-item p{max-width:30em;color:var(--ink-soft)}
.day-meta{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin-top:.9rem}
.chip{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
  border:1px solid var(--line);padding:.3rem .8rem;border-radius:999px;
}
.spaces{
  font-family:var(--mono);font-size:.78rem;letter-spacing:.05em;text-decoration:none;
  display:inline-flex;align-items:center;gap:.5rem;color:var(--ink);
  border-bottom:1px solid var(--saffron);padding-bottom:1px;
}
.spaces::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--saffron)}
.spaces.low::before{background:var(--ember);animation:status-pulse 2.2s var(--ease-breath) infinite}
.spaces.full{color:var(--ink-soft);border-bottom-color:var(--ink-soft)}
.spaces.full::before{background:transparent;border:1.5px solid var(--ember)}
.spaces:hover{opacity:.75}

/* ───────────────────── no.02 · the practice ───────────────────── */
.practice-list{counter-reset:practice;border-top:1px solid var(--line)}
.practice-row{
  display:grid;grid-template-columns:3.2rem minmax(0,1.15fr) minmax(0,1fr) auto;
  gap:1.4rem;align-items:center;padding:1.35rem 0;
  border-bottom:1px solid var(--line);text-decoration:none;color:inherit;
  transition:background .35s ease,padding-left .35s var(--ease-out);
}
.practice-row:hover{background:rgba(223,138,58,.07);padding-left:.9rem}
.practice-row .num{
  font-family:var(--mono);font-size:.78rem;letter-spacing:.1em;color:var(--ink-soft);
}
.practice-row h3{
  font-size:clamp(1.45rem,2.8vw,2.1rem);
  transition:font-style .2s ease,color .3s ease;
}
.practice-row:hover h3{font-style:italic;color:var(--ember)}
.practice-row .blurb{font-size:.95rem;color:var(--ink-soft);max-width:26em}
.energy{display:flex;align-items:flex-end;gap:3px;height:22px;justify-self:end}
.energy i{
  width:4px;border-radius:2px;background:var(--line);height:30%;
}
.energy i.on{background:var(--saffron)}
.energy[data-level="1"] i:nth-child(-n+1),
.energy[data-level="2"] i:nth-child(-n+2),
.energy[data-level="3"] i:nth-child(-n+3),
.energy[data-level="4"] i:nth-child(-n+4),
.energy[data-level="5"] i:nth-child(-n+5){background:var(--saffron)}
.energy i:nth-child(1){height:28%}.energy i:nth-child(2){height:44%}
.energy i:nth-child(3){height:60%}.energy i:nth-child(4){height:78%}
.energy i:nth-child(5){height:100%}
.energy-tag{
  font-family:var(--mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-soft);justify-self:end;margin-top:.4rem;
}
.practice-cols{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem}
@media (max-width:760px){
  .practice-row{grid-template-columns:2.2rem minmax(0,1fr) auto;gap:1rem}
  .practice-row .blurb{display:none}
}

/* ───────────────────── no.03 · the rooms ───────────────────── */
.rooms-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(1.2rem,2.5vw,2rem)}
@media (max-width:880px){.rooms-grid{grid-template-columns:minmax(0,1fr)}}
.room-card{text-decoration:none;color:inherit;display:block}
.room-card figure{
  position:relative;aspect-ratio:4/3;border-radius:16px;overflow:hidden;
  background:linear-gradient(160deg,var(--dusk-b),var(--rose));
  margin-bottom:1.2rem;
}
.room-card img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.94) sepia(.06);
  transition:transform 1.4s var(--ease-out),filter .8s ease;
}
.room-card:hover img{transform:scale(1.045);filter:saturate(1.05) sepia(0)}
.room-card figure.img-missing::after{
  content:attr(data-initial);position:absolute;inset:0;display:grid;place-items:center;
  font-family:var(--serif);font-size:5rem;color:rgba(246,238,221,.85);
}
.light-note{
  position:absolute;left:1rem;bottom:.9rem;z-index:2;
  font-family:var(--mono);font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--cream);background:rgba(19,17,36,.45);backdrop-filter:blur(6px);
  padding:.35rem .75rem;border-radius:999px;
}
.room-card h3{font-size:var(--fs-h3);margin-bottom:.45rem;display:flex;align-items:baseline;gap:.7rem}
.room-card h3 .coords{
  font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;color:var(--ink-soft);font-style:normal;
}
.room-card p{color:var(--ink-soft);font-size:.97rem;max-width:28em}
.room-link{
  display:inline-block;margin-top:.7rem;font-family:var(--mono);font-size:.74rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ember);
  border-bottom:1px solid currentColor;padding-bottom:2px;
}
.room-card:hover .room-link{color:var(--saffron)}
.room-online{
  grid-column:1/-1;margin-top:.6rem;display:flex;flex-wrap:wrap;gap:1.5rem;
  align-items:center;justify-content:space-between;
  background:linear-gradient(120deg,var(--night) 0%,#2b2350 70%,#4f3b66 100%);
  color:var(--cream);border-radius:16px;padding:clamp(1.6rem,4vw,2.6rem) clamp(1.5rem,4vw,3rem);
  text-decoration:none;position:relative;overflow:hidden;
}
.room-online::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.8;
  background:
    radial-gradient(1.5px 1.5px at 12% 30%,rgba(246,238,221,.9),transparent 60%),
    radial-gradient(1px 1px at 28% 70%,rgba(246,238,221,.7),transparent 60%),
    radial-gradient(1.5px 1.5px at 47% 22%,rgba(246,238,221,.8),transparent 60%),
    radial-gradient(1px 1px at 63% 58%,rgba(246,238,221,.65),transparent 60%),
    radial-gradient(1.5px 1.5px at 78% 32%,rgba(246,238,221,.85),transparent 60%),
    radial-gradient(1px 1px at 90% 68%,rgba(246,238,221,.7),transparent 60%);
}
.room-online h3{font-size:var(--fs-h3);margin-bottom:.4rem}
.room-online p{color:var(--cream-soft);max-width:30em}
.room-online .room-link{color:var(--gold)}

/* ───────────────────── no.04 · golden hour offer ───────────────────── */
.offer{text-align:center}
.offer .kicker{justify-content:center}
.offer .kicker::after{display:none}
.offer h2{margin-inline:auto}
.offer .lede{margin:0 auto 3rem}
.ticket{
  display:inline-flex;align-items:stretch;text-align:left;
  background:var(--paper);border-radius:18px;overflow:hidden;
  box-shadow:0 24px 60px rgba(96,52,15,.28);
  transform:rotate(-1.4deg);transition:transform .5s var(--ease-out);
  margin-bottom:2.6rem;max-width:100%;
}
.ticket:hover{transform:rotate(0deg) translateY(-4px)}
.ticket-main{padding:clamp(1.6rem,4vw,2.4rem) clamp(1.8rem,4vw,2.8rem)}
.ticket-price{font-family:var(--serif);font-size:clamp(3.4rem,8vw,5.4rem);line-height:1;color:var(--ink)}
.ticket-price sup{font-size:.38em;vertical-align:1.1em;margin-right:.08em}
.ticket-terms{
  font-family:var(--mono);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-soft);margin-top:.7rem;
}
.ticket-stub{
  border-left:2px dashed var(--line);padding:1.4rem 1.1rem;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:.64rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--ink-soft);writing-mode:vertical-rl;
}
.offer .btn-sun{background:var(--ink);color:var(--gold)}
.offer .btn-sun:hover{box-shadow:0 12px 32px rgba(37,31,25,.35)}
.testimonial{margin-top:4rem}
.stars{color:var(--ember);letter-spacing:.3em;font-size:.95rem;margin-bottom:1rem}
.testimonial blockquote{
  font-family:var(--serif);font-style:italic;font-size:clamp(1.3rem,2.6vw,1.8rem);
  max-width:24em;margin:0 auto .9rem;line-height:1.3;
}
.testimonial cite{
  font-family:var(--mono);font-style:normal;font-size:.74rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-soft);
}

/* ───────────────────── no.05 · the faculty (dusk) ───────────────────── */
.faculty-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0 clamp(2rem,5vw,4.5rem);border-top:1px solid var(--line-dark)}
@media (max-width:760px){.faculty-list{grid-template-columns:minmax(0,1fr)}}
.teacher{
  display:block;text-decoration:none;color:inherit;padding:1.5rem 0;
  border-bottom:1px solid var(--line-dark);
  transition:padding-left .35s var(--ease-out);
}
.teacher:hover{padding-left:.7rem}
.teacher h3{font-size:clamp(1.5rem,2.6vw,2rem);margin-bottom:.3rem}
.teacher:hover h3{font-style:italic;color:var(--gold)}
.teacher .tag{
  font-family:var(--mono);font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);display:block;margin-bottom:.45rem;
}
.teacher p{font-size:.95rem;color:var(--cream-soft);max-width:30em}

/* ───────────────────── no.06 · asked at the door ───────────────────── */
.faq-wrap{max-width:780px}
.faq-wrap details{border-bottom:1px solid var(--line-dark)}
.faq-wrap summary{
  cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;
  gap:1.5rem;padding:1.5rem 0;font-family:var(--serif);
  font-size:clamp(1.25rem,2.3vw,1.65rem);
}
.faq-wrap summary::-webkit-details-marker{display:none}
.faq-wrap summary .ind{
  flex:none;width:30px;height:30px;border:1px solid var(--line-dark);border-radius:50%;
  display:grid;place-items:center;font-family:var(--sans);font-size:1.1rem;font-weight:400;
  transition:transform .4s var(--ease-out),background .3s ease,color .3s ease;
}
.faq-wrap details[open] .ind{transform:rotate(45deg);background:var(--gold);color:var(--night);border-color:var(--gold)}
.faq-wrap details p{padding:0 0 1.6rem;color:var(--cream-soft);max-width:36em}

/* ───────────────────── no.07 · after dark ───────────────────── */
.afterdark{overflow:hidden}
.star-field,.star-field::before,.star-field::after{position:absolute;inset:0;pointer-events:none}
.star-field::before{
  content:"";
  background:
    radial-gradient(1.6px 1.6px at 8% 18%,rgba(246,238,221,.9),transparent 60%),
    radial-gradient(1px 1px at 21% 64%,rgba(246,238,221,.6),transparent 60%),
    radial-gradient(1.4px 1.4px at 33% 30%,rgba(246,238,221,.8),transparent 60%),
    radial-gradient(1px 1px at 44% 80%,rgba(246,238,221,.55),transparent 60%),
    radial-gradient(1.7px 1.7px at 56% 14%,rgba(246,238,221,.9),transparent 60%),
    radial-gradient(1px 1px at 67% 47%,rgba(246,238,221,.6),transparent 60%),
    radial-gradient(1.4px 1.4px at 79% 72%,rgba(246,238,221,.75),transparent 60%),
    radial-gradient(1.2px 1.2px at 88% 26%,rgba(246,238,221,.85),transparent 60%),
    radial-gradient(1px 1px at 95% 58%,rgba(246,238,221,.6),transparent 60%);
  animation:twinkle 7s var(--ease-breath) infinite;
}
.star-field::after{
  content:"";
  background:
    radial-gradient(1px 1px at 14% 42%,rgba(246,238,221,.7),transparent 60%),
    radial-gradient(1.3px 1.3px at 27% 12%,rgba(246,238,221,.8),transparent 60%),
    radial-gradient(1px 1px at 39% 56%,rgba(246,238,221,.5),transparent 60%),
    radial-gradient(1.5px 1.5px at 52% 38%,rgba(246,238,221,.85),transparent 60%),
    radial-gradient(1px 1px at 61% 84%,rgba(246,238,221,.55),transparent 60%),
    radial-gradient(1.2px 1.2px at 73% 22%,rgba(246,238,221,.7),transparent 60%),
    radial-gradient(1px 1px at 84% 50%,rgba(246,238,221,.6),transparent 60%),
    radial-gradient(1.4px 1.4px at 93% 78%,rgba(246,238,221,.8),transparent 60%);
  animation:twinkle 9s var(--ease-breath) infinite reverse;
}
@keyframes twinkle{0%,100%{opacity:.45}50%{opacity:1}}
.moon{
  position:absolute;top:clamp(3rem,8vw,5rem);right:clamp(1.5rem,8vw,7rem);
  width:64px;height:64px;border-radius:50%;
  background:radial-gradient(circle at 62% 38%,#fdf6e4,#cfc4b0 72%,#a99e8c);
  box-shadow:inset -12px 8px 0 2px #1d1a33,0 0 30px 6px rgba(246,238,221,.18);
}
.library-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.2rem;margin:2.6rem 0 2.2rem;max-width:980px}
@media (max-width:760px){.library-grid{grid-template-columns:minmax(0,1fr)}}
.library-card{
  position:relative;border:1px solid var(--line-dark);border-radius:14px;
  padding:1.6rem 1.7rem;background:rgba(246,238,221,.04);text-decoration:none;color:inherit;
  transition:border-color .4s ease,background .4s ease,transform .4s var(--ease-out);
}
.library-card:hover{border-color:rgba(242,193,120,.65);background:rgba(242,193,120,.07);transform:translateY(-3px)}
.library-card h3{font-size:1.45rem;margin-bottom:.4rem}
.library-card .meta{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cream-soft)}
.badge{
  position:absolute;top:1.1rem;right:1.1rem;font-family:var(--mono);font-size:.6rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--night);
  background:var(--gold);padding:.28rem .7rem;border-radius:999px;
}
.afterdark .price-note{color:var(--cream-soft);font-size:.95rem;margin-bottom:2rem;max-width:34em}

/* ───────────────────── no.08 · the letter ───────────────────── */
.letter .lede{margin-bottom:2.4rem}
.letter-form{display:flex;flex-direction:column;gap:1.1rem;max-width:520px}
.letter-form .row{display:flex;gap:.8rem;flex-wrap:wrap}
.letter-form input[type="email"]{
  flex:1;min-width:240px;background:rgba(246,238,221,.07);border:1px solid var(--line-dark);
  border-radius:999px;padding:1rem 1.5rem;color:var(--cream);font-family:var(--sans);font-size:1rem;
  transition:border-color .3s ease;
}
.letter-form input[type="email"]::placeholder{color:rgba(246,238,221,.45)}
.letter-form input[type="email"]:focus{border-color:var(--gold);outline:none}
.letter-form button{
  border:none;cursor:pointer;font-family:var(--sans);font-weight:600;font-size:1rem;
  background:var(--saffron);color:var(--night);border-radius:999px;padding:1rem 1.9rem;
  transition:transform .3s var(--ease-out),box-shadow .3s ease;
}
.letter-form button:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(223,138,58,.4)}
.consent{display:flex;align-items:flex-start;gap:.7rem;font-size:.86rem;color:var(--cream-soft);max-width:30em}
.consent input{margin-top:.3rem;accent-color:var(--saffron)}
.letter-success{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--gold)}

/* ───────────────────── footer ───────────────────── */
.site-footer{position:relative;padding:var(--pad-y) var(--pad-x) 2rem;overflow:hidden}
.footer-grid{
  display:grid;grid-template-columns:1.4fr repeat(3,minmax(0,1fr));
  gap:2.5rem;padding-bottom:3.5rem;border-bottom:1px solid var(--line-dark);
}
@media (max-width:880px){.footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:540px){.footer-grid{grid-template-columns:minmax(0,1fr)}}
.site-footer .wordmark{font-size:2.2rem}
.footer-dawnline{margin-top:1.2rem;font-family:var(--serif);font-style:italic;font-size:1.2rem;color:var(--cream-soft);max-width:16em}
.back-to-light{
  display:inline-block;margin-top:1.6rem;font-family:var(--mono);font-size:.7rem;
  letter-spacing:.2em;text-transform:uppercase;color:var(--gold);text-decoration:none;
  border-bottom:1px solid currentColor;padding-bottom:2px;
}
.back-to-light:hover{color:var(--saffron)}
.site-footer h4{
  font-family:var(--mono);font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--cream-soft);margin-bottom:1.1rem;font-weight:500;
}
.site-footer ul{list-style:none}
.site-footer li{margin-bottom:.55rem}
.site-footer li a{text-decoration:none;opacity:.9;font-size:.97rem}
.site-footer li a:hover{opacity:1;color:var(--gold)}
.footer-legal{
  display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;
  padding-top:1.6rem;font-size:.85rem;color:var(--cream-soft);
}
.footer-legal a{color:inherit}
.site-footer::after{ /* tomorrow's dawn, seeping up from the page edge */
  content:"";position:absolute;left:0;right:0;bottom:0;height:90px;pointer-events:none;
  background:linear-gradient(0deg,rgba(239,145,104,.28),transparent);
}

/* ───────────────────── reveals & motion safety ───────────────────── */
.sky-live .site-footer{background:transparent}
.sect.marquee{padding-inline:0}
html.js [data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out);transition-delay:var(--d,0s)}
html.js [data-reveal].revealed{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none !important;transition:none !important}
  [data-reveal]{opacity:1;transform:none}
  .marquee-track{flex-wrap:wrap;width:auto}
  .sun-companion{display:none}
}

/* ═════════════ interior pages (each page keeps its own hour) ═════════════ */
.sky-page .sect:not(.keep-bg){background:transparent}
.main-nav a[aria-current="page"]{border-color:currentColor;opacity:1}
body[data-theme="light"] .site-header{color:var(--ink)}
body[data-theme="light"] .site-header.scrolled{color:var(--ink)}

.page-hero{padding-top:9.5rem;padding-bottom:clamp(2.5rem,6vw,4.5rem)}
.crumb{
  font-family:var(--mono);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;
  display:flex;flex-wrap:wrap;gap:.8rem;margin-bottom:1.8rem;opacity:.85;
}
.crumb a{text-decoration:none;border-bottom:1px solid currentColor;padding-bottom:1px}
.page-title{font-size:clamp(2.7rem,7.5vw,5.6rem);max-width:11em;margin-bottom:1.4rem;text-wrap:balance}
.page-hero .lede{max-width:36em}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.2rem}

.prose{max-width:68ch}
.prose h2{font-size:clamp(1.5rem,3vw,2.1rem);margin:2.2em 0 .55em}
.prose h2:first-child{margin-top:0}
.prose p,.prose li{opacity:.88;margin-bottom:1.05em}
.prose ul{padding-left:1.25em;margin-bottom:1.2em}
.prose li{margin-bottom:.45em}
.prose strong{font-weight:600;opacity:1}
.prose a{color:var(--ember)}
[data-theme="dark"] .prose a{color:var(--gold)}
.prose hr{border:none;border-top:1px solid currentColor;opacity:.22;margin:2.5em 0}

.cta-band{text-align:center}
.cta-band h2{margin-inline:auto}
.cta-band .lede{margin:0 auto 2.2rem}

/* pricing tiers */
.tier-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(235px,1fr));gap:1.4rem;margin-top:3rem;text-align:left}
.tier{
  background:var(--paper);color:var(--ink);border-radius:16px;padding:2rem 1.8rem;
  box-shadow:0 18px 44px rgba(96,52,15,.16);display:flex;flex-direction:column;gap:.55rem;
  transition:transform .4s var(--ease-out);
}
.tier:hover{transform:translateY(-4px)}
.tier .t-name{font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft)}
.tier .t-price{font-family:var(--serif);font-size:2.7rem;line-height:1.1}
.tier .t-price span{font-size:1rem;font-family:var(--sans);color:var(--ink-soft)}
.tier p{font-size:.95rem;color:var(--ink-soft);flex:1}
.tier .room-link{align-self:flex-start}
.tier.featured{background:var(--ink);color:var(--cream)}
.tier.featured .t-name,.tier.featured .room-link{color:var(--gold)}
.tier.featured p,.tier.featured .t-price span{color:var(--cream-soft)}

/* schedule */
.sched-tools{display:flex;flex-wrap:wrap;align-items:center;gap:.55rem;margin:2.2rem 0 .5rem}
.sched-tools .lab{font-family:var(--mono);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;opacity:.7;margin-right:.3rem}
.chip-btn{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
  padding:.5rem 1.05rem;border-radius:999px;border:1px solid var(--line);
  background:transparent;color:inherit;cursor:pointer;
  transition:background .25s ease,color .25s ease,border-color .25s ease;
}
.chip-btn:hover{border-color:var(--ember);color:var(--ember)}
.chip-btn[aria-pressed="true"]{background:var(--ink);color:var(--gold);border-color:var(--ink)}
.sched-day{margin-top:3.2rem}
.sect h2.sched-date{
  max-width:none;
  font-family:var(--mono);font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ember);display:flex;align-items:center;gap:1.2rem;margin-bottom:.3rem;
}
.sched-date::after{content:"";height:1px;flex:1;background:currentColor;opacity:.35}
.class-row{
  display:grid;grid-template-columns:44px 84px minmax(0,1fr) auto auto;gap:1.2rem;
  align-items:center;padding:1.05rem 0;border-bottom:1px solid var(--line);
  text-decoration:none;color:inherit;
  transition:background .3s ease,padding-left .3s var(--ease-out);
}
.class-row:hover{background:rgba(223,138,58,.07);padding-left:.5rem}
.class-row .when{font-family:var(--mono);font-size:.85rem;color:var(--ember)}
.class-row .what{font-family:var(--serif);font-size:1.3rem;line-height:1.15}
.class-row .who{display:block;font-family:var(--sans);font-size:.8rem;color:var(--ink-soft);margin-top:.2rem}
.class-row .book{
  font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ember);border-bottom:1px solid currentColor;padding-bottom:2px;justify-self:end;white-space:nowrap;
}
.class-row[hidden]{display:none}
.sched-day[hidden]{display:none}
.sun-arc{width:38px;height:19px;border:1px solid var(--line);border-bottom:none;border-radius:38px 38px 0 0;position:relative}
.sun-arc i{
  position:absolute;width:7px;height:7px;border-radius:50%;
  background:radial-gradient(circle at 40% 35%,#ffd9a0,var(--saffron));
  left:calc(var(--t,.5)*100% - 3.5px);bottom:calc(sin(var(--t,.5)*3.14159)*14px - 3.5px);
}
@supports not (width:calc(sin(1)*1px)){.sun-arc i{bottom:-3.5px}}
.sched-empty{display:none;margin-top:2.5rem;font-family:var(--serif);font-style:italic;font-size:1.3rem;opacity:.8}
.sched-empty.show{display:block}
@media (max-width:740px){
  .class-row{grid-template-columns:70px minmax(0,1fr) auto}
  .class-row .sun-arc,.class-row .chip{display:none}
}

/* people */
.people-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.6rem;margin-top:2.6rem}
.person{display:block;text-decoration:none;color:inherit}
.person figure{
  aspect-ratio:4/5;border-radius:14px;overflow:hidden;margin-bottom:1rem;
  background:linear-gradient(160deg,var(--dusk-a),var(--ember));
}
.person img{width:100%;height:100%;object-fit:cover;filter:saturate(.92);transition:transform 1.2s var(--ease-out)}
.person:hover img{transform:scale(1.045)}
.person .tag{font-family:var(--mono);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:.35rem}
.person h3{font-size:1.45rem}
.person:hover h3{font-style:italic;color:var(--gold)}
.person p{font-size:.92rem;opacity:.8;margin-top:.3rem}

.bio-grid{display:grid;grid-template-columns:minmax(250px,370px) minmax(0,1fr);gap:clamp(2rem,5vw,4.5rem);align-items:start}
.bio-grid figure{aspect-ratio:4/5;border-radius:16px;overflow:hidden;position:sticky;top:7rem;background:linear-gradient(160deg,var(--dusk-a),var(--ember))}
.bio-grid img{width:100%;height:100%;object-fit:cover}
@media (max-width:830px){.bio-grid{grid-template-columns:minmax(0,1fr)}.bio-grid figure{position:static;max-width:420px}}
.spec-line{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  margin:2rem 0;padding:1.1rem 0;border-block:1px solid currentColor;line-height:2.1;opacity:.9;
}

/* first-timers steps */
.step-list{counter-reset:s;margin-top:2.5rem;max-width:760px}
.step{padding:1.7rem 0;border-bottom:1px solid var(--line-dark)}
.step::before{
  counter-increment:s;content:counter(s,decimal-leading-zero);
  font-family:var(--mono);color:var(--gold);font-size:.78rem;letter-spacing:.24em;
  display:block;margin-bottom:.55rem;
}
.step h3{font-size:var(--fs-h3);margin-bottom:.45rem}
.step p{color:var(--cream-soft);max-width:34em}

/* workshops */
.ws-card{border:1px solid var(--line-dark);border-radius:16px;padding:clamp(1.5rem,3.5vw,2.4rem);margin-top:1.4rem;background:rgba(246,238,221,.04)}
.ws-card h3{font-size:clamp(1.5rem,3vw,2rem);display:flex;flex-wrap:wrap;gap:1rem;align-items:baseline}
.ws-price{font-family:var(--mono);font-size:.85rem;letter-spacing:.1em;color:var(--gold)}
.ws-card>p{color:var(--cream-soft);max-width:40em;margin-top:.7rem}
.ws-card ul{list-style:none;margin-top:1.1rem;display:flex;flex-wrap:wrap;gap:.5rem 1.6rem}
.ws-card li{font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cream-soft)}
.ws-card li::before{content:"· "}
.ws-card .room-link{margin-top:1.4rem;display:inline-block;color:var(--gold)}

/* journal */
.post{display:block;padding:1.6rem 0;border-bottom:1px solid var(--line);text-decoration:none;color:inherit;transition:padding-left .3s var(--ease-out)}
.post:hover{padding-left:.6rem}
.post h3{font-size:clamp(1.4rem,2.6vw,1.9rem)}
.post:hover h3{font-style:italic;color:var(--ember)}
.post p{color:var(--ink-soft);max-width:40em;margin-top:.35rem}

/* studio detail */
.studio-photo{border-radius:16px;overflow:hidden;margin:2.5rem 0;aspect-ratio:16/9;background:linear-gradient(160deg,var(--dusk-b),var(--rose))}
.studio-photo img{width:100%;height:100%;object-fit:cover}
.fact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:clamp(1.5rem,3vw,2.6rem);margin-top:2.6rem}
.fact h3{font-size:1.35rem;margin-bottom:.5rem}
.fact p,.fact li{font-size:.96rem;opacity:.85}
.fact ul{list-style:none}
.fact li{padding:.45rem 0;border-bottom:1px solid var(--line)}
[data-theme="dark"] .fact li{border-color:var(--line-dark)}
