*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #3e4444;--bg-surface: #669999;--bg-raised: #b2b2b2;--bg-neutral: #b2b2b2;--border-neutral: #888888;--border: #669900;--border-sub: #5c8a00;--text: #1a1a00;--text-muted: #2a2a00;--text-sub: #3a3a00;--accent: #c8a500;--accent-dim: #c8a50030;--danger: #cc3300;--success: #559922;--radius: 8px;--radius-sm: 4px;--font: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:var(--font);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}.layout{display:flex;flex-direction:column;min-height:100vh}.content{display:flex;flex:1;gap:0}.topbar{display:flex;align-items:center;gap:16px;padding:12px 20px;background:var(--bg-surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.topbar__brand{display:flex;align-items:center;gap:8px;flex-shrink:0}.topbar__logo{font-size:20px}.topbar__title{font-size:16px;font-weight:700;letter-spacing:-.3px;color:var(--text)}.topbar__search{display:flex;align-items:center;flex:1;max-width:600px;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius);padding:0 12px;gap:8px;transition:border-color .15s}.topbar__search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.topbar__search-icon{color:var(--text-sub);font-size:13px}.search-input{flex:1;background:transparent;border:none;outline:none;color:var(--text);font-size:14px;padding:8px 0;font-family:var(--font)}.search-input::placeholder{color:var(--text-sub)}.search-clear{background:none;border:none;color:var(--text-sub);cursor:pointer;font-size:12px;padding:2px 4px;border-radius:3px;line-height:1}.search-clear:hover{color:var(--text);background:var(--bg-raised)}.filters{width:220px;flex-shrink:0;background:var(--bg-surface);border-right:1px solid var(--border);padding:16px;overflow-y:auto;height:calc(100vh - 53px);position:sticky;top:53px}.filters__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.filters__title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted)}.filters__clear{background:none;border:none;color:var(--accent);cursor:pointer;font-size:12px;padding:0}.filters__clear:hover{text-decoration:underline}.filters__section{margin-bottom:20px}.filters__section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--text-sub);margin-bottom:8px}.filter-check-row{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:13px;color:var(--text);background:var(--bg-neutral);border:1px solid var(--border-neutral);border-radius:var(--radius-sm);padding:5px 8px}.cost-row__label input[type=checkbox],.filter-check-row input[type=checkbox]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border:1.5px solid var(--border);border-radius:3px;background:var(--bg-raised);cursor:pointer;flex-shrink:0;transition:background .1s,border-color .1s;position:relative}.cost-row__label input[type=checkbox]:checked,.filter-check-row input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}.cost-row__label input[type=checkbox]:checked:after,.filter-check-row input[type=checkbox]:checked:after{content:"";position:absolute;left:3px;top:1px;width:5px;height:8px;border:2px solid white;border-top:none;border-left:none;transform:rotate(45deg)}.filters__cost-rows{display:flex;flex-direction:column;gap:6px}.cost-row{display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--bg-neutral);border:1px solid var(--border-neutral);border-radius:var(--radius-sm);padding:4px 6px}.cost-row__label{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:13px;color:var(--text);flex:1}.cost-row__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.filter-select{width:100%;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:12px;padding:5px 8px;cursor:pointer;font-family:var(--font);color-scheme:dark}.filter-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim)}.filter-select:disabled{opacity:.35;cursor:not-allowed}.filter-select--cost{width:auto;min-width:52px;flex-shrink:0}.filters__section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.filters__section-header .filters__section-title{margin-bottom:0}.filter-search{width:100%;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:12px;padding:5px 8px;margin-bottom:6px;font-family:var(--font);outline:none}.filter-search:focus{border-color:var(--accent)}.filter-search::placeholder{color:var(--text-sub)}.filters__tags-scroll{display:flex;flex-wrap:wrap;gap:5px;max-height:180px;overflow-y:auto;padding-right:2px}.filters__tags-scroll::-webkit-scrollbar{width:4px}.filters__tags-scroll::-webkit-scrollbar-track{background:transparent}.filters__tags-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.filters__tags-empty{font-size:12px;color:var(--text-sub);font-style:italic}.filters__pills{display:flex;flex-wrap:wrap;gap:5px}.filter-pill{background:#3e4444;border:1px solid #b2b2b2;border-radius:20px;color:#b2b2b2;cursor:pointer;font-size:12px;padding:3px 10px;transition:all .1s;font-family:var(--font)}.filter-pill:hover{border-color:var(--accent);color:var(--accent)}.filter-pill--active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.filter-pill--small{font-size:11px;padding:2px 8px}.results{flex:1;padding:20px;overflow-y:auto}.results__count{font-size:12px;color:var(--text-sub)}.results__toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:4px}.results__toolbar-actions{display:flex;align-items:center;gap:8px}.results__fav-toggle{display:flex;align-items:center;gap:5px;background:none;border:1px solid var(--border-neutral);border-radius:var(--radius-sm);color:var(--text-sub);cursor:pointer;font-family:var(--font);font-size:12px;font-weight:500;padding:4px 10px;transition:color .15s,border-color .15s,background .15s}.results__fav-toggle:hover{color:var(--accent);border-color:var(--accent)}.results__fav-toggle--active{color:var(--accent);border-color:var(--accent);background:#3e4444}.results__owned-toggle{display:flex;align-items:center;gap:5px;background:none;border:1px solid var(--border-neutral);border-radius:var(--radius-sm);color:var(--text-sub);cursor:pointer;font-family:var(--font);font-size:12px;font-weight:500;padding:4px 10px;transition:color .15s,border-color .15s,background .15s}.results__owned-toggle:hover:not(.results__owned-toggle--disabled){color:var(--accent);border-color:var(--accent)}.results__owned-toggle--active{color:var(--accent);border-color:var(--accent);background:#3e4444}.results__owned-toggle--disabled{opacity:.4;cursor:default}.ability-card__train-prereq-badge{font-size:10px;color:var(--accent);font-weight:500}.ability-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.ability-card{background:var(--bg-surface);border:1px solid var(--border-sub);border-radius:var(--radius);padding:14px 16px;display:flex;flex-direction:column;gap:8px;transition:border-color .15s,box-shadow .15s}.ability-card:hover{border-color:var(--border);box-shadow:0 2px 12px #00000040}.ability-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.ability-card__name-group{display:flex;flex-direction:column;gap:3px;min-width:0}.ability-card__name{font-size:14px;font-weight:600;color:var(--text);line-height:1.3}.ability-card__short-desc{font-size:12px;color:var(--text-sub);line-height:1.4}.ability-card__pillars{display:flex;gap:4px;flex-shrink:0}.ability-card__pillar{font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;border:1px solid;white-space:nowrap}.ability-card__meta{display:flex;align-items:center;gap:8px}.ability-card__cost-table{display:flex;flex-direction:column;gap:3px;border-top:1px solid #3e4444;border-bottom:1px solid #3e4444;padding:7px 0}.ability-card__cost-table-head,.ability-card__cost-table-body{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;align-items:center}.ability-card__cost-table-hdr{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-sub);text-align:center}.ability-card__cost-cell{display:flex;align-items:center;justify-content:center;gap:4px;flex-wrap:wrap}.ability-card__cost-or{font-size:9px;color:var(--text-sub);font-style:italic;flex-shrink:0}.ability-card__cost-pillar-group{display:flex;align-items:center;justify-content:center;gap:2px}.ability-card__cost-dash{font-size:13px;color:var(--text-sub);text-align:center;display:block;width:100%}.ability-card__cost{display:inline-flex;align-items:center;justify-content:center;background:#3e4444;border:1.5px solid;border-radius:20px;padding:1px 7px;font-weight:700;min-width:24px}.ability-card__cost-value{font-size:10px;font-variant-numeric:tabular-nums}.ability-card__cost-free{font-size:11px;color:var(--text-sub);font-style:italic;text-align:center;display:block;width:100%}.ability-card__type{font-size:11px;color:var(--text-sub);border:1px solid var(--border-sub);border-radius:3px;padding:1px 6px;text-transform:capitalize}.ability-card__type[data-type=spell]{color:#d4a0f0;border-color:#d4a0f044;background:#d4a0f011}.tag{font-size:11px;background:#3e4444;color:#b2b2b2;border:1px solid #b2b2b2;border-radius:var(--radius-sm);padding:1px 6px}.ability-card--expanded{border-color:var(--border)}.ability-card__toggle{display:flex;align-items:center;gap:5px;background:none;border:none;cursor:pointer;font-family:var(--font);font-size:11px;color:var(--text-sub);padding:2px 0;align-self:flex-start;transition:color .15s}.ability-card__toggle:hover{color:var(--accent)}.ability-card__toggle:hover .ability-card__chevron{border-top-color:var(--accent)}.ability-card__toggle--open{color:var(--accent)}.ability-card__toggle--open .ability-card__chevron{border-top-color:var(--accent);transform:rotate(180deg)}.ability-card__chevron{width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid var(--text-sub);transition:transform .15s,border-top-color .15s;flex-shrink:0}.ability-card__toggle-label{font-weight:600;letter-spacing:.3px}.ability-card__details{display:flex;flex-direction:column;gap:8px;padding-top:8px;border-top:1px solid var(--border-sub)}.ability-card__description{font-size:13px;color:var(--text-muted);line-height:1.5}.ability-card__prereqs{font-size:11px;color:var(--text-sub)}.ability-card__prereqs-label{font-weight:600}.ability-card__tags{display:flex;flex-wrap:wrap;gap:4px}.ability-card__actions{display:flex;gap:6px;padding-top:8px;border-top:1px solid #3e4444}.ability-card__actions--disabled{opacity:.35}.ability-card__action-btn{flex:1;background:#3e4444;border:1px solid var(--border-neutral);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-family:var(--font);font-size:14px;font-weight:600;padding:5px 0;transition:color .15s,border-color .15s,background .15s;line-height:1}.ability-card__action-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.ability-card__action-btn:disabled{cursor:not-allowed;opacity:.4}.ability-card__action-btn--fav-active{color:var(--accent);border-color:var(--accent);background:#3e4444}.ability-card__action-btn--fav-active:hover:not(:disabled){opacity:.8}.ability-card__action-btn--train-open{border-color:var(--accent);color:var(--accent)}.ability-card__train-prompt{display:flex;flex-direction:column;gap:8px;padding:10px 12px;background:#3e4444;border:1px solid var(--border);border-radius:var(--radius-sm)}.ability-card__train-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-sub)}.ability-card__train-options{display:flex;flex-direction:column;gap:5px}.ability-card__train-option{display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--bg-surface);border:1px solid var(--border-neutral);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-family:var(--font);font-size:12px;padding:6px 10px;transition:border-color .15s,color .15s;text-align:left}.ability-card__train-option:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.ability-card__train-option:disabled{opacity:.4;cursor:not-allowed}.ability-card__train-option-name{font-weight:600;flex-shrink:0}.ability-card__train-pills{display:flex;gap:3px;align-items:center}.ability-card__train-free{font-size:12px;color:var(--text-sub);font-style:italic;text-align:center;padding:4px 0}.ability-card__train-cancel{background:none;border:1px solid var(--border-neutral);border-radius:var(--radius-sm);color:var(--text-sub);cursor:pointer;font-family:var(--font);font-size:11px;padding:4px 10px;align-self:flex-end;transition:color .15s,border-color .15s}.ability-card__train-cancel:hover{color:var(--danger);border-color:var(--danger)}.state-message{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 20px;color:var(--text-muted);text-align:center}.state-message--error{color:var(--danger)}.state-message--error p{color:var(--text-muted);font-size:13px}.state-message__hint{font-size:12px;color:var(--text-sub)}.state-message__hint code{background:var(--bg-raised);padding:1px 5px;border-radius:3px;font-family:var(--font-mono)}.state-message__empty{font-size:15px}.spinner{width:28px;height:28px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn-ghost{background:none;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;font-size:13px;padding:6px 14px;font-family:var(--font);transition:border-color .1s,color .1s}.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.char-panel{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-raised);padding:10px;margin-bottom:4px}.char-panel__select{width:100%}.char-panel__empty,.char-panel__none{font-size:12px;color:var(--text-sub);line-height:1.5}.char-panel__link{color:var(--accent);text-decoration:none}.char-panel__link:hover{text-decoration:underline}.char-panel__points{display:flex;flex-direction:column;gap:3px;margin-top:6px;padding:7px 8px;background:var(--bg-surface);border:1px solid var(--border-sub);border-radius:var(--radius-sm)}.char-panel__point-row{display:flex;align-items:baseline;justify-content:space-between;gap:6px}.char-panel__point-label{font-size:11px;font-weight:700;letter-spacing:.2px;flex-shrink:0}.char-panel__point-val{font-size:11px;color:var(--text-muted);font-variant-numeric:tabular-nums;text-align:right}.char-panel__avail{font-weight:700;color:var(--text)}.char-panel__sep,.char-panel__spent{color:var(--text-sub)}.char-panel__afford-check{margin-top:6px}.char-panel__afford-check--disabled{opacity:.4;cursor:not-allowed}.char-panel__afford-check--disabled *{cursor:not-allowed;pointer-events:none}.char-panel__afford-disabled{cursor:not-allowed}.topbar__nav{display:flex;align-items:center;gap:4px;flex-shrink:0}.topbar__nav-link{font-size:13px;font-weight:500;color:var(--text-muted);text-decoration:none;padding:5px 12px;border-radius:var(--radius-sm);border:1px solid transparent;transition:color .15s,border-color .15s,background .15s;white-space:nowrap}.topbar__nav-link:hover{color:var(--accent);border-color:var(--border)}.topbar__nav-link--active{color:var(--accent);border-color:var(--accent);background:#3e4444}.cc-page{flex:1;overflow-y:auto;padding:32px 24px;display:flex;justify-content:center}.cc-form{width:100%;max-width:720px;display:flex;flex-direction:column;gap:24px}.cc-heading{font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.4px}.cc-section{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;display:flex;flex-direction:column;gap:12px}.cc-section--panel{flex:1}.cc-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.7px;color:var(--text-sub);display:flex;align-items:center;gap:10px}.cc-section-title__hint{font-size:10px;font-weight:400;text-transform:none;letter-spacing:0;color:var(--text-sub);opacity:.8}.cc-input{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:15px;font-family:var(--font);padding:9px 12px;width:100%;outline:none;transition:border-color .15s,box-shadow .15s}.cc-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.cc-input::placeholder{color:var(--text-sub)}.cc-budget-group{display:flex;gap:8px;flex-wrap:wrap}.cc-budget-option{display:flex;align-items:center;gap:7px;padding:7px 14px;background:var(--bg-raised);border:1px solid var(--border-neutral);border-radius:var(--radius-sm);cursor:pointer;font-size:13px;color:var(--text-muted);transition:border-color .15s,color .15s,background .15s}.cc-budget-option input[type=radio]{display:none}.cc-budget-option:hover{border-color:var(--accent);color:var(--accent)}.cc-budget-option--active{border-color:var(--accent);background:var(--accent-dim);color:var(--accent);font-weight:600}.cc-budget-badge{font-size:11px;font-weight:500;text-transform:none;letter-spacing:0;color:var(--success);background:#5921;border:1px solid #55992244;border-radius:20px;padding:1px 8px}.cc-budget-badge--over{color:var(--danger);background:#c301;border-color:#c304}.cc-attr-table{display:flex;flex-direction:column;gap:4px}.cc-attr-header{display:grid;grid-template-columns:44px 1fr 1fr 52px 44px;gap:8px;padding:0 6px 4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-sub);border-bottom:1px solid var(--border-sub);align-items:center}.cc-attr-header__racial{display:flex;align-items:center;gap:6px}.cc-racial-counter{font-size:10px;color:var(--text-sub);background:var(--bg-raised);border:1px solid var(--border-neutral);border-radius:20px;padding:0 6px;font-weight:600;letter-spacing:0;text-transform:none}.cc-racial-counter--full{color:var(--accent);border-color:var(--accent);background:var(--accent-dim)}.cc-attr-row{display:grid;grid-template-columns:44px 1fr 1fr 52px 44px;gap:8px;align-items:center;padding:5px 6px;border-radius:var(--radius-sm);background:var(--bg-raised);border:1px solid var(--border-neutral)}.cc-attr-label{font-size:12px;font-weight:700;color:var(--text);letter-spacing:.3px}.cc-attr-total{font-size:14px;font-weight:700;color:var(--text);text-align:center}.cc-attr-cost{font-size:12px;font-weight:600;color:var(--text-sub);text-align:center;font-variant-numeric:tabular-nums}.cc-stepper{display:flex;align-items:center;gap:0;background:var(--bg-surface);border:1px solid var(--border-sub);border-radius:var(--radius-sm);overflow:hidden}.cc-stepper__btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:15px;width:26px;height:26px;display:flex;align-items:center;justify-content:center;transition:color .1s,background .1s;flex-shrink:0;line-height:1;font-family:var(--font)}.cc-stepper__btn:hover:not(:disabled){color:var(--accent);background:var(--accent-dim)}.cc-stepper__btn:disabled{opacity:.3;cursor:not-allowed}.cc-stepper__val{min-width:26px;text-align:center;font-size:13px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.cc-panels{display:flex;gap:16px}.cc-stat-list{display:flex;flex-direction:column;gap:6px}.cc-stat-row{display:flex;align-items:baseline;justify-content:space-between;gap:8px;padding:5px 8px;border-radius:var(--radius-sm);background:var(--bg-raised);border:1px solid var(--border-neutral)}.cc-stat-label{font-size:13px;color:var(--text-muted);display:flex;align-items:baseline;gap:6px}.cc-stat-source{font-size:10px;color:var(--text-sub);font-weight:400}.cc-stat-val{font-size:14px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums;flex-shrink:0}.cc-stat-val--unity{color:var(--accent)}.cc-stat-divider{height:1px;background:var(--border-sub);margin:2px 0}.cc-error{font-size:13px;color:var(--danger);background:#c301;border:1px solid #cc330033;border-radius:var(--radius-sm);padding:8px 12px}.cc-save-btn{background:var(--accent);border:none;border-radius:var(--radius);color:#1a1a00;cursor:pointer;font-size:14px;font-weight:700;font-family:var(--font);padding:11px 28px;align-self:flex-start;transition:opacity .15s,box-shadow .15s;letter-spacing:.2px}.cc-save-btn:hover:not(:disabled){box-shadow:0 2px 12px #c8a50059;opacity:.92}.cc-save-btn:disabled{opacity:.35;cursor:not-allowed}.cp-page{flex:1;overflow-y:auto;padding:32px 24px;display:flex;justify-content:center}.cp-content{width:100%;max-width:760px;display:flex;flex-direction:column;gap:20px}.cp-selector-row{display:flex;align-items:center;gap:10px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px}.cp-selector-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-sub);flex-shrink:0}.cp-selector-select{flex:1}.cp-delete-btn{flex-shrink:0;background:none;border:1px solid var(--border-neutral);border-radius:var(--radius-sm);color:var(--text-sub);cursor:pointer;font-family:var(--font);font-size:12px;font-weight:500;padding:4px 12px;transition:color .15s,border-color .15s}.cp-delete-btn:hover{color:var(--danger);border-color:var(--danger)}.cp-flash{font-size:12px;font-weight:700;color:var(--success);background:#5921;border:1px solid #55992244;border-radius:20px;padding:2px 10px;animation:cp-fade-in .15s ease;flex-shrink:0}@keyframes cp-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.cp-form{display:flex;flex-direction:column;gap:20px}.cp-sheet{display:flex;flex-direction:column;gap:0;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.cp-sheet__header{display:flex;gap:14px;padding:18px 20px 16px;border-bottom:1px solid var(--border-sub);background:var(--bg-surface)}.cp-field{display:flex;flex-direction:column;gap:5px;flex:1}.cp-field__label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-sub);display:flex;align-items:center;gap:6px}.cp-field__hint{font-size:10px;font-weight:400;text-transform:none;letter-spacing:0;color:var(--text-sub);opacity:.8}.cp-tabs{display:flex;border-bottom:1px solid var(--border-sub);background:var(--bg-raised)}.cp-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);cursor:pointer;font-family:var(--font);font-size:13px;font-weight:500;padding:10px 18px;transition:color .15s,border-color .15s;margin-bottom:-1px}.cp-tab:hover{color:var(--accent)}.cp-tab--active{color:var(--accent);border-bottom-color:var(--accent);font-weight:700}.cp-tab-content{padding:18px 20px;display:flex;flex-direction:column;gap:16px}.cp-attr-view{display:flex;flex-direction:column;gap:16px}.cp-attr-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}.cp-attr-cell{display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 6px 8px;background:var(--bg-raised);border:1px solid var(--border-neutral);border-radius:var(--radius-sm)}.cp-attr-cell__name{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--text-sub)}.cp-attr-cell__score{font-size:22px;font-weight:700;color:var(--text);line-height:1;font-variant-numeric:tabular-nums}.cp-attr-cell__mod{font-size:12px;font-weight:600;color:var(--accent);font-variant-numeric:tabular-nums}.cp-ability-section{margin-bottom:20px}.cp-ability-section__title{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;color:var(--accent);padding:0 4px 6px;border-bottom:2px solid var(--accent);margin-bottom:10px}.cp-ability-group{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.cp-ability-group__title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-sub);padding:0 4px 4px;border-bottom:1px solid var(--border-sub);margin-bottom:2px}.cp-ability-row__acq-badge{flex-shrink:0;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#fff;padding:1px 5px;border-radius:3px;line-height:1.4}.cp-ability-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 10px;background:var(--bg-raised);border:1px solid var(--border-neutral);border-radius:var(--radius-sm)}.cp-ability-row__info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.cp-ability-row__name-line{display:flex;align-items:center;gap:6px}.cp-ability-row__pillar-dot{flex-shrink:0;width:8px;height:8px;border-radius:50%}.cp-ability-row__name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cp-ability-row__desc{font-size:11px;color:var(--text-sub);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cp-ability-row__remove{flex-shrink:0;background:none;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-sub);cursor:pointer;font-size:11px;padding:2px 6px;transition:color .15s,border-color .15s}.cp-ability-row__remove:hover{color:var(--danger);border-color:var(--danger)}.cp-ability-row__meta{display:flex;align-items:center;gap:5px}.cp-ability-row__pillar{font-size:10px;font-weight:700;padding:1px 7px;border-radius:20px;border:1.5px solid}.cp-ability-row__weapon{font-size:11px;color:var(--text-sub);background:var(--bg-surface);border:1px solid var(--border-sub);border-radius:var(--radius-sm);padding:1px 6px}.cp-tab-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 20px;border-bottom:1px solid var(--border-sub)}.cp-advance-row{display:flex;align-items:center;gap:10px}.cp-advance-counter{font-size:12px;color:var(--text-sub);font-weight:500}.cp-advance-btn{background:none;border:1px solid var(--border-neutral);border-radius:var(--radius-sm);color:var(--text-sub);cursor:pointer;font-family:var(--font);font-size:12px;font-weight:600;padding:4px 12px;transition:color .15s,border-color .15s,background .15s}.cp-advance-btn:hover{color:var(--accent);border-color:var(--accent)}.cp-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200}.cp-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px 28px;min-width:320px;max-width:440px;width:100%;display:flex;flex-direction:column;gap:14px}.cp-modal__title{font-size:16px;font-weight:700;color:var(--text)}.cp-modal__subtitle{font-size:13px;color:var(--text-sub);margin-top:-8px}.cp-modal__body{display:flex;flex-direction:column;gap:10px}.cp-modal__section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-sub)}.cp-modal__grant-list{list-style:none;display:flex;flex-direction:column;gap:4px}.cp-modal__grant-row{display:flex;align-items:center;justify-content:space-between;padding:4px 8px;background:var(--bg-raised);border-radius:var(--radius-sm)}.cp-modal__grant-name{font-size:13px;color:var(--text)}.cp-modal__grant-val{font-size:14px;font-weight:700}.cp-modal__grant-val--unity{color:var(--accent)}.cp-modal__divider{border:none;border-top:1px solid var(--border-sub);margin:2px 0}.cp-modal__hint{font-size:12px;color:var(--text-sub)}.cp-modal__roll-options{display:flex;gap:8px}.cp-modal__roll-btn,.cp-modal__avg-btn{flex:1;padding:8px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);cursor:pointer;font-family:var(--font);font-size:13px;font-weight:600;transition:background .15s,color .15s,border-color .15s}.cp-modal__roll-btn{background:var(--accent);color:var(--bg);border-color:var(--accent)}.cp-modal__roll-btn:hover{background:#b89200;border-color:#b89200}.cp-modal__avg-btn{background:var(--bg-raised);color:var(--text)}.cp-modal__avg-btn:hover{border-color:var(--accent);color:var(--accent)}.cp-modal__cancel{background:none;border:1px solid var(--border-neutral);border-radius:var(--radius-sm);color:var(--text-sub);cursor:pointer;font-family:var(--font);font-size:12px;padding:6px 14px;align-self:flex-start;transition:color .15s,border-color .15s}.cp-modal__cancel:hover{color:var(--text);border-color:var(--text)}.cp-modal__remove-text{font-size:14px;color:var(--text);line-height:1.5}.cp-modal__refund{color:var(--accent);font-weight:600}.cp-modal__actions{display:flex;gap:8px}.cp-modal__confirm-remove{background:var(--danger);border:1px solid var(--danger);border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-family:var(--font);font-size:13px;font-weight:600;padding:6px 16px;transition:background .15s}.cp-modal__confirm-remove:hover{background:#a20;border-color:#a20}.cp-empty{font-size:14px;color:var(--text-sub);text-align:center;padding:24px 0}.cp-spell-list{display:flex;flex-direction:column;gap:4px}.cp-spell-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 10px;background:var(--bg-raised);border:1px solid var(--border-neutral);border-radius:var(--radius-sm)}.cp-spell-row__info{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.cp-spell-row__name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cp-spell-row__casting-badge{flex-shrink:0;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#fff;background:#00bfff;padding:1px 5px;border-radius:3px;line-height:1.4}.cp-spell-row__level{flex-shrink:0;font-size:11px;color:var(--text-sub);font-variant-numeric:tabular-nums}.cp-notes-textarea{width:100%;min-height:320px;background:var(--surface-2);color:var(--text-main);border:1px solid var(--border);border-radius:6px;padding:12px;font-size:14px;line-height:1.6;resize:vertical;box-sizing:border-box;font-family:inherit}.cp-notes-textarea:focus{outline:none;border-color:var(--accent)}.cp-no-changes{font-size:12px;color:var(--text-sub);align-self:center}.cp-sheet__actions{display:flex;align-items:center;gap:12px;padding:14px 20px;border-top:1px solid var(--border-sub);background:var(--bg-surface)}.cp-hp-section{margin-top:16px}.cp-hp-grid{display:grid;grid-template-columns:60px 68px 16px 68px 68px;align-items:center;gap:6px 0}.cp-hp-header-row{display:contents}.cp-hp-pool-label{font-size:13px;font-weight:600;color:var(--text);padding-right:8px}.cp-hp-col-hdr{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-sub);text-align:center;line-height:1.3;padding-bottom:4px}.cp-hp-col-hdr--temp{color:var(--accent)}.cp-hp-col-hdr__sub{display:block;font-size:9px;font-weight:500;text-transform:none;letter-spacing:0;color:var(--accent);opacity:.75}.cp-hp-row{display:contents}.cp-hp-sep{font-size:18px;font-weight:300;color:var(--text-sub);text-align:center;line-height:1}.cp-hp-field__input{width:100%;background:var(--bg-raised);border:1px solid var(--border-neutral);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);font-size:20px;font-weight:700;padding:6px 4px;text-align:center;-moz-appearance:textfield}.cp-hp-field__input::-webkit-inner-spin-button,.cp-hp-field__input::-webkit-outer-spin-button{-webkit-appearance:none}.cp-hp-field__input:focus{outline:none;border-color:var(--accent)}.cp-hp-field__input--temp{border-color:#c8a50055;color:var(--accent)}.cp-hp-field__input--temp:focus{border-color:var(--accent)}.cp-hp-field__readonly{width:100%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:var(--text-sub);padding:6px 4px}.ref-tabs{display:flex;align-items:center;gap:0;background:var(--bg-surface);border-bottom:2px solid var(--border-sub);padding:0 20px;flex-shrink:0}.ref-tab{background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;color:var(--text-sub);cursor:pointer;font-family:var(--font);font-size:13px;font-weight:600;padding:10px 18px;transition:color .15s,border-color .15s}.ref-tab:hover{color:var(--accent)}.ref-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.special-abilities{display:flex;flex-direction:column;width:100%}.special-tabs{display:flex;align-items:center;border-bottom:1px solid var(--border-sub);padding:0 4px;margin-bottom:4px;flex-shrink:0}.special-tab{background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;color:var(--text-sub);cursor:pointer;font-family:var(--font);font-size:12px;font-weight:600;padding:8px 14px;transition:color .15s,border-color .15s}.special-tab:hover{color:var(--accent)}.special-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.special-content{flex:1}@media (max-width: 700px){.filters{display:none}.topbar{flex-wrap:wrap}.topbar__search{max-width:100%;width:100%}}
