:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:#eef2ff;background:#0b1120;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{background:radial-gradient(circle at 0 0,#38bdf833,#0000 34rem),#0b1120}button,input{font:inherit}button{cursor:pointer;border:0}button:disabled{opacity:.45;cursor:not-allowed}.app-shell{width:min(1180px,100%);margin:0 auto;padding:20px}.hero{grid-template-columns:1.2fr .8fr;align-items:stretch;gap:16px;margin-bottom:18px;display:grid}.panel{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#0f172ac7;border:1px solid #94a3b838;border-radius:24px;padding:18px;box-shadow:0 20px 70px #0000003d}h1,h2,h3{margin:0}.hero h1{letter-spacing:-.05em;font-size:clamp(28px,7vw,54px);line-height:.95}.hero p{color:#cbd5e1;line-height:1.55}.badges{flex-wrap:wrap;gap:8px;margin-top:14px;display:flex}.badge{color:#bae6fd;background:#38bdf81f;border-radius:999px;padding:8px 10px;font-size:13px}.layout{grid-template-columns:280px 1fr 300px;align-items:start;gap:16px;display:grid}.game-list{gap:10px;display:grid}.game-card{text-align:left;color:#e2e8f0;background:#1e293bd6;border:1px solid #94a3b829;border-radius:18px;width:100%;padding:14px}.game-card.active{background:#0e749059;outline:2px solid #38bdf8bf}.game-card strong{margin-bottom:4px;display:block}.game-card span{color:#94a3b8;font-size:13px}.toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px;display:flex}.primary,.secondary,.danger{color:#fff;background:#0284c7;border-radius:14px;padding:11px 14px}.secondary{background:#475569e6}.danger{background:#be123ce6}.muted{color:#94a3b8;font-size:13px}.board-wrap{justify-items:center;gap:10px;display:grid}.board{touch-action:manipulation;background:#020617db;border-radius:18px;gap:3px;width:min(100%,70vh);max-width:620px;padding:8px;display:grid}.cell{aspect-ratio:1;color:#f8fafc;background:#94a3b81f;border:1px solid #94a3b814;border-radius:10px;place-items:center;min-width:0;font-size:clamp(12px,3.5vw,22px);font-weight:800;display:grid}.cell.dark{background:#1e293bf2}.cell.light{background:#94a3b82e}.cell.p1{color:#020617;background:#e2e8f0}.cell.p2{color:#062235;background:#38bdf8}.cell.hint{outline:2px solid #facc15cc}.room-box{gap:10px;display:grid}.room-row{gap:8px;display:flex}.room-row input{color:#f8fafc;background:#0f172ae6;border:1px solid #94a3b840;border-radius:12px;flex:1;min-width:0;padding:10px 12px}.code{word-break:break-all;color:#bae6fd;background:#0f172acc;border-radius:12px;padding:10px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.dice-row{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.die{color:#020617;background:#e2e8f0;border-radius:16px;place-items:center;width:58px;height:58px;font-size:24px;font-weight:900;display:grid}.die.held{background:#38bdf8}.score-grid{grid-template-columns:repeat(2,1fr);gap:8px;margin-top:12px;display:grid}.score-grid button{color:#e2e8f0;background:#334155e6;border-radius:12px;padding:10px}.ad-slot{background:#713f1233;border:1px dashed #facc1573;border-radius:18px;margin-top:14px;padding:14px}@media (width<=960px){.hero,.layout{grid-template-columns:1fr}.app-shell{padding:12px}.panel{border-radius:20px}.board{width:100%}}.chess-board{background:#111827;border:1px solid #e2e8f047;border-radius:8px;gap:0;padding:10px}.chess-cell{border:0;border-radius:0;min-height:42px;font-size:clamp(20px,6vw,38px)}.chess-cell.light{color:#111827;background:#f0d9b5}.chess-cell.dark{color:#111827;background:#b58863}.chess-cell.p1,.chess-cell.p2{text-shadow:0 1px 2px #ffffff52}.chess-cell.p2{color:#111827}.janggi-board{aspect-ratio:8/9;touch-action:manipulation;background:#d9ad67;border:2px solid #6f4318;border-radius:8px;width:min(100%,62vh);max-width:560px;padding:20px;position:relative;box-shadow:inset 0 0 0 2px #fff4d647,0 14px 36px #00000047}.janggi-lines{pointer-events:none;width:calc(100% - 40px);height:calc(100% - 40px);position:absolute;inset:20px;overflow:visible}.janggi-lines line{stroke:#522d10c7;stroke-width:.035px;vector-effect:non-scaling-stroke}.janggi-lines line[data-palace]{stroke-width:.045px}.janggi-point{color:#4b1d0b;z-index:2;background:#f7dfb2;border:2px solid #5b3010e6;border-radius:50%;place-items:center;width:clamp(28px,8vw,48px);height:clamp(28px,8vw,48px);font-size:clamp(17px,5vw,28px);font-weight:900;display:grid;position:absolute;transform:translate(-50%,-50%);box-shadow:0 2px #4d2a0ebf,0 6px 14px #4d2a0e40}.janggi-point:empty,.janggi-point:not(.p1):not(.p2):not(.hint){width:22px;height:22px;box-shadow:none;background:0 0;border:0}.janggi-point.p1{color:#b91c1c}.janggi-point.p2{color:#111827}.janggi-point.hint{outline-offset:2px;outline:3px solid #facc15f2}
