:root{
  --bg:#0a0d12; --panel:#11161e; --frame:#2c3642; --green:#3ee87a; --amber:#f2c05c;
  --red:#ff5a52; --white:#e4e9ee; --muted:#8794a0; --blue:#6cb6ff;
  --mono:ui-monospace,SFMono-Regular,Menlo,Consolas,"DejaVu Sans Mono",monospace;
  --ui:system-ui,-apple-system,"Apple SD Gothic Neo","Noto Sans KR",sans-serif;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{margin:0;background:#05070a;color:var(--white);font-family:var(--ui);}
body{min-height:100dvh;}
.app{max-width:560px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;background:var(--bg);position:relative;}
.bar{display:flex;align-items:center;gap:8px;padding:9px 12px;background:#0e131b;border-bottom:1px solid var(--frame);flex:0 0 auto;}
.dot{width:11px;height:11px;border-radius:50%;}
.dot.r{background:#ff5f56;}.dot.y{background:#ffbd2e;}.dot.g{background:#27c93f;}
.bartitle{color:var(--muted);font-size:12px;font-family:var(--mono);margin-left:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.counter{margin-left:auto;color:var(--green);font-size:12px;font-family:var(--mono);}

.game{flex:1;display:flex;flex-direction:column;min-height:0;}
.hidden{display:none!important;}

/* ===== 게임 ===== */
.play{flex:1;display:flex;flex-direction:column;min-height:0;padding:12px;gap:10px;}
.topbar{display:flex;align-items:center;font-family:var(--mono);font-size:13px;flex:0 0 auto;}
.progress{color:var(--amber);font-weight:700;}
.meter{margin-left:auto;color:var(--green);}

.prompt{flex:0 0 auto;background:var(--panel);border:1px solid var(--frame);border-radius:14px;padding:14px 16px;text-align:center;}
.plabel{color:var(--muted);font-size:12px;margin-bottom:6px;}
.word{font-size:38px;font-weight:800;color:var(--amber);letter-spacing:1px;line-height:1.1;word-break:keep-all;}
.banned{margin-top:10px;display:flex;flex-wrap:wrap;gap:6px;justify-content:center;}
.banned .b{font-size:12px;color:var(--red);border:1px solid rgba(255,90,82,.4);background:rgba(255,90,82,.08);
  border-radius:20px;padding:3px 10px;text-decoration:line-through;text-decoration-color:rgba(255,90,82,.7);}
.banned .blab{font-size:11px;color:var(--muted);align-self:center;margin-right:2px;}

.chat{flex:1;min-height:80px;overflow-y:auto;display:flex;flex-direction:column;gap:9px;padding:4px 2px;-webkit-overflow-scrolling:touch;}
.msg{max-width:84%;padding:10px 13px;border-radius:14px;font-size:15px;line-height:1.45;word-break:break-word;animation:pop .18s ease;}
@keyframes pop{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}
.msg.me{align-self:flex-end;background:#16361f;border:1px solid rgba(62,232,122,.35);color:#d6ffe4;border-bottom-right-radius:4px;}
.msg.ai{align-self:flex-start;background:var(--panel);border:1px solid var(--frame);border-bottom-left-radius:4px;}
.msg.ai .who{display:block;font-size:11px;color:var(--green);font-family:var(--mono);margin-bottom:3px;}
.msg.ai .guesses{font-weight:700;color:var(--white);}
.msg.sys{align-self:center;background:transparent;color:var(--muted);font-size:13px;font-family:var(--mono);padding:4px;}
.msg.ok{align-self:center;background:rgba(62,232,122,.12);border:1px solid rgba(62,232,122,.5);color:var(--green);font-weight:800;font-size:16px;}
.msg.foul{align-self:center;background:rgba(255,90,82,.12);border:1px solid rgba(255,90,82,.5);color:var(--red);font-weight:700;font-size:14px;}
.typing{display:inline-flex;gap:4px;}
.typing i{width:6px;height:6px;border-radius:50%;background:var(--muted);animation:blink 1s infinite;}
.typing i:nth-child(2){animation-delay:.2s;}.typing i:nth-child(3){animation-delay:.4s;}
@keyframes blink{0%,60%,100%{opacity:.25;}30%{opacity:1;}}

.inputrow{flex:0 0 auto;display:flex;gap:8px;}
.clue-input{flex:1;min-width:0;background:#070a0e;border:1px solid var(--frame);border-radius:12px;
  color:var(--white);font-size:16px;font-family:var(--ui);padding:13px 14px;outline:none;}
.clue-input:focus{border-color:var(--green);}
.clue-input.shake{animation:shake .35s;border-color:var(--red);}
@keyframes shake{0%,100%{transform:translateX(0);}25%{transform:translateX(-6px);}75%{transform:translateX(6px);}}
.subrow{flex:0 0 auto;display:flex;align-items:center;margin-top:-2px;}
.linkbtn{background:none;border:none;color:var(--muted);font-size:13px;cursor:pointer;padding:4px 0;font-family:var(--ui);}
.linkbtn:hover{color:var(--white);}
.hint-mini{margin-left:auto;color:var(--muted);font-size:12px;font-family:var(--mono);}

.btn{font-family:var(--ui);font-size:15px;cursor:pointer;background:transparent;color:var(--white);
  border:1px solid var(--frame);border-radius:12px;padding:13px 18px;text-decoration:none;display:inline-block;text-align:center;}
.btn:disabled{opacity:.5;cursor:default;}
.btn.key{border-color:var(--green);color:var(--green);}
.btn.big{font-size:17px;padding:14px 24px;width:100%;}

/* ===== 오버레이 (시작/결과) ===== */
.overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(5,7,10,.92);z-index:10;padding:22px;text-align:center;backdrop-filter:blur(3px);}
.overlay.hidden{display:none;}
.ov-card{max-width:420px;width:100%;display:flex;flex-direction:column;gap:14px;}
.logo{font-size:34px;font-weight:900;color:var(--amber);}
.tagline{color:var(--white);font-size:16px;line-height:1.6;}
.howto{color:var(--muted);font-size:13px;}
.reveal{color:var(--muted);font-size:12px;font-family:var(--mono);margin-top:6px;}
.reveal b,.tagline b{color:var(--green);}
.reveal.small{text-align:center;margin-top:16px;}

/* 결과 카드 (오버레이 내부) */
.result .ctitle{font-size:15px;color:var(--green);font-family:var(--mono);}
.scorebig{font-size:64px;font-weight:900;color:var(--green);line-height:1;font-family:var(--mono);}
.scorebig .unit{font-size:24px;color:var(--green);}
.rtitle{font-size:26px;font-weight:800;color:var(--amber);}
.gauge{height:12px;background:#0a0f16;border:1px solid var(--frame);border-radius:7px;overflow:hidden;}
.gauge span{display:block;height:100%;background:var(--green);}
.rsub{color:var(--muted);font-size:13px;}
.rlist{text-align:left;display:flex;flex-direction:column;gap:5px;background:var(--panel);border:1px solid var(--frame);border-radius:12px;padding:12px 14px;}
.rrow{display:flex;font-size:14px;}
.rrow .rw{font-weight:700;}.rrow .rc{margin-left:auto;font-family:var(--mono);font-size:13px;}
.rrow.ok .rc{color:var(--green);}.rrow.no .rc{color:var(--muted);}
.rbest{color:var(--muted);font-size:13px;}.rbest b{color:var(--amber);}

/* ===== 공유 페이지 ===== */
.sharepage{align-items:center;justify-content:flex-start;gap:16px;padding:20px;}
.sharecard{background:var(--panel);border:1px solid var(--frame);border-radius:18px;padding:22px;width:100%;max-width:460px;}
.sc-h{color:var(--green);font-family:var(--mono);font-size:14px;}
.sc-score{display:flex;align-items:baseline;gap:6px;margin:8px 0 4px;}
.sc-score .big{font-size:56px;font-weight:900;color:var(--green);font-family:var(--mono);line-height:1;}
.sc-score .unit{font-size:22px;color:var(--green);}
.sc-score .sc-title{margin-left:auto;font-size:24px;font-weight:800;color:var(--amber);}
.sc-gauge{height:12px;background:#0a0f16;border:1px solid var(--frame);border-radius:7px;overflow:hidden;margin:8px 0;}
.sc-gauge span{display:block;height:100%;background:var(--green);}
.sc-sub{color:var(--muted);font-size:13px;margin-bottom:12px;}.sc-sub b{color:var(--white);}
.sc-rounds{display:flex;flex-direction:column;gap:5px;}
.sc-best{color:var(--muted);font-size:14px;margin-top:14px;}.sc-best b{color:var(--amber);}
