.utilities-panel{gap:var(--space-2);flex-direction:column;display:flex}.utilities-panel .btn{text-align:center;justify-content:center;width:100%}.selector{margin-top:var(--space-6)}.selector__title{margin:0 0 var(--space-3);color:var(--clr-text-primary);font-size:20px;font-weight:600}.selector-grid{gap:var(--space-3);flex-wrap:wrap;max-width:800px;display:flex}.selector-grid--3col{grid-template-columns:repeat(3,1fr);max-width:600px;display:grid}.selector-button{padding:var(--space-3) var(--space-4);border:2px solid var(--clr-border);background:var(--clr-bg-light);cursor:pointer;font:inherit;border-radius:8px;justify-content:center;align-items:center;min-width:120px;transition:border-color .2s,background .2s,transform .1s;display:flex}.selector-button:hover{border-color:var(--clr-primary-border);background:var(--clr-primary-bg);transform:translateY(-2px)}.selector-button:active{transform:translateY(0)}.selector-button--selected{border-color:var(--clr-primary-border);background:var(--clr-primary-bg);border-width:3px}.selector-button--selected:hover{border-color:var(--clr-primary-border);background:var(--clr-primary-bg)}.selector-button__label{color:var(--clr-text-primary);text-align:center;font-size:16px;font-weight:600}.selector-button--selected .selector-button__label{color:var(--clr-primary-border);font-weight:700}.selector-button--stacked{gap:var(--space-1);padding:var(--space-4);flex-direction:column}.selector-button__code{color:var(--clr-text-primary);text-transform:uppercase;letter-spacing:1px;font-size:18px;font-weight:700}.selector-button__sublabel{color:var(--clr-text-muted);text-align:center;font-size:12px;font-weight:500;line-height:1.3}.selector-button--selected .selector-button__code{color:var(--clr-primary-border)}.selector-button--selected .selector-button__sublabel{color:var(--clr-primary-border);font-weight:600}@media (width<=640px){.selector-grid,.selector-grid--3col{gap:var(--space-2)}.selector-grid--3col{grid-template-columns:repeat(3,1fr)}.selector-button{padding:var(--space-2) var(--space-3);min-width:100px}.selector-button--stacked{padding:var(--space-3)}.selector-button__label{font-size:14px}.selector-button__code{font-size:16px}.selector-button__sublabel{font-size:10px}}.character-info-panel{margin-top:var(--space-6);border:2px solid var(--clr-border-strong);border-radius:8px;overflow:hidden}.character-info-panel__header{text-align:left;width:100%;padding:var(--space-3) var(--space-4);cursor:pointer;background:var(--clr-bg-light);color:var(--clr-text-primary);border:0;font-size:18px;font-weight:600;transition:background .2s;display:block}.character-info-panel__header:hover{background:var(--clr-bg)}.character-info-panel__header--open{background:var(--clr-accent-sky-bg);color:var(--clr-accent-sky-text);border-bottom:2px solid var(--clr-border-strong)}.character-info-panel__content{padding:var(--space-4);background:var(--clr-panel-content-bg)}.selector-input{width:100%;max-width:500px;padding:var(--space-3) var(--space-4);border:2px solid var(--clr-border);background:var(--clr-panel-content-bg);font:inherit;border-radius:8px;font-size:16px;font-weight:500;transition:border-color .2s,background .2s}.selector-input:focus{border-color:var(--clr-primary-border);background:var(--clr-primary-bg);box-shadow:0 0 0 2px var(--clr-primary-bg);outline:none}.selector-input::placeholder{color:var(--clr-text-subtle);font-weight:400}.levels-panel{margin-bottom:2rem}.levels-panel h2{margin-bottom:1rem;font-size:1.25rem;font-weight:600}.levels-empty{color:var(--clr-text-muted);margin-bottom:1rem;font-style:italic}.levels-list{flex-direction:column;gap:1rem;margin-bottom:1rem;display:flex}.level-card{background:var(--clr-panel-content-bg);border:1px solid var(--clr-border);border-radius:6px;overflow:hidden}.level-card__header{background:var(--clr-panel-closed-bg);border-bottom:1px solid var(--clr-border);justify-content:space-between;align-items:center;padding:1rem;display:flex}.level-card__info{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.level-card__number{min-width:70px;font-size:1rem;font-weight:600}.level-card__class-select{border:1px solid var(--clr-border-strong);background:var(--clr-bg-light);cursor:pointer;border-radius:4px;min-width:140px;padding:.375rem .5rem;font-size:.9rem}.level-card__class-select:hover{border-color:var(--clr-border-strong)}.level-card__class-select:focus{border-color:var(--clr-primary-border);box-shadow:0 0 0 2px var(--clr-primary-bg);outline:none}.level-card__feat-count{color:var(--clr-accent-sky-text);background:var(--clr-accent-sky-bg);border-radius:12px;padding:.25rem .5rem;font-size:.85rem}.level-card__spell-count{color:var(--clr-accent-purple-text);background:var(--clr-accent-purple-bg);border-radius:12px;padding:.25rem .5rem;font-size:.85rem}.level-card__skill-points{color:var(--clr-accent-green-text);background:var(--clr-accent-green-bg);font-variant-numeric:tabular-nums;border-radius:12px;padding:.25rem .5rem;font-size:.85rem;font-weight:600}.level-card__skill-points--negative{color:var(--clr-danger-border);background:var(--clr-danger-bg)}.level-card__tabs{border:1px solid var(--clr-border-strong);border-radius:6px;gap:0;display:flex;overflow:hidden}.level-card__tab{border:none;border-right:1px solid var(--clr-border-strong);background:var(--clr-panel-content-bg);cursor:pointer;color:var(--clr-text-muted);padding:.4rem .85rem;font-size:.85rem;font-weight:500;transition:background .1s,color .1s}.level-card__tab:last-child{border-right:none}.level-card__tab:hover{background:var(--clr-bg);color:var(--clr-text-primary)}.level-card__tab--active{background:var(--clr-tab-feat);color:var(--clr-panel-open-fg);font-weight:700}.level-card__tab--active:hover{background:var(--clr-tab-feat);color:var(--clr-panel-open-fg)}.level-card__tab--spells.level-card__tab--active,.level-card__tab--spells.level-card__tab--active:hover{background:var(--clr-tab-spell)}.level-card__tab--skills.level-card__tab--active,.level-card__tab--skills.level-card__tab--active:hover{background:var(--clr-tab-skill)}.level-card__feats{background:var(--clr-bg-light);padding:1rem}.level-feats-search{margin-bottom:1rem}.level-feats-search__input{border:1px solid var(--clr-border-strong);border-radius:4px;width:100%;padding:.5rem;font-size:.9rem}.level-feats-search__input:focus{border-color:var(--clr-primary-border);box-shadow:0 0 0 2px var(--clr-primary-bg);outline:none}.level-feats-results{background:var(--clr-panel-content-bg);border:1px solid var(--clr-border);border-radius:4px;max-height:300px;margin-bottom:1rem;overflow-y:auto}.level-feat-result{border-bottom:1px solid var(--clr-border);padding:.75rem}.level-feat-result:last-child{border-bottom:none}.level-feat-result__header{justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.5rem;display:flex}.level-feat-result__name{font-size:.95rem;font-weight:600}.level-feat-result__button{border:1px solid var(--clr-accent-sky);background:var(--clr-accent-sky-bg);cursor:pointer;white-space:nowrap;color:var(--clr-accent-sky-text);border-radius:4px;flex-shrink:0;padding:.25rem .75rem;font-size:.85rem;font-weight:500}.level-feat-result__button:hover:not(:disabled){filter:brightness(.95)}.level-feat-result__button--selected{border-color:var(--clr-accent-green);background:var(--clr-accent-green-bg);color:var(--clr-accent-green-text);cursor:default}.level-feat-result__button:disabled{opacity:.7;cursor:not-allowed}.level-feat-result__prereq{color:var(--clr-text-muted);margin-bottom:.5rem;font-size:.85rem;font-style:italic}.level-feat-result__description{color:var(--clr-text-primary);font-size:.9rem;line-height:1.4}.level-feats-selected{background:var(--clr-panel-content-bg);border:1px solid var(--clr-border);border-radius:4px;margin-bottom:1rem;padding:.75rem}.level-feats-selected__header{color:var(--clr-text-primary);margin-bottom:.5rem;font-size:.9rem;font-weight:600}.level-feats-selected__list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.level-feat-selected{background:var(--clr-panel-closed-bg);border-radius:4px;justify-content:space-between;align-items:center;padding:.5rem;display:flex}.level-feat-selected__name{font-size:.9rem;font-weight:500}.level-feat-selected__remove{background:var(--clr-danger-border);color:var(--clr-panel-open-fg);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:1.2rem;line-height:1;display:flex}.level-feat-selected__remove:hover{filter:brightness(.85)}.level-feats-empty{color:var(--clr-text-muted);text-align:center;padding:1rem;font-style:italic}.level-card__spells{background:var(--clr-accent-purple-bg);padding:1rem}.level-spells-search{margin-bottom:1rem}.level-spells-search__input{border:1px solid var(--clr-border-strong);border-radius:4px;width:100%;padding:.5rem;font-size:.9rem}.level-spells-search__input:focus{border-color:var(--clr-accent-purple);box-shadow:0 0 0 2px var(--clr-accent-purple-bg);outline:none}.level-spells-results{background:var(--clr-panel-content-bg);border:1px solid var(--clr-border);border-radius:4px;max-height:300px;margin-bottom:1rem;overflow-y:auto}.level-spell-result{border-bottom:1px solid var(--clr-border);padding:.75rem}.level-spell-result:last-child{border-bottom:none}.level-spell-result__header{justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.5rem;display:flex}.level-spell-result__name{font-size:.95rem;font-weight:600}.level-spell-result__button{border:1px solid var(--clr-accent-purple);background:var(--clr-accent-purple-bg);cursor:pointer;white-space:nowrap;color:var(--clr-accent-purple-text);border-radius:4px;flex-shrink:0;padding:.25rem .75rem;font-size:.85rem;font-weight:500}.level-spell-result__button:hover:not(:disabled){filter:brightness(.95)}.level-spell-result__button--selected{border-color:var(--clr-accent-green);background:var(--clr-accent-green-bg);color:var(--clr-accent-green-text);cursor:default}.level-spell-result__button:disabled{opacity:.7;cursor:not-allowed}.level-spell-result__meta{color:var(--clr-accent-purple-text);margin-bottom:.5rem;font-size:.85rem}.level-spell-result__description{color:var(--clr-text-primary);font-size:.9rem;line-height:1.4}.level-spells-selected{background:var(--clr-panel-content-bg);border:1px solid var(--clr-border);border-radius:4px;margin-bottom:1rem;padding:.75rem}.level-spells-selected__header{color:var(--clr-text-primary);margin-bottom:.5rem;font-size:.9rem;font-weight:600}.level-spells-selected__list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.level-spell-selected{background:var(--clr-accent-purple-bg);border-radius:4px;justify-content:space-between;align-items:center;padding:.5rem;display:flex}.level-spell-selected__name{font-size:.9rem;font-weight:500}.level-spell-selected__remove{background:var(--clr-danger-border);color:var(--clr-panel-open-fg);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:1.2rem;line-height:1;display:flex}.level-spell-selected__remove:hover{filter:brightness(.85)}.level-spells-empty{color:var(--clr-text-muted);text-align:center;padding:1rem;font-style:italic}.level-card__skills{background:var(--clr-bg-light);border-top:1px solid var(--clr-border);padding:1rem}.skill-spending-panel{flex-direction:column;gap:1rem;display:flex}.skill-spending-warning{background:var(--clr-danger-bg);border:1px solid var(--clr-danger-border);color:var(--clr-danger-border);border-radius:6px;padding:.75rem;font-size:.9rem;font-weight:500}.skill-spending-list{flex-direction:column;gap:1rem;display:flex}.skill-spending-group{background:var(--clr-panel-content-bg);border:1px solid var(--clr-border-strong);border-radius:6px;overflow:hidden}.skill-spending-group__header{background:var(--clr-panel-closed-bg);color:var(--clr-panel-closed-fg);border-bottom:1px solid var(--clr-border-strong);padding:.5rem .75rem;font-size:.9rem;font-weight:600}.skill-spending-group__header--collapsible{text-align:left;cursor:pointer;border:none;width:100%;transition:background .15s}.skill-spending-group__header--collapsible:hover{background:var(--clr-border)}.skill-spending-group__skills{flex-direction:column;display:flex}.skill-spending-item{border-bottom:1px solid var(--clr-border);padding:.75rem}.skill-spending-item:last-child{border-bottom:none}.skill-spending-item--class{background:var(--clr-accent-green-bg)}.skill-spending-item--cross-class{background:var(--clr-accent-amber-bg)}.skill-spending-item__header{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.skill-spending-item__name{color:var(--clr-text-primary);flex:1;align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;display:flex}.skill-spending-item__ability{color:var(--clr-text-muted);text-transform:uppercase;font-size:.75rem;font-weight:600}.skill-spending-item__badge--trained{background:var(--clr-accent-amber);color:var(--clr-panel-open-fg);text-transform:uppercase;letter-spacing:.025em;border-radius:10px;padding:.125rem .375rem;font-size:.7rem;font-weight:600;display:inline-block}.skill-spending-item__controls{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.skill-spending-item__button{border:1px solid var(--clr-border-strong);background:var(--clr-bg-light);width:32px;height:32px;color:var(--clr-text-primary);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;font-size:1.25rem;font-weight:600;transition:all .15s;display:flex}.skill-spending-item__button:hover:not(:disabled){background:var(--clr-panel-closed-bg);border-color:var(--clr-border-strong)}.skill-spending-item__button:disabled{opacity:.4;cursor:not-allowed}.skill-spending-item__ranks{color:var(--clr-text-primary);text-align:center;min-width:24px;font-size:.95rem;font-weight:600}.levels-actions{flex-wrap:wrap;gap:.5rem;display:flex}.levels-actions .btn{flex:0 auto}.save-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.save-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}@media (width<=640px){.saves-grid{grid-template-columns:1fr}}.combat-stat-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.combat-stat-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}@media (width<=640px){.combat-stats__grid{grid-template-columns:1fr}.combat-stat-display{font-size:28px}.combat-stat-input--centered{font-size:20px}}@media (width<=640px){.skill-item__name{font-size:.85rem}.skill-item__calculation{flex-direction:column;align-items:flex-end;gap:.25rem}.skill-item__breakdown{font-size:.7rem}}.combat-tracker{flex-wrap:wrap;align-items:center;gap:12px;padding:6px 4px;display:flex}.combat-tracker--active{background:var(--clr-accent-amber-bg);border:1px solid var(--clr-accent-amber-border);border-radius:6px;padding:8px 12px}.combat-tracker__sword{flex-shrink:0;font-size:16px}.combat-tracker__block{flex-direction:column;align-items:center;gap:2px;display:flex}.combat-tracker__label{text-transform:uppercase;letter-spacing:.05em;color:var(--clr-accent-amber-text);font-size:10px;font-weight:700}.combat-tracker__round-controls{align-items:center;gap:4px;display:flex}.combat-tracker__round{font-variant-numeric:tabular-nums;font-size:18px;font-weight:700;font-family:var(--font-mono,monospace);text-align:center;min-width:2ch;color:var(--clr-accent-amber-text)}.combat-tracker__round-btn{border:1px solid var(--clr-accent-amber-border);width:22px;height:22px;color:var(--clr-accent-amber-text);cursor:pointer;background:0 0;border-radius:4px;justify-content:center;align-items:center;padding:0;font-size:13px;display:flex}.combat-tracker__round-btn:hover:not(:disabled){background:var(--clr-accent-amber-border)}.combat-tracker__round-btn:disabled{opacity:.35;cursor:not-allowed}.combat-tracker__init-input{border:1px solid var(--clr-accent-amber-border);width:56px;font:inherit;text-align:center;color:var(--clr-accent-amber-text);background:0 0;border-radius:4px;padding:3px 6px;font-size:15px;font-weight:700}.combat-tracker__init-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.combat-tracker__init-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.combat-tracker__init-input[type=number]{-moz-appearance:textfield}.combat-tracker__start-btn{border:1px solid var(--clr-border-strong);color:var(--clr-text-muted);cursor:pointer;background:0 0;border-radius:6px;padding:5px 12px;font-size:13px;font-weight:600}.combat-tracker__start-btn:hover{background:var(--clr-panel-closed-bg);color:var(--clr-text-primary)}.combat-tracker__end-btn{border:1px solid var(--clr-danger-border);color:var(--clr-danger-border);background:0 0;margin-left:auto}.combat-tracker__end-btn:hover{background:var(--clr-danger-bg)}.tag-list{flex-wrap:wrap;gap:6px;display:flex}.tag{border:1px solid var(--clr-border-strong);background:var(--clr-primary-bg);border-radius:999px;align-items:center;gap:4px;padding:3px 8px;font-size:13px;display:inline-flex}.tag--removable{padding-right:4px}.tag__remove{width:18px;height:18px;color:var(--clr-text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:16px;line-height:1;display:inline-flex}.tag__remove:hover{background:var(--clr-danger-bg);color:var(--clr-danger-border)}.panel-body{padding:4px 0}.hp-tracker{flex-direction:column;gap:12px;display:flex}.hp-display{align-items:center;gap:8px;display:flex}.hp-display__current{font-variant-numeric:tabular-nums;text-align:center;border:2px solid var(--clr-border-strong);background:var(--clr-bg-light);cursor:pointer;border-radius:8px;min-width:64px;padding:4px 8px;font-size:36px;font-weight:700;line-height:1.1;transition:border-color .15s}.hp-display__current:hover{border-color:var(--clr-primary-border)}.hp-display--bloodied .hp-display__current{border-color:var(--clr-hp-bloodied-border);color:var(--clr-hp-bloodied-text);background:#f973161a}.hp-display--dying .hp-display__current{border-color:var(--clr-danger-border);background:var(--clr-danger-bg);color:var(--clr-danger-border)}.hp-display__separator{color:var(--clr-text-subtle);font-size:28px;font-weight:300}.hp-display__max{text-align:center;border:1px solid var(--clr-border-strong);border-radius:6px;width:72px;padding:4px;font-size:24px;font-weight:600}.hp-display__status{letter-spacing:.5px;background:var(--clr-danger-bg);color:var(--clr-danger-border);border:1px solid var(--clr-danger-border);border-radius:4px;padding:2px 6px;font-size:11px;font-weight:700}.hp-display--bloodied .hp-display__status{color:var(--clr-hp-bloodied-text);border-color:var(--clr-hp-bloodied-border);background:#f973161a}.hp-display--dead .hp-display__current{border-color:var(--clr-hp-dead-border);background:var(--clr-hp-dead-bg);color:var(--clr-hp-dead-text)}.hp-display__status--dead{background:var(--clr-hp-dead-border);color:var(--clr-panel-open-fg);border-color:var(--clr-hp-dead-border)}.hp-display__status--stable{background:var(--clr-accent-green-bg);color:var(--clr-accent-green-text);border-color:var(--clr-accent-green-border)}.hp-tracker__stable-row{margin-top:6px}.hp-tracker__temp{color:var(--clr-hp-temp);font-size:13px;font-weight:600}.hp-tracker__controls{align-items:center;gap:8px;display:flex}.hp-tracker__delta{border:1px solid var(--clr-border-strong);width:80px;font:inherit;text-align:center;border-radius:6px;padding:6px 8px;font-size:16px}.hp-tracker__meta{flex-direction:column;gap:6px;display:flex}.hp-tracker__meta-row{align-items:center;gap:8px;display:flex}.hp-tracker__meta-label{color:var(--clr-text-muted);min-width:60px;font-size:13px}.spell-slots{flex-direction:column;gap:4px;display:flex}.spell-slots__auto-bar{background:var(--clr-bg);border:1px solid var(--clr-border);border-radius:4px;justify-content:space-between;align-items:center;gap:8px;padding:4px 6px;display:flex}.spell-slots__auto-hint{color:var(--clr-text-muted);font-size:11px}.spell-slots__header{text-transform:uppercase;letter-spacing:.4px;color:var(--clr-text-muted);border-bottom:1px solid var(--clr-border);grid-template-columns:100px 50px 50px 80px 1fr;align-items:center;gap:8px;padding:4px 6px;font-size:11px;font-weight:700;display:grid}.spell-slots__header--with-dc{grid-template-columns:100px 36px 50px 50px 80px 1fr}.spell-slots__col-label{white-space:nowrap}.spell-slots__row{border-radius:4px;grid-template-columns:100px 50px 50px 80px 1fr;align-items:center;gap:8px;padding:4px 6px;display:grid}.spell-slots__row--with-dc{grid-template-columns:100px 36px 50px 50px 80px 1fr}.spell-slots__calc-hint{color:var(--clr-accent);cursor:pointer;opacity:.8;margin-left:4px;font-size:11px}.spell-slots__calc-hint:hover{opacity:1;text-decoration:underline}.spell-slots__dc{font-variant-numeric:tabular-nums;text-align:center;color:var(--clr-text-muted);font-size:13px}.spell-slots__row:hover{background:var(--clr-bg)}.spell-slots__row--exhausted{opacity:.6}.spell-slots__level{font-size:14px;font-weight:600}.spell-slots__input{border:1px solid var(--clr-border-strong);width:48px;font:inherit;text-align:center;border-radius:4px;padding:3px 6px;font-size:14px}.spell-slots__used,.spell-slots__remaining{font-variant-numeric:tabular-nums;text-align:center;font-size:14px}.spell-slots__actions{gap:4px;display:flex}.spell-slots__footer{border-top:1px solid var(--clr-border);margin-top:4px;padding:8px 6px 4px}.memorized-spells{flex-direction:column;gap:12px;display:flex}.memorized-spells__level{flex-direction:column;gap:4px;display:flex}.memorized-spells__level-header{border-bottom:1px solid var(--clr-border);justify-content:space-between;align-items:center;padding-bottom:2px;display:flex}.memorized-spells__level-label{text-transform:uppercase;letter-spacing:.4px;color:var(--clr-text-muted);font-size:12px;font-weight:700}.memorized-spells__list{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.memorized-spells__item{background:var(--clr-bg);border-radius:4px;justify-content:space-between;align-items:center;padding:3px 6px;display:flex}.memorized-spells__spell-name{font-size:13px}.memorized-spells__remove{opacity:0;color:var(--clr-danger);padding:0 4px;transition:opacity .1s}.memorized-spells__item:hover .memorized-spells__remove{opacity:1}.memorized-spells__add{gap:6px;margin-top:2px;display:flex}.memorized-spells__input{border:1px solid var(--clr-border-strong);font:inherit;background:var(--clr-surface);color:var(--clr-text);border-radius:4px;flex:1;padding:3px 8px;font-size:13px}.resource-tracker{flex-direction:column;gap:8px;display:flex}.resource-row{border:1px solid var(--clr-border-strong);background:var(--clr-bg-light);border-radius:6px;flex-direction:column;gap:6px;padding:8px;display:flex}.resource-row--exhausted{border-color:var(--clr-danger-border);background:var(--clr-danger-bg);opacity:.7}.resource-row__info{justify-content:space-between;align-items:baseline;display:flex}.resource-row__name{font-size:15px;font-weight:600}.resource-row__count{font-variant-numeric:tabular-nums;color:var(--clr-text-muted);font-size:13px}.resource-row__pips{flex-wrap:wrap;gap:4px;display:flex}.resource-pip{border:2px solid var(--clr-border-strong);border-radius:50%;width:14px;height:14px;display:inline-block}.resource-pip--available{background:var(--clr-primary-border);border-color:var(--clr-primary-border)}.resource-pip--used{background:var(--clr-panel-closed-bg);border-color:var(--clr-border-strong)}.resource-row__actions{flex-wrap:wrap;gap:4px;display:flex}.resource-tracker__reset-all{border-top:1px solid var(--clr-border);padding-top:4px}.resource-add{border:1px dashed var(--clr-border-strong);border-radius:6px;align-items:center;gap:6px;padding:8px;display:flex}.resource-add__name{border:1px solid var(--clr-border-strong);font:inherit;border-radius:4px;flex:1;padding:6px 8px;font-size:14px}.resource-add__max{border:1px solid var(--clr-border-strong);width:64px;font:inherit;text-align:center;border-radius:4px;padding:6px 8px;font-size:14px}.taint-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.taint-tracker{border:1px solid var(--clr-border-strong);background:var(--clr-bg-light);border-radius:6px;flex-direction:column;gap:6px;padding:10px;display:flex}.taint-tracker__header{justify-content:space-between;align-items:center;display:flex}.taint-tracker__label{font-size:14px;font-weight:700}.taint-tracker__controls{align-items:center;gap:4px;display:flex}.taint-tracker__input{border:1px solid var(--clr-border-strong);width:48px;font:inherit;text-align:center;border-radius:4px;padding:3px 4px;font-size:18px;font-weight:700}.taint-tracker__effect{color:var(--clr-text-muted);font-size:12px;line-height:1.4}.taint-tracker__effect-label{color:var(--clr-text-primary);font-weight:700}.notes-textarea{border:1px solid var(--clr-border-strong);width:100%;font:inherit;resize:vertical;background:var(--clr-bg-light);color:var(--clr-text-primary);box-sizing:border-box;border-radius:6px;padding:8px 10px;font-size:14px;line-height:1.5}.notes-textarea:focus{border-color:var(--clr-primary-border);box-shadow:0 0 0 2px var(--clr-primary-bg);outline:none}.notes-readonly{border:1px solid var(--clr-border);background:var(--clr-bg-light);white-space:pre-wrap;min-height:3rem;color:var(--clr-text-primary);border-radius:6px;padding:8px 10px;font-size:14px;line-height:1.6}.overview-readonly__value{color:var(--clr-text-primary);padding:8px 10px;font-size:1rem;font-weight:500}.taint-tracker__value{text-align:center;min-width:2rem;color:var(--clr-text-primary);font-size:1.25rem;font-weight:700}.play-sheet{gap:var(--space-4);padding:var(--space-2);flex-direction:column;display:flex}.play-sheet__identity{align-items:baseline;gap:var(--space-3);padding-bottom:var(--space-2);border-bottom:2px solid var(--clr-border-strong);flex-wrap:wrap;display:flex}.play-sheet__name{color:var(--clr-text-primary);font-size:1.5rem;font-weight:700}.play-sheet__identity-detail{color:var(--clr-text-muted);font-size:.9rem;font-weight:500}.play-sheet__xp{align-items:center;gap:var(--space-2);font-size:.875rem;display:flex}.play-sheet__xp-label{text-transform:uppercase;letter-spacing:.05em;color:var(--clr-text-muted);min-width:2rem;font-size:.75rem;font-weight:700}.play-sheet__xp-input{border:1px solid var(--clr-border-strong);font-variant-numeric:tabular-nums;width:7rem;color:var(--clr-text-primary);background:var(--clr-bg-light);border-radius:4px;padding:3px 6px;font-size:.875rem}.play-sheet__xp-threshold{color:var(--clr-text-muted);font-size:.8rem}.play-sheet__currency{gap:var(--space-3);flex-wrap:wrap;display:flex}.play-sheet__coin{flex-direction:column;align-items:center;gap:2px;display:flex}.play-sheet__coin-label{text-transform:uppercase;letter-spacing:.05em;color:var(--clr-text-muted);font-size:.65rem;font-weight:700}.play-sheet__coin-input{border:1px solid var(--clr-border-strong);font-variant-numeric:tabular-nums;text-align:center;width:5rem;color:var(--clr-text-primary);background:var(--clr-bg-light);border-radius:4px;padding:3px 6px;font-size:.875rem}.play-sheet__stats-row{gap:var(--space-3);flex-wrap:wrap;display:flex}.play-sheet__stat{padding:var(--space-2) var(--space-3);background:var(--clr-bg-light);border:1px solid var(--clr-border-strong);cursor:help;border-radius:8px;flex-direction:column;align-items:center;min-width:4.5rem;transition:background .1s;display:flex}.play-sheet__stat:hover{background:var(--clr-primary-bg)}.play-sheet__stat-label{text-transform:uppercase;letter-spacing:.05em;color:var(--clr-text-muted);font-size:.7rem;font-weight:700}.play-sheet__stat-value{font-variant-numeric:tabular-nums;color:var(--clr-text-primary);font-size:1.4rem;font-weight:700;line-height:1.2}.play-sheet__stat--wide{min-width:7rem}.play-sheet__stat-value--movement{font-size:1rem;font-weight:600}.play-sheet__section{border:1px solid var(--clr-border);border-radius:8px;overflow:hidden}.play-sheet__section-label{background:var(--clr-panel-closed-bg);color:var(--clr-panel-closed-fg);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--clr-border);padding:.5rem .75rem;font-size:.85rem;font-weight:600}.play-sheet__section>:not(.play-sheet__section-label){padding:var(--space-3)}.browser__list--compact .browser__item{padding:4px 6px}.browser__item-name--btn{font:inherit;cursor:pointer;text-align:left;color:inherit;background:0 0;border:none;flex:1;padding:0;font-weight:600}.browser__item-name--btn:hover{text-decoration:underline}.status-effects{flex-direction:column;gap:8px;display:flex}.status-effects__list{flex-direction:column;gap:2px;display:flex}.status-effect-row{border:1px solid #0000;border-radius:5px;align-items:center;gap:8px;padding:5px 8px;transition:background .1s;display:flex}.status-effect-row:hover{background:var(--clr-bg)}.status-effect-row--active{background:var(--clr-accent-amber-bg);border-color:var(--clr-accent-amber-border)}.status-effect-row--active:hover{background:var(--clr-accent-amber-bg);filter:brightness(.95)}.status-effect-row__label{cursor:pointer;align-items:center;gap:6px;display:flex}.status-effect-row__check{cursor:pointer;width:15px;height:15px;accent-color:var(--clr-accent-amber)}.status-effect-row__name{font-size:14px;font-weight:500}.status-effect-row--active .status-effect-row__name{color:var(--clr-accent-amber-text);font-weight:700}.status-effect-row__rounds{align-items:center;gap:3px;display:flex}.status-effect-row__rounds-input{border:1px solid var(--clr-accent-amber-border);width:44px;font:inherit;text-align:center;background:var(--clr-accent-amber-bg);border-radius:4px;padding:2px 4px;font-size:13px}.status-effect-row__rounds-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.status-effect-row__rounds-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.status-effect-row__rounds-input[type=number]{-moz-appearance:textfield}.status-effect-row__rounds-label{color:var(--clr-accent-amber-text);font-size:11px;font-weight:600}.status-effects__footer{border-top:1px solid var(--clr-border);padding-top:6px}.ability-damage{flex-direction:column;gap:2px;display:flex}.ability-damage__header{text-transform:uppercase;letter-spacing:.04em;color:var(--clr-text-muted);border-bottom:1px solid var(--clr-border);grid-template-columns:3rem 3rem 4rem 3rem;gap:8px;padding:4px 8px;font-size:11px;font-weight:700;display:grid}.ability-damage__col--center{text-align:center}.ability-damage__row{border-radius:4px;grid-template-columns:3rem 3rem 4rem 3rem;align-items:center;gap:8px;padding:4px 8px;display:grid}.ability-damage__row:hover{background:var(--clr-bg)}.ability-damage__row--damaged{background:#f9731626}.ability-damage__row--damaged:hover{background:#f9731638}.ability-damage__ability{color:var(--clr-text-primary);font-size:13px;font-weight:700}.ability-damage__base{text-align:center;font-variant-numeric:tabular-nums;color:var(--clr-text-primary);font-size:14px}.ability-damage__input{border:1px solid var(--clr-border-strong);width:100%;font:inherit;text-align:center;background:var(--clr-bg-light);border-radius:4px;padding:3px 4px;font-size:14px}.ability-damage__input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.ability-damage__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.ability-damage__input[type=number]{-moz-appearance:textfield}.ability-damage__effective{text-align:center;font-variant-numeric:tabular-nums;color:var(--clr-text-primary);font-size:15px;font-weight:700}.ability-damage__effective--reduced{color:var(--clr-hp-bloodied-text)}.equipment{flex-direction:column;gap:8px;display:flex}.equipment__list{flex-direction:column;gap:4px;display:flex}.equipment-item{border:1px solid var(--clr-border-strong);background:var(--clr-bg-light);border-radius:6px;overflow:hidden}.equipment-item--equipped{background:var(--clr-accent-green-bg);border-color:var(--clr-accent-green-border)}.equipment-item__row{align-items:center;gap:6px;padding:6px 8px;display:flex}.equipment-item__equipped-label{cursor:pointer;align-items:center;display:flex}.equipment-item__equipped-label input[type=checkbox]{width:15px;height:15px;accent-color:var(--clr-accent-green);cursor:pointer}.equipment-item__name{cursor:pointer;flex:1;font-size:14px;font-weight:500}.equipment-item--equipped .equipment-item__name{color:var(--clr-accent-green-text);font-weight:600}.equipment-item__notes{border:none;border-top:1px solid var(--clr-border);width:100%;font:inherit;background:var(--clr-bg);box-sizing:border-box;padding:4px 8px;font-size:13px}.equipment-item__notes:focus{background:var(--clr-bg-light);outline:none}.equipment__add{align-items:center;gap:6px;display:flex}.equipment__add-input{border:1px solid var(--clr-border-strong);font:inherit;border-radius:6px;flex:1;padding:6px 8px;font-size:14px}.equipment__add-weight{border:1px solid var(--clr-border-strong);width:56px;font:inherit;text-align:right;border-radius:6px;padding:6px 4px;font-size:14px}.equipment-item__weight{border:1px solid var(--clr-border);width:52px;font:inherit;text-align:right;background:0 0;border-radius:4px;padding:2px 4px;font-size:13px}.equipment-item__weight-unit{color:var(--clr-text-muted,#888);margin-right:4px;font-size:12px}.equipment__load{flex-wrap:wrap;align-items:baseline;gap:8px;padding:6px 4px 2px;font-size:13px;display:flex}.equipment__load-total{font-weight:600}.equipment__load-status{background:var(--clr-accent-green-bg);color:var(--clr-accent-green-text);border-radius:10px;padding:1px 6px;font-size:12px;font-weight:600}.equipment__load--medium .equipment__load-status{background:var(--clr-accent-amber-bg);color:var(--clr-accent-amber-text)}.equipment__load--heavy .equipment__load-status{background:var(--clr-danger-bg);color:var(--clr-danger-border)}.equipment__load--overloaded .equipment__load-status{background:var(--clr-load-overloaded-bg);color:var(--clr-panel-open-fg)}.equipment__load-limits{color:var(--clr-text-muted,#888);margin-left:auto;font-size:12px}.weapons{flex-direction:column;gap:6px;display:flex}.weapons__empty{color:var(--clr-text-muted,#888);margin:0;font-size:13px}.weapons__add-area{margin-top:4px}.weapon-card{border:1px solid var(--clr-border-strong);border-radius:6px;padding:8px 10px}.weapon-card__header{align-items:center;gap:6px;margin-bottom:4px;display:flex}.weapon-card__name{flex:1;font-size:14px;font-weight:600}.weapon-card__type{color:var(--clr-text-muted,#888);text-transform:capitalize;border:1px solid var(--clr-border);border-radius:8px;padding:1px 5px;font-size:11px}.weapon-card__actions{gap:4px;margin-left:auto;display:flex}.weapon-card__stats{align-items:baseline;gap:10px;font-size:14px;display:flex}.weapon-card__attack-line{font-size:15px;font-weight:700;font-family:var(--font-mono,monospace);cursor:help}.weapon-card__damage{color:var(--clr-text-primary)}.weapon-card__crit{color:var(--clr-text-muted,#888);margin-left:auto;font-size:12px}.weapon-card__range{color:var(--clr-text-muted,#888);font-size:12px}.weapon-card--editing{background:var(--clr-panel-content-bg);flex-direction:column;gap:8px;display:flex}.weapon-card__edit-row{flex-wrap:wrap;align-items:flex-end;gap:8px;display:flex}.weapon-card__edit-label{color:var(--clr-text-muted,#888);text-transform:uppercase;letter-spacing:.03em;flex-direction:column;gap:2px;font-size:11px;font-weight:600;display:flex}.weapon-card__edit-input{border:1px solid var(--clr-border-strong);font:inherit;border-radius:4px;padding:4px 6px;font-size:13px}.weapon-card__edit-name{flex:1;min-width:120px}.weapon-card__edit-damage{width:64px}.weapon-card__edit-num{text-align:right;width:52px}.weapon-card__edit-dmgtype{width:100px}.weapon-card__edit-select{border:1px solid var(--clr-border-strong);font:inherit;border-radius:4px;padding:4px 6px;font-size:13px}.weapon-card__edit-actions{gap:8px;display:flex}.btn--xs{padding:1px 5px;font-size:12px}.btn--ghost{color:var(--clr-text-muted);background:0 0;border:1px solid #0000}.btn--ghost:hover{background:var(--clr-panel-closed-bg);border-color:var(--clr-border-strong)}.btn--danger-ghost{color:var(--clr-danger-border);background:0 0;border:1px solid #0000}.btn--danger-ghost:hover{background:var(--clr-danger-bg);border-color:var(--clr-danger-border)}.app-content{flex-direction:column;height:100vh;display:flex;overflow:hidden}.app-header{border-bottom:1px dashed var(--clr-border);flex-shrink:0;padding:10px 16px 0}.app-header__row{align-items:center;gap:12px;margin-bottom:10px;display:flex}.app-header__controls{flex-shrink:0;align-items:center;gap:6px;display:flex}.app-header__theme-btn{border:1px solid var(--clr-border-strong);color:var(--clr-text-primary);font:inherit;cursor:pointer;background:0 0;border-radius:6px;padding:5px 8px;font-size:14px;line-height:1}.app-header__theme-btn:hover{background:var(--clr-panel-closed-bg)}.app-header__mode-btn{border:1px solid var(--clr-border-strong);color:var(--clr-text-primary);font:inherit;cursor:pointer;letter-spacing:.3px;white-space:nowrap;background:0 0;border-radius:6px;padding:5px 14px;font-size:12px;font-weight:700}.app-header__mode-btn:hover{background:var(--clr-panel-closed-bg)}.app-title{margin:0;font-size:22px;line-height:1.2}.app-main{flex:1;padding:12px 16px 24px;overflow-y:auto}.tab-content{flex-direction:column;gap:0;display:flex}.sticky-bar{background:var(--clr-text-secondary);color:var(--clr-bg-light);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:6px;padding:6px 16px;display:flex}.sticky-bar__name{text-overflow:ellipsis;white-space:nowrap;max-width:140px;color:var(--clr-panel-open-fg);margin-right:4px;font-size:14px;font-weight:700;overflow:hidden}.sticky-stat{cursor:default;background:#ffffff12;border-radius:4px;flex-direction:column;align-items:center;min-width:42px;padding:2px 8px;display:flex}.sticky-stat--hp{min-width:72px}.sticky-stat--bloodied{border:1px solid var(--clr-hp-bloodied-border);background:#f9731633}.sticky-stat--dying{border:1px solid var(--clr-danger-border);background:#ef444440;animation:1.5s ease-in-out infinite pulse-dying}@keyframes pulse-dying{0%,to{opacity:1}50%{opacity:.6}}.sticky-stat__label{text-transform:uppercase;letter-spacing:.5px;color:var(--clr-text-subtle);font-size:9px;font-weight:700;line-height:1}.sticky-stat__value{font-variant-numeric:tabular-nums;color:var(--clr-bg-light);font-size:15px;font-weight:700;line-height:1.2}.sticky-stat__sep{color:var(--clr-text-muted);padding:0 1px;font-weight:400}.sticky-bar__mode-btn{border:1px solid var(--clr-border-strong);color:var(--clr-panel-open-fg);font:inherit;cursor:pointer;letter-spacing:.3px;white-space:nowrap;background:0 0;border-radius:6px;margin-left:auto;padding:4px 12px;font-size:12px;font-weight:700}.sticky-bar__mode-btn:hover{background:#ffffff1a}.sticky-bar__mode-btn--active{background:var(--clr-primary-border);border-color:var(--clr-primary-border);color:var(--clr-panel-open-fg)}.tab-nav{border-bottom:2px solid var(--clr-border-strong);background:var(--clr-bg);flex-shrink:0;display:flex;overflow-x:auto}.tab-nav__btn{font:inherit;color:var(--clr-text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-2px;padding:10px 8px;font-size:13px;font-weight:600;transition:color .12s,border-color .12s}.tab-nav__btn:hover{color:var(--clr-text-primary);background:#00000008}.tab-nav__btn--active{color:var(--clr-primary-border);border-bottom-color:var(--clr-primary-border)}@media (width<=640px){.app-grid{grid-template-rows:1fr auto;grid-template-columns:1fr}.sidebar{display:none}.sticky-bar{gap:4px;padding:4px 8px}.sticky-stat{min-width:36px;padding:2px 5px}.sticky-stat__value{font-size:13px}.sticky-bar__name{max-width:80px;font-size:12px}.tab-nav__btn{padding:8px 6px;font-size:12px}.app-main{padding:8px 10px 80px}.spell-slots__header,.spell-slots__row{grid-template-columns:70px 44px 44px 70px 1fr;gap:4px;font-size:12px}.taint-grid{grid-template-columns:1fr}}:root{--clr-bg:#f1f5f9;--clr-border:#e5e7eb;--clr-border-strong:#cbd5e1;--clr-panel-closed-bg:#e5e7eb;--clr-panel-closed-fg:#111827;--clr-panel-open-bg:#1f2937;--clr-panel-open-fg:#fff;--clr-panel-content-bg:#f8fafc;--clr-btn:#fff;--clr-btn-border:#cbd5e1;--clr-primary-border:#0ea5e9;--clr-primary-bg:#e0f2fe;--clr-danger-border:#ef4444;--clr-danger-bg:#fee2e2;--clr-text-primary:#0f172a;--clr-text-secondary:#1e293b;--clr-text-muted:#64748b;--clr-text-subtle:#94a3b8;--clr-bg-light:#f8fafc;--clr-accent-sky:#0ea5e9;--clr-accent-sky-bg:#e0f2fe;--clr-accent-sky-text:#0369a1;--clr-accent-green:#22c55e;--clr-accent-green-bg:#dcfce7;--clr-accent-green-text:#15803d;--clr-accent-green-border:#86efac;--clr-accent-amber:#f59e0b;--clr-accent-amber-bg:#fef3c7;--clr-accent-amber-text:#92400e;--clr-accent-amber-border:#fbbf24;--clr-accent-purple:#7c3aed;--clr-accent-purple-bg:#f3e8ff;--clr-accent-purple-text:#7c3aed;--clr-accent-indigo:#6366f1;--clr-accent-indigo-bg:#e0e7ff;--clr-accent-indigo-text:#3730a3;--clr-accent-indigo-border:#818cf8;--clr-calc-bg:#d1fae5;--clr-calc-text:#047857;--clr-calc-border:#059669;--clr-hp-bloodied-text:#c2410c;--clr-hp-bloodied-border:#f97316;--clr-hp-dead-bg:#fef2f2;--clr-hp-dead-text:#7f1d1d;--clr-hp-dead-border:#7f1d1d;--clr-hp-temp:#6366f1;--clr-load-overloaded-bg:#7f1d1d;--clr-tab-feat:#1e40af;--clr-tab-spell:#7c3aed;--clr-tab-skill:#059669}[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--clr-bg:#0f172a;--clr-border:#1e293b;--clr-border-strong:#334155;--clr-panel-closed-bg:#1e293b;--clr-panel-closed-fg:#e2e8f0;--clr-panel-open-bg:#0c1524;--clr-panel-open-fg:#f1f5f9;--clr-panel-content-bg:#162032;--clr-btn:#1e293b;--clr-btn-border:#475569;--clr-primary-border:#38bdf8;--clr-primary-bg:#0c4a6e;--clr-danger-border:#f87171;--clr-danger-bg:#450a0a;--clr-text-primary:#f1f5f9;--clr-text-secondary:#e2e8f0;--clr-text-muted:#94a3b8;--clr-text-subtle:#64748b;--clr-bg-light:#1e293b;--clr-accent-sky:#38bdf8;--clr-accent-sky-bg:#0c4a6e;--clr-accent-sky-text:#38bdf8;--clr-accent-green:#4ade80;--clr-accent-green-bg:#16a34a26;--clr-accent-green-text:#4ade80;--clr-accent-green-border:#16a34a66;--clr-accent-amber:#fbbf24;--clr-accent-amber-bg:#f59e0b26;--clr-accent-amber-text:#fbbf24;--clr-accent-amber-border:#f59e0b66;--clr-accent-purple:#a78bfa;--clr-accent-purple-bg:#7c3aed26;--clr-accent-purple-text:#a78bfa;--clr-accent-indigo:#818cf8;--clr-accent-indigo-bg:#6366f126;--clr-accent-indigo-text:#818cf8;--clr-accent-indigo-border:#6366f159;--clr-calc-bg:#05966926;--clr-calc-text:#34d399;--clr-calc-border:#059669;--clr-hp-bloodied-text:#fb923c;--clr-hp-bloodied-border:#f97316;--clr-hp-dead-bg:#7f1d1d40;--clr-hp-dead-text:#f87171;--clr-hp-dead-border:#991b1b;--clr-hp-temp:#818cf8;--clr-load-overloaded-bg:#450a0a;--clr-tab-feat:#3b82f6;--clr-tab-spell:#a78bfa;--clr-tab-skill:#34d399}[data-theme=dark] input,[data-theme=dark] textarea,[data-theme=dark] select{background:var(--clr-bg-light);color:var(--clr-text-primary);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}*,:before,:after{box-sizing:border-box}html,body,#root{height:100%}body{color:var(--clr-text-primary);background:var(--clr-bg);margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,Apple Color Emoji,Segoe UI Emoji}.input--hidden{clip:rect(0 0 0 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.app-grid{grid-template-columns:260px 1fr;height:100vh;display:grid;overflow:hidden}.sidebar{border-right:1px solid var(--clr-border);background:var(--clr-bg);width:260px;min-width:260px;height:100%;overflow-y:auto}.panel{border-bottom:1px solid var(--clr-border-strong)}.panel__header{text-align:left;cursor:pointer;background:var(--clr-panel-closed-bg);width:100%;color:var(--clr-panel-closed-fg);border:0;padding:10px 12px;font-weight:600;display:block}.panel__header--open{background:var(--clr-panel-open-bg);color:var(--clr-panel-open-fg)}.panel__content{background:var(--clr-panel-content-bg);padding:12px}.field{flex-direction:column;display:flex}.field__label{color:var(--clr-text-secondary);margin-bottom:8px;font-size:12px;font-weight:600}.input{border:1px solid var(--clr-btn-border);font:inherit;border-radius:6px;padding:8px 10px}.input:focus{border-color:var(--clr-primary-border);box-shadow:0 0 0 2px var(--clr-primary-bg);outline:none}.btn-row{flex-wrap:wrap;gap:8px;display:flex}.btn--primary{border:1px solid var(--clr-primary-border);background:var(--clr-primary-bg);padding:8px 12px;font-weight:600}.btn--danger{border:1px solid var(--clr-danger-border);background:var(--clr-danger-bg);padding:8px 12px;font-weight:600}.btn--secondary{border:1px solid var(--clr-border-strong);background:var(--clr-bg);padding:8px 12px;font-weight:500}.btn--secondary:hover:not(:disabled){background:var(--clr-panel-closed-bg)}.btn--success{border:1px solid var(--clr-accent-green);background:var(--clr-accent-green-bg);color:var(--clr-accent-green-text);padding:8px 12px;font-weight:600}.btn--ghost{color:var(--clr-text-muted);background:0 0;border:1px solid #0000;padding:8px 12px}.btn--ghost:hover{background:var(--clr-bg)}.btn--sm{padding:5px 10px;font-size:13px}.btn--xs{border-radius:4px;padding:2px 7px;font-size:12px}.btn:disabled{opacity:.45;cursor:not-allowed}.mb-8{margin-bottom:8px}.text-error{color:var(--clr-danger-border)}.grid-rawadj{grid-template-columns:1fr auto 1fr;align-items:center;display:grid}.stat-cell{border:1px solid var(--clr-border);border-radius:6px;padding:4px 8px}.dice__pool,.dice__result{font-size:14px}.panel-title{margin:0 0 var(--space-3);color:var(--clr-text-primary);font-size:20px;font-weight:600}:root{--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-6:24px}.flow>*+*{margin-top:var(--space-3)}.flow-lg>*+*{margin-top:var(--space-4)}.btn-row{gap:var(--space-2);margin-bottom:var(--space-3)}.card{margin-top:var(--space-3)}.grid-3{gap:var(--space-3)}.grid-rawadj{gap:var(--space-2) var(--space-4)}.dice__pool{margin:var(--space-2) 0 var(--space-3)}.dice__result{margin-top:var(--space-3)}.card h1,.card h2,.card h3{margin:0 0 var(--space-2)}.card p{margin:var(--space-2) 0 0}.container{max-width:1100px;margin:0 auto}.flex-row{flex-direction:row;display:flex}.items-center{align-items:center}.items-baseline{align-items:baseline}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.wrap{flex-wrap:wrap}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.p-2{padding:8px}.p-3{padding:12px}.mt-8{margin-top:8px}.mt-10{margin-top:10px}.mt-12{margin-top:12px}.m-0{margin:0}.mb-12{margin-bottom:12px}.tt-up{text-transform:uppercase}.fs-18{font-size:18px}.fs-12{font-size:12px}.tabular{font-variant-numeric:tabular-nums}.text-muted{color:var(--clr-text-muted)}.text-subtle{color:var(--clr-text-subtle)}.text-right{text-align:right}.text-center{text-align:center}.border{border:1px solid var(--clr-border)}.border-dashed{border:1px dashed var(--clr-border)}.rounded-12{border-radius:12px}.rounded-pill{border-radius:999px}.bg-faint{background:var(--clr-bg-light)}.card{border:1px solid var(--clr-border);border-radius:12px;padding:12px}.btn{cursor:pointer;font:inherit;border-radius:8px;padding:8px 12px}.btn-outline{border:1px solid var(--clr-border-strong);background:var(--clr-bg-light)}.arrow-sep{text-align:center;color:var(--clr-text-muted)}.col-span-3{grid-column:1/span 3}.ability-input{border:1px solid var(--clr-border-strong);border-radius:8px;width:100%;padding:8px}.ability-grid__racial{color:var(--clr-text-muted);text-align:center;margin-top:2px;font-size:11px;display:block}.currency-inputs{gap:var(--space-3);margin-top:var(--space-2);flex-wrap:wrap;display:flex}.currency-inputs__field{flex-direction:column;align-items:center;gap:2px;display:flex}.currency-inputs__label{text-transform:uppercase;letter-spacing:.05em;color:var(--clr-text-muted);font-size:.65rem;font-weight:700}.currency-inputs__input{border:1px solid var(--clr-border-strong);font-variant-numeric:tabular-nums;text-align:center;border-radius:4px;width:5rem;padding:4px 6px;font-size:.875rem}.badge{border:1px solid var(--clr-border);letter-spacing:.2px;cursor:default;border-radius:999px;padding:4px 10px;font-size:13px;line-height:1;text-decoration:none;display:inline-block}.badge-compact{padding:2px 8px;font-size:12px}.badge-core{background:var(--clr-accent-green-bg);border-color:var(--clr-accent-green-border);color:var(--clr-accent-green-text)}.badge-supplement{background:var(--clr-accent-indigo-bg);border-color:var(--clr-accent-indigo-border);color:var(--clr-accent-indigo-text)}.badge-checkgm{background:var(--clr-accent-amber-bg);border-color:var(--clr-accent-amber-border);color:var(--clr-accent-amber-text)}.skills-panel{margin-top:var(--space-6)}.skills-panel__empty{padding:var(--space-4);text-align:center;color:var(--clr-text-muted);background:var(--clr-bg-light);border:1px solid var(--clr-border);border-radius:8px;font-style:italic}.skills-filter__toggle{align-items:center;gap:var(--space-2);margin-bottom:var(--space-4);color:var(--clr-text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.85rem;display:flex}.skills-list{gap:var(--space-4);flex-direction:column;display:flex}.skills-ability-group{background:var(--clr-bg-light);border:1px solid var(--clr-border);border-radius:8px;overflow:hidden}.skills-ability-group__header{background:var(--clr-panel-closed-bg);color:var(--clr-panel-closed-fg);border-bottom:1px solid var(--clr-border);padding:.75rem 1rem;font-size:.95rem;font-weight:600}.skills-ability-group__skills{gap:var(--space-1);padding:var(--space-2);flex-direction:column;display:flex}.skill-item{background:var(--clr-bg-light);border:1px solid var(--clr-border);justify-content:space-between;align-items:center;gap:var(--space-2);border-radius:4px;padding:.5rem .75rem;transition:background .15s;display:flex}.skill-item:hover{background:var(--clr-bg)}.skill-item--class{background:var(--clr-accent-green-bg);border-color:var(--clr-accent-green-border)}.skill-item--cross-class{background:var(--clr-accent-amber-bg);border-color:var(--clr-accent-amber-border)}.skill-item__name{align-items:center;gap:var(--space-2);color:var(--clr-text-primary);flex:1;font-size:.9rem;font-weight:500;display:flex}.skill-item__ability{color:var(--clr-text-muted);text-transform:uppercase;font-size:.75rem;font-weight:600}.skill-item__calculation{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.skill-item__breakdown{color:var(--clr-text-muted);font-variant-numeric:tabular-nums;white-space:nowrap;font-size:.8rem}.skill-item__fractional{color:var(--clr-accent-amber);font-size:.75rem;font-style:italic}.skill-badge{text-transform:uppercase;letter-spacing:.025em;border-radius:12px;justify-content:center;align-items:center;padding:.25rem .5rem;font-size:.7rem;font-weight:600;line-height:1;display:inline-flex}.skill-badge--trained{background:var(--clr-accent-amber-bg);color:var(--clr-accent-amber-text);border:1px solid var(--clr-accent-amber-border)}.skill-badge--armor{background:var(--clr-danger-bg);color:var(--clr-danger-border);border:1px solid var(--clr-danger-border)}.skill-badge--class{background:var(--clr-accent-green);color:var(--clr-panel-open-fg);border:1px solid var(--clr-accent-green-text)}.skill-badge--cross-class{background:var(--clr-accent-indigo-bg);color:var(--clr-accent-indigo-text);border:1px solid var(--clr-accent-indigo-border)}.skill-badge--class-inline{background:var(--clr-accent-green);color:var(--clr-panel-open-fg);border:1px solid var(--clr-accent-green-text);padding:.125rem .375rem;font-size:.65rem}.skill-badge--trained-inline{background:var(--clr-accent-amber-bg);color:var(--clr-accent-amber-text);border:1px solid var(--clr-accent-amber-border);padding:.125rem .375rem;font-size:.65rem}.skill-badge--armor-inline{background:var(--clr-danger-bg);color:var(--clr-danger-border);border:1px solid var(--clr-danger-border);padding:.125rem .375rem;font-size:.65rem}.skills-list--flat{gap:var(--space-1);flex-direction:column;display:flex}.skill-item--flat{align-items:center;gap:var(--space-3);padding:.375rem .75rem;display:flex}.skill-item__stats{cursor:help;flex-shrink:0;align-items:center;display:flex}.skill-item__total{color:var(--clr-text-primary);font-variant-numeric:tabular-nums;text-align:right;min-width:2.75rem;font-size:1rem;font-weight:700}.skill-item__info{align-items:center;gap:var(--space-2);flex:1;min-width:0;display:flex}.skill-item__badges{gap:var(--space-1);flex-shrink:0;display:flex}@media (width<=640px){.skill-item__name{font-size:.85rem}.skill-item__calculation{flex-direction:column;align-items:flex-end;gap:.25rem}.skill-item__breakdown{font-size:.7rem}}.skill-item__misc{border:1px solid var(--clr-border);width:44px;font:inherit;text-align:right;background:0 0;border-radius:4px;flex-shrink:0;margin-left:6px;padding:2px 4px;font-size:12px}.browser{font-size:13px}.browser__search{padding:var(--space-2);background:var(--clr-bg-light);z-index:1;border-bottom:1px solid var(--clr-border);position:sticky;top:0}.browser__input{border:1px solid var(--clr-btn-border);width:100%;font:inherit;border-radius:4px;padding:6px 8px;font-size:12px}.browser__input:focus{border-color:var(--clr-primary-border);box-shadow:0 0 0 2px var(--clr-primary-bg);outline:none}.browser__filters{gap:var(--space-1);margin-top:var(--space-1);flex-wrap:wrap;display:flex}.browser__filter{border:1px solid var(--clr-btn-border);font:inherit;background:var(--clr-bg-light);cursor:pointer;border-radius:4px;flex:1;min-width:60px;padding:4px 6px;font-size:11px}.browser__filter:focus{border-color:var(--clr-primary-border);outline:none}.browser__count{padding:var(--space-1) var(--space-2);color:var(--clr-text-muted);background:var(--clr-bg);border-bottom:1px solid var(--clr-border);font-size:11px}.browser__list{max-height:400px;margin:0;padding:0;list-style:none;overflow-y:auto}.browser__item{padding:var(--space-2);border-bottom:1px solid var(--clr-border);cursor:pointer;transition:background .15s}.browser__item:hover{background:var(--clr-bg)}.browser__item:last-child{border-bottom:none}.browser__item--expanded{background:var(--clr-bg-light)}.browser__item-header{justify-content:space-between;align-items:flex-start;gap:var(--space-2);display:flex}.browser__item-name{color:var(--clr-text-primary);font-size:13px;font-weight:600;line-height:1.3}.browser__item-meta{color:var(--clr-text-muted);margin-top:2px;font-size:11px}.browser__item-badge{background:var(--clr-accent-sky-bg);color:var(--clr-accent-sky-text);white-space:nowrap;border-radius:3px;flex-shrink:0;padding:2px 6px;font-size:10px}.browser__item-badge--school{background:var(--clr-accent-purple-bg);color:var(--clr-accent-purple-text)}.browser__item-badge--ability{background:var(--clr-accent-green-bg);color:var(--clr-accent-green-text);text-transform:uppercase}.browser__item-badge--trained{background:var(--clr-accent-amber-bg);color:var(--clr-accent-amber-text)}.browser__details{margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px dashed var(--clr-border);color:var(--clr-text-muted);font-size:12px;line-height:1.5}.browser__details-row{margin-bottom:var(--space-1)}.browser__details-row:last-child{margin-bottom:0}.browser__details-row--description{margin-top:var(--space-2)}.browser__details-label{color:var(--clr-text-secondary);font-weight:600}.browser__details-prereq{color:var(--clr-danger-border);font-style:italic}.browser__details-source{color:var(--clr-text-subtle);margin-top:var(--space-1);font-size:11px;font-style:italic}.browser__details-tags{margin-top:var(--space-1);flex-wrap:wrap;gap:4px;display:flex}.browser__details-tag{background:var(--clr-bg);color:var(--clr-text-muted);border-radius:3px;padding:2px 6px;font-size:10px}.browser__skill-list{margin-top:var(--space-1);flex-wrap:wrap;gap:4px;display:flex}.browser__skill-tag{background:var(--clr-accent-sky-bg);color:var(--clr-accent-sky-text);border-radius:3px;padding:2px 5px;font-size:10px}.browser__empty{padding:var(--space-4) var(--space-2);text-align:center;color:var(--clr-text-subtle);font-size:12px}.browser__item-actions{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;display:flex}.browser__stats-row{flex-wrap:wrap;gap:3px;margin-top:3px;display:flex}.browser__stat{background:var(--clr-bg);color:var(--clr-text-secondary);border:1px solid var(--clr-border);border-radius:3px;padding:1px 5px;font-size:10px}.browser__stat--damage{background:var(--clr-accent-amber-bg);color:var(--clr-accent-amber-text);border-color:var(--clr-accent-amber-border)}.browser__stat--crit{background:var(--clr-accent-sky-bg);color:var(--clr-accent-sky-text);border-color:#0000}.browser__item-add{visibility:hidden;border:1px solid var(--clr-primary-border);color:var(--clr-primary);cursor:pointer;background:0 0;border-radius:3px;padding:2px 7px;font-family:inherit;font-size:11px;line-height:1.4}.browser__item:hover .browser__item-add{visibility:visible}.browser__item-add:hover{background:var(--clr-primary-bg)}.browser__item-badge--simple{background:var(--clr-accent-green-bg);color:var(--clr-accent-green-text)}.browser__item-badge--martial{background:var(--clr-accent-amber-bg);color:var(--clr-accent-amber-text)}.browser__item-badge--exotic{background:var(--clr-accent-purple-bg);color:var(--clr-accent-purple-text)}.browser__item-badge--medium{background:var(--clr-accent-amber-bg);color:var(--clr-accent-amber-text)}.browser__item-badge--heavy{background:var(--clr-accent-indigo-bg);color:var(--clr-accent-indigo-text)}.browser__item-badge--shield{background:var(--clr-accent-green-bg);color:var(--clr-accent-green-text)}.summary-panel{font-size:14px}.summary-count{padding:var(--space-2) var(--space-3);color:var(--clr-text-muted);background:var(--clr-bg-light);border-bottom:1px solid var(--clr-border);font-size:12px;font-weight:600}.summary-empty{padding:var(--space-4);text-align:center;color:var(--clr-text-subtle);border:1px dashed var(--clr-border);background:var(--clr-bg-light);border-radius:8px;font-size:14px}.summary-list{max-height:400px;margin:0;padding:0;list-style:none;overflow-y:auto}.summary-item{padding:var(--space-3);border-bottom:1px solid var(--clr-border)}.summary-item:last-child{border-bottom:none}.summary-item:hover{background:var(--clr-bg-light)}.summary-item__header{justify-content:space-between;align-items:flex-start;gap:var(--space-2);margin-bottom:var(--space-1);display:flex}.summary-item__name{color:var(--clr-text-primary);font-size:14px;font-weight:600}.summary-item__level{background:var(--clr-accent-sky-bg);color:var(--clr-accent-sky-text);white-space:nowrap;border-radius:12px;flex-shrink:0;padding:2px 8px;font-size:11px}.summary-item__meta{color:var(--clr-accent-purple-text);margin-bottom:var(--space-1);font-size:12px}.summary-item__description{color:var(--clr-text-muted);margin-bottom:var(--space-1);font-size:13px;line-height:1.5}.summary-item__source{color:var(--clr-text-subtle);font-size:11px;font-style:italic}.skills-summary__group{margin-bottom:var(--space-3)}.skills-summary__group:last-child{margin-bottom:0}.skills-summary__group-header{color:var(--clr-text-secondary);padding:var(--space-2);background:var(--clr-bg);border:1px solid var(--clr-border);border-bottom:none;border-radius:4px 4px 0 0;font-size:13px;font-weight:600}.skills-summary__skill{padding:var(--space-2);border:1px solid var(--clr-border);background:var(--clr-bg-light);border-top:none;justify-content:space-between;align-items:center;display:flex}.skills-summary__skill:last-child{border-radius:0 0 4px 4px}.skills-summary__skill-name{color:var(--clr-text-primary);font-weight:500}.skills-summary__skill-ranks{color:var(--clr-text-muted);font-size:12px}.skills-summary__skill-history{color:var(--clr-text-subtle);margin-left:var(--space-2);font-size:11px}.saves-panel{margin-top:var(--space-6)}.saves-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));display:grid}.save-item{border:1px solid var(--clr-border);padding:var(--space-4);background:var(--clr-panel-content-bg);border-radius:8px}.save-item__header{align-items:baseline;gap:var(--space-2);margin-bottom:var(--space-3);display:flex}.save-item__name{color:var(--clr-text-primary);margin:0;font-size:18px;font-weight:600}.save-item__ability{color:var(--clr-text-muted);text-transform:uppercase;font-size:12px;font-weight:600}.save-item__body{align-items:flex-end;gap:var(--space-4);margin-bottom:var(--space-3);display:flex}.save-item__input-group{gap:var(--space-1);flex-direction:column;flex:1;display:flex}.save-item__label{color:var(--clr-text-muted);font-size:12px;font-weight:600}.save-input{border:1px solid var(--clr-btn-border);width:100%;font:inherit;text-align:center;font-variant-numeric:tabular-nums;border-radius:6px;padding:8px 10px;font-size:16px}.save-input:focus{border-color:var(--clr-primary-border);box-shadow:0 0 0 2px var(--clr-primary-bg);outline:none}.save-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.save-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.save-input[type=number]{-moz-appearance:textfield}.save-item__total{align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:var(--clr-bg);border:2px solid var(--clr-primary-border);border-radius:8px;flex-direction:column;min-width:80px;display:flex}.save-item__total-label{color:var(--clr-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.save-item__total-value{color:var(--clr-accent-sky-text);font-variant-numeric:tabular-nums;font-size:24px;font-weight:700}.save-item__calculated{align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:var(--clr-calc-bg);border:2px solid var(--clr-calc-border);cursor:help;border-radius:8px;flex-direction:column;flex:1;min-width:80px;display:flex}.save-item__calculated-label{color:var(--clr-calc-text);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.save-item__calculated-value{color:var(--clr-calc-text);font-variant-numeric:tabular-nums;font-size:24px;font-weight:700}.save-item__description{color:var(--clr-text-muted);margin:0;font-size:13px;line-height:1.5}@media (width<=640px){.saves-grid{grid-template-columns:1fr}}.combat-stats{margin-top:var(--space-6)}.combat-stats__grid{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.combat-stat-card{border:1px solid var(--clr-border);background:var(--clr-panel-content-bg);padding:var(--space-4);border-radius:8px;box-shadow:0 1px 3px #0000001a}.combat-stat-card__header{margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--clr-border)}.combat-stat-card__label{color:var(--clr-text-muted);text-transform:uppercase;letter-spacing:.025em;font-size:14px;font-weight:600}.combat-stat-card__content{gap:var(--space-2);flex-direction:column;display:flex}.combat-stat-card__sublabel{color:var(--clr-text-muted);text-align:center;font-size:12px}.combat-stat-input{border:1px solid var(--clr-btn-border);width:100%;font:inherit;text-align:center;font-variant-numeric:tabular-nums;background:var(--clr-bg-light);border-radius:6px;padding:8px;font-size:16px;transition:border-color .15s}.combat-stat-input:focus{border-color:var(--clr-primary-border);box-shadow:0 0 0 2px var(--clr-primary-bg);outline:none}.combat-stat-input--hp{width:64px;font-size:20px;font-weight:600}.combat-stat-input--small{width:56px;padding:4px 8px;font-size:14px}.combat-stat-input--centered{padding:12px;font-size:24px;font-weight:600}.combat-stat-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.combat-stat-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.combat-stat-input[type=number]{-moz-appearance:textfield}.combat-stat-hp{justify-content:center;align-items:center;gap:var(--space-2);display:flex}.combat-stat-hp__separator{color:var(--clr-text-subtle);font-size:24px;font-weight:300}.combat-stat-display{text-align:center;color:var(--clr-text-primary);padding:var(--space-2);background:var(--clr-bg);border-radius:6px;font-size:32px;font-weight:700}.combat-stat-display--with-tooltip{cursor:help}.combat-stat-calculated{color:var(--clr-calc-text);text-align:center;background:var(--clr-calc-bg);cursor:help;margin-top:var(--space-2);border-radius:4px;padding:4px;font-size:12px;font-weight:500}.combat-stat-breakdown{margin-top:var(--space-2);flex-direction:column;gap:4px;display:flex}.combat-stat-breakdown__row{justify-content:space-between;align-items:center;gap:var(--space-2);padding:4px 0;display:flex}.combat-stat-breakdown__label{color:var(--clr-text-muted);text-transform:uppercase;min-width:48px;font-size:12px;font-weight:500}.combat-stat-breakdown__value{color:var(--clr-text-primary);text-align:right;min-width:32px;font-size:14px;font-weight:600}.combat-stat-movement{align-items:center;gap:var(--space-2);display:flex}.combat-stat-movement__unit{color:var(--clr-text-muted);white-space:nowrap;font-size:14px}.combat-stat-input--type{flex:1;padding:4px 8px;font-size:14px}.combat-stat-display--movement{font-size:20px;font-weight:600}@media (width<=640px){.combat-stats__grid{grid-template-columns:1fr}.combat-stat-display{font-size:28px}.combat-stat-input--centered{font-size:20px}}
