*,: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}.ac-spin::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.ac-spin::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.ac-spin{-moz-appearance:textfield}.ac-stepper{gap:2px;margin-top:2px;display:flex}.ac-stepper button{background:var(--surface);border:1px solid var(--border2);color:var(--text-dim);cursor:pointer;border-radius:3px;flex:1;padding:2px 0;font-family:inherit;font-size:9px;line-height:1}.ac-stepper button:hover{background:var(--border);color:var(--text)}.ac-stepper .ac-reset{background:var(--teal-d);border-color:var(--teal);color:var(--teal-l)}.ac-stepper .ac-reset:hover{background:var(--teal);color:#fff}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;position:relative;overflow:hidden}.roster-resize-handle{cursor:col-resize;z-index:20;width:6px;position:absolute;top:0;bottom:0;right:-3px}.roster-resize-handle:after{content:"";background:0 0;width:2px;transition:background .15s;position:absolute;top:0;bottom:0;left:2px}.roster-resize-handle:hover:after,.roster-resize-handle.dragging:after{background:var(--accent);opacity:.6}.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;align-items:center;gap:6px;padding:6px 8px;display:flex}.roster-search-inner{flex:1;position:relative}.roster-search-inner 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-inner 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:6px;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.compact{padding:6px 8px}.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:52px;font-size:13px;font-weight:700;overflow:hidden}.roster-card.compact .roster-card-name{margin-bottom:1px;font-size:12px}.roster-card-sub{color:var(--text-dim);margin-bottom:5px;font-size:10px}.roster-card.compact .roster-card-sub{margin-bottom:3px;font-size:9px}.roster-card-meta{flex-wrap:wrap;align-items:center;gap:4px;margin-top:4px;display:flex}.roster-card.compact .roster-card-meta{gap:3px;margin-top:2px}.roster-card-btns{opacity:0;gap:3px;transition:opacity .15s;display:flex;position:absolute;top:7px;right:7px}.roster-card.compact .roster-card-btns{top:5px;right:5px}.roster-card:hover .roster-card-btns{opacity:1}.enc-selector-bar{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:4px;padding:6px 8px;display:flex}.enc-select{background:var(--bg);border:1px solid var(--border2);min-width:0;color:var(--text);cursor:pointer;border-radius:5px;flex:1;padding:4px 6px;font-family:inherit;font-size:11px;font-weight:600}.enc-select:focus{border-color:var(--accent);outline:none}.enc-rename-input{background:var(--bg);border:1px solid var(--accent);min-width:0;color:var(--text);border-radius:5px;outline:none;flex:1;padding:4px 6px;font-family:inherit;font-size:11px;font-weight:600}.enc-title-row{align-items:center;gap:5px;margin-bottom:2px;padding-right:52px;display:flex}.enc-title-row .roster-card-name{flex:1;min-width:0;margin-bottom:0;padding-right:0}.enc-title-pips{flex-shrink:0;align-items:center;gap:2px;display:flex}.enc-title-lr{color:var(--teal-l);flex-shrink:0;font-size:10px}.enc-ac-hp{align-items:center;gap:5px;margin:5px 0 4px;display:flex}.hp-btn{cursor:pointer;border:1px solid;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-family:inherit;font-size:16px;font-weight:700;line-height:1;transition:all .15s;display:flex}.hp-btn-dmg{border-color:var(--red);color:#f08090;background:#3d1520}.hp-btn-dmg:hover{background:var(--red);color:#fff}.hp-btn-heal{border-color:var(--green);color:#80d0a0;background:#1a3d2a}.hp-btn-heal:hover{background:var(--green);color:#fff}.hp-input{text-align:center;background:var(--bg);border:1px solid var(--border2);color:var(--text);border-radius:5px;flex:1;min-width:0;padding:4px 2px;font-size:12px;font-weight:600}.hp-input:focus{border-color:var(--accent);outline:none}.hp-input::placeholder{color:var(--text-faint);font-weight:400}.encounter-notes{background:var(--bg);border:1px solid var(--border2);width:100%;color:var(--text);resize:none;border-radius:5px;margin-top:6px;padding:5px 7px;font-family:inherit;font-size:10px;line-height:1.45;transition:border-color .15s;display:block}.encounter-notes::placeholder{color:var(--text-faint)}.encounter-notes:focus{border-color:var(--accent);outline:none}.drag-handle{color:var(--text-faint);cursor:grab;-webkit-user-select:none;user-select:none;opacity:0;font-size:14px;line-height:1;transition:opacity .15s;position:absolute;bottom:6px;right:8px}.roster-card:hover .drag-handle{opacity:1}.drag-handle:active{cursor:grabbing}.drag-wrapper{display:block}.drag-wrapper.is-dragging .roster-card{opacity:.35}.drag-wrapper.is-drag-over-before .roster-card{border-top:2px solid var(--accent)}.drag-wrapper.is-drag-over-after .roster-card{border-bottom:2px solid var(--accent)}.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-direction:column;flex-shrink:0;gap:8px;padding:10px 16px 12px;display:flex}.npc-header-top{align-items:center;gap:10px;display:flex}.npc-header-name-block{flex:1;min-width:0}.npc-header-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:20px;font-weight:700;overflow:hidden}.npc-header-sub{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;margin-top:1px;font-size:11px;overflow:hidden}.npc-header-badges{flex-shrink:0;align-items:center;gap:6px;display:flex}.npc-badge-stat{color:var(--text-dim);white-space:nowrap;font-size:11px;font-weight:600}.npc-stats-bar{background:#0000004d;border-radius:8px;align-items:center;gap:14px;padding:7px 12px;display:flex}.hdr-stat{flex-direction:column;flex-shrink:0;align-items:center;gap:2px;display:flex}.hdr-stat-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim);white-space:nowrap;font-size:9px;font-weight:700}.hdr-stat-val{color:var(--text);font-size:16px;font-weight:800;line-height:1}.hdr-stat-speed{flex:1;align-items:flex-start;min-width:0}.hdr-divider{background:var(--border2);flex-shrink:0;width:1px;height:32px}.hdr-hp{flex:1;align-items:center;gap:5px;min-width:0;display:flex}.hdr-hp-bar-wrap{background:var(--border);border-radius:5px;flex:1;min-width:0;height:26px;position:relative;overflow:hidden}.hdr-hp-bar{border-radius:5px;width:0;transition:width .3s,background .3s;position:absolute;inset:0}.hdr-hp-text{white-space:nowrap;color:#fff;text-shadow:0 1px 4px #000000d9;justify-content:center;align-items:center;gap:1px;font-size:13px;font-weight:800;display:flex;position:absolute;inset:0}.hdr-hp-input{flex:none!important;width:72px!important;padding:5px 6px!important;font-size:13px!important}.secondary-strip{background:var(--surface);border-bottom:2px solid var(--border);flex-shrink:0;padding:10px 16px}.secondary-strip-grid{grid-template-columns:repeat(3,1fr);align-items:stretch;gap:10px;display:grid}.secondary-strip-grid .card{flex-direction:column;margin-bottom:0;display:flex}.secondary-strip-grid .card-body{flex-direction:column;flex:1;display:flex}.secondary-strip-grid .card-body>div:first-child{flex:1}.secondary-strip-grid .stat-box{flex-direction:column;justify-content:center;display:flex}.combat-stat-grid .stat-box{justify-content:space-between;padding-bottom:4px}.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-grid-2col{grid-template-columns:280px 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}.roster-view-btn{background:var(--surface2);border:1px solid var(--border2);color:var(--text-faint);cursor:pointer;border-radius:5px;flex-shrink:0;padding:5px 8px;font-size:14px;line-height:1;transition:all .15s}.roster-view-btn:hover{border-color:var(--accent);color:var(--text)}.roster-view-btn.active{border-color:var(--accent);color:var(--accent-l);background:var(--accent-d)}.folder-group{margin-bottom:3px}.folder-group-header{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text-dim);cursor:pointer;text-align:left;border-radius:6px;align-items:center;gap:6px;padding:5px 8px;font-family:inherit;font-size:11px;font-weight:600;transition:all .15s;display:flex}.folder-group-header:hover{background:var(--surface2);color:var(--text);border-color:var(--border2)}.folder-chevron{flex-shrink:0;font-size:10px;transition:transform .18s}.folder-chevron.collapsed{transform:rotate(-90deg)}.folder-group-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.folder-group-count{background:var(--border2);color:var(--text-dim);border-radius:8px;flex-shrink:0;padding:1px 5px;font-size:9px;font-weight:700}.folder-group-npcs{flex-direction:column;gap:4px;margin-top:3px;padding-left:8px;display:flex}.folder-empty{color:var(--text-faint);padding:4px 8px 2px;font-size:10px}.mgmt-section{border-top:1px solid var(--border);margin-top:12px;padding-top:12px}.mgmt-section-title{text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim);margin-bottom:8px;font-size:10px;font-weight:700}.mgmt-list{flex-direction:column;gap:4px;margin-bottom:8px;display:flex}.mgmt-row{background:var(--surface2);border:1px solid var(--border2);border-radius:6px;align-items:center;gap:6px;padding:5px 8px;display:flex}.mgmt-row-name{color:var(--text);text-overflow:ellipsis;flex:1;min-width:0;font-size:12px;overflow:hidden}.mgmt-row-btns{flex-shrink:0;gap:4px;display:flex}.mgmt-inline-input{border:none;border-bottom:1px solid var(--accent);color:var(--text);background:0 0;outline:none;flex:1;padding:2px 4px;font-family:inherit;font-size:12px}.mgmt-add-row{align-items:center;gap:6px;display:flex}.mgmt-add-row input{flex:1}.mgmt-empty{color:var(--text-faint);padding:4px 0 8px;font-size:11px}.tag-pill-sm{background:var(--teal-d);border:1px solid var(--teal);color:var(--teal-l);border-radius:10px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.tag-picker{flex-wrap:wrap;gap:5px;padding:3px 0;display:flex}.tag-picker-pill{border:1px solid var(--border2);background:var(--surface2);color:var(--text-dim);cursor:pointer;border-radius:10px;padding:3px 10px;font-family:inherit;font-size:11px;font-weight:500;transition:all .15s}.tag-picker-pill:hover{border-color:var(--teal);color:var(--text)}.tag-picker-pill.active{background:var(--teal-d);border-color:var(--teal);color:var(--teal-l);font-weight:700}.enc-round-banner{text-align:center;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);border-bottom:1px solid var(--border);background:#1a1808;flex-shrink:0;padding:4px 8px;font-size:11px;font-weight:700}.roster-card.is-down{border-color:var(--border);opacity:.65;background:#0f0e13}.roster-card.is-down:hover{border-color:var(--border2);opacity:.85}.roster-card.is-down.active{border-color:var(--accent);opacity:1}.down-badge{flex-shrink:0;font-size:11px;line-height:1}.roster-card.is-current-turn{border-color:var(--gold);box-shadow:inset 3px 0 0 var(--gold);background:#1e1a08}.roster-card.is-current-turn:hover{border-color:var(--gold-l)}.reaction-btn{border:1px solid var(--gold);cursor:pointer;width:26px;height:26px;color:var(--gold-l);background:#2a2010;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;font-family:inherit;font-size:13px;line-height:1;transition:all .15s;display:flex}.reaction-btn:hover{background:var(--gold-d);color:#fff}.reaction-btn.reaction-used{background:var(--surface2);border-color:var(--border2);color:var(--text-faint);opacity:.45;text-decoration:line-through}.reaction-btn.reaction-used:hover{opacity:.75}.concentration-btn{border:1px solid var(--purple);cursor:pointer;width:26px;height:26px;color:var(--purple-l);opacity:.5;background:#1a1030;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;font-family:inherit;font-size:13px;line-height:1;transition:all .15s;display:flex}.concentration-btn:hover{background:var(--purple);color:#fff;opacity:1}.concentration-btn.concentrating{background:var(--purple);border-color:var(--purple-l);color:#fff;opacity:1}.cond-row{flex-wrap:wrap;gap:3px;margin-top:5px;display:flex}.custom-cond-pill{background:var(--gold-d);border:1px solid var(--gold);color:var(--gold-l);border-radius:10px;align-items:center;gap:2px;padding:2px 5px 2px 7px;font-size:8px;font-weight:600;line-height:1.4;display:inline-flex}.custom-cond-remove{cursor:pointer;color:var(--gold-l);opacity:.7;background:0 0;border:none;align-items:center;padding:0;font-size:10px;line-height:1;display:flex}.custom-cond-remove:hover{opacity:1}.cond-add-row{align-items:center;gap:4px;margin-top:4px;display:flex}.cond-add-input{border:none;border-bottom:1px solid var(--border2);min-width:0;color:var(--text);background:0 0;outline:none;flex:1;padding:2px;font-family:inherit;font-size:10px}.cond-add-input:focus{border-color:var(--gold)}.cond-add-input::placeholder{color:var(--text-faint)}.footer-primary-row{align-items:stretch;gap:6px;display:flex}.footer-menu-wrap{flex-shrink:0;position:relative}.footer-menu-btn{height:100%;padding:6px 12px;font-size:14px}.footer-menu{background:var(--surface);border:1px solid var(--border2);z-index:20;border-radius:8px;min-width:210px;padding:4px;position:absolute;bottom:calc(100% + 6px);right:0;box-shadow:0 -4px 20px #00000080}.footer-menu-item{text-align:left;width:100%;color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:5px;padding:8px 12px;font-family:inherit;font-size:12px;transition:all .12s;display:block}.footer-menu-item:hover{background:var(--surface2);color:var(--text)}.footer-menu-divider{border-top:1px solid var(--border);margin:4px 0}.enc-footer-pair{gap:6px;display:flex}.enc-footer-pair>*{flex:1;min-width:0}.initiative-badge{background:var(--gold-d);border:1px solid var(--gold);color:var(--gold-l);border-radius:8px;flex-shrink:0;padding:1px 7px;font-size:10px;font-weight:700;line-height:1.6}.roster-card.is-player{border-color:var(--teal-d);cursor:default}.roster-card.is-player:hover{border-color:var(--teal)}.roster-card.is-player.is-current-turn{border-color:var(--gold)}.player-name-input{background:var(--surface2);border:1px solid var(--teal-d);min-width:0;color:var(--text);border-radius:6px;outline:none;flex:1;padding:5px 8px;font-family:inherit;font-size:12px;transition:border-color .15s}.player-name-input:focus{border-color:var(--teal)}.player-name-input::placeholder{color:var(--text-faint)}.roster-filter-btn{background:var(--surface2);border:1px solid var(--border2);color:var(--text-faint);cursor:pointer;border-radius:5px;flex-shrink:0;padding:5px 8px;font-size:12px;line-height:1;transition:all .15s}.roster-filter-btn:hover{border-color:var(--accent);color:var(--text)}.roster-filter-btn.active{border-color:var(--accent);color:var(--accent-l);background:var(--accent-d)}.filter-panel{background:var(--bg);border-bottom:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:7px;padding:8px 10px;display:flex}.filter-row{align-items:flex-start;gap:6px;display:flex}.filter-label{text-transform:uppercase;letter-spacing:.07em;width:30px;color:var(--text-faint);flex-shrink:0;padding-top:3px;font-size:9px;font-weight:700}.filter-select{background:var(--surface2);border:1px solid var(--border2);color:var(--text);border-radius:5px;outline:none;flex:1;padding:3px 5px;font-family:inherit;font-size:11px}.filter-select:focus{border-color:var(--accent)}.filter-dash{color:var(--text-faint);flex-shrink:0;padding-top:3px}.filter-pills{flex-wrap:wrap;gap:3px;display:flex}.filter-pill{border:1px solid var(--border2);background:var(--surface2);color:var(--text-dim);cursor:pointer;white-space:nowrap;border-radius:8px;padding:2px 7px;font-family:inherit;font-size:10px;font-weight:500;transition:all .12s}.filter-pill:hover{border-color:var(--accent);color:var(--text)}.filter-pill.active{background:var(--accent-d);border-color:var(--accent);color:var(--accent-l);font-weight:700}.filter-clear-btn{color:var(--text-faint);cursor:pointer;background:0 0;border:none;align-self:flex-start;padding:0;font-family:inherit;font-size:10px;transition:color .12s}.filter-clear-btn:hover{color:var(--accent-l)}.filter-chips{background:var(--bg);border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;gap:3px;padding:4px 8px;display:flex}.filter-chip{background:var(--accent-d);border:1px solid var(--accent);color:var(--accent-l);border-radius:8px;align-items:center;gap:3px;padding:2px 4px 2px 7px;font-size:10px;font-weight:600;display:inline-flex}.filter-chip button{color:var(--accent-l);cursor:pointer;opacity:.7;background:0 0;border:none;padding:0 1px;font-size:11px;line-height:1}.filter-chip button:hover{opacity:1}.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}.util-topbar{background:var(--surface);border-bottom:1px solid var(--border);flex-direction:column;flex-shrink:0;display:flex}.util-topbar-main{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:8px;padding:8px 14px;display:flex}.util-title{color:var(--text);white-space:nowrap;flex-shrink:0;font-size:14px;font-weight:700}.util-hub-btn{border:1px solid var(--border2);background:var(--surface2);color:var(--text-dim);cursor:pointer;white-space:nowrap;border-radius:6px;flex-shrink:0;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s}.util-hub-btn:hover{color:var(--text);background:var(--border)}.util-tab-strip{display:flex}.util-tab{text-align:center;border:none;border-right:1px solid var(--border);color:var(--text-dim);cursor:pointer;white-space:nowrap;text-overflow:ellipsis;background:0 0;flex:1;padding:9px 6px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s;overflow:hidden}.util-tab:last-child{border-right:none}.util-tab:hover{color:var(--text);background:var(--surface2)}.util-tab.active{color:var(--accent-l);background:var(--surface2);box-shadow:inset 0 -2px 0 var(--accent);font-weight:700}.hub-list{border-top:1px solid var(--border);flex-direction:column;width:100%;max-width:420px;padding:0 20px;display:flex}.hub-row{border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left;background:0 0;border-radius:0;align-items:center;gap:14px;width:100%;padding:16px 4px;font-family:inherit;transition:background .12s;display:flex}.hub-row:hover{background:var(--surface2)}.hub-row-icon{text-align:center;flex-shrink:0;width:32px;font-size:24px;line-height:1}.hub-row-name{color:var(--text);flex:1;font-size:15px;font-weight:700}.hub-row-arrow{color:var(--text-faint);flex-shrink:0;font-size:18px}.hub-title{color:var(--text);letter-spacing:-.02em;font-size:28px;font-weight:700}.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}.dh-wrap.svelte-md774e{background:var(--bg);flex-direction:column;flex:1;min-width:0;height:100vh;display:flex}.roster-content.svelte-md774e{flex-direction:column;flex:1;align-items:center;gap:16px;width:100%;max-width:480px;margin:0 auto;padding:20px 20px 32px;display:flex;overflow-y:auto}.roster-empty.svelte-md774e{color:var(--text-faint);text-align:center;padding:24px 0 8px;font-size:14px}.roster-list.svelte-md774e{flex-direction:column;width:100%;display:flex}.hub-row-info.svelte-md774e{flex-direction:column;flex:1;gap:2px;display:flex}.hub-row-sub.svelte-md774e{color:var(--text-faint);font-size:12px;font-weight:400}.new-char-btn.svelte-md774e{border:1px dashed var(--border2);width:100%;color:var(--text-dim);cursor:pointer;background:0 0;border-radius:10px;padding:13px;font-family:inherit;font-size:14px;font-weight:600;transition:all .15s}.new-char-btn.svelte-md774e:hover{border-color:var(--accent);color:var(--accent-l);background:color-mix(in srgb, var(--accent) 6%, transparent)}.backup-row.svelte-md774e{gap:8px;width:100%;display:flex}.backup-btn.svelte-md774e{border:1px solid var(--border2);color:var(--text-faint);cursor:pointer;background:0 0;border-radius:8px;flex:1;padding:10px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.backup-btn.svelte-md774e:hover{color:var(--text-dim);border-color:var(--border);background:var(--surface2)}.import-toast.svelte-md774e{text-align:center;background:var(--surface);border:1px solid var(--border2);width:100%;color:var(--text-dim);border-radius:10px;padding:10px 14px;font-size:13px;font-weight:600}.back-chars-btn.svelte-md774e{color:var(--text-faint);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:0;font-family:inherit;font-size:12px;font-weight:600;transition:color .15s}.back-chars-btn.svelte-md774e:hover{color:var(--text)}.sheet-title.svelte-md774e{text-align:center;text-overflow:ellipsis;white-space:nowrap;flex:1;padding:0 8px;font-size:14px;overflow:hidden}.char-class.svelte-md774e{color:var(--text-dim);margin-left:4px;font-size:12px;font-weight:400}.content.svelte-md774e{flex-direction:column;flex:1;gap:12px;width:100%;max-width:520px;margin:0 auto;padding:14px;display:flex;overflow-y:auto}.section-card.svelte-md774e{background:var(--surface);border:1px solid var(--border2);border-radius:12px;flex-direction:column;gap:10px;padding:12px 14px;display:flex}.pip-list-card.svelte-md774e{flex-direction:column;gap:20px;display:flex}.pip-row.svelte-md774e{grid-template-columns:52px 1fr 32px;align-items:center;gap:6px;display:grid}.pip-label.svelte-md774e{color:var(--text-faint);text-transform:uppercase;letter-spacing:.06em;align-items:center;font-size:12px;font-weight:700;display:flex}.pip-track.svelte-md774e{align-items:center;display:grid}.pip-count.svelte-md774e{color:var(--text-faint);text-align:right;font-size:11px}.pip.svelte-md774e{cursor:pointer;color:var(--text-faint);background:0 0;border:none;justify-content:center;align-items:center;width:100%;padding:0;font-size:22px;line-height:1;transition:color .12s,transform .12s;display:flex}.pip.svelte-md774e:hover{opacity:.8;transform:scale(1.15)}.pip.hp-pip.filled.svelte-md774e{color:var(--accent-l);transform:scale(1.1)}.pip.stress-pip.filled.svelte-md774e{color:var(--warn);transform:scale(1.1)}.pip.hope-pip.filled.svelte-md774e{color:var(--gold-l);transform:scale(1.1)}.pip.armor-pip.filled.svelte-md774e{color:var(--green);transform:scale(1.1)}.pip.pip-ghost.svelte-md774e{visibility:hidden;pointer-events:none}.status-actions.svelte-md774e{justify-content:space-between;align-items:center;gap:8px;display:flex}.rest-btn-group.svelte-md774e{gap:6px;display:flex}.rest-btn.svelte-md774e{border:1px solid var(--border2);color:var(--text-faint);cursor:pointer;background:0 0;border-radius:8px;padding:6px 12px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s}.short-rest-btn.svelte-md774e{border-color:color-mix(in srgb, var(--teal) 40%, transparent);color:var(--teal)}.long-rest-btn.svelte-md774e{border-color:color-mix(in srgb, var(--green) 40%, transparent);color:var(--green)}.session-rest-btn.svelte-md774e{border-color:color-mix(in srgb, var(--gold) 40%, transparent);color:var(--gold)}.short-rest-btn.svelte-md774e:hover{background:color-mix(in srgb, var(--teal) 12%, transparent)}.long-rest-btn.svelte-md774e:hover{background:color-mix(in srgb, var(--green) 12%, transparent)}.session-rest-btn.svelte-md774e:hover{background:color-mix(in srgb, var(--gold) 12%, transparent)}.rest-btn.confirming.svelte-md774e{animation:.6s ease-in-out infinite alternate svelte-md774e-pulse-confirm}@keyframes svelte-md774e-pulse-confirm{0%{opacity:1}to{opacity:.5}}.card-mode-strip.svelte-md774e{gap:6px;margin-bottom:10px;display:flex}.card-mode-btn.svelte-md774e{border:1px solid var(--border2);color:var(--text-faint);cursor:pointer;background:0 0;border-radius:8px;flex:1;padding:7px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.card-mode-btn.active.svelte-md774e{background:var(--surface2);color:var(--text);border-color:var(--border)}.card-paste-area.svelte-md774e{box-sizing:border-box;resize:vertical;background:var(--surface2);border:1px solid var(--border);width:100%;color:var(--text);border-radius:8px;margin-bottom:8px;padding:10px;font-family:inherit;font-size:13px;line-height:1.5}.card-parse-btn.svelte-md774e{background:var(--teal-d,#0d4f4f);border:1px solid var(--teal);width:100%;color:var(--teal);cursor:pointer;border-radius:8px;margin-bottom:4px;padding:10px;font-family:inherit;font-size:14px;font-weight:700;transition:all .15s}.card-parse-btn.svelte-md774e:hover:not(:disabled){background:color-mix(in srgb, var(--teal) 20%, transparent)}.card-parse-btn.svelte-md774e:disabled{opacity:.4;cursor:default}.use-type-strip.svelte-md774e{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.use-type-btn.svelte-md774e{border:1px solid var(--border2);color:var(--text-faint);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;flex:1;padding:5px 8px;font-family:inherit;font-size:12px;font-weight:600;transition:all .12s}.use-type-btn.active.svelte-md774e{background:color-mix(in srgb, var(--teal) 15%, transparent);border-color:var(--teal);color:var(--teal)}.edit-btn.svelte-md774e{border:1px solid var(--border2);color:var(--text-faint);cursor:pointer;background:0 0;border-radius:8px;padding:6px 14px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s}.edit-btn.svelte-md774e:hover{color:var(--gold-l);border-color:var(--gold)}.edit-overlay.svelte-md774e{z-index:200;background:#000000a6;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.edit-modal.svelte-md774e{background:var(--surface);border:1px solid var(--border2);border-radius:16px;flex-direction:column;gap:14px;width:100%;max-width:420px;max-height:90vh;padding:20px;display:flex;overflow-y:auto}.edit-modal-title.svelte-md774e{color:var(--text);text-align:center;border-bottom:1px solid var(--border2);padding-bottom:4px;font-size:16px;font-weight:800}.edit-section-label.svelte-md774e{letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);margin-bottom:-6px;font-size:10px;font-weight:700}.edit-section-note.svelte-md774e{text-transform:none;letter-spacing:0;color:var(--text-faint);font-size:10px;font-weight:400}.edit-fields-row.svelte-md774e{gap:10px;display:flex}.edit-field.svelte-md774e{flex-direction:column;flex:1;gap:5px;display:flex}.edit-field.svelte-md774e label:where(.svelte-md774e){color:var(--text-dim);text-align:center;font-size:11px;font-weight:600}.edit-field.svelte-md774e input:where(.svelte-md774e){border:1px solid var(--border2);background:var(--surface2);width:100%;color:var(--text);text-align:center;font-variant-numeric:tabular-nums;-moz-appearance:textfield;border-radius:8px;outline:none;padding:8px 4px;font-family:inherit;font-size:18px;font-weight:700;transition:border-color .15s}.edit-field.svelte-md774e input:where(.svelte-md774e):focus{border-color:var(--accent)}.edit-field.svelte-md774e input:where(.svelte-md774e)::-webkit-outer-spin-button{-webkit-appearance:none}.edit-field.svelte-md774e input:where(.svelte-md774e)::-webkit-inner-spin-button{-webkit-appearance:none}.major-label.svelte-md774e{color:var(--warn)!important}.severe-label.svelte-md774e{color:var(--red)!important}.edit-done-btn.svelte-md774e{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:10px;width:100%;margin-top:4px;padding:10px;font-family:inherit;font-size:14px;font-weight:700;transition:background .15s}.edit-done-btn.svelte-md774e:hover{background:var(--accent-l)}.edit-done-btn.secondary.svelte-md774e{border:1px solid var(--border2);color:var(--text-faint);background:0 0}.edit-done-btn.secondary.svelte-md774e:hover{background:var(--surface2)}.rest-modal.svelte-md774e{max-width:420px}.rest-modal-header.svelte-md774e{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.rest-modal-title.svelte-md774e{color:var(--text);font-size:16px;font-weight:700}.rest-moves-left.svelte-md774e{align-items:center;gap:6px;display:flex}.rest-pip.svelte-md774e{color:var(--teal);font-size:14px;transition:color .15s}.rest-pip.filled.svelte-md774e{color:var(--border2)}.rest-moves-label.svelte-md774e{color:var(--text-faint);font-size:11px;font-weight:600}.rest-moves.svelte-md774e{flex-direction:column;gap:2px;margin-bottom:12px;display:flex}.rest-move.svelte-md774e{border-bottom:1px solid var(--border);flex-direction:column;gap:8px;padding:12px 4px;transition:opacity .15s;display:flex}.rest-move.svelte-md774e:last-child{border-bottom:none}.rest-move.move-done.svelte-md774e{opacity:.4}.rest-move-desc.svelte-md774e{color:var(--text-faint);margin-bottom:2px;font-size:11px}.rest-move-ctrl.svelte-md774e{align-items:center;gap:8px;width:100%;display:flex}.rest-move-ctrl.svelte-md774e .rest-take-btn:where(.svelte-md774e){flex-shrink:0;padding:7px 20px}.rest-move-ctrl.svelte-md774e .rest-take-btn:where(.svelte-md774e):only-child{flex:1}.rest-roll-group.svelte-md774e{flex:1;align-items:center;gap:8px;display:flex}.prepare-btn.svelte-md774e{flex:1}.rest-roll-input.svelte-md774e{border:1px solid var(--border2);background:var(--surface2);width:64px;color:var(--text);text-align:center;border-radius:6px;padding:7px 6px;font-family:inherit;font-size:15px}.rest-roll-input.svelte-md774e:focus{border-color:var(--accent);outline:none}.rest-roll-input.svelte-md774e:disabled{opacity:.4}.rest-tier-label.svelte-md774e{color:var(--text-faint);white-space:nowrap;font-size:12px;font-weight:600}.rest-dice-btn.svelte-md774e{border:1px solid var(--border2);cursor:pointer;background:0 0;border-radius:6px;padding:4px 7px;font-size:13px;transition:all .12s}.rest-dice-btn.svelte-md774e:hover:not(:disabled){border-color:var(--teal)}.rest-dice-btn.svelte-md774e:disabled{opacity:.35;cursor:default}.rest-take-btn.svelte-md774e{background:color-mix(in srgb, var(--teal) 12%, transparent);border:1px solid color-mix(in srgb, var(--teal) 35%, transparent);color:var(--teal);cursor:pointer;white-space:nowrap;border-radius:6px;padding:5px 10px;font-family:inherit;font-size:12px;font-weight:700;transition:all .12s}.rest-take-btn.svelte-md774e:hover:not(:disabled){background:color-mix(in srgb, var(--teal) 22%, transparent)}.rest-take-btn.svelte-md774e:disabled{opacity:.35;cursor:default}.rest-log.svelte-md774e{background:var(--surface);border-radius:8px;flex-direction:column;gap:4px;margin-bottom:12px;padding:10px 12px;display:flex}.rest-log-entry.svelte-md774e{color:var(--text-dim);font-size:12px}.roll-mode-strip.svelte-md774e{gap:6px;display:flex}.roll-mode-btn.svelte-md774e{border:1px solid var(--border2);color:var(--text-faint);cursor:pointer;background:0 0;border-radius:8px;flex:1;padding:7px 4px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s}.roll-mode-btn.active.svelte-md774e{background:var(--surface2);color:var(--text);border-color:var(--border)}.roll-mode-btn.adv.active.svelte-md774e{border-color:var(--teal);color:var(--teal-l);background:color-mix(in srgb, var(--teal) 8%, transparent)}.roll-mode-btn.dis.active.svelte-md774e{border-color:var(--accent);color:var(--accent-l);background:color-mix(in srgb, var(--accent) 8%, transparent)}.prof-row.svelte-md774e{background:var(--surface);border:1px solid var(--border2);border-radius:10px;justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.prof-label.svelte-md774e{color:var(--text-dim);font-size:13px;font-weight:700}.prof-ctrl.svelte-md774e{align-items:center;gap:10px;display:flex}.prof-val.svelte-md774e{color:var(--text);text-align:center;min-width:32px;font-size:20px;font-weight:800}.exp-row.svelte-md774e{background:var(--surface);border:1px solid var(--border2);border-radius:10px;justify-content:space-between;align-items:center;gap:10px;padding:10px 14px;display:flex}.exp-select.svelte-md774e{background:var(--surface2);border:1px solid var(--border);max-width:260px;color:var(--text);cursor:pointer;border-radius:6px;flex:1;padding:5px 8px;font-family:inherit;font-size:13px}.exp-select.svelte-md774e:focus{border-color:var(--gold);outline:none}.drr-exp.svelte-md774e{color:var(--gold)}.stat-trait-grid.svelte-md774e{grid-template-columns:repeat(6,1fr);gap:6px;margin-bottom:8px;display:grid}.stat-trait-tile.svelte-md774e{background:var(--surface);border:1px solid var(--border2);border-radius:10px;flex-direction:column;align-items:center;gap:2px;padding:6px 4px 4px;display:flex;overflow:hidden}.stat-trait-letter.svelte-md774e{letter-spacing:0;text-transform:uppercase;white-space:nowrap;text-overflow:ellipsis;text-align:center;width:100%;font-size:7px;font-weight:800;line-height:1;overflow:hidden}.stat-trait-full.svelte-md774e{display:none}@media (width>=520px){.stat-trait-short.svelte-md774e{display:none}.stat-trait-full.svelte-md774e{letter-spacing:.04em;font-size:8px;display:block}}.stat-trait-val.svelte-md774e{color:var(--text);font-variant-numeric:tabular-nums;cursor:pointer;text-align:center;background:0 0;border:none;border-radius:6px;width:100%;padding:4px 4px 6px;font-family:inherit;font-size:22px;font-weight:800;line-height:1;transition:background .1s}.stat-trait-val.svelte-md774e:hover{background:var(--surface2)}.stat-trait-input.svelte-md774e{color:var(--text);font-variant-numeric:tabular-nums;background:var(--surface2);border:1px solid var(--border);text-align:center;-moz-appearance:textfield;border-radius:6px;width:100%;padding:3px 2px 5px;font-family:inherit;font-size:20px;font-weight:800;line-height:1}.stat-trait-input.svelte-md774e::-webkit-inner-spin-button{-webkit-appearance:none}.stat-trait-input.svelte-md774e::-webkit-outer-spin-button{-webkit-appearance:none}.trait-edit-toggle.svelte-md774e{border:1px solid var(--border2);color:var(--text-faint);cursor:pointer;background:0 0;border-radius:6px;flex-shrink:0;margin-left:auto;padding:4px 9px;font-family:inherit;font-size:12px;font-weight:600;transition:all .1s}.trait-edit-toggle.svelte-md774e:hover{border-color:var(--border);color:var(--text-dim);background:var(--surface2)}.trait-edit-toggle.active.svelte-md774e{border-color:var(--gold);color:var(--gold);background:color-mix(in srgb, var(--gold) 10%, transparent)}.dh-roll-result.svelte-md774e{border:1px solid var(--border2);background:var(--surface);cursor:pointer;text-align:left;border-radius:12px;flex-direction:row;align-items:stretch;gap:12px;width:100%;padding:12px 14px;font-family:inherit;transition:opacity .15s;display:flex}.dh-roll-result.svelte-md774e:hover{opacity:.85}.dh-roll-result.with-hope.svelte-md774e{border-color:var(--teal);background:color-mix(in srgb, var(--teal) 6%, var(--surface))}.dh-roll-result.with-fear.svelte-md774e{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 6%, var(--surface))}.drr-left.svelte-md774e{flex-direction:column;flex:1;justify-content:center;gap:6px;display:flex}.drr-label.svelte-md774e{text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);font-size:11px;font-weight:700}.drr-outcome.svelte-md774e{font-size:13px;font-weight:700}.with-hope.svelte-md774e .drr-outcome:where(.svelte-md774e){color:var(--teal-l)}.with-fear.svelte-md774e .drr-outcome:where(.svelte-md774e){color:var(--accent-l)}.drr-total.svelte-md774e{color:var(--text);font-variant-numeric:tabular-nums;border-left:1px solid var(--border2);flex-shrink:0;align-items:center;padding-left:14px;font-size:52px;font-weight:800;line-height:1;display:flex}.drr-breakdown.svelte-md774e{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.drr-die.svelte-md774e{font-variant-numeric:tabular-nums;border-radius:6px;padding:3px 7px;font-size:13px;font-weight:700}.drr-hope.svelte-md774e{color:var(--teal-l);background:color-mix(in srgb, var(--teal) 12%, transparent)}.drr-fear.svelte-md774e{color:var(--accent-l);background:color-mix(in srgb, var(--accent) 12%, transparent)}.drr-adv.svelte-md774e{color:var(--green);background:color-mix(in srgb, var(--green) 12%, transparent)}.drr-dis.svelte-md774e{color:var(--warn);background:color-mix(in srgb, var(--warn) 12%, transparent)}.drr-op.svelte-md774e{color:var(--text-faint);font-size:12px;font-weight:600}.drr-sum.svelte-md774e{color:var(--text);font-variant-numeric:tabular-nums;font-size:15px;font-weight:800}.adj-btn.svelte-md774e{border:1px solid var(--border2);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-family:inherit;font-size:16px;transition:all .1s;display:flex}.adj-btn.svelte-md774e:hover{background:var(--surface2);border-color:var(--border);color:var(--text)}.save-card-btn.svelte-md774e{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;align-self:flex-end;padding:7px 18px;font-family:inherit;font-size:13px;font-weight:700;transition:background .15s}.save-card-btn.svelte-md774e:hover{background:var(--accent-l)}.card-chevron.svelte-md774e{color:var(--text-faint);font-size:11px}.card-desc.svelte-md774e{color:var(--text-dim);white-space:pre-wrap;padding:0 12px 10px;font-size:13px;line-height:1.5}.sub-ability.svelte-md774e{border-top:1px solid var(--border2);padding:8px 12px}.sub-ability.svelte-md774e:first-of-type{border-top:none}.sub-ability.sub-used.svelte-md774e{opacity:.45}.sub-ability-hdr.svelte-md774e{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:4px;display:flex}.sub-ability-name.svelte-md774e{text-transform:uppercase;letter-spacing:.06em;flex:1;font-size:12px;font-weight:800}.sub-ability-desc.svelte-md774e{color:var(--text-dim);margin:0;font-size:13px;line-height:1.5}.ab-edit-row.svelte-md774e{background:var(--surface2);border:1px solid var(--border2);border-radius:8px;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:6px;padding:8px 10px;display:flex}.ab-edit-row.ab-editing.svelte-md774e{flex-direction:column;align-items:stretch;gap:6px}.ab-row-name.svelte-md774e{color:var(--text);flex:1;font-size:13px;font-weight:600}.ab-row-edit.svelte-md774e{border:1px solid var(--border2);color:var(--text-faint);cursor:pointer;background:0 0;border-radius:6px;padding:2px 8px;font-family:inherit}.ab-row-edit.svelte-md774e:hover{color:var(--text);border-color:var(--border)}.ab-row-del.svelte-md774e{color:var(--text-faint);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;padding:2px 6px;font-family:inherit}.ab-row-del.svelte-md774e:hover{color:var(--accent-l);border-color:var(--accent)}.ab-name-input.svelte-md774e{box-sizing:border-box;background:var(--surface);border:1px solid var(--border);width:100%;color:var(--text);border-radius:6px;padding:6px 10px;font-family:inherit;font-size:14px;font-weight:600}.ab-desc-input.svelte-md774e{box-sizing:border-box;background:var(--surface);border:1px solid var(--border);width:100%;color:var(--text);resize:vertical;border-radius:6px;padding:6px 10px;font-family:inherit;font-size:13px}.ab-done-btn.svelte-md774e{border:1px solid var(--teal);color:var(--teal);cursor:pointer;background:0 0;border-radius:6px;align-self:flex-end;padding:5px 14px;font-family:inherit;font-size:12px;font-weight:700}.ab-done-btn.svelte-md774e:hover{background:color-mix(in srgb, var(--teal) 15%, transparent)}.ab-add-btn.svelte-md774e{border:1px dashed var(--border);width:100%;color:var(--text-faint);cursor:pointer;background:0 0;border-radius:8px;margin-bottom:10px;padding:7px;font-family:inherit;font-size:13px;font-weight:600}.ab-add-btn.svelte-md774e:hover{border-color:var(--teal);color:var(--teal)}.info-grid.svelte-md774e{grid-template-columns:1fr 1fr;gap:10px;display:grid}.info-field.svelte-md774e{flex-direction:column;gap:4px;display:flex}.info-field.full.svelte-md774e{grid-column:1/-1}.info-field.svelte-md774e label:where(.svelte-md774e){letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);font-size:10px;font-weight:700}.info-field.svelte-md774e input:where(.svelte-md774e){border:1px solid var(--border2);background:var(--surface);color:var(--text);border-radius:8px;outline:none;padding:9px 12px;font-family:inherit;font-size:14px;transition:border-color .15s}.info-field.svelte-md774e input:where(.svelte-md774e):focus{border-color:var(--accent)}.info-field.svelte-md774e input:where(.svelte-md774e)::placeholder{color:var(--text-faint)}.info-field.half.svelte-md774e{grid-column:span 1}.level-ctrl.svelte-md774e{border:1px solid var(--border2);background:var(--surface);border-radius:8px;align-items:center;display:flex;overflow:hidden}.level-ctrl.svelte-md774e button:where(.svelte-md774e){color:var(--text-dim);cursor:pointer;background:0 0;border:none;padding:7px 14px;font-family:inherit;font-size:18px;transition:background .1s}.level-ctrl.svelte-md774e button:where(.svelte-md774e):hover{background:var(--surface2);color:var(--text)}.level-ctrl.svelte-md774e span:where(.svelte-md774e){text-align:center;color:var(--text);flex:1;min-width:2ch;font-size:16px;font-weight:700}.dt-section.svelte-md774e{border-left:3px solid #0000;flex-direction:column;gap:8px;padding:10px 0 10px 12px;display:flex}.dt-section-label.svelte-md774e{text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);margin-bottom:2px;font-size:11px;font-weight:700}.dt-section.sec-teal.svelte-md774e{border-left-color:var(--teal)}.dt-section.sec-teal.svelte-md774e .dt-section-label:where(.svelte-md774e){color:var(--teal)}.dt-section.sec-purple.svelte-md774e{border-left-color:#9b59b6}.dt-section.sec-purple.svelte-md774e .dt-section-label:where(.svelte-md774e){color:#9b59b6}.dt-section.sec-blue.svelte-md774e{border-left-color:#3498db}.dt-section.sec-blue.svelte-md774e .dt-section-label:where(.svelte-md774e){color:#3498db}.dt-section.sec-gold.svelte-md774e{border-left-color:var(--gold)}.dt-section.sec-gold.svelte-md774e .dt-section-label:where(.svelte-md774e){color:var(--gold)}.dt-section.sec-pink.svelte-md774e{border-left-color:#e91e8c}.dt-section.sec-pink.svelte-md774e .dt-section-label:where(.svelte-md774e){color:#e91e8c}.dt-sys-strip.svelte-md774e{gap:6px;display:flex}.dt-sys-btn.svelte-md774e{border:1px solid var(--border2);color:var(--text-faint);cursor:pointer;background:0 0;border-radius:8px;flex:1;padding:7px 4px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s}.dt-sys-btn.active.svelte-md774e{background:var(--surface2);color:var(--text);border-color:var(--border)}.dt-sys-btn.active.adv.svelte-md774e{border-color:var(--green);color:var(--green);background:color-mix(in srgb, var(--green) 10%, var(--surface2))}.dt-sys-btn.active.dis.svelte-md774e{border-color:var(--warn);color:var(--warn);background:color-mix(in srgb, var(--warn) 10%, var(--surface2))}.dt-result-area.svelte-md774e{background:var(--surface);border:1px solid var(--border2);border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:16px;transition:border-color .3s,background .3s;display:flex;position:relative}.dt-result-clear.svelte-md774e{color:var(--text-faint);cursor:pointer;opacity:.5;background:0 0;border:none;padding:2px 4px;font-size:13px;line-height:1;transition:opacity .12s;position:absolute;top:8px;right:10px}.dt-result-clear.svelte-md774e:hover{opacity:1}.dt-result-area.nat20.svelte-md774e{border-color:var(--gold);background:color-mix(in srgb, var(--gold) 8%, var(--surface))}.dt-result-area.nat1.svelte-md774e{border-color:var(--red);background:color-mix(in srgb, var(--red) 8%, var(--surface))}.dt-result-total.svelte-md774e{color:var(--text);font-variant-numeric:tabular-nums;font-size:64px;font-weight:800;line-height:1}.dt-result-total.adv.svelte-md774e{color:var(--green)}.dt-result-total.dis.svelte-md774e{color:var(--warn)}.dt-result-sub.svelte-md774e{color:var(--text-dim);font-size:13px;font-weight:600}.nat20-lbl.svelte-md774e{color:var(--gold-l)}.nat1-lbl.svelte-md774e{color:var(--red)}.dt-breakdown.svelte-md774e{flex-wrap:wrap;justify-content:center;gap:6px;margin-top:4px;display:flex}.dt-die-badge.svelte-md774e{background:var(--surface2);border:1px solid var(--border2);color:var(--text-dim);border-radius:5px;padding:2px 8px;font-size:13px;font-weight:700}.dt-mod-badge.svelte-md774e{background:var(--surface2);border:1px solid var(--border2);color:var(--accent-l);border-color:var(--accent-d);border-radius:5px;padding:2px 8px;font-size:13px;font-weight:700}.dt-adv-dice.svelte-md774e{gap:16px;margin-top:6px;display:flex}.dt-adv-die.svelte-md774e{width:52px;height:52px;color:var(--text-faint);background:var(--surface2);border:2px solid var(--border2);border-radius:10px;justify-content:center;align-items:center;font-size:24px;font-weight:700;display:flex}.dt-adv-die.kept.svelte-md774e{color:var(--text);border-color:var(--accent);background:color-mix(in srgb, var(--accent) 12%, var(--surface2))}.dt-hf-dice.svelte-md774e{gap:20px;margin-top:6px;display:flex}.dt-hf-die.svelte-md774e{background:var(--surface2);border:2px solid var(--border2);opacity:.5;border-radius:12px;flex-direction:column;align-items:center;gap:4px;padding:10px 16px;transition:all .2s;display:flex}.dt-hf-die.winner.svelte-md774e{opacity:1}.dt-hf-die.hope.svelte-md774e{border-color:var(--teal)}.dt-hf-die.hope.winner.svelte-md774e{background:color-mix(in srgb, var(--teal) 12%, var(--surface2))}.dt-hf-die.fear.svelte-md774e{border-color:var(--red)}.dt-hf-die.fear.winner.svelte-md774e{background:color-mix(in srgb, var(--red) 12%, var(--surface2))}.dt-hf-icon.svelte-md774e{font-size:16px;line-height:1}.dt-hf-die.hope.svelte-md774e .dt-hf-icon:where(.svelte-md774e){color:var(--teal-l)}.dt-hf-die.fear.svelte-md774e .dt-hf-icon:where(.svelte-md774e){color:var(--red)}.dt-hf-val.svelte-md774e{color:var(--text);font-size:32px;font-weight:800;line-height:1}.dt-hf-name.svelte-md774e{text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint);font-size:10px;font-weight:700}.dt-outcome-badge.svelte-md774e{margin-top:4px;font-size:16px;font-weight:700}.dt-dice-grid.svelte-md774e{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.dt-die-btn.svelte-md774e{border:2px solid var(--border2);background:var(--surface);color:var(--text-dim);cursor:pointer;border-radius:10px;padding:12px 0;font-family:inherit;font-size:12px;font-weight:700;transition:all .12s}.dt-die-btn.svelte-md774e:hover{border-color:var(--accent);color:var(--text);background:color-mix(in srgb, var(--accent) 10%, var(--surface))}.dt-die-btn.svelte-md774e:active{transform:scale(.93)}.dt-die-btn.d20.svelte-md774e{border-color:var(--border);color:var(--text)}.dt-sys-controls.svelte-md774e{gap:10px;display:flex}.dt-sys-controls.col.svelte-md774e{flex-direction:column}.dt-ctrl-btn.svelte-md774e{border:2px solid var(--border2);background:var(--surface);color:var(--text-dim);cursor:pointer;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:6px;padding:14px 10px;font-family:inherit;font-size:14px;font-weight:700;transition:all .15s;display:flex}.dt-ctrl-btn.hf.svelte-md774e{border-color:var(--teal-d);gap:10px;padding:16px;font-size:16px}.dt-ctrl-btn.hf.svelte-md774e:hover{border-color:var(--teal);background:color-mix(in srgb, var(--teal) 8%, var(--surface))}.dt-hf-sep.svelte-md774e{color:var(--text-faint);font-weight:400}.dt-mod-row.svelte-md774e{justify-content:center;align-items:center;gap:12px;padding:8px;display:flex}.dt-mod-label.svelte-md774e{color:var(--text-faint);flex:1;font-size:12px;font-weight:600}.dt-mod-btn.svelte-md774e{border:1px solid var(--border2);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;width:34px;height:34px;font-family:inherit;font-size:18px;transition:all .1s;display:flex}.dt-mod-btn.svelte-md774e:hover{background:var(--surface2);border-color:var(--border);color:var(--text)}.dt-mod-val.svelte-md774e{color:var(--text);text-align:center;font-variant-numeric:tabular-nums;min-width:42px;font-size:20px;font-weight:700}.dt-expr-row.svelte-md774e{gap:8px;display:flex}.dt-expr-input.svelte-md774e{border:1px solid var(--border2);background:var(--surface);color:var(--text);border-radius:10px;outline:none;flex:1;padding:11px 14px;font-family:inherit;font-size:15px;transition:border-color .15s}.dt-expr-input.svelte-md774e:focus{border-color:var(--accent)}.dt-expr-input.svelte-md774e::placeholder{color:var(--text-faint)}.dt-expr-btn.svelte-md774e{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:10px;flex-shrink:0;padding:11px 18px;font-family:inherit;font-size:14px;font-weight:700;transition:background .15s}.dt-expr-btn.svelte-md774e:hover{background:var(--accent-l)}.dt-expr-err.svelte-md774e{color:var(--red);margin:-8px 0 0;font-size:12px}.dt-history-hdr.svelte-md774e{background:var(--surface);border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);justify-content:space-between;align-items:center;padding:8px 12px;font-size:11px;font-weight:700;display:flex}.dt-history-clear.svelte-md774e{color:var(--text-faint);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-family:inherit;font-size:11px;font-weight:600}.dt-history-clear.svelte-md774e:hover{color:var(--red);background:var(--surface2)}.dt-history-entry.svelte-md774e{color:var(--text-dim);border-bottom:1px solid var(--border);font-variant-numeric:tabular-nums;padding:7px 12px;font-size:13px}.dt-history-entry.first.svelte-md774e{color:var(--text);background:var(--surface)}.dt-history-entry.svelte-md774e:last-child{border-bottom:none}.gear-roll-result.svelte-md774e{background:var(--surface);border:2px solid var(--border2);border-radius:14px;flex-direction:column;gap:8px;padding:14px 16px;transition:border-color .3s;display:flex}.gear-roll-result.hope.svelte-md774e{border-color:var(--teal)}.gear-roll-result.fear.svelte-md774e{border-color:var(--red)}.gear-roll-header.svelte-md774e{align-items:center;gap:8px;display:flex}.gear-roll-weapon.svelte-md774e{color:var(--text);flex:1;font-size:14px;font-weight:700}.gear-clear-btn.svelte-md774e{color:var(--text-faint);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:14px;line-height:1}.gear-clear-btn.svelte-md774e:hover{color:var(--text)}.gear-roll-trait.svelte-md774e{text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint);font-size:11px;font-weight:700}.gear-attack-row.svelte-md774e{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.gear-atk-total.svelte-md774e{color:var(--text);font-variant-numeric:tabular-nums;font-size:42px;font-weight:800;line-height:1}.gear-hf-pair.svelte-md774e{flex-direction:column;gap:2px;display:flex}.gear-hf-die.svelte-md774e{font-size:13px;font-weight:700}.gear-hf-die.hope.svelte-md774e{color:var(--teal-l)}.gear-hf-die.fear.svelte-md774e{color:var(--red)}.gear-hf-mod.svelte-md774e{color:var(--text-faint);font-size:13px}.gear-outcome.svelte-md774e{margin-left:auto;font-size:14px;font-weight:700}.gear-dmg-row.svelte-md774e{border-top:1px solid var(--border);align-items:center;gap:8px;padding-top:6px;display:flex}.gear-dmg-label.svelte-md774e{color:var(--text-faint);flex:1;font-size:12px}.gear-dmg-total.svelte-md774e{color:var(--accent-l);font-variant-numeric:tabular-nums;font-size:22px;font-weight:800}.gear-dmg-break.svelte-md774e{color:var(--text-faint);font-size:12px}.gear-section.svelte-md774e{flex-direction:column;gap:6px;display:flex}.gear-section-hdr.svelte-md774e{border-left:3px solid #0000;border-radius:2px;justify-content:space-between;align-items:center;padding:4px 0 4px 10px;display:flex}.gear-section-title.svelte-md774e{text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);font-size:11px;font-weight:700}.sec-teal.svelte-md774e .gear-section-hdr:where(.svelte-md774e){border-left-color:var(--teal)}.sec-teal.svelte-md774e .gear-section-title:where(.svelte-md774e){color:var(--teal)}.sec-purple.svelte-md774e .gear-section-hdr:where(.svelte-md774e){border-left-color:#9b59b6}.sec-purple.svelte-md774e .gear-section-title:where(.svelte-md774e){color:#9b59b6}.sec-red.svelte-md774e .gear-section-hdr:where(.svelte-md774e){border-left-color:var(--accent)}.sec-red.svelte-md774e .gear-section-title:where(.svelte-md774e){color:var(--accent)}.sec-blue.svelte-md774e .gear-section-hdr:where(.svelte-md774e){border-left-color:#3498db}.sec-blue.svelte-md774e .gear-section-title:where(.svelte-md774e){color:#3498db}.sec-gold.svelte-md774e .gear-section-hdr:where(.svelte-md774e){border-left-color:var(--gold)}.sec-gold.svelte-md774e .gear-section-title:where(.svelte-md774e){color:var(--gold)}.sec-green.svelte-md774e .gear-section-hdr:where(.svelte-md774e){border-left-color:var(--green)}.sec-green.svelte-md774e .gear-section-title:where(.svelte-md774e){color:var(--green)}.sec-warn.svelte-md774e .gear-section-hdr:where(.svelte-md774e){border-left-color:var(--warn)}.sec-warn.svelte-md774e .gear-section-title:where(.svelte-md774e){color:var(--warn)}.sec-pink.svelte-md774e .gear-section-hdr:where(.svelte-md774e){border-left-color:#e91e8c}.sec-pink.svelte-md774e .gear-section-title:where(.svelte-md774e){color:#e91e8c}.domain-swatch-strip.svelte-md774e{flex-wrap:wrap;align-items:center;gap:8px;margin-top:4px;display:flex}.domain-swatch.svelte-md774e{cursor:pointer;border:2px solid #0000;border-radius:50%;flex-shrink:0;width:28px;height:28px;transition:transform .12s,box-shadow .12s}.domain-swatch.active.svelte-md774e{box-shadow:0 0 0 2px var(--bg), 0 0 0 4px currentColor;transform:scale(1.2)}.none-swatch.svelte-md774e{background:var(--surface2);border-color:var(--border2);color:var(--text-faint);border-radius:6px;width:auto;height:28px;padding:0 8px;font-family:inherit;font-size:10px;font-weight:700}.none-swatch.active.svelte-md774e{box-shadow:0 0 0 2px var(--bg), 0 0 0 4px var(--border2)}.sec-toggle.svelte-md774e{cursor:pointer;text-align:left;background:0 0;border:none;flex:1;align-items:center;gap:6px;padding:0;font-family:inherit;display:flex}.sec-chevron.svelte-md774e{color:var(--text-faint);font-size:14px;font-weight:700;transition:transform .18s;display:inline-block;transform:rotate(0)}.sec-chevron.open.svelte-md774e{transform:rotate(90deg)}.gear-add-btn.svelte-md774e{border:1px solid var(--border2);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:6px;padding:4px 10px;font-family:inherit;font-size:12px;font-weight:600;transition:all .1s}.gear-add-btn.svelte-md774e:hover{border-color:var(--border);color:var(--text);background:var(--surface2)}.gear-manage-btn.svelte-md774e{border:1px solid var(--border2);color:var(--text-faint);cursor:pointer;background:0 0;border-radius:6px;padding:3px 8px;font-family:inherit;font-size:13px;font-weight:600;transition:all .1s}.gear-manage-btn.svelte-md774e:hover{border-color:var(--border);color:var(--text-dim);background:var(--surface2)}.gear-manage-btn.active.svelte-md774e{border-color:var(--purple);color:var(--purple);background:color-mix(in srgb, var(--purple) 10%, transparent)}.loadout-manager.svelte-md774e{background:var(--surface);border:1px solid var(--border2);border-radius:10px;margin:6px 0 8px;padding:8px 0;overflow:hidden}.loadout-manager-note.svelte-md774e{color:var(--text-faint);border-bottom:1px solid var(--border2);margin-bottom:4px;padding:0 12px 8px;font-size:11px}.lm-row.svelte-md774e{border-bottom:1px solid color-mix(in srgb, var(--border2) 50%, transparent);align-items:center;gap:8px;padding:6px 12px;display:flex}.lm-row.svelte-md774e:last-child{border-bottom:none}.lm-card-name.svelte-md774e{flex:1;align-items:center;gap:6px;font-size:13px;font-weight:600;display:flex}.lm-level.svelte-md774e{color:var(--text-faint);font-size:10px;font-weight:500}.lm-stress.svelte-md774e{color:var(--warn);flex-shrink:0;font-size:11px}.lm-toggle.svelte-md774e{cursor:pointer;border:1px solid var(--border2);color:var(--text-faint);background:0 0;border-radius:5px;flex-shrink:0;padding:3px 10px;font-family:inherit;font-size:11px;font-weight:600;transition:all .12s}.lm-toggle.lm-in-loadout.svelte-md774e{border-color:var(--purple);color:var(--purple);background:color-mix(in srgb, var(--purple) 10%, transparent)}.lm-toggle.svelte-md774e:hover:not(:disabled){border-color:var(--border);color:var(--text);background:var(--surface2)}.lm-toggle.svelte-md774e:disabled{opacity:.4;cursor:default}.gear-empty.svelte-md774e{color:var(--text-faint);padding:8px 4px;font-size:13px;font-style:italic}.gear-weapon-card.svelte-md774e{background:var(--surface);border:1px solid var(--border2);border-radius:12px;flex-direction:column;gap:6px;padding:12px 14px;display:flex}.gear-weapon-top.svelte-md774e{align-items:center;gap:8px;display:flex}.gear-weapon-title.svelte-md774e{flex-direction:column;flex:1;gap:1px;display:flex}.gear-weapon-name.svelte-md774e{color:var(--text);font-size:15px;font-weight:700}.gear-weapon-trait.svelte-md774e{text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:600}.gear-weapon-badges.svelte-md774e{align-items:center;gap:6px;display:flex}.gear-dice-badge.svelte-md774e{background:var(--surface2);border:1px solid var(--border2);color:var(--text-dim);border-radius:5px;padding:2px 7px;font-size:11px;font-weight:700}.gear-dmg-roll-btn.svelte-md774e{cursor:pointer;border-color:var(--accent);height:36px;color:var(--accent-l);background:color-mix(in srgb, var(--accent) 10%, transparent);border-radius:8px;padding:0 12px;font-family:inherit;font-size:13px;font-weight:700;transition:all .12s}.gear-dmg-roll-btn.svelte-md774e:hover{background:color-mix(in srgb, var(--accent) 20%, transparent)}.gear-weapon-btns.svelte-md774e{gap:6px;display:flex}.gear-roll-btn.svelte-md774e{background:var(--accent-d);border:1px solid var(--accent);color:var(--accent-l);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;height:36px;padding:0 12px;font-family:inherit;font-size:13px;font-weight:700;transition:all .12s;display:flex}.gear-roll-btn.svelte-md774e:hover{background:var(--accent);color:#fff}.gear-roll-btn.svelte-md774e:active{transform:scale(.9)}.gear-edit-btn.svelte-md774e{border:1px solid var(--border2);color:var(--text-faint);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;transition:all .12s;display:flex}.gear-edit-btn.svelte-md774e:hover{border-color:var(--border);color:var(--text);background:var(--surface2)}.gear-weapon-notes.svelte-md774e{color:var(--text-faint);margin:0;font-size:13px;line-height:1.4}.gear-item-row.svelte-md774e{text-align:left;background:var(--surface);border:1px solid var(--border2);cursor:pointer;border-radius:10px;flex-wrap:wrap;align-items:baseline;gap:10px;width:100%;padding:10px 14px;font-family:inherit;transition:border-color .1s;display:flex}.gear-item-row.svelte-md774e:hover{border-color:var(--border);background:var(--surface2)}.gear-item-name.svelte-md774e{color:var(--text);font-size:14px;font-weight:600}.gear-item-desc.svelte-md774e{color:var(--text-faint);font-size:12px}.gear-trait-grid.svelte-md774e{grid-template-columns:repeat(3,1fr);gap:6px;margin-top:6px;display:grid}.gear-trait-pick.svelte-md774e{border:1px solid var(--border2);color:var(--text-faint);cursor:pointer;background:0 0;border-radius:8px;padding:8px 4px;font-family:inherit;font-size:12px;font-weight:600;transition:all .12s}.gear-trait-pick.active.svelte-md774e{background:var(--surface2)}.gear-trait-pick.svelte-md774e:hover{border-color:var(--border);color:var(--text)}.gear-modal-btns.svelte-md774e{gap:8px;margin-top:14px;display:flex}.gear-delete-btn.svelte-md774e{border:1px solid var(--red);color:var(--red);cursor:pointer;background:0 0;border-radius:10px;padding:12px 16px;font-family:inherit;font-size:14px;font-weight:600;transition:all .15s}.gear-delete-btn.svelte-md774e:hover{background:color-mix(in srgb, var(--red) 12%, transparent)}.gear-delete-btn.confirming.svelte-md774e{background:color-mix(in srgb, var(--red) 18%, transparent);border-color:var(--red);animation:.6s ease-in-out infinite alternate svelte-md774e-pulse-red}@keyframes svelte-md774e-pulse-red{0%{opacity:.8}to{opacity:1}}.edit-modal.svelte-md774e textarea:where(.svelte-md774e){border:1px solid var(--border2);background:var(--surface);width:100%;color:var(--text);resize:vertical;box-sizing:border-box;border-radius:8px;outline:none;padding:10px 12px;font-family:inherit;font-size:14px}.edit-modal.svelte-md774e textarea:where(.svelte-md774e):focus{border-color:var(--accent)}.defense-tile.svelte-md774e{background:var(--surface);border:1px solid var(--border2);border-radius:12px;align-items:center;gap:14px;padding:12px 16px;display:flex}.evade-stat.svelte-md774e{flex-direction:column;flex-shrink:0;align-items:center;gap:2px;display:flex}.evade-label.svelte-md774e{text-transform:uppercase;letter-spacing:.07em;color:var(--text-faint);font-size:10px;font-weight:700}.evade-val.svelte-md774e{color:var(--text);font-variant-numeric:tabular-nums;font-size:22px;font-weight:800}.thr-timeline-wrap.svelte-md774e{flex-direction:column;flex:1;gap:5px;display:flex}.thr-bar-row.svelte-md774e{align-items:center;display:flex;position:relative}.thr-seg.svelte-md774e{flex:1;height:6px}.thr-seg-minor.svelte-md774e{background:var(--green);border-radius:3px 0 0 3px}.thr-seg-major.svelte-md774e{background:var(--warn)}.thr-seg-severe.svelte-md774e{background:var(--accent-l);border-radius:0 3px 3px 0}.thr-divider.svelte-md774e{flex-shrink:0;width:0;position:relative}.thr-num.svelte-md774e{color:var(--text);background:var(--surface);border:1px solid var(--border2);white-space:nowrap;z-index:1;border-radius:5px;padding:1px 6px;font-size:17px;font-weight:800;position:absolute;top:50%;left:0;transform:translate(-50%,-50%)}.thr-label-row.svelte-md774e{display:flex}.thr-lbl.svelte-md774e{text-align:center;text-transform:uppercase;letter-spacing:.06em;flex:1;font-size:10px;font-weight:700}.thr-lbl-minor.svelte-md774e{color:var(--green)}.thr-lbl-major.svelte-md774e{color:var(--warn)}.thr-lbl-severe.svelte-md774e{color:var(--accent-l)}.thr-hint.svelte-md774e{color:var(--text-faint);margin:-4px 0 8px;font-size:11px}.loadout-pip-row.svelte-md774e{vertical-align:middle;gap:4px;margin-left:8px;display:inline-flex}.loadout-pip.svelte-md774e{border:1.5px solid var(--border2);background:0 0;border-radius:50%;width:8px;height:8px;transition:all .15s}.loadout-pip.filled.svelte-md774e{background:var(--gold-l);border-color:var(--gold)}.vault-hdr.svelte-md774e{border-top:1px solid var(--border);margin-top:10px;padding-top:10px}.vault-toggle.svelte-md774e{color:var(--text-dim);align-items:center;gap:4px;font-size:13px;font-weight:700;display:flex}.vault-count.svelte-md774e{color:var(--text-faint);font-size:11px;font-weight:500}.vault-card.svelte-md774e{opacity:.72}.vault-card.svelte-md774e:hover{opacity:1}.card-level-badge.svelte-md774e{background:color-mix(in srgb, var(--border2) 60%, transparent);border:1px solid var(--border2);color:var(--text-dim);white-space:nowrap;border-radius:5px;flex-shrink:0;padding:2px 6px;font-size:10px;font-weight:700}.stress-cost-badge.svelte-md774e{background:color-mix(in srgb, var(--warn) 14%, transparent);border:1px solid var(--warn);color:var(--warn);white-space:nowrap;border-radius:5px;flex-shrink:0;padding:2px 6px;font-size:10px;font-weight:700}.use-label-badge.svelte-md774e{background:color-mix(in srgb, var(--teal) 12%, transparent);border:1px solid color-mix(in srgb, var(--teal) 40%, transparent);color:var(--teal);white-space:nowrap;border-radius:5px;flex-shrink:0;padding:2px 6px;font-family:inherit;font-size:10px;font-weight:600}.use-toggle-btn.svelte-md774e{cursor:pointer;transition:all .15s}.use-toggle-btn.is-used.svelte-md774e{background:color-mix(in srgb, var(--border) 30%, transparent);border-color:var(--border2);color:var(--text-faint);text-decoration:line-through}.use-toggle-btn.svelte-md774e:hover:not(.is-used){background:color-mix(in srgb, var(--teal) 22%, transparent)}.warn-label.svelte-md774e{color:var(--warn)!important}.feature-card.svelte-md774e{background:var(--surface);border:1px solid var(--border2);border-radius:12px;flex-direction:column;gap:8px;padding:12px 14px;display:flex}.feature-top.svelte-md774e{align-items:center;gap:8px;display:flex}.feature-name-btn.svelte-md774e{color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;flex:1;align-items:center;gap:6px;font-family:inherit;font-size:14px;font-weight:600;display:flex}.feat-ctr-btn.svelte-md774e{border:1px solid var(--border2);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;font-family:inherit;font-size:16px;transition:all .1s;display:flex}.feat-ctr-btn.svelte-md774e:hover{background:var(--surface);border-color:var(--border);color:var(--text)}.feat-ctr-val.svelte-md774e{color:var(--text);text-align:center;font-variant-numeric:tabular-nums;min-width:32px;font-size:18px;font-weight:800}.feat-ctr-max.svelte-md774e{color:var(--text-faint);font-size:12px;font-weight:400}.feat-counter-toggle.svelte-md774e{align-items:center;display:flex}.feat-toggle-label.svelte-md774e{color:var(--text-dim);cursor:pointer;align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.feat-toggle-label.svelte-md774e input[type=checkbox]:where(.svelte-md774e){cursor:pointer;width:16px;height:16px;accent-color:var(--accent)}.exp-add-row.svelte-md774e{align-items:center;gap:8px;display:flex}.exp-input.svelte-md774e{border:1px solid var(--border2);background:var(--surface);color:var(--text);border-radius:8px;outline:none;flex:1;padding:10px 12px;font-family:inherit;font-size:14px}.exp-input.svelte-md774e:focus{border-color:var(--accent)}.exp-row.svelte-md774e{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:8px 4px;display:flex}.exp-row.svelte-md774e:last-child{border-bottom:none}.exp-text.svelte-md774e{color:var(--text);flex:1;font-size:14px}.exp-bonus-badge.svelte-md774e{color:var(--gold);text-align:right;flex-shrink:0;min-width:26px;font-size:13px;font-weight:700}.exp-edit-block.svelte-md774e{border-bottom:1px solid var(--border);flex-direction:column;gap:6px;padding:8px 4px;display:flex}.exp-edit-row1.svelte-md774e{align-items:center;gap:6px;display:flex}.exp-edit-row2.svelte-md774e{align-items:center;gap:8px;display:flex}.exp-bonus-ctrl.svelte-md774e{align-items:center;gap:6px;display:flex}.exp-bonus-label.svelte-md774e{color:var(--text-faint);text-transform:uppercase;letter-spacing:.06em;font-size:11px}.exp-bonus-val.svelte-md774e{color:var(--gold);text-align:center;min-width:28px;font-size:13px;font-weight:700}.gear-add-btn.active.svelte-md774e{color:var(--accent);border-color:var(--accent)}.delete-row.svelte-md774e{justify-content:center;margin-top:8px;padding-bottom:8px;display:flex}.delete-char-btn.svelte-md774e{border:1px solid var(--border2);color:var(--text-faint);cursor:pointer;background:0 0;border-radius:8px;padding:7px 18px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s}.delete-char-btn.svelte-md774e:hover{color:var(--red);border-color:var(--red)}.delete-char-btn.confirming.svelte-md774e{color:var(--red);border-color:var(--red);background:color-mix(in srgb, var(--red) 10%, transparent)}.ability-tracker.svelte-md774e{background:var(--surface2);border:1px solid var(--border2);border-radius:8px;flex-wrap:wrap;align-items:center;gap:8px;padding:6px 10px;display:flex}.ability-tracker-label.svelte-md774e{text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint);flex-shrink:0;font-size:11px;font-weight:700}.dp-roll-btn.svelte-md774e{background:color-mix(in srgb, var(--gold) 14%, var(--surface2));border:1px solid var(--gold-d);color:var(--gold-l);cursor:pointer;border-radius:8px;flex-shrink:0;padding:4px 12px;font-family:inherit;font-size:13px;font-weight:700;transition:all .12s}.dp-roll-btn.svelte-md774e:hover{background:color-mix(in srgb, var(--gold) 24%, var(--surface2));border-color:var(--gold)}.dp-roll-btn.svelte-md774e:active{transform:scale(.94)}.dp-roll-btn.dmg.svelte-md774e{background:color-mix(in srgb, var(--accent) 14%, var(--surface2));border-color:var(--accent-d);color:var(--accent-l)}.dp-roll-btn.dmg.svelte-md774e:hover{background:color-mix(in srgb, var(--accent) 24%, var(--surface2));border-color:var(--accent)}.dp-enter-btn.svelte-md774e{border:1px solid var(--border2);color:var(--text-faint);cursor:pointer;background:0 0;border-radius:8px;flex-shrink:0;padding:4px 9px;font-family:inherit;font-size:13px;transition:all .12s}.dp-enter-btn.svelte-md774e:hover{border-color:var(--border);color:var(--text);background:var(--surface)}.dp-enter-btn.dmg.svelte-md774e:hover{border-color:var(--accent);color:var(--accent-l)}.dp-input.svelte-md774e{border:2px solid var(--gold);background:color-mix(in srgb, var(--gold) 10%, var(--surface));width:44px;height:32px;color:var(--gold-l);text-align:center;font-variant-numeric:tabular-nums;-moz-appearance:textfield;border-radius:7px;outline:none;padding:0 4px;font-family:inherit;font-size:15px;font-weight:800}.dp-input.svelte-md774e::-webkit-outer-spin-button{-webkit-appearance:none}.dp-input.svelte-md774e::-webkit-inner-spin-button{-webkit-appearance:none}.dp-input.svelte-md774e:focus{border-color:var(--gold-l)}.dp-confirm-btn.svelte-md774e{background:var(--green-d,color-mix(in srgb, var(--green) 20%, transparent));border:1px solid var(--green);color:var(--green);cursor:pointer;border-radius:8px;flex-shrink:0;padding:4px 10px;font-family:inherit;font-size:12px;font-weight:700;transition:all .12s}.dp-confirm-btn.svelte-md774e:hover{background:var(--green);color:#fff}.dp-cancel-btn.svelte-md774e{border:1px solid var(--border2);color:var(--text-faint);cursor:pointer;background:0 0;border-radius:8px;flex-shrink:0;padding:4px 8px;font-family:inherit;font-size:13px;transition:all .12s}.dp-cancel-btn.svelte-md774e:hover{border-color:var(--red);color:var(--red)}.dp-chips.svelte-md774e{flex-wrap:wrap;gap:5px;display:flex}.dp-chip.svelte-md774e{border:2px solid var(--gold);background:color-mix(in srgb, var(--gold) 15%, var(--surface));min-width:32px;height:32px;color:var(--gold-l);cursor:pointer;font-variant-numeric:tabular-nums;border-radius:7px;justify-content:center;align-items:center;padding:0 8px;font-family:inherit;font-size:15px;font-weight:800;transition:all .12s;display:flex}.dp-chip.svelte-md774e:hover{background:color-mix(in srgb, var(--gold) 28%, var(--surface))}.dp-chip.spent.svelte-md774e{border-color:var(--border2);background:var(--surface2);color:var(--text-faint);opacity:.5;text-decoration:line-through}.card-dmg-result.svelte-md774e{color:var(--accent-l);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:22px;font-weight:800}.card-dmg-break.svelte-md774e{color:var(--text-faint);font-size:12px}.feature-card.card-used.svelte-md774e{opacity:.5}.pool-config-row.svelte-md774e{background:var(--surface2);border:1px solid var(--border2);border-radius:10px;flex-wrap:wrap;align-items:center;gap:10px;margin-top:4px;padding:10px 12px;display:flex}.pool-config-label.svelte-md774e{color:var(--text-faint);white-space:nowrap;font-size:12px;font-weight:600}.pool-count-ctrl.svelte-md774e{align-items:center;gap:6px;display:flex}.pool-die-strip.svelte-md774e{flex-wrap:wrap;gap:5px;display:flex}.pool-die-btn.svelte-md774e{border:1px solid var(--border2);color:var(--text-faint);cursor:pointer;background:0 0;border-radius:7px;padding:5px 10px;font-family:inherit;font-size:12px;font-weight:700;transition:all .1s}.pool-die-btn.active.svelte-md774e{border-color:var(--gold);color:var(--gold-l);background:color-mix(in srgb, var(--gold) 12%, transparent)}.pool-die-btn.svelte-md774e:hover{border-color:var(--border);color:var(--text)}.gaming-hub.svelte-yjnjmr{background:var(--bg);flex-direction:column;justify-content:flex-start;align-items:center;gap:32px;width:100%;height:100vh;padding-top:72px;display:flex}.gaming-hub-top.svelte-yjnjmr{justify-content:space-between;align-items:center;width:100%;max-width:420px;padding:0 20px;display:flex}.signout-btn.svelte-yjnjmr{color:var(--text-faint);cursor:pointer;opacity:.35;background:0 0;border:1px solid #0000;border-radius:6px;padding:4px 8px;font-family:inherit;font-size:11px;transition:opacity .2s,border-color .2s,color .2s}.signout-btn.svelte-yjnjmr:hover{opacity:1;color:var(--text-dim);border-color:var(--border)}.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}
