
:root{--ink:#1b1f2a;--muted:#636b7a;--panel:#fff;--line:#e7e9f2;--shadow:0 8px 24px rgba(18,22,33,.10);--radius:18px;--pill:#f0f2f8}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,"Apple SD Gothic Neo","Noto Sans KR",Arial,sans-serif;color:var(--ink);
background:linear-gradient(180deg,#f7f7fb,#fbfbff)}
.app{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:22px;gap:14px}
.topbar{width:min(1240px,100%);display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--line);
box-shadow:var(--shadow);border-radius:14px;padding:10px 12px}
.dot{width:10px;height:10px;border-radius:50%;background:#c9cedb}
.title{font-weight:950;font-size:14px;margin-left:8px}
.spacer{flex:1}
.screen{display:none;width:min(1240px,100%)}
.screen--active{display:block}
.panel{background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:var(--radius);padding:18px;display:grid;gap:14px}
.panel__title{background:rgba(244,199,93,.35);border:1px solid rgba(244,199,93,.55);color:#7a5600;font-weight:950;border-radius:12px;padding:10px 12px;text-align:center}
.maps{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media (max-width:1080px){.maps{grid-template-columns:1fr 1fr}}
.mapCard{border:2px solid transparent;border-radius:16px;padding:10px;background:#f8fafc;cursor:pointer;transition:.12s}
.mapCard:hover{transform:translateY(-1px);box-shadow:0 8px 18px rgba(18,22,33,.08)}
.mapCard.selected{border-color:rgba(59,130,246,.9);box-shadow:0 0 0 4px rgba(59,130,246,.15);background:#f2f7ff}
.thumb{width:100%;height:auto;border-radius:12px;display:block;background:#0ea5e9}
.controls{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:720px){.controls{grid-template-columns:1fr}}
.controlBlock__title{background:rgba(244,199,93,.35);border:1px solid rgba(244,199,93,.55);color:#7a5600;font-weight:950;border-radius:12px;padding:8px 10px;text-align:center;margin-bottom:10px}
.btnRow{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.pill{min-width:90px;border:none;background:var(--pill);border:1px solid var(--line);border-radius:999px;padding:9px 14px;font-weight:900;cursor:pointer}
.pill.active{background:rgba(59,130,246,.12);border-color:rgba(59,130,246,.6);color:#1d4ed8}
.primary{border:none;background:linear-gradient(180deg,#fde68a,#fbbf24);color:#5a3b00;border-radius:999px;padding:12px 18px;font-weight:950;cursor:pointer;box-shadow:0 10px 18px rgba(251,191,36,.18)}
.primary:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}
.ghost{border:1px solid var(--line);background:#fff;border-radius:12px;padding:8px 12px;cursor:pointer;font-weight:900;color:#2b3347}
.miniNote{color:var(--muted);font-size:12px;line-height:1.45;text-align:center}
.tableWrap{border:1px solid var(--line);border-radius:14px;overflow-x:auto;overflow-y:hidden}
.teamTable{width:100%;min-width:920px;border-collapse:collapse;font-size:13px;table-layout:fixed}
.teamTable thead th{background:#fbfcff;border-bottom:1px solid var(--line);padding:10px;text-align:center;font-weight:950;white-space:nowrap}
.teamTable td{border-bottom:1px solid var(--line);padding:8px;text-align:center}
.teamTable tbody tr:last-child td{border-bottom:none}
.teamTable input,.teamTable select{width:100%;min-height:40px;padding:8px 10px;border-radius:12px;border:1px solid var(--line);background:#fff;font-weight:900;color:var(--ink)}
.teamTable input[type=number]{text-align:right;font-variant-numeric:tabular-nums}
.colTeam{width:180px}.colShape{width:130px}.colBottom{width:150px}.colNum{width:120px}.colDel{width:90px}
.deleteBtn{width:100%;border:none;background:#fee2e2;color:#7f1d1d;font-weight:950;border-radius:12px;padding:10px;cursor:pointer}
.actions{display:flex;gap:10px;align-items:center}
.raceWrap{background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:var(--radius);overflow:hidden}
.hud{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;align-items:center;padding:12px 14px;border-bottom:1px solid var(--line);
background:linear-gradient(180deg,#fff,#fbfbff)}
.hud__left,.hud__right{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.hud__right{justify-content:flex-end}
.tag{font-size:12px;color:#2b3347;background:#f3f6ff;border:1px solid #e6ebff;padding:6px 8px;border-radius:999px;font-weight:950}
.big{text-align:center;font-weight:950;color:#0f172a}
.raceGrid{display:grid;grid-template-columns:1.7fr .7fr}
@media (max-width:1080px){.raceGrid{grid-template-columns:1fr}}
.canvasShell{background:#0ea5e9}
#game{display:block;width:100%;height:auto;background:#0ea5e9}
.rankPanel{border-left:1px solid var(--line);padding:12px 14px}
@media (max-width:1080px){.rankPanel{border-left:none;border-top:1px solid var(--line)}}
.rankTitle{font-weight:950;padding:10px 12px;border-radius:12px;background:rgba(244,199,93,.35);border:1px solid rgba(244,199,93,.55);color:#7a5600;text-align:center;margin-bottom:10px}
.rankTable{width:100%;border-collapse:collapse;font-size:13px;border:1px solid var(--line);border-radius:12px}
.rankTable th{background:#fbfcff;padding:10px 8px;border-bottom:1px solid var(--line);font-weight:950}
.rankTable td{padding:9px 8px;border-bottom:1px solid var(--line);font-weight:900}
.rankTable tbody tr:last-child td{border-bottom:none}
.rankHint{margin-top:10px;color:var(--muted);font-size:12px;line-height:1.45}
dialog::backdrop{background:rgba(15,23,42,.45)}
.modal{width:min(560px,92vw);border:none;border-radius:16px;padding:18px 18px 14px}
.modal h3{margin:0 0 10px}
.modal__btns{display:flex;justify-content:flex-end;margin-top:10px}
