button:disabled{opacity:.35;cursor:not-allowed}:root{--bg: #1c1712;--surface: #2a2218;--surface-hover: #352c20;--primary: #1e1810;--accent: #d2691e;--accent-dim: #a8531a;--success: #5a9e3e;--warning: #d4a017;--error: #c0392b;--info: #5b8fb9;--text: #ede0d0;--text-secondary: #b8a898;--text-muted: #7a6e62;--border: #3d342a;--border-light: #4e4538;--accent-alpha-08: rgba(210, 105, 30, .08);--accent-alpha-10: rgba(210, 105, 30, .1);--accent-alpha-15: rgba(210, 105, 30, .15);--success-alpha-10: rgba(90, 158, 62, .1);--ds-orange: #d2691e;--ds-sand: #deb887;--ds-crimson: #8b0000;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 32px;--space-8: 48px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-full: 9999px;--transition-fast: .1s ease;--transition-normal: .2s ease;--transition-slow: .35s ease;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);--shadow-card: 0 2px 8px rgba(0, 0, 0, .35)}[data-theme=light]{--bg: #f5f0e8;--surface: #fffcf5;--surface-hover: #f0ebe0;--primary: #e8e0d0;--accent: #b85c1e;--accent-dim: #954a18;--text: #2a1f14;--text-secondary: #5c4a3a;--text-muted: #8a7a6a;--border: #d4c8b8;--border-light: #c0b4a4;--accent-alpha-08: rgba(184, 92, 30, .08);--accent-alpha-10: rgba(184, 92, 30, .1);--accent-alpha-15: rgba(184, 92, 30, .15);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--shadow-card: 0 2px 8px rgba(0, 0, 0, .08)}*{margin:0;padding:0;box-sizing:border-box}*:focus-visible{outline:2px solid var(--accent);outline-offset:2px}*:focus:not(:focus-visible){outline:none}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text)}.app-with-chat{display:flex;flex-direction:row;height:100vh;width:100vw;overflow:hidden}.app-with-chat>.app{flex:1;min-width:0;height:100vh}.app{display:flex;flex-direction:column;height:100vh}.app-header{background:linear-gradient(135deg,var(--primary) 0%,var(--bg) 100%);padding:var(--space-3) var(--space-6);border-bottom:2px solid var(--ds-orange);flex-shrink:0;display:flex;align-items:center;justify-content:space-between}.header-brand{display:flex;align-items:center;gap:var(--space-2)}.header-icon{color:var(--ds-orange)}.header-title{font-family:Cinzel,serif;font-size:20px;font-weight:700;letter-spacing:3px;color:var(--text)}.header-build-tag{font-size:9px;font-weight:500;color:var(--text-muted);opacity:.6;align-self:flex-end;margin-bottom:2px;cursor:default}.header-actions{display:flex;gap:var(--space-2)}.header-center{display:flex;align-items:center;flex:1;justify-content:center;min-width:0}.character-status-display{display:flex;align-items:center;gap:10px;padding:4px 16px}.character-status-name{font-size:16px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}.character-status-detail{font-size:12px;color:var(--text-secondary);white-space:nowrap}.header-btn{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:var(--accent-alpha-08);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:all var(--transition-normal)}.header-btn:hover{background:var(--accent-alpha-15);border-color:var(--accent);color:var(--text)}.header-btn-primary{background:#d2691e26;border-color:var(--ds-orange);color:var(--ds-sand)}.header-btn-primary:hover{background:#d2691e40;color:#fff}.theme-toggle-btn{padding:var(--space-2)!important;min-width:36px;justify-content:center;border-radius:var(--radius-full)!important;color:var(--ds-sand)!important;transition:transform .3s ease!important}.theme-toggle-btn:hover{background:#d2691e33!important;border-color:var(--ds-orange)!important;transform:rotate(15deg)}.theme-toggle-btn:active{transform:rotate(180deg)!important;transition:transform .4s ease!important}.subtitle{font-size:11px;color:var(--text-muted);margin-top:1px;letter-spacing:.5px}.house-rules-banner{background:var(--accent-alpha-08);border:1px solid var(--border);border-radius:8px;padding:12px 16px;margin-bottom:16px}.house-rules-switch{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;margin-bottom:6px}.house-rules-switch input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px;cursor:pointer}.house-rules-title{font-weight:600;color:var(--text)}.house-rules-description{color:var(--text-muted);font-size:12px;margin:4px 0 8px;line-height:1.4}.house-rules-effects{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:4px 16px;font-size:12px;color:var(--text-muted)}.house-rules-effects li{line-height:1.5}.house-rules-effects strong{color:var(--text)}.stats-bar-container{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.stats-bar{display:flex;justify-content:center;align-items:center;gap:2px;padding:4px 16px}.stats-bar-row-label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);min-width:52px;text-align:right;padding-right:6px}.stats-bar-suggestion{border-top:1px dashed var(--border);background:#e67e220f;padding:3px 16px}.stats-bar-suggestion .suggestion-label{color:var(--accent)}.suggestion-class-label{font-weight:600;color:var(--text)}.stats-bar-item{display:flex;align-items:center;gap:3px;padding:2px 8px;border-radius:var(--radius-sm);font-size:12px;transition:background .15s}.stats-bar-item:hover{background:var(--surface-hover)}.stats-bar-item.bonus{background:#27ae6014}.stats-bar-item.penalty{background:#e74c3c14}.stats-bar-item.suggestion-up{background:#27ae601a}.stats-bar-item.suggestion-down{background:#e74c3c1a}.stats-bar-label{font-weight:700;font-size:10px;color:var(--accent);letter-spacing:.5px}.stats-bar-value{font-weight:700;font-size:13px;color:var(--text);min-width:20px;text-align:center}.stats-bar-mod{font-size:10px;font-weight:600}.stats-bar-mod.positive{color:var(--success)}.stats-bar-mod.negative{color:var(--error)}.stats-bar-actions{display:flex;gap:4px;margin-left:8px}.stats-bar-swappable{cursor:pointer;-webkit-user-select:none;user-select:none;border:1px solid transparent;transition:background .15s,border-color .15s,box-shadow .15s}.stats-bar-swappable:hover{border-color:var(--accent);background:#e67e221a}.stats-bar-swappable.swap-selected{border-color:var(--accent);background:#e67e2233;box-shadow:0 0 4px #e67e2266}.stats-cycle-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--accent);cursor:pointer;transition:background .15s,border-color .15s}.stats-cycle-btn:hover{background:#e67e2226;border-color:var(--accent)}.character-summary-bar{background:var(--surface);border-bottom:1px solid var(--border)}.character-identity-bar{display:flex;justify-content:center;gap:8px;padding:2px 16px 4px;font-size:11px;color:var(--text-secondary)}.identity-race{font-weight:500}.identity-class{font-weight:600;color:var(--accent)}.identity-kit{font-weight:400;color:var(--text-muted);font-style:italic}.step-indicator{display:flex;align-items:center;justify-content:center;padding:16px 24px;background:var(--surface);border-bottom:1px solid var(--border);gap:0;flex-shrink:0}.step-connector{width:48px;height:2px;background:var(--border);margin:0 4px;transition:background .4s ease}.step-connector.completed{background:var(--accent)}.step-item{display:flex;align-items:center;gap:8px;padding:0;background:transparent;border:none;transition:transform .15s}.step-item:disabled{opacity:1;cursor:default}.step-item:not(:disabled):hover{transform:scale(1.03)}.step-item:not(:disabled):active{transform:scale(.97)}.step-label{padding:6px 14px;background:none;border:1px solid var(--border-light);border-radius:20px;color:var(--text-secondary);cursor:default;font-size:13px;transition:all .2s}.step-item:not(.current):not(.completed) .step-label{background:color-mix(in srgb,var(--surface-hover) 72%,transparent);border-color:var(--border-light);color:var(--text-secondary)}.step-item.current{border-color:var(--accent);color:var(--text);background:#e945601a}.step-item.completed{border-color:var(--accent-dim);color:var(--accent);cursor:pointer}.step-item.completed:hover{background:#e9456014}.step-number{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;font-size:12px;font-weight:700;background:var(--surface-hover);color:var(--ds-sand);border:1px solid var(--border-light);transition:background .3s ease,color .3s ease,transform .2s ease}.step-item.current .step-number{background:var(--accent);color:#fff;transform:scale(1.1)}.step-item.completed .step-number{background:var(--accent-dim);color:#fff}.step-label{font-weight:500}.wizard-main{display:flex;flex-direction:column;flex:1;overflow:hidden}.wizard-content{flex:1;overflow-y:auto;padding:var(--space-6) var(--space-7);animation:step-fade-in .3s ease both}.wizard-content:has(.spells-step),.wizard-content:has(.psionics-step){display:flex;flex-direction:column;overflow:hidden}@keyframes step-fade-in{0%{opacity:0}to{opacity:1}}.wizard-nav{display:flex;align-items:center;padding:12px 32px;background:var(--surface);border-top:1px solid var(--border);flex-shrink:0}.nav-spacer{flex:1}.nav-btn{padding:10px 24px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.nav-btn:hover{background:var(--surface-hover);border-color:var(--border-light)}.nav-btn:active{transform:scale(.97);transition:transform .05s}.nav-btn.next-btn{background:var(--accent);border-color:var(--accent);color:#fff}.nav-btn.next-btn:hover{background:var(--accent-dim)}.nav-btn.next-btn:active{transform:scale(.96);transition:transform .05s}.wizard-step h2{font-size:22px;font-weight:600;margin-bottom:6px}.step-description{font-size:14px;color:var(--text-secondary);margin-bottom:20px;line-height:1.5}.class-group{margin-bottom:20px}.class-group-header{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--accent);margin-bottom:10px;display:flex;align-items:center;gap:6px}.group-icon{font-size:16px}.class-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}.combo-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px}.combo-card{padding:var(--space-2) var(--space-3)}.combo-card .class-card-name{font-size:13px}.combo-card .class-card-desc{font-size:11px}.class-card{display:flex;flex-direction:column;padding:var(--space-3) var(--space-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;text-align:left;transition:all var(--transition-normal);color:var(--text)}.class-card:hover{background:var(--surface-hover);border-color:var(--border-light);transform:translateY(-2px);box-shadow:var(--shadow-md)}.class-card:active{transform:scale(.98)}.class-card.selected{border-color:var(--accent);background:var(--accent-alpha-10);box-shadow:var(--shadow-card)}.class-card-name{font-size:15px;font-weight:600;margin-bottom:4px}.class-card-desc{font-size:12px;color:var(--text-secondary);line-height:1.4}.elemental-sphere-inline{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.multiclass-sphere{margin-top:12px}.multiclass-sphere-label{margin:0 0 6px;font-size:13px;color:var(--text-secondary);width:100%}.elemental-pill{display:flex;align-items:center;gap:4px;padding:6px 12px;border:2px solid var(--border);border-radius:20px;background:var(--surface);color:var(--text-primary);cursor:pointer;transition:all .15s ease;font-size:13px}.elemental-pill:hover{border-color:var(--accent);background:var(--accent-alpha-10)}.elemental-pill.selected{border-color:var(--accent);background:var(--accent-alpha-10);box-shadow:0 0 0 1px var(--accent)}.elemental-pill.para{font-size:11px;padding:4px 8px;opacity:.7}.elemental-pill.para:hover,.elemental-pill.para.selected{opacity:1}.elemental-icon{font-size:16px}.elemental-pill.para .elemental-icon{font-size:13px}.elemental-label{font-weight:600;color:var(--text-primary)}.elemental-required-inline{font-size:12px;color:var(--error, #e74c3c);font-weight:600}.elemental-hint-inline{font-size:11px;color:var(--text-muted);font-style:italic}.druid-sphere-label{font-size:11px;color:var(--text-secondary);margin:4px 0 2px;font-weight:500}.play-header-element{color:var(--accent);margin-left:4px}.elemental-required{color:var(--error, #e74c3c);font-size:13px;font-weight:600;margin-top:8px}.class-card.ineligible{opacity:.5;border-style:dashed}.class-card.ineligible:hover{opacity:.7}.class-card-unmet{font-size:10px;color:var(--error);margin-top:4px;font-weight:500}.kit-step{max-width:800px;margin:0 auto}.kit-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.kit-card{display:flex;flex-direction:column;padding:var(--space-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;text-align:left;transition:all var(--transition-normal);color:var(--text)}.kit-card:hover{background:var(--surface-hover);border-color:var(--border-light);transform:translateY(-2px);box-shadow:var(--shadow-md)}.kit-card:active{transform:scale(.98)}.kit-card.selected{border-color:var(--accent);background:var(--accent-alpha-10);box-shadow:var(--shadow-card)}.kit-card.ineligible{opacity:.5;border-style:dashed}.kit-card-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.kit-card-name{font-size:15px;font-weight:600}.kit-card-source{font-size:10px;color:var(--text-muted);margin-left:auto}.kit-card-desc{font-size:12px;color:var(--text-secondary);line-height:1.4;margin-bottom:8px}.kit-abilities,.kit-hindrances{font-size:11px;margin-top:4px}.kit-abilities{color:var(--success)}.kit-hindrances{color:var(--warning)}.kit-section-label{font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:4px}.kit-abilities ul,.kit-hindrances ul{margin:2px 0 0 16px;padding:0}.kit-abilities li,.kit-hindrances li{margin-bottom:1px}.kit-more{color:var(--text-muted);font-style:italic}.kit-card-unmet{font-size:10px;color:var(--error);margin-top:6px;font-weight:500}.kit-card-swap-hint{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--accent);margin-top:6px;font-weight:500}.kit-choices-section{margin-top:20px;padding:16px;background:var(--surface);border:1px solid var(--accent);border-radius:var(--radius-lg)}.kit-choices-section h3{margin:0 0 12px;font-size:14px;color:var(--accent)}.kit-choice-group{margin-bottom:12px}.kit-choice-label{display:block;font-size:12px;font-weight:600;margin-bottom:6px;color:var(--text-primary)}.kit-choice-options{display:flex;gap:8px;flex-wrap:wrap}.kit-choice-btn{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:6px 14px;font-size:12px;color:var(--text-primary);cursor:pointer;transition:all .15s}.kit-choice-btn:hover{border-color:var(--accent);background:#ff98001a}.kit-choice-btn.selected{border-color:var(--accent);background:#ff980033;color:var(--accent);font-weight:600}.kit-choice-required{display:block;font-size:10px;color:var(--warning);margin-top:4px}.kit-abilities-section{margin-bottom:16px}.kit-abilities-section h3{font-size:14px;margin-bottom:8px}.kit-abilities-list{display:flex;flex-direction:column;gap:6px}.kit-ability-row{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md)}.kit-ability-name{font-size:13px;font-weight:500}.kit-ability-uses{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary)}.kit-ability-use-btn{background:var(--accent);border:none;border-radius:var(--radius-sm);color:#fff;padding:2px 8px;font-size:11px;cursor:pointer;font-weight:600}.kit-ability-use-btn:hover{opacity:.85}.kit-ability-passive{font-size:11px;color:#4caf50;font-style:italic}.kit-none-available{color:var(--text-muted);font-style:italic;text-align:center;padding:20px}.kit-loading{text-align:center;color:var(--text-muted);padding:40px}.stats-step{max-width:680px;margin:0 auto}.stats-swappable-toggle{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.swappable-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.swappable-btn:hover{border-color:var(--accent);color:var(--accent)}.swappable-btn.active{background:var(--accent-alpha-10);border-color:var(--accent);color:var(--accent)}.swappable-hint{font-size:12px;color:var(--text-muted);line-height:1.3}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}@media(max-width:600px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{display:flex;flex-direction:column;align-items:center;padding:14px 10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all .2s;text-align:center}.stat-card:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-alpha-10)}.stat-card.out-of-range{border-color:var(--warning)}.stat-card-header{display:flex;align-items:baseline;gap:6px;margin-bottom:8px}.stat-abbr{font-size:18px;font-weight:700;color:var(--accent);letter-spacing:1px}.stat-name{font-size:12px;color:var(--text-secondary);font-weight:500}.stat-input{width:72px;padding:8px 4px;text-align:center;font-size:24px;font-weight:700;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);outline:none;transition:border-color .15s;-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.stat-input::-webkit-outer-spin-button,.stat-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.stat-input:focus{border-color:var(--accent)}.stat-desc{font-size:10px;color:var(--text-muted);margin-top:6px;line-height:1.3}.stats-options-row{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.stats-actions{display:flex;gap:10px;margin-bottom:8px;align-items:stretch}.roll-group{display:flex;gap:0}.roll-method-select{padding:8px 10px;background:var(--surface);border:1px solid var(--border);border-right:none;border-radius:var(--radius-md) 0 0 var(--radius-md);color:var(--text);font-size:13px;cursor:pointer;min-width:160px}.roll-method-select:focus{border-color:var(--accent);outline:none}.roll-group .roll-btn{border-radius:0 var(--radius-md) var(--radius-md) 0}.roll-method-desc{font-size:11px;color:var(--text-muted);margin:0 0 16px;font-style:italic}.stats-action-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.stats-action-btn:hover{background:var(--surface-hover);border-color:var(--border-light)}.stats-action-btn:active{transform:scale(.97)}.stats-action-btn.roll-btn:hover{border-color:var(--accent);color:var(--accent)}.stats-availability{text-align:center;font-size:13px;color:var(--text-secondary);padding:10px;background:var(--surface);border-radius:var(--radius-md);border:1px solid var(--border)}.availability-count{font-weight:700;font-size:15px;color:var(--success)}.availability-count.none{color:var(--error)}.availability-count.all{color:var(--success)}.physical-chars-section{margin-bottom:16px}.physical-chars-toggle{display:flex;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:600;color:var(--text-secondary);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);cursor:pointer;transition:all .15s;width:100%;text-align:left}.physical-chars-toggle:hover{border-color:var(--accent);color:var(--accent)}.physical-chars-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:10px;padding:12px;background:var(--surface);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius-sm, 4px) var(--radius-sm, 4px)}@media(max-width:768px){.physical-chars-grid{grid-template-columns:repeat(2,1fr)}}.race-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}.race-card{display:flex;flex-direction:column;padding:var(--space-3) var(--space-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;text-align:left;transition:all var(--transition-normal);color:var(--text)}.race-card:hover{background:var(--surface-hover);border-color:var(--border-light);transform:translateY(-2px);box-shadow:var(--shadow-md)}.race-card:active{transform:scale(.98)}.race-card.selected{border-color:var(--accent);background:#e945601a;box-shadow:var(--card-shadow)}.race-card.disabled{opacity:.4;cursor:not-allowed}.race-card.disabled:hover{background:var(--surface);border-color:var(--border)}.race-card-name{font-size:15px;font-weight:600;margin-bottom:4px}.race-card-desc{font-size:12px;color:var(--text-secondary);line-height:1.4}.unavailable-races{margin-top:16px}.unavailable-races summary{font-size:13px;color:var(--text-muted);cursor:pointer;padding:6px 0}.unavailable-races summary:hover{color:var(--text-secondary)}.disabled-group{margin-top:10px}.options-grid{display:flex;flex-direction:column;gap:24px}.options-section h3{font-size:15px;font-weight:600;color:var(--accent);margin-bottom:10px}.section-hint{font-size:12px;color:var(--text-muted);margin-bottom:10px}.option-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px}.option-card{display:flex;flex-direction:column;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:6px;cursor:pointer;text-align:left;transition:all .15s;color:var(--text)}.option-card:hover{background:var(--surface-hover);border-color:var(--border-light)}.option-card.selected{border-color:var(--accent);background:#e945601a}.option-card-name{font-size:14px;font-weight:600;margin-bottom:2px}.option-card-desc{font-size:11px;color:var(--text-secondary)}.toggle-list{display:flex;flex-direction:column;gap:8px}.toggle-item{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .15s}.toggle-item:hover{background:var(--surface-hover)}.toggle-item input[type=checkbox]{margin-top:3px;accent-color:var(--accent);width:16px;height:16px;cursor:pointer}.toggle-label{display:flex;flex-direction:column;gap:2px}.toggle-label strong{font-size:14px;font-weight:600}.toggle-label span:last-child{font-size:12px;color:var(--text-secondary)}.summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.summary-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:16px}.summary-card h3{font-size:14px;font-weight:600;color:var(--accent);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.summary-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border)}.summary-row:last-child{border-bottom:none}.summary-label{font-size:13px;color:var(--text-secondary)}.summary-value{font-size:14px;font-weight:500;display:flex;align-items:center;gap:8px}.summary-badge{font-size:10px;padding:2px 8px;background:var(--primary);border-radius:10px;text-transform:uppercase;letter-spacing:.3px;color:var(--text-secondary)}.summary-desc{font-size:12px;color:var(--text-secondary);margin-top:10px;line-height:1.4;border-top:1px solid var(--border);padding-top:10px}.overrides{color:var(--accent);font-size:12px}.pages-card{grid-column:1 / -1}.page-list{list-style:none;display:flex;flex-direction:column;gap:4px}.page-item{display:flex;align-items:center;gap:10px;padding:6px 10px;border-radius:4px;font-size:13px}.page-item.included{background:#27ae6014}.page-item.excluded{opacity:.4}.page-number{font-weight:700;min-width:56px;color:var(--accent)}.page-title{flex:1}.page-excluded-badge{font-size:11px;padding:2px 8px;background:#e9456026;color:var(--accent);border-radius:10px}.summary-actions{text-align:center}.export-step{max-width:960px}.export-top-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.export-setting-group{margin-bottom:12px}.export-setting-label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:6px}.option-cards.compact{gap:6px}.option-cards.compact .option-card{padding:6px 12px}.toggle-list.compact{display:flex;flex-wrap:wrap;gap:8px}.toggle-list.compact .toggle-item{flex:0 0 auto}.export-optional-sections{margin-bottom:16px;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:8px}.export-optional-sections h3{font-size:13px;font-weight:600;color:var(--accent);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.export-actions-row{display:flex;align-items:flex-start;gap:20px;margin-bottom:20px}.export-actions-row .summary-actions{flex:1}.export-page-list{flex:0 0 auto;min-width:200px}.export-page-list h4{font-size:13px;font-weight:600;color:var(--accent);margin-bottom:6px}.page-list.compact .page-item{padding:2px 6px;font-size:12px}.export-preview-shell{min-height:500px;border:1px solid var(--border);border-radius:12px;background:var(--panel);overflow:hidden}@media(max-width:700px){.export-top-grid{grid-template-columns:1fr}.export-actions-row{flex-direction:column}}.export-btn{padding:14px 48px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.export-btn:hover{background:var(--accent-dim);transform:translateY(-1px);box-shadow:0 4px 16px #e945604d}.export-btn:active{transform:scale(.97);box-shadow:none;transition:transform .05s}.export-btn:not(:disabled){animation:cta-glow 2.5s ease-in-out infinite}@keyframes cta-glow{0%,to{box-shadow:0 0 #e9456000}50%{box-shadow:0 0 20px #e9456033}}.export-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.status{font-size:13px;color:var(--text-secondary);margin-top:12px}.export-success{margin-top:16px;padding:16px;background:#27ae601a;border:1px solid var(--success);border-radius:8px;text-align:center}.export-success-msg{font-size:14px;font-weight:600;color:var(--success);margin-bottom:12px}.export-action-buttons{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.action-btn{padding:8px 18px;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.action-btn:active{transform:scale(.96);transition:transform .05s}.action-btn:hover{background:var(--surface-hover);border-color:var(--border-light)}.action-btn-secondary{border-color:var(--accent);color:var(--accent)}.action-btn-secondary:hover{background:#e945601a}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:4px}.form-group select{width:100%;padding:8px 10px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:4px;font-size:14px}.form-group select:focus{border-color:var(--accent);outline:none}.description{font-size:12px;color:var(--text-secondary);margin-top:4px;line-height:1.4}.style-editor{margin-top:12px}.style-editor-toggle{display:flex;align-items:center;gap:8px;width:100%;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;text-align:left;transition:all .15s}.style-editor-toggle:hover{color:var(--text);border-color:var(--border-light)}.style-editor-toggle.open{color:var(--accent);border-color:var(--accent);border-bottom-left-radius:0;border-bottom-right-radius:0}.toggle-arrow{font-size:10px}.style-editor-content{background:var(--bg);border:1px solid var(--accent);border-top:none;border-bottom-left-radius:6px;border-bottom-right-radius:6px;padding:16px}.style-section{margin-bottom:16px}.style-section:last-of-type{margin-bottom:12px}.style-section h4{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--accent);margin-bottom:8px}.color-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.color-field{display:flex;align-items:center;gap:8px;cursor:pointer}.color-field input[type=color]{width:28px;height:28px;border:1px solid var(--border);border-radius:4px;padding:1px;background:none;cursor:pointer}.color-field input[type=color]::-webkit-color-swatch-wrapper{padding:0}.color-field input[type=color]::-webkit-color-swatch{border:none;border-radius:3px}.color-label{font-size:12px;color:var(--text-secondary)}.slider-list{display:flex;flex-direction:column;gap:6px}.slider-field{display:grid;grid-template-columns:100px 1fr 42px;align-items:center;gap:10px}.slider-label{font-size:12px;color:var(--text-secondary)}.slider-field input[type=range]{width:100%;height:4px;accent-color:var(--accent);cursor:pointer}.slider-value{font-size:11px;color:var(--text-muted);text-align:right;font-variant-numeric:tabular-nums}.reset-style-btn{width:100%;padding:8px;background:var(--surface);border:1px solid var(--border);border-radius:4px;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all .15s}.reset-style-btn:hover{background:var(--surface-hover);color:var(--text);border-color:var(--border-light)}.pdf-preview{display:flex;flex-direction:column;height:100%}.pdf-preview.disabled{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:14px}.preview-toolbar{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.preview-pages,.preview-zoom,.preview-fit{display:flex;align-items:center;gap:4px}.preview-toolbar button{padding:4px 8px;background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:14px;cursor:pointer;min-width:28px;text-align:center;transition:all .1s}.preview-toolbar button:hover:not(:disabled){background:var(--surface-hover);border-color:var(--border-light)}.preview-toolbar button:disabled{opacity:.3;cursor:not-allowed}.preview-toolbar button.active{background:var(--accent);border-color:var(--accent);color:#fff}.page-info{font-size:12px;color:var(--text-secondary);min-width:48px;text-align:center;font-variant-numeric:tabular-nums}.zoom-label{font-size:11px;font-variant-numeric:tabular-nums;min-width:44px}.preview-canvas-container{flex:1;overflow:auto;display:flex;justify-content:center;align-items:flex-start;padding:16px;position:relative}.preview-canvas{box-shadow:0 2px 12px #00000080;border-radius:2px;transition:opacity .2s}.preview-canvas.loading{opacity:.3}.preview-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:10px;z-index:10;color:var(--text-secondary);font-size:13px}.spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.preview-error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--accent);font-size:13px;text-align:center;padding:20px}.confirm-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000}.confirm-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:400px;box-shadow:var(--shadow-lg);overflow:hidden}.confirm-header{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-4) var(--space-2)}.confirm-title{flex:1;font-size:15px;font-weight:600}.confirm-icon-warning{color:var(--warning)}.confirm-icon-danger{color:var(--error)}.confirm-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:var(--space-1);border-radius:var(--radius-sm)}.confirm-close:hover{color:var(--text);background:var(--surface-hover)}.confirm-message{padding:var(--space-2) var(--space-4) var(--space-4);font-size:13px;color:var(--text-secondary);line-height:1.5}.confirm-actions{display:flex;justify-content:flex-end;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-top:1px solid var(--border);background:#0000001a}.confirm-btn{padding:var(--space-2) var(--space-4);border:1px solid var(--border);border-radius:var(--radius-md);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.confirm-btn-cancel{background:transparent;color:var(--text-secondary)}.confirm-btn-cancel:hover{background:var(--surface-hover);color:var(--text)}.confirm-btn-ok{background:var(--accent);border-color:var(--accent);color:#fff}.confirm-btn-ok:hover{filter:brightness(1.1)}.confirm-btn-warning{background:var(--warning);border-color:var(--warning)}.confirm-btn-danger{background:var(--error);border-color:var(--error)}.editor-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:16px;color:var(--text-muted);font-size:14px;background:var(--bg)}.editor-loading-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:editor-spin .8s linear infinite}@keyframes editor-spin{to{transform:rotate(360deg)}}.character-dropdown{display:flex;align-items:center;gap:4px;position:relative}.character-dropdown__trigger{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:var(--accent-alpha-08);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);font-size:13px;cursor:pointer;transition:all var(--transition-normal);max-width:320px;white-space:nowrap}.character-dropdown__trigger:hover{background:var(--accent-alpha-15);border-color:var(--accent)}.character-dropdown__dirty{width:6px;height:6px;border-radius:50%;background:var(--ds-orange);flex-shrink:0}.character-dropdown__name{font-weight:600;overflow:hidden;text-overflow:ellipsis}.character-dropdown__summary{color:var(--text-secondary);font-size:12px;overflow:hidden;text-overflow:ellipsis}.character-dropdown__action-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-normal)}.character-dropdown__action-btn:hover{background:var(--accent-alpha-08);border-color:var(--border);color:var(--text)}.character-dropdown__rename{display:flex;align-items:center;gap:4px}.character-dropdown__rename-input{width:180px;padding:3px 8px;font-size:13px;background:var(--surface);border:1px solid var(--ds-orange);border-radius:var(--radius-sm);color:var(--text);outline:none}.character-dropdown__rename-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer}.character-dropdown__rename-btn:hover{color:var(--text);background:var(--accent-alpha-08)}.character-dropdown__list{position:absolute;top:calc(100% + 4px);left:0;min-width:280px;max-height:320px;overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 8px 24px #0006;z-index:200;padding:4px}.character-dropdown__item{display:block;width:100%;text-align:left;padding:8px 12px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text);cursor:pointer;transition:background var(--transition-fast)}.character-dropdown__item:hover{background:var(--accent-alpha-08)}.character-dropdown__item.active{background:#d2691e1f;border-left:2px solid var(--ds-orange)}.character-dropdown__item-name{font-size:13px;font-weight:500}.character-dropdown__item-detail{font-size:11px;color:var(--text-secondary);display:flex;justify-content:space-between;margin-top:2px}.character-dropdown__item-date{color:var(--text-muted, var(--text-secondary));opacity:.7}.rotate-180{transform:rotate(180deg);transition:transform var(--transition-fast)}.portfolio-modal__overlay{position:fixed;inset:0;background:var(--bg);display:flex;align-items:flex-start;justify-content:center;z-index:1000;padding-top:60px}.portfolio-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg, 8px);width:800px;max-width:95vw;max-height:calc(100vh - 120px);display:flex;flex-direction:column;box-shadow:0 16px 48px #00000080}.portfolio-modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.portfolio-modal__header h2{font-size:20px;font-weight:700;color:var(--text);margin:0}.portfolio-modal__count{font-size:12px;font-weight:400;color:var(--text-secondary);margin-left:8px}.portfolio-modal__close{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;min-height:44px}.portfolio-modal__close:hover{background:var(--accent-alpha-08);color:var(--text)}.portfolio-modal__actions-bar{display:flex;gap:12px;padding:16px 24px;border-bottom:1px solid var(--border)}.portfolio-modal__action-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;background:var(--accent-alpha-08);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);color:var(--text-secondary);cursor:pointer;transition:all .15s;min-height:44px}.portfolio-modal__action-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-alpha-15)}.portfolio-modal__empty{padding:60px 24px;text-align:center;color:var(--text-secondary);font-size:16px}.portfolio-modal__table-wrap{overflow-y:auto;flex:1;padding:0}.portfolio-modal__table{width:100%;border-collapse:collapse;font-size:14px}.portfolio-modal__table thead th{position:sticky;top:0;background:var(--surface);padding:12px 16px;text-align:left;font-weight:600;color:var(--text-secondary);font-size:12px;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border);-webkit-user-select:none;user-select:none}.portfolio-modal__table thead th.sortable{cursor:pointer}.portfolio-modal__table thead th.sortable:hover{color:var(--text)}.portfolio-modal__table tbody td{padding:14px 16px;color:var(--text);border-bottom:1px solid var(--border-subtle, rgba(255, 255, 255, .05))}.portfolio-modal__table tbody tr:hover{background:var(--accent-alpha-08)}.portfolio-modal__table tbody tr.active-row{background:#d2691e14}.portfolio-modal__name-btn{background:none;border:none;color:var(--text);font-size:14px;font-weight:600;cursor:pointer;padding:4px 0;display:inline-flex;align-items:center;gap:6px}.portfolio-modal__name-btn:hover{color:var(--ds-orange)}.portfolio-modal__active-badge{font-size:10px;font-weight:400;color:var(--ds-orange);background:#d2691e26;padding:1px 6px;border-radius:8px}.portfolio-modal__rename-row{display:flex;align-items:center;gap:4px}.portfolio-modal__rename-input{width:160px;padding:2px 6px;font-size:13px;background:var(--bg);border:1px solid var(--ds-orange);border-radius:var(--radius-sm);color:var(--text);outline:none}.portfolio-modal__actions{display:flex;gap:6px}.portfolio-modal__actions button{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.portfolio-modal__actions button:hover{background:var(--accent-alpha-08);border-color:var(--border);color:var(--text)}.portfolio-modal__actions button.danger:hover{background:#dc262626;border-color:#dc262666;color:#ef4444}.portfolio-modal__confirm{padding:12px 20px;border-top:1px solid var(--border);background:#dc26260f;display:flex;align-items:center;justify-content:space-between}.portfolio-modal__confirm p{font-size:13px;color:var(--text);margin:0}.portfolio-modal__confirm-actions{display:flex;gap:8px}.portfolio-modal__confirm-actions button{padding:4px 12px;font-size:12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer}.portfolio-modal__confirm-actions .btn-danger{background:#dc2626cc;border-color:#dc262699;color:#fff}.portfolio-modal__confirm-actions .btn-danger:hover{background:#dc2626}.caster-tabs{display:flex;gap:4px;margin-bottom:12px;border-bottom:2px solid var(--border);padding-bottom:0;flex-shrink:0}.caster-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.caster-tab:hover{color:var(--text);background:var(--surface)}.caster-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.spells-step{display:flex;flex-direction:column;height:100%;min-height:0;overflow:hidden}.spells-step h2{display:flex;align-items:center;gap:8px;font-size:18px;color:var(--text);margin:0 0 4px;flex-shrink:0}.spells-step .step-description{color:var(--text-secondary);font-size:13px;margin:0 0 12px;flex-shrink:0}.spell-slot-bar{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);margin-bottom:12px;font-size:13px;flex-wrap:wrap;flex-shrink:0;z-index:10;box-shadow:0 2px 8px #0000004d}.spell-slot-bar .slot-label{color:var(--text-secondary);font-weight:600}.spell-slot-bar .slot-counts{color:var(--accent);font-family:monospace;display:flex;align-items:center;flex-wrap:wrap}.spell-slot-bar .slot-chip{cursor:help}.spell-slot-bar .slot-separator{color:var(--text-muted)}.slot-total-bonus{color:var(--info, #5b8fb9);font-weight:700}.spell-slot-bar .int-bonus{color:var(--text-muted);font-size:11px;margin-left:auto}.spells-split-view{display:grid;grid-template-columns:1fr 1fr;gap:12px;flex:1;min-height:0}.spells-browser-panel,.spells-book-panel{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--radius-sm, 4px);background:var(--primary);overflow:hidden}.spells-panel-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--surface);border-bottom:1px solid var(--border)}.spells-panel-header h3{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--text);margin:0}.spells-panel-header .spell-count{font-size:11px;color:var(--text-muted)}.spells-filters{padding:8px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:6px}.spell-search-box{display:flex;align-items:center;gap:6px;padding:4px 8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);color:var(--text-muted)}.spell-search-input{flex:1;background:transparent;border:none;color:var(--text);font-size:13px;outline:none}.spell-search-input::placeholder{color:var(--text-muted)}.spell-search-clear{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;display:flex}.spell-search-clear:hover{color:var(--text)}.spell-filter-row{display:flex;gap:6px}.spell-filter-select{flex:1;padding:3px 6px;font-size:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);color:var(--text)}.book-level-filter{flex:none;font-size:11px;padding:2px 6px}.spell-sort-btn{padding:3px 8px;font-size:11px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);color:var(--text-secondary);cursor:pointer;white-space:nowrap}.spell-sort-btn.active{background:var(--accent-alpha-15);border-color:var(--accent);color:var(--accent)}.spells-browser-list,.spells-book-list{flex:1;overflow-y:auto;padding:4px}.spell-empty{padding:24px 16px;text-align:center;color:var(--text-muted);font-size:13px;font-style:italic}.spell-browser-item{padding:6px 8px;border-radius:var(--radius-sm, 4px);cursor:pointer;transition:background .1s}.spell-browser-item:hover{background:var(--surface-hover)}.spell-item-header{display:flex;align-items:center;gap:8px;font-size:12px}.spell-item-header .spell-name{flex:1;color:var(--text);font-weight:500}.spell-item-header .spell-level{color:var(--accent);font-weight:600;font-size:11px;min-width:36px}.spell-item-header .spell-school{color:var(--text-muted);font-size:11px;min-width:80px}.spell-item-header .spell-components{color:var(--text-secondary);font-size:10px;font-family:monospace;min-width:36px}.spell-action-btn{display:flex;align-items:center;gap:3px;padding:2px 8px;font-size:11px;border-radius:var(--radius-sm, 4px);border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:all .15s}.spell-action-btn:hover{background:var(--surface-hover);color:var(--text)}.spell-action-btn.add-btn,.spell-action-btn.restore-btn{background:#5a9e3e1a;border-color:#5a9e3e66;color:var(--success)}.spell-action-btn.add-btn:hover,.spell-action-btn.restore-btn:hover{background:#5a9e3e40;border-color:var(--success)}.spell-action-btn:disabled{opacity:.35;cursor:not-allowed;background:var(--surface);border-color:var(--border);color:var(--text-muted)}.spell-action-btn:disabled:hover{background:var(--surface);border-color:var(--border);color:var(--text-muted)}.spell-action-btn.remove-btn{padding:2px 4px;color:var(--text-muted)}.spell-action-btn.remove-btn:hover{background:#dc262626;border-color:var(--error);color:var(--error)}.spell-action-btn.memorize-btn{background:#5a9e3e14;border-color:#5a9e3e4d;color:var(--success)}.spell-action-btn.memorize-btn:hover:not(:disabled){background:var(--success-alpha-10);border-color:var(--success)}.spell-action-btn.memorize-btn:disabled{opacity:.4;cursor:not-allowed}.spell-action-btn.memorize-more-btn:hover{background:var(--success-alpha-10);border-color:var(--success);color:var(--success)}.spell-action-btn.memorize-more-btn:disabled,.spell-action-btn.memorize-less-btn:disabled{opacity:.3;cursor:not-allowed}.spell-action-btn.memorize-less-btn:hover:not(:disabled){background:#dc262626;border-color:var(--error);color:var(--error)}.spell-action-btn.memorize-more-btn,.spell-action-btn.memorize-less-btn{padding:2px 4px;min-width:24px;justify-content:center}.spell-mem-counter{display:inline-flex;align-items:center;justify-content:center;min-width:20px;font-size:12px;font-weight:600;color:var(--text);text-align:center}.spell-mem-count{font-size:11px;font-weight:600;color:var(--success);margin-left:2px}.play-spell-cast-controls{display:flex;align-items:center;gap:6px;flex-shrink:0}.play-spell-count{font-size:11px;font-weight:600;color:var(--accent);margin-left:4px}.cast-remaining{font-size:10px;margin-left:4px;opacity:.8}.spell-item-details{padding:6px 8px 4px;font-size:11px;color:var(--text-secondary);display:grid;grid-template-columns:1fr 1fr;gap:2px 12px}.spell-detail-row span:first-child{color:var(--text-muted);font-weight:500}.spell-book-item{display:flex;align-items:center;justify-content:space-between;padding:5px 8px;border-radius:var(--radius-sm, 4px);transition:background .1s}.spell-book-item:hover{background:var(--surface-hover)}.spell-book-item.memorized{background:var(--success-alpha-10)}.spell-book-info{display:flex;align-items:center;gap:8px;flex:1;font-size:12px;min-width:0}.spell-book-info .spell-name{color:var(--text);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.spell-book-info .spell-level{color:var(--accent);font-size:11px;font-weight:600;flex-shrink:0}.spell-book-info .spell-school{color:var(--text-muted);font-size:11px;flex-shrink:0}.spell-book-actions{display:flex;gap:4px;flex-shrink:0}.spell-book-item{flex-wrap:wrap}.spell-book-item .spell-book-info{cursor:pointer}.spell-book-item.expanded{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);margin:2px 0}.spell-inline-card{width:100%;padding:8px;border-top:1px solid var(--border);margin-top:4px;font-size:12px}.spell-inline-subheader{font-size:11px;color:var(--text-secondary);margin-bottom:6px}.spell-inline-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px 12px;margin-bottom:6px}.spell-inline-field{display:flex;flex-direction:column;gap:1px}.spell-inline-label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.spell-inline-material{padding:4px 0;font-size:11px;color:var(--text-secondary);display:flex;flex-direction:column;gap:2px}.spell-inline-reversible{font-size:11px;color:var(--accent);font-style:italic;padding:2px 0}.spell-inline-description{font-size:11px;line-height:1.5;color:var(--text-secondary);max-height:150px;overflow-y:auto;padding:6px 0;border-top:1px solid var(--border);margin-top:4px}.spell-inline-source{font-size:10px;color:var(--text-muted);font-style:italic;padding-top:4px}.power-inline-card{width:100%;padding:8px;border-top:1px solid var(--border);margin-top:4px;font-size:12px}.power-inline-subheader{font-size:11px;color:var(--text-secondary);margin-bottom:6px}.power-inline-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px 12px;margin-bottom:6px}.power-inline-field{display:flex;flex-direction:column;gap:1px}.power-inline-label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.power-inline-prereqs{padding:4px 0;font-size:11px;color:var(--text-secondary);display:flex;flex-direction:column;gap:2px}.power-inline-result{padding:3px 0;font-size:11px;display:flex;flex-direction:column;gap:2px}.power-inline-result.success{color:var(--success)}.power-inline-result.failure{color:var(--error)}.play-spell-card,.play-power-card{cursor:pointer;flex-wrap:wrap}.psionics-step{display:flex;flex-direction:column;height:100%;min-height:0;overflow:hidden}.psionics-step h2{display:flex;align-items:center;gap:8px;font-size:18px;color:var(--text);margin:0 0 4px;flex-shrink:0}.psionics-step .step-description{color:var(--text-secondary);font-size:13px;margin:0 0 12px;flex-shrink:0}.psionic-counters{display:flex;align-items:center;gap:16px;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);margin-bottom:8px;font-size:13px;flex-wrap:wrap;flex-shrink:0}.psionic-counters .counter{display:flex;align-items:center;gap:4px;color:var(--accent);font-family:monospace}.psionic-errors{margin-bottom:8px;flex-shrink:0}.psionic-error{display:flex;align-items:center;gap:6px;padding:4px 10px;font-size:12px;color:var(--error);background:#c0392b1a;border:1px solid rgba(192,57,43,.3);border-radius:var(--radius-sm, 4px);margin-bottom:4px}.psionic-warning{display:flex;align-items:center;gap:6px;padding:6px 12px;font-size:12px;color:var(--warning);background:#d4a0171a;border:1px solid rgba(212,160,23,.3);border-radius:var(--radius-sm, 4px);margin-bottom:10px;flex-shrink:0}.discipline-selector{margin-bottom:12px;flex-shrink:0}.discipline-primary{margin-bottom:8px}.discipline-primary label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text)}.discipline-select{padding:4px 8px;font-size:13px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);color:var(--text)}.discipline-list{display:flex;flex-wrap:wrap;gap:6px}.discipline-chip{display:flex;align-items:center;gap:6px;padding:4px 10px;border:1px solid var(--border);border-radius:16px;font-size:12px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.discipline-chip:hover{border-color:var(--accent);color:var(--text)}.discipline-chip.selected{background:var(--accent-alpha-15);border-color:var(--accent);color:var(--accent)}.discipline-chip.primary{border-color:var(--accent);background:var(--accent-alpha-15);font-weight:600}.discipline-chip .discipline-counts{font-size:10px;font-family:monospace;opacity:.7}.wild-talent-toggle{display:flex;align-items:center;gap:16px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);margin-bottom:12px;flex-shrink:0}.wild-talent-label{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text);cursor:pointer}.wild-talent-count-label{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary)}.wild-talent-count-input{width:48px;padding:2px 6px;font-size:13px;background:var(--primary);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);color:var(--text);text-align:center}.psionics-split-view{display:grid;grid-template-columns:1fr 1fr;gap:12px;flex:1;min-height:0}.psionics-browser-panel,.psionics-known-panel{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--radius-sm, 4px);background:var(--primary);overflow:hidden}.psionics-panel-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--surface);border-bottom:1px solid var(--border)}.psionics-panel-header h3{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--text);margin:0}.psionics-panel-header .power-count{font-size:11px;color:var(--text-muted)}.psionics-filters{padding:8px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:6px}.psionic-search-box{display:flex;align-items:center;gap:6px;padding:4px 8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);color:var(--text-muted)}.psionic-search-input{flex:1;background:transparent;border:none;color:var(--text);font-size:13px;outline:none}.psionic-search-input::placeholder{color:var(--text-muted)}.psionic-search-clear{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;display:flex}.psionic-filter-row{display:flex;gap:6px}.psionic-filter-select{flex:1;padding:3px 6px;font-size:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);color:var(--text)}.psionics-browser-list,.psionics-known-list{flex:1;overflow-y:auto;padding:4px}.power-empty{padding:24px 16px;text-align:center;color:var(--text-muted);font-size:13px;font-style:italic}.power-browser-item{padding:6px 8px;border-radius:var(--radius-sm, 4px);cursor:pointer;transition:background .1s}.power-browser-item:hover{background:var(--surface-hover)}.power-prereq-hint{font-size:10px;color:var(--accent);padding:2px 0 0 4px;font-style:italic}.power-item-header{display:flex;align-items:center;gap:8px;font-size:12px}.power-item-header .power-name{flex:1;color:var(--text);font-weight:500}.power-item-header .power-discipline{color:var(--text-muted);font-size:11px;min-width:90px}.power-type{font-size:10px;padding:1px 5px;border-radius:3px;min-width:54px;text-align:center}.power-type.science{background:#5b8fb933;color:var(--info)}.power-type.devotion{background:var(--success-alpha-10);color:var(--success)}.power-type.high-science{background:#d2691e33;color:var(--accent)}.power-type.attack-mode{background:#c0392b26;color:var(--error)}.power-item-header .power-score{color:var(--text-secondary);font-size:10px;font-family:monospace;min-width:52px}.power-action-btn{display:flex;align-items:center;gap:3px;padding:2px 8px;font-size:11px;border-radius:var(--radius-sm, 4px);border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:all .15s}.power-action-btn:hover{background:var(--surface-hover);color:var(--text)}.power-action-btn.add-btn{background:#5a9e3e1a;border-color:#5a9e3e66;color:var(--success)}.power-action-btn.add-btn:hover{background:#5a9e3e40;border-color:var(--success)}.power-action-btn:disabled{opacity:.35;cursor:not-allowed;background:var(--surface);border-color:var(--border);color:var(--text-muted)}.power-action-btn:disabled:hover{background:var(--surface);border-color:var(--border);color:var(--text-muted)}.power-action-btn.remove-btn{padding:2px 4px;color:var(--text-muted)}.power-action-btn.remove-btn:hover{background:#dc262626;border-color:var(--error);color:var(--error)}.power-item-details{padding:6px 8px 4px;font-size:11px;color:var(--text-secondary);display:grid;grid-template-columns:1fr 1fr;gap:2px 12px}.power-detail-row span:first-child{color:var(--text-muted);font-weight:500}.known-discipline-group{margin-bottom:8px}.known-discipline-header{font-size:12px;font-weight:600;color:var(--accent);padding:4px 8px;margin:0;border-bottom:1px solid var(--border-light)}.known-power-item{display:flex;align-items:center;justify-content:space-between;padding:4px 8px;border-radius:var(--radius-sm, 4px);transition:background .1s}.known-power-item:hover{background:var(--surface-hover)}.known-power-item.auto{opacity:.6}.known-power-info{display:flex;align-items:center;gap:8px;flex:1;font-size:12px;min-width:0}.known-power-info .power-name{color:var(--text);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auto-badge{font-size:9px;padding:1px 4px;border-radius:3px;background:var(--surface);border:1px solid var(--border);color:var(--text-muted)}.bonus-badge{font-size:9px;padding:1px 4px;border-radius:3px;background:#f1c40f26;border:1px solid rgba(241,196,15,.4);color:#f1c40f;margin-left:4px}.known-power-item.bonus{background:#f1c40f0f}.known-power-actions{display:flex;align-items:center;gap:4px}.bonus-btn{font-size:12px;color:var(--text-muted);opacity:.5}.bonus-btn.active{color:#f1c40f;opacity:1}.play-sheet{max-width:100%;width:100%}.play-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-shrink:0}.play-header h2{display:flex;align-items:center;gap:8px;font-size:18px;color:var(--text);margin:0}.play-hp-tracker{display:flex;align-items:center;gap:4px;padding:4px 10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);flex-shrink:0}.hp-icon{color:#dc2626}.psp-icon{color:#4ecdc4}.gem-icon{color:#4ecdc4;flex-shrink:0}.wp-icon{color:var(--accent)}.nwp-icon{color:#9b87f5}.prof-value{font-size:16px;font-weight:700;font-family:monospace;color:var(--text-primary);min-width:30px;text-align:center}.prof-value.overbudget{color:#ff6b6b}.play-prof-tracker{padding:4px 10px;min-height:34px;box-sizing:border-box}.gem-total{font-size:14px;font-weight:700;font-family:monospace;color:#4ecdc4;min-width:24px;text-align:center}.hp-divider{width:1px;height:20px;background:var(--border);margin:0 8px}.hp-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-right:4px}.hp-input{width:48px;padding:2px 4px;font-size:16px;font-weight:700;font-family:monospace;text-align:center;background:var(--bg);border:1px solid var(--border);border-radius:3px;color:var(--text);-moz-appearance:textfield}.hp-input::-webkit-inner-spin-button,.hp-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.hp-input:focus{outline:none;border-color:var(--accent)}.hp-sep{font-size:16px;font-weight:600;color:var(--text-muted)}.currency-input{width:60px;padding:4px 6px;font-size:14px;font-weight:600;font-family:monospace;text-align:right;background:var(--bg);border:1px solid var(--border);border-radius:3px;color:var(--text);-moz-appearance:textfield}.currency-input::-webkit-inner-spin-button,.currency-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.currency-input:focus{outline:none;border-color:var(--accent)}.play-empty{text-align:center;color:var(--text-muted);padding:40px 20px;font-size:14px}.play-empty p{margin:4px 0}.play-spells-section h3,.play-psionics-section h3{display:flex;align-items:center;gap:6px;font-size:15px;color:var(--text);margin:0 0 10px;padding-bottom:6px;border-bottom:1px solid var(--border)}.play-slot-overview{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap;position:sticky;top:0;z-index:10;background:var(--primary);padding:8px 0;box-shadow:0 2px 4px #00000026}.play-slot-chip{display:flex;flex-direction:column;align-items:center;padding:6px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);min-width:56px}.play-slot-chip.exhausted{opacity:.4;border-color:var(--error)}.play-slot-chip .slot-level{font-size:10px;color:var(--text-muted);text-transform:uppercase}.play-slot-chip .slot-remaining{font-size:16px;font-weight:700;font-family:monospace;color:var(--accent)}.play-slot-chip.exhausted .slot-remaining{color:var(--error)}.play-spell-level-group{margin-bottom:16px}.play-spell-level-group h4{font-size:13px;color:var(--text-secondary);margin:0 0 6px}.play-spell-level-group .level-remaining{font-size:11px;color:var(--text-muted);margin-left:6px;font-weight:400}.play-spell-cards{display:flex;flex-direction:column;gap:4px}.play-spell-card{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);transition:all .15s}.play-spell-card.cast{opacity:.45;background:var(--primary)}.play-spell-info{display:flex;flex-direction:column;gap:2px;min-width:0}.play-spell-name{font-size:13px;font-weight:500;color:var(--text)}.play-spell-card.cast .play-spell-name{text-decoration:line-through}.play-spell-meta{font-size:11px;color:var(--text-muted)}.cast-btn{display:flex;align-items:center;gap:4px;padding:4px 12px;font-size:12px;background:var(--accent-alpha-15);border:1px solid var(--accent);border-radius:var(--radius-sm, 4px);color:var(--accent);cursor:pointer;transition:all .15s}.cast-btn:hover{background:#d2691e4d}.cast-btn:disabled{opacity:.3;cursor:not-allowed}.cast-badge{display:flex;align-items:center;gap:4px;padding:4px 10px;font-size:11px;color:var(--text-muted);font-style:italic}.play-magic-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.play-magic-header h3{margin:0;display:flex;align-items:center;gap:6px;font-size:15px;color:var(--text)}.memorize-toggle-btn{display:flex;align-items:center;gap:5px;padding:5px 14px;font-size:12px;font-weight:600;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);color:var(--text-secondary);cursor:pointer;transition:all .15s}.memorize-toggle-btn:hover{border-color:var(--accent);color:var(--accent)}.memorize-toggle-btn.active{background:var(--accent-alpha-15, rgba(210, 105, 30, .15));border-color:var(--accent);color:var(--accent)}.play-memo-panel{margin-bottom:16px}.play-memo-toolbar{display:flex;gap:8px;margin-bottom:12px;align-items:center}.play-memo-toolbar .spell-search-box{flex:1}.play-memo-filter{padding:5px 8px;font-size:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);color:var(--text);cursor:pointer}.play-memo-controls{display:flex;align-items:center;gap:4px;flex-shrink:0}.memo-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;padding:0;font-size:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);color:var(--text-secondary);cursor:pointer;transition:all .15s}.memo-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.memo-btn:disabled{opacity:.25;cursor:not-allowed}.memo-count{min-width:20px;text-align:center;font-size:13px;font-weight:700;font-family:monospace;color:var(--accent)}.play-spell-card.memorized{border-left:3px solid var(--accent)}.play-magic-actions{display:flex;gap:6px}.play-spell-card.in-spellbook{border-left:3px solid var(--accent)}.play-spell-card.not-known{opacity:.7}.play-spell-card.not-known:hover{opacity:1}.scribe-btn{color:var(--accent)!important;border-color:var(--accent)!important}.sb-capacity{margin-bottom:8px}.play-psionics-section{margin-top:24px}.psi-gem-list{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.psi-gem-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:8px 12px;min-width:180px;flex:0 1 auto}.psi-gem-header{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-bottom:6px}.psi-gem-name{flex:1;padding:2px 6px;font-size:13px;font-weight:600;background:transparent;border:1px solid transparent;border-radius:3px;color:var(--text);font-family:inherit}.psi-gem-name:hover{border-color:var(--border)}.psi-gem-name:focus{border-color:var(--accent);background:var(--bg);outline:none}.psi-gem-psp{display:flex;align-items:center;gap:4px}.psi-gem-psp-label{font-size:10px;font-weight:600;color:#4ecdc4;text-transform:uppercase;letter-spacing:.5px}.psi-gem-psp .hp-input{width:40px;font-size:14px}.psi-gem-aggregate{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:6px;margin-bottom:16px}.psi-gem-pool{font-size:18px;font-weight:700;font-family:monospace;color:#4ecdc4}.play-power-list{display:flex;flex-direction:column;gap:4px}.play-power-card{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px)}.play-power-info{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.play-power-name{font-size:13px;font-weight:500;color:var(--text)}.play-power-discipline{font-size:11px;color:var(--text-muted)}.play-power-costs{display:flex;align-items:center;gap:12px;flex-shrink:0}.play-power-cost{font-size:11px;color:var(--accent);font-family:monospace}.play-power-score{font-size:10px;color:var(--text-secondary);font-family:monospace}.play-learn-panel{margin-bottom:16px}.psi-slot-budget{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap;position:sticky;top:0;z-index:10;background:var(--primary);padding:8px 0;box-shadow:0 2px 4px #00000026}.psi-budget-chip{display:flex;flex-direction:column;align-items:center;padding:6px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);min-width:72px}.psi-budget-chip.full{opacity:.5;border-color:var(--text-muted)}.psi-budget-label{font-size:10px;color:var(--text-muted);text-transform:uppercase}.psi-budget-value{font-size:16px;font-weight:700;font-family:monospace;color:var(--accent)}.psi-budget-chip.full .psi-budget-value{color:var(--text-muted)}.psi-discipline-picker{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}.psi-disc-label{font-size:12px;color:var(--text-secondary);font-weight:600}.psi-disc-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;font-size:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);color:var(--text-secondary);cursor:pointer;transition:all .15s}.psi-disc-btn:hover{border-color:var(--accent);color:var(--accent)}.psi-disc-btn.primary{border-color:var(--accent);color:var(--accent);font-weight:600}.psi-learn-section{margin-bottom:16px}.psi-learn-section h4{font-size:13px;color:var(--text-secondary);margin:12px 0 6px}.play-power-card.known{border-left:3px solid var(--accent)}.play-power-card.available{opacity:.85}.play-power-card.available:hover{opacity:1}.psi-prereq-hint{width:100%;font-size:11px;color:var(--text-muted);font-style:italic;padding-top:4px}.memorize-toggle-btn.has-slots{animation:gentle-pulse 2s ease-in-out infinite}@keyframes gentle-pulse{0%,to{box-shadow:none}50%{box-shadow:0 0 6px #d2691e66}}.play-sheet-tabbed{max-width:100%;display:flex;flex-direction:column;height:100%}.play-header-identity h2{display:flex;align-items:center;gap:8px;font-size:18px;color:var(--text);margin:0}.play-header-subtitle{font-size:13px;color:var(--text-secondary);margin-top:2px}.play-header-kit{color:var(--accent);font-style:italic}.play-header-traits{color:var(--text-secondary);font-size:.85em}.play-tab-bar{display:flex;gap:2px;border-bottom:2px solid var(--border);margin-bottom:0;padding:0;flex-shrink:0;flex-wrap:wrap}.play-tab{display:flex;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;color:var(--text-secondary);background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:all .15s;white-space:nowrap}.play-tab:hover{color:var(--text);background:var(--surface-hover)}.play-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.play-tab-label{font-size:13px}.play-tab-content{min-height:0;flex:1;overflow-y:auto;padding-top:16px}.play-tab-panel h3{display:flex;align-items:center;gap:8px;font-size:15px;color:var(--text);margin:0 0 12px}.play-placeholder{padding:24px;text-align:center;color:var(--text-muted);font-size:13px;background:var(--surface);border-radius:var(--radius-sm, 4px);border:1px dashed var(--border)}.play-placeholder p{margin:4px 0}.vital-stats-bar{display:flex;justify-content:center;gap:24px;margin-bottom:20px;padding:12px 0}.vital-stats-bar.vital-compact{gap:12px;flex-wrap:wrap;padding:8px 0 4px;margin-bottom:8px}.vital-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.vital-icon-wrapper{position:relative;display:flex;align-items:center;justify-content:center;width:56px;height:56px}.vital-compact .vital-icon-wrapper{width:40px;height:40px}.vital-icon-wrapper svg{position:absolute;color:var(--text-muted);opacity:.35}.vital-digit{position:relative;z-index:1;font-size:20px;font-weight:800;font-family:monospace;color:var(--text);text-shadow:0 1px 2px rgba(0,0,0,.5)}.vital-compact .vital-digit{font-size:16px}.vital-save-bonus{font-size:11px;font-weight:600;color:var(--accent)}.vital-divider{width:1px;height:36px;background:var(--border);align-self:center;margin:0 4px}.vital-save-legend{text-align:center;font-size:10px;color:var(--text-secondary);margin:-4px 0 12px}.vital-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary)}.vital-compact .vital-label{font-size:9px;letter-spacing:.5px}.vital-thac0 .vital-icon-wrapper svg{color:#e8a838;opacity:.45}.vital-thac0 .vital-digit{color:#e8a838}.vital-ac .vital-icon-wrapper svg{color:var(--accent);opacity:.45}.vital-ac .vital-digit{color:var(--accent)}.vital-mv .vital-icon-wrapper svg{color:#7ec8a0;opacity:.45}.vital-mv .vital-digit{color:#7ec8a0}.vital-mac .vital-icon-wrapper svg{color:#9b87f5;opacity:.45}.vital-mac .vital-digit{color:#9b87f5}.vital-save-ppdm .vital-icon-wrapper svg,.vital-save-rsw .vital-icon-wrapper svg,.vital-save-pp .vital-icon-wrapper svg,.vital-save-bw .vital-icon-wrapper svg,.vital-save-sp .vital-icon-wrapper svg{color:#6ba3a0;opacity:.35}.vital-save-ppdm .vital-digit,.vital-save-rsw .vital-digit,.vital-save-pp .vital-digit,.vital-save-bw .vital-digit,.vital-save-sp .vital-digit{color:#6ba3a0}.vital-save-adjusted .vital-digit{color:var(--accent)}.vital-mthac0 .vital-icon-wrapper svg{color:#e8a838;opacity:.45}.vital-mthac0 .vital-digit{color:#e8a838}.vital-psp .vital-icon-wrapper svg{color:#4ecdc4;opacity:.45}.vital-psp .vital-digit{color:#4ecdc4}.vital-gem .vital-icon-wrapper svg{color:#4ecdc4;opacity:.45}.vital-gem .vital-digit{color:#4ecdc4}.psionics-vitals{margin-bottom:16px}.play-ability-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-bottom:20px}.play-ability-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);overflow:hidden}.ability-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--accent-alpha-15);border-bottom:1px solid var(--border)}.ability-name{font-weight:600;font-size:13px;color:var(--text)}.ability-score{font-size:20px;font-weight:700;color:var(--accent);font-family:monospace}input.ability-score-edit{font-size:20px;font-weight:700;color:var(--accent);font-family:monospace;background:transparent;border:1px solid transparent;border-radius:4px;width:50px;text-align:right;padding:0 4px;transition:border-color .15s;-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}input.ability-score-edit:hover{border-color:var(--border)}input.ability-score-edit:focus{border-color:var(--accent);outline:none;background:var(--surface)}input.ability-score-edit::-webkit-inner-spin-button,input.ability-score-edit::-webkit-outer-spin-button{-webkit-appearance:none;appearance:none;margin:0}.ability-details{padding:6px 12px;display:grid;grid-template-columns:1fr 1fr;gap:2px 12px}.ability-stat{display:flex;justify-content:space-between;padding:2px 0;font-size:12px}.ability-stat span:first-child{color:var(--text-secondary)}.ability-stat span:last-child{font-weight:600;color:var(--text);font-family:monospace}.ability-stat.wide{grid-column:1 / -1}.ability-stat.wide span:last-child{font-size:10px;font-weight:400;font-family:inherit;max-width:160px;text-align:right}.play-saves-table{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);overflow:hidden}.save-row{display:flex;justify-content:space-between;align-items:center;padding:6px 12px;font-size:12px;border-bottom:1px solid var(--border)}.save-row:last-child{border-bottom:none}.save-row.save-header{background:var(--accent-alpha-15);font-weight:600;font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.save-row span:first-child{color:var(--text-secondary)}.save-value{font-weight:600;font-size:14px;color:var(--accent);font-family:monospace;min-width:30px;text-align:center}.play-xp-bar{display:flex;gap:12px;padding:4px 16px 6px;background:var(--bg-primary);border-bottom:1px solid var(--border);flex-wrap:wrap}.xp-bar-entry{display:flex;align-items:center;gap:6px;flex:1;min-width:0}.xp-bar-entry.xp-frozen{opacity:.6}.xp-bar-entry.xp-level-ready{filter:drop-shadow(0 0 4px rgba(76,175,80,.4))}.xp-bar-class{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:capitalize;white-space:nowrap}.xp-bar-lvl{font-size:10px;font-weight:700;color:var(--accent);margin-left:3px}.xp-bar-label{font-size:10px;font-weight:700;text-transform:uppercase;color:var(--accent);letter-spacing:.5px}.xp-bar-input{width:90px;background:transparent;border:1px solid transparent;border-radius:3px;color:var(--text-primary);font-size:13px;font-weight:600;font-family:monospace;padding:1px 4px;text-align:right;-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield;transition:border-color .15s}.xp-bar-input::-webkit-inner-spin-button,.xp-bar-input::-webkit-outer-spin-button{-webkit-appearance:none;appearance:none;margin:0}.xp-bar-input:hover{border-color:var(--border)}.xp-bar-input:focus{border-color:var(--accent);outline:none;background:var(--surface)}.xp-bar-value{font-size:13px;font-weight:600;font-family:monospace}.xp-bar-frozen{color:var(--text-secondary)}.xp-bar-sep{font-size:12px;color:var(--text-secondary)}.xp-bar-next{font-size:12px;font-family:monospace;color:var(--text-secondary);white-space:nowrap}.xp-bar-level-btn{font-size:12px;color:#4caf50;background:none;border:1px solid #4caf50;border-radius:4px;padding:0 4px;cursor:pointer;animation:xp-pulse 1.5s ease-in-out infinite;transition:background .15s}.xp-bar-level-btn:hover{background:#4caf5033}@keyframes xp-pulse{0%,to{opacity:1}50%{opacity:.4}}.play-saves-compact{display:flex;gap:8px;flex-wrap:wrap}.save-compact-item{display:flex;flex-direction:column;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);padding:6px 12px;min-width:60px;flex:1}.save-compact-label{font-size:10px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.save-compact-value{font-size:18px;font-weight:700;color:var(--accent);font-family:monospace}.save-compact-value.save-racial-bonus{color:var(--accent-2, #6db86d)}.save-bonus-indicator{font-size:11px;vertical-align:super;color:var(--accent-2, #6db86d);margin-left:1px}.save-poison-note{font-size:13px;color:var(--accent-2, #6db86d);font-weight:600}.save-racial-note{font-size:11px;color:var(--text-secondary, #999);margin-top:2px;margin-bottom:8px;font-style:italic}.play-identity-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.identity-info-item{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);padding:6px 12px;min-width:80px}.identity-info-label{font-size:10px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.identity-info-value{font-size:13px;font-weight:500;color:var(--text)}.identity-step{max-width:600px}.identity-step h2{margin-bottom:4px}.identity-step .step-description{color:var(--text-secondary);font-size:13px;margin-bottom:20px}.identity-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.identity-field{display:flex;flex-direction:column;gap:4px}.identity-field.wide{grid-column:span 2}.identity-field label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.identity-field input,.identity-field select{padding:8px 10px;font-size:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);color:var(--text);font-family:inherit}.identity-field input:focus,.identity-field select:focus{border-color:var(--accent);outline:none}.identity-origin-custom{margin-top:6px}.play-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:16px;padding:0 4px;font-size:10px;font-weight:600;border-radius:8px;background:var(--accent-alpha-15);color:var(--accent);font-family:monospace}.play-combat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-bottom:16px}.combat-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);padding:10px 12px;text-align:center}.combat-stat-card.primary{border-color:var(--accent);background:var(--accent-alpha-15)}.combat-stat-label{display:block;font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.combat-stat-value{display:block;font-size:22px;font-weight:700;color:var(--text);font-family:monospace}.combat-stat-card.primary .combat-stat-value{color:var(--accent)}.combat-stat-note{display:block;font-size:10px;color:var(--text-muted);margin-top:2px}.weight-bar-track{width:100%;height:4px;background:var(--border);border-radius:2px;margin-top:6px;overflow:hidden}.weight-bar-fill{height:100%;border-radius:2px;transition:width .3s ease,background-color .3s ease}.weight-bar-fill--low{background-color:#4caf50}.weight-bar-fill--mid{background-color:#ff9800}.weight-bar-fill--warn{background-color:#f44336}.weight-bar-fill--over{background-color:#b71c1c}[data-weight=mid]{color:#ff9800}[data-weight=warn]{color:#f44336}[data-weight=over]{color:#b71c1c}.level-up-confirm--danger{background:#b71c1c!important}.play-tab-panel h4{font-size:13px;font-weight:600;color:var(--text-secondary);margin:16px 0 8px}.combat-mods-row{display:flex;align-items:center;justify-content:center;gap:6px;padding:6px 12px;background:var(--surface);border:1px solid var(--border);border-radius:6px;margin-bottom:12px;flex-wrap:wrap}.combat-mod-item{display:flex;align-items:baseline;gap:4px}.combat-mod-label{font-size:11px;color:var(--text-muted);font-weight:500}.combat-mod-value{font-size:14px;font-weight:700;color:var(--text)}.combat-mod-sep{color:var(--border);font-size:14px}.play-thac0-table{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);overflow-x:auto;margin-bottom:16px}.thac0-row{display:flex}.thac0-row.thac0-header{background:var(--accent-alpha-15);font-weight:600;font-size:11px;color:var(--text-secondary)}.thac0-cell{flex:1;min-width:36px;text-align:center;padding:5px 2px;font-size:12px;font-family:monospace;border-right:1px solid var(--border)}.thac0-cell:last-child{border-right:none}.thac0-row:not(.thac0-header) .thac0-cell{color:var(--text);font-weight:500}.thac0-row.thac0-rolls .thac0-cell{font-weight:700;font-size:13px}.thac0-label{font-weight:600!important;color:var(--text-secondary)!important;font-size:10px!important;text-transform:uppercase;letter-spacing:.5px;font-family:inherit!important;min-width:32px;background:var(--surface);border-right:2px solid var(--border)!important}.thac0-weapon-label{font-weight:400;color:var(--accent);font-size:12px}.attack-roll-breakdown{font-size:11px;color:var(--text-secondary, #aaa);margin:-2px 0 4px;font-style:italic}.armor-equip-grid{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.armor-slot{display:flex;align-items:center;gap:10px}.armor-slot label{font-size:12px;font-weight:600;color:var(--text-secondary);min-width:80px;text-transform:uppercase;letter-spacing:.3px}.armor-slot select{flex:1;padding:6px 8px;font-size:12px;background:var(--surface);border:1px solid var(--border);border-radius:3px;color:var(--text);font-family:inherit;min-height:36px}.armor-pieces{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:4px}.armor-pieces>label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase}.armor-piece-toggles{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.armor-mode-select{padding:4px 8px;font-size:12px;background:var(--surface);border:1px solid var(--border);border-radius:3px;color:var(--text);font-family:inherit}.armor-checkboxes{display:flex;gap:10px;flex-wrap:wrap}.armor-checkboxes label{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-secondary);cursor:pointer}.armor-checkboxes input[type=checkbox]{accent-color:var(--accent)}.armor-ac-summary{font-size:12px;font-weight:600;color:var(--accent);margin-left:auto}.weapon-list{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.weapon-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);overflow:hidden;transition:border-color .15s}.weapon-card.selected{border-color:var(--accent);border-left:4px solid var(--accent);background:var(--accent-alpha-15)}.weapon-card.selected .weapon-summary{background:transparent}.weapon-card.expanded{border-color:var(--text-muted)}.weapon-summary{display:flex;align-items:center;gap:6px;padding:6px 8px;cursor:pointer;font-size:12px;min-height:32px}.weapon-summary:hover{background:var(--surface-hover)}.weapon-select-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;border:2px solid var(--border);background:transparent;color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:all .15s}.weapon-select-btn:hover{background:var(--accent-alpha-15);border-color:var(--accent);color:var(--accent)}.weapon-select-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 6px #d2691e80}.weapon-expand-icon{color:var(--text-muted);flex-shrink:0}.weapon-summary-name{font-weight:500;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.weapon-empty{color:var(--text-muted);font-weight:400}.weapon-summary-tag{font-size:10px;padding:1px 5px;border-radius:3px;background:var(--surface-hover);color:var(--text-secondary);text-transform:capitalize;flex-shrink:0}.weapon-summary-dmg{font-size:11px;font-family:monospace;color:var(--text-secondary);flex-shrink:0}.weapon-summary-magic{font-size:11px;font-weight:600;color:var(--success);flex-shrink:0}.weapon-summary-spec{color:#f59e0b;font-size:14px;flex-shrink:0}.weapon-summary-computed{display:flex;align-items:center;gap:8px;font-size:11px;font-family:monospace;flex-shrink:0;margin-left:auto;padding-left:8px}.weapon-summary-hit{color:var(--accent);font-weight:600}.weapon-summary-dmg-bonus{color:var(--success);font-weight:600}.weapon-summary-dmg{color:var(--text);font-weight:500}.weapon-summary-dmg-lg{color:var(--text-secondary);font-weight:500}.weapon-summary-at{color:var(--text-muted);font-size:10px}.weapon-remove-btn{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:3px;flex-shrink:0;opacity:0;transition:all .15s}.weapon-summary:hover .weapon-remove-btn{opacity:1}.weapon-remove-btn:hover{background:#dc262626;color:var(--error)}.weapon-detail{padding:8px 10px 10px;border-top:1px solid var(--border);background:var(--bg)}.weapon-field-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:6px}.weapon-field{display:flex;flex-direction:column;gap:2px}.weapon-field.wide{grid-column:span 2}.weapon-field label{font-size:10px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.weapon-field input,.weapon-field select{padding:4px 6px;font-size:12px;background:var(--surface);border:1px solid var(--border);border-radius:3px;color:var(--text);font-family:inherit;width:100%;box-sizing:border-box}.weapon-field input[type=number]{font-family:monospace;-moz-appearance:textfield}.weapon-field input[type=number]::-webkit-inner-spin-button,.weapon-field input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.weapon-field input:focus,.weapon-field select:focus{outline:none;border-color:var(--accent)}.weapon-field-check{display:flex;align-items:flex-end}.weapon-field-check label{display:flex;align-items:center;gap:4px;font-size:11px;cursor:pointer;text-transform:none;font-weight:500;color:var(--text);padding:4px 0}.weapon-field-check input[type=checkbox]{width:auto;accent-color:var(--accent)}.weapon-field-ammo .ammo-inputs{display:flex;align-items:center;gap:2px}.weapon-field-ammo .ammo-inputs input{width:40px;text-align:center}.weapon-field-ammo .ammo-inputs span{color:var(--text-muted);font-weight:600}.weapon-add-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;font-size:12px;background:transparent;border:1px dashed var(--border);border-radius:var(--radius-sm, 4px);color:var(--text-secondary);cursor:pointer;transition:all .15s;width:100%;justify-content:center}.weapon-add-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-alpha-15)}.weapon-breakage-note{font-size:11px;color:var(--text-muted);margin-top:8px}.weapon-combat-list{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.weapon-combat-row{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--surface);border:1px solid var(--border);border-radius:6px;font-size:12px;cursor:pointer;transition:border-color .15s,background .15s}.weapon-combat-row:hover{border-color:var(--accent);background:var(--accent-alpha-08)}.weapon-combat-row.selected{border-color:var(--accent);background:var(--accent-alpha-15)}.weapon-combat-name{font-weight:600;color:var(--text);min-width:120px;white-space:nowrap}.weapon-combat-prof{font-size:11px;color:var(--accent)}.weapon-combat-prof.nonprof{color:var(--error, #f44336)}.grip-toggle-combat{font-size:10px;font-weight:700;padding:1px 6px;border-radius:3px;background:var(--bg-secondary);color:var(--text-muted);border:1px solid var(--border);cursor:pointer;transition:background .15s,color .15s}.grip-toggle-combat:hover{background:var(--bg-hover);color:var(--text)}.grip-toggle-combat.alt{background:var(--accent);color:#fff;border-color:var(--accent)}.weapon-combat-stats{display:flex;gap:12px;flex-wrap:wrap;color:var(--text);font-size:13px;font-weight:500;margin-left:auto}.weapon-combat-stats span{white-space:nowrap}.spd-modified{color:#4caf50;font-weight:600;cursor:help}.weapon-combat-lg{color:var(--text);font-style:italic}.weapon-combat-ammo{color:var(--accent);font-weight:600;display:inline-flex;align-items:center;gap:4px}.ammo-fire-btn{background:#ff980033;border:1px solid var(--accent);border-radius:3px;color:var(--accent);font-size:10px;font-weight:700;padding:0 4px;cursor:pointer;line-height:1.4}.ammo-fire-btn:hover{background:#ff980066}.ammo-type-select{width:100%;font-size:11px;padding:3px 4px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);margin-bottom:4px}.ammo-type-note{display:block;font-size:10px;color:var(--text-muted);font-style:italic;margin-bottom:4px}.ammo-qty-label{font-size:11px;color:var(--text-secondary)}.ammo-magic-badge{font-size:10px;color:#4caf50;font-weight:600;padding:1px 4px;background:#4caf5026;border-radius:3px}.ammo-magic-input{display:inline-flex;align-items:center;font-size:11px;color:#4caf50;font-weight:600;gap:1px}.ammo-magic-number{width:28px;font-size:11px;text-align:center;background:var(--bg-secondary);border:1px solid var(--border);border-radius:3px;color:#4caf50;padding:1px 2px}.composite-str-warning{color:var(--error);font-size:14px;margin-left:2px;cursor:help}.weapon-combat-empty{color:var(--text-muted);font-size:12px;font-style:italic;padding:8px 0}.weapon-autocomplete-wrapper{position:relative}.weapon-autocomplete-list{position:absolute;top:100%;left:0;right:0;z-index:100;background:var(--bg);border:1px solid var(--accent);border-top:none;border-radius:0 0 4px 4px;max-height:200px;overflow-y:auto;list-style:none;margin:0;padding:0;box-shadow:0 4px 12px #0006}.weapon-autocomplete-item{display:flex;justify-content:space-between;align-items:center;padding:6px 8px;cursor:pointer;font-size:12px;border-bottom:1px solid var(--border)}.weapon-autocomplete-item:last-child{border-bottom:none}.weapon-autocomplete-item:hover{background:var(--accent-alpha-15)}.weapon-autocomplete-item .ac-name{font-weight:600;color:var(--text)}.weapon-autocomplete-item .ac-meta{font-size:10px;color:var(--text-muted);white-space:nowrap}.inventory-weight-bar{font-size:12px;padding:4px 8px;margin-bottom:8px;background:var(--surface);border-radius:var(--radius-sm, 4px);color:var(--text-secondary)}.inventory-weight-bar.overweight{color:#ff6b6b;font-weight:600}.inventory-list{display:flex;flex-direction:column;gap:4px;margin-bottom:16px}.inventory-row{display:flex;align-items:center;gap:4px}.inventory-name-wrapper{flex:1;position:relative}.inventory-name-wrapper .inventory-name{width:100%}.eq-picker{margin-bottom:12px}.eq-picker-cats{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.eq-picker-cat-btn{padding:4px 10px;font-size:11px;border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:all .15s;font-family:inherit}.eq-picker-cat-btn:hover{border-color:var(--accent);color:var(--text)}.eq-picker-cat-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.eq-picker-items{border:1px solid var(--border);border-radius:6px;background:var(--surface);overflow:hidden}.eq-picker-search{width:100%;padding:6px 10px;font-size:12px;border:none;border-bottom:1px solid var(--border);background:var(--bg);color:var(--text);font-family:inherit;box-sizing:border-box}.eq-picker-search::placeholder{color:var(--text-secondary)}.eq-picker-list{max-height:200px;overflow-y:auto;display:flex;flex-direction:column}.eq-picker-item{display:flex;justify-content:space-between;align-items:center;padding:4px 10px;font-size:12px;border:none;background:transparent;color:var(--text);cursor:pointer;text-align:left;font-family:inherit;border-bottom:1px solid var(--border-light, rgba(128, 128, 128, .1))}.eq-picker-item:hover{background:var(--accent-light, rgba(100, 100, 255, .1))}.eq-picker-item:last-child{border-bottom:none}.eq-item-name{flex:1}.eq-item-meta{display:flex;gap:8px;font-size:11px;color:var(--text-secondary);white-space:nowrap}.eq-item-cost{min-width:60px;text-align:right}.eq-item-weight{min-width:40px;text-align:right}.slot-transfer-arrows{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:0 4px}.slot-transfer-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:all .15s;padding:0}.slot-transfer-btn:hover:not(:disabled){background:var(--accent-alpha-15);border-color:var(--accent);color:var(--accent)}.slot-transfer-badge{display:block;font-size:10px;font-weight:700;margin-top:2px;text-align:center}.slot-transfer-plus{color:var(--success)}.slot-transfer-minus{color:#ff6b6b}.nwp-learned-list{display:flex;flex-direction:column;gap:2px;margin-bottom:16px}.nwp-learned-item{border:1px solid var(--border);border-radius:4px;overflow:hidden}.nwp-learned-row{display:flex;align-items:center;gap:8px;padding:6px 10px;cursor:pointer;transition:background .15s}.nwp-learned-row:hover{background:var(--surface-hover)}.nwp-expand-icon{color:var(--text-secondary);flex-shrink:0}.nwp-learned-name{flex:1;font-size:13px;font-weight:500;display:flex;align-items:center;gap:6px}.nwp-kit-badge{font-size:9px;font-weight:700;text-transform:uppercase;padding:1px 4px;border-radius:3px;background:#4caf5033;color:#4caf50;letter-spacing:.5px}.nwp-kit-badge.nwp-kit-required{background:#ff980033;color:#ff9800}.nwp-learned-slots{font-size:11px;color:var(--text-secondary);min-width:50px}.nwp-learned-check{font-size:12px;font-weight:600;color:var(--accent);min-width:70px;text-align:right}.nwp-special{font-style:italic;color:var(--text-muted);font-weight:400}.nwp-detail-card{background:var(--surface);border-top:1px solid var(--border);padding:8px 12px 10px 30px;display:flex;flex-direction:column;gap:4px;font-size:12px}.nwp-detail-row{display:flex;justify-content:space-between}.nwp-detail-label{color:var(--text-secondary)}.eq-picker-cat-btn.cross-group{border-style:dashed}.eq-picker-item.already-learned{opacity:.6}.eq-picker-item.already-learned .eq-item-name{font-style:italic}.overbudget .save-compact-value,.overbudget .combat-stat-value{color:#ff6b6b!important}.overbudget{border-color:#ff6b6b66!important}.nwp-languages{display:flex;flex-direction:column;gap:4px;margin-bottom:16px}.nwp-lang-row{display:flex;align-items:center;gap:4px}.nwp-lang-row .inventory-name{flex:1}.thieving-budget-bar{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:10px;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:6px}.thieving-budget-label{font-size:12px;font-weight:600;color:var(--text)}.thieving-budget-numbers{font-size:12px;color:var(--text-muted);margin-left:auto}.thieving-budget-track{width:100%;height:6px;background:var(--accent-alpha-08);border-radius:3px;overflow:hidden}.thieving-budget-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .2s ease}.thieving-skills-table{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:6px;overflow:hidden}.thieving-row{display:grid;grid-template-columns:1fr 50px 50px 100px 55px;align-items:center;padding:6px 10px;border-bottom:1px solid var(--border);font-size:13px}.thieving-row:last-child{border-bottom:none}.thieving-header{background:var(--accent-alpha-08);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:5px 10px}.thieving-cell{text-align:center}.thieving-cell.thieving-name{text-align:left;font-weight:500;color:var(--text)}.thieving-cell.thieving-base{color:var(--text-muted);font-size:12px}.thieving-cell.thieving-mods{font-size:12px;color:var(--text-muted)}.thieving-cell.thieving-mods.positive{color:var(--success, #4caf50)}.thieving-cell.thieving-mods.negative{color:var(--error, #f44336)}.thieving-cell.thieving-alloc{display:flex;align-items:center;justify-content:center;gap:2px}.thieving-adj-btn{width:22px;height:22px;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--text);font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .15s}.thieving-adj-btn:hover:not(:disabled){background:var(--accent-alpha-08);border-color:var(--accent)}.thieving-adj-btn:disabled{opacity:.35;cursor:not-allowed}.thieving-alloc-value{min-width:28px;text-align:center;font-weight:600;font-size:13px;color:var(--accent)}.thieving-cell.thieving-total{font-weight:700;font-size:14px;color:var(--text)}.thieving-cell.thieving-total.at-cap{color:var(--accent)}.thieving-backstab{display:flex;justify-content:space-between;align-items:center;margin-top:8px;padding:6px 10px;background:var(--surface);border:1px solid var(--border);border-radius:6px;font-size:13px}.thieving-backstab-value{font-weight:700;font-size:15px;color:var(--accent)}.thieving-hint{margin-top:6px;font-size:11px;color:var(--text-muted);font-style:italic}.thieving-convict-notice{padding:8px 12px;margin-bottom:10px;background:var(--warning-bg, rgba(255, 152, 0, .1));border:1px solid var(--warning, #ff9800);border-radius:6px;font-size:12px;color:var(--text)}.thieving-cell.thieving-pick{width:30px;flex-shrink:0}.thieving-pick input[type=checkbox]{accent-color:var(--accent);width:14px;height:14px;cursor:pointer}.thieving-row.thieving-disabled{opacity:.4}.thieving-cell.thieving-name.muted{color:var(--text-muted);text-decoration:line-through}.thieving-context-note{color:var(--accent);font-weight:700;cursor:help}.thieving-context-section{margin-top:8px;padding:6px 10px;background:var(--surface);border:1px solid var(--border);border-radius:6px;font-size:12px;color:var(--text-muted)}.thieving-context-detail{margin:2px 0;line-height:1.4}.thieving-dex-trade{display:flex;align-items:center;gap:10px;margin-bottom:10px;padding:6px 12px;background:var(--surface);border:1px solid var(--accent);border-radius:6px}.thieving-dex-trade-btn{padding:4px 10px;border:1px solid var(--accent);border-radius:4px;background:var(--accent-alpha-08);color:var(--accent);font-size:12px;font-weight:600;cursor:pointer;transition:background .15s}.thieving-dex-trade-btn:hover{background:var(--accent);color:var(--bg-primary)}.thieving-dex-trade-note{color:var(--accent);font-size:11px}.thieving-total-summary{font-size:11px;color:var(--text-muted);margin-bottom:8px;text-align:center}.thieving-extended-header{margin-top:14px;margin-bottom:6px;font-size:13px;font-weight:600;color:var(--text-muted)}.thieving-extended .thieving-row{grid-template-columns:1fr 50px 50px 55px}.notes-textarea{width:100%;min-height:300px;padding:12px;font-size:13px;font-family:inherit;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);resize:vertical;line-height:1.6;box-sizing:border-box}.notes-textarea::placeholder{color:var(--text-muted)}.notes-textarea:focus{outline:none;border-color:var(--accent)}.nwp-preview-card{border-top:1px solid var(--accent);background:var(--bg);padding:12px 14px}.nwp-preview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.nwp-preview-header h5{margin:0;font-size:14px;font-weight:600;color:var(--accent)}.nwp-preview-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:14px;padding:2px 6px;border-radius:3px}.nwp-preview-close:hover{color:var(--text);background:var(--surface-hover)}.nwp-preview-stats{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--text-secondary);margin-bottom:10px}.nwp-preview-stats strong{color:var(--text)}.nwp-preview-desc{font-size:12px;line-height:1.6;color:var(--text);margin-bottom:12px;max-height:200px;overflow-y:auto;white-space:pre-wrap}.nwp-preview-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.nwp-preview-btn{padding:5px 14px;font-size:12px;font-weight:600;border-radius:4px;cursor:pointer;border:1px solid;font-family:inherit;transition:all .15s}.nwp-preview-btn-add{background:#5a9e3e26;border-color:var(--success);color:var(--success)}.nwp-preview-btn-add:hover{background:#5a9e3e4d}.nwp-preview-btn-extra{background:#d2a0171a;border-color:var(--warning);color:var(--warning)}.nwp-preview-btn-extra:hover{background:#d2a01733}.nwp-preview-btn-remove{background:#ff6b6b14;border-color:#ff6b6b66;color:#ff6b6b}.nwp-preview-btn-remove:hover{background:#ff6b6b26}.nwp-preview-learned-badge{font-size:12px;color:var(--success);font-weight:500}.eq-picker-item.previewing{background:var(--accent-alpha-10);border-left:2px solid var(--accent)}.nwp-detail-desc{margin-top:8px;padding-top:8px;border-top:1px solid var(--border);font-size:12px;line-height:1.6;color:var(--text-secondary);white-space:pre-wrap;max-height:200px;overflow-y:auto}.inventory-name{padding:4px 6px;font-size:12px;background:var(--surface);border:1px solid var(--border);border-radius:3px;color:var(--text);font-family:inherit}.inventory-weight{width:50px;padding:4px;font-size:12px;background:var(--surface);border:1px solid var(--border);border-radius:3px;color:var(--text);text-align:right;font-family:inherit}.inventory-lbs{font-size:10px;color:var(--text-muted);min-width:18px}.inventory-qty{width:36px;padding:4px;font-size:12px;background:var(--surface);border:1px solid var(--border);border-radius:3px;color:var(--text);text-align:center;font-family:inherit}.inventory-gem-psp{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:600;color:#4ecdc4;padding:1px 6px;border:1px solid rgba(78,205,196,.3);border-radius:3px;white-space:nowrap}.inventory-linked{font-size:12px;color:var(--accent);min-width:18px;text-align:center}.inventory-remove-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:3px;display:flex;align-items:center}.inventory-remove-btn:hover{color:#ff6b6b;background:#ff6b6b1a}.add-inventory-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;font-size:12px;background:transparent;border:1px dashed var(--border);border-radius:var(--radius-sm, 4px);color:var(--text-secondary);cursor:pointer;transition:all .15s;width:100%;justify-content:center}.add-inventory-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-alpha-15)}.play-currency-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px;margin-bottom:16px}.currency-slot{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);font-size:12px}.currency-label{color:var(--text-secondary)}.currency-value{font-weight:600;font-family:monospace;color:var(--text);min-width:30px;text-align:right}.spell-card-popover,.power-card-popover{position:fixed;z-index:10000;width:360px;max-height:480px;overflow-y:auto;background:var(--bg, #1c1712);border:1px solid var(--accent, #d2691e);border-radius:6px;box-shadow:0 8px 32px #00000080,0 2px 8px #0000004d;padding:0;pointer-events:auto;font-size:12px;color:var(--text, #ede0d0)}.spell-card-header,.power-card-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px 6px;border-bottom:1px solid var(--border, #3d342a)}.spell-card-name,.power-card-name{font-size:14px;font-weight:700;color:var(--text, #ede0d0)}.spell-card-level{font-size:12px;font-weight:600;color:var(--accent, #d2691e)}.power-card-type{font-size:10px;padding:2px 6px;border-radius:3px}.power-card-type.science{background:#5b8fb933;color:var(--info)}.power-card-type.devotion{background:var(--success-alpha-10);color:var(--success)}.power-card-type.high-science{background:#d2691e33;color:var(--accent)}.power-card-type.attack-mode{background:#c0392b26;color:var(--error)}.power-card-type.defense-mode{background:#5b8fb926;color:var(--info)}.spell-card-subheader,.power-card-subheader{padding:4px 12px 8px;font-size:11px;color:var(--text-secondary, #b8a898);border-bottom:1px solid var(--border, #3d342a)}.spell-card-grid,.power-card-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px 12px;padding:8px 12px;border-bottom:1px solid var(--border, #3d342a)}.spell-card-field,.power-card-field{display:flex;flex-direction:column;gap:1px}.spell-card-label,.power-card-label{font-size:10px;font-weight:600;color:var(--text-muted, #7a6e62);text-transform:uppercase;letter-spacing:.5px}.spell-card-material{padding:6px 12px;font-size:11px;color:var(--text-secondary);border-bottom:1px solid var(--border, #3d342a);display:flex;flex-direction:column;gap:2px}.spell-card-reversible{padding:4px 12px;font-size:11px;color:var(--accent, #d2691e);font-style:italic;border-bottom:1px solid var(--border, #3d342a)}.spell-card-reverse-desc{color:var(--text-secondary);font-style:normal}.power-card-prereqs{padding:6px 12px;font-size:11px;color:var(--text-secondary);border-bottom:1px solid var(--border, #3d342a);display:flex;flex-direction:column;gap:2px}.spell-card-description,.power-card-description{padding:8px 12px;font-size:11px;line-height:1.5;color:var(--text-secondary, #b8a898);max-height:160px;overflow-y:auto;border-bottom:1px solid var(--border, #3d342a)}.power-card-result{padding:4px 12px;font-size:11px;display:flex;flex-direction:column;gap:2px}.power-card-result.success{color:var(--success)}.power-card-result.failure{color:var(--error);border-bottom:1px solid var(--border, #3d342a)}.spell-card-source,.power-card-source{padding:6px 12px;font-size:10px;color:var(--text-muted, #7a6e62);font-style:italic}.character-level-row{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);margin-bottom:12px}.level-label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text);cursor:default}.level-input{width:56px;padding:4px 8px;font-size:16px;font-weight:700;text-align:center;background:var(--primary);border:1px solid var(--accent);border-radius:var(--radius-sm, 4px);color:var(--accent)}.level-input:focus{outline:2px solid var(--accent);outline-offset:1px}.level-hint{font-size:11px;color:var(--text-muted)}.character-dropdown__level-control{display:inline-flex;align-items:center;gap:2px;margin-left:6px}.character-dropdown__level{font-size:11px;color:var(--accent);font-weight:600;padding:1px 6px;background:var(--accent-alpha-15);border-radius:3px;min-width:40px;text-align:center}.character-dropdown__level-btn{display:flex;align-items:center;justify-content:center;width:18px;height:18px;padding:0;border:1px solid var(--border);border-radius:3px;background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:all .1s}.character-dropdown__level-btn:hover:not(:disabled){background:var(--accent-alpha-15);border-color:var(--accent);color:var(--accent)}.character-dropdown__level-btn:disabled{opacity:.25;cursor:not-allowed}.spell-book-level-group{margin-bottom:4px}.spell-book-level-header{display:flex;align-items:center;justify-content:space-between;padding:4px 8px;background:var(--surface);border-bottom:1px solid var(--border-light);position:sticky;top:0;z-index:1}.spell-book-level-title{font-size:12px;font-weight:700;color:var(--accent)}.spell-book-level-slots{font-size:11px;color:var(--text-secondary);font-family:monospace}.spell-book-level-slots.full{color:var(--warning)}.spell-book-level-slots .slots-remaining{color:var(--text-muted);font-family:sans-serif}.play-header-level{font-size:13px;color:var(--accent);font-weight:600;margin-left:8px;padding:2px 8px;background:var(--accent-alpha-15);border-radius:4px}.play-header-actions{display:flex;gap:6px;align-items:center}.action-circle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:all .15s;padding:0}.action-circle:hover:not(:disabled){background:var(--bg-primary);transform:scale(1.1)}.action-circle:disabled{opacity:.25;cursor:not-allowed}.action-level-up{border-color:var(--success);color:var(--success)}.action-level-up.level-up-ready{animation:level-up-pulse 2s ease-in-out infinite;box-shadow:0 0 8px #4caf5080}@keyframes level-up-pulse{0%,to{box-shadow:0 0 4px #4caf504d}50%{box-shadow:0 0 12px #4caf50b3}}.action-level-up:hover:not(:disabled){background:#4caf5026}.level-up-btn-wrapper{position:relative}.level-up-picker{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:4px;background:var(--bg);border:1px solid var(--border);border-radius:6px;box-shadow:0 4px 16px #0006;z-index:100;min-width:200px;overflow:hidden}.level-up-picker-option{display:flex;justify-content:space-between;align-items:center;width:100%;padding:8px 12px;border:none;background:transparent;color:var(--text);font-size:12px;cursor:pointer;gap:12px}.level-up-picker-option:hover{background:var(--surface)}.level-up-picker-option.picker-eligible{color:var(--success)}.picker-cls{font-weight:600;white-space:nowrap}.picker-xp{font-size:11px;color:var(--text-secondary);white-space:nowrap}.picker-ready{color:var(--success);font-weight:700}.level-up-xp-input{width:120px!important;font-size:16px}.level-up-xp-invalid{border-color:#ff6b6b!important}.level-up-xp-warning{color:#ff6b6b;font-size:12px;margin:-4px 0 12px}.level-up-confirm:disabled{opacity:.4;cursor:not-allowed}.action-level-down{border-color:#ff6b6b;color:#ff6b6b}.action-level-down:hover:not(:disabled){background:#ff6b6b26}.action-rest{border-color:#6db3e8;color:#6db3e8}.action-rest:hover:not(:disabled){background:#4682b426}.action-save{border-color:var(--accent);color:var(--accent)}.action-save:hover:not(:disabled){background:var(--accent-alpha-15)}.config-item-modal{min-width:340px}.config-item-modal h3{margin:0 0 16px;font-size:16px;color:var(--accent)}.config-item-fields{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.config-item-field{display:flex;flex-direction:column;gap:4px}.config-item-field label{font-size:12px;font-weight:600;color:var(--text-secondary)}.config-item-field input{padding:6px 10px;font-size:14px;background:var(--surface);border:1px solid var(--border);border-radius:4px;color:var(--text);font-family:inherit}.config-item-field input:focus{outline:none;border-color:var(--accent)}.config-item-actions{display:flex;gap:8px;justify-content:flex-end}.level-up-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200}.level-up-modal{background:var(--bg);border:1px solid var(--accent);border-radius:8px;padding:24px;min-width:320px;max-width:400px;box-shadow:0 8px 32px #00000080}.level-up-modal h3{margin:0 0 8px;color:var(--accent);font-size:18px}.level-up-desc{color:var(--text-secondary);font-size:13px;margin:0 0 16px}.level-up-roll-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}.level-up-roll-row label{font-size:13px;font-weight:600;color:var(--text)}.level-up-roll-row input{width:60px;padding:6px 8px;font-size:16px;text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:4px;color:var(--text);font-family:monospace}.level-up-breakdown{display:flex;gap:16px;font-size:12px;color:var(--text-secondary);margin-bottom:16px;padding:8px;background:var(--surface);border-radius:4px}.level-up-total{color:var(--accent);font-weight:600}.level-up-actions{display:flex;gap:8px;justify-content:flex-end}.level-up-confirm{padding:8px 16px;font-size:13px;font-weight:600;background:var(--accent);color:#fff;border:none;border-radius:4px;cursor:pointer}.level-up-confirm:hover{filter:brightness(1.1)}.level-up-cancel{padding:8px 16px;font-size:13px;background:transparent;border:1px solid var(--border);border-radius:4px;color:var(--text-secondary);cursor:pointer}.level-up-cancel:hover{border-color:var(--text-secondary);color:var(--text)}.reincarnate-modal{max-width:520px}.reincarnate-cases{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:12px 0}.reincarnate-case{padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 4px);display:flex;flex-direction:column;gap:8px}.reincarnate-case h4{margin:0;font-size:13px;color:var(--accent)}.reincarnate-case p{margin:0;font-size:12px;color:var(--text-secondary);line-height:1.4;flex:1}.reincarnate-preserved{font-size:11px;color:var(--text-muted);margin:4px 0 8px}.app-toast-container{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column-reverse;gap:8px;pointer-events:none;max-width:420px}.app-toast{pointer-events:auto;display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:6px;font-size:13px;line-height:1.4;box-shadow:0 4px 12px #0000004d;cursor:pointer;animation:app-toast-slide-in .25s ease-out;background:var(--bg-secondary, #2a2a3e);color:var(--text-primary, #f0f0f0);border:1px solid var(--border-color, #444)}.app-toast-exit{animation:app-toast-slide-out .25s ease-in forwards}.app-toast-info{border-color:#64b5f6}.app-toast-success{border-color:#66bb6a}.app-toast-warning{border-color:#ffb74d}.app-toast-error{border-color:#ef5350}.app-toast-icon{flex-shrink:0;font-size:14px;font-weight:700;width:18px;text-align:center}.app-toast-info .app-toast-icon{color:#64b5f6}.app-toast-success .app-toast-icon{color:#66bb6a}.app-toast-warning .app-toast-icon{color:#ffb74d}.app-toast-error .app-toast-icon{color:#ef5350}.app-toast-text{flex:1;word-break:break-word}.app-toast-action{flex-shrink:0;background:transparent;border:1px solid currentColor;color:inherit;padding:4px 10px;border-radius:4px;font-size:12px;cursor:pointer;font-weight:500}.app-toast-action:hover{background:#ffffff14}@keyframes app-toast-slide-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes app-toast-slide-out{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(20px)}}.sync-indicator{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;margin-right:6px;color:var(--text-secondary, #888);background:var(--bg-secondary, transparent);border:1px solid transparent;transition:color .2s,background .2s,border-color .2s}.sync-indicator--synced{color:#66bb6a}.sync-indicator--syncing,.sync-indicator--pending{color:#ffb74d}.sync-indicator--syncing svg,.sync-indicator--pending svg{animation:sync-indicator-spin 1.4s linear infinite}.sync-indicator--failed{color:#ef5350;border-color:#ef535066}.sync-indicator--clickable{cursor:pointer}.sync-indicator--clickable:hover{background:var(--bg-hover, rgba(255, 255, 255, .06))}@keyframes sync-indicator-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:1024px){.step-indicator{padding:12px 8px;gap:0}.step-connector{width:16px;margin:0 2px}.step-label{display:none}.step-number{width:28px;height:28px;font-size:13px}}@media(max-width:768px){.play-tab-bar{flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}.play-tab{padding:8px 10px;font-size:12px;flex-shrink:0}.play-tab-label{font-size:12px}}.layout-editor-narrow-warning{display:none}@media(max-width:1023px){.layout-editor-narrow-warning{display:block;padding:8px 14px;background:var(--surface);border-bottom:1px solid var(--border);color:var(--text-secondary);font-size:12px;line-height:1.4;text-align:center}}.play-calendar-pill-group{display:inline-flex;align-items:stretch;gap:0;border-radius:999px;background:var(--surface);border:1px solid var(--border);overflow:hidden;min-height:32px}.play-calendar-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:transparent;border:0;border-left:1px solid var(--border);border-right:1px solid var(--border);color:var(--text);font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;min-height:30px;transition:background .15s,color .15s}.play-calendar-pill:hover{background:var(--surface-elevated, var(--surface));color:var(--accent)}.play-calendar-pill:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.play-calendar-pill-moons{display:inline-flex;align-items:center;gap:2px;flex-shrink:0}.play-calendar-pill-text{font-variant-numeric:tabular-nums}.play-calendar-pill-step{display:inline-flex;align-items:center;justify-content:center;min-width:32px;padding:0 6px;background:transparent;border:0;color:var(--text-muted, var(--text));cursor:pointer;transition:background .15s,color .15s}.play-calendar-pill-step:hover{background:var(--surface-elevated, var(--surface));color:var(--accent)}.play-calendar-pill-step:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.play-calendar-pill-step:active{background:var(--accent);color:var(--surface)}@media(pointer:coarse){.play-calendar-pill-group{min-height:36px}.play-calendar-pill-step{min-width:40px}.play-calendar-pill{min-height:34px;padding:4px 12px}}.calendar-toggle{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none}.calendar-toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer}.calendar-overlay{display:block}.calendar-modal{position:absolute;background:var(--bg);border:1px solid var(--accent);border-radius:8px;box-shadow:0 8px 32px #00000080;display:flex;flex-direction:column;overflow:hidden;box-sizing:border-box;padding:0}.calendar-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 12px;flex-shrink:0;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.calendar-modal-header--dragging{cursor:grabbing}.calendar-modal-resize{position:absolute;right:0;bottom:0;width:22px;height:22px;cursor:nwse-resize;touch-action:none;-webkit-user-select:none;user-select:none;background-image:linear-gradient(135deg,transparent 0%,transparent 50%,var(--text-secondary) 50%,var(--text-secondary) 60%,transparent 60%,transparent 72%,var(--text-secondary) 72%,var(--text-secondary) 82%,transparent 82%);background-size:14px 14px;background-position:right -2px bottom -2px;background-repeat:no-repeat;opacity:.55}.calendar-modal-resize:hover{opacity:1}.calendar-modal-header h3{margin:0;color:var(--accent);font-size:18px}.calendar-modal-header-actions{display:inline-flex;align-items:center;gap:6px}.calendar-modal-undo{display:inline-flex;align-items:center;gap:4px;height:28px;padding:0 10px;background:transparent;border:1px solid var(--border);border-radius:4px;color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer}.calendar-modal-undo:hover:not(:disabled){background:var(--surface);color:var(--accent);border-color:var(--accent)}.calendar-modal-undo:disabled{opacity:.4;cursor:not-allowed}.calendar-modal-close{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:transparent;border:1px solid transparent;border-radius:4px;color:var(--text-secondary);cursor:pointer}.calendar-modal-close:hover{background:var(--surface);color:var(--text);border-color:var(--border)}.calendar-modal-body{display:grid;grid-template-columns:minmax(260px,1fr) minmax(240px,1fr);gap:18px;padding:0 18px 18px;flex:1;min-height:0;align-items:stretch}.calendar-modal-left,.calendar-modal-right{display:flex;flex-direction:column;gap:14px;min-width:0;min-height:0;overflow-y:auto}.calendar-readout{display:flex;flex-direction:column;gap:2px}.calendar-readout-line{font-size:12px;color:var(--text);line-height:1.35}.calendar-readout-primary{font-size:16px;font-weight:600;color:var(--accent)}.calendar-readout-secondary{color:var(--text-secondary)}.calendar-messenger{color:#d97706;font-weight:600}.calendar-disk-wrap{flex:1 1 auto;min-height:240px;min-width:0;display:flex;align-items:center;justify-content:center;padding:0}.calendar-disk-wrap>svg{max-width:100%;max-height:100%}.calendar-disk-svg{width:100%;height:100%;display:block}.calendar-moons{display:flex;flex-direction:column;gap:6px;padding:8px 10px;background:var(--surface);border:1px solid var(--border);border-radius:4px}.calendar-moon-row{display:flex;align-items:center;gap:10px}.calendar-moon-info{display:flex;flex-direction:column;min-width:0}.calendar-moon-name{font-size:13px;font-weight:600;color:var(--text)}.calendar-moon-phase{font-size:11px;color:var(--text-secondary);font-variant-numeric:tabular-nums}.calendar-events{list-style:none;margin:0;padding:8px 10px;background:var(--surface);border:1px solid var(--border);border-radius:4px;font-size:12px;color:var(--text);display:flex;flex-direction:column;gap:2px}.calendar-events li{margin:0}.calendar-section{display:flex;flex-direction:column;gap:6px}.calendar-section h4{margin:0 0 2px;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.calendar-step-row{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.calendar-step-row--single{display:flex;align-items:stretch;gap:6px}.calendar-step-row--single>*{flex:1 1 0;min-width:0}.calendar-stepper{display:inline-flex;align-items:stretch;background:var(--surface);border:1px solid var(--border);border-radius:4px;overflow:hidden}.calendar-stepper:hover{border-color:var(--accent)}.calendar-stepper-arrow{display:inline-flex;align-items:center;justify-content:center;padding:4px 6px;background:transparent;border:0;color:var(--text);cursor:pointer}.calendar-stepper-arrow:hover{background:var(--surface-elevated, var(--surface));color:var(--accent)}.calendar-stepper-label{display:inline-flex;flex:1 1 auto;align-items:center;justify-content:center;padding:4px 6px;font-size:12px;font-weight:600;font-variant-numeric:tabular-nums;color:var(--text);border-left:1px solid var(--border);border-right:1px solid var(--border);min-width:24px}.calendar-stepper-input{flex:1 1 auto;width:100%;min-width:36px;padding:4px 6px;background:transparent;border:0;border-left:1px solid var(--border);border-right:1px solid var(--border);color:var(--text);font-size:12px;font-weight:600;font-variant-numeric:tabular-nums;text-align:center}.calendar-stepper-input:focus{outline:1px solid var(--accent);outline-offset:-1px}.calendar-step-btn{display:inline-flex;align-items:center;justify-content:center;gap:2px;padding:6px 4px;background:var(--surface);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:11px;font-weight:600;cursor:pointer;font-variant-numeric:tabular-nums}.calendar-step-btn:hover{background:var(--surface-elevated, var(--surface));border-color:var(--accent);color:var(--accent)}.calendar-form-row{display:grid;grid-template-columns:80px 1fr auto;align-items:center;gap:8px}.calendar-form-row label{font-size:12px;color:var(--text)}.calendar-fy-input,.calendar-day-input{width:100%;padding:4px 6px;background:var(--surface);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:12px;font-variant-numeric:tabular-nums}.calendar-period-select{width:100%;padding:4px 6px;background:var(--surface);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:12px}.calendar-form-hint{font-size:11px;color:var(--text-secondary)}.calendar-notes-section{flex:1 1 auto;min-height:0}.calendar-notes-section .calendar-notes{flex:1 1 auto;min-height:80px;height:100%}.calendar-notes{width:100%;padding:6px 8px;background:var(--surface);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:12px;font-family:inherit;resize:none;min-height:56px}@media(max-width:720px){.calendar-modal-body{grid-template-columns:1fr}}.chat-panel{width:var(--chat-width, 380px);height:100%;display:flex;flex-direction:column;flex-shrink:0;background:var(--surface, #2a2218);border-left:1px solid var(--border, #3d342a);box-shadow:-4px 0 20px #0000004d;animation:chat-slide-in .2s ease-out}@keyframes chat-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border, #3d342a);background:var(--primary, #1e1810);flex-shrink:0}.chat-header-left{display:flex;align-items:center;gap:8px;color:var(--text, #ede0d0)}.chat-header-title{font-size:13px;font-weight:600}.chat-header-actions{display:flex;align-items:center;gap:4px}.chat-icon-btn{background:none;border:none;color:var(--text-secondary, #b8a898);cursor:pointer;padding:4px 6px;border-radius:4px;display:flex;align-items:center}.chat-icon-btn:hover{background:var(--surface-hover, #352c20);color:var(--text, #ede0d0)}.chat-icon-btn:disabled{opacity:.4;cursor:not-allowed}.chat-messages{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:12px}.chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;flex:1;padding:40px 20px;color:var(--text-muted, #7a6e62)}.chat-empty-icon{opacity:.3;margin-bottom:12px}.chat-empty-title{font-size:15px;font-weight:600;color:var(--text-secondary, #b8a898);margin:0 0 6px}.chat-empty-hint{font-size:12px;margin:0;line-height:1.5}.chat-message{display:flex;flex-direction:column;gap:4px}.chat-message-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.chat-message-user .chat-message-label{color:var(--accent, #d2691e)}.chat-message-assistant .chat-message-label{color:var(--success, #5a9e3e)}.chat-message-content{font-size:13px;line-height:1.6;color:var(--text, #ede0d0);background:var(--primary, #1e1810);border-radius:8px;padding:10px 12px;white-space:pre-wrap;word-break:break-word}.chat-message-user .chat-message-content{background:var(--accent-alpha-10, rgba(210, 105, 30, .1));border:1px solid var(--accent-alpha-15, rgba(210, 105, 30, .15))}.chat-message-assistant .chat-message-content{background:var(--primary, #1e1810);border:1px solid var(--border, #3d342a)}.chat-layout-edit{margin-top:8px;border:1px solid var(--accent-alpha-15, rgba(210, 105, 30, .15));border-radius:8px;overflow:hidden;background:var(--primary, #1e1810)}.chat-layout-edit-header{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:6px 10px;background:var(--accent-alpha-10, rgba(210, 105, 30, .1));color:var(--accent, #d2691e);border-bottom:1px solid var(--accent-alpha-15, rgba(210, 105, 30, .15))}.chat-layout-edit-json{font-family:Cascadia Code,Fira Code,Consolas,monospace;font-size:11px;line-height:1.5;padding:8px 10px;margin:0;overflow-x:auto;max-height:200px;overflow-y:auto;color:var(--text, #ede0d0);white-space:pre}.chat-layout-edit-actions{display:flex;gap:8px;padding:8px 10px;border-top:1px solid var(--border, #3d342a)}.chat-edit-btn{display:flex;align-items:center;gap:4px;padding:5px 12px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;border:none;transition:background .15s}.chat-edit-apply{background:var(--success, #5a9e3e);color:#fff}.chat-edit-apply:hover{background:#4e8e35}.chat-edit-cancel{background:var(--surface, #2a2218);color:var(--text-secondary, #b8a898);border:1px solid var(--border, #3d342a)}.chat-edit-cancel:hover{background:var(--surface-hover, #352c20);color:var(--text, #ede0d0)}.chat-typing{display:flex;align-items:center;gap:6px;color:var(--text-muted, #7a6e62);font-style:italic}.chat-spinner{animation:chat-spin 1s linear infinite}@keyframes chat-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.chat-error{font-size:12px;color:var(--error, #c0392b);background:#c0392b1a;border:1px solid rgba(192,57,43,.2);border-radius:6px;padding:8px 12px}.chat-splitter{display:flex;align-items:center;justify-content:center;height:8px;flex-shrink:0;cursor:row-resize;background:var(--primary, #1e1810);border-top:1px solid var(--border, #3d342a);transition:background .15s;-webkit-user-select:none;user-select:none}.chat-splitter:hover{background:var(--surface-hover, #352c20)}.chat-splitter:active{background:var(--accent-alpha-15, rgba(210, 105, 30, .15))}.chat-splitter-icon{color:var(--text-muted, #7a6e62);opacity:.6}.chat-splitter:hover .chat-splitter-icon{opacity:1;color:var(--text-secondary, #b8a898)}.chat-input-area{display:flex;align-items:stretch;gap:8px;padding:10px 12px;border-top:none;background:var(--primary, #1e1810);flex-shrink:0;height:var(--chat-input-height, auto)}.chat-input{flex:1;background:var(--bg, #1c1712);border:1px solid var(--border, #3d342a);border-radius:8px;color:var(--text, #ede0d0);font-size:13px;padding:8px 12px;resize:none;outline:none;font-family:inherit;line-height:1.4;min-height:0}.chat-input::placeholder{color:var(--text-muted, #7a6e62)}.chat-input:focus{border-color:var(--accent, #d2691e)}.chat-input:disabled{opacity:.5}.chat-send-btn{background:var(--accent, #d2691e);border:none;border-radius:8px;color:#fff;cursor:pointer;padding:8px 10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;align-self:flex-end;transition:background .15s}.chat-send-btn:hover:not(:disabled){background:var(--accent-dim, #a8531a)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:var(--border, #3d342a);border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:var(--text-muted, #7a6e62)}[data-theme=light] .chat-panel{background:var(--surface, #fffcf5);border-left-color:var(--border, #d4c8b8);box-shadow:-4px 0 20px #00000014}[data-theme=light] .chat-header{background:var(--primary, #e8e0d0);border-bottom-color:var(--border, #d4c8b8)}[data-theme=light] .chat-header-left{color:var(--text, #2a1f14)}[data-theme=light] .chat-icon-btn{color:var(--text-secondary, #5c4a3a)}[data-theme=light] .chat-icon-btn:hover{background:var(--surface-hover, #f0ebe0);color:var(--text, #2a1f14)}[data-theme=light] .chat-message-content{color:var(--text, #2a1f14)}[data-theme=light] .chat-message-user .chat-message-content{background:var(--accent-alpha-08, rgba(184, 92, 30, .08));border-color:var(--accent-alpha-10, rgba(184, 92, 30, .1))}[data-theme=light] .chat-message-assistant .chat-message-content{background:#fff;border-color:var(--border, #d4c8b8)}[data-theme=light] .chat-input-area{background:var(--primary, #e8e0d0);border-top-color:var(--border, #d4c8b8)}[data-theme=light] .chat-input{background:#fff;border-color:var(--border, #d4c8b8);color:var(--text, #2a1f14)}[data-theme=light] .chat-input:focus{border-color:var(--accent, #b85c1e)}[data-theme=light] .chat-empty{color:var(--text-muted, #8a7a6a)}[data-theme=light] .chat-empty-title{color:var(--text-secondary, #5c4a3a)}.chat-panel-bottom{position:relative;top:auto;right:auto;width:100%;height:280px;flex-shrink:0;border-left:none;border-top:1px solid var(--border, #3d342a);box-shadow:0 -2px 10px #00000026;animation:chat-slide-up .2s ease-out}@keyframes chat-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.chat-panel-bottom .chat-messages{flex:1;min-height:0}.chat-panel-bottom .chat-empty{padding:20px}.chat-panel-bottom .chat-empty-icon{display:none}.chat-markdown{white-space:normal}.chat-markdown p{margin:0 0 8px}.chat-markdown p:last-child{margin-bottom:0}.chat-markdown h1,.chat-markdown h2,.chat-markdown h3,.chat-markdown h4{margin:12px 0 6px;font-weight:600;line-height:1.3}.chat-markdown h1{font-size:16px}.chat-markdown h2{font-size:14px}.chat-markdown h3{font-size:13px}.chat-markdown h4{font-size:12px}.chat-markdown ul,.chat-markdown ol{margin:4px 0 8px;padding-left:20px}.chat-markdown li{margin:2px 0}.chat-markdown strong{font-weight:600;color:var(--text-primary, #e0e0e0)}.chat-markdown em{font-style:italic}.chat-markdown code{font-family:Cascadia Code,Fira Code,Consolas,monospace;font-size:12px;background:#00000040;border-radius:3px;padding:1px 5px;color:var(--accent, #d2691e)}.chat-markdown pre{margin:6px 0;padding:10px 12px;background:#0000004d;border-radius:6px;border:1px solid var(--border, #3d342a);overflow-x:auto;font-size:12px;line-height:1.5}.chat-markdown pre code{background:none;padding:0;border-radius:0;color:var(--text, #ede0d0)}.chat-markdown table{border-collapse:collapse;width:100%;margin:6px 0;font-size:12px}.chat-markdown th,.chat-markdown td{border:1px solid var(--border, #3d342a);padding:4px 8px;text-align:left}.chat-markdown th{background:#0003;font-weight:600}.chat-markdown blockquote{margin:6px 0;padding:4px 12px;border-left:3px solid var(--accent, #d2691e);background:var(--accent-alpha-08, rgba(210, 105, 30, .08));color:var(--text-secondary, #b8a898)}.chat-markdown hr{border:none;border-top:1px solid var(--border, #3d342a);margin:10px 0}.chat-markdown a{color:var(--accent, #d2691e);text-decoration:underline}.chat-message-actions{display:flex;gap:2px;margin-top:4px;opacity:0;transition:opacity .15s}.chat-message:hover .chat-message-actions,.chat-message-actions-visible{opacity:1}.chat-action-btn{background:none;border:none;color:var(--text-muted, #7a6e62);cursor:pointer;padding:3px 5px;border-radius:4px;display:flex;align-items:center}.chat-action-btn:hover{background:var(--surface-hover, #352c20);color:var(--text-secondary, #b8a898)}.chat-action-active{color:var(--success, #5a9e3e)!important}.chat-action-active-neg{color:var(--error, #c0392b)!important}.chat-feedback-input{padding:4px 0}.chat-feedback-text{width:100%;padding:6px 10px;border:1px solid var(--border, rgba(255, 255, 255, .15));border-radius:4px;background:var(--bg-secondary, rgba(255, 255, 255, .05));color:var(--text-primary, #e0d6c8);font-size:11px;outline:none}.chat-feedback-text:focus{border-color:var(--accent, #b85c1e)}.chat-feedback-text::placeholder{color:var(--text-muted, rgba(224, 214, 200, .4))}[data-theme=light] .chat-markdown code{background:#0000000f;color:var(--accent, #b85c1e)}[data-theme=light] .chat-markdown pre{background:#f5f0e8;border-color:var(--border, #d4c8b8)}[data-theme=light] .chat-markdown pre code{color:var(--text, #2a1f14)}[data-theme=light] .chat-markdown th{background:#0000000a}[data-theme=light] .chat-markdown th,[data-theme=light] .chat-markdown td{border-color:var(--border, #d4c8b8)}[data-theme=light] .chat-action-btn{color:var(--text-muted, #8a7a6a)}[data-theme=light] .chat-action-btn:hover{background:var(--surface-hover, #f0ebe0);color:#666}.ai-settings-page{display:flex;flex-direction:column;height:100vh;background:#1a1a1a;color:#e0e0e0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.ai-settings-header{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:#222;border-bottom:1px solid #333;flex-shrink:0}.ai-settings-header h1{margin:0;font-size:18px;font-weight:600;color:#fff}.ai-settings-header-actions{display:flex;align-items:center;gap:10px}.ai-settings-status{font-size:13px;color:#8bc34a;margin-right:8px}.ai-settings-warning{padding:8px 24px;background:#4a3000;border-bottom:1px solid #665200;color:#fc0;font-size:13px}.ai-settings-body{display:flex;flex:1;overflow:hidden}.ai-settings-sidebar{width:240px;min-width:200px;background:#1e1e1e;border-right:1px solid #333;display:flex;flex-direction:column;flex-shrink:0}.ai-settings-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #333}.ai-settings-sidebar-header h2{margin:0;font-size:14px;font-weight:600;color:#ccc}.ai-profile-list{list-style:none;margin:0;padding:0;overflow-y:auto;flex:1}.ai-profile-item{padding:10px 16px;cursor:pointer;border-bottom:1px solid #2a2a2a;display:flex;flex-direction:column;gap:2px;transition:background .15s}.ai-profile-item:hover{background:#2a2a2a}.ai-profile-item.selected{background:#333;border-left:3px solid #4fc3f7}.ai-profile-name{font-size:14px;font-weight:500;color:#fff}.ai-profile-provider{font-size:11px;color:#888}.ai-role-badge{display:inline-block;font-size:10px;padding:1px 6px;border-radius:3px;background:#2a4a6a;color:#8bc3f7;margin-top:2px;width:fit-content}.ai-profile-empty{padding:20px 16px;color:#666;font-size:13px;text-align:center}.ai-settings-editor{flex:1;padding:24px 32px;overflow-y:auto}.ai-settings-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;color:#666;font-size:15px}.ai-settings-form{display:flex;flex-direction:column;gap:16px;max-width:560px}.ai-field-group{display:flex;flex-direction:column;gap:4px}.ai-field-group label{font-size:13px;font-weight:500;color:#bbb}.ai-field-group input[type=text],.ai-field-group input[type=url],.ai-field-group input[type=password],.ai-field-group input[type=number],.ai-field-group select{padding:8px 10px;font-size:14px;background:#2a2a2a;border:1px solid #444;border-radius:4px;color:#e0e0e0;outline:none;transition:border-color .15s}.ai-field-group input:focus,.ai-field-group select:focus{border-color:#4fc3f7}.ai-field-group input::placeholder{color:#555}.ai-field-hint{font-size:11px;color:#777}.ai-field-row{flex-direction:row;align-items:center;gap:8px}.ai-field-row label{display:flex;align-items:center;gap:6px;cursor:pointer}.ai-field-row input[type=checkbox]{width:16px;height:16px;accent-color:#4fc3f7}.ai-advanced-section{margin-top:4px;border:1px solid #333;border-radius:4px;padding:0}.ai-advanced-section summary{padding:8px 12px;cursor:pointer;font-size:13px;color:#999;-webkit-user-select:none;user-select:none}.ai-advanced-section summary:hover{color:#ccc}.ai-advanced-section[open]>summary{border-bottom:1px solid #333}.ai-advanced-section .ai-field-group{padding:12px}.ai-settings-actions{display:flex;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid #333}.ai-test-result{display:flex;align-items:center;gap:8px;margin-top:12px;padding:10px 14px;border-radius:4px;font-size:13px}.ai-test-result.success{background:#1b3a1b;border:1px solid #2e6b2e;color:#8bc34a}.ai-test-result.error{background:#3a1b1b;border:1px solid #6b2e2e;color:#f44336}.ai-test-icon{font-size:16px;font-weight:700}.ai-test-latency{margin-left:auto;font-size:11px;color:#888}.ai-role-assignment{margin-top:24px;padding-top:20px;border-top:1px solid #333}.ai-role-assignment h3{margin:0 0 8px;font-size:15px;font-weight:600;color:#ccc}.ai-role-assignment .ai-field-group{margin-top:10px}.btn{padding:7px 16px;font-size:13px;border:1px solid transparent;border-radius:4px;cursor:pointer;font-weight:500;transition:background .15s,border-color .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#1976d2;color:#fff;border-color:#1565c0}.btn-primary:hover:not(:disabled){background:#1565c0}.btn-secondary{background:#333;color:#ccc;border-color:#444}.btn-secondary:hover:not(:disabled){background:#444}.btn-danger{background:#b71c1c;color:#fff;border-color:#9a0007}.btn-danger:hover:not(:disabled){background:#9a0007}.btn-small{padding:3px 10px;font-size:16px;line-height:1;font-weight:700}.btn-add{background:#2a2a2a;color:#4fc3f7;border-color:#444}.btn-add:hover{background:#333}
