*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0d0d12;--surface: #1a1a24;--border: #2a2a3a;--text: #d0d0e0;--text-dim: #7070a0;--accent: #4a90d9;--warn: #e74c3c;--gold: #f0c040;font-family:Segoe UI,system-ui,sans-serif;font-size:13px;color:var(--text);background:var(--bg)}body{overflow:hidden;height:100vh}.app-layout{display:grid;grid-template-columns:220px 1fr;grid-template-rows:1fr 140px;height:100vh;gap:0}.sidebar{grid-column:1;grid-row:1 / 3;display:flex;flex-direction:column;border-right:1px solid var(--border);overflow-y:auto}.main-area{grid-column:2;grid-row:1;display:flex;flex-direction:column;overflow:hidden}.event-panel{grid-column:2;grid-row:2;border-top:1px solid var(--border);overflow:hidden}.panel{background:var(--surface);border-bottom:1px solid var(--border)}.panel-header{padding:6px 10px;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-dim);border-bottom:1px solid var(--border)}.phase-tag{color:var(--accent)}.initiative-tracker{flex:0 0 auto}.initiative-list{list-style:none}.initiative-entry{display:flex;align-items:center;gap:6px;padding:5px 10px;cursor:pointer;border-left:3px solid transparent;transition:background .1s}.initiative-entry:hover{background:#ffffff0a}.initiative-entry.active{border-left-color:var(--gold);background:#f0c04012}.initiative-entry.selected{background:#4a90d91f}.init-score{width:26px;text-align:right;color:var(--gold);font-weight:700;font-size:12px}.actor-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.actor-resources{font-size:11px;color:var(--text-dim)}.stress{color:#e74c3c}.actor-panel{flex:1;padding:10px;overflow-y:auto}.actor-panel em{color:var(--text-dim);font-style:normal}.resource-row{display:flex;align-items:center;gap:6px;margin:6px 0}.resource-row label{width:44px;font-size:11px;color:var(--text-dim)}.bar-bg{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.bar-fill{height:100%;border-radius:3px;transition:width .3s}.spirit-fill{background:var(--accent)}.stress-fill{background:var(--warn)}.resource-row span{width:40px;text-align:right;font-size:11px}.conditions{display:flex;flex-wrap:wrap;gap:4px;margin:8px 0}.condition-tag{background:#f0c04026;color:var(--gold);border:1px solid rgba(240,192,64,.3);border-radius:3px;padding:1px 5px;font-size:10px}.hit-locations{margin-top:8px}.loc-entry{display:flex;align-items:center;gap:4px;padding:3px 0;border-bottom:1px solid var(--border);font-size:11px}.loc-entry.wounded .loc-name{color:#e67e22}.loc-entry.disabled .loc-name{color:var(--warn);text-decoration:line-through}.loc-name{flex:1}.loc-dmg{width:30px;text-align:right;color:var(--text-dim)}.loc-badge{font-size:9px;font-weight:700;background:#e67e22;color:#000;border-radius:2px;padding:0 3px}.loc-badge.red{background:var(--warn)}.action-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--surface);border-top:1px solid var(--border);flex-shrink:0}.action-bar-label{font-size:11px;color:var(--text-dim);margin-right:4px}.not-my-turn{color:var(--text-dim);font-style:italic}button{background:var(--accent);color:#fff;border:none;border-radius:4px;padding:5px 12px;cursor:pointer;font-size:12px;font-weight:600;transition:background .15s}button:hover:not(:disabled){background:#5aa3e8}button:disabled{opacity:.4;cursor:default}button.secondary{background:#444}button.secondary:hover{background:#555}button.end-turn{background:var(--warn)}button.end-turn:hover{background:#f05548}.event-log{height:140px;display:flex;flex-direction:column}.event-list{flex:1;overflow-y:auto;padding:4px 8px}.event-entry{display:flex;gap:8px;padding:2px 0;font-size:11px;border-bottom:1px solid rgba(255,255,255,.04)}.event-label{width:100px;flex-shrink:0;color:var(--text-dim)}.event-desc{color:var(--text)}.session-id-input{background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:12px;padding:4px 8px;width:200px}.session-id-input::placeholder{color:var(--text-dim)}.session-id-input:focus{outline:1px solid var(--accent)}.action-bar-divider{width:1px;height:20px;background:var(--border);flex-shrink:0}.loading{display:flex;align-items:center;justify-content:center;height:100vh;font-size:16px;color:var(--text-dim)}.loading.error{color:var(--warn)}
