:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6;font-weight:400;color:#333;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--primary-color: #d4af37;--primary-dark: #2c3e50;--secondary-color: #667eea;--accent-color: #764ba2}*{box-sizing:border-box}body{margin:0;padding:0;min-width:320px;min-height:100vh;font-family:inherit}#root{width:100%;margin:0 auto;text-align:center}h1,h2,h3,h4,h5,h6{margin:0;line-height:1.2;color:#2c3e50}a{color:#d4af37;text-decoration:none}a:hover{color:#b8860b}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}ul,ol{margin:0;padding:0;list-style:none}.wizard-step{padding:1.5rem;background:#1a2332f2;border-radius:var(--radius-lg);box-shadow:0 4px 24px #00000080,inset 0 1px 1px #d4af3714;animation:slideIn .4s ease-out;border:1px solid var(--dnd-border);position:relative}.wizard-step:before,.wizard-step:after{content:"";position:absolute;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--dnd-gold),transparent);opacity:.5}.wizard-step:before{top:0}.wizard-step:after{bottom:0}@keyframes slideIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.wizard-step h2{color:var(--dnd-gold);margin-bottom:1rem;margin-top:0;font-size:1.6rem;border-bottom:2px solid var(--dnd-gold);padding-bottom:.5rem;font-family:Georgia,serif;letter-spacing:1px;text-transform:uppercase;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.5)}.description{color:var(--dnd-text);margin-bottom:1.25rem;font-size:.95rem;line-height:1.7;letter-spacing:.3px;font-style:italic}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--dnd-gold);font-size:.9rem;letter-spacing:.5px;text-transform:uppercase;font-family:Georgia,serif}.form-select,.form-input{width:100%;padding:.625rem;background:#09191acc;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);font-size:1rem;font-family:inherit;color:var(--dnd-text-light);transition:all .3s ease}.form-select::placeholder,.form-input::placeholder{color:#d8c9b84d}.form-select:focus,.form-input:focus{outline:none;border-color:var(--dnd-gold);background:#09191a;box-shadow:0 0 20px #d4af3733,inset 0 0 0 1px var(--dnd-gold)}.form-select:hover{border-color:var(--dnd-gold)}.class-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.6rem;margin-bottom:1.25rem}.class-picker-btn{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:.7rem .4rem;background:var(--dnd-card-bg, #1a2332);border:2px solid var(--dnd-border, #423f37);border-radius:var(--radius-md, 6px);cursor:pointer;transition:all .2s ease;color:var(--dnd-text, #d8c9b8)}.class-picker-btn:hover{border-color:var(--dnd-gold, #d4af37);background:#d4af370f}.class-picker-btn.selected{border-color:var(--dnd-gold, #d4af37);background:#d4af371f;box-shadow:0 0 8px #d4af3740}.class-picker-btn.selected .class-picker-name{color:var(--dnd-gold, #d4af37)}.class-picker-icon{font-size:1.6rem;line-height:1;color:var(--dnd-gold, #d4af37)}.class-picker-icon .class-icon{width:1.6em;height:1.6em}.class-picker-name{font-size:.78rem;font-weight:600;text-align:center;line-height:1.2;font-family:Georgia,serif}.race-info,.class-info{background:#0f1419cc;padding:1.25rem;border-radius:var(--radius-md);margin-bottom:1.25rem;border-left:5px solid var(--dnd-gold);border:1px solid var(--dnd-border);border-left:4px solid var(--dnd-gold);position:relative;transition:all .3s ease}.race-info:hover,.class-info:hover{border-left-color:var(--dnd-accent-red);box-shadow:0 4px 20px #d4af371a,inset 0 0 0 1px #d4af370d}.race-info .description,.class-info .description{margin-bottom:1rem;color:var(--dnd-text);font-style:italic}.features{margin-bottom:1.25rem}.features h4,.bonuses h4,.subrace-info h4{color:var(--dnd-gold);margin-bottom:.625rem;margin-top:.75rem;font-size:1.05rem;text-transform:uppercase;letter-spacing:.5px;font-family:Georgia,serif}.features h4:first-child,.bonuses h4:first-child,.subrace-info h4:first-child{margin-top:0}.features ul,.subrace-info ul{list-style:none;padding:0;margin:0 0 1rem}.features li,.subrace-info li{padding:.375rem 0 .375rem 1.5rem;position:relative;color:var(--dnd-text);font-size:.9rem;line-height:1.5}.features li:before,.subrace-info li:before{content:"◆";position:absolute;left:0;color:var(--dnd-gold);font-size:.75rem}.bonuses{background:#8b3a3a1a;border:1px solid var(--dnd-border);border-left:3px solid var(--dnd-accent-red);padding:1rem;border-radius:var(--radius-sm);margin-top:1rem}.bonuses p{margin:.75rem 0;color:var(--dnd-text);font-size:.95rem}.bonuses strong{color:var(--dnd-accent-red)}.subrace-info{background:#d4af370d;padding:1rem;border-radius:var(--radius-sm);margin-top:1rem;border:1px solid var(--dnd-border);border-left:3px solid var(--dnd-gold)}.variant-human-choices{background:#8b3a3a14;padding:1rem;border-radius:var(--radius-sm);margin-top:1rem;border:1px solid var(--dnd-border);border-left:3px solid var(--dnd-accent-red)}.variant-human-choices h4{color:var(--dnd-gold);margin:0 0 .75rem;font-size:1rem}.variant-human-choices .form-group{margin-bottom:.75rem}.variant-human-choices .feat-description{font-size:.82rem;color:var(--text-secondary, #aaa);margin-top:.4rem;padding:.5rem .75rem;background:#0003;border-radius:4px;line-height:1.4;border-left:2px solid var(--dnd-gold)}.subclass-info{background:#d4af370d;padding:1rem;border-radius:var(--radius-sm);margin-top:1rem;border:1px solid var(--dnd-border);border-left:3px solid var(--dnd-gold)}.ability-scores-assignment{margin:1.25rem 0}.ability-method-tabs{display:flex;gap:.75rem;margin-bottom:1.25rem;flex-wrap:wrap}.method-tab{flex:1;min-width:140px;padding:.625rem 1rem;background:#09191acc;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);color:var(--dnd-text);font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;font-size:.85rem;letter-spacing:.5px}.method-tab:hover{border-color:var(--dnd-gold);background:#09191a}.method-tab.active{background:linear-gradient(135deg,var(--dnd-gold) 0%,var(--dnd-gold-dark) 100%);border-color:var(--dnd-gold);color:#1a1a1a;box-shadow:0 0 20px #d4af374d}.scores-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.75rem;margin-bottom:1.25rem}.score-box{display:flex;flex-direction:column;align-items:center;gap:.5rem}.score-input,.score-display{width:100%;padding:.75rem;background:#09191acc;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);font-size:1.1rem;font-weight:700;color:var(--dnd-gold);text-align:center;transition:all .3s ease}.score-input:focus{outline:none;border-color:var(--dnd-gold);box-shadow:0 0 15px #d4af3733}.score-label{font-size:.85rem;font-weight:700;color:var(--dnd-text);text-transform:uppercase;letter-spacing:.5px}.dnd-score-pool{background:#09191ab3;border:2px dashed var(--dnd-border);border-radius:var(--radius-md);padding:1rem;margin-bottom:1.25rem;text-align:center;transition:all .3s ease;min-height:70px}.dnd-score-pool.drag-over{border-color:var(--dnd-gold);background:#d4af3714;box-shadow:0 0 20px #d4af3726}.pool-label{display:block;color:var(--dnd-text);font-size:.85rem;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.pool-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;min-height:48px;align-items:center}.pool-empty{color:var(--dnd-gold);font-size:.9rem;font-style:italic;opacity:.8}.dnd-score-chip{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#d4af3733,#d4af370d);border:2px solid var(--dnd-gold);border-radius:var(--radius-sm);color:var(--dnd-gold);font-size:1.2rem;font-weight:700;cursor:grab;transition:all .2s ease;user-select:none;-webkit-user-select:none;touch-action:none}.dnd-score-chip:hover{transform:scale(1.1);box-shadow:0 0 16px #d4af3766;background:linear-gradient(135deg,#d4af3759,#d4af371a)}.dnd-score-chip:active{cursor:grabbing}.dnd-score-chip.dragging{opacity:.5;transform:scale(.95)}.dnd-score-chip.assigned{background:linear-gradient(135deg,#d4af374d,#d4af371a);border-color:var(--dnd-gold);cursor:grab;position:relative}.dnd-score-chip.assigned:hover{border-color:var(--dnd-accent-red);box-shadow:0 0 12px #8b3a3a4d}.dnd-score-chip.assigned:hover:after{content:"✕";position:absolute;top:-6px;right:-6px;width:16px;height:16px;background:var(--dnd-accent-red);border-radius:50%;font-size:.55rem;display:flex;align-items:center;justify-content:center;color:#fff}.dnd-empty-slot{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border:2px dashed rgba(212,175,55,.3);border-radius:var(--radius-sm);color:#d4af374d;font-size:1.2rem;font-weight:700;margin:0 auto}.dnd-drop-hint{font-size:.7rem;color:var(--dnd-text);opacity:.5;margin-top:.5rem;font-style:italic}.ability-card.dnd-drop-target{transition:all .2s ease}.ability-card.dnd-drop-target.drag-over{border-color:var(--dnd-gold);box-shadow:0 0 20px #d4af374d,inset 0 0 20px #d4af370d;transform:translateY(-3px) scale(1.02)}.ability-card.dnd-drop-target.empty-slot{border-style:dashed;opacity:.85}.ability-card.dnd-drop-target.empty-slot.drag-over{opacity:1;border-style:solid}.ability-scores-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.75rem;margin:1.25rem 0}.ability-card{background:#09191ae6;padding:1rem;border-radius:var(--radius-md);color:var(--dnd-text-light);text-align:center;border:1px solid var(--dnd-border);box-shadow:0 2px 10px #00000040;transition:all .3s ease;position:relative;box-sizing:border-box}.ability-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--dnd-gold),transparent);opacity:.5}.ability-card:hover{transform:translateY(-3px);box-shadow:0 4px 16px #d4af3726;border-color:var(--dnd-gold)}.ability-card label{display:block;font-size:.8rem;font-weight:600;margin-bottom:.5rem;color:var(--dnd-gold);text-transform:uppercase;letter-spacing:.5px}.ability-input-group{position:relative;display:flex;align-items:center;justify-content:center;gap:.25rem;margin-bottom:.5rem;flex-wrap:nowrap;overflow:visible}.point-buy-btn{width:30px;height:30px;min-width:30px;max-width:30px;padding:0;font-size:1.1rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);letter-spacing:0;text-transform:none;box-sizing:border-box;overflow:visible;flex-shrink:0;line-height:1}.point-buy-btn:disabled{opacity:.3}.ability-input{width:56px;padding:.5rem;font-size:1.1rem;text-align:center;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);background:#09191a;color:var(--dnd-gold);font-weight:700;transition:all .3s ease}.ability-input::placeholder{color:#d4af374d}.ability-input:focus{outline:none;border-color:var(--dnd-gold);background:#09191a;box-shadow:0 0 15px #d4af3733}.bonus-badge{position:absolute;top:-.4rem;right:-.3rem;background:var(--dnd-accent-red);color:var(--dnd-text-light);padding:.15rem .4rem;border-radius:var(--radius-sm);font-size:.7rem;font-weight:700;border:1px solid rgba(139,58,58,.5);z-index:2;line-height:1.2}.final-score{font-size:1.25rem;font-weight:700;color:var(--dnd-gold);margin:.5rem 0;text-shadow:0 2px 4px rgba(0,0,0,.5)}.modifier{font-size:.9rem;color:var(--dnd-text);font-style:italic}.scores-summary{background:#d4af370d;padding:1rem;border-radius:var(--radius-sm);margin-top:1.25rem;border:1px solid var(--dnd-border);border-left:3px solid var(--dnd-gold)}.scores-summary h4{color:var(--dnd-gold);margin:0 0 .625rem;font-size:1rem;text-transform:uppercase;letter-spacing:.5px;font-family:Georgia,serif}.scores-summary p{color:var(--dnd-text);margin:.5rem 0;font-size:.95rem}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:.625rem;margin:1rem 0}.skill-checkbox{display:flex;align-items:center;gap:.625rem;padding:.625rem .75rem;background:#09191acc;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);cursor:pointer;transition:all .3s ease}.skill-checkbox:hover{border-color:var(--dnd-gold);background:#09191a;box-shadow:0 0 10px #d4af371a}.skill-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--dnd-gold)}.skill-label{color:var(--dnd-text);font-weight:500;cursor:pointer;flex:1}.skill-checkbox.expertise.selected{border-color:gold;background:#ffd70026;box-shadow:0 0 12px #ffd70033}.expertise-selection{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--dnd-border)}.expertise-selection h3{color:gold;font-size:1.1rem;margin-bottom:.5rem}.button-group{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem;flex-wrap:wrap-reverse}.btn{padding:.625rem 1.25rem;background:linear-gradient(135deg,#d4af371a,#8b3a3a1a);border:1px solid var(--dnd-border);border-radius:var(--radius-sm);color:var(--dnd-text-light);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px;position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(212,175,55,.2),transparent);transition:left .5s ease}.btn:hover{border-color:var(--dnd-gold);background:linear-gradient(135deg,#d4af3733,#8b3a3a1a);box-shadow:0 0 20px #d4af3733;color:var(--dnd-gold);transform:translateY(-2px)}.btn:disabled{opacity:.5;cursor:not-allowed;border-color:var(--dnd-border)}.btn:disabled:hover{transform:none;box-shadow:none;background:linear-gradient(135deg,#d4af371a,#8b3a3a1a);color:var(--dnd-text)}.levelup-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem;background:#8b3a3a1a;border:1px solid var(--dnd-border);border-left:3px solid var(--dnd-accent-red);padding:1.25rem;border-radius:var(--radius-md)}.info-item{display:flex;flex-direction:column;gap:.5rem}.info-item span:first-child{color:var(--dnd-text);font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.info-item strong{color:var(--dnd-accent-red);font-size:1.2rem;text-shadow:0 2px 4px rgba(0,0,0,.5)}.levelup-section{margin-bottom:1.5rem;padding:1.25rem;background:#0f1419cc;border:1px solid var(--dnd-border);border-top:3px solid var(--dnd-gold);border-radius:var(--radius-md);position:relative}.levelup-section:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--dnd-gold),transparent);opacity:.4}.levelup-section h3{color:var(--dnd-gold);margin-top:0;margin-bottom:.875rem;font-size:1.15rem;text-transform:uppercase;letter-spacing:1px;font-family:Georgia,serif}.features-list{list-style:none;padding:0;margin:0 0 1rem}.features-list li{background:#d4af370d;border:1px solid var(--dnd-border);border-left:3px solid var(--dnd-gold);padding:.75rem;margin-bottom:.5rem;border-radius:var(--radius-sm)}.features-list li strong{color:var(--dnd-gold);font-size:1.05rem;display:block;margin-bottom:.5rem}.features-list li p{color:var(--dnd-text);margin:0;font-size:.95rem;line-height:1.5}.levelup-section p{color:var(--dnd-text);margin-bottom:1rem}.subclass-selection-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem;margin:1rem 0}.subclass-option{background:#09191acc;border:1px solid var(--dnd-border);border-radius:var(--radius-md);padding:1rem;cursor:pointer;transition:all .3s ease;text-align:left;display:flex;flex-direction:column;gap:.5rem}.subclass-option:hover{border-color:var(--dnd-gold);background:#09191a;box-shadow:0 0 15px #d4af371a}.subclass-option.selected{background:linear-gradient(135deg,#d4af371a,#8b3a3a0d);border-color:var(--dnd-gold);box-shadow:0 0 20px #d4af3733}.subclass-option strong{color:var(--dnd-gold);font-size:1.1rem;font-family:Georgia,serif}.subclass-option p{color:var(--dnd-text);font-size:.9rem;margin:0;line-height:1.4}.ability-increase-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:.75rem;margin-bottom:1rem}.ability-increase-btn{position:relative;padding:.875rem;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);background:#09191acc;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:.75rem;font-weight:600;color:var(--dnd-text-light)}.ability-increase-btn:hover{border-color:var(--dnd-gold);background:#09191a;box-shadow:0 0 15px #d4af371a}.ability-increase-btn.selected{background:linear-gradient(135deg,var(--dnd-gold) 0%,var(--dnd-gold-dark) 100%);border-color:var(--dnd-gold);color:#1a1a1a;box-shadow:0 0 20px #d4af374d}.ability-increase-btn.locked{background:#8b3a3a26;border-color:var(--dnd-accent-red);cursor:not-allowed;opacity:.7}.ability-increase-btn.locked:hover{border-color:var(--dnd-accent-red);background:#8b3a3a26;box-shadow:none}.ability-increase-btn:disabled{cursor:not-allowed;opacity:.5}.ability-name{font-size:.85rem;text-transform:uppercase;color:var(--dnd-text);letter-spacing:.5px}.current-score{font-size:1.4rem;color:var(--dnd-gold);font-weight:700}.increase-badge{position:absolute;top:-8px;right:-8px;background:var(--dnd-accent-red);color:var(--dnd-text-light);width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;box-shadow:0 2px 8px #8b3a3a80}.asi-total{text-align:center;padding:.75rem;background:#d4af3714;border:1px solid var(--dnd-border);margin:.75rem 0;border-radius:var(--radius-sm)}.asi-total p{margin:0;color:var(--dnd-text);font-weight:600}.asi-total strong{color:var(--dnd-gold);font-size:1.2rem}.feats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:.75rem;margin:1rem 0}.feat-card{display:block;background:#09191acc;border:1px solid var(--dnd-border);border-radius:var(--radius-md);padding:0;cursor:pointer;transition:all .3s ease;overflow:hidden;position:relative}.feat-card:hover{border-color:var(--dnd-gold);box-shadow:0 0 20px #d4af3726}.feat-card.disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.feat-card input[type=checkbox]{margin-right:1rem;width:20px;height:20px;cursor:pointer;accent-color:var(--dnd-gold)}.feat-card.selected{border-color:var(--dnd-gold);background:linear-gradient(135deg,#d4af371a,#8b3a3a0d);box-shadow:0 0 20px #d4af3733,inset 0 1px #d4af371a}.feat-card label{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;cursor:pointer;width:100%}.feat-info{flex:1;display:flex;flex-direction:column;gap:.5rem}.feat-info strong{color:var(--dnd-gold);font-size:1.1rem;font-family:Georgia,serif}.feat-description{color:var(--dnd-text);font-size:.9rem;margin:.3rem 0;line-height:1.5}.feat-prerequisite{color:var(--dnd-accent-red);font-size:.85rem;margin:.3rem 0;font-style:italic}.feat-bonus-indicator{color:var(--dnd-accent-red);font-size:.85rem;margin:.5rem 0 0;font-weight:500;text-transform:uppercase;letter-spacing:.3px}.feat-option-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease-out}.feat-option-dialog{background:linear-gradient(135deg,#1a2332fa,#0f1419fa);padding:1.5rem;border-radius:var(--radius-lg);box-shadow:0 20px 60px #000c,0 0 40px #d4af374d;max-width:550px;width:90%;animation:slideIn .3s ease-out;border:1px solid var(--dnd-gold);position:relative}.feat-option-dialog:before,.feat-option-dialog:after{content:"";position:absolute;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--dnd-gold),transparent)}.feat-option-dialog:before{top:0}.feat-option-dialog:after{bottom:0}.feat-option-dialog h4{color:var(--dnd-gold);margin:0 0 1rem;font-size:1.3rem;border-bottom:2px solid var(--dnd-gold);padding-bottom:.75rem;font-family:Georgia,serif;letter-spacing:1px}.feat-option-dialog p{color:var(--dnd-text);margin-bottom:1.25rem;line-height:1.6;font-style:italic}.feat-option-buttons{display:flex;gap:.75rem;margin-bottom:1.25rem;flex-wrap:wrap}.feat-option-buttons .btn{flex:1;min-width:120px;padding:.625rem .875rem}@media(max-width:768px){.wizard-step{padding:1rem}.wizard-step h2{font-size:1.3rem}.scores-grid,.ability-scores-grid,.ability-increase-grid{grid-template-columns:repeat(3,1fr)}.feats-grid{grid-template-columns:1fr}.button-group{flex-direction:column}.btn:not(.point-buy-btn){width:100%}}@media(max-width:480px){.wizard-step{padding:.75rem}.wizard-step h2{font-size:1.15rem}.scores-grid{grid-template-columns:repeat(3,1fr)}.ability-scores-grid{grid-template-columns:repeat(2,1fr)}.ability-card{padding:.75rem .5rem}.ability-card label{font-size:.7rem}.ability-input-group{gap:.15rem}.point-buy-btn{width:26px;height:26px;min-width:26px;max-width:26px;font-size:.95rem}.ability-input{width:44px;padding:.35rem;font-size:1rem}.ability-increase-grid{grid-template-columns:repeat(2,1fr)}.feat-card label{flex-direction:column}.feat-card input[type=checkbox]{margin-right:0}}.background-grid{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.background-card{background:var(--dnd-card-bg, #1a2332);border:2px solid var(--dnd-border, #423f37);border-radius:var(--radius-md, 6px);padding:.75rem 1rem;cursor:pointer;transition:all .2s ease}.background-card:hover{border-color:var(--dnd-gold, #d4af37);background:#d4af370d}.background-card.selected{border-color:var(--dnd-gold, #d4af37);background:#d4af371a;box-shadow:0 0 8px #d4af3733}.background-card.custom{border-style:dashed}.background-card-header{display:flex;justify-content:space-between;align-items:center;gap:1rem}.background-card-header strong{color:var(--dnd-text, #d8c9b8);font-size:1rem}.background-skills-badge{color:var(--dnd-gold, #d4af37);font-size:.85rem;opacity:.9;white-space:nowrap}.background-card-details{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--dnd-border, #423f37)}.background-description{color:var(--dnd-text, #d8c9b8);opacity:.8;font-size:.9rem;margin-bottom:.5rem}.background-detail-row{display:flex;gap:.5rem;padding:.2rem 0;font-size:.9rem}.background-detail-row .detail-label{color:var(--dnd-gold, #d4af37);font-weight:600;min-width:100px}.background-detail-row .detail-value{color:var(--dnd-text, #d8c9b8)}.background-feature-desc{color:var(--dnd-text, #d8c9b8);opacity:.7;font-size:.85rem;font-style:italic;margin-top:.4rem}.background-skill-tag{background:#d4af3740!important;border-color:var(--dnd-gold, #d4af37)!important;color:var(--dnd-gold, #d4af37)!important;font-weight:600;box-shadow:0 0 8px #d4af3733!important}.skill-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin:.5rem 0}.skill-tag{background:#d4af3726;color:var(--dnd-gold, #d4af37);border:1px solid rgba(212,175,55,.3);padding:.4rem .8rem;border-radius:16px;font-size:.85rem;font-weight:600;display:inline-flex;align-items:center;gap:.5rem;transition:all .3s ease}.skill-tag:hover{background:#d4af3740;border-color:var(--dnd-gold, #d4af37);box-shadow:0 0 8px #d4af3733}.remove-skill{background:none;border:none;color:inherit;cursor:pointer;font-size:1.1rem;padding:0;display:flex;align-items:center;justify-content:center;width:18px;height:18px;transition:transform .2s ease}.remove-skill:hover{transform:scale(1.2);color:#ff6b6b}.selected-skills{background:#1a233299;padding:1rem;border-radius:var(--radius-md);margin:1rem 0;border:1px solid rgba(212,175,55,.15)}.selected-skills h4{color:var(--dnd-gold);margin-bottom:.75rem;font-size:.95rem;text-transform:uppercase;letter-spacing:.5px}.skills-grid.compact{grid-template-columns:repeat(3,1fr)}.feature-choice-block{margin-top:1rem;padding:1rem;background:#1a233280;border:1px solid var(--dnd-border, #423f37);border-radius:var(--radius-md, 6px)}.feature-choice-block h4{color:var(--dnd-gold, #d4af37);margin-bottom:.5rem;font-family:Georgia,serif}.feature-options-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.5rem;margin-top:.75rem}.feature-option-btn{background:var(--dnd-card-bg, #1a2332);border:2px solid var(--dnd-border, #423f37);border-radius:var(--radius-md, 6px);padding:.75rem;text-align:left;cursor:pointer;transition:all .2s ease;color:var(--dnd-text, #d8c9b8)}.feature-option-btn strong{display:block;color:var(--dnd-text, #d8c9b8);margin-bottom:.25rem;font-size:.95rem}.feature-option-btn p{font-size:.82rem;opacity:.75;margin:0;line-height:1.35}.feature-option-btn:hover:not(.disabled){border-color:var(--dnd-gold, #d4af37);background:#d4af370d}.feature-option-btn.selected{border-color:var(--dnd-gold, #d4af37);background:#d4af371f;box-shadow:0 0 6px #d4af3733}.feature-option-btn.selected strong{color:var(--dnd-gold, #d4af37)}.feature-option-btn.disabled{opacity:.4;cursor:not-allowed}.already-picked-badge{display:inline-block;margin-top:.25rem;font-size:.75rem;color:var(--dnd-accent-red, #8B3A3A);font-style:italic}.level1-feature-choices{margin-top:1rem}@media(max-width:768px){.background-card-header{flex-direction:column;align-items:flex-start;gap:.25rem}.skills-grid.compact,.feature-options-grid{grid-template-columns:1fr}}.spell-selection-step{max-width:900px;margin:0 auto}.spell-selection-info{background:#141c28cc;border:1px solid var(--dnd-border);border-radius:var(--radius-md);padding:1rem 1.2rem;margin-bottom:1.2rem}.spell-selection-info p{margin:.3rem 0;color:var(--dnd-text-secondary);font-size:.9rem}.spell-prepared-note{color:var(--dnd-gold)!important;font-style:italic}.spell-search-bar{position:relative;margin-bottom:1rem}.spell-search-input{width:100%;padding:.6rem 2.2rem .6rem .8rem;background:var(--dnd-bg-input, rgba(15, 20, 30, .8));border:1px solid var(--dnd-border);border-radius:var(--radius-md);color:var(--dnd-text-primary);font-size:1rem;transition:border-color .2s}.spell-search-input:focus{outline:none;border-color:var(--dnd-gold)}.spell-search-clear{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--dnd-text-secondary);cursor:pointer;font-size:1rem;padding:.2rem .4rem}.spell-circle-section{margin-bottom:1.2rem}.spell-circle-header{display:flex;align-items:center;gap:.7rem;margin-bottom:.7rem;font-size:1.05rem;color:var(--dnd-gold);border-bottom:1px solid rgba(212,175,55,.2);padding-bottom:.3rem}.spell-circle-subheader{font-size:.95rem;color:var(--dnd-text-secondary);margin:.5rem 0;font-weight:600}.spell-count-badge{background:#d4af3726;color:var(--dnd-gold);border:1px solid rgba(212,175,55,.3);border-radius:10px;padding:.15rem .6rem;font-size:.8rem;font-weight:600;white-space:nowrap}.spell-level-counter{margin-bottom:.5rem}.spell-level-counter h3{display:flex;align-items:center;gap:.7rem;color:var(--dnd-gold)}.spell-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.5rem}.spell-card{position:relative;background:#141c28b3;border:1px solid var(--dnd-border);border-radius:var(--radius-md);padding:.6rem .8rem;cursor:pointer;transition:all .2s}.spell-card:hover{border-color:var(--dnd-gold);background:#1e2837cc}.spell-card.selected{border-color:var(--dnd-gold);background:#d4af371f;box-shadow:0 0 8px #d4af3726}.spell-card.disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.spell-card-header{display:flex;justify-content:space-between;align-items:center;gap:.3rem}.spell-card-name{font-weight:600;font-size:.85rem;color:var(--dnd-text-primary)}.spell-check{color:var(--dnd-gold);font-weight:700;font-size:1rem}.spell-card-meta{display:flex;gap:.5rem;margin-top:.25rem;font-size:.75rem;color:var(--dnd-text-secondary);opacity:.7}.spell-card-school{text-transform:capitalize}.spell-card-desc{margin-top:.5rem;font-size:.78rem;line-height:1.4;color:var(--dnd-text-secondary);max-height:200px;overflow-y:auto;border-top:1px solid rgba(212,175,55,.15);padding-top:.4rem}.spell-card-info-btn{position:absolute;bottom:.3rem;right:.4rem;background:none;border:none;color:var(--dnd-text-secondary);cursor:pointer;font-size:.75rem;padding:.1rem .3rem;opacity:.5;transition:opacity .2s}.spell-card-info-btn:hover{opacity:1;color:var(--dnd-gold)}.spell-selection-summary{background:#d4af3714;border:1px solid rgba(212,175,55,.25);border-radius:var(--radius-md);padding:.8rem 1rem;margin-top:1rem}.spell-selection-summary h3{color:var(--dnd-gold);font-size:.95rem;margin-bottom:.4rem}.spell-selection-summary .summary-group,.spell-selection-summary p{margin:.2rem 0;font-size:.85rem;color:var(--dnd-text-secondary)}.spell-prepared-panel{background:#141c28b3;border:1px solid var(--dnd-border);border-radius:var(--radius-md);padding:1rem 1.2rem;margin-top:1rem}.spell-prepared-panel h3{color:var(--dnd-gold);margin-bottom:.5rem}.spell-prepared-panel p{font-size:.88rem;line-height:1.5;color:var(--dnd-text-secondary);margin:.3rem 0}.spell-selection-section .spell-search-bar{margin-top:.5rem}@media(max-width:600px){.spell-grid{grid-template-columns:1fr}}:root[data-theme=light] .wizard-step{background:#fff;border-color:var(--dnd-border);box-shadow:0 2px 12px #0000000f}:root[data-theme=light] .wizard-step:before,:root[data-theme=light] .wizard-step:after{background:linear-gradient(90deg,transparent,rgba(122,92,30,.2),transparent)}:root[data-theme=light] .wizard-step h2{color:var(--dnd-gold);border-bottom-color:var(--dnd-gold);text-shadow:none}:root[data-theme=light] .description{color:#5c5647}:root[data-theme=light] .form-select,:root[data-theme=light] .form-input{background:#fff;color:var(--dnd-text);border-color:var(--dnd-border)}:root[data-theme=light] .form-select:focus,:root[data-theme=light] .form-input:focus{background:#fff;border-color:var(--dnd-gold);box-shadow:0 0 0 3px #7a5c1e14}:root[data-theme=light] .form-select::placeholder,:root[data-theme=light] .form-input::placeholder{color:#b0a898}:root[data-theme=light] .form-select option{background:#fff;color:var(--dnd-text)}:root[data-theme=light] .race-info,:root[data-theme=light] .class-info{background:#f8f5f0;border-color:var(--dnd-border);box-shadow:none}:root[data-theme=light] .race-info h3,:root[data-theme=light] .class-info h3{color:var(--dnd-gold)}:root[data-theme=light] .method-tab{background:#f5f2ec;color:var(--dnd-text);border-color:var(--dnd-border)}:root[data-theme=light] .method-tab:hover{background:#ede8df}:root[data-theme=light] .method-tab.active{background:linear-gradient(135deg,#a0811a,#7a5c1e);color:#fff;border-color:#7a5c1e}:root[data-theme=light] .score-input,:root[data-theme=light] .score-display{background:#fff;color:var(--dnd-text);border-color:var(--dnd-border)}:root[data-theme=light] .dnd-score-pool{background:#f0ebe3;border-color:var(--dnd-border)}:root[data-theme=light] .ability-card{background:#fff;border-color:var(--dnd-border);box-shadow:0 1px 4px #0000000d}:root[data-theme=light] .ability-card:hover{border-color:var(--dnd-gold)}:root[data-theme=light] .ability-input{background:#fff;color:var(--dnd-gold);border-color:var(--dnd-border)}:root[data-theme=light] .ability-input:focus{background:#fff;border-color:var(--dnd-gold);box-shadow:0 0 0 3px #7a5c1e14}:root[data-theme=light] .bonus-badge{background:#fce4e4;color:#8b2e2e;border-color:#d9a5a5}:root[data-theme=light] .skill-checkbox{background:#f5f2ec;border-color:var(--dnd-border)}:root[data-theme=light] .skill-checkbox:hover{background:#ede8df;border-color:var(--dnd-gold)}:root[data-theme=light] .skill-checkbox.selected{background:#7a5c1e14;border-color:var(--dnd-gold)}:root[data-theme=light] .levelup-section{background:#f8f5f0;border-color:var(--dnd-border)}.primal-champion-notice{background:#ffd7001a;border:1px solid var(--dnd-gold, #c9a84c);border-radius:8px;padding:1rem}:root[data-theme=light] .primal-champion-notice{background:#c8a53c14}:root[data-theme=light] .subclass-option{background:#fff;border-color:var(--dnd-border)}:root[data-theme=light] .subclass-option:hover{background:#f8f5f0;border-color:var(--dnd-gold)}:root[data-theme=light] .subclass-option.selected{background:#7a5c1e0f;border-color:var(--dnd-gold)}:root[data-theme=light] .ability-increase-btn{background:#fff;border-color:var(--dnd-border)}:root[data-theme=light] .ability-increase-btn:hover{background:#f5f2ec;border-color:var(--dnd-gold)}:root[data-theme=light] .ability-increase-btn.selected{background:#7a5c1e14;border-color:var(--dnd-gold)}:root[data-theme=light] .feat-option,:root[data-theme=light] .feat-card{background:#fff;border-color:var(--dnd-border)}:root[data-theme=light] .feat-option:hover,:root[data-theme=light] .feat-card:hover{background:#f8f5f0;border-color:var(--dnd-gold)}:root[data-theme=light] .feat-description{background:#00000008}:root[data-theme=light] .feat-option-dialog-overlay{background:#00000059;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}:root[data-theme=light] .feat-option-dialog{background:linear-gradient(135deg,#fff,#f8f5f0);border-color:var(--dnd-border);box-shadow:0 8px 40px #00000026}:root[data-theme=light] .feature-choice-block{background:#f8f5f0;border-color:var(--dnd-border)}:root[data-theme=light] .spell-selection-info{background:#f8f5f0;border-color:var(--dnd-border)}:root[data-theme=light] .spell-card{background:#f8f5f0;border-color:var(--dnd-border)}:root[data-theme=light] .spell-card:hover{background:#f0ebe3;border-color:var(--dnd-gold)}:root[data-theme=light] .spell-card.selected{background:#7a5c1e0f;border-color:var(--dnd-gold)}:root[data-theme=light] .skill-tag{background:#7a5c1e14;color:var(--dnd-gold);border-color:var(--dnd-gold)}:root[data-theme=light] .skill-tag:hover{background:#7a5c1e24;box-shadow:0 0 8px #7a5c1e26}:root[data-theme=light] .background-skill-tag{background:#7a5c1e1f!important;border-color:var(--dnd-gold)!important;color:var(--dnd-gold)!important;box-shadow:0 0 6px #7a5c1e26!important}:root[data-theme=light] .selected-skills{background:#f8f5f0;border-color:#7a5c1e33}:root[data-theme=light] .selected-skills h4{color:var(--dnd-gold)}.multiclass-mode-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem;margin-top:.75rem}.multiclass-mode-btn{background:var(--dnd-card-bg);border:1px solid var(--dnd-border);border-radius:var(--radius-md);padding:.75rem;cursor:pointer;text-align:left;display:flex;flex-direction:column;gap:.25rem;transition:border-color .15s,background .15s;color:var(--dnd-text);overflow:hidden;word-break:break-word}.multiclass-mode-btn strong{color:var(--dnd-gold);font-size:.9rem;line-height:1.2}.multiclass-mode-btn span{font-size:.8rem;opacity:.75}.multiclass-mode-btn:hover{border-color:var(--dnd-gold);background:#d4af370f}.multiclass-mode-btn.selected{border-color:var(--dnd-gold);background:#d4af371a;box-shadow:0 0 8px #d4af3733}.prereq-warning{background:#b43c3c26;border:1px solid #a33;border-radius:var(--radius-sm);padding:.6rem 1rem;margin-bottom:.75rem;color:#e88;font-size:.9rem}.prereq-fail-badge{display:block;font-size:.78rem;color:#e55;margin-top:.25rem}.subclass-option.disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.multiclass-proficiencies{margin-top:1rem;padding:.75rem 1rem;background:#d4af370f;border:1px solid rgba(212,175,55,.3);border-radius:var(--radius-md);font-size:.9rem}.multiclass-proficiencies h4{color:var(--dnd-gold);margin:0 0 .5rem;font-size:.95rem}.multiclass-proficiencies p{margin:.2rem 0}:root[data-theme=light] .multiclass-mode-btn{background:#fff;border-color:var(--dnd-border)}:root[data-theme=light] .multiclass-mode-btn:hover{background:#f5f0e8}:root[data-theme=light] .multiclass-mode-btn.selected{background:#7a5c1e14}:root[data-theme=light] .prereq-warning{background:#b43c3c14;color:#b33}:root[data-theme=light] .prereq-fail-badge{color:#b33}:root[data-theme=light] .multiclass-proficiencies{background:#7a5c1e0d;border-color:#7a5c1e40}.share-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:3000;padding:1rem;animation:fadeInOverlay .2s ease-out}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.share-modal{background:var(--dnd-card, rgba(26, 35, 50, .99));border:1px solid var(--dnd-border, rgba(212, 175, 55, .3));border-radius:var(--radius-lg, 12px);width:95vw;max-width:480px;max-height:85vh;overflow-y:auto;box-shadow:0 16px 48px #0009;animation:slideUp .3s ease-out;display:flex;flex-direction:column}.share-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid rgba(212,175,55,.2);flex-shrink:0}.share-modal-header h3{margin:0;font-size:1.2rem;font-weight:700;color:var(--dnd-gold, #d4af37);font-family:Georgia,serif}.share-modal-close{background:none;border:none;font-size:1.4rem;cursor:pointer;padding:.25rem;color:var(--dnd-text-secondary, #a0a0a0);line-height:1;transition:color .2s;border-radius:4px}.share-modal-close:hover{color:var(--dnd-gold, #d4af37);background:#d4af371a}.share-modal-charname{padding:0 1.5rem;margin:1rem 0 .75rem;font-weight:600;color:var(--dnd-text-primary, #e8d5b7);font-size:.95rem}.share-form{display:flex;gap:.5rem;margin:0 1.5rem 1rem}.share-email-input{flex:1;padding:.6rem .75rem;border:1px solid rgba(212,175,55,.3);border-radius:6px;font-size:.95rem;background:#0000004d;color:var(--dnd-text-primary, #e8d5b7);font-family:inherit;transition:all .2s}.share-email-input::placeholder{color:#d4af3780}.share-email-input:focus{outline:none;border-color:var(--dnd-gold, #d4af37);box-shadow:0 0 0 2px #d4af3733;background:#0006}.share-btn-add{padding:.6rem 1rem;border:1px solid var(--dnd-gold, #d4af37);border-radius:6px;background:linear-gradient(135deg,#d4af3726,#d4af370d);color:var(--dnd-gold, #d4af37);font-weight:600;cursor:pointer;white-space:nowrap;font-size:.9rem;font-family:inherit;transition:all .2s}.share-btn-add:disabled{opacity:.4;cursor:not-allowed}.share-btn-add:not(:disabled):hover{background:linear-gradient(135deg,#d4af3740,#d4af3726);box-shadow:0 0 8px #d4af374d}.share-btn-add:not(:disabled):active{transform:scale(.98)}.share-msg{margin:0 1.5rem .75rem;padding:.75rem;border-radius:6px;font-size:.9rem;border-left:3px solid;animation:slideInMsg .3s ease-out}@keyframes slideInMsg{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.share-msg-error{background:#c8323226;color:#f99;border-color:#c83232}.share-msg-success{background:#64b46426;color:#9f9;border-color:#64b464}.share-list{padding:0 1.5rem 1.5rem;flex:1;overflow-y:auto}.share-list h4{margin:0 0 .75rem;font-size:.9rem;color:var(--dnd-gold, #d4af37);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.share-list ul{list-style:none;margin:0;padding:0}.share-list-empty{font-size:.9rem;color:var(--dnd-text-secondary, #a0a0a0);font-style:italic;text-align:center;padding:1rem 0}.share-list-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;border-radius:6px;margin-bottom:.5rem;background:#d4af370d;border:1px solid rgba(212,175,55,.1);transition:all .2s}.share-list-item:last-child{margin-bottom:0}.share-list-item:hover{background:#d4af3714;border-color:#d4af3733}.share-list-info{display:flex;flex-direction:column;gap:.2rem;flex:1}.share-list-name{font-weight:500;color:var(--dnd-text-primary, #e8d5b7)}.share-list-email{font-size:.8rem;color:var(--dnd-text-secondary, #a0a0a0)}.share-btn-remove{background:none;border:1px solid rgba(200,80,80,.4);border-radius:4px;padding:.35rem .6rem;cursor:pointer;color:#f99;font-size:.85rem;transition:all .2s;flex-shrink:0}.share-btn-remove:not(:disabled):hover{background:#c8505026;border-color:#c8505099;color:#fcc}.share-btn-remove:disabled{opacity:.4;cursor:not-allowed}:root[data-theme=light] .share-modal{background:#f5f1e8;border-color:#b48c3266}:root[data-theme=light] .share-modal-header{border-bottom-color:#b48c3233}:root[data-theme=light] .share-modal-header h3{color:#8b4513}:root[data-theme=light] .share-email-input{background:#fafaf8;color:#333;border-color:#b48c324d}:root[data-theme=light] .share-email-input::placeholder{color:#b48c3280}:root[data-theme=light] .share-email-input:focus{border-color:#b48c32;background:#fffbf5}:root[data-theme=light] .share-btn-add{color:#8b4513;border-color:#b48c32;background:linear-gradient(135deg,#b48c321a,#b48c3205)}:root[data-theme=light] .share-btn-add:not(:disabled):hover{background:linear-gradient(135deg,#b48c3226,#b48c320d);box-shadow:0 0 8px #b48c3233}:root[data-theme=light] .share-modal-charname{color:#333}:root[data-theme=light] .share-list h4{color:#8b4513}:root[data-theme=light] .share-list-name{color:#333}:root[data-theme=light] .share-list-email{color:#999}:root[data-theme=light] .share-list-item{background:#b48c320d;border-color:#b48c3226}:root[data-theme=light] .share-msg-error{background:#c864641a;color:#c83232;border-color:#e88888}:root[data-theme=light] .share-msg-success{background:#64b4641a;color:#2d7a2d;border-color:#8d8}.pull-to-refresh-container{position:relative;width:100%;height:100%}.pull-to-refresh-indicator{position:fixed;top:0;left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:6px;z-index:10001;pointer-events:none;padding-top:env(safe-area-inset-top,0px);color:#fff}.pull-to-refresh-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#000;z-index:10000;pointer-events:none}.pull-to-refresh-indicator.ready{color:var(--dnd-gold, #ffd700)}.pull-to-refresh-indicator.refreshing{color:#7ddf7d}.refresh-spinner{width:40px;height:40px;position:relative;display:flex;align-items:center;justify-content:center;transition:transform .1s linear}.spinner-arc{width:32px;height:32px;border:3px solid transparent;border-top:3px solid currentColor;border-right:3px solid currentColor;border-radius:50%;animation:none}.pull-to-refresh-indicator.refreshing .spinner-arc{animation:spinnerRotate .8s linear infinite}@keyframes spinnerRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.refresh-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:currentColor;white-space:nowrap}:root[data-theme=light] .pull-to-refresh-indicator{color:var(--dnd-text, #1a1a1a)}:root[data-theme=light] .pull-to-refresh-indicator.ready{color:#d4a844}:root[data-theme=light] .pull-to-refresh-indicator.refreshing{color:#4caf50}:root[data-theme=light] .refresh-label{color:currentColor}.slide-panel{touch-action:auto}@media(max-width:768px){.refresh-spinner{width:36px;height:36px}.spinner-arc{width:28px;height:28px;border-width:2px}.refresh-label{font-size:.7rem}}@media(max-width:480px){.refresh-spinner{width:32px;height:32px}.spinner-arc{width:24px;height:24px;border-width:2px}.refresh-label{font-size:.65rem}}@keyframes marching-ants{0%{background-position:0 0,0 100%,0 0,100% 0}to{background-position:20px 0,-20px 100%,0 -20px,100% 20px}}:root{--rc-drag-handle-size: 12px;--rc-drag-handle-mobile-size: 24px;--rc-drag-handle-bg-colour: rgba(0, 0, 0, .2);--rc-drag-bar-size: 6px;--rc-border-color: rgba(255, 255, 255, .7);--rc-focus-color: #0088ff}.ReactCrop{position:relative;display:inline-block;cursor:crosshair;max-width:100%}.ReactCrop *,.ReactCrop *:before,.ReactCrop *:after{box-sizing:border-box}.ReactCrop--disabled,.ReactCrop--locked{cursor:inherit}.ReactCrop__child-wrapper{overflow:hidden;max-height:inherit}.ReactCrop__child-wrapper>img,.ReactCrop__child-wrapper>video{display:block;max-width:100%;max-height:inherit}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>img,.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>video{touch-action:none}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__crop-selection{touch-action:none}.ReactCrop__crop-mask{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;width:calc(100% + .5px);height:calc(100% + .5px)}.ReactCrop__crop-selection{position:absolute;top:0;left:0;transform:translateZ(0);cursor:move}.ReactCrop--disabled .ReactCrop__crop-selection{cursor:inherit}.ReactCrop--circular-crop .ReactCrop__crop-selection{border-radius:50%}.ReactCrop--circular-crop .ReactCrop__crop-selection:after{pointer-events:none;content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border:1px solid var(--rc-border-color);opacity:.3}.ReactCrop--no-animate .ReactCrop__crop-selection{outline:1px dashed white}.ReactCrop__crop-selection:not(.ReactCrop--no-animate .ReactCrop__crop-selection){animation:marching-ants 1s;background-image:linear-gradient(to right,#fff 50%,#444 50%),linear-gradient(to right,#fff 50%,#444 50%),linear-gradient(to bottom,#fff 50%,#444 50%),linear-gradient(to bottom,#fff 50%,#444 50%);background-size:10px 1px,10px 1px,1px 10px,1px 10px;background-position:0 0,0 100%,0 0,100% 0;background-repeat:repeat-x,repeat-x,repeat-y,repeat-y;color:#fff;animation-play-state:running;animation-timing-function:linear;animation-iteration-count:infinite}.ReactCrop__crop-selection:focus{outline:2px solid var(--rc-focus-color);outline-offset:-1px}.ReactCrop--invisible-crop .ReactCrop__crop-mask,.ReactCrop--invisible-crop .ReactCrop__crop-selection{display:none}.ReactCrop__rule-of-thirds-vt:before,.ReactCrop__rule-of-thirds-vt:after,.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-hz:after{content:"";display:block;position:absolute;background-color:#fff6}.ReactCrop__rule-of-thirds-vt:before,.ReactCrop__rule-of-thirds-vt:after{width:1px;height:100%}.ReactCrop__rule-of-thirds-vt:before{left:33.3333333333%}.ReactCrop__rule-of-thirds-vt:after{left:66.6666666667%}.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-hz:after{width:100%;height:1px}.ReactCrop__rule-of-thirds-hz:before{top:33.3333333333%}.ReactCrop__rule-of-thirds-hz:after{top:66.6666666667%}.ReactCrop__drag-handle{position:absolute;width:var(--rc-drag-handle-size);height:var(--rc-drag-handle-size);background-color:var(--rc-drag-handle-bg-colour);border:1px solid var(--rc-border-color)}.ReactCrop__drag-handle:focus{background:var(--rc-focus-color)}.ReactCrop .ord-nw{top:0;left:0;transform:translate(-50%,-50%);cursor:nw-resize}.ReactCrop .ord-n{top:0;left:50%;transform:translate(-50%,-50%);cursor:n-resize}.ReactCrop .ord-ne{top:0;right:0;transform:translate(50%,-50%);cursor:ne-resize}.ReactCrop .ord-e{top:50%;right:0;transform:translate(50%,-50%);cursor:e-resize}.ReactCrop .ord-se{bottom:0;right:0;transform:translate(50%,50%);cursor:se-resize}.ReactCrop .ord-s{bottom:0;left:50%;transform:translate(-50%,50%);cursor:s-resize}.ReactCrop .ord-sw{bottom:0;left:0;transform:translate(-50%,50%);cursor:sw-resize}.ReactCrop .ord-w{top:50%;left:0;transform:translate(-50%,-50%);cursor:w-resize}.ReactCrop__disabled .ReactCrop__drag-handle{cursor:inherit}.ReactCrop__drag-bar{position:absolute}.ReactCrop__drag-bar.ord-n{top:0;left:0;width:100%;height:var(--rc-drag-bar-size);transform:translateY(-50%)}.ReactCrop__drag-bar.ord-e{right:0;top:0;width:var(--rc-drag-bar-size);height:100%;transform:translate(50%)}.ReactCrop__drag-bar.ord-s{bottom:0;left:0;width:100%;height:var(--rc-drag-bar-size);transform:translateY(50%)}.ReactCrop__drag-bar.ord-w{top:0;left:0;width:var(--rc-drag-bar-size);height:100%;transform:translate(-50%)}.ReactCrop--new-crop .ReactCrop__drag-bar,.ReactCrop--new-crop .ReactCrop__drag-handle,.ReactCrop--fixed-aspect .ReactCrop__drag-bar,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-n,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-e,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-s,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-w{display:none}@media(pointer:coarse){.ReactCrop .ord-n,.ReactCrop .ord-e,.ReactCrop .ord-s,.ReactCrop .ord-w{display:none}.ReactCrop__drag-handle{width:var(--rc-drag-handle-mobile-size);height:var(--rc-drag-handle-mobile-size)}}@keyframes sheetFadeIn{0%{opacity:0}to{opacity:1}}@keyframes sectionSlideUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes headerDrop{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes goldPulse{0%,to{box-shadow:0 0 8px #d4af3726}50%{box-shadow:0 0 18px #d4af3759}}@keyframes itemAppear{0%{opacity:0;transform:translate(-10px) scale(.97)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes hpFlash{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes criticalPulse{0%,to{opacity:1;box-shadow:0 0 4px #ef53504d}50%{opacity:.7;box-shadow:0 0 12px #ef535099}}@keyframes bloodiedPulse{0%,to{box-shadow:0 0 4px #f39c1233}50%{box-shadow:0 0 10px #f39c1266}}@keyframes slotDeplete{0%{transform:scale(1.3);opacity:1}to{transform:scale(1);opacity:.4}}@keyframes diceShake{0%,to{transform:translate(0)}10%{transform:translate(-3px) rotate(-1deg)}30%{transform:translate(3px) rotate(1deg)}50%{transform:translate(-2px)}70%{transform:translate(2px)}90%{transform:translate(-1px)}}@keyframes nat20Glow{0%{box-shadow:0 0 10px #ffd7004d}50%{box-shadow:0 0 30px #ffd700cc,0 0 60px #ffd7004d}to{box-shadow:0 0 10px #ffd7004d}}@keyframes nat1Flash{0%,to{background:transparent}50%{background:#e74c3c26}}@keyframes tabIndicatorSlide{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.character-sheet{background:linear-gradient(180deg,var(--dnd-darker) 0%,var(--dnd-dark) 50%,#0a0f1a 100%);background-attachment:fixed;min-height:100vh;padding:1.25rem;padding-top:calc(1.25rem + env(safe-area-inset-top,0px));color:var(--dnd-text);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;position:relative;animation:sheetFadeIn .5s ease-out}.character-sheet:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 20% 50%,rgba(212,175,55,.03) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(139,58,58,.02) 0%,transparent 50%);pointer-events:none;z-index:0}.sheet-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;margin-bottom:1.25rem;background:linear-gradient(135deg,#1a2332f2,#0f1419f2);padding:1.5rem;border-radius:var(--radius-lg);border:1px solid var(--dnd-border);box-shadow:0 4px 24px #00000080,inset 0 1px 1px #d4af3714;position:relative;z-index:50;animation:headerDrop .5s ease-out;gap:1.25rem}.sheet-header:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--dnd-gold),transparent);opacity:.6}.sheet-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--dnd-gold),transparent);opacity:.6}.character-title{flex:1 1 auto;min-width:250px;display:flex;flex-direction:column;align-items:flex-start}.character-title h1{font-size:2.4rem;margin:0;color:var(--dnd-gold);text-shadow:2px 2px 4px rgba(0,0,0,.7),0 0 20px rgba(212,175,55,.15);font-family:Georgia,serif;letter-spacing:2px;font-weight:700}.character-name-editable{cursor:pointer;transition:all .2s ease;padding:.25rem .5rem;border-radius:4px;position:relative}.character-name-editable:hover{background:#d4af371a;text-shadow:2px 2px 4px rgba(0,0,0,.7),0 0 30px rgba(212,175,55,.3)}.character-name-editable:after{content:" ✎";font-size:.7em;opacity:.5;transition:opacity .2s}.character-name-editable:hover:after{opacity:1}.name-edit-container{display:flex;flex-direction:column;gap:.5rem;margin:0;max-width:100%}.name-edit-actions{display:flex;gap:.5rem}.name-edit-save{padding:.3rem .75rem;font-size:.8rem;background:linear-gradient(135deg,#4caf50,#388e3c);color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600;transition:all .2s}.name-edit-save:hover{box-shadow:0 2px 8px #4caf5066}.name-edit-save:active{transform:scale(.97)}.name-edit-cancel{padding:.3rem .75rem;font-size:.8rem;background:#ffffff1a;color:var(--dnd-text-light);border:1px solid rgba(255,255,255,.2);border-radius:4px;cursor:pointer;font-weight:500;transition:all .2s}.name-edit-cancel:hover{background:#ffffff26}.name-edit-cancel:active{transform:scale(.97)}.name-edit-input{font-size:2.4rem;font-family:Georgia,serif;letter-spacing:2px;color:var(--dnd-gold);background:#0000004d;border:2px solid var(--dnd-gold);border-radius:4px;padding:.25rem .5rem;margin:0;text-shadow:2px 2px 4px rgba(0,0,0,.7);min-width:300px}.name-edit-input:focus{outline:none;box-shadow:0 0 12px #d4af3766}.btn-sm{padding:.2rem .4rem;font-size:.75rem;min-width:auto;height:auto}.edit-name-btn{padding:0!important;font-size:1rem!important;background:none!important;border:none!important;cursor:pointer;opacity:.7;transition:opacity .2s}.edit-name-btn:hover{opacity:1}.btn-confirm{background:linear-gradient(135deg,#4caf50,#388e3c);color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:700;transition:all .2s;padding:.2rem .4rem;font-size:.75rem}.btn-confirm:hover{box-shadow:0 2px 8px #4caf5066}.btn-confirm:active{transform:scale(.95)}.btn-cancel{background:linear-gradient(135deg,#f44336,#d32f2f);color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:700;transition:all .2s;padding:.2rem .4rem;font-size:.75rem}.btn-cancel:hover{box-shadow:0 2px 8px #f4433666}.btn-cancel:active{transform:scale(.95)}.subtitle{font-size:1.2rem;color:var(--dnd-text-light);margin:.5rem 0 0;text-shadow:1px 1px 2px rgba(0,0,0,.7);font-family:Georgia,serif;letter-spacing:1px}.subclass{color:var(--dnd-text);font-style:italic;margin:.375rem 0 0;font-size:1rem;letter-spacing:.5px;opacity:.9}.header-buttons{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center;align-items:center;flex:1 1 100%}.burger-menu-wrapper{display:block;position:absolute;top:calc(1rem + env(safe-area-inset-top,0px));right:1rem}.burger-toggle{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:40px;height:40px;background:#d4af371a;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);cursor:pointer;padding:8px;transition:all .2s ease}.burger-toggle:hover{background:#d4af3733;border-color:var(--dnd-gold)}.burger-toggle span{display:block;width:20px;height:2px;background:var(--dnd-gold);border-radius:2px;transition:all .3s ease}.burger-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.burger-toggle.open span:nth-child(2){opacity:0}.burger-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.burger-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;background:linear-gradient(135deg,#1a2332fa,#0f1419fa);border:1px solid var(--dnd-border);border-radius:var(--radius-sm);box-shadow:0 8px 32px #0009;z-index:100;padding:.5rem 0;animation:burgerSlideIn .2s ease-out}@keyframes burgerSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.burger-item{display:block;width:100%;padding:.65rem 1rem;background:none;border:none;color:var(--dnd-text);font-size:.9rem;text-align:left;cursor:pointer;transition:background .15s ease;white-space:nowrap}.burger-item:hover{background:#d4af371f;color:var(--dnd-gold)}.burger-item:disabled{opacity:.5;cursor:not-allowed}.burger-divider{height:1px;background:var(--dnd-border);margin:.3rem .75rem}.burger-user{display:block;padding:.4rem 1rem;font-size:.8rem;color:var(--dnd-gold);opacity:.7}.header-buttons .btn{flex:0 1 auto;min-width:max-content;font-size:.9rem;padding:.7rem 1rem;text-align:center;white-space:nowrap;border-radius:4px;transition:all .2s ease}.header-buttons .btn:hover{transform:translateY(-1px)}.sheet-header .button-group{display:flex;gap:.75rem;margin-left:1.5rem;align-self:flex-start}.sheet-grid{display:flex;flex-wrap:wrap;gap:1.25rem;margin-bottom:1.25rem;position:relative;z-index:1;align-items:flex-start}.sheet-top-block{margin-bottom:1.25rem;position:relative;z-index:1;animation:sectionSlideUp .45s ease-out both;animation-delay:.05s}.sheet-top-block .vitals-combat{flex:none;min-width:0;max-width:100%;width:100%}.section-header-static{color:var(--dnd-gold);margin-top:0;margin-bottom:1rem;font-size:1.15rem;border-bottom:2px solid rgba(212,175,55,.25);padding-bottom:.5rem;font-family:Georgia,serif;letter-spacing:1px;text-transform:uppercase;font-weight:700}.vitals-section-body{display:block}.vitals-combat-divider{height:2px;background:linear-gradient(90deg,transparent,var(--dnd-gold),transparent);margin:1.5rem 0;opacity:.35}.sheet-bottom-block{margin-bottom:1.25rem;position:relative;z-index:1;animation:sectionSlideUp .45s ease-out both;animation-delay:.15s}.sheet-tabs{display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:0;background:#1a233299;border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:.5rem .5rem 0;border:1px solid var(--dnd-border);border-bottom:none;border-top:3px solid var(--dnd-gold)}.sheet-tab{padding:.85rem 1rem;border:none;background:transparent;color:var(--dnd-text-muted);font-family:Georgia,serif;font-size:.85rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;cursor:pointer;border-radius:var(--radius-md) var(--radius-md) 0 0;transition:all .2s ease;position:relative}.sheet-tab:hover{color:var(--dnd-text);background:#d4af3714}.sheet-tab.active{color:var(--dnd-gold);background:#1a2332cc;box-shadow:inset 0 2px 0 var(--dnd-gold)}.sheet-tab.active:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--dnd-gold);border-radius:0 0 3px 3px;animation:tabIndicatorSlide .3s cubic-bezier(.4,0,.2,1);transform-origin:center}.sheet-tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:#1a2332cc}.tab-content{border-radius:0 0 var(--radius-lg) var(--radius-lg);border-top:none;min-width:0;max-width:100%;width:100%;flex:none}.tab-content>.section-body{animation:sectionExpand .2s ease-out}.section{background:#1a2332cc;color:var(--dnd-text);padding:1.25rem;border-radius:var(--radius-lg);box-shadow:0 2px 12px #0006,inset 0 1px 1px #d4af370a;border:1px solid var(--dnd-border);flex:1 1 calc(33.333% - 1rem);min-width:300px;max-width:100%;box-sizing:border-box;border-top:3px solid var(--dnd-gold);transition:all .3s ease;position:relative;animation:sectionSlideUp .45s ease-out both}.section:nth-child(1){animation-delay:.05s}.section:nth-child(2){animation-delay:.12s}.section:nth-child(3){animation-delay:.19s}.section:nth-child(4){animation-delay:.26s}.section:nth-child(5){animation-delay:.33s}.section:nth-child(6){animation-delay:.4s}.section:hover{border-top-color:var(--dnd-accent-red);box-shadow:0 8px 30px #d4af371a,inset 0 1px 1px #d4af371a}.section:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--dnd-gold),transparent);opacity:.4}.section h3{color:var(--dnd-gold);margin-top:0;margin-bottom:1rem;font-size:1.15rem;border-bottom:2px solid rgba(212,175,55,.25);padding-bottom:.5rem;font-family:Georgia,serif;letter-spacing:1px;text-transform:uppercase;font-weight:700}.section h3.section-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;display:flex;align-items:center;gap:.5rem;transition:color .2s ease}.section h3.section-toggle:hover{color:var(--dnd-accent-red)}.section.collapsed h3.section-toggle{margin-bottom:0;border-bottom-color:transparent;padding-bottom:0}.toggle-icon{font-size:.85em;line-height:1;transition:transform .2s ease}.section-body{animation:sectionExpand .25s ease-out}@keyframes sectionExpand{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.vitals{grid-column:span 1}.hp-tracker{margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid rgba(212,175,55,.1)}.hp-display{margin-bottom:.75rem}.hp-bar-container{position:relative;height:22px;background:#09191acc;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);margin-bottom:.5rem;display:flex;overflow:visible}.hp-bar{height:100%;background:linear-gradient(90deg,#2d7a3a,#4caf50);border-radius:var(--radius-sm) 0 0 var(--radius-sm);transition:width .5s cubic-bezier(.4,0,.2,1),background .5s ease;flex-shrink:0}.hp-bar-container.hp-bloodied .hp-bar{background:linear-gradient(90deg,#d35400,#e67e22)}.hp-bar-container.hp-critical .hp-bar{background:linear-gradient(90deg,#c0392b,#e74c3c);animation:criticalPulse 1.5s ease-in-out infinite}.hp-bar-container.hp-bloodied{animation:bloodiedPulse 2s ease-in-out infinite}.hp-bar.temp{background:linear-gradient(90deg,#1565c0,#42a5f5);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.hp-numbers{display:flex;align-items:baseline;gap:.25rem;font-weight:700}.hp-current{font-size:1.5rem;color:var(--dnd-gold)}.hp-separator{color:var(--dnd-text);font-size:1rem;opacity:.5}.hp-max{font-size:1rem;color:var(--dnd-text)}.hp-temp{font-size:.8rem;color:#42a5f5;margin-left:.5rem;font-style:italic}.hp-controls{display:flex;gap:.35rem;align-items:center;flex-wrap:nowrap}.hp-input{width:68px;padding:.3rem .35rem;background:#09191ae6;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);color:var(--dnd-text-light);font-size:1rem;text-align:center;font-weight:700}.hp-input:focus{outline:none;border-color:var(--dnd-gold);box-shadow:0 0 8px #d4af3733}.hp-input::placeholder{color:#d8c9b84d;font-weight:400}.hp-buttons{display:flex;gap:.25rem}.hp-btn{padding:.5rem .625rem;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;background:#09191acc;color:var(--dnd-text);min-width:3.8rem;text-align:center}.hp-btn.damage{border-color:var(--dnd-accent-red);color:var(--dnd-accent-red)}.hp-btn.damage:hover{background:#8b3a3a4d;box-shadow:0 0 8px #8b3a3a4d}.hp-btn.heal{border-color:#4caf50;color:#4caf50}.hp-btn.heal:hover{background:#4caf5033;box-shadow:0 0 8px #4caf504d}.hp-btn.temp-hp{border-color:#42a5f5;color:#42a5f5}.hp-btn.temp-hp:hover{background:#42a5f533;box-shadow:0 0 8px #42a5f54d}.hp-btn.reset{border-color:var(--dnd-gold);color:var(--dnd-gold)}.hp-btn.reset:hover{background:#d4af3726}.vitals-compact-row{display:flex;justify-content:space-around;align-items:center;gap:1rem;padding:.75rem 0;margin-bottom:.75rem;border-bottom:1px solid rgba(212,175,55,.1);font-size:.9rem}.compact-stat-item{display:flex;align-items:center;gap:.4rem;flex:1;justify-content:center;position:relative}.compact-stat-icon{font-size:1.3rem;display:inline-block}.ac-shield-icon,.init-lightning-icon,.speed-run-icon,.prof-laurel-icon{width:1.3em;height:1.3em;vertical-align:middle;color:var(--dnd-gold)}.stat-tooltip{position:absolute;bottom:120%;left:50%;transform:translate(-50%);background:#000000e6;color:var(--dnd-gold);padding:.5rem .75rem;border-radius:var(--radius-sm);border:1px solid var(--dnd-gold);white-space:nowrap;font-size:.85rem;font-weight:600;z-index:1000;box-shadow:0 4px 12px #00000080;animation:tooltipFadeIn .2s ease-out}.stat-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:#000000e6}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(5px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.compact-stat-value{font-weight:700;color:var(--dnd-gold);font-size:1.1rem;cursor:pointer;transition:color .2s ease}.compact-stat-value:hover{color:var(--dnd-gold-light)}.compact-stat-value.ac-manual{color:#ffb74d}.compact-stat-value .ac-edit.inline{display:flex;gap:.25rem}.stat-box{display:flex;justify-content:space-between;align-items:center;padding:.625rem 0;border-bottom:1px solid rgba(212,175,55,.08);transition:all .3s ease}.stat-box:last-child{border-bottom:none}.stat-box:hover{background:#d4af370d;padding-left:.5rem;margin-left:-.5rem}.stat-label{font-weight:600;color:var(--dnd-text);font-size:.95rem;letter-spacing:.5px}.stat-value{color:var(--dnd-gold);font-size:1.3rem;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.5)}.speed-bonus-hint{font-size:.7rem;color:var(--text-secondary, #aaa);font-weight:400}.ac-box{position:relative;flex-wrap:wrap}.ac-clickable{cursor:pointer;transition:all .2s ease;border-bottom:1px dashed rgba(212,175,55,.3);padding:0 .25rem}.ac-clickable:hover{color:var(--dnd-accent-red);border-bottom-color:var(--dnd-accent-red)}.ac-clickable.ac-manual{color:#6ecfff;text-shadow:0 0 6px rgba(110,207,255,.3)}.ac-edit{display:flex;align-items:center;gap:.375rem}.ac-input{width:3.5rem;padding:.25rem .375rem;background:#0006;border:1px solid var(--dnd-gold);border-radius:var(--radius-sm);color:var(--dnd-gold);font-size:1.1rem;font-weight:700;text-align:center}.ac-input:focus{outline:none;box-shadow:0 0 0 2px #d4af374d}.ac-btn{background:none;border:1px solid var(--dnd-border);color:var(--dnd-text-light);cursor:pointer;padding:.2rem .4rem;border-radius:var(--radius-sm);font-size:.9rem;transition:all .2s ease}.ac-btn.save{color:#66bb6a;border-color:#66bb6a4d}.ac-btn.save:hover{background:#66bb6a26}.ac-btn.reset{color:#ef9a9a;border-color:#ef9a9a4d}.ac-btn.reset:hover{background:#ef9a9a26}.armor-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;background:#0009;display:flex;align-items:center;justify-content:center;animation:armorModalFadeIn .2s ease-out}@keyframes armorModalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes armorModalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.armor-modal{display:flex;flex-direction:column;gap:.75rem;background:var(--dnd-bg-card, #1a1a2e);border:1px solid var(--dnd-gold);border-radius:var(--radius-md, 8px);padding:0;min-width:300px;max-width:380px;width:90vw;box-shadow:0 8px 32px #00000080;animation:armorModalSlideIn .25s ease-out}.armor-modal-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid rgba(212,175,55,.2)}.armor-modal-header h3{margin:0;font-size:1rem;color:var(--dnd-gold);font-family:Georgia,serif;text-transform:uppercase;letter-spacing:.5px}.armor-modal-close{background:none;border:none;color:var(--dnd-text-muted);font-size:1.2rem;cursor:pointer;padding:.25rem;line-height:1;border-radius:var(--radius-sm);transition:all .15s ease}.armor-modal-close:hover{color:var(--dnd-gold);background:#d4af371a}.armor-modal-body{display:flex;flex-direction:column;gap:.75rem;padding:0 1rem}.armor-modal-footer{display:flex;gap:.5rem;justify-content:center;padding:.75rem 1rem;border-top:1px solid rgba(212,175,55,.2)}.armor-modal-footer .ac-btn{font-size:.85rem;padding:.375rem 1rem}.armor-select-group{display:flex;flex-direction:column;gap:.25rem}.armor-select-label{font-size:.75rem;color:var(--dnd-gold);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.armor-select{width:100%;padding:.375rem .5rem;background:#0006;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);color:var(--dnd-text);font-size:.85rem;cursor:pointer}.armor-select:focus{outline:none;border-color:var(--dnd-gold);box-shadow:0 0 0 2px #d4af3733}.armor-select optgroup{font-weight:700;color:var(--dnd-gold)}.armor-shield-toggle{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--dnd-text);cursor:pointer}.armor-shield-toggle input[type=checkbox]{accent-color:var(--dnd-gold);width:1rem;height:1rem;cursor:pointer}.armor-details{display:flex;gap:.375rem;flex-wrap:wrap}.armor-detail-tag{font-size:.7rem;padding:.125rem .375rem;border-radius:var(--radius-sm);background:#d4af371a;color:var(--dnd-text-light);border:1px solid rgba(212,175,55,.15)}.armor-detail-tag.warning{background:#ef9a9a26;color:#ef9a9a;border-color:#ef9a9a40}.armor-ac-summary{font-size:.85rem;color:var(--dnd-text-light);text-align:center;padding:.25rem 0;border-top:1px solid rgba(212,175,55,.1)}.armor-ac-summary strong{color:var(--dnd-gold);font-size:1.1rem}.ac-manual-note{font-size:.75rem;color:#ffb74d}.armor-actions{display:flex;gap:.375rem;justify-content:center}.armor-actions .ac-btn{font-size:.8rem;padding:.25rem .75rem}.armor-manual-override{display:flex;gap:.25rem;align-items:center;padding-top:.25rem;border-top:1px solid rgba(212,175,55,.1)}.armor-manual-override .ac-input{flex:1;font-size:.9rem}.section-drag-handle{cursor:grab;color:#d4af374d;font-size:1rem;line-height:1;transition:all .2s ease;padding:.125rem .25rem;border-radius:var(--radius-sm);-webkit-user-select:none;user-select:none;flex-shrink:0}.section-drag-handle:hover{color:var(--dnd-gold);background:#d4af371a}.section-drag-handle:active{cursor:grabbing;color:var(--dnd-accent-red)}.section-toggle-text{display:flex;align-items:center;gap:.5rem;flex:1;cursor:pointer}.section.section-dragging{opacity:.4;transform:scale(.98);border-color:var(--dnd-gold)}.section.section-drag-over{border-top:3px solid var(--dnd-accent-red);box-shadow:0 -4px 12px #8b3a3a4d,0 2px 12px #0006}.abilities{grid-column:span 1}.ability-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.625rem}.ability-box{background:linear-gradient(135deg,#d4af3714,#8b3a3a14);border:1px solid var(--dnd-border);color:var(--dnd-text-light);padding:.75rem;border-radius:var(--radius-sm);text-align:center;box-shadow:inset 0 1px 1px #d4af370a,0 2px 8px #0003;transition:all .3s ease;position:relative}.ability-box:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--dnd-gold),transparent);opacity:0;transition:opacity .3s ease}.ability-box:hover{border-color:var(--dnd-gold);background:linear-gradient(135deg,#d4af3726,#8b3a3a1a);box-shadow:0 0 20px #d4af3726,inset 0 1px 1px #d4af371a;transform:translateY(-2px) scale(1.03)}.ability-box:hover:before{opacity:1}.ability-short{font-size:.7rem;font-weight:700;text-transform:uppercase;display:block;margin-bottom:.25rem;opacity:.8;letter-spacing:1px}.ability-score{font-size:1.6rem;font-weight:700;display:block;color:var(--dnd-gold);text-shadow:0 1px 3px rgba(0,0,0,.4);position:relative}.ability-mod{font-size:.9rem;color:var(--dnd-accent-red);margin-top:.25rem;font-weight:700}.saving-throw{display:flex;align-items:center;justify-content:center;gap:.3rem;margin-top:.35rem;padding:.2rem .4rem;border-radius:4px;background:#0003;font-size:.7rem;color:var(--text-secondary)}.saving-throw.proficient{background:#d4af371f;color:var(--dnd-gold)}.save-label{font-weight:600;letter-spacing:.03em}.save-value{font-weight:800;font-size:.8rem}.ability-score-input{width:3.2rem;padding:.25rem .35rem;text-align:center;font-size:1.4rem;font-weight:700;color:var(--dnd-gold);background:#00000059;border:1px solid var(--dnd-gold);border-radius:6px;outline:none;-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.ability-score-input::-webkit-outer-spin-button,.ability-score-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.ability-score-input:focus{box-shadow:0 0 8px #d4af3759}.ability-score.clickable{cursor:pointer;position:relative;transition:color .15s ease}.ability-score.clickable:hover{color:#fff;text-shadow:0 0 8px rgba(212,175,55,.6)}.ability-roll-icon{position:absolute;right:-.2rem;top:50%;transform:translateY(-50%);font-size:.7rem;opacity:0;transition:opacity .15s ease}.ability-score.clickable:hover .ability-roll-icon{opacity:1}.saving-throw.clickable{cursor:pointer;transition:all .15s ease}.saving-throw.clickable:hover{background:#d4af372e;color:#fff}.saving-throw.clickable:hover .save-roll-icon{opacity:1}.save-roll-icon{font-size:.65rem;opacity:0;transition:opacity .15s ease;margin-right:2px}.saving-throw.editable{cursor:pointer;transition:all .15s ease;border:1px dashed transparent}.saving-throw.editable:hover{border-color:var(--dnd-gold);background:#d4af3726}.ability-grid.edit-mode .ability-box{border:1px solid rgba(212,175,55,.3)}.skills-list{display:flex;flex-direction:column;gap:.375rem}.skill-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;border-left:2px solid var(--dnd-border);border-radius:var(--radius-sm);transition:all .3s ease;background:#09191a80;position:relative}.skill-row:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--dnd-gold),transparent);opacity:0;transition:opacity .3s ease}.skill-row.proficient{background:#d4af371a;border-left-color:var(--dnd-gold)}.skill-row:hover{border-left-color:var(--dnd-gold);background:#d4af3726}.skill-row:hover:before{opacity:1}.skill-name{display:flex;align-items:center;gap:.5rem;font-weight:500;color:var(--dnd-text-light);flex:1;letter-spacing:.3px;font-size:.9rem}.proficiency-mark{color:var(--dnd-gold);font-weight:700;font-size:1.1rem;text-shadow:0 2px 4px rgba(0,0,0,.5)}.skill-modifier{background:#09191acc;padding:.25rem .625rem;border-radius:var(--radius-sm);font-weight:700;color:var(--dnd-text);min-width:40px;text-align:center;border:1px solid var(--dnd-border);font-size:.85rem}.skill-row.proficient .skill-modifier{background:linear-gradient(135deg,var(--dnd-gold) 0%,var(--dnd-gold-dark) 100%);color:#fff;border-color:var(--dnd-gold);box-shadow:0 0 10px #d4af3733}.skill-row.expertise{background:#d4af3733;border-left-color:gold;border-left-width:3px}.skill-row.expertise .skill-modifier{background:linear-gradient(135deg,gold,#b8860b);color:#fff;border-color:gold;box-shadow:0 0 14px #ffd70059;font-weight:900}.expertise-mark{color:gold;font-weight:700;font-size:1.1rem;text-shadow:0 0 6px rgba(255,215,0,.5)}.empty-mark{color:var(--dnd-text-dim);font-size:1.1rem;opacity:.5}.background-skill-tag{font-size:.6rem;font-weight:700;color:#1a1a2e;background:#8b5cf6;border-radius:3px;padding:0 4px;margin-left:4px;line-height:1.4;letter-spacing:.5px;vertical-align:middle}.skill-row{cursor:pointer;-webkit-user-select:none;user-select:none}.skills-header-bar{display:flex;justify-content:flex-end;margin-bottom:.5rem}.skills-edit-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:var(--dnd-text-light, #e0e0e0);padding:.3rem .75rem;border-radius:6px;font-size:.78rem;cursor:pointer;transition:all .2s ease;letter-spacing:.3px}.skills-edit-btn:hover{background:#ffffff24;border-color:var(--dnd-gold, #d4a843)}.skills-edit-btn.active{background:#d4a84326;border-color:var(--dnd-gold, #d4a843);color:var(--dnd-gold, #d4a843)}.skills-list.edit-mode .skill-row{border-left:2px solid transparent;transition:border-color .15s ease}.skills-list.edit-mode .skill-row:hover{border-left-color:var(--dnd-gold, #d4a843)}.roll-icon{font-size:.75rem;margin-right:3px;opacity:0;transition:opacity .15s ease}.skill-row:hover .roll-icon{opacity:1}.skills-list.edit-mode .roll-icon{display:none}.skill-roll-result{display:flex;align-items:center;justify-content:space-between;background:#09191ad9;border:1px solid var(--dnd-gold, #d4a843);border-radius:8px;padding:.6rem 1rem;margin-bottom:.75rem;animation:rollSlideIn .3s ease;font-size:.95rem}.skill-roll-result.crit-success{border-color:#22c55e;background:#22c55e1f}.skill-roll-result.crit-fail{border-color:#ef4444;background:#ef44441f}.roll-skill-name{font-weight:600;color:var(--dnd-gold, #d4a843);letter-spacing:.3px}.roll-formula{color:var(--dnd-text-light, #e0e0e0);display:flex;align-items:center;gap:4px}.roll-die{font-weight:700;color:var(--dnd-text-light, #e0e0e0);background:#ffffff14;padding:0 5px;border-radius:4px;min-width:1.5em;text-align:center}.roll-die.nat20{color:#22c55e;background:#22c55e26;text-shadow:0 0 6px rgba(34,197,94,.5)}.roll-die.nat1{color:#ef4444;background:#ef444426;text-shadow:0 0 6px rgba(239,68,68,.5)}.roll-total{font-weight:700;font-size:1.1em;color:#fff;background:#ffffff1a;padding:0 6px;border-radius:4px}@keyframes rollSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.features-content h4{color:var(--dnd-gold);margin:.875rem 0 .5rem;font-family:Georgia,serif;letter-spacing:.5px;font-size:1.1rem}.features-content h4:first-child{margin-top:0}.features-content ul{list-style:none;padding:0;margin:.5rem 0 .75rem}.features-content li{padding:.5rem 0 .5rem 1.5rem;position:relative;color:var(--dnd-text);font-size:.9rem;line-height:1.4;margin-bottom:.375rem}.features-content li strong{color:var(--dnd-gold);display:block;font-size:1rem}.features-content li p{color:var(--dnd-text);margin:.5rem 0 0;font-style:normal;line-height:1.5;font-size:.9rem}.features-by-level{display:flex;flex-direction:column;gap:.5rem}.features-section-title{color:var(--dnd-gold);margin:.75rem 0 .4rem;font-family:Georgia,serif;font-size:1rem;letter-spacing:.5px}.feature-level-group{position:relative}.feature-level-label{color:var(--dnd-gold);font-family:Georgia,serif;font-size:.8rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;margin-bottom:.35rem;padding-bottom:.2rem;border-bottom:1px solid rgba(212,175,55,.15)}.feature-level-items{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.25rem}.feature-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .65rem;background:#1a2332b3;border:1px solid var(--dnd-border);border-radius:6px;color:var(--dnd-text-light);font-size:.82rem;cursor:pointer;transition:all .15s ease;line-height:1.3}.feature-chip:hover{border-color:var(--dnd-gold);background:#d4af3714}.feature-chip.active{border-color:var(--dnd-gold);background:#d4af371f;box-shadow:0 0 6px #d4af3726}.feature-chip-name{font-weight:500}.feature-chip-source{font-size:.7rem;color:#d4af37b3;background:#d4af3714;padding:.1rem .35rem;border-radius:3px;white-space:nowrap}.feature-chip-source.feat-source{color:#b482ffd9;background:#b482ff14}.feature-tooltip{margin-top:.25rem;margin-bottom:.4rem;padding:.6rem .75rem;background:#0f1419f2;border:1px solid rgba(212,175,55,.25);border-left:3px solid var(--dnd-gold);border-radius:6px;animation:featureTooltipIn .15s ease-out}@keyframes featureTooltipIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.feature-tooltip-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem}.feature-tooltip-header strong{color:var(--dnd-gold);font-size:.9rem;flex:1}.feature-tooltip-source{font-size:.7rem;color:#d4af3799;background:#d4af370f;padding:.1rem .35rem;border-radius:3px}.feature-tooltip-close{background:none;border:none;color:var(--dnd-text);opacity:.5;font-size:.85rem;cursor:pointer;padding:0;line-height:1}.feature-tooltip-close:hover{opacity:1}.feature-tooltip-text{color:var(--dnd-text);font-size:.83rem;line-height:1.55;margin:0}.feature-tooltip-text p{margin:0 0 8px}.feature-tooltip-text p:last-child{margin-bottom:0}.chosen-options-list{display:flex;flex-direction:column;gap:.75rem;margin-top:.5rem}.chosen-option-group{background:#09191a80;border:1px solid rgba(212,175,55,.12);border-radius:8px;padding:.6rem .8rem}.chosen-option-title{color:var(--dnd-gold, #d4a843);font-size:.85rem;display:block;margin-bottom:.35rem}.chosen-option-item{padding:.3rem 0}.chosen-option-name{font-weight:600;color:var(--dnd-text-light, #e0e0e0);font-size:.88rem}.chosen-option-desc{color:var(--dnd-text-dim, #aaa);font-size:.78rem;margin:.15rem 0 0;line-height:1.4}.class-resources{margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid rgba(212,175,55,.15)}.class-resources-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem;flex-wrap:wrap;gap:.4rem}.class-resources-header h4{color:var(--dnd-gold);font-size:.95rem;margin:0;font-family:Georgia,serif}.resource-rest-buttons{display:flex;gap:.4rem}.btn-rest{padding:3px 10px;border-radius:4px;border:1px solid var(--dnd-border);background:#0000004d;color:var(--text-secondary);font-size:.7rem;cursor:pointer;transition:all .2s ease}.btn-rest:hover{border-color:var(--dnd-gold);color:var(--dnd-gold);background:#d4af3714}.btn-rest.long{border-color:#64b46466}.btn-rest.long:hover{border-color:#64b464;color:#64b464;background:#64b4641a}.resources-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.5rem}.resource-card{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem .4rem;background:#0003;border:1px solid var(--dnd-border);border-radius:6px;cursor:default;transition:border-color .2s ease,box-shadow .2s ease}.resource-card:hover{border-color:var(--dnd-gold);box-shadow:0 0 6px #d4af3726}.resource-card.trackable{padding:.6rem .5rem;gap:.35rem}.resource-name{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);font-weight:600;text-align:center;line-height:1.2}.resource-value{font-weight:800;font-size:1rem;color:var(--dnd-gold);text-align:center}.resource-counter{display:flex;align-items:center;gap:.2rem}.resource-btn{width:22px;height:22px;border-radius:4px;border:1px solid var(--dnd-border);background:#0000004d;color:var(--text-secondary);font-size:.9rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;padding:0;line-height:1}.resource-btn:not(:disabled):hover{border-color:var(--dnd-gold);color:var(--dnd-gold);background:#d4af371a}.resource-btn:disabled{opacity:.3;cursor:not-allowed}.resource-btn.use{color:#e88}.resource-btn.use:not(:disabled):hover{border-color:#e88;color:#e88;background:#ee88881a}.resource-btn.restore{color:#8c8}.resource-btn.restore:not(:disabled):hover{border-color:#8c8;color:#8c8;background:#88cc881a}.resource-current{font-weight:800;font-size:1.1rem;color:var(--dnd-gold);min-width:1.4em;text-align:center}.resource-current.depleted{color:#e66}.resource-separator{color:var(--text-muted);font-size:.85rem;margin:0 1px}.resource-max{color:var(--text-secondary);font-size:.85rem;min-width:1.2em;text-align:center}.resource-pips{display:flex;flex-wrap:wrap;gap:3px;justify-content:center;margin-top:2px}.resource-pip{width:8px;height:8px;border-radius:50%;border:1px solid var(--dnd-border);transition:all .2s ease}.resource-pip.available{background:var(--dnd-gold);border-color:var(--dnd-gold);box-shadow:0 0 3px #d4af3766}.resource-pip.used{background:transparent;border-color:#d4af374d}.resource-rest-label{font-size:.6rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.sheet-footer{text-align:center;padding:1rem;background:#09191a99;border-radius:var(--radius-md);border:1px solid var(--dnd-border);color:var(--dnd-text);font-size:.85rem;position:relative;z-index:1}.inventory{grid-column:span 1}.currency-section{margin-bottom:.75rem}.currency-row{display:flex;gap:.375rem}.currency-box{flex:1;display:flex;flex-direction:column;align-items:center;gap:.2rem}.currency-input{width:100%;padding:.4rem .25rem;background:#09191ae6;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);color:var(--dnd-text-light);font-size:1rem;font-weight:700;text-align:center;box-sizing:border-box}.currency-input:focus{outline:none;border-color:var(--dnd-gold);box-shadow:0 0 6px #d4af3733}.currency-label{font-size:.7rem;letter-spacing:.05em;font-weight:700;opacity:.7}.currency-platinum .currency-input{border-color:#b4b4dc80;color:#c8c8e8}.currency-gold .currency-input{border-color:#d4af3780;color:var(--dnd-gold)}.currency-silver .currency-input{border-color:#b4b4b466;color:#b0b0b0}.currency-copper .currency-input{border-color:#b4643c66;color:#c8885a}.currency-platinum .currency-label{color:#c8c8e8}.currency-gold .currency-label{color:var(--dnd-gold)}.currency-silver .currency-label{color:#b0b0b0}.currency-copper .currency-label{color:#c8885a}.weight-bar{display:flex;justify-content:space-between;align-items:center;padding:.3rem .625rem;margin-bottom:.5rem;background:#09191a80;border:1px solid rgba(66,63,55,.4);border-radius:var(--radius-sm);font-size:.8rem;color:var(--dnd-text);opacity:.8}.weight-bar.overloaded{border-color:var(--dnd-accent-red);background:#8b3a3a1a;opacity:1}.overload-warning{color:var(--dnd-accent-red);font-weight:700;font-size:.75rem;letter-spacing:.05em}.category-tabs{display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:.625rem}.cat-tab{display:inline-flex;align-items:center;gap:.2rem;padding:.25rem .5rem;font-size:.75rem;background:#09191a99;border:1px solid rgba(66,63,55,.5);border-radius:20px;color:var(--dnd-text);cursor:pointer;transition:all .15s ease;white-space:nowrap}.cat-tab:hover{border-color:var(--dnd-gold);color:var(--dnd-gold);background:#d4af3712}.cat-tab.active{background:#d4af3726;border-color:var(--dnd-gold);color:var(--dnd-gold)}.cat-count{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;background:#d4af3740;border-radius:8px;font-size:.65rem;font-weight:700;color:var(--dnd-gold)}.inventory-list{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.625rem}.inventory-item{display:flex;align-items:flex-start;gap:.4rem;padding:.5rem .625rem;background:#09191a80;border:1px solid rgba(66,63,55,.5);border-radius:var(--radius-sm);transition:all .25s ease;animation:itemAppear .3s ease-out both}.inventory-item:nth-child(1){animation-delay:0s}.inventory-item:nth-child(2){animation-delay:.04s}.inventory-item:nth-child(3){animation-delay:.08s}.inventory-item:nth-child(4){animation-delay:.12s}.inventory-item:nth-child(5){animation-delay:.16s}.inventory-item:nth-child(6){animation-delay:.2s}.inventory-item:nth-child(n+7){animation-delay:.24s}.inventory-item.dragging{opacity:.4;transform:scale(.97);border-color:var(--dnd-gold);box-shadow:0 0 12px #d4af374d}.inventory-item.drag-over{border-color:var(--dnd-gold);border-top:2px solid var(--dnd-gold);background:#d4af3714;transform:translateY(2px)}.inventory-item .drag-handle{display:flex;align-items:center;cursor:grab;color:var(--dnd-text);opacity:.3;font-size:.9rem;padding:0 .15rem;flex-shrink:0;-webkit-user-select:none;user-select:none;transition:opacity .2s ease}.inventory-item:hover .drag-handle{opacity:.7}.inventory-item .drag-handle:active{cursor:grabbing;opacity:1;color:var(--dnd-gold)}.inventory-item:hover{border-color:var(--dnd-gold);background:#d4af370a}.inventory-item.equipped{border-color:#d4af3799;background:#d4af3712;animation:goldPulse 3s ease-in-out infinite}.equip-btn{width:28px;height:28px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border:1px solid rgba(66,63,55,.6);border-radius:var(--radius-sm);background:#09191ab3;cursor:pointer;font-size:.85rem;transition:all .15s ease;padding:0;opacity:.5}.equip-btn:hover{opacity:1;border-color:var(--dnd-gold);background:#d4af371a}.equip-btn.is-equipped{opacity:1;border-color:var(--dnd-gold);background:#d4af3733;box-shadow:0 0 6px #d4af374d}.item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.item-name{color:var(--dnd-text-light);font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-meta{display:flex;flex-wrap:wrap;gap:.25rem;align-items:center}.item-tag{display:inline-block;padding:.1rem .35rem;border-radius:3px;font-size:.7rem;font-weight:600;letter-spacing:.02em}.weapon-tag{background:#8b3a3a40;color:#d4836a;border:1px solid rgba(139,58,58,.4)}.armor-tag{background:#3c648c40;color:#7aabcf;border:1px solid rgba(60,100,140,.4)}.weight-tag{background:#423f3766;color:var(--dnd-text);opacity:.7;border:1px solid rgba(66,63,55,.5)}.item-desc{font-size:.72rem;color:var(--dnd-text);opacity:.6;font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inventory-item.editing{background:#d4af3714;border:1px solid rgba(212,175,55,.3);padding:.75rem}.edit-item-form{width:100%;display:flex;flex-direction:column;gap:.5rem}.edit-item-actions{display:flex;gap:.5rem;margin-top:.25rem}.edit-item-actions .btn-add-submit{flex:1}.edit-item-actions .btn-toggle-add{flex:0 0 auto;width:auto;padding:.5rem 1rem}.item-controls{display:flex;align-items:center;gap:.25rem;flex-shrink:0}.item-qty{color:var(--dnd-gold);font-weight:700;min-width:24px;text-align:center;font-size:.9rem}.qty-btn{width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:#09191acc;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);color:var(--dnd-text);cursor:pointer}.qty-btn.edit-btn{color:var(--dnd-gold);border-color:#d4af374d;font-size:.85rem}.qty-btn.edit-btn:hover{background:#d4af3726;color:#fff}.qty-btn{font-size:.8rem;transition:all .2s ease;padding:0}.qty-btn:hover{border-color:var(--dnd-gold);color:var(--dnd-gold);background:#d4af371a}.qty-btn.remove{color:var(--dnd-accent-red);border-color:#8b3a3a66}.qty-btn.remove:hover{border-color:var(--dnd-accent-red);background:#8b3a3a33}.qty-btn.info{color:#42a5f5;border-color:#42a5f566}.qty-btn.info:hover{border-color:#42a5f5;background:#42a5f526}.spell-detail-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.spell-detail-modal{background:#1a2332fa;border:1px solid var(--dnd-border);border-radius:var(--radius-lg);max-width:600px;max-height:85vh;overflow-y:auto;box-shadow:0 8px 32px #00000080;animation:slideInModal .3s ease-out}@keyframes slideInModal{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.spell-detail-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid rgba(212,175,55,.2);position:sticky;top:0;background:#1a2332fa}.spell-detail-header h3{margin:0;color:var(--dnd-gold);font-size:1.3rem;font-family:Georgia,serif}.spell-detail-header .close-btn{background:none;border:none;color:var(--dnd-text);font-size:1.5rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s ease}.spell-detail-header .close-btn:hover{background:#d4af371a;color:var(--dnd-gold)}.spell-detail-content{padding:1.5rem;color:var(--dnd-text);line-height:1.6}.spell-detail-content p{margin:.75rem 0;font-size:.95rem}.spell-detail-content strong{color:var(--dnd-gold)}.spell-description{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(212,175,55,.1)}.spell-text{margin-top:.75rem;font-size:.95rem;line-height:1.7;color:var(--dnd-text-light)}.spell-not-found{padding:2rem;text-align:center;color:var(--text-muted);font-style:italic}.add-item-section{margin-top:.5rem}.btn-toggle-add{width:100%;padding:.45rem;background:#d4af3714;border:1px dashed rgba(212,175,55,.35);border-radius:var(--radius-sm);color:var(--dnd-gold);font-size:.85rem;cursor:pointer;transition:all .2s ease;letter-spacing:.03em}.btn-toggle-add:hover,.btn-toggle-add.open{background:#d4af3724;border-color:var(--dnd-gold)}.add-item-form{display:flex;flex-direction:column;gap:.4rem;margin-top:.5rem;padding:.75rem;background:#09191a99;border:1px solid rgba(66,63,55,.6);border-radius:var(--radius-sm)}.add-form-row{display:flex;gap:.4rem}.form-input{padding:.45rem .6rem;background:#09191ae6;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);color:var(--dnd-text-light);font-size:1rem;min-width:0}.form-input:focus{outline:none;border-color:var(--dnd-gold);box-shadow:0 0 6px #d4af3733}.form-input::placeholder{color:#d8c9b84d}.form-input.flex-1{flex:1}.form-input.qty-small{width:58px;text-align:center;flex-shrink:0}.form-input.weight-input{width:72px;flex-shrink:0}.form-input.full-width{width:100%;box-sizing:border-box}.form-select{flex:1;padding:.45rem .5rem;background:#09191ae6;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);color:var(--dnd-text-light);font-size:1rem;cursor:pointer}.form-select:focus{outline:none;border-color:var(--dnd-gold)}.btn-add-submit{padding:.5rem;background:#d4af3726;border:1px solid var(--dnd-gold);border-radius:var(--radius-sm);color:var(--dnd-gold);font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s ease;letter-spacing:.03em}.btn-add-submit:hover{background:#d4af374d;box-shadow:0 0 8px #d4af3740}.empty-state{color:var(--dnd-text);opacity:.4;font-style:italic;font-size:.85rem;text-align:center;padding:1rem 0;margin:0}.notes-section{grid-column:span 1}.notes-textarea{width:100%;min-height:120px;padding:.75rem;background:#09191ae6;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);color:var(--dnd-text-light);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:1rem;line-height:1.6;resize:vertical;box-sizing:border-box}.notes-textarea:focus{outline:none;border-color:var(--dnd-gold);box-shadow:0 0 8px #d4af3733}.notes-textarea::placeholder{color:#d8c9b84d}.btn-save,.btn-load,.btn-export{font-size:.85rem!important}.btn-export{background:#3c648c26;border-color:#64a0dc80;color:#7aabcf}.btn-export:hover:not(:disabled){background:#3c648c4d;box-shadow:0 0 8px #64a0dc4d}.btn-export:disabled{opacity:.5;cursor:not-allowed}.pdf-export-mode{border-radius:0!important}.pdf-export-mode .notes-section,.pdf-export-mode .currency-input{pointer-events:none}.load-screen{max-width:600px;margin:2rem auto;padding:2rem;background:linear-gradient(135deg,#1a2332f2,#0f1419f2);border:1px solid var(--dnd-border);border-radius:var(--radius-lg);border-top:3px solid var(--dnd-gold);color:var(--dnd-text)}.load-screen h2{color:var(--dnd-gold);font-family:Georgia,serif;margin-top:0;margin-bottom:1.25rem;text-align:center;letter-spacing:1px}.saved-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem}.saved-entry{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#09191a99;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease}.saved-entry:hover{border-color:var(--dnd-gold);background:#d4af3714}.saved-entry-info{flex:1}.saved-entry-name{color:var(--dnd-gold);font-weight:700;font-size:1rem}.saved-entry-detail{color:var(--dnd-text);font-size:.8rem;opacity:.7;margin-top:.25rem}.saved-entry-actions{display:flex;gap:.375rem}.saved-entry-actions button{padding:.375rem .625rem;font-size:.75rem;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);cursor:pointer;background:#09191acc;color:var(--dnd-text);transition:all .2s ease}.saved-entry-actions .load-btn{border-color:var(--dnd-gold);color:var(--dnd-gold)}.saved-entry-actions .load-btn:hover{background:#d4af3733}.saved-entry-actions .delete-btn{border-color:var(--dnd-accent-red);color:var(--dnd-accent-red)}.saved-entry-actions .delete-btn:hover{background:#8b3a3a33}.load-screen .btn-back{display:block;margin:0 auto}.sheet-footer:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--dnd-gold),transparent);opacity:.5}@media(max-width:768px){.character-sheet{padding:.75rem;padding-top:calc(.75rem + env(safe-area-inset-top,0px))}.sheet-header{flex-direction:column;gap:.75rem;padding:1rem}.character-title{min-width:auto}.character-title h1{font-size:1.6rem;letter-spacing:1px}.subtitle{font-size:.95rem}.name-edit-input{font-size:1.4rem;padding:.15rem .3rem}.header-buttons .btn{font-size:.85rem!important}.sheet-grid{gap:1rem}.section{flex:1 1 calc(50% - 1rem);min-width:280px}.sheet-tabs{gap:.15rem;padding:.35rem .35rem 0}.sheet-tab{padding:.6rem .65rem;font-size:.75rem;letter-spacing:.3px}.ability-grid{grid-template-columns:repeat(3,1fr);gap:.4rem}.ability-box{padding:.6rem .3rem}.ability-score{font-size:1.3rem}.section{padding:1rem}.section h3{font-size:1.05rem}.category-tabs{gap:.2rem}.cat-tab{padding:.2rem .4rem;font-size:.7rem}.currency-row{gap:.25rem}.currency-input{font-size:1rem;padding:.3rem .15rem}.inventory-item{padding:.4rem .5rem}.item-name{font-size:.85rem}.add-item-form{padding:.6rem}.add-form-row{flex-direction:column}.form-input.qty-small,.form-input.weight-input{width:100%}.hp-controls{flex-direction:row;flex-wrap:nowrap;gap:.15rem;overflow-x:auto}.hp-buttons{width:auto;display:flex;gap:.1rem;flex-shrink:0}.hp-btn{flex:none;padding:.45rem .25rem;font-size:.7rem;letter-spacing:.15px;font-weight:600;white-space:nowrap;min-width:3rem;text-align:center}.hp-input{width:98px;padding:.35rem .3rem;font-size:1rem;min-width:auto;flex-shrink:0}.vitals-compact-row{gap:.5rem;padding:.6rem 0;margin-bottom:.6rem}.compact-stat-item{gap:.3rem}.compact-stat-icon{font-size:1.1rem}.compact-stat-value{font-size:.95rem}.stat-tooltip{font-size:.8rem;padding:.45rem .7rem}.skill-row{padding:.4rem .625rem}}@media(max-width:480px){.character-sheet{padding:.5rem;padding-top:calc(.5rem + env(safe-area-inset-top,0px))}.sheet-grid{gap:.75rem}.section{flex:1 1 100%;min-width:0}.sheet-tabs{display:grid;grid-template-columns:repeat(4,1fr);gap:.2rem;padding:.35rem;overflow-x:visible}.sheet-tab{padding:.6rem .25rem;font-size:.65rem;white-space:nowrap;flex-shrink:unset;text-align:center;border-radius:var(--radius-sm)}.sheet-tab.active:after{display:none}.sheet-top-block .section,.sheet-bottom-block .section{padding:.75rem}.character-title h1{font-size:1.3rem}.subtitle{font-size:.85rem}.ability-grid{grid-template-columns:repeat(3,1fr);gap:.3rem}.ability-box{padding:.5rem .2rem}.ability-short{font-size:.6rem}.ability-score{font-size:1.15rem}.ability-mod{font-size:.75rem}.stat-label{font-size:.8rem}.stat-value{font-size:1.1rem}.vitals-compact-row{gap:.4rem;padding:.5rem 0;margin-bottom:.5rem}.compact-stat-item{gap:.2rem}.compact-stat-icon{font-size:1rem}.compact-stat-value{font-size:.85rem}.stat-tooltip{bottom:auto;top:120%;font-size:.75rem;padding:.4rem .6rem;white-space:normal;max-width:150px}.stat-tooltip:after{top:auto;bottom:100%;border-top:none;border-bottom-color:#000000e6}.hp-buttons{gap:.15rem}.hp-btn{padding:.45rem .15rem;font-size:.6rem;min-width:2.2rem;letter-spacing:.1px}.resource-rest-buttons{gap:.3rem;flex-wrap:wrap}.btn-rest{padding:2px 6px;font-size:.6rem}.section{padding:.75rem}.section h3{font-size:.95rem;margin-bottom:.75rem}.cat-tab{padding:.15rem .3rem;font-size:.65rem}.item-controls{gap:.15rem}.qty-btn{width:22px;height:22px;font-size:.7rem}.skill-name{font-size:.8rem}.skill-modifier{font-size:.75rem;min-width:32px;padding:.2rem .4rem}.notes-textarea{min-height:80px;font-size:1rem}.combat-weapon-card{padding:.6rem}.weapon-stats{flex-direction:column;gap:.3rem}}.spellcasting-info{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;margin-bottom:1rem;padding:.6rem .75rem;background:#0003;border-radius:6px;border:1px solid var(--dnd-border)}.spellcasting-info-header{width:100%;display:flex;justify-content:flex-end;margin-bottom:-.25rem}.spell-edit-form{display:flex;flex-direction:column;gap:.8rem;width:100%;padding:.5rem 0}.spell-edit-row{display:flex;align-items:stretch;gap:.6rem;flex-wrap:wrap}.spell-edit-label{font-size:.7rem;font-weight:600;color:var(--text-secondary);min-width:120px;text-transform:uppercase;letter-spacing:.04em;display:flex;align-items:center}.spell-edit-input{flex:0 0 auto;width:80px;padding:.35rem .45rem;border:1px solid var(--dnd-gold);border-radius:4px;background:#0000004d;color:var(--dnd-gold);font-weight:700;font-size:1rem;text-align:center;height:2.2rem;box-sizing:border-box}.spell-edit-input:focus{outline:none;box-shadow:0 0 0 2px #d4af374d}.spell-edit-select{flex:0 0 auto;padding:.35rem .5rem;border:1px solid var(--dnd-gold);border-radius:4px;background:#0000004d;color:var(--dnd-gold);font-weight:700;font-size:1rem;cursor:pointer;height:2.2rem;box-sizing:border-box}.spell-edit-select:focus{outline:none;box-shadow:0 0 0 2px #d4af374d}.spell-edit-select option{background:#1a1a2e;color:var(--dnd-gold)}.spell-edit-reset{flex:0 0 auto;background:none;border:1px solid rgba(212,175,55,.3);color:var(--dnd-gold);cursor:pointer;font-size:.85rem;padding:.25rem .5rem;border-radius:4px;opacity:.7;transition:all .2s ease;height:2.2rem;display:flex;align-items:center;justify-content:center;min-width:2rem}.spell-edit-reset:hover{opacity:1;background:#d4af371a}.spell-info-value .override-hint{display:inline-block;font-size:.55rem;font-weight:500;color:var(--dnd-gold);opacity:.6;margin-left:.3rem;vertical-align:super;text-transform:uppercase;letter-spacing:.03em}.spell-info-value.overridden{color:#e8c547}.spell-info-item{display:flex;flex-direction:column;align-items:center;min-width:70px}.spell-info-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);font-weight:600}.spell-info-value{font-weight:800;font-size:1.1rem;color:var(--dnd-gold)}.btn-restore-slots{margin-left:auto;background:#64b46426;color:var(--success);border:1px solid var(--success);border-radius:6px;padding:.35rem .7rem;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-restore-slots:hover{background:#64b46440}.spell-circle-group{margin-bottom:.75rem;padding:.5rem .65rem;background:#0000001f;border-radius:6px;border-left:3px solid var(--dnd-gold)}.spell-circle-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.spell-circle-name{font-weight:700;font-size:.9rem;color:var(--dnd-gold);text-transform:uppercase;letter-spacing:.04em}.spell-slots-display{display:flex;align-items:center;gap:.3rem}.slot-pip{width:16px;height:16px;border-radius:50%;border:2px solid var(--dnd-gold);transition:all .25s cubic-bezier(.4,0,.2,1);cursor:pointer;position:relative}.slot-pip.available{background:var(--dnd-gold);box-shadow:0 0 6px #d4af3766}.slot-pip.available:hover{transform:scale(1.25);box-shadow:0 0 12px #d4af3799}.slot-pip.used{background:transparent;opacity:.4}.slot-pip.just-used{animation:slotDeplete .4s ease-out}.slot-controls{display:flex;gap:.2rem;margin-left:.4rem}.slot-btn{width:22px;height:22px;border-radius:4px;border:1px solid var(--dnd-border);background:#0000004d;color:var(--text-primary);font-size:.85rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;line-height:1;padding:0}.slot-btn:disabled{opacity:.3;cursor:not-allowed}.slot-btn.use:not(:disabled):hover{background:#dc323233;border-color:var(--dnd-accent-red)}.slot-btn.restore:not(:disabled):hover{background:#64b46433;border-color:var(--success)}.slot-max-input{width:40px;height:26px;border-radius:4px;border:1px solid var(--dnd-border);background:#0000004d;color:var(--dnd-gold);font-size:16px;font-weight:600;text-align:center;margin-left:.3rem;padding:0;outline:none;transition:border-color .2s ease}.slot-max-input:focus{border-color:var(--dnd-gold)}.slot-max-input-active{display:block}.slot-max-btn{width:40px;height:26px;border-radius:4px;border:1px solid var(--dnd-border);background:#0000004d;color:var(--dnd-gold);font-size:.85rem;font-weight:600;text-align:center;margin-left:.3rem;padding:0;cursor:pointer;transition:all .2s ease}.slot-max-btn:hover{border-color:var(--dnd-gold);background:#d4af3726}.slot-reset-btn{width:26px;height:26px;border-radius:4px;border:1px solid var(--dnd-border);background:#0000004d;color:var(--dnd-gold);font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;margin-left:.15rem;transition:all .15s ease}.slot-reset-btn:hover{background:#d4af3726;border-color:var(--dnd-gold)}.btn-add-spell-general{margin-top:.75rem;border-style:dashed;opacity:.8}.spell-list{display:flex;flex-direction:column;gap:.2rem}.spell-item{display:flex;align-items:center;justify-content:space-between;gap:.4rem;padding:.25rem .4rem;border-radius:4px;transition:background .15s ease}.spell-item:hover{background:#d4af370f}.spell-name{flex:1;font-size:.85rem;color:var(--text-primary);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.spell-item-buttons{display:flex;gap:.25rem;flex-shrink:0}.add-spell-inline{display:flex;align-items:center;gap:.3rem;padding:.2rem 0}.add-spell-inline .form-input{flex:1;background:var(--primary-dark);color:var(--text-primary);border:1px solid var(--dnd-border);border-radius:4px;padding:.3rem .5rem;font-size:1rem;font-family:inherit}.add-spell-inline .form-input:focus{outline:none;border-color:var(--dnd-gold)}.btn-add-spell{background:transparent;color:var(--text-muted);border:none;font-size:.85rem;cursor:pointer;padding:.2rem .4rem;transition:color .15s ease}.spell-input-wrapper{position:relative;flex:1}.spell-suggestions{position:absolute;top:100%;left:0;right:0;background:#09191af2;border:1px solid var(--dnd-border);border-top:none;border-radius:0 0 4px 4px;margin:0;padding:.3rem 0;list-style:none;max-height:250px;overflow-y:auto;z-index:100;box-shadow:0 4px 12px #0000004d}.suggestion-item{padding:.5rem .8rem;cursor:pointer;color:var(--dnd-text);font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:all .15s ease}.suggestion-item:hover,.suggestion-item.active{background:var(--dnd-gold);color:var(--primary-dark);font-weight:500}.btn-add-spell:hover{color:var(--dnd-gold)}.combat-section h3{color:var(--dnd-gold);border-bottom:2px solid var(--dnd-gold);padding-bottom:.5rem}.combat-weapons-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.combat-weapon-card{background:var(--primary-darker);border:1px solid var(--border-color);border-radius:8px;padding:.6rem .75rem;animation:itemAppear .3s ease-out;transition:border-color .2s ease,box-shadow .2s ease,transform .15s ease}.combat-weapon-card:hover{border-color:var(--dnd-gold);box-shadow:0 0 12px #c4a46933;transform:translateY(-1px)}.weapon-expanded-view{display:flex;flex-direction:column;gap:.5rem}.weapon-expanded-header{display:flex;align-items:center;gap:.6rem}.weapon-expanded-header .weapon-name{flex:1}.weapon-expanded-actions{display:flex;gap:.25rem;align-items:center;margin-left:auto}.weapon-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem}.weapon-header-controls{display:flex;gap:.25rem;align-items:center}.combat-weapon-card.editing{border-color:#d4af3766;background:#d4af370f}.weapon-name{font-weight:700;font-size:1.05rem;color:var(--text-primary);letter-spacing:.02em}.weapon-stats{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:.6rem;padding:.5rem .65rem;background:#0003;border-radius:6px}.weapon-stat{display:flex;flex-direction:column;align-items:center;min-width:55px}.weapon-stat-label{font-size:.7rem;text-transform:uppercase;color:var(--text-secondary);letter-spacing:.08em;margin-bottom:.15rem}.weapon-stat-value{font-weight:700;font-size:1.1rem;color:var(--dnd-gold)}.weapon-stat-breakdown{font-size:.65rem;color:var(--text-muted);margin-top:.1rem;white-space:nowrap}.weapon-stat-type{font-size:.85rem;font-weight:600;text-transform:capitalize}.weapon-stat-range{font-size:.85rem;font-weight:600;color:var(--accent)}.weapon-details{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.6rem}.weapon-detail-tag{background:#c4a4691f;color:var(--dnd-gold);font-size:.72rem;padding:.2rem .5rem;border-radius:4px;font-weight:600;letter-spacing:.03em}.weapon-detail-tag .prof-indicator{color:var(--success);font-weight:700}.magic-tag{background:#8a64dd26;color:#b48eff}.prop-tag{background:#64a0dc1f;color:#7bbce8;font-weight:500;font-style:italic}.weapon-notes{font-size:.8rem;color:var(--text-secondary);font-style:italic;background:#ffffff0a;border-left:2px solid rgba(196,164,105,.35);padding:.35rem .6rem;border-radius:0 4px 4px 0;margin-bottom:.6rem;line-height:1.45;white-space:pre-wrap}.weapon-notes-input{width:100%;resize:vertical;min-height:3.5rem;font-size:1rem;padding:.4rem .6rem;margin-bottom:0}.weapon-roll-section{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.btn-roll-attack{background:linear-gradient(135deg,#5a3e1b,#7a5a2b);color:var(--dnd-gold);border:1px solid var(--dnd-gold);border-radius:6px;padding:.4rem .9rem;font-weight:700;font-size:.82rem;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-roll-attack:hover{background:linear-gradient(135deg,#7a5a2b,#9a7a3b);box-shadow:0 0 10px #c4a4694d}.weapon-row-compact{display:flex;align-items:center;gap:.6rem;padding:.5rem .6rem;background:#00000026;border-radius:6px;font-size:.87rem}.weapon-expand-btn{background:none;border:none;color:var(--dnd-gold);cursor:pointer;font-size:.75rem;padding:0 .3rem;min-width:1.2rem;display:flex;align-items:center;justify-content:center;transition:color .2s ease,transform .2s ease;transform:rotate(0)}.weapon-expand-btn.expanded{transform:rotate(90deg)}.weapon-expand-btn:hover{color:var(--dnd-gold-light)}.weapon-name-compact{flex:1;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary);font-size:.9rem}.weapon-atk-compact{min-width:3rem;text-align:right;color:var(--dnd-gold);font-weight:700;font-size:.95rem}button.weapon-atk-compact{background:none;border:1px solid transparent;border-radius:4px;cursor:pointer;padding:.1rem .3rem;transition:background .15s ease,border-color .15s ease;line-height:1}button.weapon-atk-compact:hover{background:#c4a4692e;border-color:#c4a46973}button.weapon-atk-compact:active{transform:scale(.92)}.weapon-dmg-compact{min-width:3.5rem;text-align:right;color:var(--dnd-gold);font-weight:700;font-size:.95rem}.btn-roll-attack:hover{transform:translateY(-1px)}.btn-roll-attack:active{transform:translateY(0)}.roll-result{display:flex;gap:1rem;flex-wrap:wrap;background:#00000040;border-radius:6px;padding:.4rem .7rem;animation:itemAppear .25s ease-out}.roll-result.crit{background:#ffd7001f;border:1px solid rgba(255,215,0,.4);box-shadow:0 0 12px #ffd70026}.roll-result.fumble{background:#dc32321f;border:1px solid rgba(220,50,50,.35)}.roll-attack,.roll-damage{display:flex;align-items:center;gap:.3rem;font-size:.82rem}.roll-label{color:var(--text-secondary);font-weight:600}.roll-value{font-weight:800;font-size:1.05rem;color:var(--text-primary)}.roll-d20{font-size:.72rem;color:var(--text-muted)}.roll-type{font-size:.72rem;color:var(--text-secondary);font-style:italic}.roll-crit-label{color:gold;font-weight:800;font-size:.85rem;animation:goldPulse .6s ease}.add-weapon-section{margin-top:.5rem}.weapon-add-buttons{display:flex;gap:.5rem;margin-bottom:.6rem}.weapon-add-buttons .btn-toggle-add{flex:1;margin-bottom:0}.preset-weapons-panel{padding:.75rem;background:var(--primary-darker, rgba(9, 25, 26, .9));border:1px solid var(--border-color, var(--dnd-border));border-radius:8px;animation:itemAppear .2s ease-out;margin-bottom:.6rem}.preset-weapons-filters{display:flex;gap:.5rem;margin-bottom:.6rem}.preset-weapons-filters .form-input,.preset-weapons-filters .form-select{flex:1;background:#09191acc;color:var(--dnd-text-light);border:1px solid var(--dnd-border);border-radius:4px;padding:.4rem .5rem;font-size:1rem}.preset-weapons-list{max-height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:.25rem}.preset-weapon-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .6rem;background:#1a233299;border:1px solid rgba(212,175,55,.1);border-radius:6px;transition:all .2s ease;gap:.5rem}.preset-weapon-item:hover{background:#d4af3714;border-color:#d4af3740}.preset-weapon-info{display:flex;flex-direction:column;gap:.15rem;min-width:0;flex:1}.preset-weapon-name{font-weight:700;color:var(--dnd-gold);font-size:.9rem}.preset-weapon-stats{font-size:.8rem;color:var(--dnd-text-light)}.preset-weapon-props{font-size:.75rem;color:var(--dnd-text-muted);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-add-preset{flex-shrink:0;width:32px;height:32px;border-radius:50%;border:1px solid var(--dnd-gold);background:#d4af371a;color:var(--dnd-gold);font-size:1.2rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.btn-add-preset:hover{background:#d4af3740;transform:scale(1.1)}.btn-toggle-add{background:transparent;color:var(--dnd-gold);border:1px dashed var(--dnd-gold);border-radius:6px;padding:.45rem .9rem;font-weight:600;font-size:.82rem;cursor:pointer;transition:all .2s ease;width:100%;margin-bottom:.6rem}.btn-toggle-add:hover{background:#c4a4691a}.btn-toggle-add.open{border-style:solid;background:#c4a46914}.add-weapon-section .add-item-form{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:var(--primary-darker);border:1px solid var(--border-color);border-radius:8px;animation:itemAppear .2s ease-out}.add-form-row{display:flex;gap:.5rem;align-items:center}.add-form-row .form-input,.add-form-row .form-select{flex:1;background:var(--primary-dark);color:var(--text-primary);border:1px solid var(--border-color);border-radius:4px;padding:.4rem .55rem;font-size:1rem;font-family:inherit}.add-form-row .form-input:focus,.add-form-row .form-select:focus{outline:none;border-color:var(--dnd-gold);box-shadow:0 0 4px #c4a46933}.form-input.full-width{width:100%}.combat-checkbox-label{display:flex;align-items:center;gap:.35rem;color:var(--text-secondary);font-size:.82rem;white-space:nowrap;cursor:pointer}.combat-checkbox-label input[type=checkbox]{accent-color:var(--dnd-gold);width:15px;height:15px;cursor:pointer}.btn-add-submit{background:linear-gradient(135deg,var(--dnd-gold) 0%,#d4a843 100%);color:var(--primary-darker);border:none;border-radius:6px;padding:.5rem;font-weight:700;font-size:.85rem;cursor:pointer;transition:all .2s ease}.btn-add-submit:hover{filter:brightness(1.1);box-shadow:0 0 8px #c4a4694d}.empty-state{color:var(--text-muted);font-style:italic;text-align:center;padding:1rem;font-size:.88rem}.prepared-counter{border:1px solid rgba(212,175,55,.3);border-radius:6px;padding:.2rem .5rem!important;background:#d4af370f}.prepared-counter .spell-info-value.at-limit{color:#e67e22}.spell-prepare-toggle{display:flex;align-items:center;cursor:pointer;flex-shrink:0;margin-right:.3rem}.spell-prepare-checkbox{display:none}.spell-prepare-indicator{width:16px;height:16px;border:2px solid rgba(212,175,55,.4);border-radius:3px;background:transparent;transition:all .2s;position:relative}.spell-prepare-checkbox:checked+.spell-prepare-indicator{background:var(--dnd-gold);border-color:var(--dnd-gold)}.spell-prepare-checkbox:checked+.spell-prepare-indicator:after{content:"✓";position:absolute;top:-2px;left:1px;color:#1a1a2e;font-size:12px;font-weight:700}.spell-prepare-toggle:hover .spell-prepare-indicator{border-color:var(--dnd-gold);box-shadow:0 0 4px #d4af374d}.spell-item.spell-not-prepared{opacity:.5}.spell-item.spell-not-prepared .spell-name{color:var(--text-muted);font-style:italic}.spell-item.spell-item-mc{border-left:2px solid var(--dnd-gold, #c9a84c);padding-left:6px;opacity:.9}.spell-class-badge{font-size:.68rem;color:var(--dnd-gold, #c9a84c);background:color-mix(in srgb,var(--dnd-gold, #c9a84c) 15%,transparent);border-radius:4px;padding:1px 5px;margin-left:6px;white-space:nowrap}.rest-hd-class-label{font-size:.8rem;opacity:.75;margin-right:6px;display:inline-block;min-width:90px}.prepared-spell-search{position:relative;margin-bottom:10px}.prepared-spell-search .form-input{width:100%;padding-right:32px}.spell-search-clear-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:2px 6px}.spell-search-clear-btn:hover{color:var(--text-primary)}.prepared-spell-checklist{display:flex;flex-direction:column;gap:2px}.prepared-spell-checklist .spell-item{transition:opacity .2s ease,background-color .2s ease;padding:4px 8px;border-radius:4px}.prepared-spell-checklist .spell-item:hover{background:#d4af370f}.prepared-spell-checklist .spell-item.spell-not-prepared{opacity:.65}.prepared-spell-checklist .spell-item.spell-not-prepared .spell-name{font-style:normal;color:var(--text-muted)}.prepared-spell-checklist .spell-item:not(.spell-not-prepared) .spell-name{color:var(--dnd-gold);font-weight:500}.spell-browser-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1100;padding:1rem}.spell-browser-modal{background:#1a2332fc;border:1px solid var(--dnd-border);border-radius:var(--radius-lg);width:95vw;max-width:750px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 12px 48px #0009;animation:slideInModal .3s ease-out}.spell-browser-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid rgba(212,175,55,.2);flex-shrink:0}.spell-browser-header h3{margin:0;color:var(--dnd-gold);font-size:1.3rem;font-family:Georgia,serif}.spell-browser-header .close-btn{background:none;border:none;color:var(--dnd-text);font-size:1.5rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s ease}.spell-browser-header .close-btn:hover{background:#d4af371a;color:var(--dnd-gold)}.spell-browser-filters{padding:1rem 1.5rem;border-bottom:1px solid rgba(212,175,55,.1);flex-shrink:0;display:flex;flex-direction:column;gap:.75rem}.spell-browser-search{position:relative}.spell-browser-search .form-input{width:100%;padding-right:2.5rem}.spell-browser-search .spell-search-clear-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:2px 6px}.spell-browser-filter-row{display:flex;gap:.5rem;flex-wrap:wrap}.spell-filter-select{flex:1;min-width:120px;padding:.5rem .75rem!important;font-size:1rem!important;background:#0f172a99;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);color:var(--dnd-text);cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.spell-filter-select:focus{border-color:var(--dnd-gold);outline:none}.spell-browser-list{flex:1;overflow-y:auto;padding:.5rem 0;min-height:200px}.spell-browser-list .empty-state{padding:2rem;text-align:center;color:var(--text-muted);font-style:italic}.spell-browser-item{border-bottom:1px solid rgba(212,175,55,.06);transition:background .15s ease}.spell-browser-item:hover{background:#d4af370a}.spell-browser-item.spell-already-known{opacity:.55}.spell-browser-item-header{display:flex;align-items:center;justify-content:space-between;padding:.65rem 1.5rem;cursor:pointer;gap:.75rem}.spell-browser-item-info{display:flex;flex-direction:column;gap:.15rem;min-width:0;flex:1}.spell-browser-item-name{color:var(--dnd-text);font-size:.95rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spell-browser-item.spell-already-known .spell-browser-item-name{text-decoration:line-through;text-decoration-color:#d4af374d}.spell-browser-item-meta{font-size:.78rem;color:var(--text-muted)}.spell-browser-item-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.spell-browser-known-badge{font-size:.75rem;color:var(--dnd-gold);background:#d4af371f;padding:.2rem .6rem;border-radius:var(--radius-sm);white-space:nowrap}.spell-browser-add-btn{background:#d4af371f;color:var(--dnd-gold);border:1px solid rgba(212,175,55,.3);border-radius:var(--radius-sm);padding:.3rem .75rem;font-size:.8rem;cursor:pointer;white-space:nowrap;transition:all .2s ease}.spell-browser-add-btn:hover{background:#d4af3738;border-color:var(--dnd-gold)}.spell-browser-expand-icon{font-size:.7rem;color:var(--text-muted);width:20px;text-align:center}.spell-browser-detail{padding:.5rem 1.5rem 1rem;background:#0f172a66;border-top:1px solid rgba(212,175,55,.08);font-size:.88rem;line-height:1.6;color:var(--dnd-text-light)}.spell-browser-detail p{margin:.4rem 0}.spell-browser-detail strong{color:var(--dnd-gold)}.spell-browser-description{margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(212,175,55,.08);font-size:.85rem;line-height:1.65}.spell-browser-footer{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;border-top:1px solid rgba(212,175,55,.2);flex-shrink:0}.spell-browser-count{font-size:.85rem;color:var(--text-muted)}.spell-browser-footer .btn-secondary{background:#d4af371a;color:var(--dnd-gold);border:1px solid rgba(212,175,55,.25);border-radius:var(--radius-sm);padding:.45rem 1.25rem;font-size:.85rem;cursor:pointer;transition:all .2s ease}.spell-browser-footer .btn-secondary:hover{background:#d4af3733;border-color:var(--dnd-gold)}@media(max-width:600px){.spell-browser-overlay{padding:0}.spell-browser-modal{width:100vw;max-height:100vh;max-height:100dvh;border-radius:0;padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0px)}.spell-browser-filter-row{flex-direction:column}.spell-filter-select{min-width:100%}.spell-browser-item-header{padding:.65rem 1rem}.spell-browser-detail{padding:.5rem 1rem 1rem}.spell-browser-header,.spell-browser-filters,.spell-browser-footer{padding-left:1rem;padding-right:1rem}}.spell-browser-header-actions{display:flex;align-items:center;gap:.5rem}.btn-create-spell{background:#64b4641f;color:#7cc87c;border:1px solid rgba(100,180,100,.3);border-radius:var(--radius-sm);padding:.35rem .9rem;font-size:.82rem;cursor:pointer;white-space:nowrap;transition:all .2s ease}.btn-create-spell:hover{background:#64b46438;border-color:#7cc87c}.btn-create-spell.active{background:#dc50501f;color:#e06060;border-color:#dc50504d}.btn-create-spell.active:hover{background:#dc505038;border-color:#e06060}.custom-spell-form{padding:1rem 1.5rem;border-bottom:1px solid rgba(212,175,55,.2);background:#0f172a66}.custom-spell-form h4{margin:0 0 .75rem;color:var(--dnd-gold);font-family:Georgia,serif;font-size:1.05rem}.custom-spell-error{color:#e06060;font-size:.85rem;margin:0 0 .5rem;padding:.4rem .75rem;background:#dc50501a;border:1px solid rgba(220,80,80,.2);border-radius:var(--radius-sm)}.custom-spell-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}.custom-spell-field{display:flex;flex-direction:column;gap:.25rem}.custom-spell-field label{font-size:.78rem;color:var(--text-muted);font-weight:500}.custom-spell-field .form-input{padding:.4rem .6rem;font-size:1rem}.custom-spell-ritual{display:flex;align-items:flex-end}.custom-spell-checkbox-label{display:flex;align-items:center;gap:.4rem;font-size:.88rem;color:var(--dnd-text);cursor:pointer;padding-bottom:.3rem}.custom-spell-checkbox-label input[type=checkbox]{accent-color:var(--dnd-gold)}.custom-spell-text-field{margin-top:.6rem}.custom-spell-textarea{width:100%;resize:vertical;min-height:80px;font-size:1rem;line-height:1.5}.custom-spell-form-actions{display:flex;gap:.5rem;margin-top:.75rem}.btn-create-submit{background:#64b46426;color:#7cc87c;border:1px solid rgba(100,180,100,.35);border-radius:var(--radius-sm);padding:.45rem 1.2rem;font-size:.85rem;cursor:pointer;transition:all .2s ease}.btn-create-submit:hover{background:#64b46447;border-color:#7cc87c}.custom-spell-form-actions .btn-secondary{background:transparent;color:var(--text-muted);border:1px solid var(--dnd-border);border-radius:var(--radius-sm);padding:.45rem 1rem;font-size:.85rem;cursor:pointer;transition:all .2s ease}.custom-spell-form-actions .btn-secondary:hover{color:var(--dnd-text);border-color:var(--dnd-text)}.spell-homebrew-badge{display:inline-block;font-size:.65rem;color:#7cc87c;background:#64b4641f;border:1px solid rgba(100,180,100,.25);border-radius:3px;padding:.05rem .4rem;margin-left:.5rem;vertical-align:middle;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.spell-source-badge{margin:.2rem 0 .5rem;font-size:.82rem;color:#7cc87c}.spell-browser-delete-btn{background:none;border:none;color:var(--text-muted);font-size:.9rem;cursor:pointer;padding:.15rem .3rem;border-radius:var(--radius-sm);transition:all .2s ease;opacity:.6}.spell-browser-delete-btn:hover{color:#e06060;opacity:1;background:#dc50501a}@media(max-width:600px){.custom-spell-form-grid{grid-template-columns:1fr}.custom-spell-form{padding:.75rem 1rem}.spell-browser-header-actions{gap:.25rem}.btn-create-spell{font-size:.75rem;padding:.3rem .65rem}}.history-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1100;padding:1rem}.history-modal{background:#1a2332fc;border:1px solid var(--dnd-border);border-radius:var(--radius-lg);width:95vw;max-width:500px;max-height:70vh;display:flex;flex-direction:column;box-shadow:0 12px 48px #0009;animation:slideInModal .3s ease-out}.history-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid rgba(212,175,55,.2);flex-shrink:0}.history-modal-header h3{margin:0;color:var(--dnd-gold);font-size:1.2rem;font-family:Georgia,serif}.history-modal-header .close-btn{background:none;border:none;color:var(--dnd-text);font-size:1.5rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s ease}.history-modal-header .close-btn:hover{background:#d4af371a;color:var(--dnd-gold)}.history-modal-content{flex:1;overflow-y:auto;padding:1rem}.history-modal-content .empty-state{padding:2rem;text-align:center;color:var(--text-muted);font-style:italic}.history-list{display:flex;flex-direction:column;gap:.75rem}.history-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#0f172a99;border:1px solid rgba(212,175,55,.15);border-radius:var(--radius-md);transition:all .2s ease}.history-item:hover{background:#0f172acc;border-color:#d4af374d}.history-item-info{display:flex;flex-direction:column;gap:.25rem}.history-level{font-weight:600;color:var(--dnd-text);font-size:.95rem}.history-time{font-size:.8rem;color:var(--text-muted)}.history-restore-btn{background:#d4af371f;color:var(--dnd-gold);border:1px solid rgba(212,175,55,.3);border-radius:var(--radius-sm);padding:.4rem 1rem;font-size:.85rem;cursor:pointer;white-space:nowrap;transition:all .2s ease}.history-restore-btn:hover{background:#d4af3738;border-color:var(--dnd-gold)}@media(max-width:600px){.history-modal{width:100vw;max-height:80vh;border-radius:0}.history-item{flex-direction:column;align-items:flex-start;gap:.5rem}.history-restore-btn{width:100%;text-align:center}}.dice-roll-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1200;padding:1rem}.dice-roll-modal{background:#1a2332fc;border:1px solid var(--dnd-border);border-radius:var(--radius-lg);width:95vw;max-width:420px;box-shadow:0 12px 48px #0009;animation:slideInModal .25s ease-out;overflow:hidden;overflow-x:hidden}.dice-roll-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid rgba(212,175,55,.2)}.dice-roll-title{display:flex;align-items:center;gap:.5rem}.dice-roll-icon{font-size:1.4rem}.dice-roll-title h3{margin:0;color:var(--dnd-gold);font-size:1.15rem;font-family:Georgia,serif}.dice-roll-header .close-btn{background:none;border:none;color:var(--dnd-text);font-size:1.5rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s ease}.dice-roll-header .close-btn:hover{background:#d4af371a;color:var(--dnd-gold)}.dice-roll-info{padding:.75rem 1.5rem;text-align:center;border-bottom:1px solid rgba(212,175,55,.1)}.dice-roll-formula{font-size:1.1rem;color:var(--dnd-text-light);font-family:Courier New,monospace;letter-spacing:.05em}.dice-roll-buttons{display:flex;gap:.5rem;padding:1.25rem 1.5rem}.dice-roll-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:1rem .5rem;border:1px solid rgba(212,175,55,.2);border-radius:var(--radius-md, 8px);cursor:pointer;transition:all .2s ease;background:#0f172a80}.dice-roll-btn:hover{border-color:var(--dnd-gold);background:#d4af3714}.dice-roll-btn:active{transform:scale(.97)}.dice-roll-btn.full-width{flex:none;width:100%}.dice-btn-icon{font-size:1.5rem}.dice-btn-label{font-size:.85rem;font-weight:600;color:var(--dnd-text)}.dice-btn-desc{font-size:.7rem;color:var(--text-muted)}.dice-roll-btn.normal{border-color:#d4af3759}.dice-roll-btn.normal:hover{background:#d4af371f;box-shadow:0 0 12px #d4af3726}.dice-roll-btn.normal .dice-btn-label{color:var(--dnd-gold)}.dice-roll-btn.advantage{border-color:#4caf5059}.dice-roll-btn.advantage:hover{border-color:#4caf50;background:#4caf501a}.dice-roll-btn.advantage .dice-btn-icon,.dice-roll-btn.advantage .dice-btn-label{color:#4caf50}.dice-roll-btn.disadvantage{border-color:#ef535059}.dice-roll-btn.disadvantage:hover{border-color:#ef5350;background:#ef53501a}.dice-roll-btn.disadvantage .dice-btn-icon,.dice-roll-btn.disadvantage .dice-btn-label{color:#ef5350}.dice-roll-rolling-container{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem 1.5rem;color:var(--dnd-text-light);font-size:1rem;perspective:1000px}.dice-roll-rolling-scene{width:160px;height:160px;position:relative;display:flex;align-items:center;justify-content:center;perspective:1200px}.rolling-dice-image{width:140px;height:140px;animation:spinningDice .7s ease-in-out;filter:drop-shadow(0 0 12px rgba(212,175,55,.6))}@keyframes spinningDice{0%{transform:rotateX(0) rotateY(0) rotate(0)}25%{transform:rotateX(180deg) rotateY(180deg) rotate(90deg)}50%{transform:rotateX(360deg) rotateY(360deg) rotate(180deg)}75%{transform:rotateX(540deg) rotateY(540deg) rotate(270deg)}to{transform:rotateX(720deg) rotateY(720deg) rotate(360deg)}}.dice-rolling-text{font-weight:600;letter-spacing:.1em;animation:pulseTextRolling .6s ease-in-out infinite}@keyframes pulseTextRolling{0%,to{opacity:.7}50%{opacity:1}}.dice-roll-result{padding:1.25rem 1.5rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.dice-roll-result.dice-shaking{animation:diceShake .4s ease-in-out}.dice-roll-total-display{font-size:4.5rem;font-weight:800;color:var(--dnd-gold);text-shadow:0 0 20px rgba(212,175,55,.4);line-height:1;margin:.5rem 0;font-family:Georgia,serif;letter-spacing:-.05em}.dice-roll-total-display.total-crit{color:gold;text-shadow:0 0 30px rgba(255,215,0,.8),0 0 60px rgba(255,215,0,.3);animation:critGlow 1s ease-in-out infinite}@keyframes critGlow{0%,to{text-shadow:0 0 30px rgba(255,215,0,.8),0 0 60px rgba(255,215,0,.3)}50%{text-shadow:0 0 50px rgba(255,215,0,1),0 0 80px rgba(255,215,0,.5),0 0 120px rgba(255,215,0,.2)}}.dice-roll-total-display.total-fumble{color:#ef5350;text-shadow:0 0 30px rgba(239,83,80,.8),0 0 16px rgba(239,83,80,.4);animation:fumbleGlow 1s ease-in-out infinite}.dice-roll-result.total-fumble-container{animation:nat1Flash .8s ease-in-out 2}@keyframes fumbleGlow{0%,to{text-shadow:0 0 30px rgba(239,83,80,.8),0 0 16px rgba(239,83,80,.4)}50%{text-shadow:0 0 40px rgba(239,83,80,1),0 0 24px rgba(239,83,80,.6)}}.dice-roll-breakdown{display:flex;flex-direction:column;align-items:center;gap:.6rem;width:100%}.dice-roll-free-formula{font-family:Courier New,monospace;font-weight:700;color:var(--dnd-gold);font-size:1.1rem}.dice-roll-dice{display:flex;justify-content:center;gap:1rem}.dice-pair{display:flex;gap:1rem}.dice-face{width:64px;height:64px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:700;background:#0f172a99;border:2px solid var(--dnd-border);border-radius:var(--radius-md, 8px);color:var(--dnd-text);font-family:Georgia,serif;animation:diceFadeIn .3s ease-out}@keyframes diceFadeIn{0%{opacity:0;transform:scale(.5) rotate(-25deg)}to{opacity:1;transform:scale(1) rotate(0)}}.dice-face.chosen{border-color:var(--dnd-gold);color:var(--dnd-gold);background:#d4af3714;box-shadow:0 0 12px #d4af3733}.dice-face.discarded{opacity:.35;border-style:dashed}.dice-face.nat20{border-color:gold;color:gold;background:#ffd7001a;box-shadow:0 0 20px #ffd70066,0 0 40px #ffd70026;animation:diceFadeIn .3s ease-out,nat20Glow 1.5s ease-in-out infinite}.dice-face.nat1{border-color:#ef5350;color:#ef5350;background:#ef53501a;box-shadow:0 0 16px #ef53504d}.dice-roll-mode-badge{font-size:.75rem;font-weight:600;padding:.2rem .75rem;border-radius:100px;text-transform:uppercase;letter-spacing:.05em}.dice-roll-mode-badge.advantage{color:#4caf50;background:#4caf501f;border:1px solid rgba(76,175,80,.3)}.dice-roll-mode-badge.disadvantage{color:#ef5350;background:#ef53501f;border:1px solid rgba(239,83,80,.3)}.dice-roll-crit-badge{font-size:.9rem;font-weight:700;color:gold;text-transform:uppercase;letter-spacing:.1em;animation:critPulse .6s ease-in-out infinite alternate;text-shadow:0 0 8px rgba(255,215,0,.4)}@keyframes critPulse{0%{text-shadow:0 0 4px rgba(255,215,0,.3)}to{text-shadow:0 0 20px rgba(255,215,0,.8),0 0 40px rgba(255,215,0,.3)}}.dice-roll-fumble-badge{font-size:.9rem;font-weight:700;color:#ef5350;text-transform:uppercase;letter-spacing:.1em;animation:fumblePulse .6s ease-in-out infinite alternate}@keyframes fumblePulse{0%{text-shadow:0 0 4px rgba(239,83,80,.3)}to{text-shadow:0 0 16px rgba(239,83,80,.8)}}.dice-roll-calc{display:flex;align-items:center;gap:.4rem;font-size:1.2rem;font-family:Courier New,monospace;color:var(--dnd-text-light);padding:.5rem 1rem;background:#0f172a66;border-radius:var(--radius-sm)}.dice-roll-calc-die{color:var(--dnd-gold);font-weight:700}.dice-roll-calc-op{color:var(--text-muted)}.dice-roll-calc-mod{color:var(--dnd-text)}.dice-roll-calc-eq{color:var(--text-muted);margin:0 .15rem}.dice-roll-calc-total{font-size:1.1rem;font-weight:700;color:var(--dnd-text);min-width:2ch;text-align:center}.dice-roll-damage{width:100%;margin-top:.5rem;padding-top:.75rem;border-top:1px solid rgba(212,175,55,.15);text-align:center}.dice-roll-damage-header{font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:.5rem}.dice-roll-damage-calc{display:flex;align-items:center;justify-content:center;gap:.3rem;font-size:1rem;font-family:Courier New,monospace;color:var(--dnd-text-light);flex-wrap:wrap}.dice-roll-damage-total{font-size:1.3rem;font-weight:700;color:#ff8a65}.dice-roll-damage-type{font-size:.8rem;color:var(--text-muted);font-style:italic;margin-left:.3rem}.damage-crit-bonus{color:#4caf50;font-weight:600}.dice-roll-reroll{margin-top:.5rem}.dice-roll-btn-reroll{background:#d4af371a;color:var(--dnd-gold);border:1px solid rgba(212,175,55,.25);border-radius:var(--radius-sm);padding:.5rem 1.5rem;font-size:.85rem;cursor:pointer;transition:all .2s ease}.dice-roll-btn-reroll:hover{background:#d4af3733;border-color:var(--dnd-gold)}@media(max-width:600px){.dice-roll-overlay{padding:.5rem}.dice-roll-modal{width:100%;max-width:100%;border-radius:10px}.dice-roll-header{padding:.75rem 1rem}.dice-roll-title h3{font-size:.95rem}.dice-roll-info{padding:.5rem 1rem}.dice-roll-buttons{flex-direction:column;padding:.75rem 1rem;gap:.4rem}.dice-roll-btn{flex-direction:row;padding:.6rem .75rem;gap:.6rem}.dice-btn-icon{font-size:1.2rem}.dice-btn-desc{display:none}.dice-roll-rolling-container{padding:1.25rem 1rem}.dice-roll-rolling-scene{width:100px;height:100px}.rolling-dice-image{width:90px;height:90px}.dice-roll-result{padding:1rem}.dice-roll-total-display{font-size:3.2rem}.dice-face{width:50px;height:50px;font-size:1.4rem}.dice-roll-calc{font-size:1rem;padding:.4rem .6rem;flex-wrap:wrap;justify-content:center}.dice-roll-damage-calc{font-size:.85rem;flex-wrap:wrap;justify-content:center}.dice-roll-crit-badge,.dice-roll-fumble-badge{font-size:.75rem}}.quick-dice-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;flex:1;min-height:0;overflow-y:auto;padding-right:.5rem;scrollbar-width:thin;scrollbar-color:rgba(212,175,55,.3) transparent}.quick-dice-grid::-webkit-scrollbar{width:6px}.quick-dice-grid::-webkit-scrollbar-track{background:transparent}.quick-dice-grid::-webkit-scrollbar-thumb{background:#d4af374d;border-radius:3px}.quick-dice-grid::-webkit-scrollbar-thumb:hover{background:#d4af3780}.quick-dice-item{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:#0f172a66;border:1px solid rgba(212,175,55,.15);border-radius:var(--radius-md, 8px);transition:all .2s ease}.quick-dice-item:hover{background:#0f172a99;border-color:#d4af374d}.quick-dice-quick-btn{background:#d4af371a;color:var(--dnd-gold);border:1px solid rgba(212,175,55,.3);border-radius:var(--radius-sm);padding:.4rem .8rem;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease}.quick-dice-quick-btn:hover{background:#d4af3733;border-color:#d4af3780}.quick-dice-quick-btn:active{transform:scale(.95)}.quick-dice-counter{display:flex;align-items:center;justify-content:space-between;gap:.3rem}.quick-dice-counter-btn{background:#d4af3714;color:var(--dnd-gold);border:1px solid rgba(212,175,55,.2);border-radius:var(--radius-sm);width:28px;height:28px;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.quick-dice-counter-btn:hover:not(:disabled){background:#d4af3726;border-color:#d4af3766}.quick-dice-counter-btn:disabled{opacity:.3;cursor:not-allowed}.quick-dice-count{flex:1;text-align:center;font-weight:700;color:var(--dnd-gold);min-width:1.5ch}.quick-dice-selected{padding:.5rem .75rem;background:#4caf5014;border:1px solid rgba(76,175,80,.2);border-radius:var(--radius-md, 8px);display:flex;align-items:center;gap:.5rem;margin-top:0;flex-shrink:0}.quick-dice-selected-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.quick-dice-selected-value{font-family:Courier New,monospace;font-weight:700;color:var(--dnd-gold);flex:1;text-align:right;word-break:break-all}.quick-dice-modifier{display:flex;align-items:center;gap:.75rem;margin-top:0;padding:.5rem .75rem;background:#0f172a66;border:1px solid rgba(212,175,55,.15);border-radius:var(--radius-md, 8px);flex-shrink:0}.quick-dice-modifier label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.quick-dice-modifier input{flex:1;min-width:0;background:#0f172a99;border:1px solid rgba(212,175,55,.2);border-radius:var(--radius-sm);padding:.4rem .6rem;color:var(--dnd-gold);font-weight:600;font-family:Courier New,monospace;text-align:center;font-size:1rem}.quick-dice-modifier input:focus{outline:none;border-color:#d4af3780;background:#0f172acc;box-shadow:0 0 8px #d4af3733}.quick-dice-modifier input::-webkit-outer-spin-button,.quick-dice-modifier input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.quick-dice-modifier input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.quick-dice-actions{display:flex;gap:.75rem;margin-top:0;flex-shrink:0}.quick-dice-btn{flex:1;padding:.6rem;border-radius:var(--radius-md, 8px);font-weight:600;cursor:pointer;transition:all .2s ease;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}.quick-dice-btn.reset{background:#d77b531a;color:#d77b53;border:1px solid rgba(215,123,83,.3)}.quick-dice-btn.reset:hover{background:#d77b5326;border-color:#d77b5380}.quick-dice-btn.roll{background:linear-gradient(135deg,var(--dnd-gold),rgba(212,175,55,.8));color:var(--dnd-bg-dark);border:1px solid rgba(212,175,55,.5);font-weight:700}.quick-dice-btn.roll:hover:not(:disabled){background:linear-gradient(135deg,rgba(212,175,55,1),var(--dnd-gold));box-shadow:0 0 16px #d4af3766}.quick-dice-btn.roll:disabled{opacity:.5;cursor:not-allowed}:root[data-theme=light] .character-sheet{background:linear-gradient(180deg,#f8f5f0,#ede8df,#e5dfd4);color:var(--dnd-text)}:root[data-theme=light] .character-sheet:before{background-image:radial-gradient(ellipse at 20% 50%,rgba(139,119,79,.05) 0%,transparent 50%),radial-gradient(ellipse at 80% 50%,rgba(139,119,79,.04) 0%,transparent 50%),radial-gradient(circle at 50% 100%,rgba(122,92,30,.03) 0%,transparent 40%)}:root[data-theme=light] .section{background:#fff;border-color:var(--dnd-border);border-top-color:var(--dnd-gold);box-shadow:0 2px 8px #0000000d,inset 0 1px 3px #8b774f0a;border-left:1px solid rgba(139,119,79,.12)}:root[data-theme=light] .sheet-header{background:linear-gradient(135deg,#fff,#f5f2ec);box-shadow:0 2px 12px #00000014;border-color:var(--dnd-border)}:root[data-theme=light] .sheet-header:before,:root[data-theme=light] .sheet-header:after{background:linear-gradient(90deg,transparent,rgba(122,92,30,.3),transparent)}:root[data-theme=light] .burger-toggle{background:#7a5c1e14;border-color:var(--dnd-border)}:root[data-theme=light] .burger-toggle span{background:#5a4a2a}:root[data-theme=light] .burger-dropdown{background:linear-gradient(135deg,#fff,#f8f6f0);border-color:var(--dnd-border);box-shadow:0 8px 32px #00000026}:root[data-theme=light] .burger-item{color:#2d2a24}:root[data-theme=light] .burger-item:hover{background:#7a5c1e14;color:#5a4a2a}:root[data-theme=light] .burger-user{color:#5a4a2a}:root[data-theme=light] .character-title h1{color:#2d2a24;text-shadow:none}:root[data-theme=light] .character-name-editable{padding:.25rem .5rem;border-radius:4px}:root[data-theme=light] .character-name-editable:hover{background:#7a5c1e26;color:#1a1a1a}:root[data-theme=light] .name-edit-input{color:#2d2a24;background:#fffc;border-color:#8b6914}:root[data-theme=light] .name-edit-input:focus{box-shadow:0 0 12px #7a5c1e80}:root[data-theme=light] .character-subtitle{color:#5c5647}:root[data-theme=light] .section h3{color:var(--dnd-gold);border-bottom-color:#7a5c1e33}:root[data-theme=light] .sheet-tabs{background:#f5f0e8cc;border-color:var(--dnd-border);border-top-color:var(--dnd-gold)}:root[data-theme=light] .sheet-tab{color:#7a6e5e}:root[data-theme=light] .sheet-tab:hover{color:#4a4035;background:#7a5c1e14}:root[data-theme=light] .sheet-tab.active{color:var(--dnd-gold);background:#fff;box-shadow:inset 0 2px 0 var(--dnd-gold)}:root[data-theme=light] .sheet-tab.active:after{background:#fff}:root[data-theme=light] .tab-content{border-top:none}:root[data-theme=light] .section-header-static{color:var(--dnd-gold);border-bottom-color:#7a5c1e33}:root[data-theme=light] .vitals-combat-divider{background:linear-gradient(90deg,transparent,var(--dnd-gold),transparent);opacity:.3}:root[data-theme=light] .hp-bar-container{background:#f0ebe3;border-color:var(--dnd-border)}:root[data-theme=light] .hp-input{background:#fff;color:var(--dnd-text);border-color:var(--dnd-border)}:root[data-theme=light] .hp-input::placeholder{color:#b0a898}:root[data-theme=light] .hp-btn{background:#fff;color:var(--dnd-text);border-color:var(--dnd-border);box-shadow:0 1px 3px #0000000d}:root[data-theme=light] .hp-btn:hover{background:#f5f2ec}:root[data-theme=light] .qty-btn{background:#fff;color:#1a1a2e;border-color:#d0d0d0}:root[data-theme=light] .qty-btn:hover{background:#f5f2ec;border-color:var(--dnd-gold);color:var(--dnd-gold)}:root[data-theme=light] .qty-btn.edit-btn{color:var(--dnd-gold);border-color:#d4af3780}:root[data-theme=light] .qty-btn.edit-btn:hover{background:#d4af3726;color:#8b6914}:root[data-theme=light] .qty-btn.remove{color:#c71c1c;border-color:#c71c1c4d}:root[data-theme=light] .qty-btn.remove:hover{background:#c71c1c1a;border-color:#c71c1c;color:#8b0000}:root[data-theme=light] .qty-btn.info{color:#1976d2;border-color:#1976d24d}:root[data-theme=light] .qty-btn.info:hover{background:#1976d21a;border-color:#1976d2}:root[data-theme=light] .ac-input{background:#fff;color:var(--dnd-gold);border-color:var(--dnd-gold)}:root[data-theme=light] .ac-btn{background:#fff;border-color:var(--dnd-border)}:root[data-theme=light] .ac-override-hint{color:#3a7ca5}:root[data-theme=light] .armor-modal{background:#faf8f4;border-color:var(--dnd-gold);box-shadow:0 8px 32px #00000026}:root[data-theme=light] .armor-modal-overlay{background:#00000059}:root[data-theme=light] .armor-modal-header{border-bottom-color:#7a5c1e33}:root[data-theme=light] .armor-modal-footer{border-top-color:#7a5c1e33}:root[data-theme=light] .armor-modal-close{color:#888}:root[data-theme=light] .armor-modal-close:hover{color:var(--dnd-gold);background:#7a5c1e1a}:root[data-theme=light] .armor-select{background:#fff;color:var(--dnd-text);border-color:var(--dnd-border)}:root[data-theme=light] .armor-detail-tag{background:#7a5c1e14;color:var(--dnd-text);border-color:#7a5c1e26}:root[data-theme=light] .armor-detail-tag.warning{background:#c832321a;color:#b71c1c;border-color:#c8323233}:root[data-theme=light] .ability-box{background:linear-gradient(135deg,#7a5c1e0f,#8b2e2e0a);border-color:var(--dnd-border)}:root[data-theme=light] .ability-box:hover{background:linear-gradient(135deg,#7a5c1e1f,#8b2e2e0f);border-color:var(--dnd-gold);box-shadow:0 4px 12px #7a5c1e1a}:root[data-theme=light] .ability-score-input{background:#fff;color:var(--dnd-gold);border-color:var(--dnd-gold)}:root[data-theme=light] .saving-throw{background:#0000000a}:root[data-theme=light] .saving-throw.proficient{background:#7a5c1e14}:root[data-theme=light] .skill-row{background:#00000005;border-left-color:var(--dnd-border)}:root[data-theme=light] .skill-row:hover{background:#7a5c1e0f}:root[data-theme=light] .skill-row.proficient{background:#7a5c1e0f}:root[data-theme=light] .skill-row.expertise{background:#7a5c1e1a}:root[data-theme=light] .skill-modifier{background:#f0ebe3;color:var(--dnd-text);border-color:var(--dnd-border)}:root[data-theme=light] .skill-row.proficient .skill-modifier{background:linear-gradient(135deg,var(--dnd-gold) 0%,var(--dnd-gold-dark) 100%);color:#fff;border-color:var(--dnd-gold)}:root[data-theme=light] .skill-row.expertise .skill-modifier{background:linear-gradient(135deg,gold,#b8860b);color:#fff;border-color:gold}:root[data-theme=light] .skills-edit-btn{background:#fff;color:var(--dnd-text);border-color:var(--dnd-border)}:root[data-theme=light] .skills-edit-btn.active{background:#7a5c1e1a;color:var(--dnd-gold);border-color:var(--dnd-gold)}:root[data-theme=light] .skill-roll-result{background:#fff;border-color:var(--dnd-border);box-shadow:0 2px 8px #00000014}:root[data-theme=light] .chosen-option-group{background:#f8f5f0;border-color:#7a5c1e1f}:root[data-theme=light] .feature-chip{background:#f8f5f0;border-color:var(--dnd-border);color:var(--dnd-text)}:root[data-theme=light] .feature-chip:hover{background:#7a5c1e14;border-color:var(--dnd-gold)}:root[data-theme=light] .feature-chip.active{background:#7a5c1e1a;border-color:var(--dnd-gold)}:root[data-theme=light] .feature-tooltip{background:#fff;border-color:#7a5c1e33;border-left-color:var(--dnd-gold)}:root[data-theme=light] .resource-card{background:#f0ebe3;border-color:var(--dnd-border)}:root[data-theme=light] .btn-rest{background:#fff;border-color:var(--dnd-border)}:root[data-theme=light] .currency-input{background:#fff;border-color:var(--dnd-border)}:root[data-theme=light] .weight-bar{background:#f0ebe3;border-color:var(--dnd-border)}:root[data-theme=light] .cat-tab{background:#f5f2ec;border-color:var(--dnd-border)}:root[data-theme=light] .cat-tab.active{background:#7a5c1e1a;border-color:var(--dnd-gold)}:root[data-theme=light] .inventory-item{background:#f8f5f0;border-color:var(--dnd-border)}:root[data-theme=light] .add-item-form{background:#f5f2ec;border-color:var(--dnd-border)}:root[data-theme=light] .form-input,:root[data-theme=light] .form-select,:root[data-theme=light] .notes-textarea{background:#fff;color:var(--dnd-text);border-color:var(--dnd-border)}:root[data-theme=light] .form-input::placeholder,:root[data-theme=light] .notes-textarea::placeholder{color:#b0a898}:root[data-theme=light] .form-input:focus,:root[data-theme=light] .form-select:focus,:root[data-theme=light] .notes-textarea:focus{border-color:var(--dnd-gold);background:#fff;box-shadow:0 0 0 3px #7a5c1e14}:root[data-theme=light] .btn-toggle-add{background:#7a5c1e0f;border-color:#7a5c1e40}:root[data-theme=light] .btn-add-submit{background:#7a5c1e1a;border-color:var(--dnd-gold)}:root[data-theme=light] .btn-export{background:#3c648c14;border-color:#3c648c4d}:root[data-theme=light] .load-screen{background:linear-gradient(135deg,#fff,#f5f2ec);box-shadow:0 2px 12px #00000014}:root[data-theme=light] .saved-entry{background:#f8f5f0;border-color:var(--dnd-border)}:root[data-theme=light] .saved-entry:hover{background:#7a5c1e0f;border-color:var(--dnd-gold)}:root[data-theme=light] .saved-entry-actions button{background:#fff;border-color:var(--dnd-border)}:root[data-theme=light] .spell-detail-modal-overlay,:root[data-theme=light] .spell-browser-overlay,:root[data-theme=light] .history-modal-overlay,:root[data-theme=light] .dice-roll-overlay{background:#00000059;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}:root[data-theme=light] .spell-detail-modal,:root[data-theme=light] .spell-browser-modal,:root[data-theme=light] .history-modal,:root[data-theme=light] .dice-roll-modal{background:#fff;border-color:var(--dnd-border);box-shadow:0 8px 40px #00000026}:root[data-theme=light] .spell-detail-header,:root[data-theme=light] .spell-browser-header,:root[data-theme=light] .history-modal-header,:root[data-theme=light] .dice-roll-header{background:linear-gradient(135deg,#7a5c1e,#5a4210);border-bottom-color:#7a5c1e4d}:root[data-theme=light] .spell-detail-header h3,:root[data-theme=light] .spell-browser-header h3,:root[data-theme=light] .history-modal-header h3,:root[data-theme=light] .dice-roll-header h3{color:#fff}:root[data-theme=light] .spell-detail-header .close-btn,:root[data-theme=light] .history-modal-header .close-btn{color:#fff}:root[data-theme=light] .spell-detail-header .close-btn:hover,:root[data-theme=light] .history-modal-header .close-btn:hover{background:#ffffff26;color:#fff}:root[data-theme=light] .history-item{background:#f5f5f5;border-color:var(--dnd-border)}:root[data-theme=light] .history-item:hover{background:#f0ebe3;border-color:#7a5c1e}:root[data-theme=light] .history-level,:root[data-theme=light] .history-time{color:#333}:root[data-theme=light] .history-restore-btn{background:#d4af371a;color:#7a5c1e;border-color:#d4af37}:root[data-theme=light] .history-restore-btn:hover{background:#d4af3733;border-color:#d4af37}:root[data-theme=light] .spell-edit-input{background:#fff;border-color:#c4a02a;color:#5a4210}:root[data-theme=light] .spell-edit-select{background:#fff;border-color:#c4a02a;color:#5a4210}:root[data-theme=light] .spell-edit-select option{background:#fff;color:#5a4210}:root[data-theme=light] .spell-edit-reset{border-color:#7a5c1e4d;color:#7a5c1e}:root[data-theme=light] .spell-edit-reset:hover{background:#7a5c1e1a}:root[data-theme=light] .spell-info-value .override-hint{color:#7a5c1e}:root[data-theme=light] .spell-info-value.overridden{color:#7a5c1e}:root[data-theme=light] .spell-browser-header .close-btn{color:#fff}:root[data-theme=light] .spell-browser-header .close-btn:hover{background:#ffffff26;color:#fff}:root[data-theme=light] .btn-create-spell{background:#3c8c3c1a;color:#3a8a3a;border-color:#3c8c3c4d}:root[data-theme=light] .btn-create-spell:hover{background:#3c8c3c2e}:root[data-theme=light] .btn-create-spell.active{background:#c83c3c1a;color:#c44040;border-color:#c83c3c4d}:root[data-theme=light] .custom-spell-form{background:#f8f5f0;border-bottom-color:var(--dnd-border)}:root[data-theme=light] .custom-spell-form h4{color:var(--dnd-gold)}:root[data-theme=light] .custom-spell-error{color:#c44040;background:#c83c3c0f;border-color:#c83c3c26}:root[data-theme=light] .btn-create-submit{background:#3c8c3c1a;color:#3a8a3a;border-color:#3c8c3c4d}:root[data-theme=light] .btn-create-submit:hover{background:#3c8c3c33}:root[data-theme=light] .spell-homebrew-badge{color:#3a8a3a;background:#3c8c3c1a;border-color:#3c8c3c40}:root[data-theme=light] .spell-source-badge{color:#3a8a3a}:root[data-theme=light] .spell-browser-delete-btn:hover{color:#c44040;background:#c83c3c14}:root[data-theme=light] .spell-browser-detail{background:#f5f2ec;border-top-color:var(--dnd-border)}:root[data-theme=light] .spell-filter-select{background:#fff;color:var(--dnd-text);border-color:var(--dnd-border)}:root[data-theme=light] .spell-filter-select:focus{border-color:var(--dnd-gold)}:root[data-theme=light] .spell-card,:root[data-theme=light] .spell-browser-card{background:#f8f5f0;border-color:var(--dnd-border)}:root[data-theme=light] .spell-card:hover,:root[data-theme=light] .spell-browser-card:hover{background:#f0ebe3;border-color:var(--dnd-gold)}:root[data-theme=light] .dice-roll-btn{background:#f5f2ec;border-color:var(--dnd-border)}:root[data-theme=light] .dice-roll-btn:hover{background:#ede8df}:root[data-theme=light] .dice-roll-btn.selected{background:#7a5c1e14}:root[data-theme=light] .dice-result-total{color:var(--dnd-gold);text-shadow:none}:root[data-theme=light] .dice-result-formula{color:var(--dnd-text-light)}:root[data-theme=light] .quick-dice-item{background:#f8f5f0;border-color:var(--dnd-border)}:root[data-theme=light] .quick-dice-item:hover{background:#ede8df;border-color:var(--dnd-gold)}:root[data-theme=light] .quick-dice-quick-btn{background:#7a5c1e14;color:var(--dnd-gold);border-color:#7a5c1e40}:root[data-theme=light] .quick-dice-quick-btn:hover{background:#7a5c1e26;border-color:#7a5c1e66}:root[data-theme=light] .quick-dice-counter-btn{background:#fff;color:var(--dnd-gold);border-color:var(--dnd-border)}:root[data-theme=light] .quick-dice-counter-btn:hover:not(:disabled){background:#f5f2ec;border-color:var(--dnd-gold)}:root[data-theme=light] .quick-dice-count{color:var(--dnd-gold)}:root[data-theme=light] .quick-dice-selected{background:#2d78370f;border-color:#2d783733}:root[data-theme=light] .quick-dice-modifier{background:#f0ebe3;border-color:var(--dnd-border)}:root[data-theme=light] .quick-dice-modifier label{color:#5c5647}:root[data-theme=light] .quick-dice-modifier input{background:#fff;color:var(--dnd-gold);border-color:var(--dnd-border)}:root[data-theme=light] .quick-dice-modifier input:focus{border-color:var(--dnd-gold);background:#fff;box-shadow:0 0 0 3px #7a5c1e14}:root[data-theme=light] .quick-dice-btn.reset{background:#b450320f;color:#9a5a3a;border-color:#b4503233}:root[data-theme=light] .quick-dice-btn.roll{background:linear-gradient(135deg,#a0811a,#7a5c1e);color:#fff;border-color:#7a5c1e}:root[data-theme=light] .quick-dice-btn.roll:hover:not(:disabled){background:linear-gradient(135deg,#b8952a,#a0811a);box-shadow:0 4px 12px #7a5c1e33}:root[data-theme=light] .spell-slot,:root[data-theme=light] .spell-slot-pip{background:#f0ebe3;border-color:var(--dnd-border)}:root[data-theme=light] .spell-slot.used,:root[data-theme=light] .spell-slot-pip.used{background:#7a5c1e26}:root[data-theme=light] .slot-max-input{background:#f8f5f0;border-color:var(--dnd-border);color:var(--dnd-gold)}:root[data-theme=light] .slot-max-btn{background:#f8f5f0;border-color:var(--dnd-border);color:var(--dnd-gold)}:root[data-theme=light] .slot-max-btn:hover{border-color:var(--dnd-gold);background:#d4af371a}:root[data-theme=light] .slot-reset-btn{background:#f8f5f0;border-color:var(--dnd-border);color:var(--dnd-gold)}:root[data-theme=light] .spell-prepared-panel{background:#f8f5f0;border-color:var(--dnd-border)}.rest-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem}.rest-modal{background:#1a2332fa;border:1px solid var(--dnd-border);border-radius:var(--radius-lg);width:100%;max-width:440px;max-height:85vh;overflow-y:auto;box-shadow:0 8px 32px #00000080;animation:slideInModal .3s ease-out}.rest-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid rgba(212,175,55,.2);position:sticky;top:0;background:#1a2332fa}.rest-modal-header h3{margin:0;font-family:Georgia,serif;color:var(--dnd-gold);font-size:1.2rem}.rest-modal-header .close-btn{background:none;border:none;color:var(--dnd-text);font-size:1.5rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s ease}.rest-modal-header .close-btn:hover{background:#d4af371a;color:var(--dnd-gold)}.rest-modal-content{padding:1rem 1.25rem 1.5rem}.rest-hp-info{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.rest-hp-display{text-align:center;padding:10px 12px;background:#4caf5014;border:1px solid rgba(76,175,80,.2);border-radius:6px;font-size:.95rem;color:#4caf50;font-weight:500}.rest-hp-display strong{color:#66bb6a;font-weight:700}.rest-hit-dice-info{text-align:center;padding:10px 12px;background:#d4af3714;border:1px solid rgba(212,175,55,.15);border-radius:6px;font-size:.9rem;color:var(--dnd-gold);font-weight:500}.rest-section{margin-bottom:14px;padding:12px;background:#d4af370a;border:1px solid rgba(212,175,55,.15);border-radius:8px}.rest-section:last-child{margin-bottom:0}.rest-section h4{margin:0 0 6px;font-family:Georgia,serif;color:var(--dnd-gold);font-size:1rem}.rest-description{margin:0 0 10px;font-size:.8rem;color:var(--dnd-text-dim);line-height:1.4}.rest-subsection-label{display:block;font-size:.82rem;color:var(--dnd-text);margin-bottom:6px;font-weight:500}.rest-hit-dice-section{margin-bottom:10px}.rest-hit-dice-controls{display:flex;gap:6px;flex-wrap:wrap}.rest-hit-dice-btn{padding:5px 10px;background:#d4af371f;border:1px solid rgba(212,175,55,.3);border-radius:6px;color:var(--dnd-gold);font-size:.8rem;cursor:pointer;transition:all .15s;font-weight:500}.rest-hit-dice-btn:hover{background:#d4af3740;border-color:var(--dnd-gold)}.rest-hit-dice-btn:active{transform:scale(.97)}.rest-roll-result{margin-top:6px;padding:6px 8px;background:#d4af3714;border-left:2px solid var(--dnd-gold);border-radius:4px;font-size:.8rem;color:var(--dnd-gold);font-weight:500}.rest-empty{font-size:.8rem;color:var(--dnd-text-dim);font-style:italic;margin:2px 0 6px}.rest-recovery-list{margin:8px 0 10px}.rest-recovery-item{font-size:.82rem;color:#4caf50;padding:2px 0}.long-rest-list .rest-recovery-item{color:#5c9eff}.rest-arcane-recovery{margin:8px 0 10px}.rest-arcane-slots{display:flex;gap:6px;flex-wrap:wrap}.rest-arcane-slot-btn{padding:5px 10px;background:#648ce61f;border:1px solid rgba(100,140,230,.3);border-radius:6px;color:#7aadff;font-size:.8rem;cursor:pointer;transition:all .15s}.rest-arcane-slot-btn:hover{background:#648ce640;border-color:#7aadff}.rest-arcane-slot-btn:disabled{opacity:.5;cursor:not-allowed;border-color:#648ce626;color:#7aadff80}.rest-arcane-used{margin-top:8px;font-size:.8rem;color:#7aadffcc;text-align:center}.rest-action-btn{display:block;width:100%;padding:8px 12px;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:6px}.short-rest-btn{background:#d4af3726;color:var(--dnd-gold);border:1px solid rgba(212,175,55,.3)}.short-rest-btn:hover{background:#d4af3747;border-color:var(--dnd-gold)}.long-rest-btn{background:#648ce626;color:#7aadff;border:1px solid rgba(100,140,230,.3)}.long-rest-btn:hover{background:#648ce647;border-color:#7aadff}.rest-reset-btn{background:#b4b4b41f;color:#aaa;border:1px solid rgba(180,180,180,.25)}.rest-reset-btn:hover{background:#b4b4b438;border-color:#aaa}:root[data-theme=light] .rest-modal{background:#faf7f2fa;border-color:#d9d3c8}:root[data-theme=light] .rest-modal-header{background:#faf7f2fa;border-bottom-color:#8b6d3826}:root[data-theme=light] .rest-modal-header h3{color:#8b6d38}:root[data-theme=light] .rest-modal-header .close-btn{color:#3d3d3d}:root[data-theme=light] .rest-modal-header .close-btn:hover{background:#8b6d381f;color:#8b6d38}:root[data-theme=light] .rest-hp-display{background:#4caf5014;border-color:#4caf5026;color:#3a8a3e}:root[data-theme=light] .rest-hp-display strong{color:#2e7d32}:root[data-theme=light] .rest-hit-dice-info{background:#8b6d3814;border-color:#8b6d381f;color:#8b6d38}:root[data-theme=light] .rest-section{background:#8b6d380a;border-color:#8b6d381f}:root[data-theme=light] .rest-section h4{color:#8b6d38}:root[data-theme=light] .rest-description{color:#666}:root[data-theme=light] .rest-subsection-label{color:#333}:root[data-theme=light] .rest-hit-dice-btn{background:#8b6d381a;border-color:#8b6d3840;color:#8b6d38}:root[data-theme=light] .rest-hit-dice-btn:hover{background:#8b6d3833;border-color:#8b6d38}:root[data-theme=light] .rest-roll-result{background:#8b6d380f;border-left-color:#8b6d38;color:#8b6d38}:root[data-theme=light] .rest-empty{color:#999}:root[data-theme=light] .rest-recovery-item{color:#3a8a3e}:root[data-theme=light] .long-rest-list .rest-recovery-item{color:#4a6faa}:root[data-theme=light] .rest-arcane-slot-btn{background:#4664a01a;border-color:#4664a040;color:#4a6faa}:root[data-theme=light] .rest-arcane-slot-btn:hover{background:#4664a033;border-color:#4a6faa}:root[data-theme=light] .rest-arcane-slot-btn:disabled{opacity:.5;border-color:#4664a01a;color:#4a6faa80}:root[data-theme=light] .rest-arcane-used{color:#4a6faabf}:root[data-theme=light] .short-rest-btn{background:#8b6d381f;color:#8b6d38;border-color:#8b6d3840}:root[data-theme=light] .short-rest-btn:hover{background:#8b6d3838;border-color:#8b6d38}:root[data-theme=light] .long-rest-btn{background:#4664a01f;color:#4a6faa;border-color:#4664a040}:root[data-theme=light] .long-rest-btn:hover{background:#4664a038;border-color:#4a6faa}:root[data-theme=light] .rest-reset-btn{background:#8c8c8c1a;color:#888;border-color:#8c8c8c33}:root[data-theme=light] .rest-reset-btn:hover{background:#8c8c8c2e;border-color:#888}.sticky-fab-group{position:fixed;bottom:1.5rem;right:1.5rem;z-index:1001;display:flex;flex-direction:column;gap:10px;align-items:center}.sticky-fab{width:50px;height:50px;border-radius:50%;border:2px solid var(--dnd-border, #3a3a5c);background:var(--dnd-surface-1, #1e1e3a);color:var(--dnd-text, #e0ddd4);font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;box-shadow:0 3px 12px #00000059;transition:background .25s,transform .2s,box-shadow .25s,border-color .25s}.sticky-fab:hover{transform:scale(1.1);box-shadow:0 4px 18px #00000073}.sticky-fab:active{transform:scale(.95)}.sticky-fab.active{background:var(--dnd-accent, #c9a44a);color:#1a1a2e;border-color:var(--dnd-accent, #c9a44a);box-shadow:0 0 16px #c9a44a66}.sticky-fab.quick-dice-fab{background:linear-gradient(135deg,var(--dnd-gold, #d4af37),rgba(212,175,55,.8));border-color:#d4af37e6;color:#1a1a2e;box-shadow:0 4px 12px #d4af374d}.sticky-fab.quick-dice-fab:hover{box-shadow:0 6px 16px #d4af3780}.sticky-fab.quick-dice-fab.active{background:linear-gradient(135deg,gold,#c9a44a);box-shadow:0 0 20px #ffd70073}.sticky-fab-badge{position:absolute;top:-5px;right:-5px;background:var(--dnd-danger, #cc4444);color:#fff;font-size:.62rem;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1;pointer-events:none}.slide-panel-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:999;opacity:1;transition:opacity .3s cubic-bezier(.4,0,.2,1);pointer-events:auto;cursor:pointer}.slide-panel{position:fixed;top:0;right:0;bottom:0;width:340px;max-width:90vw;z-index:1000;background:var(--dnd-surface-0, #16162e);border-left:1px solid var(--dnd-border, #3a3a5c);box-shadow:-4px 0 24px #00000080;display:flex;flex-direction:column;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);will-change:transform}.slide-panel.open{transform:translate(0)}.slide-panel-header{display:flex;align-items:center;justify-content:space-between;padding:calc(14px + env(safe-area-inset-top,0px)) 16px 14px 16px;border-bottom:1px solid var(--dnd-border, #3a3a5c);background:var(--dnd-surface-1, #1e1e3a);flex-shrink:0}.slide-panel-header h3{margin:0;font-size:1rem;color:var(--dnd-accent, #c9a44a);font-weight:600}.slide-panel-header-actions{display:flex;gap:6px}.slide-panel-btn{background:none;border:none;color:var(--dnd-muted, #8888aa);cursor:pointer;font-size:1.05rem;padding:4px 8px;border-radius:6px;transition:color .2s,background .2s}.slide-panel-btn:hover{color:var(--dnd-text, #e0ddd4);background:#ffffff14}.slide-panel-body{overflow-y:auto;padding:10px calc(10px + env(safe-area-inset-right,0px)) calc(10px + env(safe-area-inset-bottom,0px)) 10px;flex:1;scrollbar-width:thin;scrollbar-color:var(--dnd-border, #3a3a5c) transparent}.dice-log-empty{text-align:center;color:var(--dnd-muted, #8888aa);font-style:italic;padding:32px 16px;font-size:.85rem}.dice-log-entry{position:relative;padding:10px 12px;margin-bottom:8px;border-radius:8px;background:var(--dnd-surface-1, #1e1e3a);border:1px solid var(--dnd-border, #3a3a5c);transition:background .2s;animation:diceLogEntryIn .3s ease-out}@keyframes diceLogEntryIn{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.dice-log-entry.log-crit{border-color:gold;background:#ffd70014}.dice-log-entry.log-fumble{border-color:#c44;background:#cc444414}.dice-log-entry-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;gap:8px}.dice-log-header-right{display:flex;align-items:center;gap:6px;white-space:nowrap}.dice-log-label{font-weight:600;font-size:.82rem;color:var(--dnd-text, #e0ddd4);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.dice-log-time{font-size:.7rem;color:var(--dnd-muted, #8888aa);font-family:monospace}.dice-log-entry-result{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.dice-log-total{font-size:1.3rem;font-weight:700;color:var(--dnd-accent, #c9a44a);min-width:36px}.dice-log-total.crit{color:gold;text-shadow:0 0 8px rgba(255,215,0,.5)}.dice-log-total.fumble{color:#c44;text-shadow:0 0 8px rgba(204,68,68,.4)}.dice-log-formula{font-size:.75rem;color:var(--dnd-muted, #8888aa)}.dice-log-mode{font-weight:700}.dice-log-mode.advantage{color:#4caf50}.dice-log-mode.disadvantage{color:#c44}.dice-log-damage{font-size:.75rem;color:#e07a5f;font-weight:500}.dice-log-crit-badge,.dice-log-fumble-badge{display:inline-block;font-size:.55rem;font-weight:800;letter-spacing:.3px;padding:2px 5px;border-radius:3px;flex-shrink:0}.dice-log-crit-badge{background:#ffd70033;color:gold;border:1px solid rgba(255,215,0,.4)}.dice-log-fumble-badge{background:#c443;color:#c44;border:1px solid rgba(204,68,68,.4)}.quick-dice-content{display:flex;flex-direction:column;gap:.75rem}:root[data-theme=light] .sticky-fab{background:#fff;border-color:#c4b998;color:#5c4b2e;box-shadow:0 2px 8px #0000001f}:root[data-theme=light] .sticky-fab:hover{background:#f8f0e0}:root[data-theme=light] .sticky-fab.active{background:#8b6914;color:#fff;border-color:#8b6914}:root[data-theme=light] .sticky-fab.quick-dice-fab{background:linear-gradient(135deg,#a0811a,#7a5c1e);border-color:#7a5c1e;color:#fff;box-shadow:0 4px 12px #7a5c1e40}:root[data-theme=light] .sticky-fab.quick-dice-fab:hover{box-shadow:0 6px 20px #7a5c1e59}:root[data-theme=light] .sticky-fab.quick-dice-fab.active{background:linear-gradient(135deg,#c9a44a,#a0811a)}:root[data-theme=light] .slide-panel-overlay{background:#00000040;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}:root[data-theme=light] .slide-panel{background:#faf6ee;border-left-color:#c4b998;box-shadow:-4px 0 24px #0000001f}:root[data-theme=light] .slide-panel-header{background:#f0e8d8;border-bottom-color:#c4b998}:root[data-theme=light] .slide-panel-btn:hover{background:#0000000f}:root[data-theme=light] .dice-log-entry{background:#fff;border-color:#d8cfb8}:root[data-theme=light] .dice-log-entry.log-crit{border-color:#c9a44a;background:#c9a44a14}:root[data-theme=light] .dice-log-entry.log-fumble{border-color:#c44;background:#cc44440f}:root[data-theme=light] .dice-log-label{color:#3c2f1e}:root[data-theme=light] .dice-log-total{color:#8b6914}.sticky-fab-group.panel-open{pointer-events:none;opacity:0;transform:translate(80px);transition:opacity .25s,transform .25s}.sticky-fab-group{transition:opacity .25s,transform .25s}@media(max-width:600px){.sticky-fab-group{bottom:1rem;right:1rem}.sticky-fab{width:44px;height:44px;font-size:1.15rem}.slide-panel{width:100vw;max-width:100vw;padding-right:env(safe-area-inset-right,0px);padding-bottom:env(safe-area-inset-bottom,0px)}}.readonly-banner{background:linear-gradient(135deg,#4a90d9,#5865f2);color:#fff;text-align:center;padding:.6rem 1rem;font-weight:600;font-size:.95rem;border-radius:8px;margin-bottom:.75rem}[data-theme=dark] .readonly-banner{background:linear-gradient(135deg,#3a5f8a,#4752c4)}.character-sheet--readonly input,.character-sheet--readonly textarea,.character-sheet--readonly select{pointer-events:none!important;opacity:.75;cursor:default}.character-sheet--readonly .hp-controls,.character-sheet--readonly .hp-btn,.character-sheet--readonly .hp-input,.character-sheet--readonly .inv-item-actions,.character-sheet--readonly .combat-weapon-actions,.character-sheet--readonly .ability-edit-btn,.character-sheet--readonly .edit-name-btn,.character-sheet--readonly .resource-controls,.character-sheet--readonly .btn-add-weapon,.character-sheet--readonly .rest-btn,.character-sheet--readonly .section-toggle-edit,.character-sheet--readonly .skill-toggle,.character-sheet--readonly .extra-save-toggle,.character-sheet--readonly .slot-checkbox,.character-sheet--readonly .shield-toggle,.character-sheet--readonly .ac-override,.character-sheet--readonly .armor-selector,.character-sheet--readonly .spell-actions .spell-remove-btn,.character-sheet--readonly .spell-actions .spell-prepare-btn,.character-sheet--readonly .btn-add-spell,.character-sheet--readonly .btn-browse-spells,.character-sheet--readonly .spell-item-buttons .qty-btn.remove,.character-sheet--readonly .spell-prepare-toggle,.character-sheet--readonly .spell-item-buttons,.character-sheet--readonly .add-weapon-section,.character-sheet--readonly .combat-weapon-card .qty-btn,.character-sheet--readonly .btn-add-preset,.character-sheet--readonly .btn-add-submit,.character-sheet--readonly .btn-toggle-add,.character-sheet--readonly .weapon-add-buttons,.character-sheet--readonly .skills-edit-btn,.character-sheet--readonly .ability-score-input,.character-sheet--readonly .saving-throw.editable,.character-sheet--readonly .slot-btn,.character-sheet--readonly .slot-max-btn,.character-sheet--readonly .slot-max-input,.character-sheet--readonly .slot-reset-btn,.character-sheet--readonly .slot-pip,.character-sheet--readonly .resource-btn,.character-sheet--readonly .spell-prepare-checkbox,.character-sheet--readonly .spell-edit-reset,.character-sheet--readonly .currency-input,.character-sheet--readonly .equip-btn,.character-sheet--readonly .drag-handle,.character-sheet--readonly .add-item-section,.character-sheet--readonly .ac-edit,.character-sheet--readonly .armor-modal-overlay,.character-sheet--readonly .armor-modal,.character-sheet--readonly .armor-select,.character-sheet--readonly .armor-shield-toggle,.character-sheet--readonly .notes-textarea,.character-sheet--readonly .rest-hit-dice-btn,.character-sheet--readonly .rest-arcane-slot-btn,.character-sheet--readonly .rest-action-btn{pointer-events:none!important;opacity:.35;cursor:not-allowed;filter:grayscale(60%)}.character-sheet--readonly .add-item-form,.character-sheet--readonly .add-weapon-form,.character-sheet--readonly .add-weapon-section,.character-sheet--readonly .combat-weapon-card.editing{display:none!important}.character-sheet--readonly .sheet-tab,.character-sheet--readonly .feature-chip,.character-sheet--readonly .ability-score.clickable,.character-sheet--readonly .saving-throw.clickable,.character-sheet--readonly .skill-row,.character-sheet--readonly .weapon-atk-rollable,.character-sheet--readonly .spell-item-name,.character-sheet--readonly .qty-btn.info,.character-sheet--readonly .quick-dice-fab,.character-sheet--readonly .dice-log-toggle{pointer-events:auto!important;opacity:1!important;cursor:pointer!important;filter:none!important}.portrait-container{flex-shrink:0}.portrait-display{width:90px;height:90px;border-radius:50%;overflow:hidden;border:2px solid var(--dnd-gold);box-shadow:0 0 12px #d4af3733,0 2px 8px #0006;position:relative}.portrait-display.portrait-clickable{cursor:pointer;transition:all .3s ease}.portrait-display.portrait-clickable:hover{border-color:gold;box-shadow:0 0 20px #d4af3766,0 2px 12px #00000080;transform:scale(1.05)}.portrait-display.portrait-clickable:after{content:"✏️";position:absolute;bottom:2px;right:2px;font-size:.65rem;background:#000000b3;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease}.portrait-display.portrait-clickable:hover:after{opacity:1}.portrait-cropped-wrapper{width:100%;height:100%;overflow:hidden;position:relative}.portrait-cropped-img{display:block;position:absolute;top:0;left:0}.portrait-cropped-img.portrait-no-crop{width:100%;height:100%;object-fit:cover;position:relative}.portrait-add-btn{width:90px;height:90px;border-radius:50%;border:2px dashed var(--dnd-border);background:#d4af370d;color:var(--dnd-text-light);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;transition:all .3s ease}.portrait-add-btn:hover{border-color:var(--dnd-gold);background:#d4af371f;transform:scale(1.05)}.portrait-add-icon{font-size:1.4rem}.portrait-add-text{font-size:.55rem;text-align:center;line-height:1.2;opacity:.7}.portrait-viewer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1300;padding:1rem;animation:fadeIn .2s ease}.portrait-viewer{position:relative;display:flex;flex-direction:column;align-items:center;max-width:90vw;max-height:90vh}.portrait-viewer-close{position:absolute;top:-36px;right:-8px;background:none;border:none;color:#ffffffb3;font-size:1.5rem;cursor:pointer;padding:4px 8px;transition:color .2s;z-index:2}.portrait-viewer-close:hover{color:#fff}.portrait-viewer-image-wrap{display:flex;align-items:center;justify-content:center;max-width:80vw;max-height:75vh}.portrait-viewer-img{max-width:80vw;max-height:75vh;object-fit:contain;border-radius:8px;box-shadow:0 8px 32px #0009}.portrait-viewer-actions{display:flex;gap:1rem;margin-top:1rem}.portrait-viewer-edit-btn,.portrait-viewer-delete-btn{padding:.5rem 1.25rem;border:none;border-radius:8px;font-size:.95rem;cursor:pointer;transition:all .2s ease}.portrait-viewer-edit-btn{background:linear-gradient(135deg,var(--dnd-gold),#b8860b);color:#fff}.portrait-viewer-edit-btn:hover{filter:brightness(1.15);transform:translateY(-1px)}.portrait-viewer-delete-btn{background:#dc3545d9;color:#fff}.portrait-viewer-delete-btn:hover{background:#dc3545;transform:translateY(-1px)}.portrait-editor-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1300;padding:1rem}.portrait-editor{background:#1a2332fc;border:1px solid var(--dnd-border);border-radius:var(--radius-lg);width:95vw;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 12px 48px #0009;animation:slideInModal .25s ease-out}.portrait-editor-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid rgba(212,175,55,.2)}.portrait-editor-header h3{margin:0;color:var(--dnd-gold);font-family:Georgia,serif;font-size:1.1rem}.portrait-editor-hint{margin:0;padding:0 1.25rem .25rem;color:var(--dnd-text-secondary, rgba(255,255,255,.55));font-size:.8rem;line-height:1.4}.portrait-url-input-row{display:flex;gap:.5rem;padding:1rem 1.25rem}.portrait-url-input{flex:1;padding:.6rem .75rem;border-radius:var(--radius-sm);border:1px solid var(--dnd-border);background:#0000004d;color:var(--dnd-text);font-size:.85rem;outline:none;transition:border-color .2s}.portrait-url-input:focus{border-color:var(--dnd-gold)}.portrait-load-btn{padding:.6rem 1rem;border:1px solid var(--dnd-gold);border-radius:var(--radius-sm);background:#d4af371a;color:var(--dnd-gold);cursor:pointer;font-size:.85rem;white-space:nowrap;transition:all .2s}.portrait-load-btn:hover{background:#d4af3740}.portrait-crop-area{padding:0 1.25rem 1rem;display:flex;flex-direction:column;align-items:center}.portrait-crop-hint{font-size:.8rem;color:var(--dnd-text-light);opacity:.7;margin:0 0 .5rem}.portrait-crop-area .ReactCrop{max-width:100%;border-radius:var(--radius-sm);overflow:hidden}.portrait-loading{padding:2rem 1.25rem;text-align:center;color:var(--dnd-gold);font-size:.9rem}.portrait-loading p{margin:0}.portrait-error{padding:.75rem 1.25rem;color:#ef5350;font-size:.85rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.75rem}.portrait-error p{margin:0}.portrait-retry-proxy-btn{padding:.4rem .75rem;border:1px solid #ef5350;border-radius:var(--radius-sm);background:#ef53501a;color:#ef5350;cursor:pointer;font-size:.75rem;transition:all .2s}.portrait-retry-proxy-btn:hover{background:#ef535040}.portrait-editor-actions{display:flex;justify-content:flex-end;gap:.5rem;padding:1rem 1.25rem;border-top:1px solid rgba(212,175,55,.15)}.portrait-remove-btn{margin-right:auto;padding:.5rem 1rem;border:1px solid #ef5350;border-radius:var(--radius-sm);background:#ef53501a;color:#ef5350;cursor:pointer;font-size:.85rem;transition:all .2s}.portrait-remove-btn:hover{background:#ef535040}.portrait-cancel-btn{padding:.5rem 1rem;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);background:transparent;color:var(--dnd-text-light);cursor:pointer;font-size:.85rem;transition:all .2s}.portrait-cancel-btn:hover{background:#ffffff0d}.portrait-save-btn{padding:.5rem 1.25rem;border:1px solid var(--dnd-gold);border-radius:var(--radius-sm);background:#d4af3726;color:var(--dnd-gold);cursor:pointer;font-size:.85rem;font-weight:600;transition:all .2s}.portrait-save-btn:hover{background:#d4af374d}.portrait-save-btn:disabled{opacity:.4;cursor:not-allowed}:root[data-theme=light] .portrait-editor{background:#f8f5f0;border-color:var(--dnd-border)}:root[data-theme=light] .portrait-url-input{background:#fff;color:var(--dnd-text);border-color:var(--dnd-border)}:root[data-theme=light] .portrait-add-btn{background:#7a5c1e0d;color:var(--dnd-text)}:root[data-theme=light] .portrait-cancel-btn{color:var(--dnd-text)}:root[data-theme=light] .portrait-cancel-btn:hover{background:#0000000d}.theme-toggle{position:fixed;top:calc(1.5rem + env(safe-area-inset-top,0px));right:1.5rem;width:44px;height:44px;border-radius:50%;background:#d4af371a;border:2px solid rgba(212,175,55,.3);color:var(--dnd-gold);font-size:1.3rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;z-index:999;box-shadow:0 2px 8px #0003}.theme-toggle:hover{background:#d4af3733;border-color:#d4af3780;transform:scale(1.1);box-shadow:0 4px 12px #d4af3726}.theme-toggle:active{transform:scale(.95) rotate(180deg);transition:transform .4s cubic-bezier(.4,0,.2,1)}:root[data-theme=light] .theme-toggle{background:#fff;border-color:var(--dnd-border);color:var(--dnd-gold);box-shadow:0 2px 8px #00000014}:root[data-theme=light] .theme-toggle:hover{background:#f8f5f0;border-color:var(--dnd-gold);box-shadow:0 4px 12px #7a5c1e26}@media(max-width:640px){.theme-toggle{width:38px;height:38px;top:calc(.75rem + env(safe-area-inset-top,0px));right:.75rem;font-size:1.1rem}}:root{--dnd-dark: #0f1420;--dnd-darker: #0a0f1a;--dnd-gold: #d4af37;--dnd-gold-dark: #8b7014;--dnd-text: #d8c9b8;--dnd-text-light: #e8dcc8;--dnd-accent-red: #8B3A3A;--dnd-card-bg: #1a2332;--dnd-border: #2d2d4a;--text-muted: #6c6c88;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--dnd-surface-0: #0a0f1a;--dnd-surface-1: #111827;--dnd-surface-2: #1a2332;--dnd-surface-3: #22304a;--dnd-accent-purple: #7b68ee;--dnd-accent-gold: #c9a83e;--dnd-success: #4caf50;--dnd-danger: #ef5350;--dnd-warning: #f39c12;--dnd-info: #42a5f5;--shadow-sm: 0 1px 3px rgba(0,0,0,.3);--shadow-md: 0 4px 12px rgba(0,0,0,.4);--shadow-lg: 0 8px 24px rgba(0,0,0,.5);--theme-transition: background-color .3s ease, color .3s ease, border-color .3s ease, box-shadow .3s ease}:root[data-theme=light]{--dnd-dark: #ede8df;--dnd-darker: #f8f5f0;--dnd-gold: #7a5c1e;--dnd-gold-dark: #5a4210;--dnd-text: #2d2a24;--dnd-text-light: #4a463b;--dnd-accent-red: #8b2e2e;--dnd-card-bg: #ffffff;--dnd-border: #c9c0b0;--text-muted: #7a7366;--dnd-surface-0: #f8f5f0;--dnd-surface-1: #ffffff;--dnd-surface-2: #f0ebe3;--dnd-surface-3: #e8e0d5;--dnd-accent-purple: #6b52d8;--dnd-accent-gold: #8b7014;--dnd-success: #27ae60;--dnd-danger: #c0392b;--dnd-warning: #e67e22;--dnd-info: #2980b9;--shadow-sm: 0 1px 3px rgba(0,0,0,.06);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 8px 24px rgba(0,0,0,.12)}body{background-color:var(--dnd-darker);color:var(--dnd-text);transition:var(--theme-transition)}.character-sheet,.wizard-container,.section,.sheet-header,.sheet-tabs,.sheet-tab,.tab-content,.hp-bar-container,.hp-btn,.hp-input,.dice-roll-modal,.dice-roll-header,.dice-roll-btn,.burger-dropdown,.burger-item,.combat-weapon-card,.spell-circle-row,.slot-btn,.quick-dice-panel,.theme-toggle{transition:background-color .3s ease,color .3s ease,border-color .3s ease,box-shadow .3s ease}.wizard-container{min-height:100vh;background:linear-gradient(180deg,var(--dnd-darker) 0%,var(--dnd-dark) 50%,var(--dnd-dark) 100%);background-attachment:fixed;padding:1.25rem 1rem;padding-top:calc(1.25rem + env(safe-area-inset-top,0px));font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;position:relative}.wizard-container:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 20% 50%,rgba(212,175,55,.03) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(139,58,58,.02) 0%,transparent 50%);pointer-events:none;z-index:0}:root[data-theme=light] .wizard-container:before{background-image:radial-gradient(circle at 20% 50%,rgba(139,112,20,.05) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(217,83,79,.03) 0%,transparent 50%)}.wizard-header{text-align:center;margin-bottom:1.25rem;animation:fadeIn .8s ease-out;position:relative;z-index:1}@keyframes fadeIn{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.wizard-header h1{color:var(--dnd-gold);font-size:2.2rem;margin:0 0 .25rem;text-shadow:2px 2px 4px rgba(0,0,0,.7),0 0 30px rgba(212,175,55,.3),0 0 60px rgba(212,175,55,.1);letter-spacing:2px;font-family:Georgia,serif;font-weight:700}.wizard-header:after{content:"";display:block;width:300px;height:2px;background:linear-gradient(90deg,transparent,var(--dnd-gold),transparent);margin:1rem auto;box-shadow:0 1px 4px #d4af3766}.wizard-header p{color:var(--dnd-text);font-style:italic;letter-spacing:1px;margin:0}.progress-indicator{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap;margin-top:1.25rem}.progress-indicator .step{width:38px;height:38px;border-radius:50%;background:#0d1b2acc;border:2px solid var(--dnd-border);display:flex;align-items:center;justify-content:center;color:var(--dnd-text);font-weight:700;font-size:1rem;transition:all .3s ease;cursor:default;position:relative;box-shadow:0 2px 10px #0006}.progress-indicator .step:before{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;background:radial-gradient(circle,#d4af3700,#d4af3733);opacity:0;transition:opacity .3s ease}.progress-indicator .step.active{background:linear-gradient(135deg,var(--dnd-gold) 0%,var(--dnd-gold-dark) 100%);border-color:var(--dnd-gold);color:#1a1a1a;box-shadow:0 0 0 4px #d4af3733,0 0 20px #d4af3780,inset 0 1px #ffffff4d;transform:scale(1.15);font-weight:700}.progress-indicator .step.active:before{opacity:1}.progress-indicator .step.completed{background:#8b3a3a4d;border-color:var(--dnd-accent-red);color:var(--dnd-accent-red)}.wizard-content{max-width:900px;margin:0 auto;animation:slideIn .6s ease-out;position:relative;z-index:1}.character-review{background:#1a2332f2;padding:1.5rem;border-radius:var(--radius-lg);border:1px solid var(--dnd-border);box-shadow:0 8px 32px #000000b3,inset 0 1px 1px #d4af371a;position:relative;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.character-review:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--dnd-gold),transparent);opacity:.6}.character-review:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--dnd-gold),transparent);opacity:.6}.name-input-group{margin-bottom:1.5rem;display:flex;flex-direction:column}.name-input-group label{font-weight:600;color:var(--dnd-gold);margin-bottom:.75rem;font-size:1.1rem;letter-spacing:1px;text-transform:uppercase;font-family:Georgia,serif}.name-input-group input{padding:.75rem;background:#09191acc;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);font-size:1rem;font-family:inherit;color:var(--dnd-text-light);transition:all .3s ease}.name-input-group input::placeholder{color:#d8c9b84d}.name-input-group input:focus{outline:none;border-color:var(--dnd-gold);background:#09191a;box-shadow:inset 0 0 0 1px var(--dnd-gold),0 0 20px #d4af3733}.review-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;margin-bottom:1.5rem}.review-section{background:#0f1419cc;padding:1.25rem;border-radius:var(--radius-md);border:1px solid var(--dnd-border);border-left:3px solid var(--dnd-gold);position:relative;transition:all .3s ease}.review-section:hover{border-left-color:var(--dnd-accent-red);box-shadow:0 4px 20px #d4af371a,inset 0 0 0 1px #d4af370d}.review-section h3{color:var(--dnd-gold);margin-top:0;margin-bottom:.75rem;font-size:1.1rem;font-family:Georgia,serif;letter-spacing:1px;text-transform:uppercase;font-weight:700}.info-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid rgba(212,175,55,.08)}.info-row:last-child{border-bottom:none}.label{font-weight:600;color:var(--dnd-text);font-size:.95rem}.value{color:var(--dnd-gold);font-weight:700;letter-spacing:.5px}.ability-scores{grid-column:span 1}.ability-scores-compact{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.ability-compact{background:#09191acc;padding:.625rem;border-radius:var(--radius-sm);text-align:center;border:1px solid var(--dnd-border);transition:all .3s ease;position:relative}.ability-compact:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--dnd-gold),transparent);opacity:0;transition:opacity .3s ease}.ability-compact:hover{border-color:var(--dnd-gold);background:#09191a;box-shadow:0 4px 15px #d4af3726}.ability-compact:hover:before{opacity:1}.ability-short{display:block;font-size:.75rem;font-weight:700;color:var(--dnd-text);margin-bottom:.4rem;text-transform:uppercase;letter-spacing:1px}.ability-score{display:block;font-size:1.4rem;font-weight:700;color:var(--dnd-gold);text-shadow:0 2px 4px rgba(0,0,0,.5)}.ability-mod{display:block;font-size:.85rem;color:var(--dnd-accent-red);font-weight:700;margin-top:.25rem}.skills{grid-column:span 1}.skills-list{list-style:none;padding:0;margin:0}.skills-list li{padding:.6rem 0 .6rem 1.5rem;position:relative;color:var(--dnd-text);font-size:.95rem;transition:color .3s ease}.skills-list li:hover{color:var(--dnd-gold)}.skills-list li:before{content:"◆";position:absolute;left:0;color:var(--dnd-gold);font-size:.8rem}.features{grid-column:span 1}.review-summary{margin-bottom:1.5rem}.summary-card{background:linear-gradient(135deg,#d4af3726,#8b3a3a1a);border:1px solid var(--dnd-gold);color:var(--dnd-text-light);padding:1.25rem;border-radius:var(--radius-md);text-align:center;box-shadow:0 0 20px #d4af3733,inset 0 1px #d4af371a;position:relative}.summary-card:before,.summary-card:after{content:"◆ ◆ ◆";position:absolute;left:1rem;color:var(--dnd-gold);opacity:.5;font-size:.8rem;letter-spacing:4px}.summary-card:before{top:1rem}.summary-card:after{bottom:1rem;right:1rem;left:auto}.summary-card h4{margin-top:0;margin-bottom:.5rem;font-size:1.25rem;font-family:Georgia,serif;font-weight:700;letter-spacing:1px;color:var(--dnd-gold)}.summary-card p{margin:.75rem 0;font-size:1rem;text-shadow:1px 1px 2px rgba(0,0,0,.5)}.text-center{text-align:center}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.btn{background:linear-gradient(135deg,#d4af371a,#8b3a3a1a);border:1px solid var(--dnd-border);color:var(--dnd-text-light);padding:.625rem 1.25rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px;position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:1px;background:linear-gradient(90deg,transparent,var(--dnd-gold),transparent);transition:left .3s ease}.btn:hover:before{left:100%}.btn:hover{border-color:var(--dnd-gold);background:linear-gradient(135deg,#d4af3733,#8b3a3a1a);box-shadow:0 0 20px #d4af3733;color:var(--dnd-gold)}.btn-primary{border-color:var(--dnd-gold);color:var(--dnd-gold)}.btn-primary:hover{background:linear-gradient(135deg,var(--dnd-gold) 0%,var(--dnd-gold-dark) 100%);color:#1a1a1a;box-shadow:0 0 30px #d4af3766}.btn-secondary{border-color:var(--dnd-text);color:var(--dnd-text)}.btn-secondary:hover{border-color:var(--dnd-gold);color:var(--dnd-gold)}.btn-success{border-color:var(--dnd-accent-red);color:var(--dnd-accent-red)}.btn-success:hover{background:linear-gradient(135deg,var(--dnd-accent-red) 0%,rgba(139,58,58,.7) 100%);border-color:var(--dnd-accent-red);color:var(--dnd-text-light);box-shadow:0 0 30px #8b3a3a4d}@media(max-width:768px){.wizard-container{padding:1rem}.wizard-header h1{font-size:2rem}.progress-indicator{gap:.75rem}.progress-indicator .step{width:34px;height:34px;font-size:.9rem}.character-review{padding:1.5rem}.review-grid{grid-template-columns:1fr}.ability-scores-compact{grid-template-columns:repeat(2,1fr)}}:root[data-theme=light] body{background-color:var(--dnd-darker)}:root[data-theme=light] h1,:root[data-theme=light] h2,:root[data-theme=light] h3,:root[data-theme=light] h4,:root[data-theme=light] h5,:root[data-theme=light] h6{color:#2d2a24}:root[data-theme=light] .wizard-container{background:linear-gradient(180deg,#f8f5f0,#ede8df,#e5dfd4)}:root[data-theme=light] .wizard-container:before{background-image:radial-gradient(circle at 20% 50%,rgba(122,92,30,.04) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(139,46,46,.02) 0%,transparent 50%)}:root[data-theme=light] .wizard-header h1{color:#2d2a24;text-shadow:none}:root[data-theme=light] .wizard-header p{color:#5c5647}:root[data-theme=light] .progress-indicator .step{background:#fff;border-color:var(--dnd-border);color:var(--dnd-text);box-shadow:0 2px 6px #00000014}:root[data-theme=light] .progress-indicator .step.active{background:linear-gradient(135deg,#c9a230,#a0811a);border-color:#a0811a;color:#fff;box-shadow:0 0 0 3px #7a5c1e26,0 2px 10px #7a5c1e40}:root[data-theme=light] .progress-indicator .step.completed{background:#8b2e2e1f;border-color:#8b2e2e;color:#8b2e2e}:root[data-theme=light] .btn{border-color:var(--dnd-border);background:#fff;color:var(--dnd-text);box-shadow:0 1px 3px #0000000f}:root[data-theme=light] .btn:hover{background:#f5f2ec;border-color:var(--dnd-gold);color:var(--dnd-gold)}:root[data-theme=light] .btn-primary,:root[data-theme=light] .btn-next,:root[data-theme=light] .btn-complete{background:linear-gradient(135deg,#a0811a,#7a5c1e);color:#fff;border-color:#7a5c1e}:root[data-theme=light] .btn-primary:hover,:root[data-theme=light] .btn-next:hover,:root[data-theme=light] .btn-complete:hover{background:linear-gradient(135deg,#b8952a,#a0811a);box-shadow:0 4px 12px #7a5c1e40}:root[data-theme=light] .btn-load{background:#fff;border-color:var(--dnd-border)}:root[data-theme=light] .character-review{background:#fff;box-shadow:0 2px 12px #0000000f}:root[data-theme=light] .review-section{background:#f8f5f0;border-color:var(--dnd-border);box-shadow:none}:root[data-theme=light] .name-input-group input{background:#fff;border-color:var(--dnd-border);color:var(--dnd-text)}:root[data-theme=light] .name-input-group input:focus{background:#fff;border-color:var(--dnd-gold);box-shadow:0 0 0 3px #7a5c1e1a}:root[data-theme=light] .name-input-group input::placeholder{color:#b0a898}:root[data-theme=light] .ability-compact{background:#fff;border-color:var(--dnd-border);box-shadow:0 1px 4px #0000000d}:root[data-theme=light] .ability-compact:hover{background:#f8f5f0;border-color:var(--dnd-gold)}:root[data-theme=light] input,:root[data-theme=light] select,:root[data-theme=light] textarea{background:#fff;color:var(--dnd-text);border-color:var(--dnd-border)}:root[data-theme=light] input:focus,:root[data-theme=light] select:focus,:root[data-theme=light] textarea:focus{border-color:var(--dnd-gold);box-shadow:0 0 0 3px #7a5c1e1a}@media(max-width:480px){.wizard-header h1{font-size:1.5rem}.progress-indicator .step{width:32px;height:32px;font-size:.85rem}.character-review{padding:1rem}.ability-scores-compact{grid-template-columns:repeat(3,1fr)}.btn{width:100%}}.wizard-header-top{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding-right:5rem;padding-top:max(.5rem,env(safe-area-inset-top,0px))}.user-bar{display:flex;align-items:center;gap:.5rem}.user-name{color:var(--dnd-text);font-size:.8rem;opacity:.7;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-signout{background:#8b3a3a33;border:1px solid var(--dnd-accent-red);color:var(--dnd-text-light);padding:.3rem .6rem;border-radius:var(--radius-sm);font-size:.75rem;cursor:pointer;transition:all .3s ease;white-space:nowrap}.btn-signout:hover{background:#8b3a3a66}.btn-back-to-list{font-size:.8rem;padding:.3rem .7rem;white-space:nowrap;flex-shrink:0}@media(max-width:480px){.wizard-header-top{padding-right:0;justify-content:center}}.sg-section{margin-top:2rem;padding-top:1.5rem;border-top:2px solid var(--dnd-border)}.sg-section-title{color:var(--dnd-gold);font-size:1.1rem;font-family:Georgia,serif;letter-spacing:.5px;margin:0 0 .25rem}.sg-section-subtitle{color:var(--dnd-muted);font-size:.8rem;margin:0 0 1rem}.sg-create-btn{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;border:2px dashed var(--dnd-border);border-radius:8px;background:transparent;color:var(--dnd-gold);font-size:.9rem;cursor:pointer;transition:all .2s;margin-bottom:.75rem}.sg-create-btn:hover{border-color:var(--dnd-gold);background:#d4af3714}.sg-group-card{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--dnd-card);border:1px solid var(--dnd-border);border-radius:8px;cursor:pointer;transition:all .2s;margin-bottom:.5rem}.sg-group-card:hover{border-color:var(--dnd-gold);transform:translate(2px)}.sg-group-icon{font-size:1.4rem;flex-shrink:0}.sg-group-info{flex:1;min-width:0}.sg-group-name{color:var(--dnd-text);font-weight:600;font-size:.95rem}.sg-group-meta{color:var(--dnd-muted);font-size:.8rem;margin-top:.15rem}.sg-group-actions{display:flex;gap:.25rem;flex-shrink:0}.sg-group-actions button{background:transparent;border:none;cursor:pointer;font-size:1rem;padding:.25rem;border-radius:4px;transition:background .15s}.sg-group-actions button:hover{background:#ffffff1a}.sg-builder{max-width:800px;margin:0 auto;padding:1rem}.sg-builder-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.sg-back-btn{background:transparent;border:1px solid var(--dnd-border);color:var(--dnd-text);padding:.5rem .75rem;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s}.sg-back-btn:hover{border-color:var(--dnd-gold);color:var(--dnd-gold)}.sg-builder-title{color:var(--dnd-gold);font-size:1.2rem;font-family:Georgia,serif;flex:1}.sg-form-group{margin-bottom:1rem}.sg-form-label{display:block;color:var(--dnd-muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.35rem}.sg-form-input{width:100%;padding:.6rem .75rem;background:var(--dnd-card);border:1px solid var(--dnd-border);border-radius:6px;color:var(--dnd-text);font-size:16px;box-sizing:border-box}.sg-form-input:focus{outline:none;border-color:var(--dnd-gold)}.sg-form-textarea{resize:vertical;min-height:60px}.sg-save-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;background:var(--dnd-gold);color:#1a1a2e;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .2s}.sg-save-btn:hover{opacity:.9}.sg-save-btn:disabled{opacity:.5;cursor:not-allowed}.sg-members-section{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--dnd-border)}.sg-members-title{color:var(--dnd-gold);font-size:1rem;margin:0 0 .75rem}.sg-member-item{display:flex;align-items:center;gap:.5rem;padding:.6rem .75rem;background:var(--dnd-card);border:1px solid var(--dnd-border);border-radius:6px;margin-bottom:.4rem;transition:all .15s}.sg-member-item:hover{border-color:var(--dnd-gold)}.sg-member-item--inactive{opacity:.5}.sg-member-item--access-lost{border-color:#c0392b;opacity:.6}.sg-member-drag{cursor:grab;color:var(--dnd-muted);font-size:1.1rem;flex-shrink:0;-webkit-user-select:none;user-select:none}.sg-member-drag:active{cursor:grabbing}.sg-member-info{flex:1;min-width:0}.sg-member-name{color:var(--dnd-text);font-weight:600;font-size:.9rem}.sg-member-details{color:var(--dnd-muted);font-size:.8rem}.sg-member-alias{color:var(--dnd-gold);font-size:.75rem;font-style:italic}.sg-member-controls{display:flex;align-items:center;gap:.35rem;flex-shrink:0}.sg-member-controls button{background:transparent;border:none;cursor:pointer;font-size:.9rem;padding:.2rem;border-radius:4px;transition:background .15s}.sg-member-controls button:hover{background:#ffffff1a}.sg-member-toggle{width:36px;height:20px;border-radius:10px;background:var(--dnd-border);border:none;cursor:pointer;position:relative;transition:background .2s;flex-shrink:0}.sg-member-toggle--active{background:var(--dnd-gold)}.sg-member-toggle:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s}.sg-member-toggle--active:after{transform:translate(16px)}.sg-add-member-btn{display:flex;align-items:center;gap:.5rem;width:100%;padding:.6rem .75rem;border:2px dashed var(--dnd-border);border-radius:6px;background:transparent;color:var(--dnd-muted);font-size:.85rem;cursor:pointer;transition:all .2s;margin-top:.5rem}.sg-add-member-btn:hover{border-color:var(--dnd-gold);color:var(--dnd-gold)}.sg-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.sg-picker{background:var(--dnd-dark);border:1px solid var(--dnd-border);border-radius:12px;width:100%;max-width:500px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.sg-picker-header{padding:1rem;border-bottom:1px solid var(--dnd-border);display:flex;align-items:center;justify-content:space-between}.sg-picker-title{color:var(--dnd-gold);font-size:1rem;font-family:Georgia,serif}.sg-picker-close{background:transparent;border:none;color:var(--dnd-muted);font-size:1.3rem;cursor:pointer;padding:.25rem}.sg-picker-search{padding:.75rem 1rem;border-bottom:1px solid var(--dnd-border)}.sg-picker-search input{width:100%;padding:.5rem .75rem;background:var(--dnd-card);border:1px solid var(--dnd-border);border-radius:6px;color:var(--dnd-text);font-size:.85rem;box-sizing:border-box}.sg-picker-search input:focus{outline:none;border-color:var(--dnd-gold)}.sg-picker-list{flex:1;overflow-y:auto;padding:.5rem}.sg-picker-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border-radius:6px;cursor:pointer;transition:background .15s}.sg-picker-item:hover{background:#d4af371a}.sg-picker-item--added{opacity:.5;cursor:not-allowed}.sg-picker-char-icon{font-size:1.2rem;flex-shrink:0}.sg-picker-char-info{flex:1;min-width:0}.sg-picker-char-name{color:var(--dnd-text);font-weight:600;font-size:.9rem}.sg-picker-char-details{color:var(--dnd-muted);font-size:.8rem}.sg-picker-char-owner{color:var(--dnd-muted);font-size:.75rem}.sg-picker-empty{text-align:center;color:var(--dnd-muted);padding:2rem;font-size:.9rem}.sg-party-view{max-width:960px;margin:0 auto;padding:1rem}.sg-party-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.sg-party-title{color:var(--dnd-gold);font-size:1.3rem;font-family:Georgia,serif;flex:1}.sg-party-mode-toggle{display:flex;border:1px solid var(--dnd-border);border-radius:6px;overflow:hidden}.sg-party-mode-btn{padding:.4rem .8rem;background:transparent;border:none;color:var(--dnd-muted);font-size:.8rem;cursor:pointer;transition:all .2s}.sg-party-mode-btn--active{background:var(--dnd-gold);color:#1a1a2e;font-weight:600}.sg-party-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem}.sg-pc-card{background:var(--dnd-card);border:1px solid var(--dnd-border);border-radius:10px;padding:.75rem;transition:all .2s;position:relative;display:flex;flex-direction:column}.sg-pc-card--player{border-left:4px solid #3498db}.sg-pc-card:hover{border-color:var(--dnd-gold)}.sg-pc-card--player:hover{border-color:#3498db;border-left-color:#3498db}.sg-pc-card--access-lost{opacity:.5;border-color:#c0392b}.sg-pc-card--inactive{opacity:.4}.sg-pc-header{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.5rem;position:relative}.sg-pc-icon{font-size:1.5rem;flex-shrink:0}.sg-pc-name-block{flex:1;min-width:0}.sg-pc-name{color:var(--dnd-text);font-weight:700;font-size:1rem}.sg-pc-alias{color:var(--dnd-gold);font-size:.75rem;font-style:italic}.sg-pc-class{color:var(--dnd-muted);font-size:.8rem}.sg-pc-owner{color:var(--dnd-muted);font-size:.7rem}.sg-pc-initiative-badge{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.4rem .6rem;background:#d4af3726;border:1px solid rgba(212,175,55,.4);border-radius:6px;flex-shrink:0;min-width:50px}.sg-pc-initiative-badge--header{order:-1;margin-right:.5rem}.sg-pc-initiative-footer{display:none}.sg-pc-initiative-label{color:var(--dnd-muted);font-size:.65rem;text-transform:uppercase;letter-spacing:.5px}.sg-pc-initiative-value{color:var(--dnd-gold);font-size:1.1rem;font-weight:700;cursor:pointer;transition:color .15s}.sg-pc-initiative-value:hover{color:#f4d03f}.sg-pc-initiative-input{width:45px;padding:.25rem .4rem;background:#ffffff1a;border:1px solid var(--dnd-gold);border-radius:4px;color:var(--dnd-gold);font-size:1.1rem;font-weight:700;text-align:center;outline:none}.sg-pc-initiative-input:focus{background:#d4af3733;border-color:#f4d03f}.sg-pc-stats{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.5rem}.sg-pc-stat{display:flex;flex-direction:column;align-items:center;padding:.3rem .5rem;background:#ffffff0a;border:1px solid var(--dnd-border);border-radius:6px;min-width:50px}.sg-pc-stat-label{color:var(--dnd-muted);font-size:.65rem;text-transform:uppercase;letter-spacing:.5px}.sg-pc-stat-value{color:var(--dnd-text);font-size:1rem;font-weight:700}.sg-pc-stat-value--hp{color:#27ae60}.sg-pc-stat-value--low-hp{color:#c0392b}.sg-pc-actions{display:flex;gap:.3rem;flex-wrap:wrap;margin-top:.4rem}.sg-pc-action-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:#d4af371a;border:1px solid rgba(212,175,55,.3);border-radius:4px;color:var(--dnd-gold);font-size:.75rem;cursor:pointer;transition:all .15s}.sg-pc-action-btn:hover{background:#d4af3733}.sg-pc-action-btn:disabled{opacity:.4;cursor:not-allowed}.sg-pc-spell-slots{display:flex;flex-wrap:wrap;gap:.3rem .6rem;margin-bottom:.5rem;padding:.4rem .5rem;background:#ffffff08;border:1px solid var(--dnd-border);border-radius:6px}.sg-pc-spell-row{display:flex;align-items:center;gap:.25rem}.sg-pc-spell-circle{color:var(--dnd-gold);font-size:.65rem;font-weight:700;width:.9rem;text-align:center;flex-shrink:0}.sg-pc-spell-pips{display:flex;gap:2px;align-items:center}.sg-pc-spell-pip{width:8px;height:8px;border-radius:50%;border:1.5px solid var(--dnd-gold);background:transparent;opacity:.35;transition:all .2s}.sg-pc-spell-pip--avail{background:var(--dnd-gold);opacity:1;box-shadow:0 0 4px #d4af3759}.sg-pc-access-lost{text-align:center;padding:1rem;color:#c0392b;font-size:.85rem}.sg-readonly-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;background:#ffffff0d;border:1px solid var(--dnd-border);border-radius:12px;color:var(--dnd-muted);font-size:.75rem}.sg-sync-indicator{display:inline-flex;align-items:center;gap:.25rem;padding:.15rem .5rem;background:#27ae601a;border:1px solid rgba(39,174,96,.35);border-radius:12px;color:#27ae60;font-size:.7rem;font-weight:600;letter-spacing:.5px;animation:sg-sync-pulse 2s ease-in-out infinite;flex-shrink:0}@keyframes sg-sync-pulse{0%,to{opacity:1}50%{opacity:.6}}.sg-inline-input{width:3rem;padding:.15rem .25rem;background:var(--dnd-card);border:1px solid var(--dnd-border);border-radius:4px;color:var(--dnd-text);font-size:16px;text-align:center}.sg-inline-input:focus{outline:none;border-color:var(--dnd-gold)}.sg-loading{text-align:center;padding:2rem;color:var(--dnd-muted)}.sg-error{text-align:center;padding:1rem;color:#c0392b;background:#c0392b1a;border-radius:8px;margin:1rem 0}.sg-empty{text-align:center;padding:2rem;color:var(--dnd-muted);font-size:.9rem}@media(max-width:600px){.sg-party-grid{grid-template-columns:1fr}.sg-party-header{flex-direction:column;align-items:stretch}.sg-party-mode-toggle{align-self:center}}.sg-create-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.sg-create-modal{background:var(--dnd-dark);border:1px solid var(--dnd-border);border-radius:12px;width:100%;max-width:450px;padding:1.25rem}.sg-create-modal h3{color:var(--dnd-gold);font-family:Georgia,serif;margin:0 0 1rem}.sg-create-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1rem}.sg-cancel-btn{padding:.5rem 1rem;background:transparent;border:1px solid var(--dnd-border);color:var(--dnd-text);border-radius:6px;cursor:pointer;font-size:.85rem}.sg-cancel-btn:hover{border-color:var(--dnd-gold)}.sg-delete-btn{padding:.5rem 1rem;background:#c0392b;border:none;color:#fff;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:600}.sg-delete-btn:hover{opacity:.9}.sg-npc-card{border-color:#c0392b73;border-left:4px solid #c0392b}.sg-npc-card:hover{border-color:#c0392b;border-left-color:#c0392b}.sg-npc-badge{color:#e67e22;font-style:italic}.sg-npc-remove-btn{background:transparent;border:none;color:var(--dnd-muted);font-size:.85rem;cursor:pointer;padding:.15rem .3rem;border-radius:4px;transition:color .15s,background .15s;flex-shrink:0;align-self:flex-start}.sg-npc-remove-btn:hover{color:#c0392b;background:#c0392b1a}.sg-npc-hp-input{width:3.5rem}.sg-add-npc-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .8rem;background:#c0392b26;border:1px solid rgba(192,57,43,.5);border-radius:6px;color:#e74c3c;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.sg-add-npc-btn:hover{background:#c0392b40;border-color:#c0392b}.sg-npc-generator{max-width:420px}.sg-npc-form{padding:1rem;display:flex;flex-direction:column;gap:.75rem;overflow-y:auto;max-height:calc(80vh - 60px)}.sg-npc-row{display:flex;flex-direction:column;gap:.3rem}.sg-npc-row-inline{display:grid;grid-template-columns:auto auto;gap:.75rem}.sg-npc-level-range{display:flex;align-items:center;gap:.5rem}.sg-npc-level-sep{color:var(--dnd-muted);font-size:.9rem}.sg-npc-actions{display:flex;gap:.5rem;flex-wrap:wrap}.sg-npc-gen-btn{flex:1;padding:.55rem 1rem;background:var(--dnd-gold);border:none;border-radius:6px;color:#1a1a2e;font-weight:700;font-size:.9rem;cursor:pointer;transition:opacity .2s;white-space:nowrap}.sg-npc-gen-btn:hover{opacity:.88}.sg-npc-add-btn{flex:1;padding:.55rem 1rem;background:#c0392b26;border:1px solid rgba(192,57,43,.5);border-radius:6px;color:#e74c3c;font-weight:600;font-size:.85rem;cursor:pointer;transition:all .2s;white-space:nowrap}.sg-npc-add-btn:hover{background:#c0392b40}.sg-npc-add-btn--full{width:100%;flex:none;margin-top:.5rem}.sg-npc-preview{padding:.75rem;background:#c0392b0f;border:1px solid rgba(192,57,43,.3);border-radius:8px;display:flex;flex-direction:column;gap:.3rem}.sg-npc-preview-header{color:var(--dnd-muted);font-size:.7rem;text-transform:uppercase;letter-spacing:.5px}.sg-npc-preview-name{color:var(--dnd-text);font-weight:700;font-size:1rem}.sg-npc-preview-sub{color:#e67e22;font-size:.8rem;font-style:italic}.sg-npc-preview-stats{display:flex;gap:1rem;color:var(--dnd-muted);font-size:.85rem}.sg-combat-order-hint{display:flex;align-items:center;gap:.4rem;color:var(--dnd-muted);font-size:.75rem;margin-bottom:.5rem;padding:.3rem .5rem;background:#ffffff08;border-radius:6px;border:1px solid var(--dnd-border);width:fit-content}.sg-edit-party-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .8rem;background:#3498db1f;border:1px solid rgba(52,152,219,.45);border-radius:6px;color:#3498db;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.sg-edit-party-btn:hover{background:#3498db38;border-color:#3498db}.sg-npc-header-clickable{cursor:pointer;border-radius:6px;transition:background .15s}.sg-npc-header-clickable:hover{background:#c0392b14}.sg-npc-delta-row{display:flex;gap:.4rem;align-items:center;padding-top:.35rem;flex-wrap:wrap}.sg-npc-delta-input{width:4.5rem;flex-shrink:0}.sg-npc-dmg-btn,.sg-npc-heal-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.3rem .65rem;border:none;border-radius:5px;font-size:.78rem;font-weight:600;cursor:pointer;transition:opacity .15s,filter .15s;white-space:nowrap}.sg-npc-dmg-btn{background:#c0392b2e;color:#e74c3c;border:1px solid rgba(192,57,43,.4)}.sg-npc-dmg-btn:hover{background:#c0392b4d;border-color:#c0392b}.sg-npc-heal-btn{background:#27ae6026;color:#27ae60;border:1px solid rgba(39,174,96,.4)}.sg-npc-heal-btn:hover{background:#27ae6047;border-color:#27ae60}.sg-stepper{display:inline-flex;align-items:center;gap:0;border:1px solid var(--dnd-border);border-radius:6px;overflow:hidden;background:var(--dnd-card);width:fit-content}.sg-stepper-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:none;color:var(--dnd-gold);font-size:1.2rem;font-weight:700;cursor:pointer;transition:background .15s;user-select:none;-webkit-user-select:none}.sg-stepper-btn:hover:not(:disabled){background:#d4af3726}.sg-stepper-btn:active:not(:disabled){background:#d4af3740}.sg-stepper-btn:disabled{opacity:.3;cursor:not-allowed}.sg-stepper-value{min-width:40px;text-align:center;color:var(--dnd-text);font-size:1rem;font-weight:700;padding:0 .25rem;border-left:1px solid var(--dnd-border);border-right:1px solid var(--dnd-border);line-height:36px}.sg-npc-detail-modal{background:var(--dnd-card-bg);border:1px solid var(--dnd-border);border-radius:12px;width:min(480px,96vw);max-height:88vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 8px 32px #00000059}.sg-npc-detail-body{padding:1rem;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:.75rem}.sg-npc-detail-sub{color:#e67e22;font-size:.85rem;font-style:italic}.sg-npc-detail-stats{display:flex;gap:.75rem;flex-wrap:wrap;padding:.5rem;background:#ffffff08;border-radius:8px;border:1px solid var(--dnd-border)}.sg-npc-detail-stat{display:flex;flex-direction:column;align-items:center;min-width:3.5rem}.sg-npc-detail-stat-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.5px;color:var(--dnd-muted)}.sg-npc-detail-stat-value{font-size:1.1rem;font-weight:700;color:var(--dnd-text)}.sg-npc-detail-section-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.8px;color:var(--dnd-muted);font-weight:600;border-bottom:1px solid var(--dnd-border);padding-bottom:.2rem}.sg-npc-ability-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.4rem}.sg-npc-ability{display:flex;flex-direction:column;align-items:center;padding:.4rem .2rem;border:1px solid var(--dnd-border);border-radius:6px;background:#ffffff05}.sg-npc-ability--primary{border-color:#f39c1280;background:#f39c120f}.sg-npc-ability-label{font-size:.6rem;text-transform:uppercase;letter-spacing:.4px;color:var(--dnd-muted);font-weight:600}.sg-npc-ability-score{font-size:1rem;font-weight:700;color:var(--dnd-text);line-height:1.2}.sg-npc-ability-mod{font-size:.75rem;color:var(--dnd-muted)}.sg-npc-attacks{display:flex;flex-direction:column;gap:.35rem}.sg-npc-attack-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;font-size:.82rem;padding:.3rem .5rem;border-radius:6px;background:#ffffff05;border:1px solid var(--dnd-border)}.sg-npc-attack-name{font-weight:600;color:var(--dnd-text);flex:1;min-width:8rem}.sg-npc-attack-bonus{color:#3498db;white-space:nowrap}.sg-npc-attack-damage{color:#e67e22;white-space:nowrap}.sg-npc-spell-info{display:flex;gap:.75rem;flex-wrap:wrap;font-size:.8rem;color:var(--dnd-muted);padding:.4rem .5rem;background:#ffffff05;border:1px solid var(--dnd-border);border-radius:6px}.sg-npc-spell-group{display:flex;flex-direction:column;gap:.3rem}.sg-npc-spell-subtitle{font-size:.72rem;color:var(--dnd-muted);font-style:italic}.sg-npc-spell-list{display:flex;flex-wrap:wrap;gap:.3rem}.sg-npc-spell-tag{padding:.15rem .5rem;background:#9b59b61f;border:1px solid rgba(155,89,182,.3);border-radius:12px;color:#9b59b6;font-size:.78rem}.sg-npc-spell-tag--clickable{cursor:pointer;transition:background .15s,border-color .15s,color .15s}.sg-npc-spell-tag--clickable:hover{background:#9b59b640;border-color:#9b59b699;color:#c39bd3}.sg-npc-spell-tag--active{background:#9b59b659;border-color:#9b59b6;color:#d7bde2;font-weight:600}.sg-npc-spell-slot-count{font-weight:400;color:var(--dnd-muted);font-style:normal}.sg-npc-spell-detail{margin-top:.4rem;padding:.6rem .75rem;background:#9b59b612;border:1px solid rgba(155,89,182,.3);border-radius:8px;font-size:.82rem}.sg-npc-spell-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.35rem}.sg-npc-spell-detail-name{font-weight:700;color:var(--dnd-accent)}.sg-npc-spell-detail-close{background:none;border:none;cursor:pointer;color:var(--dnd-muted);font-size:.85rem;padding:0 .25rem;line-height:1}.sg-npc-spell-detail-close:hover{color:var(--dnd-text)}.sg-npc-spell-detail-meta{display:flex;flex-wrap:wrap;gap:.4rem .8rem;margin-bottom:.4rem;font-size:.77rem;color:var(--dnd-muted)}.sg-npc-spell-detail-text{font-size:.8rem;line-height:1.5;color:var(--dnd-text)}.char-list-page{min-height:100vh;background:linear-gradient(180deg,var(--dnd-darker) 0%,var(--dnd-dark) 50%,var(--dnd-dark) 100%);background-attachment:fixed;padding:1.5rem 1rem;padding-top:calc(1.5rem + env(safe-area-inset-top,0px));font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;position:relative}.char-list-page:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 20% 50%,rgba(212,175,55,.03) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(139,58,58,.02) 0%,transparent 50%);pointer-events:none;z-index:0}:root[data-theme=light] .char-list-page:before{background-image:radial-gradient(circle at 20% 50%,rgba(139,112,20,.05) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(217,83,79,.03) 0%,transparent 50%)}.char-list-container{max-width:800px;margin:0 auto;position:relative;z-index:1}.char-list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--dnd-border);padding-right:3.5rem;flex-wrap:wrap;gap:.75rem}.char-list-title{display:flex;align-items:center;gap:.75rem}.char-list-logo{font-size:2rem}.char-list-title h1{color:var(--dnd-gold);font-size:1.4rem;margin:0;font-family:Georgia,serif;letter-spacing:1px;text-transform:uppercase;text-shadow:0 2px 4px rgba(0,0,0,.5)}:root[data-theme=light] .char-list-title h1{text-shadow:none}.char-list-subtitle{color:var(--dnd-text);font-size:.85rem;margin:.15rem 0 0;opacity:.7;font-style:italic}.char-list-sync{color:var(--dnd-gold, #b8860b);font-weight:500}.char-list-user{display:flex;align-items:center;gap:.5rem}.char-list-username{color:var(--dnd-text);font-size:.8rem;opacity:.7;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.char-list-tabs{display:flex;gap:0;margin-bottom:1.5rem;border-bottom:2px solid var(--dnd-border)}.char-list-tab{flex:1;padding:.75rem 1rem;background:transparent;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;color:var(--dnd-muted);font-size:.95rem;font-weight:600;font-family:Georgia,serif;cursor:pointer;transition:all .2s ease;letter-spacing:.3px}.char-list-tab:hover{color:var(--dnd-text);background:#d4af370d}.char-list-tab--active{color:var(--dnd-gold);border-bottom-color:var(--dnd-gold)}:root[data-theme=light] .char-list-tab--active{color:var(--dnd-gold);border-bottom-color:var(--dnd-gold)}.char-list-new-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem;margin-bottom:1.5rem;background:linear-gradient(135deg,#d4af371f,#d4af370f);border:2px solid var(--dnd-gold);border-radius:var(--radius-lg);color:var(--dnd-gold);font-size:1rem;font-weight:600;font-family:Georgia,serif;letter-spacing:.5px;cursor:pointer;transition:all .3s ease}.char-list-new-btn:hover{background:linear-gradient(135deg,#d4af3733,#d4af371a);border-color:var(--dnd-gold);box-shadow:0 4px 16px #d4af3733;transform:translateY(-1px)}.char-list-new-btn:active{transform:translateY(0)}.char-list-new-icon{font-size:1.3rem;line-height:1}.char-list-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:3rem 0;color:var(--dnd-text)}.char-list-empty{text-align:center;padding:3rem 1rem;color:var(--dnd-text)}.char-list-empty-icon{font-size:3rem;margin-bottom:.75rem;opacity:.5}.char-list-empty h3{color:var(--dnd-gold);font-family:Georgia,serif;font-size:1.2rem;margin:0 0 .5rem}.char-list-empty p{opacity:.6;font-style:italic;margin:0}.char-list-grid{display:flex;flex-direction:column;gap:.75rem}.char-card{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:#1a2332f2;border:1px solid var(--dnd-border);border-radius:var(--radius-lg);cursor:pointer;transition:all .3s ease;position:relative}:root[data-theme=light] .char-card{background:var(--dnd-card-bg);box-shadow:0 1px 4px #0000000f}.char-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--dnd-gold);border-radius:var(--radius-lg) 0 0 var(--radius-lg);opacity:0;transition:opacity .3s ease}.char-card:hover{border-color:var(--dnd-gold);box-shadow:0 4px 20px #d4af371a,inset 0 0 0 1px #d4af370d;transform:translateY(-2px)}.char-card:hover:before{opacity:1}.char-card:active{transform:translateY(0)}.char-card-icon{font-size:2rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#d4af3714;border-radius:var(--radius-md);flex-shrink:0}:root[data-theme=light] .char-card-icon{background:#7a5c1e0f}.char-card-info{flex:1;min-width:0}.char-card-name{color:var(--dnd-text-light);font-size:1.1rem;font-weight:600;font-family:Georgia,serif;margin-bottom:.2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.char-card-details{display:flex;align-items:center;gap:.3rem;color:var(--dnd-text);font-size:.85rem;flex-wrap:wrap}.char-card-level{color:var(--dnd-gold);font-weight:600}.char-card-sep{opacity:.4}.char-card-subclass{color:var(--dnd-text);font-size:.8rem;font-style:italic;opacity:.7;margin-top:.1rem}.char-card-date{color:var(--dnd-text);font-size:.75rem;opacity:.4;margin-top:.25rem}.char-card-delete{background:none;border:none;font-size:1.1rem;cursor:pointer;padding:.5rem;opacity:.3;transition:all .2s ease;border-radius:var(--radius-sm);flex-shrink:0}.char-card-delete:hover{opacity:1;background:#8b3a3a33}.char-card-delete:disabled{cursor:not-allowed}@media(max-width:640px){.char-list-header{flex-direction:column;align-items:flex-start;padding-right:3.5rem}.char-list-title h1{font-size:1.1rem}.char-card{padding:.8rem 1rem}.char-card-icon{width:40px;height:40px;font-size:1.5rem}}.char-list-pregen-btn{background:linear-gradient(135deg,#6495ed1f,#6495ed0f);border-color:var(--dnd-accent, #6495ed);color:var(--dnd-accent, #6495ed);margin-top:-.75rem}.char-list-pregen-btn:hover{background:linear-gradient(135deg,#6495ed33,#6495ed1a);border-color:var(--dnd-accent, #6495ed);box-shadow:0 4px 16px #6495ed33}.pregen-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1100;padding:1rem;animation:fadeIn .25s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.pregen-modal{background:var(--dnd-card, rgba(26, 35, 50, .99));border:1px solid var(--dnd-border);border-radius:var(--radius-lg, 12px);width:95vw;max-width:680px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 16px 48px #0009;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.pregen-header{position:relative;padding:1.25rem 1.5rem;border-bottom:1px solid rgba(212,175,55,.2)}.pregen-header h2{margin:0;color:var(--dnd-gold, #d4af37);font-family:Georgia,serif;font-size:1.25rem}.pregen-subtitle{margin:.25rem 0 0;color:var(--dnd-text-secondary, #a0a0a0);font-size:.85rem}.pregen-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:var(--dnd-text-secondary, #999);font-size:1.4rem;cursor:pointer;line-height:1;padding:.25rem;transition:color .2s}.pregen-close:hover{color:var(--dnd-gold, #d4af37)}.pregen-list{overflow-y:auto;padding:.75rem 1rem 1rem;display:flex;flex-direction:column;gap:.5rem;flex:1;min-height:0}.pregen-card{border:1px solid var(--dnd-border, rgba(255,255,255,.1));border-radius:var(--radius-md, 8px);flex-shrink:0;transition:border-color .2s,box-shadow .2s}.pregen-card:hover{border-color:var(--dnd-gold, #d4af37)}.pregen-card--expanded{border-color:#d4af3766;box-shadow:0 4px 16px #d4af371a}.pregen-card-header{display:flex;align-items:center;gap:.75rem;padding:.9rem 1rem;cursor:pointer;-webkit-user-select:none;user-select:none}.pregen-card-header:hover{background:#d4af370d}.pregen-card-icon{font-size:1.6rem;min-width:2.2rem;text-align:center}.pregen-card-info{flex:1;min-width:0}.pregen-card-name{font-weight:700;color:var(--dnd-text, #e0e0e0);font-size:1rem;line-height:1.2;margin:0}.pregen-card-class{color:var(--dnd-gold, #d4af37);font-size:.85rem;margin-top:.15rem;line-height:1.3;margin-bottom:0}.pregen-card-summary{color:var(--dnd-text-secondary, #a0a0a0);font-size:.8rem;margin-top:.2rem;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pregen-card-expand{color:var(--dnd-text-secondary, #999);font-size:.75rem;flex-shrink:0;line-height:1;padding:.1rem}.pregen-card-details{padding:.75rem 1rem 1rem;border-top:1px solid var(--dnd-border, rgba(255,255,255,.08));display:flex;flex-direction:column;gap:.6rem}.pregen-abilities{display:grid;grid-template-columns:repeat(6,1fr);gap:.35rem;text-align:center}.pregen-ability{display:flex;flex-direction:column;gap:.1rem;background:#ffffff08;border:1px solid var(--dnd-border, rgba(255,255,255,.08));border-radius:var(--radius-sm, 4px);padding:.35rem .2rem}.pregen-ability-label{font-size:.65rem;color:var(--dnd-gold, #d4af37);font-weight:600;letter-spacing:.5px;text-transform:uppercase}.pregen-ability-value{font-size:1.1rem;font-weight:700;color:var(--dnd-text, #e0e0e0)}.pregen-ability-mod{font-size:.75rem;color:var(--dnd-text-secondary, #a0a0a0)}.pregen-section{font-size:.85rem;color:var(--dnd-text, #e0e0e0);line-height:1.4}.pregen-section-label{font-weight:600;color:var(--dnd-gold, #d4af37)}.pregen-spell-row{margin-top:.15rem;padding-left:.5rem;font-size:.83rem}.pregen-spell-level{font-weight:600;color:var(--dnd-text-secondary, #a0a0a0)}.pregen-select-btn{margin-top:.5rem;padding:.65rem 1.25rem;background:linear-gradient(135deg,var(--dnd-gold, #d4af37),#b8961e);border:none;border-radius:var(--radius-md, 8px);color:#1a1a2e;font-weight:700;font-size:.9rem;cursor:pointer;transition:all .2s;width:100%}.pregen-select-btn:hover{box-shadow:0 4px 12px #d4af3766;transform:translateY(-1px)}.pregen-select-btn:active{transform:translateY(0)}:root[data-theme=light] .pregen-modal{background:var(--dnd-card, #fff);box-shadow:0 16px 48px #00000026}:root[data-theme=light] .pregen-backdrop{background:#00000080}:root[data-theme=light] .pregen-ability{background:#00000005;border-color:var(--dnd-border, rgba(0,0,0,.1))}:root[data-theme=light] .pregen-select-btn{color:#fff;background:linear-gradient(135deg,#8b6914,#a07c1c)}@media(max-width:640px){.pregen-backdrop{padding:0}.pregen-modal{width:100vw;max-width:100%;max-height:100vh;max-height:100dvh;border-radius:0;padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0px)}.pregen-abilities{grid-template-columns:repeat(3,1fr)}.pregen-card-summary{white-space:normal}}.class-icon{width:1.3em;height:1.3em;vertical-align:middle;color:var(--dnd-gold)}.char-card-actions{display:flex;flex-direction:column;gap:.25rem;flex-shrink:0}.char-card-share{background:none;border:none;font-size:1.1rem;cursor:pointer;padding:.5rem;opacity:.3;transition:all .2s ease;border-radius:var(--radius-sm)}.char-card-share:hover{opacity:1;background:#5865f233}.shared-section{margin-top:2rem;padding-top:1.5rem;border-top:2px solid var(--border-color, #e0e0e0)}.shared-section-title{font-size:1.25rem;font-weight:700;margin:0 0 .25rem;color:var(--dnd-text, #e0e0e0)}:root[data-theme=light] .shared-section-title{color:#1a1a2e}.shared-section-subtitle{font-size:.85rem;color:var(--dnd-text-secondary, #a0a0a0);margin:0 0 1rem;font-style:italic}:root[data-theme=light] .shared-section-subtitle{color:#666}.shared-section-loading{font-size:.9rem;color:var(--dnd-text-secondary, #a0a0a0);font-style:italic}:root[data-theme=light] .shared-section-loading{color:#666}.char-card--shared{border-left:3px solid var(--accent-color, #5865f2);position:relative}.char-card--shared:hover{border-left-color:var(--dnd-gold, #d4af37)}.char-card-owner{font-size:.8rem;color:var(--accent-color, #5865f2);margin-top:.15rem}.char-card-readonly-badge{font-size:1.2rem;opacity:.5;flex-shrink:0;padding:.5rem}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,var(--dnd-darker) 0%,var(--dnd-dark) 50%,var(--dnd-dark) 100%);background-attachment:fixed;padding:1.25rem 1rem;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;position:relative}.auth-page:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 20% 50%,rgba(212,175,55,.03) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(139,58,58,.02) 0%,transparent 50%);pointer-events:none;z-index:0}:root[data-theme=light] .auth-page:before{background-image:radial-gradient(circle at 20% 50%,rgba(139,112,20,.05) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(217,83,79,.03) 0%,transparent 50%)}.auth-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;color:var(--dnd-text);z-index:1}.auth-container{width:100%;max-width:420px;padding:2rem;background:#1a2332f2;border-radius:var(--radius-lg);box-shadow:0 4px 24px #00000080,inset 0 1px 1px #d4af3714;border:1px solid var(--dnd-border);position:relative;z-index:1;animation:authFadeIn .5s ease-out}:root[data-theme=light] .auth-container{background:var(--dnd-card-bg);box-shadow:0 4px 24px #0000001a,inset 0 1px 1px #7a5c1e0f}.auth-container:before,.auth-container:after{content:"";position:absolute;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--dnd-gold),transparent);opacity:.5}.auth-container:before{top:0}.auth-container:after{bottom:0}@keyframes authFadeIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.auth-header{text-align:center;margin-bottom:1.75rem}.auth-logo{display:flex;align-items:center;justify-content:center;gap:.6rem;margin-bottom:.5rem}.auth-logo-icon{font-size:1.8rem}.auth-logo h1{color:var(--dnd-gold);font-size:1.4rem;font-family:Georgia,serif;letter-spacing:1px;text-transform:uppercase;margin:0;text-shadow:0 2px 4px rgba(0,0,0,.5)}:root[data-theme=light] .auth-logo h1{text-shadow:none}.auth-subtitle{color:var(--dnd-text);font-size:.95rem;margin:0;font-style:italic;letter-spacing:.3px}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-field{display:flex;flex-direction:column;gap:.4rem}.auth-field label{display:block;font-weight:600;color:var(--dnd-gold);font-size:.8rem;letter-spacing:.5px;text-transform:uppercase;font-family:Georgia,serif}.auth-field input{width:100%;padding:.625rem;background:#09191acc;border:1px solid var(--dnd-border);border-radius:var(--radius-sm);font-size:1rem;font-family:inherit;color:var(--dnd-text-light);transition:all .3s ease;box-sizing:border-box}:root[data-theme=light] .auth-field input{background:var(--dnd-darker)}.auth-field input::placeholder{color:#d8c9b84d}:root[data-theme=light] .auth-field input::placeholder{color:#2d2a2459}.auth-field input:focus{outline:none;border-color:var(--dnd-gold);background:#09191a;box-shadow:0 0 20px #d4af3733,inset 0 0 0 1px var(--dnd-gold)}:root[data-theme=light] .auth-field input:focus{background:#fff;box-shadow:0 0 0 2px #7a5c1e40}.auth-error{background:#8b3a3a33;border:1px solid var(--dnd-accent-red);border-radius:var(--radius-sm);padding:.6rem .8rem;color:#e8a0a0;font-size:.85rem;line-height:1.4}:root[data-theme=light] .auth-error{background:#8b2e2e14;color:var(--dnd-accent-red)}.auth-success{background:#2e8b5726;border:1px solid rgba(46,139,87,.4);border-radius:var(--radius-sm);padding:.6rem .8rem;color:#7cd4a8;font-size:.85rem;line-height:1.4}:root[data-theme=light] .auth-success{background:#2e8b5714;color:#1a6b3a}.auth-btn{width:100%;padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;border:none;display:flex;align-items:center;justify-content:center;gap:.5rem;font-family:inherit}.auth-btn:disabled{opacity:.6;cursor:not-allowed}.auth-btn-primary{background:linear-gradient(135deg,var(--dnd-gold) 0%,var(--dnd-gold-dark) 100%);color:#1a1a1a;text-transform:uppercase;letter-spacing:.5px;font-family:Georgia,serif}.auth-btn-primary:hover:not(:disabled){box-shadow:0 4px 16px #d4af3766;transform:translateY(-1px)}.auth-btn-primary:active:not(:disabled){transform:translateY(0)}.auth-btn-google{background:#ffffff14;border:1px solid var(--dnd-border);color:var(--dnd-text-light)}:root[data-theme=light] .auth-btn-google{background:var(--dnd-darker);color:var(--dnd-text)}.auth-btn-google:hover:not(:disabled){background:#ffffff1f;border-color:var(--dnd-gold)}:root[data-theme=light] .auth-btn-google:hover:not(:disabled){background:var(--dnd-card-bg);border-color:var(--dnd-gold)}.auth-google-icon{flex-shrink:0}.auth-btn-loading{display:flex;align-items:center;gap:.5rem}.auth-divider{display:flex;align-items:center;gap:1rem;margin:1.25rem 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--dnd-border),transparent)}.auth-divider span{color:var(--dnd-text);font-size:.8rem;text-transform:uppercase;letter-spacing:1px;opacity:.6}.auth-footer{margin-top:1.5rem;display:flex;flex-direction:column;align-items:center;gap:.5rem}.auth-footer-text{color:var(--dnd-text);font-size:.85rem}.auth-link{background:none;border:none;color:var(--dnd-gold);cursor:pointer;font-size:.85rem;padding:0;font-family:inherit;transition:color .2s ease;text-decoration:none}.auth-link:hover{color:var(--dnd-text-light);text-decoration:underline}.auth-spinner{width:36px;height:36px;border:3px solid var(--dnd-border);border-top-color:var(--dnd-gold);border-radius:50%;animation:authSpin .8s linear infinite}.auth-spinner-small{display:inline-block;width:16px;height:16px;border:2px solid rgba(26,26,26,.3);border-top-color:#1a1a1a;border-radius:50%;animation:authSpin .8s linear infinite}@keyframes authSpin{to{transform:rotate(360deg)}}.auth-migration-notice{margin-bottom:1.5rem;padding:1rem;border-radius:var(--radius-md);background-color:#d4af3714;border:1px solid rgba(212,175,55,.3);display:flex;gap:.75rem;align-items:flex-start}.migration-notice-icon{font-size:1.5rem;flex-shrink:0;margin-top:.125rem}.migration-notice-content{flex:1;display:flex;flex-direction:column;gap:.5rem}.migration-notice-title{font-weight:600;color:var(--dnd-gold);margin:0;font-size:.95rem}.migration-notice-text{margin:0;font-size:.875rem;color:var(--dnd-text-light);line-height:1.4}.migration-notice-apology{color:var(--dnd-text);font-style:italic}:root[data-theme=light] .auth-migration-notice{background-color:#8b70141f;border-color:#8b701466}:root[data-theme=light] .migration-notice-title{color:#8b7014}@media(max-width:480px){.auth-container{padding:1.5rem 1.25rem}.auth-logo h1{font-size:1.2rem}}
