:root{--bg:#0d0f0e;--surface:#141816;--surface2:#1b1f1d;--surface3:#222826;--border:#2e3830;--border-bright:#3d4f47;--teal:#4ecdc4;--teal-dim:#2a6b66;--gold:#c9a84c;--gold-dim:#7a6130;--red:#c0392b;--text:#d4cfc4;--text-dim:#7a8a82;--text-bright:#ede8dc;--crisis:#e74c3c;--font-display:"Cinzel",serif;--font-body:"Crimson Text",serif;--font-mono:"Inconsolata",monospace}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);background-image:radial-gradient(ellipse at 20% 10%,rgba(78,205,196,.04) 0,transparent 50%),radial-gradient(ellipse at 80% 90%,rgba(201,168,76,.04) 0,transparent 50%);color:var(--text);font-family:var(--font-body);font-size:16px;min-height:100vh}header{background:linear-gradient(135deg,var(--surface) 0,#0f1614 100%);border-bottom:1px solid var(--border-bright);box-shadow:0 4px 24px rgba(0,0,0,.5);justify-content:space-between;padding:20px 32px;position:sticky;top:0;z-index:100}.logo,header{align-items:center;display:flex}.logo{color:var(--teal);font-family:var(--font-display);font-size:1.1rem;gap:10px;letter-spacing:.15em;text-transform:uppercase}.logo:before{color:var(--gold);content:"✦";font-size:.9em}.tabs{display:flex;gap:4px}.tab{background:transparent;border:1px solid var(--border);color:var(--text-dim);cursor:pointer;font-family:var(--font-display);font-size:.65rem;letter-spacing:.12em;padding:7px 16px;text-transform:uppercase;transition:all .2s}.tab:hover{border-color:var(--teal-dim);color:var(--teal)}.tab.active{background:var(--teal-dim);border-color:var(--teal);color:var(--text-bright)}.page{display:none;margin:0 auto;max-width:1400px;padding:28px 32px}.page.active{animation:fadeIn .3s ease;display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.grid-2{grid-template-columns:1fr 1fr}.grid-2,.grid-3{display:grid;gap:20px}.grid-3{grid-template-columns:1fr 1fr 1fr}.col-span-2{grid-column:span 2}.section{background:var(--surface);border:1px solid var(--border);padding:18px 20px;position:relative}.section:before{background:var(--teal-dim);content:"";height:100%;left:0;position:absolute;top:0;width:3px}.section-title{align-items:center;border-bottom:1px solid var(--border);color:var(--teal);display:flex;font-family:var(--font-display);font-size:.6rem;gap:8px;letter-spacing:.2em;margin-bottom:14px;padding-bottom:8px;text-transform:uppercase}.section-title .icon{color:var(--gold)}.field{margin-bottom:14px}.field:last-child{margin-bottom:0}label{color:var(--text-dim);display:block;font-family:var(--font-display);font-size:.55rem;letter-spacing:.18em;margin-bottom:5px;text-transform:uppercase}input:not([type]),input[type=number],input[type=text],select,textarea{-webkit-appearance:none;background:var(--surface2);border:1px solid var(--border);color:var(--text-bright);font-family:var(--font-body);font-size:1rem;outline:none;padding:8px 11px;transition:border-color .2s,box-shadow .2s;width:100%}input:not([type]):focus,input[type=number]:focus,input[type=text]:focus,select:focus,textarea:focus{border-color:var(--teal);box-shadow:0 0 0 2px rgba(78,205,196,.12)}textarea{min-height:70px;resize:vertical}input[type=number]{font-family:var(--font-mono)}.field-row{display:flex;gap:12px}.field-row .field{flex:1}.attr-grid{display:grid;gap:12px;grid-template-columns:1fr 1fr}.attr-block{background:var(--surface2);border:1px solid var(--border);display:flex;flex-direction:column;gap:8px;padding:12px 14px}.attr-name{color:var(--gold);font-family:var(--font-display);font-size:.65rem;letter-spacing:.15em;text-transform:uppercase}.attr-inputs{align-items:center;display:flex;gap:8px}.attr-inputs input{flex-shrink:0;font-family:var(--font-mono);font-size:1.2rem;text-align:center;width:52px}.attr-sep{color:var(--text-dim);font-size:.8rem}.status-grid{display:grid;gap:8px;grid-template-columns:1fr 1fr}.status-item{align-items:center;background:var(--surface2);border:1px solid var(--border);cursor:pointer;display:flex;gap:8px;padding:7px 10px;transition:all .15s;user-select:none}.status-item:hover{border-color:var(--border-bright)}.status-item.active-status{background:rgba(192,57,43,.12);border-color:var(--red)}.status-check{align-items:center;border:1px solid var(--border-bright);color:var(--red);display:flex;flex-shrink:0;font-size:.7rem;height:14px;justify-content:center;transition:all .15s;width:14px}.status-item.active-status .status-check{background:rgba(192,57,43,.2);border-color:var(--red)}.status-label{color:var(--text-dim);font-family:var(--font-display);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase}.status-item.active-status .status-label{color:var(--crisis)}.vital-block{align-items:center;background:var(--surface2);border:1px solid var(--border);display:flex;gap:16px;margin-bottom:10px;padding:14px 16px}.vital-block:last-child{margin-bottom:0}.vital-label{flex-shrink:0;font-family:var(--font-display);font-size:1.2rem;font-weight:700;width:32px}.vital-label.hp{color:var(--red)}.vital-label.mp{color:var(--teal)}.vital-label.ip{color:var(--gold)}.vital-inputs{align-items:center;display:flex;flex:1;gap:8px}.vital-inputs input{font-family:var(--font-mono);font-size:1.1rem;text-align:center}.vital-sep{color:var(--text-dim);flex-shrink:0;font-size:.8rem}.vital-formula{color:var(--text-dim);font-family:var(--font-mono);font-size:.75rem}.crisis-badge{border:1px solid var(--crisis);color:var(--crisis);flex-shrink:0;font-family:var(--font-display);font-size:.5rem;letter-spacing:.15em;padding:2px 6px;text-transform:uppercase}.level-display{background:var(--surface2);border:1px solid var(--border);padding:20px;text-align:center}.level-num{color:var(--gold);font-size:3.5rem;line-height:1}.level-num,.level-text{display:block;font-family:var(--font-display)}.level-text{color:var(--text-dim);font-size:.55rem;letter-spacing:.25em;margin-top:4px;text-transform:uppercase}.xp-bar-wrap{background:var(--surface3);border:1px solid var(--border);height:8px;margin-top:14px;overflow:hidden;position:relative}.xp-bar{background:linear-gradient(90deg,var(--gold-dim),var(--gold));height:100%;transition:width .5s ease}.xp-label{color:var(--text-dim);display:flex;font-family:var(--font-mono);font-size:.75rem;justify-content:space-between;margin-top:5px}.fp-pips{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.fp-pip{align-items:center;background:var(--surface2);border:2px solid var(--border-bright);border-radius:50%;cursor:pointer;display:flex;height:28px;justify-content:center;transition:all .15s;width:28px}.fp-pip.filled{background:var(--teal);box-shadow:0 0 8px rgba(78,205,196,.4)}.fp-pip.filled,.fp-pip:hover{border-color:var(--teal)}.fp-rules{border-top:1px solid var(--border);margin-top:14px;padding-top:12px}.fp-rule{color:var(--text-dim);font-size:.85rem;padding:3px 0 3px 12px;position:relative}.fp-rule:before{color:var(--gold);content:"✦";font-size:.5rem;left:0;position:absolute;top:5px}.fp-rule strong{color:var(--text)}.bond-block{background:var(--surface2);border:1px solid var(--border);margin-bottom:10px;padding:14px}.bond-block:last-child{margin-bottom:0}.bond-header{gap:10px;margin-bottom:10px}.bond-header,.bond-num{align-items:center;display:flex}.bond-num{border:1px solid var(--gold-dim);color:var(--gold);flex-shrink:0;font-family:var(--font-display);font-size:.6rem;height:22px;justify-content:center;width:22px}.bond-header input{flex:1}.bond-feelings{display:grid;gap:5px;grid-template-columns:repeat(3,1fr)}.bond-feeling{align-items:center;color:var(--text-dim);cursor:pointer;display:flex;font-size:.8rem;gap:5px;user-select:none}.bond-feeling.active{color:var(--teal)}.bond-feeling-box{align-items:center;border:1px solid var(--border-bright);display:flex;flex-shrink:0;font-size:.6rem;height:12px;justify-content:center;transition:all .15s;width:12px}.bond-feeling.active .bond-feeling-box{background:var(--teal);border-color:var(--teal);color:#000}.equip-row{border-bottom:1px solid var(--border);display:grid;gap:0;grid-template-columns:120px 1fr}.equip-row:last-child{border-bottom:none}.equip-slot{align-items:center;background:var(--surface3);border-right:1px solid var(--border);color:var(--gold);display:flex;font-family:var(--font-display);font-size:.55rem;letter-spacing:.15em;padding:10px 12px;text-transform:uppercase}.equip-fields{display:flex;flex-direction:column;gap:0}.equip-fields input{border:none;border-bottom:1px solid var(--border);font-size:.9rem;padding:7px 10px}.equip-fields input:last-child{border-bottom:none}.equip-fields input::placeholder{color:var(--border-bright);font-style:italic}.martial-row{display:flex;flex-wrap:wrap;gap:16px;margin-top:10px}.martial-item{cursor:pointer;gap:6px;user-select:none}.martial-box,.martial-item{align-items:center;display:flex}.martial-box{border:1px solid var(--border-bright);color:var(--teal);font-size:.65rem;height:14px;justify-content:center;transition:all .15s;width:14px}.martial-item.checked .martial-box{background:var(--teal-dim);border-color:var(--teal)}.martial-item span{color:var(--text-dim);font-family:var(--font-display);font-size:.55rem;letter-spacing:.1em;text-transform:uppercase}.class-block{background:var(--surface2);border:1px solid var(--border);margin-bottom:12px}.class-block:last-child{margin-bottom:0}.class-header{border-bottom:1px solid var(--border);display:grid;gap:0;grid-template-columns:1fr 1fr}.class-header input{border:none;border-right:1px solid var(--border);font-size:.9rem}.class-header input:last-child{border-right:none}.class-skills{padding:0}.class-skills textarea{background:transparent;border:none;font-size:.85rem;min-height:80px}.spells-table{border-collapse:collapse;width:100%}.spells-table thead tr{background:var(--surface3)}.spells-table th{border-bottom:1px solid var(--border-bright);color:var(--teal);font-family:var(--font-display);font-size:.52rem;letter-spacing:.15em;padding:8px 10px;text-align:left;text-transform:uppercase}.spells-table td{border-bottom:1px solid var(--border);vertical-align:top}.spells-table td input,.spells-table td textarea{border:none;font-size:.9rem;min-height:32px;padding:6px 8px}.spells-table td textarea{min-height:55px}.spell-name-col{width:35%}.spell-mp-col{width:12%}.spell-dur-col,.spell-targets-col{width:18%}.spell-del-col{width:40px}.spell-del-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:.9rem;padding:6px 8px;transition:color .15s}.spell-del-btn:hover{color:var(--red)}.add-btn{align-items:center;background:transparent;border:1px solid var(--teal-dim);color:var(--teal);cursor:pointer;display:inline-flex;font-family:var(--font-display);font-size:.55rem;gap:6px;letter-spacing:.15em;margin-top:8px;padding:6px 14px;text-transform:uppercase;transition:all .15s}.add-btn:hover{background:var(--teal-dim);color:var(--text-bright)}.disciplines-row{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:14px}.disc-item{cursor:pointer;gap:6px;user-select:none}.disc-box,.disc-item{align-items:center;display:flex}.disc-box{border:1px solid var(--border-bright);color:var(--gold);font-size:.6rem;height:13px;justify-content:center;transition:all .15s;width:13px}.disc-item.checked .disc-box{background:var(--gold-dim);border-color:var(--gold)}.disc-item span{color:var(--text-dim);font-family:var(--font-display);font-size:.55rem;letter-spacing:.08em;text-transform:uppercase}.disc-item.checked span{color:var(--gold)}.toolbar{align-items:center;display:flex;gap:8px}.btn-load,.btn-save{background:transparent;border:1px solid var(--gold-dim);color:var(--gold);cursor:pointer;font-family:var(--font-display);font-size:.55rem;letter-spacing:.15em;padding:7px 16px;text-transform:uppercase;transition:all .2s}.btn-save:hover{background:var(--gold-dim);color:var(--text-bright)}.btn-load{border-color:var(--border-bright);color:var(--text-dim)}.btn-export,.btn-load:hover{border-color:var(--teal-dim);color:var(--teal)}.btn-export:hover{background:var(--teal-dim);color:var(--text-bright)}.btn-import{border-color:var(--border-bright);color:var(--text-dim)}.btn-import:hover{border-color:var(--gold-dim);color:var(--gold)}.toolbar-sep{background:var(--border);height:20px;margin:0 4px;width:1px}.save-status{color:var(--teal);font-family:var(--font-mono);font-size:.7rem;opacity:0;transition:opacity .3s}.save-status.show{opacity:1}.ornament{color:var(--gold-dim);font-size:.8rem;letter-spacing:.5em;margin:8px 0;text-align:center}.def-row{display:grid;gap:10px;grid-template-columns:repeat(3,1fr);margin-bottom:14px}.def-block{background:var(--surface2);border:1px solid var(--border);padding:10px 12px;text-align:center}.def-block label{display:block;margin-bottom:6px}.def-block input{font-family:var(--font-mono);font-size:1.2rem;font-weight:600;text-align:center}.url-banner{align-items:center;background:var(--surface2);border-bottom:1px solid var(--teal-dim);color:var(--text-dim);display:flex;font-family:var(--font-body);font-size:.9rem;gap:10px;padding:10px 32px}.url-banner strong{color:var(--text)}.url-banner-icon{color:var(--teal);flex-shrink:0;font-size:.85rem}.manage-grid{display:grid;gap:20px;grid-template-columns:1fr 1fr;max-width:800px}.manage-desc{color:var(--text-dim);font-size:.9rem;line-height:1.6;margin-bottom:18px}.manage-btn-row{display:flex;flex-wrap:wrap;gap:10px}.btn-lg{font-size:.6rem;padding:11px 22px}[data-theme=light]{--bg:#f4efe4;--surface:#ede7d9;--surface2:#e6dfd0;--surface3:#dcd5c3;--border:#c8bfa8;--border-bright:#a89878;--teal:#1a7a76;--teal-dim:#b8e0de;--gold:#7a5a18;--gold-dim:#e8d8a0;--red:#b02a20;--text:#2a2218;--text-dim:#6a5f50;--text-bright:#1a1410;--crisis:#c0392b}[data-theme=light] body{background-image:radial-gradient(ellipse at 20% 10%,rgba(26,122,118,.07) 0,transparent 50%),radial-gradient(ellipse at 80% 90%,rgba(122,90,24,.07) 0,transparent 50%)}[data-theme=light] header{background:linear-gradient(135deg,var(--surface) 0,var(--surface3) 100%);box-shadow:0 4px 24px rgba(0,0,0,.1)}[data-theme=light] input:not([type]):focus,[data-theme=light] input[type=number]:focus,[data-theme=light] input[type=text]:focus,[data-theme=light] select:focus,[data-theme=light] textarea:focus{box-shadow:0 0 0 2px rgba(26,122,118,.15)}[data-theme=light] .fp-pip.filled{box-shadow:0 0 8px rgba(26,122,118,.35)}.btn-theme{background:transparent;border:1px solid var(--border-bright);color:var(--text-dim);cursor:pointer;font-family:var(--font-display);font-size:.55rem;letter-spacing:.12em;padding:7px 12px;text-transform:uppercase;transition:all .2s}.btn-theme:hover{border-color:var(--gold-dim);color:var(--gold)}@media (max-width:900px){.grid-2,.grid-3{grid-template-columns:1fr}.col-span-2{grid-column:span 1}header{flex-direction:column;gap:12px}.tabs{flex-wrap:wrap}}[title]{cursor:help}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border-bright)}::-webkit-scrollbar-thumb:hover{background:var(--teal-dim)}