:root{--bg-body:#0a0a14;--bg-panel:#12182a;--bg-panel-dark:#0a0e1e;--bg-selected:#1e2844;--bg-slot:#1a1a2e;--bg-slot-selected:#335;--gold:#c8a84e;--gold-bright:#f0d060;--gold-dim:#8a6e30;--silver:#b0b8c8;--parchment:#d4c4a0;--border-panel:#6a5630;--border-highlight:#c8a84e4d;--text-primary:#b0b8c8;--text-hint:#78a;--text-dim:#556;--color-danger:#f44;--color-heal:#4f8;--color-mana:#48f;--color-xp:#fd4;--font-title:"Cinzel Decorative", "Cinzel", serif;--font-heading:"Cinzel", serif;--font-body:"MedievalSharp", "Cinzel", serif;--font-mono:monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-body);color:var(--text-primary);font-family:var(--font-body);background-image:radial-gradient(at 50% 0,#1e284480 0%,#0000 60%),radial-gradient(at 50% 100%,#140f0a66 0%,#0000 50%);background-attachment:fixed;min-height:100vh;font-size:14px;line-height:1.4}body:after{content:"";pointer-events:none;z-index:9999;background:radial-gradient(#0000 50%,#0006 100%);position:fixed;inset:0}.panel{background:var(--bg-panel);border:2px solid var(--border-panel);box-shadow:inset 0 0 0 1px var(--border-highlight);border-radius:4px;padding:12px;transition:box-shadow .25s,border-color .25s,transform .2s;position:relative}.panel:hover{box-shadow:inset 0 0 0 1px var(--border-highlight), 0 0 12px #c8a84e14}.panel--accent{border-color:var(--gold);box-shadow:inset 0 0 0 1px var(--border-highlight), 0 0 20px #c8a84e1a}.panel--accent:before,.panel--accent:after{content:"";border:1px solid var(--gold);opacity:.6;pointer-events:none;width:8px;height:8px;position:absolute}.panel--accent:before{border-bottom:none;border-right:none;top:4px;left:4px}.panel--accent:after{border-bottom:none;border-left:none;top:4px;right:4px}.spell-card{transition:box-shadow .25s,border-color .25s,transform .2s}.spell-card:hover{box-shadow:inset 0 0 0 1px var(--border-highlight), 0 4px 16px #0000004d, 0 0 12px #c8a84e1a;border-color:var(--gold-dim);transform:translateY(-2px)}.spell-card__body{opacity:0;max-height:0;margin-top:0;padding-top:0;transition:max-height .35s,opacity .25s,margin-top .25s,padding-top .25s;overflow:hidden}.spell-card__body--expanded{opacity:1;border-top:1px solid var(--border-highlight);max-height:600px;margin-top:10px;padding-top:10px}.panel__title{font-family:var(--font-heading);color:var(--gold);text-shadow:1px 1px 2px #000c;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #c8a84e33;margin-bottom:10px;padding-bottom:6px;font-size:13px;font-weight:700}.btn{font-family:var(--font-heading);border:1px solid var(--gold-dim);color:var(--gold);cursor:pointer;text-shadow:1px 1px 2px #000c;background:#c8a84e26;border-radius:4px;padding:6px 14px;font-size:12px;transition:background .15s,border-color .15s,transform .1s,box-shadow .15s}.btn:hover{border-color:var(--gold);background:#c8a84e4d;box-shadow:0 0 8px #c8a84e26}.btn:active{box-shadow:none;transform:scale(.96)}.btn--active{border-color:var(--gold-bright);color:var(--gold-bright);background:#f0d06040;box-shadow:0 0 10px #f0d06026}.btn--danger{border-color:var(--color-danger);color:var(--color-danger);background:#ff44441a}.btn--danger:hover{background:#ff444440;box-shadow:0 0 8px #ff444426}.btn--danger:active{transform:scale(.96)}.btn:disabled{border-color:var(--text-dim);color:var(--text-dim);background:var(--bg-panel-dark);cursor:not-allowed;box-shadow:none;transform:none}.chip{font-family:var(--font-body);background:var(--bg-panel-dark);color:var(--text-dim);cursor:pointer;opacity:.5;border:1px solid #0000;border-radius:12px;padding:2px 10px;font-size:11px;transition:opacity .15s,background .15s,border-color .15s,box-shadow .15s,transform .1s;display:inline-block}.chip:hover{opacity:.8;transform:translateY(-1px);box-shadow:0 0 6px #c8a84e1a}.chip:active{transform:scale(.95)}.chip--active{opacity:1;border-color:var(--color-danger);color:var(--color-danger);background:#ff444426;box-shadow:0 0 8px #ff444426}.pip{border:2px solid var(--border-panel);background:var(--bg-slot);cursor:pointer;border-radius:50%;width:22px;height:22px;transition:background .2s,border-color .2s,box-shadow .3s,transform .1s}.pip:hover{transform:scale(1.1)}.pip:active{transform:scale(.9)}.pip--available{background:linear-gradient(180deg, var(--gold-bright) 0%, var(--gold) 100%);border-color:var(--gold-dim);animation:2.5s ease-in-out infinite pip-glow;box-shadow:inset 0 1px 2px #ffffff4d,inset 0 -1px 2px #0000004d,0 0 8px #f0d0604d}@keyframes pip-glow{0%,to{box-shadow:inset 0 1px 2px #ffffff4d,inset 0 -1px 2px #0000004d,0 0 6px #f0d06033}50%{box-shadow:inset 0 1px 2px #ffffff4d,inset 0 -1px 2px #0000004d,0 0 14px #f0d06073}}@keyframes concentration-pulse{0%,to{border-color:var(--color-mana);box-shadow:inset 0 0 0 1px var(--border-highlight), 0 0 8px #4488ff26}50%{box-shadow:inset 0 0 0 1px var(--border-highlight), 0 0 18px #4488ff4d;border-color:#48f9}}.concentration-banner{animation:3s ease-in-out infinite concentration-pulse}.stat-value{font-family:var(--font-mono);text-shadow:1px 1px 2px #000c;font-weight:700;transition:color .3s}.proficient{color:var(--gold)}.label{font-family:var(--font-heading);color:var(--text-hint);text-transform:uppercase;letter-spacing:.5px;font-size:10px}.divider{border:none;border-top:1px solid #c8a84e33;margin:8px 0}.school-abjuration{color:#48f}.school-conjuration{color:#4c8}.school-divination{color:#b0b8c8}.school-enchantment{color:#c6c}.school-evocation{color:#f64}.school-illusion{color:#a8f}.school-necromancy{color:#8c4}.school-transmutation{color:#fa4}.character-name{font-family:var(--font-title);color:var(--gold-bright);text-shadow:1px 1px 3px #000000e6,0 0 20px #f0d06026;letter-spacing:.5px;font-size:18px;line-height:1.3}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-panel-dark)}::-webkit-scrollbar-thumb{background:var(--border-panel);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--gold-dim)}.search-input{background:var(--bg-panel);color:var(--text-primary);border:1px solid var(--border-panel);font-family:var(--font-body);border-radius:4px;outline:none;width:200px;padding:6px 10px;font-size:13px;transition:border-color .2s,box-shadow .2s}.search-input:focus{border-color:var(--gold-dim);box-shadow:0 0 8px #c8a84e26}.search-input::placeholder{color:var(--text-dim)}.hp-input{font-family:var(--font-mono);text-align:center;background:var(--bg-panel-dark);border-radius:4px;outline:none;font-weight:700;transition:box-shadow .2s}.hp-input:focus{box-shadow:0 0 10px #c8a84e33}.spell-tag{font-size:9px;font-family:var(--font-heading);letter-spacing:.3px;text-transform:uppercase;border-radius:4px;padding:1px 6px;font-weight:600}.spell-tag--concentration{color:var(--color-mana);background:#48f3;box-shadow:0 0 4px #4488ff1a}.spell-tag--ritual{color:var(--gold);background:#c8a84e33;box-shadow:0 0 4px #c8a84e1a}.spell-tag--level{background:var(--bg-panel-dark);color:var(--text-hint);border:1px solid #c8a84e26}.ability-row{background:var(--bg-panel-dark);border-radius:4px;align-items:center;padding:5px 8px;font-size:12px;transition:background .15s;display:flex}.ability-row:hover{background:var(--bg-selected)}.ability-row--proficient{border-left:2px solid var(--gold)}.ability-row--normal{border-left:2px solid #0000}.skill-row{background:var(--bg-panel-dark);border-radius:4px;justify-content:space-between;padding:4px 8px;font-size:12px;transition:background .15s;display:flex}.skill-row:hover{background:var(--bg-selected)}.feature-item{padding:6px 0;font-size:12px;transition:opacity .15s}.feature-item+.feature-item{border-top:1px solid #c8a84e1a;padding-top:8px}.combat-stat{text-align:center;border-radius:4px;padding:4px 8px;transition:background .15s}.combat-stat:hover{background:#c8a84e0d}.app{gap:12px;max-width:1200px;min-height:100vh;margin:0 auto;padding:12px;display:flex}.sidebar{flex-direction:column;flex-shrink:0;gap:8px;width:260px;max-height:100vh;padding-bottom:12px;display:flex;position:sticky;top:0;overflow-y:auto}.main{flex-direction:column;flex:1;gap:8px;min-width:0;display:flex}.mobile-combat-bar,.mobile-nav{display:none}.desktop-only{display:contents}@media (width<=767px){.app{flex-direction:column;padding:8px}.sidebar{width:100%;max-height:none;position:static;overflow-y:visible}.sidebar--hidden,.main--hidden{display:none}.mobile-combat-bar{background:var(--bg-panel);border-bottom:1px solid var(--border-panel);text-align:center;z-index:10;justify-content:space-around;padding:8px;font-size:12px;display:flex;position:sticky;top:0}.mobile-nav{z-index:11;display:block;position:sticky;top:0}.desktop-only{display:none}}
