*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0a12;--surface: #12121e;--surface2: #1a1a28;--border: #2a2a3e;--text: #e8e0d0;--text-dim: #7a7080;--accent: #c9a84c;--accent-dim: #6b5a28;--danger: #c0392b;--success: #27ae60;--warning: #e67e22;--sidebar-w: 280px;--header-h: 56px}html,body,#root{width:100%;height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,sans-serif}.dashboard-shell{display:flex;flex-direction:column;height:100dvh}.dashboard-header{height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:16px;flex-shrink:0}.dashboard-header .logo{font-size:1rem;font-weight:700;color:var(--accent);letter-spacing:.05em}.dashboard-header .session-info{font-size:.8rem;color:var(--text-dim);font-family:monospace}.dashboard-header .xcard-btn{margin-left:auto;background:var(--danger);color:#fff;border:none;border-radius:8px;padding:8px 20px;font-weight:700;font-size:.9rem;cursor:pointer;letter-spacing:.05em;transition:opacity .2s}.dashboard-header .xcard-btn:hover{opacity:.85}.dashboard-body{flex:1;display:grid;grid-template-columns:var(--sidebar-w) 1fr var(--sidebar-w);min-height:0;overflow:hidden}.dashboard-col{overflow-y:auto;padding:16px;border-right:1px solid var(--border);display:flex;flex-direction:column;gap:16px}.dashboard-col:last-child{border-right:none}.card{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden}.card-header{padding:10px 14px;border-bottom:1px solid var(--border);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);font-weight:600}.card-body{padding:14px;display:flex;flex-direction:column;gap:12px}.player-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:.9rem}.player-row:last-child{border-bottom:none}.player-row .player-avatar{width:32px;height:32px;border-radius:50%;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.player-row .player-name{flex:1;font-weight:500}.player-row .player-hp{font-size:.8rem;color:var(--danger);font-weight:600}.player-row .player-status{width:8px;height:8px;border-radius:50%;background:var(--success)}.inject-area{display:flex;flex-direction:column;gap:10px}.inject-area textarea{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:12px;color:var(--text);font-size:.9rem;resize:vertical;min-height:80px;outline:none;font-family:inherit;transition:border-color .2s}.inject-area textarea:focus{border-color:var(--accent)}.btn-row{display:flex;gap:8px}.btn-primary{background:var(--accent);color:#0a0a12;border:none;border-radius:7px;padding:10px 16px;font-size:.85rem;font-weight:700;cursor:pointer;flex:1;transition:opacity .2s}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-primary:hover:not(:disabled){opacity:.85}.btn-secondary{background:transparent;color:var(--text-dim);border:1px solid var(--border);border-radius:7px;padding:10px 16px;font-size:.85rem;cursor:pointer}.btn-danger{background:var(--danger);color:#fff;border:none;border-radius:7px;padding:10px 16px;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .2s}.btn-danger:hover{opacity:.85}.npc-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);font-size:.9rem}.npc-row:last-child{border-bottom:none}.npc-row .npc-name{flex:1;font-weight:500}.npc-mood-btn{font-size:.7rem;padding:3px 8px;border-radius:12px;border:1px solid var(--border);background:transparent;color:var(--text-dim);cursor:pointer;transition:background .15s,color .15s}.npc-mood-btn.hostile{border-color:var(--danger);color:var(--danger)}.npc-mood-btn.friendly{border-color:var(--success);color:var(--success)}.npc-mood-btn.active{background:var(--surface2)}.whisper-tool{display:flex;flex-direction:column;gap:10px}.player-select{display:flex;flex-wrap:wrap;gap:6px}.player-chip{padding:5px 12px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--text-dim);font-size:.8rem;cursor:pointer;transition:all .15s}.player-chip.selected{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.whisper-tool textarea{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:10px;color:var(--text);font-size:.9rem;resize:vertical;min-height:64px;outline:none;font-family:inherit}.whisper-tool textarea:focus{border-color:var(--accent)}.whisper-log{display:flex;flex-direction:column;gap:6px;max-height:180px;overflow-y:auto}.whisper-log-entry{font-size:.78rem;padding:6px 10px;background:var(--surface2);border-radius:6px;color:var(--text-dim);border-left:2px solid var(--accent-dim)}.whisper-log-entry strong{color:var(--text)}.narration-log{display:flex;flex-direction:column;gap:10px;max-height:360px;overflow-y:auto}.narration-entry{padding:10px 12px;background:var(--surface2);border-radius:8px;border-left:2px solid var(--border);font-size:.85rem;line-height:1.5}.narration-entry.narrator{border-left-color:var(--accent-dim)}.narration-entry.npc{border-left-color:var(--success)}.narration-entry .entry-speaker{font-size:.7rem;color:var(--text-dim);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.combatant-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:.9rem}.combatant-row:last-child{border-bottom:none}.combatant-row.current-turn{background:#c9a84c0d;border-radius:6px;padding:8px}.combatant-row .init-badge{background:var(--surface2);border-radius:4px;padding:3px 7px;font-size:.75rem;font-weight:700;color:var(--accent);min-width:30px;text-align:center}.combatant-row .comb-name{flex:1}.combatant-row .comb-hp{font-size:.8rem;color:var(--danger);font-weight:600}.join-screen{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;gap:24px}.join-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:32px;width:100%;max-width:460px;display:flex;flex-direction:column;gap:18px}.join-card h1{font-size:1.3rem;color:var(--accent)}.join-card p{font-size:.85rem;color:var(--text-dim);line-height:1.6}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);font-weight:600}.form-group input{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:12px;color:var(--text);font-size:.95rem;font-family:monospace;outline:none}.form-group input:focus{border-color:var(--accent)}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--text-dim)}.status-dot.connected{background:var(--success)}.status-dot.error{background:var(--danger)}.status-dot.connecting{background:var(--accent);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.empty-state{text-align:center;color:var(--text-dim);font-size:.85rem;padding:24px 0}.toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px 20px;font-size:.85rem;color:var(--text);z-index:200;animation:fadeInUp .3s ease,fadeOut .4s ease 2s forwards;white-space:nowrap}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%)}}@keyframes fadeOut{to{opacity:0}}.dashboard-header .logo{background:linear-gradient(135deg,var(--accent) 0%,#e8c56a 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 8px rgba(201,168,76,.3))}.dashboard-header .xcard-btn{background:linear-gradient(135deg,var(--danger),#e74c3c);box-shadow:0 2px 8px #c0392b66;font-size:.85rem;letter-spacing:.06em}.dashboard-header .xcard-btn:hover{box-shadow:0 2px 14px #c0392b99;opacity:1;background:linear-gradient(135deg,#e74c3c,var(--danger))}.card{box-shadow:0 2px 8px #0000004d;transition:border-color .15s}.card:hover{border-color:var(--border)}.card-header{background:#ffffff04}.combatant-row.current-turn{background:linear-gradient(90deg,rgba(201,168,76,.08) 0%,transparent 100%);border-left:2px solid var(--accent);padding-left:10px;border-radius:6px}.narration-entry.narrator{border-left-color:var(--accent)}.narration-entry.npc{border-left-color:var(--success);background:#27ae6008}.inject-area textarea{transition:height .15s ease,border-color .2s}.player-row .player-hp{padding:2px 8px;background:#c0392b1a;border-radius:12px;font-weight:700}.npc-mood-btn{transition:all .15s}.npc-mood-btn.friendly.active{background:#27ae6026}.npc-mood-btn.hostile.active{background:#c0392b26}.player-chip.selected{box-shadow:0 0 8px #c9a84c33}.join-screen{background:radial-gradient(ellipse at 50% 20%,rgba(201,168,76,.05) 0%,transparent 60%)}.join-card{box-shadow:0 8px 32px #00000080,0 0 0 1px var(--border)}button:focus-visible,input:focus-visible,textarea:focus-visible,a:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
