/* =========================================================================
   Time Until Christmas — "Midnight Frost & Gold"
   A magical winter-night theme. Dark indigo sky, aurora, gold-forward accents.
   ========================================================================= */

:root {
  /* Night sky */
  --night-0:#05081a;
  --night-1:#0a0f2b;
  --night-2:#111a44;
  --night-3:#1b2a63;

  /* Frost & ink */
  --snow:#f7fbff;
  --ink:#e7edff;
  --ink-soft:#aebada;
  --ink-faint:#6f7ca6;

  /* Festive accents */
  --gold:#f6d27a;
  --gold-2:#f0b94e;
  --gold-deep:#c8932f;
  --red:#ff5d6c;
  --red-2:#e2354a;
  --pine:#48e3a2;
  --pine-2:#16a06a;
  --cyan:#67e8f9;
  --violet:#9d8bf5;

  --glass: rgba(20,30,72,0.45);
  --glass-line: rgba(160,185,255,0.16);
  --glass-hi: rgba(255,255,255,0.06);

  --radius: 22px;
  --radius-sm: 13px;
  --shadow: 0 30px 80px -30px rgba(0,0,0,0.7);

  --font-display:"Fraunces", Georgia, "Times New Roman", serif;
  --font-body:"Hanken Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --wrap: 1140px;
}

/* ----- Reset ----- */
*,*::before,*::after { box-sizing:border-box; }
* { margin:0; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; overflow-x:clip; }
body {
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--night-0);
  line-height:1.6;
  min-height:100vh;
  overflow-x:hidden;
  position:relative;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
button { font:inherit; color:inherit; cursor:pointer; border:none; background:none; }
input,textarea { font:inherit; color:inherit; }
::selection { background:var(--gold); color:var(--night-0); }

/* =========================================================================
   Background atmosphere
   ========================================================================= */
body::before {
  /* base sky gradient + aurora pools */
  content:"";
  position:fixed; inset:0; z-index:-3;
  background:
    radial-gradient(120% 80% at 50% -10%, #1a2a66 0%, transparent 55%),
    radial-gradient(90% 60% at 85% 8%, rgba(157,139,245,0.16) 0%, transparent 60%),
    radial-gradient(70% 50% at 10% 18%, rgba(72,227,162,0.12) 0%, transparent 60%),
    linear-gradient(180deg, var(--night-1) 0%, var(--night-0) 38%, #04060f 100%);
}

.layer {
  position:fixed; inset:0; width:100%; height:100%;
  z-index:-2; pointer-events:none;
}
#snow { z-index:-1; }

.grain {
  position:fixed; inset:0; z-index:1; pointer-events:none; opacity:0.5;
  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='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.55'/%3E%3C/svg%3E");
}

/* Aurora bands — slow drifting light */
.aurora { position:fixed; inset:0; z-index:-2; pointer-events:none; overflow:hidden; }
.aurora__band {
  position:absolute; left:-20%; right:-20%; height:46vh;
  filter:blur(60px); opacity:0.5; border-radius:50%;
  mix-blend-mode:screen;
}
.aurora__band--1 { top:-8vh; background:radial-gradient(50% 100% at 50% 50%, rgba(103,232,249,0.42), transparent 70%); animation:auroraDrift 26s ease-in-out infinite; }
.aurora__band--2 { top:2vh; background:radial-gradient(50% 100% at 50% 50%, rgba(72,227,162,0.35), transparent 70%); animation:auroraDrift 34s ease-in-out infinite reverse; }
.aurora__band--3 { top:-4vh; background:radial-gradient(50% 100% at 50% 50%, rgba(157,139,245,0.30), transparent 70%); animation:auroraDrift 44s ease-in-out infinite; }
.aurora__moon {
  position:absolute; top:9vh; right:14vw; width:90px; height:90px; border-radius:50%;
  background:radial-gradient(circle at 35% 30%, #fff 0%, #f3eecf 40%, #d9c98f 75%, #b9a563 100%);
  box-shadow:0 0 60px 18px rgba(246,210,122,0.45), inset -10px -8px 22px rgba(120,100,40,0.4);
}
@keyframes auroraDrift {
  0%,100% { transform:translateX(-6%) translateY(0) scaleY(1); opacity:0.45; }
  50% { transform:translateX(8%) translateY(2vh) scaleY(1.15); opacity:0.65; }
}

/* Sleigh flyover */
.sleigh {
  position:fixed; top:16vh; left:-12vw; z-index:0; font-size:2.2rem;
  filter:drop-shadow(0 4px 10px rgba(0,0,0,0.5));
  opacity:0; pointer-events:none;
}
.sleigh.fly { animation:sleighFly 9s linear forwards; }
@keyframes sleighFly {
  0% { transform:translate(0,0) rotate(-6deg); opacity:0; }
  8% { opacity:1; }
  50% { transform:translate(55vw,-7vh) rotate(-9deg); }
  92% { opacity:1; }
  100% { transform:translate(124vw,4vh) rotate(-4deg); opacity:0; }
}

/* =========================================================================
   Top bar
   ========================================================================= */
.topbar {
  position:sticky; top:0; z-index:30;
  display:flex; align-items:center; gap:1.2rem;
  padding:0.85rem clamp(1rem,4vw,2.4rem);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  background:linear-gradient(180deg, rgba(7,11,31,0.72), rgba(7,11,31,0.18));
  border-bottom:1px solid rgba(160,185,255,0.08);
}
.brand { display:flex; align-items:center; gap:0.6rem; font-family:var(--font-display); font-weight:600; }
.brand__mark { color:var(--cyan); filter:drop-shadow(0 0 8px rgba(103,232,249,0.6)); animation:spinSlow 18s linear infinite; }
@keyframes spinSlow { to { transform:rotate(360deg); } }
.brand__text { font-size:1.15rem; letter-spacing:0.2px; }
.brand__text em { font-style:normal; background:linear-gradient(120deg,var(--gold),var(--red-2)); -webkit-background-clip:text; background-clip:text; color:transparent; }

.topnav { margin-left:auto; display:flex; gap:1.6rem; font-size:0.92rem; font-weight:600; color:var(--ink-soft); }
.topnav a { position:relative; padding:0.2rem 0; transition:color .25s; }
.topnav a::after { content:""; position:absolute; left:0; bottom:-2px; width:0; height:2px; background:linear-gradient(90deg,var(--gold),var(--red)); transition:width .3s; border-radius:2px; }
.topnav a:hover { color:var(--snow); }
.topnav a:hover::after { width:100%; }

.controls { display:flex; gap:0.5rem; }
.ctrl {
  display:flex; align-items:center; gap:0.45rem;
  padding:0.5rem 0.8rem; border-radius:999px;
  background:var(--glass); border:1px solid var(--glass-line);
  font-size:0.82rem; font-weight:600; color:var(--ink-soft);
  transition:transform .2s, border-color .2s, color .2s;
}
.ctrl:hover { transform:translateY(-1px); color:var(--snow); border-color:rgba(246,210,122,0.5); }
.ctrl[aria-pressed="false"] { opacity:0.5; }
.ctrl__icon { font-size:0.95rem; }

/* =========================================================================
   Layout helpers
   ========================================================================= */
.wrap { width:min(var(--wrap), 92vw); margin-inline:auto; }
.band { padding:clamp(4rem,9vw,8rem) 0; position:relative; z-index:2; }
.band__head { text-align:center; max-width:640px; margin:0 auto clamp(2.5rem,5vw,4rem); }
.eyebrow {
  display:inline-block; font-weight:700; letter-spacing:0.28em; text-transform:uppercase;
  font-size:0.72rem; color:var(--gold); margin-bottom:0.9rem;
  padding:0.3rem 0.9rem; border:1px solid rgba(246,210,122,0.3); border-radius:999px;
  background:rgba(246,210,122,0.06);
}
h2 { font-family:var(--font-display); font-weight:600; font-size:clamp(1.9rem,4.5vw,3rem); line-height:1.08; letter-spacing:-0.02em; }
.lede { color:var(--ink-soft); margin-top:0.9rem; font-size:1.05rem; }

/* =========================================================================
   Hero
   ========================================================================= */
.hero {
  position:relative; z-index:2;
  min-height:100svh; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center;
  padding:6rem 1rem 9rem;
}
.hero__inner { max-width:920px; }
.kicker {
  color:var(--ink-soft); font-weight:600; letter-spacing:0.12em; text-transform:uppercase;
  font-size:0.8rem; margin-bottom:1.4rem;
}
.kicker__dot { color:var(--cyan); }

.hero__title {
  font-family:var(--font-display);
  font-weight:600; line-height:0.95; letter-spacing:-0.03em;
  font-size:clamp(2.6rem,9vw,6rem);
  margin-bottom:0.4rem;
}
.hero__count {
  display:block;
  background:linear-gradient(180deg,#fff 0%, var(--gold) 45%, var(--gold-deep) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  text-shadow:0 0 60px rgba(246,210,122,0.25);
  font-variant-numeric:tabular-nums; font-weight:800;
  font-size:clamp(4.5rem,18vw,11rem); line-height:0.85;
}
.hero__unit { display:block; font-size:clamp(1.5rem,5vw,3rem); color:var(--snow); font-weight:500; }
.hero__sub { color:var(--ink-soft); font-size:1.1rem; margin-bottom:2.6rem; }
.hero__sub strong { color:var(--gold); }

/* Odometer countdown */
.countdown {
  display:flex; align-items:flex-start; justify-content:center; gap:clamp(0.3rem,2vw,1rem);
  margin-bottom:2.8rem;
}
.cd-unit { display:flex; flex-direction:column; align-items:center; gap:0.6rem; }
.cd-tile {
  position:relative; overflow:hidden;
  min-width:clamp(64px,15vw,108px); padding:0.7rem 0.5rem 0.6rem;
  border-radius:var(--radius-sm);
  background:linear-gradient(180deg, rgba(34,48,104,0.65), rgba(12,18,46,0.55));
  border:1px solid var(--glass-line);
  box-shadow:inset 0 1px 0 var(--glass-hi), 0 14px 30px -16px rgba(0,0,0,0.8);
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
}
.cd-tile::after { /* frost cap */
  content:""; position:absolute; inset:0 0 auto 0; height:42%;
  background:linear-gradient(180deg, rgba(255,255,255,0.10), transparent);
  pointer-events:none;
}
.cd-num {
  display:block; font-family:var(--font-display); font-weight:800;
  font-size:clamp(2rem,7vw,3.6rem); line-height:1; text-align:center;
  font-variant-numeric:tabular-nums; color:var(--snow);
  text-shadow:0 0 22px rgba(103,232,249,0.25);
}
.cd-num.tick { animation:tick .5s ease; }
@keyframes tick { 0%{ transform:translateY(-32%); opacity:0; filter:blur(2px);} 60%{ filter:blur(0);} 100%{ transform:translateY(0); opacity:1; } }
.cd-label { font-size:0.72rem; letter-spacing:0.22em; text-transform:uppercase; color:var(--ink-faint); font-weight:700; }
.cd-sep { font-family:var(--font-display); font-size:clamp(1.6rem,5vw,2.8rem); color:var(--ink-faint); margin-top:0.5rem; animation:blink 2s steps(1) infinite; }
@keyframes blink { 50% { opacity:0.25; } }

/* Year progress ring */
.progress { display:flex; flex-direction:column; align-items:center; gap:0.7rem; margin-top:0.5rem; }
.progress__ring {
  --p:0;
  width:120px; height:120px; border-radius:50%;
  display:grid; place-items:center;
  background:
    radial-gradient(closest-side, var(--night-1) 79%, transparent 80% 100%),
    conic-gradient(var(--gold) calc(var(--p)*1%), rgba(160,185,255,0.12) 0);
  box-shadow:0 0 30px -8px rgba(246,210,122,0.4);
  transition:--p 1.2s ease;
}
.progress__pct { font-family:var(--font-display); font-weight:700; font-size:1.5rem; color:var(--gold); }
.progress__cap { max-width:240px; font-size:0.85rem; color:var(--ink-faint); }

/* Scroll cue */
.scrollcue { display:block; width:26px; height:42px; margin:2.4rem auto 0; border:2px solid rgba(160,185,255,0.4); border-radius:999px; position:relative; }
.scrollcue span { position:absolute; top:7px; left:50%; width:4px; height:8px; margin-left:-2px; border-radius:2px; background:var(--gold); animation:cue 1.6s ease-in-out infinite; }
@keyframes cue { 0%,100%{ transform:translateY(0); opacity:1; } 70%{ transform:translateY(14px); opacity:0; } }

/* Horizon */
.hero__horizon { position:absolute; bottom:0; left:0; right:0; height:38vh; z-index:1; pointer-events:none; overflow:hidden; }
.hero__hills { position:absolute; bottom:0; width:100%; height:100%; }
.hill--back { fill:#10173a; opacity:0.85; }
.hill--mid { fill:#0b1130; }
.hill--front { fill:#070b22; }
.trees { position:absolute; bottom:4%; left:0; right:0; height:60%; }
.tree {
  position:absolute; bottom:0; width:0; height:0;
  border-left:var(--w) solid transparent; border-right:var(--w) solid transparent;
  border-bottom:var(--h) solid #0a1430;
  filter:drop-shadow(0 -1px 0 rgba(160,185,255,0.08));
}
.tree::after { content:"❄"; position:absolute; top:calc(var(--h)*-1); left:50%; transform:translateX(-50%); font-size:0.6rem; color:var(--gold); opacity:0.8; }

/* =========================================================================
   Timeline / road to Christmas
   ========================================================================= */
.timeline { position:relative; padding:2rem 0 0; }
.timeline__track { position:relative; height:6px; border-radius:999px; background:rgba(160,185,255,0.12); margin:0 auto 2.4rem; }
.timeline__fill { position:absolute; inset:0 auto 0 0; width:0; border-radius:999px; background:linear-gradient(90deg,var(--pine),var(--gold) 70%,var(--red)); transition:width 1.6s cubic-bezier(.2,.7,.2,1); box-shadow:0 0 18px rgba(246,210,122,0.5); }
.timeline__sled { position:absolute; top:50%; left:0; transform:translate(-50%,-60%); font-size:1.4rem; transition:left 1.6s cubic-bezier(.2,.7,.2,1); filter:drop-shadow(0 3px 6px rgba(0,0,0,0.5)); }
.timeline__stops { list-style:none; display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; padding:0; }
.tl-stop { text-align:center; position:relative; padding-top:1rem; }
.tl-stop::before { content:""; position:absolute; top:-2.9rem; left:50%; transform:translateX(-50%); width:14px; height:14px; border-radius:50%; background:var(--night-2); border:2px solid var(--ink-faint); transition:.3s; }
.tl-stop.done::before { background:var(--gold); border-color:var(--gold); box-shadow:0 0 14px var(--gold); }
.tl-stop.now::before { background:var(--red); border-color:var(--red); box-shadow:0 0 16px var(--red); animation:pulse 1.8s infinite; }
@keyframes pulse { 0%,100%{ box-shadow:0 0 10px var(--red);} 50%{ box-shadow:0 0 24px var(--red);} }
.tl-stop__emoji { font-size:1.5rem; }
.tl-stop__name { font-family:var(--font-display); font-weight:600; font-size:1.05rem; margin-top:0.2rem; }
.tl-stop__date { font-size:0.8rem; color:var(--ink-faint); }
.tl-stop__when { font-size:0.82rem; color:var(--gold); font-weight:600; margin-top:0.2rem; }

/* =========================================================================
   Cards / toolkit
   ========================================================================= */
.cards { display:grid; grid-template-columns:repeat(auto-fit,minmax(310px,1fr)); gap:clamp(1rem,2.4vw,1.8rem); }
.card {
  position:relative; isolation:isolate;
  padding:1.6rem 1.5rem; border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(22,33,78,0.55), rgba(10,15,40,0.5));
  border:1px solid var(--glass-line);
  box-shadow:var(--shadow), inset 0 1px 0 var(--glass-hi);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  transition:transform .35s cubic-bezier(.2,.7,.2,1), border-color .35s;
  overflow:hidden;
}
.card:hover { transform:translateY(-6px); border-color:rgba(246,210,122,0.35); }
.card__glow {
  position:absolute; z-index:-1; inset:-2px;
  background:radial-gradient(circle at var(--mx,50%) var(--my,0%), rgba(246,210,122,0.18), transparent 45%);
  opacity:0; transition:opacity .35s;
}
.card:hover .card__glow { opacity:1; }
.card__head { display:flex; align-items:center; gap:0.7rem; margin-bottom:0.6rem; }
.card__emoji { font-size:1.6rem; filter:drop-shadow(0 2px 6px rgba(0,0,0,0.4)); }
.card h3 { font-family:var(--font-display); font-weight:600; font-size:1.3rem; letter-spacing:-0.01em; }
.card__desc { color:var(--ink-soft); font-size:0.92rem; margin-bottom:1.2rem; }

/* Form bits */
.field { margin-bottom:1rem; }
.field label { display:block; font-size:0.78rem; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:0.4rem; }
.input-money { display:flex; align-items:center; background:rgba(5,8,26,0.6); border:1px solid var(--glass-line); border-radius:var(--radius-sm); padding:0 0.9rem; transition:border-color .2s, box-shadow .2s; }
.input-money:focus-within { border-color:var(--gold); box-shadow:0 0 0 3px rgba(246,210,122,0.15); }
.input-money span { color:var(--ink-faint); font-weight:700; }
.input-money input { background:none; border:none; outline:none; padding:0.75rem 0.5rem; width:100%; font-size:1.05rem; font-weight:600; }
input[type=text], textarea {
  width:100%; background:rgba(5,8,26,0.6); border:1px solid var(--glass-line);
  border-radius:var(--radius-sm); padding:0.75rem 0.9rem; outline:none; resize:vertical;
  transition:border-color .2s, box-shadow .2s;
}
input[type=text]:focus, textarea:focus { border-color:var(--gold); box-shadow:0 0 0 3px rgba(246,210,122,0.15); }
input[type=number]::-webkit-outer-spin-button, input[type=number]::-webkit-inner-spin-button { -webkit-appearance:none; }

/* Segmented control */
.seg { display:flex; gap:0.3rem; padding:0.3rem; background:rgba(5,8,26,0.6); border:1px solid var(--glass-line); border-radius:999px; margin-bottom:1.1rem; }
.seg__btn { flex:1; padding:0.5rem; border-radius:999px; font-size:0.85rem; font-weight:700; color:var(--ink-soft); transition:.25s; }
.seg__btn.is-active { background:linear-gradient(120deg,var(--gold),var(--gold-2)); color:var(--night-0); box-shadow:0 6px 16px -6px rgba(246,210,122,0.6); }

/* Chips */
.chips { display:flex; flex-wrap:wrap; gap:0.4rem; margin-bottom:1.1rem; }
.chip { padding:0.4rem 0.85rem; border-radius:999px; font-size:0.82rem; font-weight:600; color:var(--ink-soft); background:rgba(5,8,26,0.55); border:1px solid var(--glass-line); transition:.2s; }
.chip.is-active { color:var(--night-0); background:linear-gradient(120deg,var(--pine),var(--cyan)); border-color:transparent; }
.chip:hover { transform:translateY(-1px); }

/* Buttons */
.btn {
  display:inline-flex; align-items:center; gap:0.5rem; justify-content:center;
  width:100%; padding:0.85rem 1.2rem; border-radius:999px;
  font-weight:700; letter-spacing:0.01em; position:relative; overflow:hidden;
  transition:transform .2s, box-shadow .2s, filter .2s;
}
.btn::before { content:""; position:absolute; inset:0; background:linear-gradient(120deg,transparent 30%, rgba(255,255,255,0.45) 50%, transparent 70%); transform:translateX(-120%); transition:transform .6s; }
.btn:hover::before { transform:translateX(120%); }
.btn:hover { transform:translateY(-2px); }
.btn:active { transform:translateY(0) scale(.99); }
.btn--gold { background:linear-gradient(120deg,var(--gold),var(--gold-2)); color:var(--night-0); box-shadow:0 14px 30px -12px rgba(246,210,122,0.7); }
.btn--pine { background:linear-gradient(120deg,var(--pine),var(--pine-2)); color:#04140d; box-shadow:0 14px 30px -12px rgba(72,227,162,0.6); }
.btn--red { background:linear-gradient(120deg,var(--red),var(--red-2)); color:#fff; box-shadow:0 14px 30px -12px rgba(255,93,108,0.6); }
.btn--ghost { width:auto; background:rgba(5,8,26,0.5); border:1px solid var(--glass-line); color:var(--ink); }
.btn--ghost:hover { border-color:var(--gold); }

/* Results */
.result { display:block; margin-top:1.1rem; min-height:1.5rem; font-size:0.95rem; color:var(--ink); }
.result:empty { display:none; }
.result.show { animation:popIn .45s cubic-bezier(.2,.9,.3,1.2); }
@keyframes popIn { from { opacity:0; transform:translateY(8px) scale(.96);} to { opacity:1; transform:none; } }
.result .big { font-family:var(--font-display); font-size:1.8rem; font-weight:700; color:var(--gold); display:block; }
.result .muted { color:var(--ink-faint); font-size:0.85rem; }

.result--gift .gift-line { display:flex; align-items:center; gap:0.6rem; font-size:1.05rem; padding:0.9rem 1rem; border-radius:var(--radius-sm); background:rgba(72,227,162,0.08); border:1px solid rgba(72,227,162,0.25); }
.result--gift .gift-emoji { font-size:1.6rem; }

.result--santa ul { list-style:none; padding:0; display:grid; gap:0.4rem; }
.result--santa li { display:flex; align-items:center; gap:0.5rem; padding:0.55rem 0.8rem; border-radius:var(--radius-sm); background:rgba(5,8,26,0.5); border:1px solid var(--glass-line); font-size:0.92rem; }
.result--santa .arrow { color:var(--gold); font-weight:800; }
.result--santa .giver { font-weight:700; }

.result--elf { text-align:center; }
.result--elf .elf-name { font-family:var(--font-display); font-size:2rem; font-weight:800; background:linear-gradient(120deg,var(--gold),var(--red)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.result--elf .elf-job { color:var(--ink-soft); font-size:0.9rem; }

.result--nice { text-align:center; }
.result--nice .verdict { font-family:var(--font-display); font-size:1.6rem; font-weight:700; }
.result--nice .verdict.nice { color:var(--pine); }
.result--nice .verdict.naughty { color:var(--red); }
.result--nice .verdict.mid { color:var(--gold); }

.result--movie .movie-pick { text-align:center; }
.result--movie .movie-title { font-family:var(--font-display); font-size:1.7rem; font-weight:700; color:var(--gold); }
.result--movie .movie-meta { color:var(--ink-soft); font-size:0.9rem; }

/* Naughty/nice meter */
.meter { position:relative; width:160px; height:84px; margin:0 auto 1rem; overflow:hidden; }
.meter__face { position:absolute; inset:0; border-radius:160px 160px 0 0; background:conic-gradient(from 270deg at 50% 100%, var(--pine) 0deg, var(--gold) 90deg, var(--red) 180deg); -webkit-mask:radial-gradient(closest-side at 50% 100%, transparent 54%, #000 55%); mask:radial-gradient(closest-side at 50% 100%, transparent 54%, #000 55%); opacity:0.85; }
.meter__needle { position:absolute; bottom:0; left:50%; width:3px; height:74px; background:var(--snow); transform-origin:bottom center; transform:translateX(-50%) rotate(0deg); border-radius:3px; box-shadow:0 0 8px rgba(255,255,255,0.6); transition:transform 2.4s cubic-bezier(.16,.84,.3,1); z-index:2; }
.meter__needle::after { content:""; position:absolute; bottom:-6px; left:50%; transform:translateX(-50%); width:14px; height:14px; border-radius:50%; background:var(--snow); }

/* =========================================================================
   Fun facts
   ========================================================================= */
.factcard {
  position:relative; max-width:760px; margin:0 auto;
  padding:clamp(2rem,5vw,3.5rem); border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(22,33,78,0.55), rgba(10,15,40,0.5));
  border:1px solid var(--glass-line);
  box-shadow:var(--shadow), inset 0 1px 0 var(--glass-hi);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
}
.factcard__quote { position:absolute; top:-0.4em; left:0.3em; font-family:var(--font-display); font-size:7rem; line-height:1; color:rgba(246,210,122,0.18); }
.factcard__text { font-family:var(--font-display); font-size:clamp(1.3rem,3.2vw,1.9rem); font-weight:500; line-height:1.4; min-height:3em; }
.factcard__text.swap { animation:factSwap .5s ease; }
@keyframes factSwap { 0%{ opacity:0; transform:translateY(10px); filter:blur(3px);} 100%{ opacity:1; transform:none; filter:blur(0);} }
.factcard__foot { display:flex; align-items:center; justify-content:space-between; gap:1rem; margin-top:1.6rem; flex-wrap:wrap; }
.factcard__count { color:var(--ink-faint); font-size:0.85rem; font-weight:600; letter-spacing:0.05em; }

/* =========================================================================
   Footer
   ========================================================================= */
.footer { position:relative; z-index:2; padding:4rem 0 5rem; text-align:center; border-top:1px solid rgba(160,185,255,0.08); margin-top:2rem; background:linear-gradient(180deg, transparent, rgba(4,6,15,0.6)); }
.footer__wish { font-family:var(--font-display); font-size:1.5rem; }
.footer__wish em { font-style:normal; background:linear-gradient(120deg,var(--gold),var(--red)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.footer__by { color:var(--ink-soft); margin-top:0.6rem; }
.footer__by a { color:var(--gold); font-weight:700; border-bottom:1px solid transparent; transition:border-color .2s; }
.footer__by a:hover { border-color:var(--gold); }
.footer__meta { color:var(--ink-faint); font-size:0.82rem; margin-top:0.8rem; letter-spacing:0.04em; }
.cookie-reopen { appearance:none; border:0; background:none; padding:0; font:inherit; color:var(--ink-faint); text-decoration:underline; text-underline-offset:2px; cursor:pointer; transition:color .2s; }
.cookie-reopen:hover { color:var(--gold); }
.footer__meta a { color:var(--ink-faint); text-decoration:underline; text-underline-offset:2px; transition:color .2s; }
.footer__meta a:hover { color:var(--gold); }

/* =========================================================================
   Legal / privacy prose
   ========================================================================= */
.legal { padding-top:clamp(6rem,12vw,9rem); min-height:72vh; }
.legal__wrap { max-width:760px; }
.legal__title { font-family:var(--font-display); font-weight:600; font-size:clamp(2.2rem,6vw,3.4rem); line-height:1.05; letter-spacing:-0.02em; }
.legal__body { color:var(--ink-soft); font-size:1.02rem; line-height:1.7; }
.legal__body h2 { font-family:var(--font-display); font-weight:600; color:var(--snow); font-size:1.4rem; margin:2.2rem 0 0.6rem; letter-spacing:-0.01em; }
.legal__body p { margin-bottom:1rem; }
.legal__body ul { margin:0 0 1rem; padding-left:1.2rem; display:grid; gap:0.55rem; }
.legal__body li { padding-left:0.2rem; }
.legal__body strong { color:var(--ink); }
.legal__body a { color:var(--gold); text-decoration:underline; text-underline-offset:2px; }
.legal__body .cookie-reopen { color:var(--gold); }
.legal__back { margin-top:2.4rem; font-weight:700; }

/* =========================================================================
   Cookie consent pill (reused from shiprekt, re-themed)
   ========================================================================= */
.cookie-pill {
  position:fixed; left:0; right:0; bottom:18px; margin:0 auto;
  width:fit-content; max-width:min(680px, calc(100vw - 24px));
  z-index:96; display:flex; align-items:center; gap:14px;
  padding:11px 13px 11px 20px; border-radius:999px;
  border:1px solid var(--glass-line);
  background:linear-gradient(180deg, rgba(22,33,78,0.92), rgba(10,15,40,0.9));
  -webkit-backdrop-filter:blur(20px) saturate(150%);
  backdrop-filter:blur(20px) saturate(150%);
  box-shadow:var(--shadow);
  animation:ckpIn .45s cubic-bezier(.2,.7,.2,1);
}
.cookie-pill[hidden] { display:none; }
@keyframes ckpIn { from { opacity:0; transform:translateY(24px); } to { opacity:1; transform:none; } }
.ckp-text { flex:1; min-width:0; margin:0; font-size:0.86rem; line-height:1.45; color:var(--ink-soft); }
.ckp-text a { color:var(--gold); text-decoration:underline; text-underline-offset:2px; white-space:nowrap; font-weight:600; }
.ckp-btns { flex:0 0 auto; display:flex; gap:8px; }
.ckp-btn { width:auto; padding:0.6rem 1.2rem; font-size:0.85rem; }
@media (max-width:560px) {
  .cookie-pill { width:auto; left:12px; right:12px; bottom:12px; flex-direction:column; align-items:stretch; gap:10px; border-radius:var(--radius); padding:14px 16px; }
  .ckp-btns .ckp-btn { flex:1; }
}

/* =========================================================================
   Reveal-on-scroll
   ========================================================================= */
.reveal { opacity:0; transform:translateY(26px); transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity:1; transform:none; }
.hero .reveal { transition-delay:calc(var(--i,0) * 0.09s); }

/* =========================================================================
   Responsive
   ========================================================================= */
@media (max-width:780px) {
  .topnav { display:none; }
  .controls { margin-left:auto; }
  .ctrl__label { display:none; }
  .cd-sep { display:none; }
  .countdown { gap:0.6rem; }

  /* Timeline → vertical glass cards (the horizontal track + hanging dots
     don't survive a 2-up grid, so swap to a clean stacked list). */
  .timeline { padding-top:0.5rem; }
  .timeline__track { display:none; }
  .timeline__stops { grid-template-columns:1fr; gap:0.7rem; }
  .tl-stop {
    display:flex; align-items:center; gap:0.9rem; text-align:left;
    padding:0.85rem 1rem;
    background:linear-gradient(180deg, rgba(22,33,78,0.5), rgba(10,15,40,0.45));
    border:1px solid var(--glass-line); border-radius:var(--radius-sm);
  }
  .tl-stop::before { display:none; }
  .tl-stop__emoji { font-size:1.9rem; line-height:1; flex:0 0 auto; }
  .tl-stop__body { display:flex; flex-direction:column; gap:0.1rem; min-width:0; }
  .tl-stop__name { margin-top:0; }
  .tl-stop__when {
    align-self:flex-start; margin-top:0.3rem;
    padding:0.12rem 0.62rem; border-radius:999px;
    background:rgba(246,210,122,0.12);
  }
  .tl-stop.done { border-color:rgba(246,210,122,0.3); }
  .tl-stop.done .tl-stop__when { background:rgba(72,227,162,0.14); color:var(--pine); }
  .tl-stop.now { border-color:rgba(255,93,108,0.5); box-shadow:0 0 18px -6px var(--red); }
  .tl-stop.now .tl-stop__when { background:rgba(255,93,108,0.16); color:var(--red); }
}
@media (max-width:480px) {
  .brand__text { font-size:1rem; }
  .hero { padding-top:4rem; }
  .kicker { letter-spacing:0.08em; font-size:0.72rem; }
}

/* =========================================================================
   Reduced motion / accessibility
   ========================================================================= */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
  .reveal { opacity:1; transform:none; }
}
:focus-visible { outline:2px solid var(--gold); outline-offset:3px; border-radius:6px; }
