@font-face { font-family:'Sora'; font-weight:200; font-style:normal; font-display:swap;
  src:url('fonts/sora-latin-200-normal.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Sora'; font-weight:200; font-style:normal; font-display:swap;
  src:url('fonts/sora-latin-ext-200-normal.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF; }
@font-face { font-family:'Sora'; font-weight:300; font-style:normal; font-display:swap;
  src:url('fonts/sora-latin-300-normal.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Sora'; font-weight:300; font-style:normal; font-display:swap;
  src:url('fonts/sora-latin-ext-300-normal.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF; }
@font-face { font-family:'Sora'; font-weight:400; font-style:normal; font-display:swap;
  src:url('fonts/sora-latin-400-normal.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Sora'; font-weight:400; font-style:normal; font-display:swap;
  src:url('fonts/sora-latin-ext-400-normal.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF; }

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

[data-theme="dark"] {
  --bg:#0A0806;
  --title:rgba(255,252,245,.95); --accent:rgba(220,188,135,.88);
  --sub:rgba(200,170,120,.64); --counter:rgba(200,170,120,.6); --hint:rgba(200,170,120,.48);
  --cta:rgba(200,170,120,.52); --brand:rgba(200,170,120,.46); --micro:rgba(200,170,120,.42); --ghost:rgba(200,170,120,.56);
  --title-shadow:0 0 40px rgba(10,8,6,.95), 0 0 80px rgba(10,8,6,.8), 0 2px 4px rgba(10,8,6,.9);
  --in-bg:rgba(255,250,240,.06); --in-border:rgba(200,170,120,.18); --in-focus:rgba(200,170,120,.4); --in-text:rgba(255,250,240,.92);
  --btn-bg:rgba(200,170,120,.14); --btn-border:rgba(200,170,120,.26); --btn-text:rgba(255,250,240,.9);
  --btn-ghost:rgba(200,170,120,.62); --btn-ghost-bdr:rgba(200,170,120,.2);
  --tog-bdr:rgba(200,170,120,.15); --tog-on:rgba(255,250,240,.95); --tog-off:rgba(200,170,120,.55); --tog-on-bg:rgba(200,170,120,.15);
  --grad:linear-gradient(transparent,rgba(10,8,6,.88) 30%,rgba(10,8,6,.99));
  --flash:rgba(255,250,240,.95); --flash-glow:rgba(200,170,120,.35);
  --cr-bg:rgba(10,8,6,.97); --cr-text:rgba(255,250,240,.9); --cr-sub:rgba(200,170,120,.65);
  --ph:rgba(200,170,120,.46); --blur:saturate(120%) blur(18px); --pill-bg:rgba(10,8,6,.45);
}
[data-theme="light"] {
  --bg:#ECE6D9;
  --title:rgba(25,18,8,.94); --accent:rgba(110,82,40,.84);
  --sub:rgba(90,68,32,.62); --counter:rgba(90,68,32,.6); --hint:rgba(90,68,32,.48);
  --cta:rgba(90,68,32,.56); --brand:rgba(90,68,32,.5); --micro:rgba(90,68,32,.46); --ghost:rgba(90,68,32,.6);
  --title-shadow:0 0 40px rgba(236,230,217,.95), 0 0 80px rgba(236,230,217,.8), 0 2px 4px rgba(236,230,217,.9);
  --in-bg:rgba(25,18,8,.05); --in-border:rgba(110,82,40,.24); --in-focus:rgba(110,82,40,.48); --in-text:rgba(25,18,8,.88);
  --btn-bg:rgba(110,82,40,.1); --btn-border:rgba(110,82,40,.28); --btn-text:rgba(25,18,8,.86);
  --btn-ghost:rgba(90,68,32,.66); --btn-ghost-bdr:rgba(110,82,40,.22);
  --tog-bdr:rgba(110,82,40,.15); --tog-on:rgba(25,18,8,.92); --tog-off:rgba(110,82,40,.56); --tog-on-bg:rgba(110,82,40,.14);
  --grad:linear-gradient(transparent,rgba(236,230,217,.88) 30%,rgba(236,230,217,.99));
  --flash:rgba(25,18,8,.92); --flash-glow:rgba(110,82,40,.15);
  --cr-bg:rgba(236,230,217,.97); --cr-text:rgba(25,18,8,.9); --cr-sub:rgba(110,82,40,.62);
  --ph:rgba(110,82,40,.48); --blur:saturate(110%) blur(16px); --pill-bg:rgba(236,230,217,.5);
}

html, body { height:100%; }
body {
  background:var(--bg); color:var(--title);
  font-family:'Sora', system-ui, sans-serif;
  overflow:hidden;
  transition:background .5s ease;
  -webkit-font-smoothing:antialiased;
}

.noscript { text-align:center; padding:20vh 20px; color:var(--title); }
.noscript a { color:var(--accent); }

#app { position:fixed; inset:0; overflow:hidden; }

#wall { position:fixed; inset:0; overflow:hidden; pointer-events:none; z-index:4; }
.drop {
  position:absolute; top:0; left:0;
  display:flex; align-items:baseline; gap:6px;
  line-height:1.4; letter-spacing:.01em;
  max-width:min(260px,62vw); overflow-wrap:break-word; word-break:break-word;
  user-select:none; -webkit-user-select:none; cursor:pointer;
  pointer-events:auto; will-change:transform,opacity;
  transform-origin:left center;
  transition:transform .2s ease-out, color .12s ease;
}
.drop.voted { cursor:default; }
.drop .vote { font-weight:300; white-space:nowrap; flex-shrink:0; }

.plus-one {
  position:absolute; z-index:60; pointer-events:none;
  font-size:12px; font-weight:300; color:var(--accent);
  animation:uP 1s ease forwards;
}

#title {
  position:fixed; top:6%; left:50%; transform:translateX(-50%);
  text-align:center; z-index:10; pointer-events:none; width:90%; max-width:600px;
}
#title .sub { font-size:clamp(9px,1.8vw,11px); font-weight:300; letter-spacing:.3em; text-transform:uppercase; color:var(--sub); margin-bottom:6px; text-shadow:var(--title-shadow); }
#title h1 { font-size:clamp(28px,8vw,52px); font-weight:200; color:var(--title); line-height:1.15; letter-spacing:-.02em; text-shadow:var(--title-shadow); }
#title h1 .accent { color:var(--accent); }
#title .counter { margin-top:8px; font-size:clamp(10px,1.8vw,12px); font-weight:300; color:var(--counter); letter-spacing:.05em; text-shadow:var(--title-shadow); }
#title .hint { margin-top:3px; font-size:clamp(8px,1.3vw,10px); font-weight:200; color:var(--hint); letter-spacing:.05em; font-style:italic; text-shadow:var(--title-shadow); }

#controls { position:fixed; top:10px; right:12px; z-index:20; display:flex; gap:5px; }
.pill { display:flex; background:var(--pill-bg); -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px); border:1px solid var(--tog-bdr); border-radius:6px; overflow:hidden; }
.tog { padding:4px 10px; font-size:10px; font-weight:200; font-family:inherit; letter-spacing:.08em; color:var(--tog-off); background:transparent; border:none; cursor:pointer; text-transform:uppercase; transition:all .3s ease; }
.tog.on { font-weight:400; color:var(--tog-on); background:var(--tog-on-bg); }

.pill-btn {
  position:fixed; top:12px; left:12px; z-index:20;
  background:var(--pill-bg); -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px);
  border:1px solid var(--tog-bdr); border-radius:6px;
  color:var(--micro); font-size:9px; font-weight:200; font-family:inherit; letter-spacing:.06em;
  padding:5px 10px; cursor:pointer; transition:color .3s ease;
}
.pill-btn:hover { color:var(--ghost); }

#flash {
  position:fixed; top:38%; left:50%; transform:translate(-50%,-50%);
  font-size:clamp(17px,4vw,24px); font-weight:200; color:var(--flash);
  text-align:center; max-width:80%; z-index:50; line-height:1.4;
  text-shadow:0 0 40px var(--flash-glow); pointer-events:none;
  animation:uFl 3.2s ease forwards;
}

#bottom {
  position:fixed; bottom:0; left:0; right:0; z-index:20;
  background:var(--grad); -webkit-backdrop-filter:var(--blur); backdrop-filter:var(--blur);
  padding:40px 16px calc(16px + env(safe-area-inset-bottom));
}
#inputPhase { max-width:460px; margin:0 auto; display:flex; gap:8px; align-items:center; }
#msgInput {
  flex:1; background:var(--in-bg); border:1px solid var(--in-border); border-radius:8px;
  padding:12px 14px; font-size:14px; font-weight:200; font-family:inherit; color:var(--in-text);
  outline:none; transition:border-color .3s ease;
}
#msgInput:focus { border-color:var(--in-focus); }
#msgInput::placeholder { color:var(--ph); }
#submitBtn {
  background:var(--btn-bg); border:1px solid var(--btn-border); border-radius:8px;
  padding:12px 16px; font-size:12px; font-weight:300; font-family:inherit; color:var(--btn-text);
  cursor:pointer; letter-spacing:.06em; white-space:nowrap; transition:all .3s ease;
}
#submitBtn:disabled { background:transparent; border-color:var(--in-border); color:var(--micro); cursor:default; }

#submittedPhase { text-align:center; animation:uF 1s ease; }
#submittedPhase .after { font-size:13px; font-weight:200; color:var(--btn-ghost); margin-bottom:12px; }
#againBtn, .cr-back {
  background:none; border:1px solid var(--btn-ghost-bdr); border-radius:6px;
  padding:7px 18px; font-size:11px; font-weight:300; font-family:inherit; color:var(--btn-ghost);
  cursor:pointer; transition:all .3s ease;
}
#againBtn:hover { color:var(--accent); border-color:var(--ghost); }

#cta { text-align:center; margin-top:12px; }
.ar-card {
  max-width:380px; margin:0 auto; padding:14px 20px 16px;
  border:1px solid var(--in-border); border-radius:12px; background:var(--in-bg);
}
.cta-warm { font-size:11px; font-weight:300; color:var(--ghost); line-height:1.5; margin-bottom:11px; }
.cta-brand { display:inline-flex; align-items:center; justify-content:center; gap:7px; text-decoration:none; }
.cta-brand:hover .cta-name { text-decoration:underline; }
.cta-mark { width:18px; height:18px; color:var(--accent); flex-shrink:0; }
.cta-name { font-size:17px; font-weight:300; color:var(--title); letter-spacing:.01em; }
.cta-tagline { margin-top:5px; font-size:10.5px; font-weight:300; letter-spacing:.04em; color:var(--accent); }
.cta-desc { margin-top:9px; font-size:10.5px; font-weight:200; color:var(--cta); line-height:1.55; }
.foot { margin-top:14px; display:flex; align-items:center; justify-content:center; gap:9px; }
.foot a { font-size:9px; font-weight:300; letter-spacing:.16em; text-transform:uppercase; color:var(--brand); text-decoration:none; cursor:pointer; transition:color .3s ease; }
.foot a:hover { color:var(--accent); }
.foot-sep { font-size:9px; color:var(--micro); }

#crisis { position:fixed; inset:0; z-index:1000; background:var(--cr-bg); display:flex; align-items:center; justify-content:center; animation:uF .4s ease; }
.crisis-box { max-width:400px; padding:36px 28px; text-align:center; }
.crisis-box .cr1 { font-size:17px; font-weight:200; color:var(--cr-text); line-height:1.6; margin-bottom:8px; }
.crisis-box .cr2 { font-size:15px; font-weight:200; color:var(--cr-sub); line-height:1.6; margin-bottom:28px; }
.cr-link { display:inline-block; padding:12px 24px; background:rgba(180,150,100,.08); border:1px solid rgba(180,150,100,.18); border-radius:8px; color:var(--cr-text); font-size:13px; font-weight:300; text-decoration:none; }
.cr-back { border:none; color:var(--ghost); font-size:11px; font-weight:200; margin-top:24px; padding:0; }

[hidden] { display:none !important; }

@keyframes uFl { 0%{opacity:0;transform:translate(-50%,-50%) scale(.96)} 15%{opacity:1;transform:translate(-50%,-50%) scale(1)} 65%{opacity:1} 100%{opacity:0;transform:translate(-50%,-50%) scale(1.01)} }
@keyframes uF { from{opacity:0;transform:translateY(5px)} to{opacity:1;transform:translateY(0)} }
@keyframes uP { 0%{opacity:0;transform:translateY(0)} 20%{opacity:1} 100%{opacity:0;transform:translateY(-24px)} }

@media (prefers-reduced-motion:reduce) {
  .drop { transition:none; }
  #flash { animation-duration:3.2s; }
}
