/* PENTA — styles. Dark, mobile-first, pink accent to match dogonthetable.com */
:root{
  --bg:#0e0e12; --bg2:#16161d; --card:#1b1b24; --line:#2a2a36;
  --ink:#f4f4f6; --muted:#9a9aa8; --pink:#ff1493; --pink-dim:#c01070;
  --green:#3aa655; --yellow:#caa613; --grey:#3a3a46;
  --good:#39b15a; --bad:#d2435a;
  --r:14px; --font:"Onest",-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:radial-gradient(120% 80% at 50% -10%, #1c1430 0%, var(--bg) 55%) fixed;
  color:var(--ink); font-family:var(--font);
  min-height:100dvh; -webkit-font-smoothing:antialiased;
  display:flex; flex-direction:column; align-items:center;
}
button{font-family:inherit}
.muted{color:var(--muted)}

/* header */
.top{width:100%;max-width:560px;padding:14px 18px 6px;display:flex;align-items:center;gap:10px}
.brand{display:flex;flex-direction:column;line-height:1;flex:1}
.brand h1{margin:0;font-size:1.7rem;font-weight:800;letter-spacing:.14em;
  background:linear-gradient(90deg,#fff,var(--pink));-webkit-background-clip:text;background-clip:text;color:transparent}
.brand .tag{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:5px}
.icon-btn{background:var(--card);border:1px solid var(--line);color:var(--ink);
  width:38px;height:38px;border-radius:10px;font-size:1.05rem;cursor:pointer;transition:.15s}
.icon-btn:hover{border-color:var(--pink);color:var(--pink)}

.subbar{width:100%;max-width:560px;padding:0 18px;display:flex;justify-content:space-between;align-items:center}
#puz-no{font-weight:700;color:var(--pink)}
#puz-date{font-size:.82rem;color:var(--muted)}
body.is-practice #puz-no{color:#f5a524}
body.is-practice .subbar{background:rgba(245,165,36,.1);border:1px solid rgba(245,165,36,.35);
  border-radius:9px;padding:6px 12px;margin-top:2px}
.practice-again{max-width:360px;margin:16px auto 0;display:block;background:#f5a524;color:#3a2700}
.practice-again:hover{background:#e0951a}

/* progress dots */
#progress{display:flex;gap:8px;justify-content:center;margin:12px 0 4px;width:100%;max-width:560px;padding:0 18px}
.dot{flex:1;height:40px;border-radius:10px;background:var(--bg2);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;font-size:1.05rem;opacity:.5;transition:.2s}
.dot.active{opacity:1;border-color:var(--pink);box-shadow:0 0 0 2px rgba(255,20,147,.25)}
.dot.win{opacity:1;border-color:var(--good);background:rgba(57,177,90,.12)}
.dot.lose{opacity:1;border-color:var(--bad);background:rgba(210,67,90,.1)}

/* stage / cards */
main{width:100%;max-width:560px;padding:8px 18px 40px;flex:1}
#stage{animation:fade .35s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.round-tag{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--pink);font-weight:700;margin-top:6px}
.round-title{font-size:1.55rem;margin:.2rem 0 .15rem;font-weight:800}
.round-sub{margin:0 0 1rem;color:var(--muted);font-size:.95rem;line-height:1.4}

.btn{background:var(--pink);color:#fff;border:none;border-radius:12px;padding:14px 18px;
  font-size:1rem;font-weight:700;cursor:pointer;width:100%;margin-top:18px;transition:.15s}
.btn:hover{background:var(--pink-dim)}
.next-btn{background:linear-gradient(90deg,var(--pink),#ff5bb0)}

.round-end{margin-top:16px;padding:14px;border-radius:12px;background:var(--card);border:1px solid var(--line);text-align:center}
.end-line{margin:0;font-size:1rem}

/* WORD */
.wd-board{display:flex;justify-content:center;margin:2px 0 10px}
.wd-grid{display:grid;grid-template-columns:repeat(5,clamp(44px,15vw,58px));gap:6px}
.wd-tile{aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  font-size:clamp(1.4rem,6vw,2rem);font-weight:800;border:2px solid var(--line);border-radius:6px;text-transform:uppercase;color:var(--ink)}
.wd-tile.filled{border-color:#555}
.wd-tile.correct{background:var(--green);border-color:var(--green);color:#fff}
.wd-tile.present{background:var(--yellow);border-color:var(--yellow);color:#fff}
.wd-tile.absent{background:var(--grey);border-color:var(--grey);color:#cfcfd6}
.wd-tile.shake{animation:shake .45s}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-5px)}40%,80%{transform:translateX(5px)}}
.wd-msg{height:20px;text-align:center;color:var(--pink);font-weight:600;font-size:.85rem;opacity:0;transition:.2s}
.wd-msg.show{opacity:1}
.wd-keys{margin-top:8px;display:flex;flex-direction:column;gap:6px}
.kb-row{display:flex;gap:5px;justify-content:center}
.kb-key{flex:1;max-width:42px;height:50px;border:none;border-radius:7px;background:#3a3a46;color:var(--ink);
  font-size:.95rem;font-weight:700;cursor:pointer;text-transform:uppercase}
.kb-key.wide{max-width:58px;font-size:1.1rem}
.kb-key.correct{background:var(--green);color:#fff}
.kb-key.present{background:var(--yellow);color:#fff}
.kb-key.absent{background:#26262e;color:#6a6a76}
.kb-key:active{transform:translateY(1px)}

/* MC rounds */
.mc-opts{display:flex;flex-direction:column;gap:10px;margin-top:6px}
.mc-opt{text-align:left;padding:16px 18px;border-radius:12px;background:var(--card);border:1px solid var(--line);
  color:var(--ink);font-size:1.05rem;font-weight:600;cursor:pointer;transition:.12s}
.mc-opt:hover:not(:disabled){border-color:var(--pink);transform:translateX(3px)}
.mc-opt:disabled{cursor:default}
.mc-opt.correct{background:rgba(57,177,90,.18);border-color:var(--good);color:#bdf0cb}
.mc-opt.wrong{background:rgba(210,67,90,.16);border-color:var(--bad);color:#f4bcc5}

.flag-prompt{text-align:center;margin:4px 0 14px}
.flag-emoji{font-size:clamp(5rem,28vw,8.5rem);line-height:1;filter:drop-shadow(0 6px 18px rgba(0,0,0,.5))}
.cap-prompt{text-align:center;margin:4px 0 16px}
.cap-flag{font-size:3.4rem;line-height:1}
.cap-country{font-size:1.6rem;font-weight:800;margin-top:6px}
.tr-prompt{font-size:1.2rem;font-weight:700;line-height:1.4;margin:4px 0 16px;
  padding:16px;background:var(--card);border:1px solid var(--line);border-left:3px solid var(--pink);border-radius:12px}

/* GLOBE */
.globe-form{display:flex;gap:8px;margin:4px 0 12px}
.globe-input{flex:1;padding:14px;border-radius:12px;background:var(--bg2);border:1px solid var(--line);
  color:var(--ink);font-size:1rem;font-family:inherit}
.globe-input:focus{outline:none;border-color:var(--pink)}
.globe-input.shake{animation:shake .45s}
.globe-go{width:auto;margin:0;padding:0 22px;flex:0 0 auto}
.globe-left{text-align:center;color:var(--muted);font-size:.82rem;margin-top:4px}
.globe-guesses{display:flex;flex-direction:column;gap:6px}
.g-row{display:grid;grid-template-columns:30px 1fr auto auto;gap:8px;align-items:center;
  padding:9px 12px;border-radius:10px;background:var(--card);border:1px solid var(--line);font-size:.9rem}
.g-row.win{border-color:var(--good);background:rgba(57,177,90,.14)}
.g-flag{font-size:1.25rem}
.g-name{font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.g-dist{color:var(--muted);font-variant-numeric:tabular-nums;font-size:.82rem}
.g-arrow{font-size:1.1rem}
.g-prox{grid-column:1/-1;position:relative;height:16px;border-radius:8px;background:var(--bg2);overflow:hidden;display:flex;align-items:center}
.g-prox-fill{position:absolute;left:0;top:0;bottom:0;border-radius:8px;transition:width .4s}
.g-prox-num{position:relative;margin-left:auto;padding-right:8px;font-size:.7rem;font-weight:700;color:#fff;mix-blend-mode:difference}

/* RESULTS */
.results{text-align:center;padding-top:4px}
.res-emoji{font-size:2.7rem;line-height:1}
.res-title{font-size:2.2rem;margin:.2rem 0 0;font-weight:800}
.res-grade{margin:.05rem 0 .6rem;color:var(--pink);font-weight:700;letter-spacing:.04em}
.share-btn{max-width:360px;margin:6px auto 0;display:block;font-size:1.05rem;
  box-shadow:0 6px 22px rgba(255,20,147,.4);animation:pulseShare 2.2s ease-in-out infinite}
@keyframes pulseShare{0%,100%{box-shadow:0 6px 22px rgba(255,20,147,.34)}50%{box-shadow:0 6px 30px rgba(255,20,147,.6)}}
.wa-btn{max-width:360px;margin:9px auto 0;display:block;font-size:1.02rem;
  background:#25d366;color:#06351a}
.wa-btn:hover{background:#1fbb59}
.share-hint{margin:.55rem 0 1rem;color:var(--muted);font-size:.78rem}
.res-rows{display:flex;flex-direction:column;gap:6px;text-align:left;max-width:360px;margin:0 auto}
.res-row{display:grid;grid-template-columns:28px 1fr auto auto;gap:10px;align-items:center;
  padding:9px 14px;border-radius:11px;background:var(--card);border:1px solid var(--line)}
.res-row.win{border-left:3px solid var(--good)}
.res-row.lose{border-left:3px solid var(--bad)}
.rr-icon{font-size:1.1rem}
.rr-label{font-weight:700}
.rr-detail{color:var(--muted);font-size:.85rem}
.rr-pts{font-weight:800;color:var(--pink);min-width:34px;text-align:right}
.res-stats{display:flex;gap:8px;justify-content:center;margin:14px 0 4px}
.chip{flex:1;max-width:120px;background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:10px}
.chip-num{display:block;font-size:1.5rem;font-weight:800}
.chip-lab{display:block;font-size:.66rem;color:var(--muted);letter-spacing:.03em;margin-top:2px}
.res-foot{margin-top:14px;color:var(--muted);font-size:.85rem;font-variant-numeric:tabular-nums}

/* modals */
#backdrop{position:fixed;inset:0;background:rgba(0,0,0,.6);opacity:0;pointer-events:none;transition:.2s;z-index:40}
#backdrop.open{opacity:1;pointer-events:auto}
.modal{position:fixed;left:50%;top:50%;transform:translate(-50%,-46%) scale(.97);opacity:0;pointer-events:none;
  width:min(92vw,440px);max-height:86dvh;overflow:auto;background:var(--card);border:1px solid var(--line);
  border-radius:18px;padding:24px;z-index:50;transition:.2s}
.modal.open{opacity:1;pointer-events:auto;transform:translate(-50%,-50%) scale(1)}
.modal h3{margin:0 0 .3rem;font-size:1.3rem}
.modal h4{margin:1.1rem 0 .3rem;font-size:.95rem;color:var(--pink)}
.modal p,.modal li{color:#d4d4dc;font-size:.92rem;line-height:1.5}
.modal ul{padding-left:1.1rem;margin:.3rem 0}
.modal .close{position:absolute;top:14px;right:16px;background:none;border:none;color:var(--muted);font-size:1.4rem;cursor:pointer}
.howrow{display:flex;gap:10px;align-items:flex-start;margin:.5rem 0}
.howrow .hi{font-size:1.4rem;flex:0 0 auto}
.legend{display:flex;gap:6px;margin:.4rem 0}
.legend span{display:inline-flex;width:30px;height:30px;align-items:center;justify-content:center;border-radius:5px;font-weight:800;color:#fff}
.lg-c{background:var(--green)}.lg-p{background:var(--yellow)}.lg-a{background:var(--grey)}
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:10px 0}
.stat-grid .chip{max-width:none}
#stat-history{display:flex;gap:4px;align-items:flex-end;height:80px;margin-top:8px;padding:8px;background:var(--bg2);border-radius:10px}
.hist-bar{flex:1;background:linear-gradient(180deg,var(--pink),var(--pink-dim));border-radius:3px;min-height:6px}

footer{width:100%;max-width:560px;padding:10px 18px 24px;text-align:center;color:var(--muted);font-size:.75rem}
footer a{color:var(--muted)}
