@import "https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;800&family=Inter:wght@300;400;500;600;700&display=swap";:root{--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--radius-sm:6px;--radius-md:12px;--radius-lg:20px;--radius-round:50%;--font-display:"Cinzel", "Georgia", serif;--font-body:"Inter", "Outfit", system-ui, sans-serif;--font-mono:"Courier New", Courier, monospace;--bg-primary:#18150f;--bg-secondary:#262118;--bg-tertiary:#383124;--card-bg:#383124a6;--card-border:#f59e0b59;--card-border-hover:#f59e0bb3;--text-primary:#fef3c7;--text-secondary:#fde68a;--text-muted:#f59e0b;--color-accent:#f59e0b;--color-accent-hover:#fbbf24;--color-gold:#d4af37;--color-gold-hover:#f1cc5b;--color-success:#3c7d3c;--color-info:#3572b4;--color-warning:#d97706;--gradient-gold:linear-gradient(135deg, #b8860b 0%, #e6ca65 50%, #b8860b 100%);--gradient-dark:linear-gradient(135deg, #262118 0%, #18150f 100%);--gradient-accent:linear-gradient(135deg, #78350f 0%, #f59e0b 100%);--shadow-sm:0 2px 4px #00000080;--shadow-md:0 4px 12px #000000b3;--shadow-lg:0 8px 24px #000000e6;--shadow-gold:0 0 15px #d4af374d;--shadow-glow:0 0 20px #f59e0b66;--transition-fast:.2s cubic-bezier(.4, 0, .2, 1);--transition-normal:.3s cubic-bezier(.4, 0, .2, 1);--transition-slow:.5s cubic-bezier(.4, 0, .2, 1)}.theme-barbarian{--bg-primary:#120e0c;--bg-secondary:#1a1411;--bg-tertiary:#261d19;--card-bg:#261d19a6;--card-border:#d4af3733;--card-border-hover:#d4af3780;--text-primary:#f4ebe1;--text-secondary:#c2b5a7;--text-muted:#8c7d6e;--color-accent:#b12714;--color-accent-hover:#e03b22;--gradient-accent:linear-gradient(135deg, #7c1a0e 0%, #b12714 100%);--shadow-glow:0 0 20px #b1271466}.theme-arcane{--bg-primary:#070913;--bg-secondary:#0c1020;--bg-tertiary:#141b32;--card-bg:#141b32a6;--card-border:#6366f14d;--card-border-hover:#6366f199;--text-primary:#e0e7ff;--text-secondary:#a5b4fc;--text-muted:#6366f1;--color-accent:#6366f1;--color-accent-hover:#818cf8;--gradient-accent:linear-gradient(135deg, #312e81 0%, #6366f1 100%);--shadow-glow:0 0 20px #6366f166}.theme-forest{--bg-primary:#09110d;--bg-secondary:#0e1a14;--bg-tertiary:#16291f;--card-bg:#16291fa6;--card-border:#4a75594d;--card-border-hover:#4a755999;--text-primary:#ecfdf5;--text-secondary:#a7f3d0;--text-muted:#10b981;--color-accent:#10b981;--color-accent-hover:#34d399;--gradient-accent:linear-gradient(135deg, #064e3b 0%, #10b981 100%);--shadow-glow:0 0 20px #10b98166}.theme-shadowfell{--bg-primary:#080808;--bg-secondary:#111;--bg-tertiary:#1c1c1c;--card-bg:#1c1c1ca6;--card-border:#9333ea40;--card-border-hover:#9333ea80;--text-primary:#f3e8ff;--text-secondary:#d8b4fe;--text-muted:#a855f7;--color-accent:#a855f7;--color-accent-hover:#c084fc;--gradient-accent:linear-gradient(135deg, #581c87 0%, #a855f7 100%);--shadow-glow:0 0 20px #a855f766}.theme-divine{--bg-primary:#18150f;--bg-secondary:#262118;--bg-tertiary:#383124;--card-bg:#383124a6;--card-border:#f59e0b59;--card-border-hover:#f59e0bb3;--text-primary:#fef3c7;--text-secondary:#fde68a;--text-muted:#f59e0b;--color-accent:#f59e0b;--color-accent-hover:#fbbf24;--gradient-accent:linear-gradient(135deg, #78350f 0%, #f59e0b 100%);--shadow-glow:0 0 20px #f59e0b66}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--color-gold)}@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background-color:var(--bg-primary);color:var(--text-primary);transition:background-color var(--transition-normal), color var(--transition-normal);line-height:1.5;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);letter-spacing:.05em;color:var(--text-primary);text-shadow:0 2px 4px #0009}.card{background:var(--card-bg);-webkit-backdrop-filter:blur(10px);border:1px solid var(--card-border);border-radius:var(--radius-md);padding:var(--spacing-md);box-shadow:var(--shadow-md);transition:transform var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast)}.card:hover{border-color:var(--card-border-hover);box-shadow:var(--shadow-lg), var(--shadow-glow)}.btn{font-family:var(--font-display);text-transform:uppercase;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);cursor:pointer;justify-content:center;align-items:center;gap:var(--spacing-sm);transition:all var(--transition-fast);color:#fff;text-shadow:0 1px 2px #00000080;border:1px solid #0000;min-height:44px;font-weight:600;display:inline-flex}.btn-primary{background:var(--gradient-accent);border:1px solid var(--color-accent);box-shadow:var(--shadow-sm)}.btn-primary:hover{background:var(--color-accent-hover);box-shadow:var(--shadow-md), var(--shadow-glow);transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{border:1px solid var(--text-secondary);color:var(--text-primary);background:0 0}.btn-secondary:hover{border-color:var(--color-gold);color:var(--color-gold);box-shadow:var(--shadow-gold);background:#ffffff0d;transform:translateY(-2px)}.btn-gold{background:var(--gradient-gold);border:1px solid var(--color-gold);color:#2c1a04;text-shadow:none;font-weight:800}.btn-gold:hover{background:var(--color-gold-hover);box-shadow:var(--shadow-md), var(--shadow-gold);transform:translateY(-2px)}.input{font-family:var(--font-body);border:1px solid var(--card-border);color:var(--text-primary);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);transition:all var(--transition-fast);background:#0000004d;outline:none}.input:focus{border-color:var(--color-gold);box-shadow:var(--shadow-gold)}input[type=number].input{appearance:textfield}input[type=number].input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number].input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}select.input{cursor:pointer;background-color:var(--bg-secondary)!important;color:var(--text-primary)!important}select.input option{color:#fef3c7!important;background-color:#262118!important}.theme-barbarian select.input option{color:#f4ebe1!important;background-color:#1a1411!important}.theme-arcane select.input option{color:#e0e7ff!important;background-color:#0c1020!important}.theme-forest select.input option{color:#ecfdf5!important;background-color:#0e1a14!important}.theme-shadowfell select.input option{color:#f3e8ff!important;background-color:#111!important}.theme-divine select.input option{color:#fef3c7!important;background-color:#262118!important}@keyframes pulseGlow{0%{box-shadow:0 0 10px #b127144d}50%{box-shadow:0 0 25px #b12714b3}to{box-shadow:0 0 10px #b127144d}}@keyframes spinRunic{0%{transform:translate(-50%,-50%)rotate(0)}to{transform:translate(-50%,-50%)rotate(360deg)}}.glow-pulse{animation:2s ease-in-out infinite pulseGlow}.grid-2{gap:var(--spacing-md);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--spacing-md);grid-template-columns:repeat(3,1fr);display:grid}@media (width<=768px){.grid-2,.grid-3{grid-template-columns:1fr}}.app-root{background-color:var(--bg-primary);min-height:100vh;color:var(--text-primary);transition:background-color var(--transition-normal);flex-direction:column;display:flex}.app-header{padding:0 var(--spacing-lg);background:var(--bg-secondary);box-shadow:var(--shadow-md);z-index:10;border-bottom:1px solid #d4af374d;justify-content:space-between;align-items:center;height:64px;display:flex}@media (width<=768px){.app-header{height:56px;padding:0 var(--spacing-md);flex-direction:row;justify-content:center}.header-actions{display:none}}.header-brand{align-items:center;gap:var(--spacing-sm);display:flex}.brand-logo{filter:drop-shadow(0 0 4px var(--color-gold));font-size:1.3rem}.header-brand h1{font-size:1.2rem;font-family:var(--font-display);color:var(--color-gold);letter-spacing:.05em}.header-nav{gap:var(--spacing-xs);align-items:center;height:100%;display:flex}.nav-link{color:var(--text-secondary);font-family:var(--font-display);text-transform:uppercase;letter-spacing:.08em;cursor:pointer;height:64px;transition:all var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;padding:0 16px;font-size:.85rem;font-weight:600;display:flex}.nav-link:hover{color:var(--color-gold);background:#ffffff05}.nav-link.active{color:var(--color-gold);border-bottom-color:var(--color-gold);text-shadow:0 0 6px #d4af3766;background:#d4af3708}.header-actions{align-items:center;gap:var(--spacing-sm);display:flex}.btn-header{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.06em;padding:0 var(--spacing-md);border-radius:var(--radius-sm);cursor:pointer;height:36px;transition:all var(--transition-fast);color:var(--text-secondary);border:1px solid var(--card-border);background:#ffffff05;justify-content:center;align-items:center;gap:6px;font-size:.8rem;font-weight:600;display:inline-flex}.btn-header:hover{border-color:var(--color-gold);color:var(--color-gold);background:#ffffff0f;box-shadow:0 0 10px #d4af3726}.btn-header-primary{background:var(--gradient-gold);border:1px solid var(--color-gold);color:#1a1411;font-weight:800}.btn-header-primary:hover{background:var(--color-gold-hover);box-shadow:var(--shadow-gold), 0 0 12px #d4af3759;color:#1a1411}.user-profile-badge{align-items:center;gap:var(--spacing-sm);padding:0 var(--spacing-sm) 0 var(--spacing-md);border:1px solid var(--card-border);border-radius:var(--radius-sm);height:36px;transition:all var(--transition-fast);background:#00000040;display:flex}.user-profile-badge:hover{border-color:#d4af3766}.user-name{color:var(--text-secondary);align-items:center;gap:6px;font-size:.8rem;font-weight:500;display:flex}.admin-badge{font-size:.65rem;font-family:var(--font-display);background:var(--color-gold);color:#120e0c;letter-spacing:.05em;border-radius:3px;padding:1px 5px;font-weight:800}.logout-btn-clean{color:var(--text-muted);font-family:var(--font-display);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;padding:4px 8px;font-size:.75rem;font-weight:600}.logout-btn-clean:hover{color:var(--color-accent);text-shadow:0 0 5px #b1271433}.app-main{transition:grid-template-columns var(--transition-normal);flex-grow:1;grid-template-columns:1fr 0;display:grid;overflow:hidden}.app-main.drawer-open{grid-template-columns:1fr 340px}@media (width<=1024px){.app-main,.app-main.drawer-open{grid-template-columns:1fr}}.main-content-column{padding:var(--spacing-md);height:calc(100vh - 64px);overflow-y:auto}@media (width<=480px){.main-content-column{padding:var(--spacing-sm)}}@media (width<=768px){.main-content-column{height:calc(100vh - 128px);padding-bottom:80px}.header-nav{display:none}}.dice-roller-column{border-left:1px solid var(--card-border);background:var(--bg-secondary);height:calc(100vh - 64px);transition:transform var(--transition-normal);display:none;overflow-y:auto;transform:translate(100%)}.app-main.drawer-open .dice-roller-column{display:block;transform:translate(0)}@media (width<=1024px){.dice-roller-column{z-index:50;width:320px;box-shadow:var(--shadow-lg);border-left:2px solid var(--color-gold);position:fixed;top:64px;bottom:0;right:0}.dice-roller-column.open{display:block;transform:translate(0)}}.party-roll-toast{background:var(--bg-secondary);border:2px solid var(--color-gold);padding:var(--spacing-md);border-radius:var(--radius-md);box-shadow:var(--shadow-lg), var(--shadow-gold);align-items:center;gap:var(--spacing-md);z-index:200;max-width:350px;animation:slideInToast var(--transition-normal) forwards;display:flex;position:fixed;bottom:20px;right:20px}@keyframes slideInToast{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}.toast-logo{font-size:2.2rem;animation:.6s ease-in-out shakeDice}.toast-body{color:var(--text-primary);font-size:.9rem}.toast-total{font-family:var(--font-display);color:var(--color-gold);margin:0 4px;font-size:1.4rem;font-weight:700}.toast-formula{color:var(--text-muted);margin-top:2px;font-size:.75rem}.bottom-nav{background:var(--bg-secondary);border-top:2px solid var(--color-gold);z-index:100;justify-content:space-around;align-items:center;height:64px;display:none;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 10px #0006}@media (width<=768px){.bottom-nav{display:flex}.dice-roller-column{z-index:90;width:100%;height:calc(100vh - 128px);position:fixed;top:auto;bottom:64px}}.bottom-nav-item{color:var(--text-secondary);font-family:var(--font-display);cursor:pointer;height:100%;transition:all var(--transition-fast);background:0 0;border:none;flex-direction:column;flex-grow:1;justify-content:center;align-items:center;gap:4px;font-size:.75rem;font-weight:600;display:flex}.bottom-nav-item.active{color:var(--color-gold);text-shadow:0 0 5px #d4af3766;background:#d4af370d}.bottom-nav-icon{font-size:1.2rem}.character-dropdown-select{border:1px solid var(--card-border);color:var(--color-gold);height:32px;font-family:var(--font-display);border-radius:var(--radius-sm);cursor:pointer;margin-left:var(--spacing-sm);transition:all var(--transition-fast);background-color:#00000059;outline:none;padding:0 10px;font-size:.8rem;font-weight:600}.character-dropdown-select:hover{border-color:var(--color-gold);background-color:#d4af370d}.character-dropdown-select:focus{border-color:var(--color-gold-hover,#ffdf7a);box-shadow:0 0 8px #d4af3766}.character-dropdown-select option{background-color:var(--bg-secondary);color:var(--text-primary)}.modal-overlay{z-index:1100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:var(--spacing-md);background:#000000d9;justify-content:center;align-items:center;animation:.2s ease-out modalFadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-secondary);border:2px solid var(--color-gold);border-radius:var(--radius-lg);width:100%;padding:var(--spacing-lg);box-shadow:var(--shadow-lg), var(--shadow-gold);animation:.2s ease-out modalScaleUp;position:relative}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalScaleUp{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.character-sheet-card{background:var(--bg-secondary);border:1px solid var(--card-border);gap:var(--spacing-md);flex-direction:column;height:100%;display:flex;overflow-y:auto}.char-header{gap:var(--spacing-md);border-bottom:1px solid var(--card-border);padding-bottom:var(--spacing-sm);flex-wrap:wrap;align-items:center;display:flex}.avatar-frame{width:64px;height:64px;color:var(--color-gold);flex-shrink:0;margin:5px;position:relative}.avatar-ring{pointer-events:none;filter:drop-shadow(0 0 3px #00000080);width:calc(100% + 10px);height:calc(100% + 10px);position:absolute;inset:-5px}.avatar-placeholder{background:var(--bg-tertiary);border-radius:var(--radius-round);width:100%;height:100%;box-shadow:var(--shadow-sm);justify-content:center;align-items:center;font-size:1.8rem;display:flex}.avatar-image{border-radius:var(--radius-round);object-fit:cover;width:100%;height:100%;box-shadow:var(--shadow-sm);display:block}.nfc-bind-trigger{text-transform:none;background:#0006;min-height:auto;padding:4px 10px;font-size:.7rem}.char-identity{gap:var(--spacing-xs);flex-direction:column;flex-grow:1;min-width:0;display:flex}.char-name-row{align-items:center;gap:var(--spacing-md);display:flex}.char-name-input{font-family:var(--font-display);padding:var(--spacing-xs) 0;border-color:#0000;border-bottom:2px solid var(--card-border);color:var(--color-gold);background:0 0;border-radius:0;flex:0 360px;min-width:140px;font-size:1.5rem;font-weight:700}.char-name-input:focus{border-color:var(--color-gold);box-shadow:none}.header-flourish{min-width:80px;color:var(--color-gold);opacity:.65;flex:1;align-items:center;display:flex}.header-flourish:before,.header-flourish:after{content:"";flex:1;height:1px}.header-flourish:before{background:linear-gradient(90deg,#0000,currentColor)}.header-flourish:after{background:linear-gradient(90deg,currentColor,#0000)}.flourish-gem{flex-shrink:0;width:64px;height:18px}.char-details-row{align-items:center;gap:var(--spacing-sm);display:flex}.detail-gem{width:9px;height:9px;color:var(--color-gold);opacity:.7;flex-shrink:0}.char-sub-input{border-color:#0000;border-bottom:1px solid var(--card-border);background:0 0;border-radius:0;flex:0 140px;width:auto;min-width:70px;padding:2px 0;font-size:.85rem}.char-sub-input:focus{border-color:var(--color-gold);box-shadow:none}.header-right{flex-direction:column;align-items:flex-end;gap:6px;margin-left:auto;display:flex}.level-input-box{font-family:var(--font-display);color:var(--text-secondary);align-items:center;gap:6px;font-size:.8rem;display:flex}.header-level{border:1px solid var(--card-border);background:#00000040;border-radius:999px;padding:4px 10px}.level-label{letter-spacing:.08em}.level-btn{border-radius:50%;justify-content:center;align-items:center;width:22px;min-width:auto;height:22px;min-height:auto;padding:0;font-size:.8rem;line-height:1;display:flex}.char-num-input{text-align:center;width:45px;padding:2px;font-weight:700}.level-num{width:38px;font-family:var(--font-display);color:var(--color-gold);background:0 0;border-color:#0000;font-size:1rem}@media (width<=768px){.char-header{text-align:center;gap:var(--spacing-sm);flex-direction:column;align-items:center}.char-identity{align-items:center;width:100%}.char-name-row{justify-content:center;width:100%}.char-name-input{text-align:center;flex:auto}.header-flourish{display:none}.char-details-row{justify-content:center;width:100%}.char-sub-input{text-align:center}.header-right{align-items:center;margin-left:0}}.char-vitals-row{gap:var(--spacing-sm);grid-template-columns:2fr 1fr 1fr 1fr;display:grid}@media (width<=768px){.char-vitals-row{grid-template-columns:repeat(3,1fr)}.char-vitals-row .vital-item:first-child{grid-column:span 3}}.vital-item{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:80px;display:flex;padding:var(--spacing-sm)!important;background:var(--bg-tertiary)!important}.vital-item.clickable{cursor:pointer}.vital-item.clickable:hover{transform:translateY(-2px)}.vital-label{color:var(--text-muted);text-transform:uppercase;font-size:.75rem}.hp-inputs{margin:var(--spacing-xs) 0;justify-content:center;align-items:center;gap:4px;display:flex}.hp-val{text-align:center;background:#0006;width:50px;padding:2px;font-size:1.1rem;font-weight:700}.slash{color:var(--text-muted);font-weight:700}.temp-hp-box{color:var(--text-secondary);align-items:center;gap:2px;font-size:.7rem;display:flex}.temp-hp-input{text-align:center;width:35px;padding:1px;font-size:.75rem}.vital-value{font-family:var(--font-display);color:var(--color-gold);margin:var(--spacing-xs) 0}.click-to-roll{color:var(--text-muted);text-transform:uppercase;font-size:.65rem}.ac-input,.speed-input{text-align:center;width:50px;margin-top:4px;padding:2px;font-size:1.2rem;font-weight:700}.sheet-tabs{border-bottom:2px solid var(--card-border);flex-shrink:0;gap:2px;display:flex;overflow-x:auto}.tab-btn{color:var(--text-secondary);cursor:pointer;font-family:var(--font-display);transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;flex-grow:1;padding:10px;font-size:.85rem}.tab-btn:hover{color:var(--color-gold);background:#ffffff05}.tab-btn.active{color:var(--color-gold);border-bottom:3px solid var(--color-gold);background:#ffffff0d;font-weight:700}.tab-content{flex-grow:1}.sheet-tabs-content-container{gap:var(--spacing-md);grid-template-columns:1fr 1fr 2fr;align-items:stretch;width:100%;display:grid}@media (width<=1024px){.sheet-tabs-content-container{grid-template-columns:1fr}}.tab-content.inventory-tab.active{flex-direction:column;gap:12px;display:flex}.tab-content.sheet-col.active{gap:var(--spacing-md);flex-direction:column;display:flex}.abilities-row{justify-content:space-between;align-items:stretch;gap:var(--spacing-md);flex-wrap:wrap;display:flex}.secondary-vitals .vital-item,.hp-vital-wrap .vital-item{height:100%}.hp-box{min-width:230px}.hp-ddb{justify-content:center;align-items:center;gap:10px;margin-top:2px;display:flex}.hp-heal-dmg{flex-direction:column;align-items:center;gap:3px;display:flex}.hp-amount{text-align:center;width:48px;padding:2px;font-size:.85rem}.hp-btns{gap:3px;display:flex}.hp-heal-btn,.hp-dmg-btn{text-transform:uppercase;letter-spacing:.3px;cursor:pointer;background:0 0;border:1px solid;border-radius:3px;padding:2px 6px;font-size:.6rem}.hp-heal-btn{color:#86efac;background:#22c55e26;border-color:#22c55e}.hp-heal-btn:hover{background:#22c55e4d}.hp-dmg-btn{color:#fca5a5;background:#ef444426;border-color:#ef4444}.hp-dmg-btn:hover{background:#ef44444d}.hp-cm{align-items:flex-end;gap:6px;display:flex}.hp-cm-item{flex-direction:column;align-items:center;gap:1px;display:flex}.hp-sub{color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;font-size:.55rem}.hp-slash{color:var(--text-muted);padding-bottom:2px;font-size:1.1rem}.hp-cm .hp-val{text-align:center;width:42px;font-size:1.05rem;font-family:var(--font-display);color:var(--color-gold);padding:2px}.hp-cm .hp-temp{color:#93c5fd}.secondary-vitals{gap:var(--spacing-sm);display:flex}.abilities-row .vital-item{min-width:76px}.hp-vital-wrap{display:flex}.status-group{align-items:stretch;gap:var(--spacing-sm);display:flex}.concentration-box{justify-content:center;gap:4px}.switch{cursor:pointer;width:42px;height:22px;margin-top:4px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.switch-slider{border:1px solid var(--card-border);background:#ffffff1f;border-radius:22px;transition:background .2s,border-color .2s;position:absolute;inset:0}.switch-slider:before{content:"";background:#cbd5e1;border-radius:50%;width:16px;height:16px;transition:transform .2s,background .2s;position:absolute;top:2px;left:2px}.switch input:checked+.switch-slider{background:#3b82f680;border-color:#3b82f6}.switch input:checked+.switch-slider:before{background:#bfdbfe;transform:translate(20px)}.conditions-box{cursor:pointer;z-index:30;min-width:130px;max-width:220px;position:relative}.conditions-summary{flex-wrap:wrap;justify-content:center;gap:3px;margin-top:2px;display:flex}.conditions-none{color:var(--text-muted);font-size:.85rem}.cond-chip{color:#fca5a5;white-space:nowrap;background:#ef444426;border:1px solid #ef444480;border-radius:8px;padding:1px 5px;font-size:.6rem}.cond-chip.cond-exhaustion{color:#d8b4fe;background:#a855f726;border-color:#a855f780}.cond-chip.cond-positive{color:#86efac;background:#22c55e26;border-color:#22c55e80}.cond-chip.cond-concentration{color:#93c5fd;background:#3b82f626;border-color:#3b82f680}.cond-concentration-row{color:var(--text-secondary);cursor:pointer;border-bottom:1px dashed #ffffff1a;align-items:center;gap:6px;margin-bottom:6px;padding-bottom:6px;font-size:.78rem;display:flex}.cond-concentration-row input{margin:0}.cond-group-label{text-transform:uppercase;letter-spacing:.5px;color:var(--color-gold);margin:6px 0 3px;font-size:.62rem}.cond-option-positive{color:#86efac}.conditions-dropdown{z-index:40;background:var(--bg-secondary,#1a1410);border:1px solid var(--color-gold);border-radius:var(--radius-sm);cursor:default;width:230px;padding:8px;position:absolute;top:calc(100% + 4px);left:50%;transform:translate(-50%);box-shadow:0 8px 20px #00000080}.cond-exhaustion-row{color:var(--text-secondary);border-bottom:1px dashed #ffffff1a;justify-content:space-between;align-items:center;gap:6px;margin-bottom:6px;padding-bottom:6px;font-size:.75rem;display:flex}.cond-exh-val{font-family:var(--font-display);color:var(--color-gold);text-align:center;min-width:14px}.cond-list{grid-template-columns:1fr 1fr;gap:2px 6px;max-height:210px;display:grid;overflow-y:auto}.cond-option{color:var(--text-primary);cursor:pointer;align-items:center;gap:4px;font-size:.72rem;display:flex}.cond-option input{margin:0}.attributes-grid{gap:var(--spacing-sm);grid-template-columns:repeat(6,minmax(0,116px));margin-bottom:0;display:grid}@media (width<=1024px){.attributes-grid{grid-template-columns:repeat(3,minmax(0,116px))}}@media (width<=480px){.attributes-grid{grid-template-columns:repeat(3,1fr)}}.attribute-card{text-align:center;align-items:center;background:var(--bg-tertiary)!important;padding:4px 6px!important}.attr-name{font-family:var(--font-display);color:var(--text-muted);font-size:.8rem}.attr-mod-box{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);background:#0000004d;border:1px solid #0000;margin:2px 0;padding:2px 4px}.attr-mod-box:hover{border-color:var(--color-gold);background:#00000080;transform:scale(1.05)}.attr-mod-box h2{color:var(--text-primary);margin:0;font-size:1.2rem}.roll-hint{color:var(--text-muted);text-transform:uppercase;font-size:.6rem}.attr-score-input{text-align:center;width:45px;padding:2px;font-size:.85rem}.saves-grid{gap:var(--spacing-sm);grid-template-columns:repeat(2,1fr);display:grid}.save-prof-dot{border:1px solid var(--color-gold);border-radius:var(--radius-sm);opacity:.5;flex-shrink:0;width:14px;height:14px;display:inline-block;position:relative}.save-prof-dot.on{opacity:1}.save-prof-dot.on:after{content:"";background:var(--color-gold);border-radius:2px;width:8px;height:8px;position:absolute;top:2px;left:2px}@media (width<=768px){.saves-grid{grid-template-columns:1fr}}.sheet-text-field{margin-top:var(--spacing-sm);flex-direction:column;gap:4px;display:flex}.sheet-text-field label{letter-spacing:.5px;color:var(--color-gold);font-size:.72rem;font-family:var(--font-display);text-transform:uppercase}.sheet-text-field textarea{resize:vertical;width:100%;font-size:.8rem;line-height:1.4}.passives-grid{gap:var(--spacing-sm);grid-template-columns:repeat(3,1fr);display:grid}.passive-item{text-align:center;background:var(--bg-tertiary);border:1px solid var(--card-border);border-radius:var(--radius-sm);flex-direction:column;justify-content:center;align-items:center;padding:6px 4px;display:flex}.passive-value{font-family:var(--font-display);color:var(--color-gold);font-size:1.3rem;line-height:1.1}.passive-label{color:var(--text-muted);text-transform:uppercase;font-size:.6rem}.add-action-form{gap:var(--spacing-sm);margin-bottom:var(--spacing-md);flex-wrap:wrap;display:flex}.add-action-form .input{flex:70px;min-width:56px}.add-action-form .input:first-child{flex:2 120px}.actions-table{margin-bottom:var(--spacing-md);flex-direction:column;gap:4px;display:flex}.actions-row{border-radius:var(--radius-sm);border-left:3px solid var(--color-gold);background:#0003;grid-template-columns:1.5fr .8fr 1fr 1.7fr 78px;align-items:center;gap:6px;padding:6px 8px;font-size:.8rem;display:grid}.actions-row.actions-head{color:var(--text-muted);text-transform:uppercase;background:0 0;border-left:3px solid #0000;padding:0 8px;font-size:.62rem}.action-name{color:var(--color-gold);font-weight:600}.actions-derived-hint{color:var(--text-muted);margin:-6px 0 12px;font-size:.75rem}.action-source-badge{text-transform:uppercase;letter-spacing:.05em;border:1px solid var(--card-border);color:var(--text-muted);background:#00000040;border-radius:3px;place-self:center start;padding:2px 6px;font-size:.65rem}.action-source-badge.source-weapon{color:var(--color-gold);border-color:#d4af3766}.action-source-badge.source-species{color:#6ee7b7;border-color:#6ee7b759}.action-source-badge.source-class{color:#93c5fd;border-color:#93c5fd59}.action-source-badge.source-combat{color:#fca5a5;border-color:#fca5a559}.action-source-badge.source-spell{color:#d8b4fe;border-color:#d8b4fe59}.action-source-badge.source-subclass{color:#c4b5fd;border-color:#c4b5fd59}.action-econ-section{margin-bottom:var(--spacing-md)}.spell-level-group{margin-bottom:10px}.spell-level-header{font-family:var(--font-display);color:var(--color-gold);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px dashed #d4af3740;margin:8px 0 4px;padding-bottom:3px;font-size:.85rem}.spell-table{flex-direction:column;gap:3px;display:flex}.spell-table-row{background:#00000026;border-left:3px solid #d4af3759;border-radius:4px;grid-template-columns:26px 1.4fr 42px .75fr .85fr 1.05fr 1.35fr 22px;align-items:center;gap:8px;padding:4px 6px;font-size:.82rem;display:grid}.spell-table-row.spell-table-head{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;background:0 0;border-left:3px solid #0000;padding:0 6px;font-size:.66rem}.spell-table-row .spell-name-display{font-weight:600}.spell-table-dc{font-family:var(--font-mono,monospace);white-space:nowrap;font-size:.78rem}.spell-table-effect{color:var(--text-primary)}.spell-table-notes{color:var(--text-muted);font-size:.74rem}.action-econ-title{font-family:var(--font-display);color:var(--color-gold);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px dashed #d4af3740;margin:0 0 6px;padding-bottom:4px;font-size:.9rem}.action-econ-empty{color:var(--text-muted);margin:0;font-size:.75rem;font-style:italic}.action-econ-hint{color:var(--text-muted);margin:6px 0 0;font-size:.7rem}.actions-row.actions-note-row{grid-template-columns:1.5fr 3.5fr 78px}.action-note{color:var(--text-secondary);font-size:.75rem}.attunement-slots-panel{margin-top:var(--spacing-md)}.attunement-slots{flex-direction:column;gap:4px;display:flex}.attunement-slot{border-radius:var(--radius-sm);background:#0003;border-left:3px solid #0000;align-items:center;gap:8px;padding:6px 8px;font-size:.8rem;display:flex}.attunement-slot.filled{border-left-color:#9370db}.attunement-slot.filled .attunement-slot-gem{color:#b9a3e3}.attunement-slot.filled .attunement-slot-name{color:var(--text-primary);font-weight:600}.attunement-slot.empty .attunement-slot-gem,.attunement-slot.empty .attunement-slot-name{color:var(--text-muted);font-style:italic}.attunement-slot .attune-btn{margin-left:auto}.class-trait-panels{gap:var(--spacing-md);margin-top:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.class-trait-panel{border:1px solid var(--card-border);border-radius:var(--radius-sm);background:#0003;padding:10px 12px}.class-trait-list{color:var(--text-primary);flex-direction:column;gap:4px;margin:0;padding-left:18px;font-size:.8rem;display:flex}.infusions-panel{margin-top:var(--spacing-md)}.infusion-list{flex-direction:column;gap:4px;display:flex}.infusion-row{border-radius:var(--radius-sm);background:#0003;border-left:3px solid #0000;align-items:center;gap:8px;padding:6px 8px;font-size:.8rem;display:flex}.infusion-row.infusion-active{border-left-color:#60a5fa}.infusion-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:600;overflow:hidden}.infusion-row.infusion-active .infusion-name{color:#93c5fd}.infusion-status{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;max-width:40%;font-size:.72rem;overflow:hidden}.infusion-status.muted{color:var(--text-muted);font-style:italic}.infusion-target-select{max-width:150px;padding:2px 6px;font-size:.72rem}.infusion-item-badge{color:#93c5fd;white-space:nowrap;background:#60a5fa1f;border:1px solid #60a5fa66;border-radius:999px;padding:2px 6px;font-size:.65rem}.crafting-check-badge{color:var(--color-gold);cursor:pointer;background:#d4af371f;border:1px solid #d4af3766;border-radius:999px;padding:2px 7px;font-size:.68rem;font-weight:700}.crafting-check-badge:hover{background:#d4af3740}.crafting-check-line{color:var(--text-secondary);flex-wrap:wrap;align-items:center;gap:6px;margin:0 0 8px;font-size:.82rem;display:flex}.crafting-roll-btn{margin-left:6px;padding:2px 12px!important;font-size:.7rem!important}.crafting-professions-row{flex-wrap:wrap;gap:10px;margin-top:8px;display:flex}.crafting-profession-chip{border:1px solid var(--card-border);background:#00000040;border-radius:999px;align-items:center;gap:8px;padding:4px 12px;display:flex}.crafting-profession-name{font-family:var(--font-display);color:var(--color-gold);letter-spacing:.04em;font-size:.78rem}.crafting-recipes-list{flex-direction:column;gap:6px;margin-top:8px;display:flex}.crafting-recipe{border:1px solid var(--card-border);border-radius:var(--radius-sm);background:#0003;padding:8px 12px}.crafting-recipe-header{cursor:pointer}.crafting-recipe-header:hover h4{text-shadow:0 0 8px #d4af3766}.crafting-recipe-body{border-top:1px dashed #d4af3740;margin-top:8px;padding-top:8px;font-size:.85rem;line-height:1.5}.rest-toast{z-index:1200;background:var(--bg-secondary,#15120c);border:1px solid var(--color-gold);border-radius:var(--radius-md);box-shadow:var(--shadow-lg,0 8px 24px #0009);color:var(--color-gold);animation:slideInToast var(--transition-normal,.25s ease) forwards;padding:10px 18px;font-size:.85rem;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.rest-buttons{gap:6px;display:flex}.rest-btn{text-transform:none!important;padding:4px 10px!important;font-size:.7rem!important}.calc-link{cursor:pointer}.calc-link:hover{color:var(--color-gold);text-underline-offset:3px;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.ac-breakdown-note{color:var(--text-muted);white-space:pre-line;margin:6px 0 0;font-size:.7rem;font-style:italic}.attribute-card{position:relative}.attribute-card.attr-boosted{border-color:#9370db80!important}.attr-boost-badge{color:#b9a3e3;background:#9370db26;border:1px solid #9370db73;border-radius:999px;padding:1px 5px;font-size:.6rem;font-weight:700;position:absolute;top:4px;right:6px}.char-size-select{max-width:110px;flex:none!important}.hp-hit-dice{color:var(--text-muted);text-align:center;letter-spacing:.04em;margin-top:4px;font-size:.68rem}.death-saves{flex-direction:column;justify-content:center;gap:4px;display:flex}.death-saves-hint{color:var(--text-muted);font-size:.6rem;font-style:italic}.hp-cm-col{flex-direction:column;align-items:center;gap:2px;display:flex}.death-saves-row{align-items:center;gap:6px;display:flex}.death-saves-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;width:86px;font-size:.65rem}.death-save-bubble{border:1.5px solid var(--text-muted);cursor:pointer;width:14px;height:14px;transition:all var(--transition-fast);border-radius:50%}.death-save-bubble.success{border-color:#6ee7b7}.death-save-bubble.success.filled{background:#6ee7b7;box-shadow:0 0 6px #6ee7b799}.death-save-bubble.failure{border-color:#f87171}.death-save-bubble.failure.filled{background:#f87171;box-shadow:0 0 6px #f8717199}.spellcasting-stats{gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(140px,1fr));display:grid;padding:var(--spacing-md)!important;margin-bottom:var(--spacing-md)!important}.spellcasting-stat{border:1px solid var(--card-border);border-radius:var(--radius-sm);background:#0003;flex-direction:column;align-items:center;gap:2px;padding:10px 8px;display:flex}.spellcasting-stat.clickable:hover{border-color:var(--color-gold);cursor:pointer}.spellcasting-stat-value{font-family:var(--font-display);color:var(--color-gold);font-size:1.3rem;font-weight:700}.spellcasting-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.62rem}.ac-breakdown-drawer{z-index:1000;background:var(--bg-secondary,#15120c);border:2px solid var(--color-gold);border-radius:var(--radius-md) 0 0 var(--radius-md);width:300px;max-height:calc(100vh - 100px);box-shadow:var(--shadow-lg,0 8px 24px #0009);text-align:left;cursor:default;animation:acDrawerSlideIn var(--transition-normal,.25s ease) forwards;border-right:none;padding:12px 14px;position:fixed;top:80px;right:0;overflow-y:auto}@keyframes acDrawerSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.ac-breakdown-header{font-family:var(--font-display);color:var(--color-gold);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px dashed #d4af3740;justify-content:space-between;align-items:center;margin-bottom:6px;padding-bottom:4px;font-size:.8rem;display:flex}.ac-breakdown-row{color:var(--text-primary);justify-content:space-between;gap:8px;padding:2px 0;font-size:.78rem;display:flex}.ac-breakdown-label{color:var(--text-secondary)}.ac-breakdown-value{color:var(--text-primary);font-weight:600}.ac-breakdown-total{color:var(--color-gold);border-top:1px solid #d4af3759;margin-top:4px;padding-top:4px;font-weight:700}.ac-breakdown-mismatch{border-top:1px dashed #d4af3733;margin-top:6px;padding-top:6px}.ac-breakdown-mismatch p{color:var(--text-muted);margin:0 0 6px;font-size:.7rem}.ac-breakdown-apply{width:100%;padding:4px 10px!important;font-size:.7rem!important}.attunement-counter{color:var(--text-muted);font-size:.72rem;font-family:var(--font-body);letter-spacing:.04em}.inventory-item.item-equipped{border-left:2px solid var(--color-gold);padding-left:6px}.equip-btn,.attune-btn{border:1px solid var(--card-border);color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast), border-color var(--transition-fast), background var(--transition-fast);white-space:nowrap;background:#0000004d;border-radius:999px;align-items:center;gap:4px;padding:2px 8px;font-size:.68rem;display:inline-flex}.equip-btn:hover,.attune-btn:hover:not(:disabled){color:var(--color-gold);border-color:var(--color-gold)}.equip-btn.on{color:var(--color-gold);border-color:var(--color-gold);background:#d4af371f}.attune-btn.on{color:#c4b5fd;background:#8b5cf61f;border-color:#8b5cf6}.attune-btn:disabled{opacity:.4;cursor:not-allowed}.section-title{color:var(--color-gold);margin-bottom:var(--spacing-md);border-bottom:1px solid #ffffff0d;padding-bottom:4px;font-size:1.1rem}.skills-grid{gap:var(--spacing-sm);grid-template-columns:1fr;display:grid}.skill-item{align-items:center;gap:var(--spacing-sm);font-size:.85rem;display:flex}.skill-item input[type=checkbox]{display:none}.skill-trained-label{border:1px solid var(--color-gold);border-radius:var(--radius-sm);cursor:pointer;width:14px;height:14px;display:inline-block;position:relative}.skill-item input[type=checkbox]:checked+.skill-trained-label:after{content:"";background:var(--color-gold);border-radius:2px;width:8px;height:8px;position:absolute;top:2px;left:2px}.skill-modifier{font-weight:700;font-family:var(--font-mono);border-radius:var(--radius-sm);cursor:pointer;background:#0000004d;border:1px solid #0000;padding:2px 6px}.skill-modifier:hover{border-color:var(--color-gold);color:var(--color-gold)}.skill-name{flex-grow:1}.skill-parent-attr{color:var(--text-muted);font-size:.75rem}.spell-slots-grid{gap:var(--spacing-sm);margin-bottom:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(92px,1fr));display:grid}@media (width<=768px){.spell-slots-grid{grid-template-columns:repeat(3,1fr)}}.slot-tracker-card{text-align:center;padding:var(--spacing-sm)!important;background:var(--bg-tertiary)!important}.slot-level{font-family:var(--font-display);color:var(--text-secondary);font-size:.8rem}.slot-editor{margin:var(--spacing-xs) 0;justify-content:space-around;gap:2px;display:flex}.slot-group{color:var(--text-muted);flex-direction:column;align-items:center;font-size:.65rem;display:flex}.slot-num{text-align:center;width:28px;padding:1px;font-size:.75rem}.slot-bubbles{flex-wrap:wrap;justify-content:center;gap:4px;margin-top:4px;display:flex}.slot-bubble{cursor:pointer;border:1px solid var(--color-gold);border-radius:50%;width:10px;height:10px}.slot-bubble.empty{background:0 0}.slot-bubble.used{background:var(--color-gold);box-shadow:0 0 5px var(--color-gold)}.add-spell-form,.add-item-form{gap:var(--spacing-sm);margin-bottom:var(--spacing-md);display:flex}.add-spell-input,.add-item-name{flex-grow:1}.add-spell-level,.add-item-qty{width:80px}.item-suggestions{z-index:30;background:var(--bg-secondary,#1a1410);border:1px solid var(--color-gold);border-radius:var(--radius-sm);max-height:240px;margin:0;padding:4px;list-style:none;position:absolute;top:calc(100% + 2px);left:0;right:0;overflow-y:auto;box-shadow:0 8px 20px #00000080}.item-suggestion{color:var(--text-primary);cursor:pointer;border-radius:var(--radius-sm);padding:6px 10px;font-size:.85rem}.item-suggestion:hover{color:var(--color-gold);background:#d4af3726}.spells-list,.inventory-list{gap:var(--spacing-sm);flex-direction:column;max-height:300px;display:flex;overflow-y:auto}.spell-list-item,.inventory-item{border-radius:var(--radius-sm);border-left:3px solid var(--color-gold);align-items:center;gap:var(--spacing-sm);background:#0003;padding:6px 12px;display:flex}.btn-prep{cursor:pointer;background:0 0;border:none;font-size:.9rem}.btn-prep.unprepared{opacity:.3;filter:grayscale()}.btn-prep.prepared{opacity:1;filter:none;text-shadow:0 0 5px var(--color-gold)}.spell-name-display,.item-name{flex-grow:1;font-size:.9rem}.spell-level-badge{background:var(--bg-tertiary);border-radius:var(--radius-sm);color:var(--text-secondary);padding:2px 6px;font-size:.75rem}.remove-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:1.2rem;line-height:1}.remove-btn:hover{color:var(--color-accent)}.no-spells,.no-items{text-align:center;color:var(--text-muted);padding:var(--spacing-md) 0;font-size:.85rem}.item-qty{font-family:var(--font-mono);color:var(--color-gold);font-weight:700}.theme-selectors-grid{gap:var(--spacing-sm);margin-top:var(--spacing-sm);grid-template-columns:repeat(2,1fr);display:grid}@media (width<=480px){.theme-selectors-grid{grid-template-columns:1fr}}.theme-select-btn{border-color:var(--card-border);padding:10px;font-size:.8rem}.theme-select-btn.active{border-color:var(--color-gold);color:var(--color-gold);background:#ffffff0d}@media (width<=480px){.attributes-grid{grid-template-columns:repeat(2,1fr)}}.tab-content{display:none}.tab-content.active{display:block}.tab-content.card{margin:0!important}.level-up-modal-overlay{z-index:1100;-webkit-backdrop-filter:blur(8px)saturate(180%);padding:var(--spacing-md);background-color:#0a0a0ab3;justify-content:center;align-items:center;animation:.25s ease-out fadeIn;display:flex;position:fixed;inset:0}.level-up-modal-content{border-radius:var(--radius-md);width:100%;padding:24px;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;box-shadow:0 8px 32px #00000080,0 0 15px #d4af3733;border:1px solid var(--color-gold)!important;background:#1a1a1ae6!important}.level-btn{transition:all var(--transition-fast) ease-in-out}.level-btn:hover{background:var(--color-gold)!important;color:var(--color-bg,#1a1a1a)!important}.choice-grid{gap:var(--spacing-sm);margin-top:8px;display:grid}.choice-card{border-radius:var(--radius-sm);padding:var(--spacing-sm);cursor:pointer;transition:all var(--transition-fast) ease-in-out;border:1px solid var(--card-border)!important;background:#00000040!important;border-left:3px solid #0000!important}.choice-card:hover{transform:translateY(-1px);background:#ffffff08!important;border-color:#d4af3780!important}.choice-card.active{box-shadow:0 0 10px #d4af371a;border-color:var(--color-gold)!important;border-left:3px solid var(--color-gold)!important;background:#d4af3714!important}.modal-section{gap:var(--spacing-xs);flex-direction:column;display:flex}.score-method-tabs{border-bottom:1px solid var(--card-border);gap:4px;display:flex}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){.level-up-modal-overlay,.level-up-modal-content,.level-btn,.choice-card,.attr-mod-box{transition:none!important;animation:none!important;transform:none!important}}.compendium-container{gap:var(--spacing-md);border-radius:var(--radius-lg);flex-direction:column;height:100%;animation:.3s ease-out fadeIn;display:flex;background:var(--bg-secondary)!important;border:1px solid var(--card-border)!important;padding:var(--spacing-lg)!important}.compendium-controls{justify-content:space-between;align-items:center;gap:var(--spacing-md);flex-wrap:wrap;flex-shrink:0;display:flex}.compendium-search-box{flex:1;align-items:center;min-width:250px;display:flex;position:relative}.search-icon{color:var(--text-muted);font-size:.95rem;position:absolute;left:12px}.search-input{width:100%;font-size:.9rem;border-color:var(--card-border)!important;padding-left:36px!important}.clear-search-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:1.2rem;position:absolute;right:12px}.clear-search-btn:hover{color:var(--color-gold)}.ruleset-filter-group{border-radius:var(--radius-md);border:1px solid var(--card-border);background:#0003;gap:4px;padding:4px;display:flex}.ruleset-toggle-btn{min-width:auto!important;color:var(--text-muted)!important;transition:all var(--transition-fast)!important;background:0 0!important;border:none!important;padding:6px 12px!important;font-size:.75rem!important}.ruleset-toggle-btn.active{border-radius:var(--radius-sm);font-weight:700;box-shadow:0 0 5px #d4af3766;background:var(--gradient-gold)!important;color:#2c1a04!important}.compendium-tabs{border-bottom:2px solid var(--card-border);flex-shrink:0;gap:8px;padding-bottom:2px;display:flex;overflow-x:auto}.compendium-tab-btn{color:var(--text-muted);padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;font-family:var(--font-display);letter-spacing:.05em;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;font-size:.8rem;font-weight:700}.compendium-tab-btn:hover{color:var(--color-gold)}.compendium-tab-btn.active{color:var(--color-gold);border-color:var(--color-gold);text-shadow:0 0 8px #d4af374d}.compendium-content{flex-grow:1;padding-right:4px;overflow-y:auto}.compendium-grid{gap:var(--spacing-md);grid-template-columns:repeat(auto-fill,minmax(360px,1fr));display:grid}@media (width<=768px){.compendium-grid{grid-template-columns:1fr}}.compendium-card{padding:var(--spacing-md)!important;transition:all var(--transition-fast)!important;border-color:var(--card-border)!important;background:#ffffff03!important}.compendium-card.flex-row{gap:var(--spacing-md);align-items:flex-start;display:flex}.compendium-card:hover{transform:translateY(-2px);border-color:var(--color-gold)!important;box-shadow:0 4px 15px #d4af371f!important}.compendium-card-emblem{border-radius:var(--radius-md);border:1px solid #ffffff1a;justify-content:center;align-items:center;width:54px;min-width:54px;height:54px;font-size:1.8rem;display:flex;overflow:hidden;box-shadow:inset 0 2px 4px #ffffff26}.compendium-card-emblem .emblem-img{object-fit:contain;border-radius:var(--radius-md);width:100%;height:100%}.compendium-card-details{flex-direction:column;flex-grow:1;gap:6px;display:flex}.card-header-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.card-header-row h3{color:var(--color-gold);margin:0;font-size:1.15rem}.source-badge{color:var(--color-gold);background:#d4af3726;border:1px solid #d4af374d;border-radius:4px;padding:2px 6px;font-size:.65rem;font-weight:700}.card-tagline{color:var(--text-secondary);font-size:.8rem;line-height:1.4}.card-quick-stats{gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);border:1px solid var(--card-border);color:var(--text-muted);background:#0003;grid-template-columns:repeat(3,1fr);font-size:.75rem;display:grid}.view-details-btn{align-self:flex-start;margin-top:4px;padding:6px 12px!important;font-size:.7rem!important}.compendium-list-view{gap:var(--spacing-sm);flex-direction:column;display:flex}.compendium-list-card{padding:var(--spacing-md)!important;transition:all var(--transition-fast)!important;border-color:var(--card-border)!important;background:#ffffff03!important}.compendium-list-card:hover{transform:translate(2px);border-color:var(--color-gold)!important;box-shadow:0 2px 10px #d4af371a!important}.item-list-card .card-header-row{flex-wrap:nowrap}.item-list-card .card-header-row h4{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;margin:0;overflow:hidden}.item-card-badges{flex-shrink:0;align-items:center;gap:4px;display:flex}.item-card-badges .badge{white-space:nowrap}.attune-badge{color:#b9a3e3;background:#9370db26;border:1px solid #9370db73;border-radius:4px;padding:2px 6px;font-size:.65rem}.item-origin-badge{color:var(--text-secondary,#aaa);background:#ffffff0d;border-color:#ffffff26}.description-snippet{color:var(--text-muted);margin-top:4px;font-size:.8rem;line-height:1.4}.compendium-wiki-link{color:var(--color-gold);cursor:pointer;transition:color var(--transition-fast);font-weight:700;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.compendium-wiki-link:hover{color:#fbbf24;text-shadow:0 0 5px #fbbf2466;text-decoration-style:solid}.compendium-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1100;background:#000000bf;justify-content:center;align-items:center;animation:.25s ease-out fadeIn;display:flex;position:fixed;inset:0}.compendium-drawer{border-radius:var(--radius-lg);flex-direction:column;width:100%;max-width:900px;height:90%;max-height:850px;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;display:flex;position:relative;overflow:hidden;background:var(--bg-secondary)!important;border:2px solid var(--color-gold)!important;box-shadow:0 10px 45px #000c, var(--shadow-gold)!important;padding:0!important}.compendium-popup{border-radius:var(--radius-md);flex-direction:column;width:90%;max-width:600px;max-height:80%;animation:.25s cubic-bezier(.16,1,.3,1) scaleUp;display:flex;position:relative;overflow-y:auto;background:var(--bg-secondary)!important;border:1px solid var(--color-gold)!important;padding:var(--spacing-lg)!important;box-shadow:0 8px 35px #000000b3!important}.compendium-close-btn{color:var(--text-secondary);cursor:pointer;z-index:100;background:0 0;border:none;font-size:2.2rem;line-height:1;position:absolute;top:15px;right:20px}.compendium-close-btn:hover{color:var(--color-gold)}.drawer-header{align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);border-bottom:1px solid var(--card-border);background:#0000004d;display:flex}.drawer-icon{border:1px solid #d4af374d;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;font-size:1.6rem;display:flex;overflow:hidden;box-shadow:0 0 10px #d4af3733}.drawer-icon .drawer-icon-img{object-fit:contain;border-radius:50%;width:100%;height:100%}.drawer-title-box h2{color:var(--color-gold);margin:0;font-size:1.5rem}.drawer-body{padding:var(--spacing-lg);gap:var(--spacing-lg);flex-direction:column;flex-grow:1;display:flex;overflow-y:auto}.drawer-quick-stats{gap:var(--spacing-sm);color:var(--text-secondary);text-align:center;grid-template-columns:repeat(5,1fr);font-size:.8rem;display:grid;border-color:var(--card-border)!important;padding:var(--spacing-sm) var(--spacing-md)!important;background:#0003!important}@media (width<=600px){.drawer-quick-stats{grid-template-columns:1fr 1fr}}.drawer-quick-stats div{padding:4px}.compendium-table-container{overflow-x:auto;border-color:var(--card-border)!important}.compendium-progression-table{border-collapse:collapse;text-align:left;width:100%;font-size:.85rem}.compendium-progression-table th{color:var(--color-gold);border-bottom:2px solid var(--color-gold);font-family:var(--font-display);background:#d4af3714;padding:10px 12px;font-weight:700}.compendium-progression-table td{border-bottom:1px solid var(--card-border);color:var(--text-primary);padding:10px 12px}.compendium-progression-table tr:nth-child(2n){background:#ffffff05}.compendium-progression-table tr:hover{background:#d4af370a}.popup-header{border-bottom:1px solid var(--card-border);padding-bottom:var(--spacing-md);margin-bottom:var(--spacing-md);flex-direction:column;gap:4px;display:flex}.popup-category{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;font-weight:700}.popup-header h2{color:var(--color-gold);margin:0;font-size:1.4rem}.spell-metrics{margin-bottom:var(--spacing-md);border-color:var(--card-border)!important;background:#0003!important}.popup-body{flex-grow:1;overflow-y:auto}.class-markdown-body,.popup-markdown-body{color:var(--text-primary);flex-direction:column;gap:16px;max-width:800px;margin:0 auto;font-size:1rem;line-height:1.7;display:flex}.compendium-header{color:var(--color-gold);font-family:var(--font-display);border-bottom:1px dashed var(--card-border);margin-top:var(--spacing-md);padding-bottom:4px}.compendium-p{margin:0}.compendium-list{flex-direction:column;gap:6px;margin:0;padding-left:20px;display:flex}.compendium-blockquote{border-left:3px solid var(--color-gold);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--text-secondary);background:#d4af370d;margin:0;padding:10px 16px;font-style:italic}@keyframes scaleUp{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.compendium-workspace{gap:var(--spacing-lg);flex-grow:1;grid-template-columns:440px 1fr;height:calc(100vh - 240px);min-height:500px;display:grid;position:relative;overflow:hidden}.compendium-list-pane{height:100%;padding-right:8px;overflow-y:auto}.compendium-details-pane{border-left:1px solid var(--card-border);height:100%;padding:0 var(--spacing-xl) var(--spacing-xl) var(--spacing-xl);transition:all var(--transition-normal);overflow-y:auto}.compendium-details-pane.empty{border-radius:var(--radius-md);border:1px dashed var(--card-border);background:#0000000d;justify-content:center;align-items:center;display:flex}.details-placeholder{text-align:center;padding:var(--spacing-lg);color:var(--text-muted)}.placeholder-icon{margin-bottom:var(--spacing-sm);opacity:.5;font-size:3rem;display:block}.detail-view-wrapper{flex-direction:column;height:100%;display:flex;position:relative}.close-details-btn{color:var(--text-secondary);cursor:pointer;z-index:100;width:44px;height:44px;transition:all var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;font-size:1.8rem;line-height:1;display:flex;position:absolute;top:15px;right:15px;border:1px solid var(--card-border)!important;background:#0006!important}.close-details-btn:hover{color:var(--color-gold);border-color:var(--color-gold)!important;background:#ffffff26!important}.compendium-card.selected-card,.compendium-list-card.selected-card{border-color:var(--color-gold)!important;background:#d4af370a!important;box-shadow:0 0 12px #d4af3740!important}.compendium-callout{border-radius:var(--radius-md);border-left:4px solid;margin:12px 0;padding:12px 16px;font-size:.85rem;line-height:1.5}.callout-warning,.callout-danger,.callout-caution{color:#fca5a5!important;background:#dc262614!important;border:1px solid #dc262633!important}.callout-warning .callout-title,.callout-danger .callout-title,.callout-caution .callout-title{color:#f87171!important}.callout-tip{color:#a7f3d0!important;background:#10b98114!important;border:1px solid #10b98133!important}.callout-tip .callout-title{color:#34d399!important}.callout-info,.callout-note,.callout-important{color:#bfdbfe!important;background:#3b82f614!important;border:1px solid #3b82f633!important}.callout-info .callout-title,.callout-note .callout-title,.callout-important .callout-title{color:#60a5fa!important}.callout-header{align-items:center;gap:8px;margin-bottom:6px;font-weight:700;display:flex}.callout-icon{font-size:1.1rem}.callout-p{margin:0}.compendium-code-block{border:1px solid var(--card-border);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);background:#0006;margin:12px 0;font-family:monospace;font-size:.8rem;overflow-x:auto}.compendium-inline-code{color:#fbbf24;background:#00000040;border:1px solid #ffffff0d;border-radius:4px;padding:2px 6px;font-family:monospace;font-size:.85em}.compendium-external-link{color:var(--color-gold);cursor:pointer;transition:all var(--transition-fast);text-decoration:underline}.compendium-external-link:hover{color:#fbbf24;text-shadow:0 0 5px #fbbf2466}@media (width<=1024px){.compendium-workspace{grid-template-columns:1fr;height:calc(100vh - 200px)}.compendium-details-pane{z-index:10;opacity:0;pointer-events:none;border-left:none;position:absolute;inset:0;transform:translate(100%);background:var(--bg-secondary)!important;padding:var(--spacing-md)!important}.compendium-details-pane.open{opacity:1;pointer-events:auto;transform:translate(0)}}.admin-editable{cursor:text;transition:all var(--transition-fast);position:relative}.admin-editable:hover{outline:1px dashed var(--color-gold-muted);background:#d4af3708;border-radius:6px}.compendium-inline-editor{gap:var(--spacing-sm);background:var(--bg-secondary);border-radius:var(--radius-md);flex-direction:column;display:flex}.compendium-editor-textarea:focus{outline:1px solid var(--color-gold)!important;box-shadow:0 0 8px #d4af3733!important}.editor-modal-body{gap:var(--spacing-lg);flex-grow:1;min-height:0;margin-top:10px;display:flex;overflow:hidden}.editor-legend{border-left:1px solid var(--card-border);width:280px;padding-left:var(--spacing-md);flex-direction:column;flex-shrink:0;gap:14px;height:100%;font-size:.75rem;display:flex;overflow-y:auto}.editor-legend-section{flex-direction:column;gap:14px;display:flex}.editor-legend-section h3{color:var(--color-gold);font-size:.85rem;font-family:var(--font-display);border-bottom:1px dashed var(--card-border);margin:0 0 6px;padding-bottom:4px}.editor-legend-item{flex-direction:column;gap:4px;margin-bottom:10px;display:flex}.editor-legend-item strong{color:var(--text-secondary);margin-bottom:4px;display:block}.editor-legend-item code{color:#fbbf24;white-space:pre-wrap;word-break:break-all;background:#0006;border:1px solid #ffffff0d;border-radius:4px;padding:6px 8px;font-family:Consolas,Cascadia Code,Fira Code,Monaco,monospace;font-size:.75rem;line-height:1.4;display:block}@media (width<=768px){.editor-modal-body{flex-direction:column;height:auto;overflow-y:auto}.editor-legend{border-left:none;border-top:1px solid var(--card-border);width:100%;padding-left:0;padding-top:var(--spacing-md);flex-shrink:0;overflow-y:visible}}.compendium-filter-sort-panel{z-index:10;background:var(--bg-secondary);border-bottom:1px solid var(--card-border);flex-direction:column;gap:8px;margin-bottom:12px;padding:8px 4px 10px;display:flex;position:sticky;top:0}.compendium-filter-bar{flex-direction:column;width:100%;display:flex}.filter-select-group{grid-template-columns:repeat(3,1fr);gap:6px;width:100%;display:grid}.filter-select{box-sizing:border-box;width:100%;font-family:inherit;border:1px solid var(--card-border)!important;color:var(--text-primary)!important;border-radius:var(--radius-sm)!important;cursor:pointer!important;transition:all var(--transition-fast)!important;background:#00000059!important;outline:none!important;padding:5px 8px!important;font-size:.72rem!important}.filter-select:hover,.filter-select:focus{border-color:var(--color-gold)!important;background:#00000073!important}.filter-select option{color:var(--text-primary)!important;background:#111827!important}.compendium-sort-bar{flex-wrap:wrap;align-items:center;gap:6px;width:100%;display:flex}.sort-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-right:4px;font-size:.7rem;font-weight:700}.sort-btn{font-weight:500;border:1px solid var(--card-border)!important;min-width:auto!important;color:var(--text-secondary)!important;border-radius:var(--radius-sm)!important;cursor:pointer!important;transition:all var(--transition-fast)!important;background:#ffffff08!important;padding:4px 10px!important;font-size:.72rem!important}.sort-btn:hover{border-color:var(--color-gold)!important;color:var(--color-gold)!important;background:#d4af370d!important}.sort-btn.active{background:var(--gradient-gold)!important;color:#2c1a04!important;border-color:var(--color-gold)!important;font-weight:700!important;box-shadow:0 0 5px #d4af3766!important}.crafting-tab-hint{color:var(--text-muted);margin:6px 0 0;font-size:.75rem}.crafting-rank-badge{border:1px solid;border-radius:4px;padding:2px 6px;font-size:.65rem;font-weight:700}.crafting-rank-badge.rank-novice{color:#9ca3af;background:#9ca3af1a;border-color:#9ca3af80}.crafting-rank-badge.rank-apprentice{color:#6ee7b7;background:#6ee7b71a;border-color:#6ee7b780}.crafting-rank-badge.rank-artisan{color:#93c5fd;background:#93c5fd1a;border-color:#93c5fd80}.crafting-rank-badge.rank-expert{color:#c4b5fd;background:#c4b5fd1a;border-color:#c4b5fd80}.crafting-rank-badge.rank-master{color:#fbbf24;background:#fbbf241f;border-color:#fbbf2480}.recipe-share-menu{z-index:1000;background:var(--bg-secondary,#15120c);border:1px solid var(--color-gold);border-radius:var(--radius-md);flex-direction:column;gap:2px;min-width:180px;max-height:50vh;padding:6px;display:flex;position:fixed;overflow-y:auto;box-shadow:0 8px 24px #0009}.recipe-share-option{color:var(--text-primary);text-align:left;border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;padding:5px 8px;font-size:.78rem}.recipe-share-option:hover{color:var(--color-gold);background:#d4af371f}.recipe-share-option.on{color:var(--color-gold);font-weight:600}.recipe-share-empty{color:var(--text-muted);padding:5px 8px;font-size:.72rem;font-style:italic}.recipe-share-backdrop{z-index:999;cursor:default;background:0 0;position:fixed;inset:0}.nfc-modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:var(--spacing-md);background:#000000d9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.nfc-modal-card{background:var(--bg-secondary);border:2px solid var(--color-gold);border-radius:var(--radius-lg);width:100%;max-width:450px;padding:var(--spacing-lg);text-align:center;box-shadow:var(--shadow-lg), var(--shadow-gold);position:relative}.nfc-close-btn{color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;font-size:2rem;line-height:1;position:absolute;top:15px;right:20px}.nfc-close-btn:hover{color:var(--color-accent)}.nfc-title{color:var(--color-gold);margin-bottom:var(--spacing-md);font-size:1.6rem}.nfc-portal-container{width:160px;height:160px;margin:var(--spacing-lg) auto;position:relative}.nfc-portal-ring{border:4px double var(--color-accent);box-shadow:0 0 15px var(--color-accent);transition:all var(--transition-normal);border-radius:50%;position:absolute;inset:0}.nfc-portal-ring.spinning{border-color:var(--color-gold);box-shadow:0 0 25px var(--color-gold), inset 0 0 20px #d4af374d;animation:10s linear infinite spinRunic}.nfc-portal-ring.success{border-color:var(--color-success);box-shadow:0 0 35px var(--color-success), inset 0 0 20px #3c7d3c80;transform:scale(1.05)}.nfc-rune-inner{width:100px;height:100px;color:var(--text-secondary);justify-content:center;align-items:center;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.nfc-runes-svg{width:100%;height:100%;color:var(--color-gold);opacity:.8}.nfc-center-symbol{fill:var(--color-gold);font-size:2.5rem}.nfc-status-box{border-radius:var(--radius-sm);padding:var(--spacing-md);margin-bottom:var(--spacing-lg);background:#0006;flex-direction:column;justify-content:center;min-height:80px;display:flex}.nfc-status-text{color:var(--text-primary);font-size:.95rem;line-height:1.4}.nfc-error-text{color:#ff6b6b;margin-top:var(--spacing-sm);font-size:.85rem}.nfc-action-container{margin-bottom:var(--spacing-lg)}.nfc-simulator-box{border-radius:var(--radius-md);padding:var(--spacing-md);border:1px dashed var(--text-muted);background:#ffffff08}.simulator-divider{text-align:center;color:var(--text-muted);font-family:var(--font-display);margin-bottom:var(--spacing-sm);align-items:center;font-size:.8rem;display:flex}.simulator-divider:before,.simulator-divider:after{content:"";border-bottom:1px dashed var(--text-muted);flex:1}.simulator-divider:not(:empty):before{margin-right:.5em}.simulator-divider:not(:empty):after{margin-left:.5em}.simulator-info{color:var(--text-secondary);margin-bottom:var(--spacing-sm);font-size:.8rem}.simulator-buttons{gap:var(--spacing-sm);flex-direction:column;display:flex}.simulator-mini-btn{border-left:4px solid var(--btn-accent,var(--color-gold));background:var(--bg-primary);text-transform:none;justify-content:flex-start;padding:8px 12px;font-size:.85rem}.simulator-mini-btn:hover{background:var(--bg-tertiary);border-color:var(--btn-accent,var(--color-gold))}.char-builder-overlay{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);z-index:1000;padding:var(--spacing-md);background:#000000bf;justify-content:center;align-items:center;animation:.3s ease-out fadeInModal;display:flex;position:fixed;inset:0}@keyframes fadeInModal{0%{opacity:0}to{opacity:1}}.char-builder-container{flex-direction:column;width:100%;max-width:1180px;height:90%;max-height:860px;display:flex;position:relative;overflow:hidden;background:var(--bg-secondary)!important;border:2px solid var(--color-gold)!important;box-shadow:0 10px 40px #0009, var(--shadow-gold)!important;padding:0!important}.builder-close-btn{color:var(--text-secondary);cursor:pointer;z-index:100;transition:color var(--transition-fast);background:0 0;border:none;font-size:2.2rem;line-height:1;position:absolute;top:15px;right:20px}.builder-close-btn:hover{color:var(--color-gold)}.builder-mandatory-hint{z-index:100;color:var(--color-gold);font-size:.75rem;font-family:var(--font-display);letter-spacing:.04em;position:absolute;top:22px;right:20px}.builder-progress{border-bottom:1px solid var(--card-border);padding:var(--spacing-md) var(--spacing-sm);background:#00000040;justify-content:space-around;display:flex;position:relative}.progress-step{z-index:2;flex-direction:column;flex:1;align-items:center;display:flex;position:relative}.progress-step:after{content:"";background:var(--card-border);z-index:-1;width:100%;height:2px;position:absolute;top:16px;left:50%}.progress-step:last-child:after{display:none}.progress-step.completed:after{background:var(--color-gold)}.step-num{background:var(--bg-tertiary);border:1px solid var(--text-muted);width:32px;height:32px;color:var(--text-muted);font-family:var(--font-display);transition:all var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;font-size:.9rem;font-weight:700;display:flex}.step-label{font-family:var(--font-display);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;text-align:center;transition:all var(--transition-fast);margin-top:4px;font-size:.7rem}.progress-step.active .step-num{background:var(--color-gold);border-color:var(--color-gold);color:#2c1a04;box-shadow:0 0 10px #d4af3780}.progress-step.active .step-label{color:var(--color-gold);font-weight:700}.progress-step.completed .step-num{background:var(--bg-secondary);border-color:var(--color-gold);color:var(--color-gold)}.progress-step.completed .step-label{color:var(--text-secondary)}.builder-body{padding:var(--spacing-lg);flex-direction:column;flex-grow:1;display:flex;overflow-y:auto}.builder-step-content{gap:var(--spacing-md);flex-direction:column;flex-grow:1;display:flex}.builder-step-content.align-center{justify-content:center;align-items:center}.builder-subtitle{color:var(--color-gold);text-align:center;margin-bottom:var(--spacing-xs);text-shadow:0 2px 4px #000c;font-size:1.8rem}.builder-instruction{text-align:center;color:var(--text-secondary);margin-bottom:var(--spacing-md);font-size:.95rem}.builder-field-group{gap:var(--spacing-sm);width:100%;max-width:500px;margin-bottom:var(--spacing-md);flex-direction:column;display:flex}.builder-field-group label{font-family:var(--font-display);color:var(--color-gold);text-transform:uppercase;font-size:.9rem}.name-builder-input{text-align:center;border-color:var(--card-border);padding:12px;font-size:1.2rem;font-weight:700}.alignments-grid{gap:var(--spacing-xs);grid-template-columns:repeat(3,1fr);width:100%;display:grid}.align-select-btn{border-color:var(--card-border);text-transform:none;background:#0003;min-height:auto;font-size:.75rem;padding:var(--spacing-sm)!important}.align-select-btn.active{color:#2c1a04;border-color:var(--color-gold);font-weight:700;background:var(--gradient-gold)!important}.choice-grid{gap:var(--spacing-md);padding-bottom:var(--spacing-md);grid-template-columns:repeat(2,1fr);display:grid}@media (width<=600px){.choice-grid{grid-template-columns:1fr}}.choice-card{gap:var(--spacing-md);cursor:pointer;display:flex;border:1px solid var(--card-border)!important;transition:all var(--transition-fast)!important;padding:var(--spacing-md)!important;background:#ffffff05!important}.choice-card:hover{transform:translateY(-2px);border-color:var(--color-gold)!important;box-shadow:0 4px 15px #d4af3726!important}.choice-card.active{border-color:var(--color-gold)!important;background:#d4af370d!important;box-shadow:0 4px 20px #d4af3733,inset 0 0 10px #d4af371a!important}.choice-avatar{border-radius:var(--radius-md);border:1px solid var(--card-border);background:#0003;justify-content:center;align-items:center;width:60px;height:60px;font-size:2.8rem;display:flex}.choice-info{flex-direction:column;flex-grow:1;gap:4px;display:flex}.choice-info h4{color:var(--color-gold);font-size:1.1rem}.choice-desc{color:var(--text-secondary);font-size:.8rem;line-height:1.4}.racial-traits,.class-skills,.class-meta{color:var(--text-muted);margin-top:4px;font-size:.75rem}.class-meta{gap:var(--spacing-md);display:flex}.stat-bonuses{margin-top:var(--spacing-sm);flex-wrap:wrap;gap:4px;display:flex}.stat-bonus-pill{color:var(--color-gold);border:1px solid var(--color-gold);background:#0006;border-radius:10px;padding:2px 6px;font-size:.65rem;font-weight:700}.score-method-tabs{border-bottom:2px solid var(--card-border);margin-bottom:var(--spacing-md);gap:4px;display:flex}.score-method-tabs .tab-btn{text-align:center;flex-grow:1;padding:12px;font-size:.85rem}.roll-action-container{padding:var(--spacing-xl) 0;align-items:center;gap:var(--spacing-md);flex-direction:column;display:flex}.roll-desc{color:var(--text-secondary);max-width:400px;font-size:.9rem;line-height:1.5}.roll-all-btn{box-shadow:var(--shadow-gold);padding:12px 24px;font-size:1.1rem}.scores-pool-section{gap:var(--spacing-md);flex-direction:column;display:flex}.scores-pool-section h4{color:var(--color-gold);font-size:.9rem}.scores-pool{justify-content:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);flex-wrap:wrap;display:flex}.pool-score{border:1px solid var(--color-gold);border-radius:var(--radius-sm);width:44px;height:44px;font-family:var(--font-display);color:var(--color-gold);transition:all var(--transition-fast);background:#0006;justify-content:center;align-items:center;font-size:1.3rem;font-weight:700;display:flex;box-shadow:inset 0 0 5px #d4af3733}.pool-score.used{opacity:.25;border-color:var(--card-border);color:var(--text-muted);box-shadow:none;background:#111}.assign-scores-grid{gap:var(--spacing-md);grid-template-columns:repeat(2,1fr);display:grid}@media (width<=600px){.assign-scores-grid{grid-template-columns:1fr}}.stat-assign-row{justify-content:space-between;align-items:center;display:flex;padding:var(--spacing-sm) var(--spacing-md)!important;background:#00000026!important}.stat-label-box{flex-direction:column;gap:2px;display:flex}.stat-name{font-family:var(--font-display);color:var(--text-secondary);font-size:1rem;font-weight:700}.stat-bonus-badge{color:var(--color-gold);font-size:.65rem}.stat-assign-controls{align-items:center;gap:var(--spacing-md);display:flex}.stat-select-dropdown{text-align-last:center;width:100px;padding:var(--spacing-xs) var(--spacing-sm);font-weight:700}.stat-final-output{border-radius:var(--radius-round);border:1px solid var(--color-gold);background:#0006;flex-direction:column;justify-content:center;align-items:center;width:48px;height:48px;display:flex;box-shadow:0 0 5px #d4af3733}.final-score-val{font-size:1.1rem;font-weight:700;line-height:1}.final-score-mod{color:var(--color-gold);font-size:.65rem;font-weight:700}.gear-choices{gap:var(--spacing-md);flex-direction:column;width:100%;max-width:500px;display:flex}.gear-option-card{align-items:center;gap:var(--spacing-md);cursor:pointer;display:flex;border-color:var(--card-border)!important;padding:var(--spacing-md)!important;transition:all var(--transition-fast)!important;background:#0003!important}.gear-option-card:hover{border-color:var(--color-gold)!important}.gear-option-card.active{border-color:var(--color-gold)!important;background:#d4af370d!important;box-shadow:0 0 10px #d4af371a!important}.gear-checkbox{opacity:.3;transition:all var(--transition-fast);font-size:1.5rem}.gear-option-card.active .gear-checkbox{opacity:1;color:var(--color-gold);filter:drop-shadow(0 0 5px var(--color-gold))}.gear-text{text-align:left}.gear-text h4{color:var(--color-gold);margin-bottom:2px}.gear-text p{color:var(--text-secondary);font-size:.85rem}.review-summary-card{width:100%;max-width:500px;padding:var(--spacing-lg)!important;background:#0000004d!important}.summary-header{gap:var(--spacing-md);border-bottom:1px solid var(--card-border);padding-bottom:var(--spacing-md);margin-bottom:var(--spacing-md);align-items:center;display:flex}.summary-icon{text-shadow:0 0 10px var(--color-gold);font-size:3rem}.summary-title-section{text-align:left}.summary-title-section h3{color:var(--color-gold);font-size:1.4rem}.summary-title-section p{color:var(--text-muted);font-size:.85rem}.summary-stats-box{gap:var(--spacing-xs);margin-bottom:var(--spacing-md);grid-template-columns:repeat(6,1fr);display:grid}.summary-stat-item{border:1px solid var(--card-border);padding:var(--spacing-xs);border-radius:var(--radius-sm);background:#ffffff08;flex-direction:column;align-items:center;display:flex}.summary-stat-lbl{color:var(--text-muted);font-size:.6rem}.summary-stat-val{color:var(--text-primary);margin:2px 0;font-size:1.1rem}.summary-stat-mod{color:var(--color-gold);font-size:.65rem;font-weight:700}.summary-details{text-align:left;color:var(--text-secondary);gap:var(--spacing-xs);flex-direction:column;font-size:.85rem;display:flex}.builder-footer{border-top:1px solid var(--card-border);padding:var(--spacing-md) var(--spacing-lg);background:#00000040;justify-content:space-between;display:flex}.builder-footer .btn{min-width:100px}.note-vault-container{gap:var(--spacing-md);grid-template-columns:300px 1fr;height:calc(100vh - 120px);min-height:500px;display:grid}.mobile-back-btn{display:none}@media (width<=768px){.note-vault-container{grid-template-columns:1fr;height:auto}.mobile-back-btn{min-height:auto;margin-right:var(--spacing-sm);padding:6px 12px;font-size:.8rem;display:inline-flex}.note-vault-container.has-active-note .vault-sidebar,.note-vault-container:not(.has-active-note) .note-display-panel{display:none}}.vault-sidebar{background:var(--bg-secondary);flex-direction:column;height:100%;display:flex}.vault-title{color:var(--color-gold);border-bottom:1px solid var(--card-border);padding-bottom:var(--spacing-sm);margin-bottom:var(--spacing-md)}.sidebar-search{gap:var(--spacing-sm);margin-bottom:var(--spacing-md);display:flex}.search-input{flex-grow:1}.add-note-btn{width:44px;min-height:44px;padding:0;font-size:1.3rem}.notes-list{gap:var(--spacing-sm);flex-direction:column;flex-grow:1;display:flex;overflow-y:auto}.no-notes-desc{color:var(--text-muted);text-align:center;margin-top:var(--spacing-lg);font-size:.85rem}.note-sidebar-item{border-radius:var(--radius-sm);padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;transition:all var(--transition-fast);background:#0003;border-left:3px solid #0000}.note-sidebar-item:hover{border-left-color:var(--color-gold);background:#ffffff08}.note-sidebar-item.active{border-left-color:var(--color-gold);background:#d4af3714}.note-item-title{color:var(--text-primary);margin-bottom:2px;font-size:.95rem;font-weight:700}.note-item-preview{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.note-item-tags{margin-top:var(--spacing-xs);gap:4px;display:flex}.tag-pill{background:var(--bg-tertiary);color:var(--color-gold);border-radius:4px;padding:1px 6px;font-size:.65rem}.note-display-panel{background:var(--bg-secondary);flex-direction:column;height:100%;display:flex;overflow:hidden}.note-display-content{flex-direction:column;height:100%;display:flex;overflow-y:auto}.note-meta-header{border-bottom:1px solid var(--card-border);padding-bottom:var(--spacing-md);margin-bottom:var(--spacing-md);justify-content:space-between;align-items:center;gap:var(--spacing-md);display:flex}.note-title-display{color:var(--color-gold);flex-grow:1;font-size:1.8rem}.note-title-edit{font-family:var(--font-display);color:var(--color-gold);flex-grow:1;font-size:1.5rem;font-weight:700}.note-actions{gap:var(--spacing-sm);display:flex}.note-tags-row{gap:var(--spacing-sm);margin-bottom:var(--spacing-md);flex-wrap:wrap;align-items:center;display:flex}.tag-pill-large{color:var(--color-gold);border-radius:var(--radius-sm);align-items:center;gap:var(--spacing-xs);background:#d4af371a;border:1px solid #d4af3733;padding:3px 10px;font-size:.8rem;display:inline-flex}.remove-tag-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:.9rem;font-weight:700}.remove-tag-btn:hover{color:var(--color-accent)}.tag-input-field{width:180px;padding:4px 8px;font-size:.8rem}.editor-workspace{flex-direction:column;flex-grow:1;min-height:250px;display:flex;position:relative}.editor-input-wrapper{flex-direction:column;flex-grow:1;display:flex;position:relative}.note-textarea{resize:none;font-family:var(--font-mono);padding:var(--spacing-md);background:#0006;flex-grow:1;font-size:.9rem;line-height:1.6}.wikilink-autocomplete-list{z-index:100;background:var(--bg-tertiary);border:1px solid var(--color-gold);width:220px;max-height:180px;box-shadow:var(--shadow-lg);border-radius:var(--radius-sm);padding:var(--spacing-xs);position:absolute;overflow-y:auto}.autocomplete-header{color:var(--text-muted);text-transform:uppercase;border-bottom:1px solid #ffffff0d;padding:4px;font-size:.7rem}.autocomplete-item{padding:6px var(--spacing-sm);cursor:pointer;color:var(--text-secondary);border-radius:4px;font-size:.8rem}.autocomplete-item:hover{color:var(--color-gold);background:#d4af3726}.note-preview-rendered{padding:var(--spacing-md);color:var(--text-primary);border-radius:var(--radius-md);background:#00000026;flex-grow:1;line-height:1.6}.note-preview-rendered h1,.note-preview-rendered h2,.note-preview-rendered h3{margin-top:var(--spacing-md);margin-bottom:var(--spacing-sm);color:var(--color-gold)}.note-preview-rendered h1{font-size:1.5rem}.note-preview-rendered h2{font-size:1.3rem}.note-preview-rendered h3{font-size:1.1rem}.note-preview-rendered p{margin-bottom:var(--spacing-md)}.note-preview-rendered ul{margin-left:var(--spacing-lg);margin-bottom:var(--spacing-md)}.note-preview-rendered li{margin-bottom:var(--spacing-xs)}.wikilink{cursor:pointer;transition:all var(--transition-fast);border-bottom:1px dashed #0000;font-weight:700}.wikilink.resolved{color:var(--color-gold)}.wikilink.resolved:hover{border-bottom-color:var(--color-gold);text-shadow:0 0 5px #d4af374d}.wikilink.unresolved{color:var(--text-muted)}.wikilink.unresolved:hover{color:var(--color-accent);border-bottom-color:var(--color-accent)}.backlinks-panel{border-top:1px solid var(--card-border);padding-top:var(--spacing-md);margin-top:var(--spacing-lg)}.backlinks-title{color:var(--text-secondary);margin-bottom:var(--spacing-sm);font-size:.9rem}.backlinks-grid{gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.backlink-btn{text-transform:none;background:#0003;min-height:auto;padding:6px 12px;font-size:.8rem}.empty-vault-state{text-align:center;padding:var(--spacing-xl);color:var(--text-secondary);flex-direction:column;flex-grow:1;justify-content:center;align-items:center;display:flex}.empty-symbol{margin-bottom:var(--spacing-md);filter:drop-shadow(0 0 10px #d4af3733);font-size:4rem}.empty-vault-state h3{color:var(--color-gold);margin-bottom:var(--spacing-sm)}.empty-vault-state p{color:var(--text-muted);max-width:400px;margin-bottom:var(--spacing-lg);font-size:.9rem}.graph-view-panel{background:var(--bg-secondary);flex-direction:column;height:calc(100vh - 120px);min-height:500px;display:flex;overflow:hidden;padding:0!important}.graph-header{padding:var(--spacing-md);border-bottom:1px solid var(--card-border);justify-content:space-between;align-items:center;gap:var(--spacing-sm);background:#0003;flex-wrap:wrap;display:flex}.graph-title{color:var(--color-gold)}.graph-controls{align-items:center;gap:var(--spacing-md);flex-wrap:wrap;display:flex}.graph-reset-btn{text-transform:none;min-height:auto;padding:4px 10px;font-size:.75rem}.legend{gap:var(--spacing-sm);color:var(--text-secondary);font-size:.75rem;display:flex}.legend-item{align-items:center;gap:4px;display:flex}.legend-dot{border:1px solid #fff3;border-radius:50%;width:8px;height:8px;display:inline-block}.graph-canvas{cursor:grab;background:radial-gradient(circle,#1a1411 0%,#0d0908 100%);flex-grow:1}.graph-canvas:active{cursor:grabbing}.dice-roller-panel{background:var(--bg-secondary);flex-direction:column;height:100%;display:flex;position:relative}.dice-close-btn{color:var(--text-secondary);cursor:pointer;z-index:10;transition:color var(--transition-fast);background:0 0;border:none;font-size:1.8rem;line-height:1;position:absolute;top:10px;right:15px}.dice-close-btn:hover{color:var(--color-accent)}.dice-title{color:var(--color-gold);border-bottom:1px solid var(--card-border);padding-bottom:var(--spacing-sm);margin-bottom:var(--spacing-md);text-align:center}.dice-controls{margin-bottom:var(--spacing-md);justify-content:space-between;align-items:center;gap:var(--spacing-md);display:flex}.modifier-box{align-items:center;gap:var(--spacing-sm);display:flex}.modifier-box label{color:var(--text-secondary);font-size:.85rem}.modifier-input{text-align:center;width:60px;font-weight:700}.advantage-toggle{gap:var(--spacing-sm);display:flex}.roll-mode-btn{border-color:var(--text-muted);min-height:auto;padding:4px 10px;font-size:.75rem}.roll-mode-btn.active.advantage{background:var(--color-success);border-color:#55a255;box-shadow:0 0 10px #3c7d3c66}.roll-mode-btn.active.disadvantage{background:var(--color-accent);border-color:#d63d27;box-shadow:0 0 10px #b1271466}.dice-buttons-grid{gap:var(--spacing-sm);margin-bottom:var(--spacing-md);grid-template-columns:repeat(4,1fr);display:grid}@media (width<=480px){.dice-buttons-grid{grid-template-columns:repeat(3,1fr)}}.die-button{padding:var(--spacing-sm);border-color:var(--card-border);flex-direction:column;min-height:56px}.die-button:hover{border-color:var(--color-gold);color:var(--color-gold)}.die-icon{color:var(--color-accent);margin-bottom:2px;font-size:1.2rem}.die-name{font-family:var(--font-display);font-size:.8rem}.active-roll-container{border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md);text-align:center;border:1px solid var(--card-border);background:#0000004d;flex-direction:column;justify-content:center;align-items:center;min-height:100px;display:flex}.success-glow{border-color:var(--color-gold);box-shadow:inset 0 0 15px #d4af3733}@keyframes shakeDice{0%{transform:translate(1px,1px)rotate(0)}10%{transform:translate(-1px,-2px)rotate(-1deg)}20%{transform:translate(-3px)rotate(1deg)}30%{transform:translateY(2px)rotate(0)}40%{transform:translate(1px,-1px)rotate(1deg)}50%{transform:translate(-1px,2px)rotate(-1deg)}60%{transform:translate(-3px,1px)rotate(0)}70%{transform:translate(2px,1px)rotate(-1deg)}80%{transform:translate(-1px,-1px)rotate(1deg)}90%{transform:translate(2px,2px)rotate(0)}to{transform:translate(1px,-2px)rotate(-1deg)}}@keyframes diceTumble{0%{transform:rotate(0)scale(1)}50%{transform:rotate(360deg)scale(1.18)}to{transform:rotate(720deg)scale(1)}}.rolling-dice-animation{font-size:3rem;animation:.6s linear infinite diceTumble;display:inline-block}.rolling-text{font-family:var(--font-display);color:var(--text-secondary);margin-top:var(--spacing-sm);font-size:.85rem}.active-roll-value{font-family:var(--font-display);color:var(--color-gold);text-shadow:0 0 10px #d4af3766;font-size:3rem;line-height:1.1}.active-roll-details{color:var(--text-secondary);margin-top:4px;font-size:.8rem}.roll-history-container{flex-direction:column;flex-grow:1;min-height:180px;display:flex}.history-header{font-family:var(--font-display);color:var(--text-secondary);padding-bottom:var(--spacing-xs);margin-bottom:var(--spacing-sm);border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;font-size:.85rem;display:flex}.clear-history{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:.75rem}.clear-history:hover{color:var(--color-accent)}.history-list{gap:var(--spacing-sm);flex-direction:column;flex-grow:1;max-height:250px;padding-right:4px;display:flex;overflow-y:auto}.no-rolls{text-align:center;color:var(--text-muted);margin-top:var(--spacing-lg);font-size:.85rem}.roll-history-item{border-radius:var(--radius-sm);border-left:3px solid var(--color-accent);background:#00000026;padding:8px 12px}.roll-item-meta{color:var(--text-muted);justify-content:space-between;margin-bottom:2px;font-size:.75rem;display:flex}.roll-player-name{color:var(--text-secondary);font-weight:700}.roll-item-body{justify-content:space-between;align-items:center;gap:var(--spacing-sm);display:flex}.roll-formula{font-size:.85rem;font-weight:500}.roll-math{color:var(--text-muted);flex-grow:1;font-size:.75rem}.roll-result-total{font-family:var(--font-display);color:var(--color-gold);font-size:1.2rem;font-weight:700}.landing-root{background:#070503;justify-content:center;align-items:center;width:100%;min-height:100vh;display:flex;position:relative;overflow:hidden}.landing-sky{width:100%;height:100%;position:absolute;inset:0}.lp-star{animation:3s ease-in-out infinite lpTwinkle}@keyframes lpTwinkle{0%,to{opacity:.15}50%{opacity:1}}.lp-flock{animation:44s linear infinite lpFlockFly}.lp-bat{animation:2s ease-in-out infinite alternate lpBatFlutter}.lp-bat-wing{transform-box:fill-box;animation:.3s ease-in-out infinite alternate lpBatFlapL}.lp-bat-wing-l{transform-origin:100% 30%}.lp-bat-wing-r{transform-origin:0 30%;animation-name:lpBatFlapR}@keyframes lpFlockFly{0%{opacity:0;transform:translate(-220px,240px)scale(.45)}37%{opacity:0}42%{opacity:1}50%{opacity:1;transform:translate(1040px,150px)scale(.62)}56%{opacity:0}to{opacity:0;transform:translate(1700px,80px)scale(.45)}}@keyframes lpBatFlutter{0%{transform:translateY(-7px)}to{transform:translateY(7px)}}@keyframes lpBatFlapL{0%{transform:rotate(-16deg)}to{transform:rotate(24deg)}}@keyframes lpBatFlapR{0%{transform:rotate(16deg)}to{transform:rotate(-24deg)}}.lp-landscape{filter:brightness(.45)saturate(.85)}.lp-win{animation:4.5s ease-in-out infinite lpFlicker}@keyframes lpFlicker{0%,to{opacity:.95}42%{opacity:.35}55%{opacity:.85}70%{opacity:.5}}.lp-mist{animation:22s ease-in-out infinite alternate lpMist}.lp-mist-2{animation-duration:30s;animation-direction:alternate-reverse}@keyframes lpMist{0%{transform:translate(-60px)}to{transform:translate(60px)}}.landing-embers{pointer-events:none;position:absolute;inset:0}.lp-ember{background:var(--color-accent);opacity:0;border-radius:50%;animation:linear infinite lpEmberRise;position:absolute;bottom:-8px;box-shadow:0 0 6px 2px #f59e0b73}@keyframes lpEmberRise{0%{opacity:0;transform:translate(0)}8%{opacity:.9}60%{opacity:.6}to{opacity:0;transform:translate(28px,-92vh)}}.landing-content{z-index:2;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-xl) var(--spacing-md);flex-direction:column;width:100%;max-width:420px;display:flex;position:relative}.landing-brand{align-items:center;gap:var(--spacing-sm);flex-direction:column;animation:.9s ease-out both lpFadeUp;display:flex}.landing-title{font-family:var(--font-display);letter-spacing:.14em;text-transform:uppercase;background:var(--gradient-gold);color:#0000;filter:drop-shadow(0 4px 12px #000c);text-align:center;-webkit-background-clip:text;background-clip:text;margin:0;font-size:clamp(2.6rem,7vw,4.2rem);font-weight:800}.landing-flourish{color:var(--color-gold);opacity:.8;align-items:center;width:220px;display:flex}.landing-flourish:before,.landing-flourish:after{content:"";flex:1;height:1px}.landing-flourish:before{background:linear-gradient(90deg,#0000,currentColor)}.landing-flourish:after{background:linear-gradient(90deg,currentColor,#0000)}.landing-flourish-gem{flex-shrink:0;width:64px;height:18px}.landing-tagline{color:var(--text-secondary);letter-spacing:.18em;text-transform:uppercase;text-align:center;margin:0;font-size:.9rem}.landing-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);width:100%;animation:.9s ease-out .25s both lpFadeUp;background:#140f09d1!important}.landing-mode-tabs{border-bottom:1px solid var(--card-border);margin-bottom:var(--spacing-md);display:flex}.landing-mode-tab{color:var(--text-muted);font-family:var(--font-display);letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:color var(--transition-fast), border-color var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:8px 0;font-size:.85rem}.landing-mode-tab:hover{color:var(--text-secondary)}.landing-mode-tab.active{color:var(--color-gold);border-bottom-color:var(--color-gold)}.landing-invite-input{font-family:var(--font-mono);letter-spacing:.08em}.landing-hint{color:var(--text-muted);text-transform:none;letter-spacing:normal;font-size:.68rem;font-family:var(--font-body)}.landing-form{gap:var(--spacing-md);flex-direction:column;display:flex}.landing-label{letter-spacing:.08em;text-transform:uppercase;font-size:.72rem;font-family:var(--font-display);color:var(--color-gold);flex-direction:column;gap:4px;display:flex}.landing-label .input{box-sizing:border-box;width:100%}.landing-error{color:#fca5a5;border-radius:var(--radius-sm);background:#ef444414;border:1px solid #ef444440;padding:6px 10px;font-size:.78rem}.landing-submit{justify-content:center;width:100%}.landing-divider{align-items:center;gap:var(--spacing-sm);margin:var(--spacing-md) 0;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;display:flex}.landing-divider:before,.landing-divider:after{content:"";background:var(--card-border);flex:1;height:1px}.landing-nfc{text-transform:none;justify-content:center;width:100%}.landing-qr-box{margin-top:var(--spacing-md);align-items:center;gap:var(--spacing-sm);border:1px solid var(--card-border);border-radius:var(--radius-sm);padding:var(--spacing-md);background:#00000040;flex-direction:column;display:flex}.landing-qr-img{border-radius:var(--radius-sm);border:2px solid var(--color-gold);width:200px;height:200px}.landing-qr-hint{color:var(--text-secondary);text-align:center;margin:0;font-size:.78rem}.landing-guest-link{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;font-size:.8rem}.landing-guest-link:hover{color:var(--color-gold)}@keyframes lpFadeUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){.lp-star,.lp-flock,.lp-bat,.lp-bat-wing,.lp-win,.lp-mist,.lp-ember,.landing-brand,.landing-card{animation:none!important}.lp-ember{display:none}}.campsel-root{width:100%;min-height:100vh;padding-bottom:var(--spacing-xl);background:radial-gradient(80% 50% at 50% -10%,#d4af3714,#0000),linear-gradient(#0a0805 0%,#18120a 55%,#221709 100%);flex-direction:column;align-items:center;display:flex;position:relative;overflow-x:hidden}.campsel-header{width:100%;padding:var(--spacing-md) var(--spacing-lg);box-sizing:border-box;justify-content:space-between;align-items:center;display:flex}.campsel-brand{align-items:center;gap:var(--spacing-sm);font-family:var(--font-display);color:var(--color-gold);letter-spacing:.1em;text-transform:uppercase;font-weight:700;display:flex}.campsel-user{align-items:center;gap:var(--spacing-md);color:var(--text-secondary);font-size:.85rem;display:flex}.campsel-dm-badge{border:1px solid var(--color-gold);color:var(--color-gold);background:#d4af3726;border-radius:3px;padding:1px 6px;font-size:.65rem;font-weight:700}.campsel-logout{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;font-size:.8rem}.campsel-logout:hover{color:var(--color-gold)}.campsel-hero{align-items:center;gap:var(--spacing-sm);margin:var(--spacing-xl) var(--spacing-md) var(--spacing-lg);text-align:center;flex-direction:column;animation:.7s ease-out both csFadeUp;display:flex}.campsel-title{font-family:var(--font-display);letter-spacing:.1em;text-transform:uppercase;background:var(--gradient-gold);color:#0000;-webkit-background-clip:text;background-clip:text;margin:0;font-size:clamp(1.6rem,4vw,2.4rem)}.campsel-flourish{color:var(--color-gold);opacity:.75;align-items:center;width:240px;display:flex}.campsel-flourish:before,.campsel-flourish:after{content:"";flex:1;height:1px}.campsel-flourish:before{background:linear-gradient(90deg,#0000,currentColor)}.campsel-flourish:after{background:linear-gradient(90deg,currentColor,#0000)}.campsel-flourish-gem{flex-shrink:0;width:64px;height:18px}.campsel-sub{color:var(--text-muted);max-width:460px;margin:0;font-size:.85rem}.campsel-grid{justify-content:center;gap:var(--spacing-lg);max-width:1080px;padding:0 var(--spacing-md);flex-wrap:wrap;display:flex}.campsel-card{background:var(--bg-secondary);border:1px solid var(--card-border);border-radius:var(--radius-md);cursor:pointer;text-align:left;width:300px;color:inherit;font:inherit;box-shadow:var(--shadow-md);transition:transform var(--transition-normal), border-color var(--transition-normal), box-shadow var(--transition-normal);padding:0;animation:.6s ease-out both csFadeUp;overflow:hidden}.campsel-card:hover{border-color:var(--card-border-hover);box-shadow:var(--shadow-lg), var(--shadow-gold);transform:translateY(-6px)}.campsel-art{border-bottom:1px solid var(--card-border);height:150px;position:relative;overflow:hidden}.campsel-art svg,.campsel-art-img{object-fit:cover;width:100%;height:100%;transition:transform .6s;display:block}.campsel-card:hover .campsel-art svg,.campsel-card:hover .campsel-art-img{transform:scale(1.06)}.campsel-art-tools{opacity:0;transition:opacity var(--transition-fast);gap:6px;display:flex;position:absolute;top:8px;right:8px}.campsel-card:hover .campsel-art-tools,.campsel-art-tools:focus-within{opacity:1}.campsel-art-btn{border:1px solid var(--card-border);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;transition:border-color var(--transition-fast), color var(--transition-fast);background:#0009;border-radius:50%;justify-content:center;align-items:center;font-size:.85rem;display:flex}.campsel-art-btn:hover{border-color:var(--color-gold);color:var(--color-gold)}.campsel-body{padding:var(--spacing-md);gap:var(--spacing-sm);flex-direction:column;display:flex}.campsel-name{font-family:var(--font-display);color:var(--color-gold);letter-spacing:.03em;margin:0;font-size:1.05rem}.campsel-meta{color:var(--text-secondary);justify-content:space-between;align-items:center;font-size:.78rem;display:flex}.campsel-players{border:1px solid var(--card-border);background:#0000004d;border-radius:999px;padding:2px 8px}.campsel-create{cursor:default;background:#00000040;border-style:dashed;align-items:stretch;min-height:230px;display:flex}.campsel-create:hover{transform:translateY(-6px)}.campsel-create-trigger{color:var(--text-secondary);font-family:var(--font-display);letter-spacing:.06em;cursor:pointer;justify-content:center;align-items:center;gap:var(--spacing-sm);transition:color var(--transition-fast);background:0 0;border:none;flex-direction:column;flex:1;font-size:.95rem;display:flex}.campsel-create-trigger:hover{color:var(--color-gold)}.campsel-create-plus{color:var(--color-gold);font-size:2rem;animation:2.4s ease-in-out infinite csPulse}.campsel-create-form{justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);flex-direction:column;flex:1;display:flex}.campsel-create-form .input{box-sizing:border-box;width:100%}.campsel-create-actions{justify-content:flex-end;gap:var(--spacing-sm);display:flex}.campsel-error{color:#fca5a5;font-size:.75rem}.campsel-empty{text-align:center;max-width:380px;color:var(--text-secondary)}.campsel-empty-sub{color:var(--text-muted);font-size:.8rem}.campsel-invites-toggle{border:1px solid var(--card-border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast), border-color var(--transition-fast);background:#0000004d;padding:4px 10px;font-size:.78rem}.campsel-invites-toggle:hover{color:var(--color-gold);border-color:var(--color-gold)}.campsel-invites{width:100%;max-width:640px;margin:0 var(--spacing-md) var(--spacing-lg);gap:var(--spacing-md);flex-direction:column;animation:.4s ease-out both csFadeUp;display:flex}.campsel-invites-forge{gap:var(--spacing-sm);display:flex}.campsel-invites-forge .input{flex:1;min-width:0}.campsel-invites-empty{color:var(--text-muted);text-align:center;margin:0;font-size:.8rem}.campsel-invites-list{flex-direction:column;gap:6px;max-height:220px;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.campsel-invite{align-items:center;gap:var(--spacing-sm);color:var(--text-secondary);border:1px solid var(--card-border);border-radius:var(--radius-sm);background:#00000040;padding:6px 10px;font-size:.78rem;display:flex}.campsel-invite.used{opacity:.55}.campsel-invite-code{font-family:var(--font-mono);color:var(--color-gold);letter-spacing:.05em}.campsel-invite-target{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.campsel-invite-status{color:var(--text-muted);white-space:nowrap}.campsel-invite-actions{gap:6px;display:flex}.campsel-invite-btn{border:1px solid var(--card-border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast), border-color var(--transition-fast);background:0 0;padding:2px 8px;font-size:.7rem}.campsel-invite-btn:hover{color:var(--color-gold);border-color:var(--color-gold)}.campsel-invite-btn.danger:hover{color:#fca5a5;border-color:#ef4444}.cs-star{animation:3.2s ease-in-out infinite csTwinkle}.cs-glow{animation:4s ease-in-out infinite csPulse}.cs-win{animation:4.5s ease-in-out infinite csFlicker}.cs-mist{animation:18s ease-in-out infinite alternate csMist}.cs-drift{animation:26s linear infinite csDrift}.cs-lava{animation:2.2s ease-in-out infinite csPulse}.cs-firefly{animation:5s ease-in-out infinite csFirefly}.cs-portal{animation-duration:2.6s}.cs-rune{opacity:0;animation:7s linear infinite csRuneRise}@keyframes csTwinkle{0%,to{opacity:.15}50%{opacity:1}}@keyframes csPulse{0%,to{opacity:.45}50%{opacity:1}}@keyframes csFlicker{0%,to{opacity:.95}42%{opacity:.35}55%{opacity:.85}70%{opacity:.5}}@keyframes csMist{0%{transform:translate(-24px)}to{transform:translate(24px)}}@keyframes csDrift{0%{transform:translate(-70px,60px)scale(.8)}50%{transform:translate(200px,30px)scale(1)}to{transform:translate(470px,50px)scale(.85)}}@keyframes csFirefly{0%,to{opacity:0;transform:translate(0)}30%{opacity:1}60%{opacity:.4;transform:translate(8px,-10px)}80%{opacity:.9}}@keyframes csRuneRise{0%{opacity:0;transform:translateY(8px)}20%{opacity:.9}80%{opacity:.3}to{opacity:0;transform:translateY(-26px)}}@keyframes csFadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){.cs-star,.cs-glow,.cs-win,.cs-mist,.cs-drift,.cs-lava,.cs-firefly,.cs-rune,.campsel-card,.campsel-hero,.campsel-create-plus{animation:none!important}}.campaign-map-view{gap:12px;height:calc(100vh - 96px);min-height:460px;display:flex}@media (width<=768px){.campaign-map-view{flex-direction:column;height:calc(100vh - 144px)}}.map-toolbar{background:var(--bg-secondary);border:1px solid var(--card-border);border-radius:var(--radius-md);flex-direction:column;flex-shrink:0;gap:12px;width:220px;padding:12px;display:flex;overflow-y:auto}@media (width<=768px){.map-toolbar{width:auto;max-height:38vh}}.map-toolbar-title{font-family:var(--font-display);color:var(--color-gold);letter-spacing:.08em;text-transform:uppercase;align-items:center;gap:6px;font-size:.85rem;display:flex}.map-section-label{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:6px;font-size:.68rem;font-weight:700}.map-tool-grid{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}.map-tool-btn{border:1px solid var(--card-border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;font-size:.62rem;font-family:var(--font-display);letter-spacing:.02em;transition:all var(--transition-fast);background:#00000040;flex-direction:column;align-items:center;gap:2px;padding:6px 2px;font-weight:600;display:flex}.map-tool-btn .map-tool-icon{font-size:1rem}.map-tool-btn:hover{border-color:var(--color-gold);color:var(--color-gold)}.map-tool-btn.active{border-color:var(--color-gold);color:var(--color-gold);background:#d4af371f;box-shadow:0 0 8px #d4af3733}.map-swatch-grid{grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.map-swatch{cursor:pointer;height:30px;transition:all var(--transition-fast);border:2px solid #0006;border-radius:4px;position:relative}.map-swatch:hover{transform:scale(1.06)}.map-swatch.active{border-color:var(--color-gold);box-shadow:0 0 8px #d4af3773}.map-swatch-name{color:var(--text-secondary);text-align:center;margin-top:2px;font-size:.6rem;line-height:1.1;display:block}.map-marker-grid{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}.map-range{width:100%;accent-color:var(--color-gold)}.map-range-row{color:var(--text-secondary);align-items:center;gap:8px;font-size:.72rem;display:flex}.map-range-value{font-family:var(--font-display);color:var(--color-gold);text-align:right;min-width:22px}.map-hint{color:var(--text-muted);font-size:.68rem;font-style:italic;line-height:1.45}.map-btn{border:1px solid var(--card-border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;font-size:.72rem;font-family:var(--font-display);letter-spacing:.04em;transition:all var(--transition-fast);background:#00000040;justify-content:center;align-items:center;gap:5px;padding:6px 10px;font-weight:600;display:inline-flex}.map-btn:hover{border-color:var(--color-gold);color:var(--color-gold)}.map-btn.active{border-color:var(--color-gold);color:var(--color-gold);background:#d4af371f}.map-btn.danger:hover{color:#e03b22;border-color:#b12714}.map-btn-row{gap:6px;display:flex}.map-btn-row .map-btn{flex:1}.map-toolbar-footer{border-top:1px solid var(--card-border);flex-direction:column;gap:8px;margin-top:auto;padding-top:10px;display:flex}.map-save-status{font-size:.7rem;font-family:var(--font-display);letter-spacing:.04em;color:var(--text-muted);text-align:center}.map-save-status.saved{color:var(--color-success)}.map-save-status.error{color:#e03b22}.map-save-status.dirty,.map-save-status.saving{color:var(--color-gold)}.map-canvas-wrap{border-radius:var(--radius-md);border:1px solid var(--card-border);background:#15110b;flex:1;min-width:0;position:relative;overflow:hidden}.map-canvas{touch-action:none;width:100%;height:100%;display:block}.map-canvas.tool-pan{cursor:grab}.map-canvas.tool-pan:active{cursor:grabbing}.map-canvas.tool-brush,.map-canvas.tool-isle,.map-canvas.tool-fog-reveal,.map-canvas.tool-fog-hide{cursor:crosshair}.map-canvas.tool-marker,.map-canvas.tool-party{cursor:copy}.map-zoom-controls{z-index:4;flex-direction:column;gap:6px;display:flex;position:absolute;bottom:12px;right:12px}.map-zoom-btn{border-radius:var(--radius-sm);border:1px solid var(--card-border);width:34px;height:34px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:#18150fd9;font-size:1rem}.map-zoom-btn:hover{border-color:var(--color-gold);color:var(--color-gold)}.map-preview-banner{border:1px solid var(--color-gold);color:var(--color-gold);font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;border-radius:var(--radius-sm);z-index:4;pointer-events:none;background:#18150fd9;padding:4px 12px;font-size:.7rem;position:absolute;top:12px;left:50%;transform:translate(-50%)}.map-popup{background:var(--bg-secondary);border:1px solid var(--color-gold);border-radius:var(--radius-sm);z-index:6;width:230px;box-shadow:var(--shadow-lg), var(--shadow-gold);flex-direction:column;gap:8px;padding:10px;display:flex;position:absolute;transform:translate(-50%,calc(-100% - 14px))}.map-popup:after{content:"";background:var(--bg-secondary);border-right:1px solid var(--color-gold);border-bottom:1px solid var(--color-gold);width:12px;height:12px;position:absolute;bottom:-7px;left:50%;transform:translate(-50%)rotate(45deg)}.map-popup-title{font-family:var(--font-display);color:var(--color-gold);word-break:break-word;align-items:center;gap:6px;font-size:.85rem;font-weight:700;display:flex}.map-popup-meta{color:var(--text-muted);font-size:.68rem}.map-popup input[type=text]{box-sizing:border-box;border:1px solid var(--card-border);width:100%;color:var(--text-primary);background:#0000004d;border-radius:4px;outline:none;padding:6px 8px;font-size:.78rem}.map-popup input[type=text]:focus{border-color:var(--color-gold)}.map-popup-check{color:var(--text-secondary);cursor:pointer;align-items:center;gap:6px;font-size:.7rem;display:flex}.map-popup-check input{accent-color:var(--color-gold)}.map-toast{border:1px solid var(--color-gold);color:var(--text-primary);border-radius:var(--radius-sm);z-index:7;box-shadow:var(--shadow-md);background:#18150feb;padding:8px 16px;font-size:.78rem;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.map-empty-state{border:1px solid var(--card-border);border-radius:var(--radius-md);background:radial-gradient(ellipse at center, #d4af370f, transparent 70%), var(--bg-secondary);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:24px;display:flex}.map-empty-state .map-empty-icon{filter:drop-shadow(0 0 12px #d4af374d);font-size:3rem}.map-empty-state h3{font-family:var(--font-display);color:var(--color-gold);letter-spacing:.06em;font-size:1.1rem}.map-empty-state p{color:var(--text-secondary);max-width:420px;font-size:.85rem;line-height:1.5}.map-no-campaign{text-align:center;color:var(--text-secondary);font-family:var(--font-display);padding:48px 24px;font-size:1rem}.campaign-dashboard-container{width:100%;max-width:1200px;padding:var(--spacing-sm) 0;gap:var(--spacing-md);flex-direction:column;margin:0 auto;animation:.3s ease-out fadeIn;display:flex}.campaign-unauthenticated-state{text-align:center;padding:var(--spacing-xl);align-items:center;gap:var(--spacing-md);flex-direction:column;display:flex}.unauth-icon{filter:drop-shadow(0 0 10px #d4af374d);font-size:3.5rem}.campaign-grid{gap:var(--spacing-lg);grid-template-columns:320px 1fr;align-items:start;display:grid}@media (width<=900px){.campaign-grid{grid-template-columns:1fr}}.campaign-sidebar-panel{gap:var(--spacing-md);flex-direction:column;display:flex}.campaign-active-card{border-left:4px solid var(--color-gold)}.active-badge-display{margin-top:var(--spacing-md);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);color:var(--text-muted);background:#0000004d;justify-content:space-between;align-items:center;font-size:.75rem;display:flex}.active-badge-display code{color:var(--color-gold);font-family:var(--font-mono)}.card-subtitle{color:var(--text-secondary);margin-bottom:var(--spacing-xs);font-size:.8rem}.campaign-list-card{border-top:3px solid var(--color-accent)}.dashboard-title{margin-bottom:var(--spacing-md);color:var(--text-primary);font-size:1.5rem}.no-campaigns-desc,.no-party-members{color:var(--text-muted);padding:var(--spacing-md) 0;font-size:.9rem;font-style:italic}.campaign-list-item{border:1px solid var(--card-border);transition:all var(--transition-fast);background:#0003}.campaign-list-item:hover{border-color:#d4af3766;box-shadow:0 4px 12px #00000080}.campaign-list-item.active-campaign-highlight{border-color:var(--color-gold);box-shadow:var(--shadow-gold)}.campaign-item-header{cursor:pointer;padding:var(--spacing-xs) 0;justify-content:space-between;align-items:center;display:flex}.campaign-name{font-family:var(--font-display);color:var(--text-primary);font-size:1.1rem}.campaign-dm-tag{color:var(--text-muted);align-items:center;gap:6px;font-size:.75rem;display:flex}.admin-pill{background:var(--color-accent);color:#fff;border-radius:3px;padding:1px 4px;font-size:.65rem;font-weight:700}.campaign-item-actions{align-items:center;gap:var(--spacing-sm);display:flex}.badge-active-indicator{text-transform:uppercase;border:1px solid var(--color-gold);color:var(--color-gold);letter-spacing:.05em;background:#d4af3726;border-radius:4px;padding:2px 8px;font-size:.7rem;font-weight:800}.expand-chevron{color:var(--text-muted);transition:transform var(--transition-fast);font-size:.8rem}.campaign-expanded-content{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--card-border);animation:.25s ease-out slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.party-listing h5{font-family:var(--font-display);color:var(--color-gold);margin-bottom:var(--spacing-sm);letter-spacing:.05em;font-size:.95rem}.party-members-grid{gap:var(--spacing-sm);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.party-member-card{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);border-radius:var(--radius-sm);transition:all var(--transition-fast);background:#ffffff05;border:1px solid #ffffff0d;flex-wrap:wrap;display:flex;position:relative}.member-actions{gap:6px;width:100%;display:flex}.member-actions .btn{white-space:nowrap;flex:1;min-height:30px;padding:2px 8px!important;font-size:.75rem!important}.party-member-card:hover{border-color:var(--card-border);background:#ffffff0d}.member-avatar{opacity:.8;filter:drop-shadow(0 0 4px var(--color-gold));font-size:1.8rem}.member-details{flex-direction:column;flex-grow:1;gap:2px;display:flex}.member-name{color:var(--text-primary);font-size:.85rem;font-weight:600}.member-meta{color:var(--text-secondary);font-size:.75rem}.member-owner{color:var(--text-muted);font-size:.7rem}.remove-member-btn{width:fit-content;color:#ef4444e6!important;border-color:#ef44444d!important}.remove-member-btn:hover{background:#ef444414!important;border-color:#ef4444b3!important}.feedback-toast{padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-md);border-left:4px solid #0000;font-size:.85rem}.feedback-toast.success{border-left-color:var(--color-success);background:#3c7d3c0d}.feedback-toast.error{border-left-color:var(--color-accent);background:#b127140d}.player-campaign-card{max-width:900px;margin:0 auto}.player-campaign-hero{object-fit:cover;border-radius:var(--radius-md);border:1px solid var(--card-border);width:100%;max-height:220px;margin-bottom:12px}.player-campaign-info{border:1px solid var(--card-border);border-radius:var(--radius-md);background:#0003;margin-top:12px;padding:12px 16px}.player-campaign-info h5,.party-listing h5{color:var(--color-gold);margin-bottom:8px}.campaign-info-body{color:var(--text-primary);font-size:.88rem;line-height:1.5}
