/* ============================================================
   Retirement Countdown — style
   Deep-space aurora + neon glassmorphism. Mobile-first, scales up.
   ============================================================ */
:root{
  --bg0:#0a0420; --bg1:#160a36; --bg2:#1f0b46;
  --ink:#f4eefe; --muted:#b9a9e8;
  --magenta:#ff3ca6; --violet:#9b5cff; --cyan:#28e7ff; --gold:#ffd34d; --lime:#7bffb0;
  --card:rgba(255,255,255,.06); --card-brd:rgba(255,255,255,.14);
  --glow: 0 0 28px;
  --grad: linear-gradient(110deg, var(--magenta), var(--violet) 40%, var(--cyan) 75%, var(--lime));
  --maxw: 1080px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Outfit',system-ui,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(1200px 800px at 15% -10%, rgba(155,92,255,.30), transparent 60%),
    radial-gradient(1000px 700px at 100% 0%, rgba(40,231,255,.18), transparent 55%),
    radial-gradient(900px 900px at 50% 120%, rgba(255,60,166,.22), transparent 60%),
    linear-gradient(160deg, var(--bg0), var(--bg1) 50%, var(--bg2));
  background-attachment:fixed;
  min-height:100dvh; overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
canvas#bg,canvas#fx{position:fixed; inset:0; width:100vw; height:100dvh; z-index:0; pointer-events:none}
canvas#fx{z-index:60}
main{position:relative; z-index:10; max-width:var(--maxw); margin:0 auto; padding:0 20px 80px}

/* ---------- top bar ---------- */
.topbar{position:relative; z-index:20; max-width:var(--maxw); margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; padding:18px 20px 0}
.brand{font-weight:700; letter-spacing:.35em; font-size:.72rem; color:var(--muted)}
.controls{display:flex; gap:10px}
.chip{font-family:inherit; font-size:.78rem; font-weight:500; color:var(--ink);
  background:var(--card); border:1px solid var(--card-brd); border-radius:999px;
  padding:8px 14px; cursor:pointer; backdrop-filter:blur(8px); transition:.2s}
.chip:hover{border-color:var(--violet); box-shadow:var(--glow) rgba(155,92,255,.4); transform:translateY(-1px)}
.chip[aria-pressed="true"]{border-color:var(--lime); color:var(--lime)}

/* ---------- hero ---------- */
.hero{position:relative; text-align:center; padding:46px 0 8px}
.eyebrow{display:inline-block; font-weight:700; letter-spacing:.4em; font-size:.8rem;
  color:var(--gold); padding:8px 16px; border:1px solid rgba(255,211,77,.35); border-radius:999px;
  background:rgba(255,211,77,.07); text-shadow:0 0 16px rgba(255,211,77,.5)}
.title{font-family:'Fraunces',serif; font-weight:900; line-height:.9; margin:.28em 0 .1em;
  font-size:clamp(3.2rem, 14vw, 9.5rem); letter-spacing:-.02em;
  text-shadow:0 0 60px rgba(155,92,255,.45)}
.title .word{display:inline-block}
.title .grad{background:var(--grad); background-size:280% 280%;
  -webkit-background-clip:text; background-clip:text; color:transparent;
  animation:flow 9s ease infinite}
@keyframes flow{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.subtitle{font-size:clamp(1.05rem,3.6vw,1.5rem); color:var(--muted); margin:.2em 0 0; font-weight:300}
.subtitle b{color:var(--ink); font-weight:700}
.hero-glow{position:absolute; left:50%; top:46%; width:min(620px,90vw); height:280px;
  transform:translate(-50%,-50%);
  background:radial-gradient(closest-side, rgba(155,92,255,.30), transparent 70%); filter:blur(18px); z-index:-1}

/* ---------- countdown ---------- */
.countdown{display:flex; align-items:stretch; justify-content:center; gap:clamp(6px,1.6vw,18px);
  margin:30px auto 8px; flex-wrap:nowrap}
.unit{flex:1 1 0; min-width:0; max-width:200px; text-align:center;
  background:var(--card); border:1px solid var(--card-brd); border-radius:20px;
  padding:clamp(12px,2.4vw,26px) clamp(4px,1vw,10px); backdrop-filter:blur(10px);
  box-shadow:0 10px 40px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.08)}
.num{font-family:'Fraunces',serif; font-weight:900; line-height:1;
  font-size:clamp(2.2rem,9vw,5.4rem);
  background:linear-gradient(180deg,#fff, #d9c8ff); -webkit-background-clip:text; background-clip:text; color:transparent;
  text-shadow:0 0 30px rgba(155,92,255,.55); font-variant-numeric:tabular-nums; letter-spacing:-.02em}
.unit:nth-child(1) .num{filter:drop-shadow(0 0 12px rgba(255,60,166,.5))}
.unit:nth-child(3) .num{filter:drop-shadow(0 0 12px rgba(155,92,255,.5))}
.unit:nth-child(5) .num{filter:drop-shadow(0 0 12px rgba(40,231,255,.5))}
.unit:nth-child(7) .num{filter:drop-shadow(0 0 12px rgba(123,255,176,.5))}
.lab{margin-top:8px; font-size:clamp(.6rem,1.8vw,.85rem); letter-spacing:.25em; text-transform:uppercase; color:var(--muted)}
.sep{display:flex; align-items:center; font-family:'Fraunces',serif; font-weight:900;
  font-size:clamp(1.6rem,6vw,3.4rem); color:var(--violet); opacity:.5; animation:blink 2s steps(2,start) infinite}
@keyframes blink{50%{opacity:.12}}
.num.tick{animation:pop .5s ease}
@keyframes pop{0%{transform:translateY(-6px) scale(1.12); filter:brightness(1.6)}100%{transform:none}}

.cta-row{text-align:center; margin:26px 0 8px}
.btn-celebrate{font-family:inherit; font-weight:700; font-size:1.05rem; color:#1a0630;
  background:var(--grad); background-size:200% 200%; border:0; border-radius:999px;
  padding:15px 34px; cursor:pointer; box-shadow:var(--glow) rgba(255,60,166,.55), 0 8px 30px rgba(0,0,0,.4);
  animation:flow 6s ease infinite; transition:transform .15s}
.btn-celebrate:hover{transform:translateY(-2px) scale(1.03)}
.btn-celebrate:active{transform:scale(.97)}

/* ---------- progress ---------- */
.progress-wrap{max-width:760px; margin:40px auto 8px}
.progress-head{display:flex; justify-content:space-between; font-size:.82rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--muted); margin-bottom:10px}
.progress-head span:last-child{color:var(--gold); font-weight:700}
.progress-track{position:relative; height:18px; border-radius:999px;
  background:rgba(255,255,255,.07); border:1px solid var(--card-brd); overflow:hidden}
.progress-fill{height:100%; width:0%; border-radius:999px; background:var(--grad); background-size:200% 200%;
  animation:flow 6s ease infinite; box-shadow:0 0 22px rgba(155,92,255,.6); transition:width 1.2s cubic-bezier(.2,.8,.2,1)}
.progress-flag{position:absolute; top:50%; left:0; transform:translate(-50%,-55%); font-size:1.2rem;
  transition:left 1.2s cubic-bezier(.2,.8,.2,1); filter:drop-shadow(0 0 6px rgba(0,0,0,.6))}

/* ---------- stats ---------- */
.stats{display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:14px; margin:46px auto; max-width:920px}
.stat{background:var(--card); border:1px solid var(--card-brd); border-radius:18px; padding:20px 16px; text-align:center;
  backdrop-filter:blur(8px); transition:.25s; position:relative; overflow:hidden}
.stat:hover{transform:translateY(-3px); border-color:var(--violet); box-shadow:var(--glow) rgba(155,92,255,.35)}
.stat .emoji{font-size:1.7rem}
.stat .big{font-family:'Fraunces',serif; font-weight:900; font-size:1.9rem; margin:.1em 0 .05em;
  background:linear-gradient(180deg,#fff,#cdb8ff); -webkit-background-clip:text; background-clip:text; color:transparent;
  font-variant-numeric:tabular-nums}
.stat .cap{font-size:.78rem; color:var(--muted); line-height:1.3}

/* ---------- wishes ---------- */
.wishes{max-width:760px; margin:64px auto 0}
.wishes-title{font-family:'Fraunces',serif; font-weight:900; font-size:clamp(1.6rem,5vw,2.4rem); text-align:center; margin:0}
.wishes-sub{text-align:center; color:var(--muted); margin:.4em 0 1.4em}
.wishes-sub span{color:var(--lime)}
.wish-form{background:var(--card); border:1px solid var(--card-brd); border-radius:20px; padding:18px; backdrop-filter:blur(10px)}
.wish-name,.wish-msg{width:100%; font-family:inherit; color:var(--ink); background:rgba(0,0,0,.25);
  border:1px solid var(--card-brd); border-radius:12px; padding:12px 14px; font-size:1rem; margin-bottom:10px; resize:vertical}
.wish-name:focus,.wish-msg:focus{outline:none; border-color:var(--violet); box-shadow:0 0 0 3px rgba(155,92,255,.25)}
.wish-msg{min-height:84px}
.wish-actions{display:flex; align-items:center; justify-content:space-between}
.wish-counter{font-size:.78rem; color:var(--muted)}
.btn-post{font-family:inherit; font-weight:700; color:#1a0630; background:var(--grad); background-size:200% 200%;
  border:0; border-radius:999px; padding:11px 24px; cursor:pointer; animation:flow 6s ease infinite; transition:transform .15s}
.btn-post:hover{transform:translateY(-1px) scale(1.03)}
.btn-post:disabled{opacity:.5; cursor:default; animation:none; transform:none}
.wish-status{font-size:.82rem; margin-top:8px; min-height:1.1em; color:var(--lime)}
.wish-status.err{color:var(--magenta)}

.wish-wall{margin-top:22px; columns:2; column-gap:14px}
@media (max-width:560px){.wish-wall{columns:1}}
.wish-card{break-inside:avoid; margin:0 0 14px; background:var(--card); border:1px solid var(--card-brd);
  border-radius:16px; padding:14px 16px; backdrop-filter:blur(8px); animation:rise .5s ease both}
@keyframes rise{from{opacity:0; transform:translateY(14px)}to{opacity:1; transform:none}}
.wish-card .msg{font-size:1rem; line-height:1.45; color:var(--ink)}
.wish-card .who{margin-top:8px; font-size:.82rem; color:var(--gold); font-weight:700}
.wish-card .when{color:var(--muted); font-weight:400}

.foot{text-align:center; color:var(--muted); margin-top:60px; font-size:.85rem}

/* ---------- RETIRED overlay ---------- */
.retired-overlay{position:fixed; inset:0; z-index:80; display:grid; place-items:center;
  background:radial-gradient(closest-side, rgba(20,6,40,.6), rgba(10,4,32,.92)); backdrop-filter:blur(4px)}
/* respect the `hidden` attribute — a class display rule otherwise defeats the
   UA [hidden]{display:none}, which made the finale overlay show on load */
.retired-overlay[hidden]{display:none}
.retired-card{text-align:center; padding:30px}
.retired-big{font-family:'Fraunces',serif; font-weight:900; font-size:clamp(3rem,16vw,9rem);
  background:var(--grad); background-size:260% 260%; -webkit-background-clip:text; background-clip:text; color:transparent;
  animation:flow 5s ease infinite; text-shadow:0 0 80px rgba(255,60,166,.5)}
.retired-sub{font-size:1.2rem; color:var(--ink); margin:.2em 0 1.2em}

/* ---------- motion-reduced ---------- */
@media (prefers-reduced-motion:reduce){
  *{animation:none !important; transition:none !important}
}
