:root,body[data-theme=light]{--bg:#eef2f7;--surface:#fff;--surface-2:#f1f4f9;--border:#d3dbe7;--text:#1b2434;--muted:#66728a;--ink:#11161f;--card-face:#fff;--card-border:#ccd5e4;--card-num:#98a2b3;--card-name:#465063;--back-1:#e7edf6;--back-2:#d3dcea;--back-border:#c4cedd;--emblem:90, 120, 165;--scrim:#dee5f0cc;--shadow:#283c5f24}body[data-theme=dark]{--bg:#0b0e14;--surface:#161c26;--surface-2:#1d2531;--border:#2c3744;--text:#e6e9f0;--muted:#9aa6b6;--ink:#fff;--card-face:#1b2230;--card-border:#36424f;--card-num:#8995a6;--card-name:#cdd5e2;--back-1:#1e2940;--back-2:#10151e;--back-border:#ffffff1a;--emblem:140, 224, 255;--scrim:#080a10d1;--shadow:#00000080}*{box-sizing:border-box}body{-webkit-user-select:none;user-select:none;margin:0;padding:0;font-family:Pretendard,Inter,sans-serif;transition:background-color .3s,color .3s;overflow-x:hidden}body[data-theme]{background-color:var(--bg);color:var(--text)}.hidden{display:none!important}.flip-main{flex-direction:column;min-height:100vh;padding-top:64px;display:flex}.btn-primary,.btn-ghost{cursor:pointer;border-radius:12px;font-family:inherit;font-weight:700;transition:transform .12s,background .2s,box-shadow .2s,color .2s}.btn-primary{color:#fff;background:linear-gradient(135deg,#4dabf7,#5c7cfa);border:none;padding:14px 28px;font-size:17px;box-shadow:0 8px 22px #4d7cfa52}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 28px #4d7cfa6b}.btn-primary:active{transform:translateY(0)}.btn-ghost{background:var(--surface);color:var(--muted);border:1px solid var(--border);padding:11px 22px;font-size:14px}.btn-ghost:hover{color:var(--ink);border-color:var(--muted)}.btn-ghost.small{border-radius:50%;width:40px;height:40px;padding:0;font-size:19px}.overlay{z-index:50;background:var(--scrim);-webkit-backdrop-filter:blur(12px);justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.panel{background:var(--surface);border:1px solid var(--border);text-align:center;box-shadow:0 20px 55px var(--shadow);border-radius:22px;width:100%;max-width:460px;max-height:calc(100vh - 90px);padding:32px 30px;animation:.35s cubic-bezier(.2,.8,.2,1) pop;overflow-y:auto}@keyframes pop{0%{opacity:0;transform:translateY(14px)scale(.96)}to{opacity:1;transform:none}}.game-title{background:linear-gradient(135deg,#4dabf7,#7c5cff);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 10px;font-family:Space Grotesk,Pretendard,sans-serif;font-size:29px}.game-sub{color:var(--muted);margin:0 0 22px;font-size:14px;line-height:1.6}.setup-row{margin-bottom:16px}.setup-label{color:var(--muted);margin-bottom:9px;font-size:13px;font-weight:600;display:block}.setup-label .hint{opacity:.7;font-weight:400}.team-count{justify-content:center;gap:8px;display:flex}.count-btn{border:1px solid var(--border);background:var(--surface-2);width:44px;height:44px;color:var(--text);cursor:pointer;border-radius:12px;font-family:Space Grotesk,sans-serif;font-size:18px;font-weight:700;transition:all .15s}.count-btn:hover{border-color:var(--muted)}.count-btn.sel{color:#fff;background:linear-gradient(135deg,#4dabf7,#5c7cfa);border-color:#0000;box-shadow:0 6px 16px #4d7cfa59}.team-names{flex-direction:column;gap:8px;margin:4px 0 18px;display:flex}.team-name-row{align-items:center;gap:10px;display:flex}.team-dot{border-radius:50%;flex-shrink:0;width:14px;height:14px}.team-name-row input{background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:10px;flex:1;padding:10px 13px;font-family:inherit;font-size:14px}.team-name-row input:focus{border-color:#4dabf7;outline:none}.peek-ctrl{align-items:center;gap:10px;display:flex}.step-btn{border:1px solid var(--border);background:var(--surface-2);width:34px;height:34px;color:var(--text);cursor:pointer;border-radius:9px;flex-shrink:0;font-size:20px;font-weight:700;line-height:1;transition:all .15s}.step-btn:hover{border-color:var(--muted)}.peek-ctrl input[type=range]{accent-color:#4dabf7;cursor:pointer;flex:1;height:4px}.peek-val{text-align:right;min-width:48px;color:var(--text);flex-shrink:0;font-family:Space Grotesk,sans-serif;font-size:15px;font-weight:700}.theme-toggle{gap:8px;display:flex}.theme-opt{border:1px solid var(--border);background:var(--surface-2);color:var(--muted);cursor:pointer;border-radius:10px;flex:1;padding:10px;font-family:inherit;font-size:14px;font-weight:600;transition:all .15s}.theme-opt:hover{border-color:var(--muted)}.theme-opt.sel{color:var(--ink);background:color-mix(in srgb, #4dabf7 14%, var(--surface));border-color:#4dabf7;box-shadow:0 0 0 1px #4dabf7}#start-btn{width:100%;margin:4px 0 10px}#rules-btn{width:100%}.game-stage{flex-direction:row;flex:1;align-items:stretch;gap:16px;min-height:0;padding:12px 16px 14px;display:flex;position:relative}.jumbo{flex-direction:column;flex:0 0 clamp(186px,18.5vw,290px);gap:10px;min-height:0;display:flex}.jumbo-team{text-align:center;background:var(--surface);border:1px solid var(--border);border-left:5px solid var(--chip,#4dabf7);opacity:.82;min-height:0;box-shadow:0 1px 3px var(--shadow);border-radius:14px;flex-direction:column;flex:1 1 0;justify-content:center;align-items:center;gap:1px;padding:6px 8px;transition:transform .2s,box-shadow .2s,opacity .2s;display:flex;position:relative;overflow:hidden}.jumbo-team.current{opacity:1;border-color:var(--chip,#4dabf7);box-shadow:0 0 0 2px var(--chip,#4dabf7), 0 8px 22px var(--shadow);transform:scale(1.025)}.jumbo-team.current:before{content:"";background:color-mix(in srgb, var(--chip,#4dabf7) 12%, transparent);pointer-events:none;position:absolute;inset:0}.jt-top{z-index:1;align-items:center;gap:6px;display:flex}.jt-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:13ch;font-size:clamp(13px,1.45vw,19px);font-weight:800;overflow:hidden}.jt-badge{font-size:clamp(13px,1.45vw,19px)}.jt-score{color:color-mix(in srgb, var(--chip,#4dabf7) 74%, var(--ink));z-index:1;font-family:Space Grotesk,sans-serif;font-size:clamp(30px,6.4vh,66px);font-weight:700;line-height:1.05}.jt-unit{opacity:.82;margin-left:2px;font-family:Pretendard,Inter,sans-serif;font-size:.4em;font-weight:700}.jt-turn{color:color-mix(in srgb, var(--chip,#4dabf7) 70%, var(--ink));letter-spacing:.02em;z-index:1;min-height:14px;font-size:clamp(10px,1vw,13px);font-weight:700}.jumbo-team.scored{animation:.75s cubic-bezier(.2,.8,.2,1) jtScored}@keyframes jtScored{0%{transform:scale(1.025)}35%{box-shadow:0 0 0 3px var(--chip,#4dabf7), 0 0 30px var(--chip,#4dabf7);transform:scale(1.11)}to{transform:scale(1.025)}}.play-area{flex-direction:column;flex:auto;justify-content:center;align-items:center;gap:12px;min-width:0;display:flex}.turn-banner{text-align:center}.turn-now{color:var(--ink);font-size:clamp(16px,1.9vw,22px);font-weight:800}.turn-dot{vertical-align:middle;border-radius:50%;width:12px;height:12px;margin-right:7px;display:inline-block;box-shadow:0 0 0 2px #7f7f7f2e}.group-progress{color:var(--muted);min-height:20px;margin-top:4px;font-size:clamp(12px,1.4vw,15px)}.group-progress b{color:color-mix(in srgb, var(--grp,#4dabf7) 72%, var(--ink))}.board{--cw:max(58px, min((78vw - 110px) / 5, (100vh - 200px) / 3, 300px));grid-template-columns:repeat(5, var(--cw));grid-auto-rows:calc(var(--cw) * 3 / 4);justify-content:center;gap:12px;width:100%;display:grid}.board .card{cursor:pointer;perspective:900px;-webkit-backdrop-filter:none;backdrop-filter:none;min-width:0;min-height:0;box-shadow:none;background:0 0;border:none;border-radius:0;flex:none;margin:0;padding:0;transition:none;position:relative;overflow:visible}.card-inner{transform-style:preserve-3d;transition:transform .45s cubic-bezier(.2,.8,.2,1);position:absolute;inset:0}.card.flipped .card-inner{transform:rotateY(180deg)}.card-back,.card-front{backface-visibility:hidden;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.card-back{background:linear-gradient(155deg, var(--back-1), var(--back-2));border:1px solid var(--back-border)}.card-back:before{content:"";aspect-ratio:1;border:2px solid rgba(var(--emblem), .4);height:46%;box-shadow:inset 0 0 10px rgba(var(--emblem), .12);border-radius:50%;transition:border-color .2s}.card-back:after{content:"?";font-family:Space Grotesk,sans-serif;font-size:clamp(16px, calc(var(--cw) * .2), 52px);color:rgba(var(--emblem), .58);font-weight:700;position:absolute}.card:hover .card-back:before{border-color:rgba(var(--emblem), .62)}.c-coord{font-family:Space Grotesk,sans-serif;font-weight:600;font-size:clamp(9px, calc(var(--cw) * .085), 15px);color:rgba(var(--emblem), .58);letter-spacing:.02em;position:absolute;top:7%;left:8%}.card-front{background:var(--card-face);border:1.5px solid var(--card-border);color:var(--ink);box-shadow:0 1px 3px var(--shadow);padding:7% 8%;overflow:hidden;transform:rotateY(180deg)}.c-num{font-family:Space Grotesk,sans-serif;font-weight:600;font-size:clamp(9px, calc(var(--cw) * .088), 17px);color:var(--card-num);position:absolute;top:9%;left:8%}.c-sym{font-family:Space Grotesk,sans-serif;font-weight:700;font-size:clamp(22px, calc(var(--cw) * .3), 82px);letter-spacing:-.01em;color:var(--ink);line-height:1}.c-name{font-size:clamp(10px, calc(var(--cw) * .112), 21px);color:var(--card-name);margin-top:6px}.c-group{font-size:clamp(9px, calc(var(--cw) * .092), 16px);color:color-mix(in srgb, var(--g,#4dabf7) 66%, var(--ink));letter-spacing:.03em;font-weight:700;display:none;position:absolute;bottom:9%}.card.active .card-front{box-shadow:0 0 0 3px var(--team,#4dabf7), 0 0 16px color-mix(in srgb, var(--team,#4dabf7) 55%, transparent)}.card.correct .card-front{animation:.5s goodPulse}@keyframes goodPulse{0%{transform:rotateY(180deg)scale(1)}50%{transform:rotateY(180deg)scale(1.07)}to{transform:rotateY(180deg)scale(1)}}.card.wrong .card-front{border-color:#ef4444;animation:.4s shake;box-shadow:0 0 0 3px #ef4444,0 0 18px #ef444473}@keyframes shake{0%,to{margin-left:0}25%{margin-left:-5px}75%{margin-left:5px}}.card.collected{pointer-events:none}.card.collected .card-inner{transform:rotateY(180deg)scale(.95)}.card.collected .card-front{background:color-mix(in srgb, var(--g,#4dabf7) 16%, var(--card-face));border:2px solid var(--g,#4dabf7);box-shadow:none}.card.collected .c-group{display:block}.card.collected .card-front:after{content:"✓";font-size:clamp(11px, calc(var(--cw) * .1), 20px);color:#16a34a;font-weight:700;position:absolute;top:9%;right:8%}.card.just-solved .card-inner{animation:.7s cubic-bezier(.2,.8,.2,1) solvePop}@keyframes solvePop{0%{transform:rotateY(180deg)scale(.95)}40%{transform:rotateY(180deg)scale(1.12)}to{transform:rotateY(180deg)scale(.95)}}.card.just-solved .card-front{animation:.7s solveGlow}@keyframes solveGlow{0%{box-shadow:0 0 0 0 var(--g,#4dabf7)}35%{box-shadow:0 0 0 5px color-mix(in srgb, var(--g,#4dabf7) 55%, transparent), 0 0 34px var(--g,#4dabf7)}to{box-shadow:none}}.fx-layer{pointer-events:none;z-index:65;position:fixed;inset:0;overflow:hidden}.confetti{pointer-events:none;opacity:0;will-change:transform, opacity;border-radius:2px;animation:1.2s cubic-bezier(.15,.6,.35,1) forwards confettiFly;position:fixed}@keyframes confettiFly{0%{opacity:1;transform:translate(0)rotate(0)}12%{opacity:1}to{transform:translate(var(--dx), calc(var(--dy) + 340px)) rotate(var(--rot));opacity:0}}.spark{pointer-events:none;opacity:0;will-change:transform, opacity;border-radius:50%;position:fixed;transform:translateZ(0)}.float-plus{text-shadow:0 2px 10px #00000040;pointer-events:none;font-family:Space Grotesk,sans-serif;font-size:clamp(26px,3.4vw,46px);font-weight:700;animation:1.1s cubic-bezier(.2,.8,.2,1) forwards floatUp;position:fixed;transform:translate(-50%,-50%)}@keyframes floatUp{0%{opacity:0;transform:translate(-50%,-50%)scale(.5)}25%{opacity:1;transform:translate(-50%,-90%)scale(1.15)}to{opacity:0;transform:translate(-50%,-210%)scale(1)}}.help-fab{z-index:30;box-shadow:0 4px 14px var(--shadow);position:fixed;bottom:16px;right:16px}.theme-fab{z-index:30;box-shadow:0 4px 14px var(--shadow);position:fixed;bottom:16px;right:66px}.toast{border:1px solid var(--toast,#ffffff29);color:#fff;opacity:0;pointer-events:none;z-index:75;white-space:nowrap;background:#181e2af5;border-radius:14px;max-width:92vw;padding:12px 22px;font-size:15px;font-weight:700;transition:opacity .25s,transform .25s;position:fixed;bottom:26px;left:50%;transform:translate(-50%,24px);box-shadow:0 10px 30px #141e3259}.toast.show{opacity:1;transform:translate(-50%)}.result-panel h2{color:var(--ink);margin:0 0 20px;font-size:26px}.ranking{flex-direction:column;gap:9px;margin-bottom:22px;display:flex}.rank-row{background:var(--surface-2);border:1px solid var(--border);border-radius:13px;align-items:center;gap:12px;padding:12px 16px;display:flex}.rank-row.win{background:linear-gradient(135deg, color-mix(in srgb, #ffc400 22%, var(--surface)), var(--surface));border-color:#f0b41499}.rank-medal{text-align:center;width:26px;font-size:20px}.rank-dot{border-radius:50%;width:13px;height:13px}.rank-name{text-align:left;color:var(--text);flex:1;font-size:15.5px;font-weight:700}.rank-score{color:var(--text);font-family:Space Grotesk,sans-serif;font-size:19px;font-weight:700}#replay-btn{width:100%;margin-bottom:10px}#reset-btn{width:100%}.modal{z-index:80;background:var(--scrim);-webkit-backdrop-filter:blur(8px);justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.rules-panel{text-align:left;max-width:480px}.rules-panel h2{text-align:center;color:var(--ink);margin:0 0 18px;font-size:22px}.rules-list{color:var(--text);margin:0 0 16px;padding-left:20px;font-size:14.5px;line-height:1.7}.rules-list b{color:#4dabf7}.rules-note{background:color-mix(in srgb, #ffc400 14%, var(--surface));color:color-mix(in srgb, #a06a00 60%, var(--ink));border:1px solid #f0be3c80;border-radius:12px;margin:0 0 22px;padding:12px 14px;font-size:13.5px;line-height:1.6}.rules-note b{color:#d99800}#rules-close{width:100%}@media (width<=820px){.game-stage{flex-direction:column;align-items:stretch;gap:10px;padding:10px 12px 12px}.jumbo{flex-direction:row;flex:none;gap:8px;padding-bottom:2px;overflow-x:auto}.jumbo-team{border-left:none;border-top:4px solid var(--chip,#4dabf7);flex:1 0 auto;min-width:88px;padding:6px}.jt-score{font-size:clamp(22px,7vw,38px)}.jt-name{font-size:13px}.board{--cw:max(50px, min((95vw - 48px) / 5, (100vh - 330px) / 3, 200px))}}@media (width<=480px){.panel{padding:26px 20px}.game-title{font-size:24px}}
