*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0e13;--surface:#18171f;--surface2:#201f29;--border:#2a2936;--border2:#38374c;--text:#e2dff0;--text-dim:#8882a8;--text-faint:#504d6e;--accent:#c0384c;--accent-l:#e8506a;--accent-d:#781e2b;--gold:#c9a84c;--gold-l:#e0bf72;--gold-d:#7a6028;--teal:#2a9090;--teal-l:#40c0c0;--teal-d:#1a5858;--green:#4caf7a;--warn:#e07840;--red:#d04050;--blue:#4878c0;--blue-l:#6898e0;--purple:#8060c0;--purple-l:#a080e0}html,body{height:100%;overflow:hidden}body{background:var(--bg);color:var(--text);font-family:Segoe UI,system-ui,sans-serif;font-size:13px;line-height:1.4}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}#app{height:100vh;display:flex;overflow:hidden}.card{background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:10px;padding:12px}.card-title{text-transform:uppercase;letter-spacing:.08em;color:var(--accent-l);border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px;padding-bottom:6px;font-size:11px;font-weight:700;display:flex}.card-title:hover{color:var(--text)}.card.collapsed .card-title{border-bottom-color:#0000;margin-bottom:0}.card.collapsed .chevron{transform:rotate(-90deg)}.chevron{color:var(--text-faint);flex-shrink:0;font-size:10px;transition:transform .2s}.btn{border:1px solid var(--border2);background:var(--surface2);color:var(--text);cursor:pointer;border-radius:6px;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:500;line-height:1.3;transition:all .15s}.btn:hover{background:var(--border)}.btn-accent{background:var(--accent-d);border-color:var(--accent);color:var(--accent-l)}.btn-accent:hover{background:var(--accent);color:#fff}.btn-gold{background:var(--gold-d);border-color:var(--gold);color:var(--gold-l)}.btn-gold:hover{background:var(--gold);color:#1a1000}.btn-teal{background:var(--teal-d);border-color:var(--teal);color:var(--teal-l)}.btn-teal:hover{background:var(--teal);color:#fff}.btn-green{border-color:var(--green);color:#80d0a0;background:#1a3d2a}.btn-green:hover{background:var(--green);color:#fff}.btn-red{border-color:var(--red);color:#f08090;background:#3d1520}.btn-red:hover{background:var(--red);color:#fff}.btn-warn{border-color:var(--warn);color:var(--warn);background:#3d2010}.btn-warn:hover{background:var(--warn);color:#fff}.btn-purple{border-color:var(--purple);color:var(--purple-l);background:#2a1a50}.btn-purple:hover{background:var(--purple);color:#fff}.btn-sm{padding:3px 8px;font-size:11px}.btn-lg{padding:8px 18px;font-size:13px}.btn-icon{padding:3px 7px;font-size:12px}.field{flex-direction:column;gap:3px;display:flex}.field label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;font-size:10px}input,select,textarea{background:var(--surface2);border:1px solid var(--border2);color:var(--text);border-radius:5px;width:100%;padding:5px 8px;font-family:inherit;font-size:12px;transition:border-color .2s}input:focus,select:focus,textarea:focus{border-color:var(--accent);outline:none}input[type=number]::-webkit-inner-spin-button{opacity:.5}select option{background:var(--surface2)}.stat-box{background:var(--surface2);border:1px solid var(--border2);text-align:center;border-radius:8px;padding:8px 4px}.stat-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px;font-size:9px}.stat-val{color:var(--text);font-size:20px;font-weight:800}.stat-mod{color:var(--accent-l);margin-top:2px;font-size:13px;font-weight:700}.tag{text-transform:uppercase;letter-spacing:.04em;border:1px solid;border-radius:10px;padding:2px 6px;font-size:9px;font-weight:600;display:inline-block}.tag-cr{background:var(--accent-d);color:var(--accent-l);border-color:var(--accent)}.tag-type{color:var(--blue-l);border-color:var(--blue);background:#1a1a2e}.tag-resist{color:var(--teal-l);border-color:var(--teal);background:#1a2a2e}.tag-immune{color:var(--accent-l);border-color:var(--accent);background:#2a1a1e}.tag-vuln{color:var(--warn);border-color:var(--warn);background:#2a2010}.tag-cond{color:var(--purple-l);border-color:var(--purple);background:#2a1a30}.tag-gold{background:var(--gold-d);color:var(--gold-l);border-color:var(--gold)}.tag-green{color:#80d0a0;border-color:var(--green);background:#1a3d2a}.hp-bar-wrap{background:var(--border);border-radius:3px;height:6px;margin:4px 0;overflow:hidden}.hp-bar{border-radius:3px;height:100%;transition:width .3s,background .3s}.pip{cursor:pointer;border:1px solid;border-radius:3px;width:14px;height:14px;transition:all .15s;display:inline-block}.pip-full{background:var(--accent);border-color:var(--accent-l)}.pip-empty{border-color:var(--border2);background:0 0}.pip-full:hover{filter:brightness(1.3)}.pip-empty:hover{border-color:var(--accent)}.cond-btn{border:1px solid var(--border2);background:var(--surface2);color:var(--text-dim);cursor:pointer;text-align:center;border-radius:5px;padding:4px;font-family:inherit;font-size:10px;font-weight:500;transition:all .15s}.cond-btn:hover{background:var(--border)}.cond-btn.active{border-color:var(--red);color:#f08090;background:#3d1520;font-weight:700}.action-entry{background:var(--surface2);border:1px solid var(--border2);border-radius:8px;margin-bottom:6px;padding:10px;transition:border-color .15s}.action-entry:hover{border-color:var(--border2)}.action-name{color:var(--gold-l);margin-bottom:4px;font-size:12px;font-weight:700}.action-desc{color:var(--text-dim);white-space:pre-wrap;font-size:11px;line-height:1.55}.action-rolls{flex-wrap:wrap;gap:5px;margin-top:6px;display:flex}.recharge-badge{border:1px solid var(--green);color:#80d0a0;cursor:pointer;background:#1a3d2a;border-radius:10px;padding:1px 6px;font-size:10px;font-weight:600;display:inline-block}.recharge-badge.spent{border-color:var(--border2);background:var(--bg);color:var(--text-faint)}.roll-entry{background:var(--surface2);border-left:3px solid var(--accent);border-radius:6px;margin-bottom:4px;padding:6px 8px;font-size:11px}.roll-entry.crit{border-left-color:var(--gold);background:#2a2310}.roll-entry.fumble{border-left-color:var(--red)}.roll-name{color:var(--text);font-weight:700}.roll-breakdown{color:var(--text-dim);margin-top:2px}.roll-result{color:var(--accent-l);margin-top:2px;font-size:14px;font-weight:800}.roll-result.crit-result{color:var(--gold-l)}.modal-overlay{z-index:200;background:#000000b3;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.modal-overlay.active{display:flex}.modal{background:var(--surface);border:1px solid var(--border2);border-radius:12px;width:94%;max-width:500px;max-height:88vh;padding:20px;overflow-y:auto}.modal h3{color:var(--accent-l);margin-bottom:14px;font-size:15px}.modal-grid{gap:8px;margin-bottom:8px;display:grid}.modal-actions{justify-content:flex-end;gap:8px;margin-top:16px;display:flex}.modal-section{border-top:1px solid var(--border);margin-top:10px;padding-top:10px}.modal-section-title{text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim);margin-bottom:8px;font-size:10px;font-weight:700}.roster{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:256px;display:flex;overflow:hidden}.roster-tabs{border-bottom:1px solid var(--border);flex-shrink:0;display:flex}.roster-tab{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;justify-content:center;align-items:center;gap:5px;padding:9px 6px;font-size:11px;font-weight:600;transition:color .15s,border-color .15s;display:flex}.roster-tab:hover{color:var(--text)}.roster-tab.active{color:var(--accent-l);border-bottom-color:var(--accent)}.roster-tab-count{background:var(--accent-d);color:var(--accent-l);border-radius:8px;padding:1px 5px;font-size:9px;font-weight:700;line-height:1.4}.roster-tab.active .roster-tab-count{background:var(--accent);color:#fff}.roster-subtabs{border-bottom:1px solid var(--border);background:var(--bg);flex-shrink:0;display:flex}.roster-subtab{color:var(--text-faint);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;justify-content:center;align-items:center;gap:4px;padding:6px 4px;font-size:10px;font-weight:600;transition:color .15s,border-color .15s;display:flex}.roster-subtab:hover{color:var(--text-dim)}.roster-subtab.active{color:var(--gold-l);border-bottom-color:var(--gold)}.roster-subtab-count{background:var(--gold-d);color:var(--gold-l);border-radius:6px;padding:0 4px;font-size:8px;font-weight:700;line-height:1.5}.roster-subtab.active .roster-subtab-count{background:var(--gold);color:#1a1400}.roster-search{border-bottom:1px solid var(--border);flex-shrink:0;padding:6px 8px;position:relative}.roster-search input{background:var(--bg);border:1px solid var(--border2);width:100%;color:var(--text);border-radius:5px;padding:5px 24px 5px 8px;font-size:11px}.roster-search input:focus{border-color:var(--accent);outline:none}.roster-search-clear{color:var(--text-faint);cursor:pointer;background:0 0;border:none;padding:2px 4px;font-size:10px;line-height:1;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.roster-search-clear:hover{color:var(--text)}.roster-list{flex-direction:column;flex:1;gap:6px;padding:8px;display:flex;overflow-y:auto}.roster-empty{text-align:center;color:var(--text-faint);padding:24px 8px;font-size:11px;line-height:1.7}.roster-section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-faint);border-bottom:1px solid var(--border);margin-bottom:2px;padding:4px 8px 2px;font-size:9px;font-weight:700}.roster-footer{border-top:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:6px;padding:10px;display:flex}.roster-card{background:var(--surface2);border:1px solid var(--border2);cursor:pointer;border-radius:8px;padding:10px;transition:border-color .15s,background .15s;position:relative}.roster-card:hover{border-color:var(--accent)}.roster-card.active{border-color:var(--accent);background:#2a1520}.roster-card-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;padding-right:42px;font-size:13px;font-weight:700;overflow:hidden}.roster-card-sub{color:var(--text-dim);margin-bottom:5px;font-size:10px}.roster-card-meta{flex-wrap:wrap;align-items:center;gap:4px;margin-top:4px;display:flex}.roster-card-btns{opacity:0;gap:3px;transition:opacity .15s;display:flex;position:absolute;top:7px;right:7px}.roster-card:hover .roster-card-btns{opacity:1}.compendium-card{background:var(--surface2);border:1px solid var(--border2);border-radius:8px;padding:8px 10px;transition:border-color .15s;position:relative}.compendium-card:hover{border-color:var(--teal)}.compendium-card.active{border-color:var(--teal);background:#0e2222}.compendium-card-btns{opacity:0;gap:3px;transition:opacity .15s;display:flex;position:absolute;top:7px;right:7px}.compendium-card:hover .compendium-card-btns{opacity:1}.npc-area{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.npc-header{border-bottom:2px solid var(--accent);background:linear-gradient(135deg,#200e18 0%,#130910 100%);flex-shrink:0;align-items:center;gap:10px;padding:10px 16px;display:flex}.npc-header-name{color:var(--text);flex:1;min-width:0;font-size:20px;font-weight:700}.npc-body{flex:1;padding:12px;overflow-y:auto}.sheet-grid{grid-template-columns:270px 1fr 1fr;align-items:start;gap:12px;display:grid}.sheet-col{min-width:0}.empty-state{color:var(--text-faint);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;display:flex}.empty-state h2{color:var(--text-dim);font-size:18px}.empty-state p{text-align:center;max-width:280px;font-size:13px;line-height:1.6}.flex-row{align-items:center;gap:6px;display:flex}.flex-wrap{flex-wrap:wrap}.ml-auto{margin-left:auto}.w-full{width:100%}.divider{border:none;border-top:1px solid var(--border);margin:8px 0}.import-modal.svelte-3rghwu{max-width:580px}.import-instructions.svelte-3rghwu{background:var(--surface2);border:1px solid var(--border);color:var(--text-dim);border-radius:8px;margin-bottom:12px;padding:10px 12px;font-size:12px;line-height:1.7}.import-instructions.svelte-3rghwu ol:where(.svelte-3rghwu){padding-left:18px}.import-instructions.svelte-3rghwu strong:where(.svelte-3rghwu){color:var(--text)}.import-textarea.svelte-3rghwu{background:var(--surface2);border:1px solid var(--border2);width:100%;color:var(--text);resize:vertical;border-radius:8px;padding:10px;font-family:Cascadia Code,Consolas,monospace;font-size:11px;line-height:1.5}.import-textarea.svelte-3rghwu:focus{border-color:var(--accent);outline:none}.import-textarea.svelte-3rghwu::placeholder{color:var(--text-faint)}.import-warnings.svelte-3rghwu{background:color-mix(in srgb, var(--warn) 12%, transparent);border:1px solid color-mix(in srgb, var(--warn) 40%, transparent);border-radius:8px;margin-bottom:12px;padding:10px 12px}.import-warnings-title.svelte-3rghwu{color:var(--warn);margin-bottom:6px;font-size:11px;font-weight:700}.import-warning-item.svelte-3rghwu{color:var(--text-dim);font-size:11px;line-height:1.6}.import-preview-grid.svelte-3rghwu{background:var(--surface2);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:3px;margin-bottom:10px;padding:8px 10px;display:flex}.preview-row.svelte-3rghwu{align-items:baseline;gap:8px;font-size:12px;display:flex}.preview-label.svelte-3rghwu{text-transform:uppercase;letter-spacing:.06em;width:80px;color:var(--text-faint);flex-shrink:0;font-size:10px;font-weight:700}.import-scores.svelte-3rghwu{gap:6px;margin-bottom:10px;display:flex}.import-score-cell.svelte-3rghwu{background:var(--surface2);border:1px solid var(--border);text-align:center;border-radius:6px;flex:1;padding:5px 3px}.import-score-label.svelte-3rghwu{text-transform:uppercase;color:var(--text-faint);letter-spacing:.05em;font-size:8px;font-weight:700}.import-score-val.svelte-3rghwu{color:var(--text);font-size:14px;font-weight:700;line-height:1.2}.import-score-mod.svelte-3rghwu{color:var(--text-dim);font-size:10px}.import-counts.svelte-3rghwu{flex-wrap:wrap;gap:5px;margin-bottom:12px;display:flex}.import-count-chip.svelte-3rghwu{background:var(--surface2);border:1px solid var(--border2);color:var(--text-dim);border-radius:10px;padding:2px 7px;font-size:10px;font-weight:600}.import-count-chip.accent.svelte-3rghwu{background:color-mix(in srgb, var(--accent) 15%, transparent);border-color:color-mix(in srgb, var(--accent) 40%, transparent);color:var(--accent-l)}.import-count-chip.gold.svelte-3rghwu{background:color-mix(in srgb, var(--gold) 15%, transparent);border-color:color-mix(in srgb, var(--gold) 40%, transparent);color:var(--gold-l)}.import-count-chip.teal.svelte-3rghwu{background:color-mix(in srgb, var(--teal) 15%, transparent);border-color:color-mix(in srgb, var(--teal) 40%, transparent);color:var(--teal-l)}.import-save-row.svelte-3rghwu{flex-wrap:wrap;align-items:center;gap:8px;margin-top:4px;display:flex}.import-save-btns.svelte-3rghwu{flex-wrap:wrap;justify-content:flex-end;gap:6px;margin-left:auto;display:flex}.btn-gold{background:var(--gold-d);color:var(--gold-l);border-color:var(--gold)}.btn-gold:hover:not(:disabled){background:color-mix(in srgb, var(--gold-d) 70%, var(--gold))}.import-save-hint.svelte-3rghwu{color:var(--text-faint);margin-top:8px;font-size:10px;line-height:1.6}.import-save-hint.svelte-3rghwu strong:where(.svelte-3rghwu){color:var(--text-dim)}.login-shell.svelte-8ukb9p{background:var(--bg);justify-content:center;align-items:center;height:100vh;display:flex}.login-card.svelte-8ukb9p{background:var(--surface);border:1px solid var(--border2);border-radius:16px;flex-direction:column;align-items:center;gap:12px;width:340px;padding:36px 32px;display:flex}.login-logo.svelte-8ukb9p{margin-bottom:4px;font-size:40px;line-height:1}.login-title.svelte-8ukb9p{color:var(--accent-l);margin:0;font-size:22px;font-weight:700}.login-sub.svelte-8ukb9p{color:var(--text-dim);text-align:center;margin:0;font-size:12px}.login-error.svelte-8ukb9p{background:color-mix(in srgb, var(--red) 15%, transparent);border:1px solid color-mix(in srgb, var(--red) 40%, transparent);width:100%;color:var(--red);border-radius:8px;padding:8px 12px;font-size:12px}.login-info.svelte-8ukb9p{background:color-mix(in srgb, var(--green) 15%, transparent);border:1px solid color-mix(in srgb, var(--green) 40%, transparent);width:100%;color:var(--green);border-radius:8px;padding:8px 12px;font-size:12px}.login-fields.svelte-8ukb9p{flex-direction:column;gap:8px;width:100%;display:flex}.login-fields.svelte-8ukb9p input:where(.svelte-8ukb9p){background:var(--surface2);border:1px solid var(--border2);width:100%;color:var(--text);border-radius:8px;padding:9px 12px;font-size:13px}.login-fields.svelte-8ukb9p input:where(.svelte-8ukb9p):focus{border-color:var(--accent);outline:none}.login-submit.svelte-8ukb9p{width:100%;padding:10px;font-size:14px;font-weight:600}.login-toggle.svelte-8ukb9p{color:var(--text-dim);cursor:pointer;background:0 0;border:none;padding:0;font-size:11px}.login-toggle.svelte-8ukb9p:hover{color:var(--text);text-decoration:underline}.app-loading.svelte-1n46o8q{height:100vh;color:var(--text-faint);flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:36px;display:flex}.app-loading.svelte-1n46o8q p:where(.svelte-1n46o8q){font-size:13px}.signout-btn.svelte-1n46o8q{border:1px solid var(--border);color:var(--text-faint);cursor:pointer;z-index:10;background:0 0;border-radius:6px;padding:4px 8px;font-size:14px;position:fixed;bottom:12px;left:12px}.signout-btn.svelte-1n46o8q:hover{color:var(--text);border-color:var(--border2)}
