/* ============================================================
   FOG THEORY CAFÉ — styles.css
   Day↔Night engine driven by --t (0 day → 1 night), set from scroll.
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --t:0; /* 0 = daytime · 1 = night. JS animates this on scroll. */

  /* palette anchors */
  --day-bg:#f4eee1; --day-ink:#16213e; --day-accent:#c0532b; --day-accent2:#1b2a4a;
  --night-bg:#070912; --night-ink:#f4eee1; --night-accent:#e11d8f; --night-accent2:#7b2ff7;

  /* live tweened tokens */
  --bg:      color-mix(in oklab, var(--day-bg),      var(--night-bg)      calc(var(--t)*100%));
  --ink:     color-mix(in oklab, var(--day-ink),     var(--night-ink)     calc(var(--t)*100%));
  --accent:  color-mix(in oklab, var(--day-accent),  var(--night-accent)  calc(var(--t)*100%));
  --accent2: color-mix(in oklab, var(--day-accent2), var(--night-accent2) calc(var(--t)*100%));
  --line:    color-mix(in oklab, var(--ink) 22%, transparent);
  --scrim:   color-mix(in oklab, var(--bg) 64%, transparent);
  --glass:   color-mix(in oklab, var(--bg) 38%, transparent);

  --serif:"Fraunces",Georgia,serif;
  --sans:"Inter",system-ui,sans-serif;
  --mono:"Space Mono",ui-monospace,monospace;
  --ease:cubic-bezier(.16,1,.3,1);
  --maxw:1280px;
}

html{scroll-behavior:auto;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans); color:var(--ink);
  background:
    radial-gradient(120% 90% at 50% -10%, color-mix(in oklab,var(--bg),transparent 30%), transparent 60%),
    var(--bg);
  line-height:1.5; overflow-x:hidden;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  cursor:none;
}
@media (hover:none){body{cursor:auto}}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none}
em{font-style:italic}
::selection{background:var(--accent);color:var(--bg)}

/* ─────────────  ATMOSPHERE LAYERS  ───────────── */
#fog-canvas{position:fixed;inset:0;width:100vw;height:100vh;z-index:-3;display:block}
#fog-fallback{position:fixed;inset:0;z-index:-3;display:none;
  background:
    radial-gradient(70% 60% at 30% 20%, color-mix(in oklab,var(--accent2),transparent 65%), transparent 70%),
    radial-gradient(80% 70% at 80% 80%, color-mix(in oklab,var(--accent),transparent 70%), transparent 70%),
    var(--bg);
}
.grain{position:fixed;inset:0;z-index:-2;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.vignette{position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(130% 100% at 50% 42%, transparent 52%, color-mix(in oklab,var(--night-bg),transparent calc(60% - var(--t)*30%)) 100%)}

/* ─────────────  CURSOR  ───────────── */
.cursor{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;mix-blend-mode:exclusion;will-change:transform}
.cursor__dot{position:absolute;width:7px;height:7px;border-radius:50%;background:#fff;transform:translate(-50%,-50%)}
.cursor__ring{position:absolute;width:38px;height:38px;border:1.5px solid rgba(255,255,255,.7);border-radius:50%;transform:translate(-50%,-50%);transition:width .3s var(--ease),height .3s var(--ease),opacity .3s}
.cursor__label{position:absolute;transform:translate(-50%,-50%);font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:#fff;opacity:0;white-space:nowrap}
.cursor.is-hover .cursor__ring{width:58px;height:58px;border-color:var(--accent)}
.cursor.is-hot .cursor__ring{width:64px;height:64px;border-style:dashed}
.cursor.is-hot .cursor__label{opacity:1}
@media (hover:none){.cursor{display:none}}

/* ─────────────  PRELOADER  ───────────── */
#preloader{position:fixed;inset:0;z-index:9000;display:grid;place-content:center;justify-items:center;gap:26px;background:var(--day-bg);color:var(--day-ink);transition:opacity .8s var(--ease),visibility .8s}
.preloader__cloud .mark{width:120px;height:70px;color:var(--day-ink);animation:bob 3s ease-in-out infinite}
.preloader__bar{width:180px;height:2px;background:color-mix(in oklab,var(--day-ink),transparent 80%);overflow:hidden}
.preloader__bar span{display:block;height:100%;width:0;background:var(--day-accent);transition:width .3s linear}
.preloader__line{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;opacity:.7}
body:not(.is-loading) #preloader{opacity:0;visibility:hidden}
@keyframes bob{50%{transform:translateY(-10px)}}

/* ─────────────  NAV  ───────────── */
.nav{position:fixed;top:0;left:0;width:100%;z-index:800;display:flex;align-items:center;justify-content:space-between;
  padding:clamp(14px,2.4vw,26px) clamp(18px,4vw,48px);mix-blend-mode:difference;color:#fff}
.nav__brand{display:flex;align-items:center;gap:12px}
.nav__mark{width:42px;height:34px;color:#fff}
.nav__word{font-family:var(--serif);font-weight:600;font-size:15px;letter-spacing:.16em;text-transform:uppercase;line-height:1}
.nav__word em{font-style:normal;font-weight:400;font-size:10px;letter-spacing:.3em;display:block;opacity:.7;margin-top:3px}
.nav__links{display:flex;gap:26px}
.nav__links a{font-size:12px;letter-spacing:.06em;text-transform:uppercase;position:relative;opacity:.85}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1px;background:#fff;transition:width .4s var(--ease)}
.nav__links a:hover::after{width:100%}
.nav__tools{display:flex;align-items:center;gap:14px}
.secrets{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;padding:7px 11px;border:1px solid rgba(255,255,255,.35);border-radius:30px}
.secrets__key{color:#fff}
.secrets.pulse{animation:secretPulse .7s var(--ease)}
@keyframes secretPulse{0%{transform:scale(1)}40%{transform:scale(1.18);box-shadow:0 0 0 6px rgba(255,255,255,.12)}100%{transform:scale(1)}}
.sound{width:34px;height:34px;border:1px solid rgba(255,255,255,.35);border-radius:50%;display:grid;place-content:center}
.sound__bars{display:flex;align-items:flex-end;gap:2px;height:13px}
.sound__bars i{width:2px;height:4px;background:#fff;border-radius:2px}
.sound[aria-pressed="true"] .sound__bars i{animation:eq .8s ease-in-out infinite}
.sound__bars i:nth-child(2){animation-delay:.15s}.sound__bars i:nth-child(3){animation-delay:.3s}.sound__bars i:nth-child(4){animation-delay:.45s}
@keyframes eq{0%,100%{height:4px}50%{height:13px}}
@media(max-width:820px){.nav__links{display:none}}

/* ─────────────  TYPOGRAPHY HELPERS  ───────────── */
.kicker{font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:12px;margin-bottom:26px}
.kicker span{display:inline-grid;place-content:center;width:30px;height:30px;border:1px solid var(--accent);border-radius:50%;font-size:11px}
.display{font-family:var(--serif);font-weight:400;line-height:1.02;letter-spacing:-.02em;font-size:clamp(2.4rem,6vw,5.2rem)}
.display.big{font-size:clamp(3rem,9vw,8rem)}
.display.huge{font-size:clamp(2.8rem,8.5vw,7.6rem)}
.display .italic,.italic{font-style:italic}
.ink-accent{color:var(--accent)}
.lede{font-size:clamp(1.05rem,1.7vw,1.45rem);line-height:1.55;max-width:42ch;color:color-mix(in oklab,var(--ink) 86%,transparent)}
.lede.center{margin-inline:auto;text-align:center}

/* reveal-on-scroll */
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;padding:16px 26px;border-radius:40px;position:relative;overflow:hidden;transition:transform .4s var(--ease)}
.btn--ghost{border:1px solid var(--ink);color:var(--ink)}
.btn--ghost svg{transition:transform .4s var(--ease)}
.btn--ghost:hover svg{transform:translateY(4px)}
.btn--solid{background:var(--accent);color:var(--bg);padding:18px 30px}
.btn span{position:relative;z-index:1}
.btn--solid::before{content:"";position:absolute;inset:0;background:var(--accent2);transform:translateY(101%);transition:transform .5s var(--ease)}
.btn--solid:hover::before{transform:translateY(0)}

/* ─────────────  SECTION SHELL  ───────────── */
main>section,.footer{position:relative;padding:clamp(90px,14vh,180px) clamp(20px,5vw,80px);max-width:100%}
section .kicker,section .display,section .lede{position:relative;z-index:2}

/* ─────────────  HERO  ───────────── */
.hero{min-height:100svh;display:grid;place-content:center;text-align:center;overflow:hidden}
.hero__inner{position:relative;z-index:3;max-width:980px;margin-inline:auto}
.hero__eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--accent);margin-bottom:28px}
.hero__title{font-family:var(--serif);font-weight:500;font-size:clamp(3.4rem,13vw,11rem);line-height:.92;letter-spacing:-.03em;margin-bottom:30px;text-shadow:0 2px 40px color-mix(in oklab,var(--bg),transparent 40%)}
.hero__title .line{display:block;overflow:hidden}
.hero__title .word{display:inline-block;transform:translateY(115%);transition:transform 1.05s var(--ease)}
.hero__title .word.up{transform:translateY(0)}
.hero__sub{font-size:clamp(1.05rem,2vw,1.5rem);max-width:30ch;margin:0 auto 40px;line-height:1.45;color:color-mix(in oklab,var(--ink) 90%,transparent)}
.scroll-cue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;display:grid;justify-items:center;gap:10px;font-family:var(--mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;opacity:.6}
.scroll-cue i{width:1px;height:42px;background:linear-gradient(var(--ink),transparent);position:relative;overflow:hidden}
.scroll-cue i::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--accent);animation:cueDrop 1.8s var(--ease) infinite}
@keyframes cueDrop{to{top:100%}}
.hero__threshold{position:absolute;inset:0;display:grid;place-content:center;z-index:1;pointer-events:none}
.hero__threshold span{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);border:1px solid color-mix(in oklab,var(--accent) 50%,transparent);border-radius:50%}
.hero__threshold span:nth-child(1){width:46vmin;height:46vmin}
.hero__threshold span:nth-child(2){width:64vmin;height:64vmin;opacity:.6}
.hero__threshold span:nth-child(3){width:86vmin;height:86vmin;opacity:.3}

/* Karl the Fog */
.karl{position:absolute;top:4%;left:50%;transform:translateX(-50%);z-index:2;width:min(240px,46vw);animation:floaty 6s ease-in-out infinite}
.karl__svg{width:100%;height:auto;overflow:visible;filter:drop-shadow(0 18px 30px color-mix(in oklab,var(--night-bg),transparent 70%))}
.karl__shadow{fill:color-mix(in oklab,var(--night-bg),transparent 88%)}
.karl__cloud{fill:color-mix(in oklab,#ffffff,var(--accent2) calc(var(--t)*55%));stroke:color-mix(in oklab,var(--ink),transparent 70%);stroke-width:1.5}
.eye{fill:#fff;stroke:rgba(0,0,0,.12)}
.pupil{fill:#16213e;transition:transform .12s linear}
.glint{fill:#fff}
.karl__smile{stroke:#16213e;stroke-width:3;stroke-linecap:round}
.karl__blush{fill:color-mix(in oklab,var(--accent),transparent 55%)}
.karl.is-poked{animation:pokeShake .5s var(--ease)}
@keyframes pokeShake{25%{transform:translateX(calc(-50% - 8px)) rotate(-3deg)}75%{transform:translateX(calc(-50% + 8px)) rotate(3deg)}}
@keyframes floaty{50%{transform:translate(-50%,-14px)}}
.karl__bubble{position:absolute;top:-10px;left:78%;background:var(--bg);color:var(--ink);border:1.5px solid var(--accent);border-radius:16px 16px 16px 4px;padding:10px 14px;font-family:var(--serif);font-style:italic;font-size:14px;white-space:nowrap;opacity:0;transform:scale(.7) translateY(8px);transform-origin:bottom left;transition:.35s var(--ease);pointer-events:none}
.karl__bubble.show{opacity:1;transform:none}

/* ─────────────  LIVING ROOM  ───────────── */
.living__grid{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(30px,6vw,90px);align-items:start;max-width:var(--maxw);margin-inline:auto}
.living__lead .kicker span{color:var(--accent)}
.mantra{margin-top:34px;font-family:var(--serif);font-size:clamp(1.4rem,2.6vw,2.1rem);line-height:1.3}
.mantra p{opacity:.55;transition:opacity .5s}
.mantra p.mantra__last{color:var(--accent);opacity:1;font-style:italic}
.mantra:hover p{opacity:1}
.stat-row{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:24px;max-width:var(--maxw);margin:clamp(60px,9vw,120px) auto 0;border-top:1px solid var(--line);padding-top:40px}
.stat-row b{font-family:var(--serif);font-size:clamp(2.2rem,5vw,3.6rem);display:block;line-height:1}
.stat-row b i{font-style:normal;font-size:.5em;color:var(--accent)}
.stat-row span{font-size:13px;letter-spacing:.02em;color:color-mix(in oklab,var(--ink) 70%,transparent);margin-top:8px;display:block}
@media(max-width:760px){.living__grid{grid-template-columns:1fr}.stat-row{grid-template-columns:1fr 1fr;gap:30px 18px}}

/* ─────────────  WORLDS  ───────────── */
.worlds__head{max-width:var(--maxw);margin:0 auto clamp(40px,6vw,70px)}
.worlds__rail{display:flex;gap:28px;overflow-x:auto;padding:10px 2px 30px;scroll-snap-type:x mandatory;scrollbar-width:none;cursor:grab}
.worlds__rail::-webkit-scrollbar{display:none}
.worlds__rail.dragging{cursor:grabbing}
.world{flex:0 0 min(420px,82vw);scroll-snap-align:center;border:1px solid var(--line);border-radius:22px;padding:30px;background:var(--glass);backdrop-filter:blur(10px);position:relative;overflow:hidden;transition:transform .5s var(--ease),border-color .5s}
.world:hover{transform:translateY(-8px);border-color:var(--accent)}
.world__art{height:230px;display:grid;place-content:center;position:relative;margin-bottom:24px}
.world__tag{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.world__copy h3{font-family:var(--serif);font-size:1.9rem;margin:6px 0 12px;font-weight:500}
.world__copy p{font-size:.95rem;color:color-mix(in oklab,var(--ink) 80%,transparent);line-height:1.55}
.world__copy em{color:var(--accent)}
/* coffee torus */
.torus{width:170px;height:170px;position:relative;display:grid;place-content:center}
.torus span{position:absolute;inset:0;border-radius:50%;border:14px solid transparent;border-top-color:var(--accent);border-right-color:color-mix(in oklab,var(--accent2),transparent 30%);animation:spin 4s linear infinite}
.torus span:nth-child(2){inset:18px;border-width:10px;animation-duration:3s;animation-direction:reverse;opacity:.7}
.torus span:nth-child(3){inset:38px;border-width:7px;animation-duration:2.2s;opacity:.5}
.torus__core{width:46px;height:46px;border-radius:50%;background:radial-gradient(circle at 40% 35%,var(--accent2),#000);box-shadow:0 0 40px color-mix(in oklab,var(--accent2),transparent 30%)}
@keyframes spin{to{transform:rotate(360deg)}}
.steam{position:absolute;top:-6px;left:50%;transform:translateX(-50%);display:flex;gap:12px}
.steam i{width:5px;height:42px;background:linear-gradient(transparent,color-mix(in oklab,#fff,transparent 40%),transparent);border-radius:50%;filter:blur(2px);animation:steam 3s ease-in-out infinite}
.steam i:nth-child(2){animation-delay:.5s}.steam i:nth-child(3){animation-delay:1s}
@keyframes steam{0%{opacity:0;transform:translateY(10px) scaleX(1)}50%{opacity:.7}100%{opacity:0;transform:translateY(-26px) scaleX(1.6)}}
/* pizza sacred geometry */
.sacred{width:210px;height:210px;color:color-mix(in oklab,var(--accent) 70%,transparent);opacity:.6}
.sacred circle{stroke-dasharray:290;stroke-dashoffset:290;transition:stroke-dashoffset 1.4s var(--ease)}
.world--pizza.in .sacred circle{stroke-dashoffset:0}
.slice{position:absolute;font-size:74px;filter:drop-shadow(0 10px 20px rgba(0,0,0,.3));transition:transform .5s var(--ease)}
.world--pizza:hover .slice{transform:rotate(14deg) scale(1.1)}
/* signal screen */
.screen{width:230px;height:150px;border-radius:8px;background:#05060c;border:1px solid var(--line);position:relative;overflow:hidden;box-shadow:0 0 50px color-mix(in oklab,var(--accent2),transparent 60%)}
.screen__flicker{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent 0 2px,rgba(255,255,255,.04) 2px 4px);animation:flick 4s steps(12) infinite}
.screen__beam{position:absolute;top:0;left:-40%;width:40%;height:100%;background:linear-gradient(90deg,transparent,color-mix(in oklab,var(--accent2),transparent 40%),transparent);animation:sweep 5s var(--ease) infinite}
@keyframes flick{0%,100%{opacity:.6}50%{opacity:1}}
@keyframes sweep{0%{left:-40%}60%,100%{left:120%}}
.projector{position:absolute;bottom:-12px;left:50%;transform:translateX(-50%);width:30px;height:18px;background:var(--ink);border-radius:3px;opacity:.5}
/* cloches */
.world__art--cloches{display:flex;gap:14px;align-items:flex-end;justify-content:center;height:230px}
.cloche{position:relative;width:88px;height:120px;display:grid;justify-items:center;align-content:end;cursor:none}
.cloche__cookie{font-size:40px;transform:translateY(8px) scale(.9);transition:transform .5s var(--ease)}
.cloche__glass{position:absolute;left:50%;top:6px;transform:translateX(-50%);width:80px;height:96px;border-radius:50% 50% 8px 8px/60% 60% 8px 8px;background:linear-gradient(135deg,color-mix(in oklab,#fff,transparent 78%),color-mix(in oklab,#fff,transparent 94%));border:1px solid color-mix(in oklab,#fff,transparent 70%);backdrop-filter:blur(2px);transition:transform .55s var(--ease),opacity .4s}
.cloche__glass::before{content:"";position:absolute;top:-9px;left:50%;transform:translateX(-50%);width:12px;height:12px;border-radius:50%;background:inherit;border:1px solid color-mix(in oklab,#fff,transparent 70%)}
.cloche b{font-family:var(--mono);font-size:8.5px;letter-spacing:.04em;text-transform:uppercase;color:color-mix(in oklab,var(--ink) 70%,transparent);margin-top:6px;text-align:center;line-height:1.3}
.cloche:hover .cloche__glass{transform:translateX(-50%) translateY(-34px);opacity:.4}
.cloche:hover .cloche__cookie{transform:translateY(-4px) scale(1.25) rotate(-6deg)}
.worlds__hint{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:color-mix(in oklab,var(--ink) 55%,transparent);text-align:center;margin-top:20px}

/* ─────────────  COOKIE LAB / CIRCULATION  ───────────── */
.lab__head{max-width:760px;margin:0 auto clamp(50px,7vw,90px);text-align:center}
.lab__head .kicker{justify-content:center}
.lab__head .lede{margin-inline:auto;text-align:center}
.circulation{position:relative;width:min(620px,90vw);aspect-ratio:1;margin:0 auto}
.circulation__ring{position:absolute;inset:8%;border-radius:50%;border:1px dashed color-mix(in oklab,var(--accent) 60%,transparent);animation:spin 60s linear infinite}
.circulation__ring::before{content:"";position:absolute;inset:14%;border-radius:50%;border:1px solid var(--line)}
.circulation__steps{list-style:none;position:absolute;inset:0}
.circulation__steps li{position:absolute;top:50%;left:50%;width:180px;text-align:center;
  transform:translate(-50%,-50%) rotate(calc(var(--i)*72deg)) translateY(calc(-1*min(290px,42vw))) rotate(calc(var(--i)*-72deg));}
.circulation__steps .num{display:inline-grid;place-content:center;width:34px;height:34px;border-radius:50%;background:var(--accent);color:var(--bg);font-family:var(--serif);font-weight:600;margin-bottom:8px}
.circulation__steps b{display:block;font-family:var(--serif);font-size:1.05rem;margin-bottom:4px}
.circulation__steps p{font-size:.78rem;line-height:1.4;color:color-mix(in oklab,var(--ink) 72%,transparent)}
.circulation__center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:160px;height:160px;border-radius:50%;display:grid;place-content:center;text-align:center;background:radial-gradient(circle,color-mix(in oklab,var(--accent2),transparent 55%),transparent 70%)}
.circulation__center span{font-family:var(--serif);font-size:1.3rem;line-height:1.15}
.circulation__center em{color:var(--accent)}
@media(max-width:680px){
  .circulation__steps li{width:130px;transform:translate(-50%,-50%) rotate(calc(var(--i)*72deg)) translateY(-40vw) rotate(calc(var(--i)*-72deg))}
  .circulation__steps p{display:none}
}

/* ─────────────  MICRO-MOMENTS  ───────────── */
.micro{text-align:center;overflow:hidden}
.micro__inner{max-width:820px;margin-inline:auto;position:relative;z-index:2}
.micro .kicker{justify-content:center}
.micro .lede{margin:30px auto 0;text-align:center}
.micro .lede b{color:var(--accent);font-size:1.2em}
.mirror{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-top:60px;height:120px;perspective:600px}
.mirror i{background:linear-gradient(160deg,color-mix(in oklab,var(--accent2),transparent 40%),color-mix(in oklab,var(--accent),transparent 55%));border-radius:6px;opacity:.5;animation:mirrorPulse 4s ease-in-out infinite;transform-style:preserve-3d}
.mirror i:nth-child(odd){animation-delay:.6s;transform:rotateY(18deg)}
.mirror i:nth-child(3n){animation-delay:1.1s;transform:rotateY(-18deg)}
@keyframes mirrorPulse{50%{opacity:1;transform:translateY(-10px) rotateY(0)}}

/* ─────────────  WEEK BOARD  ───────────── */
.week__head{max-width:var(--maxw);margin:0 auto clamp(36px,5vw,60px)}
.week__board{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;max-width:var(--maxw);margin-inline:auto;min-height:300px}
.day{position:relative;border:1px solid var(--line);border-radius:14px;padding:20px 16px;text-align:left;overflow:hidden;transition:flex .5s,background .5s var(--ease),border-color .4s;background:var(--glass);display:flex;flex-direction:column;gap:8px;min-height:200px}
.day__d{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}
.day b{font-family:var(--serif);font-size:1.15rem;font-weight:500;line-height:1.15}
.day p{font-size:.82rem;color:color-mix(in oklab,var(--ink) 72%,transparent);opacity:0;transform:translateY(10px);transition:.5s var(--ease)}
.day.is-active{background:color-mix(in oklab,var(--accent),transparent 78%);border-color:var(--accent)}
.day.is-active p{opacity:1;transform:none}
.day::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:3px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.day.is-active::after{transform:scaleX(1)}
@media(max-width:820px){.week__board{grid-template-columns:1fr 1fr;min-height:0}.day p{opacity:1;transform:none}}

/* ─────────────  VISIT  ───────────── */
.visit{text-align:center;min-height:92vh;display:grid;place-content:center}
.visit__inner{max-width:980px;margin-inline:auto}
.visit .display.huge span{display:block}
.signup{display:flex;gap:10px;max-width:480px;margin:44px auto 18px;flex-wrap:wrap;justify-content:center}
.signup input{flex:1;min-width:220px;padding:18px 22px;border-radius:40px;border:1px solid var(--line);background:var(--glass);color:var(--ink);font-family:var(--mono);font-size:13px;backdrop-filter:blur(8px)}
.signup input::placeholder{color:color-mix(in oklab,var(--ink) 50%,transparent)}
.signup input:focus{outline:none;border-color:var(--accent)}
.visit__fine{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:color-mix(in oklab,var(--ink) 55%,transparent)}

/* ─────────────  FOOTER  ───────────── */
.footer{text-align:center;display:grid;justify-items:center;gap:22px;padding-block:clamp(70px,10vw,130px)}
.footer__mark svg{width:64px;height:52px;color:var(--ink);opacity:.8}
.footer__tag{font-family:var(--serif);font-style:italic;font-size:clamp(1.6rem,4vw,2.6rem)}
.footer__nav{display:flex;gap:24px;font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase}
.footer__nav a{opacity:.7;transition:opacity .3s,color .3s}
.footer__nav a:hover{opacity:1;color:var(--accent)}
.footer__fine{font-size:12px;color:color-mix(in oklab,var(--ink) 50%,transparent);max-width:48ch}

/* ─────────────  HOTSPOTS + LORE  ───────────── */
.hotspot{position:absolute;left:var(--hx);top:var(--hy);width:34px;height:34px;border-radius:50%;z-index:5;cursor:none}
.hotspot::before{content:"";position:absolute;inset:0;border-radius:50%;border:1px solid var(--accent);animation:ripple 2.6s var(--ease) infinite}
.hotspot::after{content:"✦";position:absolute;inset:0;display:grid;place-content:center;color:var(--accent);font-size:13px;text-shadow:0 0 12px var(--accent)}
.hotspot.found{opacity:.25;pointer-events:none}
.hotspot.found::before{animation:none}
@keyframes ripple{0%{transform:scale(.5);opacity:1}100%{transform:scale(2.4);opacity:0}}
.lore{position:fixed;inset:0;z-index:9500;display:grid;place-content:center;opacity:0;visibility:hidden;transition:.5s var(--ease)}
.lore.open{opacity:1;visibility:visible}
.lore__scrim{position:absolute;inset:0;background:color-mix(in oklab,var(--night-bg),transparent 25%);backdrop-filter:blur(8px);cursor:none}
.lore__card{position:relative;width:min(460px,88vw);background:var(--bg);border:1px solid var(--accent);border-radius:20px;padding:46px 38px;text-align:center;transform:scale(.85) translateY(20px);transition:.5s var(--ease);box-shadow:0 40px 100px rgba(0,0,0,.5)}
.lore.open .lore__card{transform:none}
.lore__key{font-size:24px;color:var(--accent);text-shadow:0 0 24px var(--accent)}
.lore__eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin:14px 0 8px}
.lore__title{font-family:var(--serif);font-size:1.8rem;font-weight:500;margin-bottom:14px}
.lore__body{font-size:1rem;line-height:1.6;color:color-mix(in oklab,var(--ink) 85%,transparent)}
.lore__btn{margin-top:26px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);border-bottom:1px solid var(--accent);padding-bottom:3px}

/* ─────────────  REDUCED MOTION  ───────────── */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.001s!important}
  .reveal{opacity:1;transform:none}
  #fog-canvas{display:none}#fog-fallback{display:block}
  .hero__title .word{transform:none}
}
