:root{--bg: #07140f;--panel: #102820;--panel-2: #16352a;--line: #244b3c;--text: #e9f6ef;--muted: #8fb6a4;--accent: #7ed957;--accent-2: #34d8c4;--gold: #ffd166}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{font-family:Pretendard,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--text);background:radial-gradient(1200px 600px at 50% -10%,#14503c 0%,transparent 60%),linear-gradient(180deg,#08191200,#051009),var(--bg)}.app{min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;padding-left:max(24px,env(safe-area-inset-left));padding-right:max(24px,env(safe-area-inset-right));padding-bottom:max(24px,env(safe-area-inset-bottom));gap:18px}button,.btn,.preset,.icon-btn{-webkit-tap-highlight-color:transparent;touch-action:manipulation}.brand{display:flex;align-items:center;gap:10px;font-size:30px;font-weight:800;letter-spacing:-.5px}.brand .sub{font-size:13px;font-weight:500;color:var(--muted)}.card{width:min(100%,460px);background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:18px;padding:22px;display:flex;flex-direction:column;gap:14px;box-shadow:0 24px 60px #00000073}.hint{margin:0;font-size:13px;color:var(--muted);line-height:1.5}.hint code{background:#0c1f17;padding:1px 6px;border-radius:6px;color:var(--accent)}textarea.names{width:100%;min-height:130px;resize:vertical;padding:14px;font-size:15px;line-height:1.5;border-radius:12px;border:1px solid var(--line);background:#0b1c15;color:var(--text);outline:none;transition:border-color .15s}textarea.names:focus{border-color:var(--accent)}.row{display:flex;align-items:center;justify-content:space-between;gap:12px}.count{font-size:13px;color:var(--muted)}.count b{color:var(--accent);font-size:16px}.warnings{margin:0;padding-left:18px;color:var(--gold);font-size:12px;line-height:1.5}.presets{display:flex;flex-wrap:wrap;align-items:center;gap:7px}.presets-label{font-size:12px;color:var(--muted)}.preset{padding:5px 12px;border-radius:999px;border:1px solid var(--line);background:#16352a;color:var(--text);font-size:13px;cursor:pointer;transition:background .15s}.preset:hover{background:#1f4a3a}.chips{display:flex;flex-wrap:wrap;gap:7px}.chip{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:8px;background:#0c1f17;border:1px solid var(--line);font-size:13px;color:var(--text);max-width:140px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.btn{border:none;border-radius:12px;padding:13px 18px;font-size:15px;font-weight:700;cursor:pointer;transition:transform .08s,filter .15s,background .15s}.btn:active{transform:translateY(1px)}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#06251a}.btn-primary:disabled{background:#2b4438;color:#6c8678;cursor:not-allowed}.btn-ghost{background:#20392f;color:var(--text);border:1px solid var(--line)}.btn-gold{background:linear-gradient(135deg,var(--gold),#ffb347);color:#3a2a00}.icon-btn{width:42px;height:42px;border-radius:12px;border:1px solid var(--line);background:#16352a;color:var(--text);font-size:18px;cursor:pointer}.icon-btn.on{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#06251a;border-color:transparent}.stage{position:relative;max-width:100%}.canvas-wrap{position:relative;line-height:0}canvas.field{display:block;border-radius:16px;background:#aee6ff;box-shadow:0 24px 60px #00000080;width:min(96vw,1180px);height:auto}.board{position:absolute;top:54px;right:14px;width:196px;background:#0816109e;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:10px;display:flex;flex-direction:column;gap:6px;max-height:72%;overflow:hidden}.board h3{margin:2px 4px 6px;font-size:14px;color:var(--muted);letter-spacing:.4px}.board ol{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px;overflow-y:auto}.entry{display:grid;grid-template-columns:22px 1fr auto;align-items:center;gap:8px;padding:7px 9px;border-radius:10px;background:#0d2019;font-size:13px;transition:background .2s}.entry .rank{font-weight:800;color:var(--muted);text-align:center}.entry.top1{background:linear-gradient(90deg,#ffd16640,#0d2019)}.entry.top1 .rank{color:var(--gold)}.entry.top2 .rank{color:#cfe3ff}.entry.top3 .rank{color:#ffc08a}.entry .name{display:flex;align-items:center;gap:7px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.dot{width:11px;height:11px;border-radius:50%;flex:none}.entry .pct{font-variant-numeric:tabular-nums;color:var(--muted);font-size:12px}.controls{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.status{color:var(--muted);font-size:13px;margin:0}.modal-back{position:fixed;top:0;right:0;bottom:0;left:0;background:#030c0899;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:20;animation:fade .25s ease}.modal{position:relative;width:min(92vw,380px);background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:20px;padding:28px 24px;text-align:center;box-shadow:0 30px 80px #0009;animation:pop .35s cubic-bezier(.2,1.4,.4,1)}.modal .trophy{font-size:56px}.modal .label{color:var(--muted);font-size:14px;margin:6px 0 2px}.modal .winner-name{font-size:32px;font-weight:800;margin:0 0 18px}.confetti{position:absolute;top:-10px;font-size:18px;animation:fall linear forwards;pointer-events:none}@keyframes fade{0%{opacity:0}to{opacity:1}}@keyframes pop{0%{opacity:0;transform:scale(.8) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes fall{to{transform:translateY(120vh) rotate(540deg);opacity:.2}}.modal.results{width:min(94vw,420px)}.standings{list-style:none;margin:0 0 18px;padding:0;display:flex;flex-direction:column;gap:5px;max-height:320px;overflow-y:auto;text-align:left}.standing{display:grid;grid-template-columns:30px 1fr auto;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;background:#0d2019;font-size:14px}.standing .medal{text-align:center;font-weight:800;color:var(--muted)}.standing.m1{background:linear-gradient(90deg,#ffd16647,#0d2019)}.standing.m2{background:linear-gradient(90deg,#cfe3ff38,#0d2019)}.standing.m3{background:linear-gradient(90deg,#ffc08a38,#0d2019)}.standing .sname{display:flex;align-items:center;gap:8px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.standing .stime{font-variant-numeric:tabular-nums;color:var(--muted);font-size:13px}@media (max-width: 760px){.app{padding:12px;gap:12px}.brand{font-size:22px}.brand .sub{font-size:11px}.card{padding:16px;border-radius:14px;gap:11px}textarea.names{min-height:110px;font-size:16px;padding:12px}.preset{padding:5px 11px;font-size:12px}.btn{padding:12px 16px;font-size:14px}.icon-btn{width:38px;height:38px;font-size:16px}.stage{width:100%;display:flex;flex-direction:column;gap:10px}.canvas-wrap{width:100%}canvas.field{width:100%}.board{position:static;width:100%;max-height:220px;background:#081610d9;font-size:12px}.board ol{max-height:180px}.modal{padding:22px 18px}.modal .trophy{font-size:44px}.modal .winner-name{font-size:26px}.standings{max-height:260px}}
