*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #1a1a2e;--surface: #16213e;--card: #0f3460;--accent: #e94560;--accent2: #f5a623;--text: #eaeaea;--muted: #8888a0;--green: #4caf50;--red: #f44336;--border: #2a2a4a;font-family:Segoe UI,system-ui,sans-serif}body{background:var(--bg);color:var(--text);min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;border:none;border-radius:6px;padding:8px 18px;font-size:14px;font-weight:600;transition:opacity .15s}button:hover{opacity:.85}button:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-secondary{background:var(--card);color:var(--text)}.btn-sm{padding:4px 10px;font-size:12px}input,select{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:8px 12px;font-size:14px;width:100%}input:focus,select:focus{outline:2px solid var(--accent)}label{font-size:13px;color:var(--muted);display:block;margin-bottom:4px}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px}.error{color:var(--red);font-size:13px;margin-top:6px}.success{color:var(--green);font-size:13px;margin-top:6px}nav{display:flex;align-items:center;gap:16px;padding:12px 20px;background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap}nav .logo{font-size:20px;font-weight:700;color:var(--accent2)}nav .spacer{flex:1}.page{max-width:1100px;margin:0 auto;padding:32px 20px}@media (max-width: 600px){.page{padding:16px 12px}nav{gap:12px;padding:10px 14px}nav .logo{font-size:17px}.board-wrap{gap:16px}.board-info{flex-direction:row!important;flex-wrap:wrap;gap:10px!important;width:100%}.board-info>.card{flex:1;min-width:140px;padding:14px}.clock{font-size:22px;min-width:70px}.die{width:40px;height:40px;font-size:22px}}table{width:100%;border-collapse:collapse}th,td{padding:10px 14px;text-align:left;border-bottom:1px solid var(--border)}th{color:var(--muted);font-size:12px;text-transform:uppercase}tr:hover td{background:var(--card)}.die{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:10px;background:var(--card);border:2px solid var(--accent2);font-size:26px;font-weight:700;color:var(--accent2);transition:background .3s,border-color .3s,color .3s}.die.rolling{animation:tumble .15s linear infinite;border-color:var(--accent2)!important;background:var(--card)!important;color:var(--accent2)!important}@keyframes tumble{0%{transform:rotate(0) scale(1)}25%{transform:rotate(8deg) scale(1.08)}50%{transform:rotate(0) scale(.94)}75%{transform:rotate(-8deg) scale(1.08)}to{transform:rotate(0) scale(1)}}.clock{font-size:28px;font-weight:700;font-variant-numeric:tabular-nums;padding:8px 16px;border-radius:8px;background:var(--card);border:2px solid var(--border);min-width:90px;text-align:center}.clock.active{border-color:var(--accent2);color:var(--accent2)}.clock.low{border-color:var(--red);color:var(--red)}.board-wrap{display:flex;gap:24px;align-items:flex-start;flex-wrap:wrap}.board-side{display:flex;flex-direction:column;gap:12px}.board-info{display:flex;flex-direction:column;gap:8px;min-width:160px;max-width:220px}@media (max-width: 600px){.board-info{max-width:100%}}.player-label{font-weight:600;font-size:15px}.turn-indicator{font-size:13px;color:var(--muted)}.turn-indicator.active{color:var(--accent2);font-weight:600}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--surface);border-radius:16px;padding:32px;max-width:400px;width:90%}.modal h2,.form-group{margin-bottom:16px}.form-row{display:flex;gap:12px}.form-row .form-group{flex:1}.spectate-board{pointer-events:none}
