html{width:100%;box-sizing:border-box}*,*:before,*:after{box-sizing:inherit}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:var(--accent-primary, #646cff);text-decoration:inherit}a:hover{color:var(--accent-hover, #535bf2)}body{margin:0;min-width:320px;min-height:100vh;width:100%;background-color:var(--bg-primary, #ffffff);color:var(--text-primary, #213547)}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;cursor:pointer;transition:border-color .25s}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.character-creator{width:100%;margin:0 auto;padding:20px;box-sizing:border-box}.character-creator h2{color:var(--accent-primary);margin-bottom:30px;text-align:center}.wizard-progress{display:flex;justify-content:space-between;margin-bottom:40px;padding:20px;background:var(--card-bg);border-radius:12px;box-shadow:0 2px 8px var(--shadow-color)}.progress-step{display:flex;flex-direction:column;align-items:center;flex:1;position:relative}.progress-step:not(:last-child):after{content:"";position:absolute;top:20px;left:60%;width:80%;height:3px;background:var(--border-color-medium);transition:background .3s ease}.progress-step.completed:not(:last-child):after{background:var(--accent-primary)}.step-number{width:40px;height:40px;border-radius:50%;background:var(--border-color-medium);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;margin-bottom:8px;transition:all .3s ease;position:relative;z-index:1}.progress-step.active .step-number{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;transform:scale(1.2);box-shadow:0 4px 12px var(--shadow-color-medium)}.progress-step.completed .step-number{background:var(--accent-primary);color:#fff}.step-label{font-size:.85rem;color:var(--text-secondary);font-weight:600;text-align:center}.progress-step.active .step-label{color:var(--accent-primary);font-weight:700}.wizard-navigation{display:flex;justify-content:space-between;gap:15px;margin-top:30px;padding-top:20px;border-top:2px solid var(--border-color)}.wizard-navigation button{flex:1;max-width:200px}.wizard-navigation button:disabled{opacity:.5;cursor:not-allowed}.form-section{background:var(--card-bg);padding:20px;margin-bottom:20px;border-radius:8px;border:2px solid var(--border-color-medium)}.form-section h3{color:var(--accent-primary);margin-top:0;margin-bottom:15px;font-size:1.1rem;font-weight:600}.help-text{color:var(--text-secondary);font-size:.9rem;margin-bottom:15px;font-style:italic}.form-group{margin-bottom:15px;flex:1}.form-group label{display:block;font-weight:600;margin-bottom:5px;color:var(--text-secondary);text-transform:capitalize}.form-group input,.form-group select{width:100%;padding:10px;font-size:16px;border:2px solid var(--border-color-medium);border-radius:4px;transition:border-color .2s;background:var(--input-bg);color:var(--text-primary)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--accent-primary)}.form-row{display:flex;gap:15px}.ability-scores-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:15px}.ability-score-input{display:flex;flex-direction:column;align-items:center;padding:15px;background:var(--bg-tertiary);border-radius:8px;border:2px solid var(--border-color-medium)}.ability-score-input label{font-weight:700;color:var(--accent-primary);margin-bottom:8px;font-size:.9rem}.ability-score-input input{width:80px;text-align:center;font-size:1.2rem;font-weight:600;padding:8px;margin-bottom:5px;background:var(--input-bg);color:var(--text-primary)}.ability-score-input .modifier{font-size:1rem;color:var(--text-secondary);font-weight:600}.btn-primary{width:100%;padding:15px;font-size:1.1rem;font-weight:600;background:var(--accent-primary);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background .2s}.btn-primary:hover{background:var(--accent-secondary)}@media(max-width:768px){.form-row{flex-direction:column}.ability-scores-grid{grid-template-columns:repeat(2,1fr)}}.options-list{display:flex;flex-direction:column;gap:10px}.option-item{border:2px solid var(--border-color-medium);border-radius:8px;overflow:hidden;transition:border-color .2s}.option-item:hover{border-color:var(--accent-primary)}.option-header{display:flex;justify-content:space-between;align-items:center;padding:15px;background:var(--bg-tertiary);cursor:pointer;-webkit-user-select:none;user-select:none}.option-header:hover{background:var(--bg-tertiary)}.option-header h4{margin:0;color:var(--accent-primary);font-size:1rem;font-weight:600}.expand-icon{color:var(--accent-primary);font-size:.9rem;transition:transform .2s}.option-description{padding:20px;background:var(--card-bg);border-top:1px solid var(--border-color-medium)}.option-description h5{color:var(--accent-primary);margin-top:15px;margin-bottom:8px;font-size:1rem}.option-description h5:first-child{margin-top:0}.option-description ul{margin:0 0 15px 20px;padding:0}.option-description li{margin-bottom:8px;line-height:1.5}.subrace{margin-left:15px;margin-bottom:15px;padding:10px;background:var(--bg-tertiary);border-radius:4px}.subrace strong{color:var(--accent-primary);display:block;margin-bottom:8px}.btn-select{padding:10px 20px;background:var(--accent-primary);color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600;transition:background .2s;margin-top:10px}.btn-select:hover{background:var(--accent-secondary)}.trait-table{margin:10px 0;overflow-x:auto}.trait-table table{width:100%;border-collapse:collapse;margin:10px 0;font-size:.9rem}.trait-table th,.trait-table td{border:1px solid var(--border-color-medium);padding:8px;text-align:left}.trait-table th{background-color:var(--accent-primary);color:#fff;font-weight:600}.trait-table tr:nth-child(2n){background-color:var(--bg-tertiary)}.racial-bonus{font-size:.85rem;color:var(--accent-primary);font-weight:600;margin-top:5px}.total-score{font-size:1rem;color:var(--text-secondary);font-weight:700;margin-top:5px}.ability-score-input select{width:100%;text-align:center;font-size:1.2rem;font-weight:600;padding:8px;margin-bottom:5px;border:2px solid var(--border-color-medium);border-radius:4px;background:var(--input-bg);color:var(--text-primary);cursor:pointer}.ability-score-input select:focus{outline:none;border-color:var(--accent-primary)}.ability-score-input option:disabled{color:var(--text-secondary)}.combat-stats-display{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px}.stat-box{background:var(--bg-tertiary);padding:15px;border-radius:8px;border:2px solid var(--border-color-medium);text-align:center}.stat-box label{display:block;font-weight:600;color:var(--accent-primary);margin-bottom:10px;font-size:.9rem;text-transform:none}.stat-value{font-size:2rem;font-weight:700;color:var(--text-secondary);margin-bottom:5px}.stat-calculation{font-size:.75rem;color:var(--text-secondary);line-height:1.4}.hp-input{width:100%;font-size:2rem;font-weight:700;text-align:center;padding:5px;border:2px solid var(--accent-primary);border-radius:4px;margin-bottom:5px;background:var(--input-bg);color:var(--text-primary)}.hp-input:focus{outline:none;border-color:var(--accent-secondary)}.skills-selection{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.skill-checkbox{display:flex;align-items:center;gap:10px;padding:10px;background:var(--bg-tertiary);border:2px solid var(--border-color-medium);border-radius:4px;cursor:pointer;transition:all .2s}.skill-checkbox:hover{background:var(--bg-tertiary);border-color:var(--accent-primary)}.skill-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer}.skill-checkbox input[type=checkbox]:checked{accent-color:var(--accent-primary)}.skill-label{font-weight:600;flex:1}.skill-ability-label{font-size:.85rem;color:var(--text-secondary);margin-left:5px}.saves-display{display:flex;gap:10px;flex-wrap:wrap;margin-top:15px}.save-badge{padding:12px 20px;background:var(--bg-tertiary);border:2px solid var(--border-color-medium);border-radius:8px;font-weight:600;color:var(--text-secondary);text-align:center;min-width:120px}.save-badge.proficient{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.proficient-mark{margin-left:8px;font-size:1.2rem}@media(max-width:768px){.skills-selection{grid-template-columns:1fr}}.equipment-choices-container{background:var(--bg-tertiary);padding:20px;border-radius:8px;border:2px solid var(--accent-primary)}.equipment-section-title{margin:0 0 20px;color:var(--accent-primary);font-size:1.2rem}.equipment-choice-group{margin-bottom:25px;padding:15px;background:var(--card-bg);border-radius:6px;border:1px solid var(--border-color)}.choice-title{margin:0 0 12px;color:var(--text-primary);font-size:1rem;font-weight:600}.choice-options{display:flex;flex-direction:column;gap:10px}.equipment-choice-option{display:flex;align-items:center;padding:12px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .3s ease}.equipment-choice-option:hover{border-color:var(--accent-primary);background:var(--bg-tertiary)}.equipment-choice-option input[type=radio]{margin-right:12px;width:20px;height:20px;cursor:pointer}.equipment-choice-option input[type=radio]:checked+.option-label{color:var(--accent-primary);font-weight:600}.option-label{font-size:.95rem;color:var(--text-primary);transition:all .3s ease}.fixed-equipment-group{margin-top:20px;padding:15px;background:var(--bg-secondary);border-radius:6px;border:1px solid var(--border-color-medium)}.fixed-equipment-list{list-style:none;padding:0;margin:10px 0 0}.fixed-equipment-list li{padding:6px 0;color:var(--text-primary);font-size:.95rem}.fixed-equipment-list li:before{content:"✓ ";color:var(--accent-primary);font-weight:700;margin-right:8px}.equipment-categories{display:grid;grid-template-columns:1fr;gap:25px;margin-top:20px}.equipment-category{background:var(--bg-tertiary);padding:20px;border-radius:8px;border:1px solid var(--border-color)}.equipment-category h4{margin:0 0 15px;color:var(--accent-primary);font-size:1.1rem;font-weight:600}.equipment-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}.equipment-checkbox{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .2s ease}.equipment-checkbox:hover{border-color:var(--accent-primary);background:var(--bg-primary)}.equipment-checkbox input{cursor:pointer}.review-sections{display:flex;flex-direction:column;gap:25px;margin-top:20px}.review-section{background:var(--bg-tertiary);padding:20px;border-radius:8px;border:1px solid var(--border-color)}.review-section h4{margin:0 0 15px;color:var(--accent-primary);font-size:1.1rem;font-weight:600;padding-bottom:10px;border-bottom:2px solid var(--border-color)}.review-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px}.review-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--card-bg);border-radius:6px;border:1px solid var(--border-color)}.review-label{font-weight:600;color:var(--text-secondary);margin-right:10px}.review-value{color:var(--text-primary);font-weight:500;text-align:right;flex:1}@media(max-width:768px){.equipment-list,.review-grid{grid-template-columns:1fr}}.spell-limits-display{display:flex;gap:20px;margin-bottom:20px;padding:15px;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border-color)}.spell-limit-box{flex:1;text-align:center;padding:10px;background:var(--card-bg);border-radius:6px}.limit-label{display:block;font-size:.9rem;color:var(--text-secondary);margin-bottom:5px}.limit-value{display:block;font-size:1.2rem;font-weight:700;color:var(--accent-primary)}.spell-category{margin-bottom:30px}.spell-category h4{margin:0 0 15px;color:var(--accent-primary);font-size:1.1rem;font-weight:600}.spell-selection-list{display:flex;flex-direction:column;gap:8px}.spell-select-item{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;overflow:hidden}.spell-checkbox{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background .2s ease}.spell-checkbox:hover{background:var(--card-bg)}.spell-checkbox input[type=checkbox]{cursor:pointer;width:18px;height:18px}.spell-checkbox input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.spell-name{flex:1;font-weight:600;color:var(--text-primary)}.spell-school{font-size:.85rem;color:var(--text-secondary);padding:2px 8px;background:var(--border-color);border-radius:4px}.btn-expand-spell{background:none;border:none;color:var(--accent-primary);cursor:pointer;padding:8px 12px;font-size:.9rem;transition:all .2s ease}.btn-expand-spell:hover{background:var(--bg-tertiary)}.spell-expanded-details{padding:15px;background:var(--card-bg);border-top:1px solid var(--border-color);font-size:.9rem;line-height:1.6}.spell-expanded-details p{margin:8px 0}.spell-expanded-details strong{color:var(--accent-primary);font-weight:600}.subclass-descriptions{margin-top:30px}.subclass-descriptions h4{color:var(--accent-primary);margin-bottom:20px;font-size:1.3rem;text-align:center}.subclass-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-top:20px}.subclass-card{background:var(--card-bg);border:2px solid var(--border-color);border-radius:8px;padding:20px;transition:all .3s ease}.subclass-card:hover{border-color:var(--accent-primary);box-shadow:0 4px 12px var(--shadow-color-medium);transform:translateY(-2px)}.subclass-card h5{color:var(--accent-primary);margin:0 0 12px;font-size:1.1rem;font-weight:600}.subclass-card p{color:var(--text-primary);margin:0;font-size:.9rem;line-height:1.5}.asi-allocation-grid{display:flex;flex-direction:column;gap:20px;margin-top:20px}.asi-allocation-item{display:flex;align-items:center;gap:15px;padding:20px;background:var(--card-bg);border:2px solid var(--border-color);border-radius:8px;transition:all .2s ease}.asi-allocation-item:hover{border-color:var(--accent-primary);box-shadow:0 4px 12px var(--shadow-color-medium)}.asi-ability-label{font-weight:700;font-size:1.1rem;color:var(--accent-primary);min-width:120px}.asi-controls{display:flex;align-items:center;gap:15px;flex:1}.asi-btn{width:40px;height:40px;border-radius:50%;border:2px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-size:1.5rem;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.asi-btn:hover:not(:disabled){background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;transform:scale(1.1)}.asi-btn:disabled{opacity:.3;cursor:not-allowed}.asi-btn-plus{background:linear-gradient(135deg,#10b981,#059669);border-color:#10b981;color:#fff}.asi-btn-plus:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 12px #10b98166}.asi-btn-minus{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#ef4444;color:#fff}.asi-btn-minus:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 12px #ef444466}.asi-score-display{display:flex;align-items:center;gap:8px;font-size:1.1rem;flex:1}.asi-base{font-weight:600;color:var(--text-primary)}.asi-bonus{color:#10b981;font-weight:700}.asi-total{font-weight:700;color:var(--accent-primary);font-size:1.2rem}.asi-modifier{color:var(--text-secondary);font-style:italic}.asi-max-warning{color:#f59e0b;font-weight:600;font-size:.9rem}.asi-info-box{background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:8px;padding:15px;margin-top:20px}.asi-info-box h5{color:var(--accent-primary);margin:0 0 10px;font-size:1.1rem}.asi-info-box p{margin:5px 0;color:var(--text-primary);line-height:1.6}@media(max-width:768px){.spell-limits-display{flex-direction:column}.subclass-grid{grid-template-columns:1fr}.asi-allocation-item{flex-direction:column;align-items:flex-start}.asi-controls{width:100%}.asi-ability-label{min-width:unset}}.character-sheet{margin:0 auto;padding:100px 20px 40px;background:var(--bg-primary);min-height:100vh;max-width:1400px;width:100%;box-sizing:border-box}@media(max-width:1024px){.character-sheet{padding-top:120px}}.sheet-header{background:linear-gradient(135deg,#dc262626,#ef44441a);padding:12px 24px;border-radius:8px;margin-top:0;margin-bottom:16px;box-shadow:none;border:1px solid var(--border-color);display:flex;align-items:center;gap:20px;position:relative;overflow:visible;flex-wrap:nowrap}@media(max-width:768px){.sheet-header{padding-right:20px;flex-wrap:wrap;gap:12px}}.header-left{display:flex;gap:12px;align-items:center;flex-shrink:0}.character-portrait-container{position:relative;width:50px;height:50px}.character-portrait{width:100%;height:100%;border-radius:50%;border:2px solid var(--border-color);box-shadow:none;object-fit:cover}.btn-edit-avatar{position:absolute;bottom:-2px;right:-2px;width:20px;height:20px;border-radius:50%;background:var(--primary-color);border:2px solid var(--card-background);color:#fff;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .2s;line-height:1}.btn-edit-avatar:hover{background:var(--primary-hover);transform:scale(1.1)}.header-name-info{display:flex;flex-direction:row;align-items:center;gap:12px}.character-name{margin:0;color:var(--text-primary);font-size:1.5rem;font-weight:800;letter-spacing:-.4px;text-shadow:none;line-height:1.1;white-space:nowrap}.level-badge{padding:0;background:transparent;border:none;color:var(--text-secondary);font-size:.9rem;font-weight:600;text-shadow:none;white-space:nowrap}.header-center{display:flex;align-items:center;flex-shrink:0}.race-class-text{color:var(--text-primary);font-size:1rem;font-weight:600;text-shadow:none;opacity:1;white-space:nowrap}.header-right{display:flex;gap:16px;align-items:center;margin-left:auto}.hp-display-compact{display:flex;flex-direction:column;gap:4px;min-width:140px}.hp-label-compact{color:var(--text-secondary);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;text-shadow:none}.hp-values-compact{display:flex;align-items:center;gap:6px}.hp-input-compact{width:45px;background:var(--input-bg);border:2px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:1.3rem;font-weight:700;text-align:center;padding:4px 6px;text-shadow:none;transition:all .2s ease}.hp-input-compact:focus{outline:none;background:var(--bg-secondary);border-color:var(--accent-primary);box-shadow:0 0 0 3px #dc26261a}.hp-input-compact::-webkit-outer-spin-button,.hp-input-compact::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.hp-slash{color:var(--text-secondary);font-size:1.2rem;font-weight:600}.hp-max-compact{color:var(--text-primary);font-size:1.3rem;font-weight:700;text-shadow:none}.hp-adjust-buttons{display:flex;gap:6px;margin-top:4px}.btn-hp-adjust{padding:4px 12px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s ease;text-shadow:none}.btn-hp-adjust:hover{background:var(--bg-tertiary);border-color:var(--accent-primary);transform:none}.btn-hp-adjust.damage{border-color:var(--accent-primary);color:var(--accent-primary)}.btn-hp-adjust.damage:hover{background:#dc262614;border-color:var(--accent-primary)}.btn-hp-adjust.heal{border-color:#10b981;color:#10b981}.btn-hp-adjust.heal:hover{background:#10b98114;border-color:#10b981}.temp-hp-compact{display:flex;flex-direction:column;gap:4px;min-width:100px}.temp-hp-input-compact{width:60px;background:var(--input-bg);border:2px solid #60a5fa;border-radius:4px;color:#60a5fa;font-size:1.3rem;font-weight:700;text-align:center;padding:4px 6px;text-shadow:none;transition:all .2s ease}.temp-hp-input-compact:focus{outline:none;background:var(--bg-secondary);border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa1a}.temp-hp-input-compact::-webkit-outer-spin-button,.temp-hp-input-compact::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.rest-buttons-compact{display:flex;gap:8px}.btn-rest-compact{padding:8px 16px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:.85rem;font-weight:700;cursor:pointer;transition:all .2s ease;text-shadow:none}.btn-rest-compact:hover{background:var(--bg-tertiary);border-color:var(--accent-primary);transform:none;box-shadow:none}.btn-rest-compact:active{transform:none}.xp-section{display:flex;flex-direction:column;gap:3px}.xp-label{font-size:.7rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.xp-input{width:100%;max-width:180px;text-align:left;font-size:.9rem;font-weight:600;color:var(--text-primary);background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:4px;padding:5px 8px;transition:all .2s ease}.xp-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #ef44441a}.xp-input::placeholder{color:var(--text-secondary)}.inspiration-section{display:flex;align-items:center}.inspiration-checkbox-label{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:6px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s ease}.inspiration-checkbox-label:hover{background:var(--bg-tertiary);border-color:var(--accent-primary)}.inspiration-checkbox{width:16px;height:16px;cursor:pointer;accent-color:#10b981}.inspiration-text{color:var(--text-primary);font-size:.8rem;font-weight:600}.header-right{display:flex;flex-direction:column;gap:8px;justify-self:end;align-self:start;align-items:flex-end}.header-right-sheet{display:flex;gap:12px;align-items:center;margin-left:auto;flex-shrink:0}.hp-compact-wrapper{display:flex;gap:12px;align-items:center}.hp-compact{display:flex;align-items:center;gap:6px}.hp-label-small,.temp-hp-text{font-size:.75rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.hp-section{display:flex;flex-direction:row;gap:12px;align-items:flex-start}.hp-main{display:flex;flex-direction:column;gap:4px}.hp-label{color:var(--text-secondary);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.hp-inputs{display:flex;align-items:center;gap:4px}.hp-input{width:50px;text-align:center;font-size:1rem;font-weight:800;color:var(--text-primary);background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:4px;padding:4px 6px;transition:all .2s ease}.hp-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #ef44441a}.hp-separator{color:var(--text-secondary);font-weight:700;font-size:.9rem;margin:0 1px}.hp-max{color:var(--text-primary);font-size:1rem;font-weight:800}.hp-bar-mini{width:100%;height:3px;background:#0000004d;border-radius:2px;overflow:hidden;box-shadow:inset 0 1px 2px #0000004d}.hp-bar-fill{height:100%;background:linear-gradient(90deg,#28a745,#20c997);transition:width .5s ease,background .3s ease;border-radius:2px;box-shadow:0 0 6px #28a74580}.hp-bar-fill.low{background:linear-gradient(90deg,#ffc107,#ff9800);box-shadow:0 0 6px #ffc10780}.hp-bar-fill.critical{background:linear-gradient(90deg,#dc3545,#c82333);box-shadow:0 0 6px #dc354580;animation:pulse-critical 1.5s ease-in-out infinite}.temp-hp-section{display:flex;flex-direction:column;gap:4px}.temp-hp-label{color:var(--text-secondary);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.temp-hp-input{width:50px;text-align:center;font-size:.9rem;font-weight:600;color:#60a5fa;background:#3b82f626;border:2px solid rgba(96,165,250,.3);border-radius:4px;padding:4px 6px;transition:all .2s ease}.temp-hp-input:focus{outline:none;border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa1a}.temp-hp-input::placeholder{color:var(--text-secondary)}.hp-actions{display:flex;gap:6px}.btn-hp-action{flex:1;padding:6px 10px;border:2px solid;border-radius:4px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-damage{background:#dc262633;border-color:#dc262699;color:#ef4444}.btn-damage:hover{background:#dc26264d;border-color:#ef4444;transform:translateY(-1px)}.btn-heal{background:#10b98133;border-color:#10b98199;color:#10b981}.btn-heal:hover{background:#10b9814d;border-color:#10b981;transform:translateY(-1px)}.rest-buttons{display:flex;gap:6px}.btn-rest{flex:1;padding:6px 10px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-rest:hover{background:var(--bg-tertiary);border-color:var(--accent-primary);transform:translateY(-1px)}.character-details{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.detail-badge{display:inline-flex;align-items:center;gap:6px;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.25);padding:6px 12px;border-radius:20px;font-size:.85rem;font-weight:600;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.3);transition:all .2s ease}.detail-badge:hover{background:#ffffff40;transform:translateY(-1px);box-shadow:0 2px 8px #0003}.badge-icon{font-size:1rem;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.level-badge{background:#ffd70033;border-color:#ffd70066}.subclass-badge{background:#8a2be233;border-color:#8a2be266}.header-stats{display:flex;gap:16px;align-items:center}.header-stat-box{background:#0000004d;border:2px solid #444;border-radius:8px;padding:12px 20px;min-width:120px;text-align:center;cursor:pointer;transition:all .2s ease}.header-stat-box:hover{border-color:#ef4444;transform:translateY(-2px);box-shadow:0 4px 12px #ef444466}.header-stat-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:#9ca3af;margin-bottom:6px}.header-stat-value{font-size:1.8rem;font-weight:900;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.5)}.inspiration-box .header-stat-value.active{color:#10b981;text-shadow:0 0 12px rgba(16,185,129,.8)}.initiative-box{border-color:#dc2626;background:linear-gradient(135deg,#dc262633,#b91c1c1a)}.initiative-box:hover{border-color:#ef4444;background:linear-gradient(135deg,#dc26264d,#b91c1c33)}.initiative-box .header-stat-value{color:#ef4444}.btn-level-up{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:2px solid #10b981;padding:10px 20px;border-radius:8px;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #10b98166;text-shadow:0 1px 2px rgba(0,0,0,.2);animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 4px 12px #10b98166}50%{box-shadow:0 6px 20px #10b981cc}}.btn-level-up:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px);box-shadow:0 6px 16px #10b98199}.btn-level-up:active{transform:translateY(0)}.header-actions{display:flex;gap:8px;align-items:center}.btn-header-action{position:relative;z-index:1;background:#ffffff26;color:var(--button-text);border:2px solid rgba(255,255,255,.4);padding:8px 12px;border-radius:6px;font-size:.85rem;cursor:pointer;display:flex;align-items:center;gap:4px;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-weight:600;white-space:nowrap}.btn-header-action:hover{background:#ffffff40;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.btn-header-action:active{transform:translateY(0)}.btn-close{position:relative;z-index:1;background:#ffffff26;color:var(--button-text);border:2px solid rgba(255,255,255,.4);width:40px;height:40px;border-radius:50%;font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-weight:700}.btn-close:hover{background:#ffffff40;transform:scale(1.1) rotate(90deg);box-shadow:0 4px 12px #0000004d}.hp-section-header{display:flex;gap:16px;background:#ffffff1f;border:2px solid rgba(255,255,255,.25);border-radius:12px;padding:16px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.hp-main{flex:1;display:flex;flex-direction:column;gap:8px}.hp-label{font-size:.75rem;font-weight:700;color:#ffffffe6;text-transform:uppercase;letter-spacing:.8px;text-shadow:0 1px 2px rgba(0,0,0,.3)}.hp-section{background:#1a1a1a;border:2px solid #444;border-radius:8px;padding:16px;margin-bottom:16px;box-shadow:0 2px 8px #00000080}.section-header{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:#ef4444;margin:0 0 12px;padding-bottom:8px;border-bottom:2px solid #ef4444}.hp-main-container{display:flex;flex-direction:column;gap:12px}.hp-values{display:flex;align-items:center;justify-content:space-between;gap:16px}.hp-current-max{display:flex;align-items:center;gap:8px}.hp-input-large{width:70px;text-align:center;font-size:2rem;font-weight:900;color:#fff;background:#0003;border:2px solid rgba(255,255,255,.3);border-radius:8px;padding:8px;transition:all .3s ease;text-shadow:0 2px 4px rgba(0,0,0,.5)}.hp-input-large:focus{outline:none;border-color:#fff;box-shadow:0 0 0 3px #fff3;background:#0000004d}.hp-slash{font-size:1.8rem;font-weight:700;color:#ffffffb3;text-shadow:0 2px 4px rgba(0,0,0,.3)}.hp-max-large{font-size:2rem;font-weight:900;color:#ffffffe6;text-shadow:0 2px 4px rgba(0,0,0,.5)}.temp-hp-section{display:flex;flex-direction:column;gap:8px;min-width:100px}.temp-hp-label{font-size:.75rem;font-weight:700;color:#ffffffe6;text-transform:uppercase;letter-spacing:.8px;text-shadow:0 1px 2px rgba(0,0,0,.3)}.temp-hp-input-large{width:100%;text-align:center;font-size:1.5rem;font-weight:900;color:#60a5fa;background:#3b82f633;border:2px solid rgba(96,165,250,.5);border-radius:8px;padding:8px;transition:all .3s ease}.temp-hp-input-large:focus{outline:none;border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa33;background:#3b82f64d}.rest-buttons-header{display:flex;gap:8px}.btn-rest-header{flex:1;padding:12px 16px;background:#3b82f633;border:2px solid rgba(96,165,250,.5);border-radius:10px;color:#fff;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .3s ease;text-shadow:0 1px 2px rgba(0,0,0,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-rest-header:hover{background:#3b82f64d;border-color:#60a5fa;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.btn-rest-header:active{transform:translateY(0)}.stats-banner{display:flex;justify-content:space-evenly;gap:12px;margin-bottom:20px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:16px;box-shadow:0 2px 4px var(--shadow-color);flex-wrap:nowrap;overflow-x:auto}@media(max-width:768px){.stats-banner{flex-wrap:wrap}}.stat-item{text-align:center;padding:12px;background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%);border-radius:8px;border:1px solid var(--border-color);transition:all .3s ease;flex:1}.stat-item:hover{transform:translateY(-2px);box-shadow:0 4px 8px var(--shadow-color-medium);border-color:var(--accent-primary)}.stat-item.clickable{cursor:pointer}.stat-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);font-weight:600;margin-bottom:8px}.stat-value{font-size:1.8rem;font-weight:900;color:var(--accent-primary);line-height:1;text-shadow:0 2px 4px rgba(0,0,0,.3)}.stat-value.inspiration-active{color:#10b981;animation:glow-inspiration 2s ease-in-out infinite}@keyframes glow-inspiration{0%,to{text-shadow:0 0 10px rgba(16,185,129,.5)}50%{text-shadow:0 0 20px rgba(16,185,129,.8)}}.stat-input{width:80%;text-align:center;font-size:1.5rem;font-weight:900;color:var(--accent-primary);background:var(--bg-secondary);border:2px solid var(--border-color-medium);border-radius:6px;padding:6px;transition:all .3s ease;margin:0 auto}.stat-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #ef444433}.temp-hp-input{color:#60a5fa;border-color:#60a5fa66;background:#3b82f60d}.temp-hp-input:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa33}.temp-hp-input-banner{width:80%;text-align:center;font-size:1.5rem;font-weight:900;color:#60a5fa;background:#3b82f626;border:2px solid rgba(96,165,250,.4);border-radius:6px;padding:6px;transition:all .3s ease;margin:0 auto}.temp-hp-input-banner:focus{outline:none;border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa33;background:#3b82f640}.temp-hp-input-banner::placeholder{color:#60a5fa80}.hp-current-input{width:60px;height:50px;text-align:center;font-size:2rem;font-weight:900;color:#ef4444;background:#0000004d;border:2px solid #444;border-radius:6px;padding:4px;transition:all .2s ease}.hp-current-input:focus{outline:none;border-color:#ef4444;box-shadow:0 0 0 3px #ef444433}.hp-separator{font-size:2rem;font-weight:700;color:#666;margin:0 4px}.hp-max-display{font-size:2rem;font-weight:900;color:#d1d5db}.hp-temp-section{flex:1}.hp-temp-input{width:60px;height:50px;text-align:center;font-size:1.4rem;font-weight:700;color:#3b82f6;background:#3b82f61a;border:2px solid #3b82f6;border-radius:6px;padding:4px;transition:all .2s ease}.hp-temp-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #3b82f633}.hp-labels{display:flex;gap:16px;margin-top:4px}.hp-label-text{font-size:.7rem;font-weight:600;text-transform:uppercase;color:#9ca3af;letter-spacing:.5px;flex:0 0 68px}.hp-label-text:last-child{flex:0 0 60px}.hp-actions{display:flex;gap:12px}.btn-hp-action{flex:1;padding:10px 16px;border:2px solid;border-radius:6px;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px}.btn-damage{background:#dc262633;border-color:#dc2626;color:#ef4444}.btn-damage:hover{background:#dc26264d;border-color:#ef4444;transform:translateY(-2px);box-shadow:0 4px 12px #dc262666}.btn-heal{background:#10b98133;border-color:#10b981;color:#10b981}.btn-heal:hover{background:#10b9814d;border-color:#10b981;transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.hp-bar-container{width:100%;height:12px;background:#0006;border-radius:6px;overflow:hidden;box-shadow:inset 0 2px 4px #0000004d}.hp-bar-fill{height:100%;background:linear-gradient(90deg,#10b981,#059669);border-radius:6px;transition:width .5s ease,background .3s ease;box-shadow:0 0 8px #10b98199}.hp-bar-fill.low{background:linear-gradient(90deg,#fbbf24,#f59e0b);box-shadow:0 0 8px #fbbf2499}.hp-bar-fill.critical{background:linear-gradient(90deg,#ef4444,#dc2626);box-shadow:0 0 8px #ef444499;animation:pulse-critical 1.5s ease-in-out infinite}.rest-buttons{display:flex;gap:12px;margin-top:4px}.btn-rest{flex:1;padding:10px 16px;background:#3b82f633;border:2px solid #3b82f6;border-radius:6px;color:#60a5fa;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px}.btn-rest:hover{background:#3b82f64d;border-color:#2563eb;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.primary-stats-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;margin-bottom:20px;box-shadow:0 2px 4px var(--shadow-color)}.info-item{display:flex;flex-direction:column;gap:6px;padding:12px 16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;min-width:150px;transition:all .2s ease}.info-item.clickable{cursor:pointer}.info-item.clickable:hover{background:var(--bg-tertiary);border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:0 4px 8px var(--shadow-color)}.info-item.depleted{opacity:.5}.info-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.info-value{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.info-item.resource-pool .info-value{color:var(--accent-primary);font-size:1.2rem}.secondary-info-bar{display:flex;gap:16px;align-items:center;flex-wrap:wrap;background:var(--card-bg);padding:12px 16px;border-radius:8px;margin-bottom:16px;border:1px solid var(--border-color);box-shadow:0 2px 4px var(--shadow-color)}.spell-slots-compact{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.spell-slots-label{font-size:.85rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.spell-slot-group{display:flex;gap:6px;align-items:center;padding:6px 12px;background:var(--bg-secondary);border:2px solid var(--border-color-medium);border-radius:6px;transition:all .2s ease}.spell-slot-group:hover{border-color:var(--accent-primary);transform:translateY(-1px)}.slot-level{font-size:.75rem;font-weight:700;color:var(--text-secondary);min-width:12px}.slot-count{font-size:1rem;font-weight:800;color:var(--accent-primary)}@keyframes pulse-critical{0%,to{opacity:1}50%{opacity:.7}}.sheet-main-grid{display:grid;grid-template-columns:180px 1fr 180px;gap:16px;width:100%;max-width:100%;overflow:hidden;min-height:calc(100vh - 200px);align-items:start}@media(max-width:1200px){.sheet-main-grid{grid-template-columns:160px 1fr}}@media(max-width:968px){.sheet-main-grid{grid-template-columns:1fr}}.ability-scores-panel{display:flex;flex-direction:column;gap:0}.panel-title{text-align:center;background:transparent;color:var(--accent-primary);padding:8px 0;border-bottom:3px solid var(--accent-primary);margin:0 0 10px;font-size:.8rem;letter-spacing:1px;text-transform:uppercase;font-weight:700}.ability-box{background:transparent;border:none;border-bottom:1px solid rgba(75,85,99,.3);border-radius:0;padding:10px 14px;text-align:center;transition:all .2s ease;box-shadow:none;position:relative;overflow:hidden}.ability-box.clickable{cursor:pointer}.ability-box.clickable:hover{background:#dc262614;border-bottom-color:#dc262666;transform:none;box-shadow:none}.ability-box.clickable:active{transform:none}.ability-name{font-size:.75rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;position:relative;z-index:1}.ability-modifier{font-size:2rem;font-weight:800;color:var(--accent-primary);margin:6px 0;line-height:1;position:relative;z-index:1;text-shadow:none}.ability-score{font-size:.9rem;color:var(--text-primary);font-weight:600;margin-top:8px;position:relative;z-index:1}.passive-stat{background:transparent;border:none;border-bottom:1px solid rgba(75,85,99,.3);border-radius:0;padding:10px 14px;text-align:center;margin-top:5px;box-shadow:none}.passive-label{font-size:.65rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.passive-value{font-size:1.5rem;font-weight:800;color:var(--accent-primary)}.right-sidebar-panel{display:flex;flex-direction:column;gap:0}@media(max-width:1200px){.right-sidebar-panel{display:none}}.sidebar-section{background:transparent;border:none;border-bottom:1px solid rgba(75,85,99,.3);border-radius:0;padding:12px 0;box-shadow:none}.sidebar-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-secondary);margin:0 0 12px;padding-bottom:8px;border-bottom:2px solid var(--border-color)}.ac-speed-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.ac-value-large{font-size:2rem!important;font-weight:900!important;color:var(--accent-primary)!important}.info-box{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;padding:10px 8px;text-align:center;box-shadow:0 1px 3px var(--shadow-color)}.info-box-label{font-size:.65rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.info-box-value{font-size:1.3rem;font-weight:700;color:var(--text-primary)}.info-box.text-left{text-align:left}.info-box-value.small-text{font-size:.8rem;line-height:1.4;color:var(--text-primary)}.info-box-empty{padding:12px;text-align:center;color:var(--text-secondary);font-size:.85rem;font-style:italic}.conditions-list{display:flex;flex-direction:column;gap:4px}.condition-item{background:#dc262633;border:1px solid #dc2626;border-radius:4px;padding:8px 10px;color:#ef4444;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;justify-content:space-between;align-items:center}.condition-item:hover{background:#dc26264d;border-color:#ef4444}.remove-icon{opacity:.6;font-weight:700}.condition-item:hover .remove-icon{opacity:1}.senses-list{display:flex;flex-direction:column;gap:8px}.tabbed-content-area{background:var(--card-bg);border-radius:6px;box-shadow:0 2px 4px var(--shadow-color);border:1px solid var(--border-color);overflow:hidden;display:flex;flex-direction:column;min-width:0;width:100%;height:100%}.tab-navigation{display:flex;background:var(--bg-tertiary);border-bottom:3px solid var(--border-color-medium);position:sticky;top:0;z-index:10}.tab-button{flex:1;padding:12px 16px;background:transparent;border:none;border-bottom:3px solid transparent;font-size:.85rem;font-weight:700;color:var(--text-secondary);cursor:pointer;transition:all .3s ease;position:relative;text-transform:uppercase;letter-spacing:.5px}.tab-button:before{content:"";position:absolute;bottom:-3px;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));transform:scaleX(0);transition:transform .3s ease}.tab-button:hover{background:var(--bg-secondary);color:var(--accent-primary)}.tab-button.active{color:var(--accent-primary);background:var(--card-bg)}.tab-button.active:before{transform:scaleX(1)}.tab-content{padding:16px;flex:1;overflow-y:auto;overflow-x:hidden;width:100%;max-width:100%;box-sizing:border-box}.actions-tab,.skills-tab,.inventory-tab,.spells-tab,.features-tab{width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}.actions-tab{display:flex;flex-direction:column;gap:16px}.combat-section{background:var(--bg-tertiary);border-radius:6px;padding:12px;border:1px solid var(--border-color);box-shadow:0 2px 4px var(--shadow-color);width:100%;box-sizing:border-box}.section-title{margin:0 0 16px;color:var(--text-primary);font-size:1.1rem;font-weight:800;padding:12px 16px;border-bottom:none;background:linear-gradient(135deg,#ef444426,#dc26261a);border-left:4px solid #ef4444;border-radius:4px;text-transform:uppercase;letter-spacing:1.2px;box-shadow:0 1px 3px #0000001a}.skills-saves-grid{display:grid;grid-template-columns:1fr 2fr;gap:25px;width:100%;box-sizing:border-box}@media(max-width:968px){.skills-saves-grid{grid-template-columns:1fr}}.saves-column h4,.skills-column h4{margin:0 0 12px;color:#ef4444;font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;padding-bottom:8px;border-bottom:2px solid #ef4444}.save-item{display:flex;align-items:center;gap:12px;padding:12px 15px;background:var(--card-bg);border-radius:8px;border:2px solid transparent;margin-bottom:8px;transition:all .2s ease}.save-item.clickable{cursor:pointer}.save-item:hover{border-color:var(--accent-primary);transform:translate(5px);box-shadow:0 4px 8px var(--shadow-color)}.save-item.proficient{border-color:var(--accent-primary);background:linear-gradient(135deg,var(--card-bg) 0%,rgba(139,0,0,.05) 100%)}.save-prof-indicator{font-size:1.2rem;color:var(--accent-primary);width:20px;text-align:center}.save-modifier{min-width:45px;text-align:center;font-size:1.3rem;font-weight:800;color:var(--accent-primary)}.save-name{font-weight:700;color:var(--text-primary);flex:1;font-size:1rem}.skills-list{display:flex;flex-direction:column;gap:4px}.skill-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:transparent;border-radius:0;border:none;border-bottom:1px solid rgba(75,85,99,.3);transition:all .2s ease}.skill-item.clickable{cursor:pointer}.skill-item:hover{background:#dc262614;border-bottom-color:#dc262666}.skill-item.proficient{background:#dc26260d;border-bottom-color:#dc26264d}.skill-prof-indicator{font-size:.95rem;color:#9ca3af;width:18px;text-align:center;flex-shrink:0}.skill-item.proficient .skill-prof-indicator{color:#ef4444}.skill-modifier{min-width:42px;text-align:left;font-size:1rem;font-weight:800;color:#ef4444;flex-shrink:0}.skill-name{font-weight:600;color:var(--text-primary);flex:1;font-size:.9rem}.skill-ability{font-size:.7rem;color:#9ca3af;text-transform:uppercase;font-weight:600;flex-shrink:0}.weapons-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr));gap:15px;width:100%;box-sizing:border-box}.weapon-card{background:var(--card-bg);border:2px solid var(--border-color-medium);border-radius:12px;padding:18px;transition:all .3s ease;box-shadow:0 2px 4px var(--shadow-color)}.weapon-card:hover{border-color:var(--accent-primary);transform:translateY(-4px);box-shadow:0 8px 16px var(--shadow-color-medium)}.weapon-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:12px;border-bottom:2px solid var(--border-color)}.weapon-header h4{margin:0;color:var(--accent-primary);font-size:1rem;font-weight:600}.weapon-type{background:var(--bg-tertiary);padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.weapon-stats{display:flex;gap:10px;margin-bottom:12px}.btn-roll-attack,.btn-roll-damage{flex:1;padding:12px 16px;border:none;border-radius:10px;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 3px 6px var(--shadow-color);text-transform:uppercase;letter-spacing:.5px}.btn-roll-attack{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:var(--button-text)}.btn-roll-attack:hover{transform:translateY(-3px);box-shadow:0 6px 12px var(--shadow-color-medium)}.btn-roll-damage{background:linear-gradient(135deg,#ff6b35,#f7931e);color:#fff}.btn-roll-damage:hover{transform:translateY(-3px);box-shadow:0 6px 12px #ff6b3566}.weapon-properties{font-size:.85rem;color:var(--text-secondary);font-style:italic;margin-top:10px}.actions-list-container{display:flex;flex-direction:column;gap:0;width:100%}.action-list-item{background:transparent;border:none;border-bottom:1px solid rgba(75,85,99,.3);border-radius:0;padding:10px 14px;transition:all .2s ease}.action-list-item:hover{background:#dc262614;border-bottom-color:#dc262666}.action-source-group{margin-bottom:20px}.action-source-header{font-size:.85rem;font-weight:700;color:var(--accent-primary);text-transform:uppercase;letter-spacing:1px;padding:8px 12px;background:var(--bg-tertiary);border-left:4px solid var(--accent-primary);border-radius:4px;margin-bottom:12px;box-shadow:0 1px 3px var(--shadow-color)}.action-source-subheader{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.8px;padding:6px 8px;margin:16px 0 8px;border-bottom:1px solid var(--border-color)}.action-list-header{display:flex;align-items:center;gap:12px;padding:8px 0;cursor:pointer;-webkit-user-select:none;user-select:none}.action-list-header.clickable:hover{background:var(--bg-tertiary);border-radius:4px;margin:0 -8px;padding:8px}.expand-icon{font-size:.7rem;color:var(--text-secondary);width:16px;transition:transform .2s ease}.spell-level-badge{background:var(--accent-primary);color:#fff;font-size:.7rem;font-weight:600;padding:2px 6px;border-radius:10px;opacity:.8}.action-type-indicator{font-size:1rem;line-height:1}.action-type-indicator.action{color:#ff6b35}.action-type-indicator.bonus{color:#8b5cf6}.action-type-indicator.reaction{color:#06b6d4}.action-name{font-weight:600;font-size:.95rem;color:var(--text-primary);flex:1}.action-source-badge{font-size:.9rem;opacity:.7}.action-list-details{padding-left:24px;font-size:.875rem;line-height:1.5;color:var(--text-secondary)}.action-detail{display:block;margin-bottom:8px}.action-list-buttons{display:flex;gap:8px;margin-top:8px}.btn-roll-mini{padding:6px 12px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;border:none;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px var(--shadow-color)}.btn-roll-mini:hover{transform:translateY(-2px);box-shadow:0 4px 8px var(--shadow-color-medium)}.btn-roll-mini.damage{background:linear-gradient(135deg,#ff6b35,#f7931e)}.action-uses-counter{display:flex;gap:4px;margin-left:auto;align-items:center}.weapon-buttons{display:flex;gap:6px;margin-left:8px;align-items:center}.use-box{display:inline-block;width:20px;height:20px;cursor:pointer;transition:all .2s ease;border-radius:2px;border:2px solid var(--text-secondary);margin:0 2px;background:transparent}.use-box.available{background:var(--card-background);border-color:var(--text-secondary);box-shadow:inset 0 1px 2px #0000001a}.use-box.available:hover{border-color:var(--text-primary);box-shadow:inset 0 1px 3px #00000026}.use-box.used{background:var(--text-secondary);border-color:var(--text-secondary);position:relative}.use-box.used:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--card-background);font-size:.75rem;font-weight:900}.use-box.used:hover{background:var(--text-primary);border-color:var(--text-primary)}.death-saves-section{background:linear-gradient(135deg,var(--bg-tertiary) 0%,rgba(220,53,69,.05) 100%);border:2px solid #dc3545}.death-saves{display:flex;justify-content:space-around;gap:30px;padding:20px}.death-save-group{text-align:center;flex:1}.death-save-label{font-size:.9rem;font-weight:800;text-transform:uppercase;letter-spacing:1px;margin-bottom:15px}.death-save-label.success{color:#28a745}.death-save-label.failure{color:#dc3545}.death-save-boxes{display:flex;gap:12px;justify-content:center}.death-save-box{width:30px;height:30px;border:3px solid currentColor;border-radius:6px;cursor:pointer;transition:all .2s ease;background:var(--card-bg)}.death-save-box:hover{transform:scale(1.15);box-shadow:0 4px 8px var(--shadow-color)}.death-save-box.filled.success{background:#28a745;border-color:#28a745;box-shadow:0 0 10px #28a74580}.death-save-box.filled.failure{background:#dc3545;border-color:#dc3545;box-shadow:0 0 10px #dc354580}.no-spells{text-align:center;padding:60px 20px;color:var(--text-secondary);font-size:1.1rem}.features-tab{display:flex;flex-direction:column;gap:30px}.feature-section{background:var(--bg-tertiary);border-radius:12px;padding:25px;border:2px solid var(--border-color)}.feature-section-title{margin:0 0 20px;color:#ef4444;font-size:.95rem;font-weight:700;padding-bottom:10px;border-bottom:3px solid #ef4444;text-transform:uppercase;letter-spacing:1.5px}.feature-card{background:transparent;border:none;border-bottom:1px solid rgba(75,85,99,.3);border-radius:0;padding:10px 14px;margin-bottom:0;transition:all .2s ease;box-shadow:none}.feature-card:hover{background:#dc262614;border-bottom-color:#dc262666;box-shadow:none;transform:none}.feature-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}.feature-card h4{margin:0;color:var(--accent-primary);font-size:.95rem;font-weight:700;flex:1}.feature-level-badge{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;font-size:.75rem;font-weight:700;padding:3px 8px;border-radius:12px;white-space:nowrap;flex-shrink:0}.feature-description{color:var(--text-primary);line-height:1.6;font-size:.9rem}.feature-description p{margin:6px 0}.feature-description ul,.feature-description ol{margin:10px 0;padding-left:25px}.feature-description li{margin:5px 0}.feature-description strong{color:var(--accent-primary);font-weight:700}.feature-description table{width:100%;margin:15px 0;border-collapse:collapse}.feature-description th,.feature-description td{padding:8px 12px;border:1px solid var(--border-color-medium);text-align:left}.feature-description th{background:var(--bg-tertiary);font-weight:700;color:var(--accent-primary)}@media(max-width:768px){.character-name-section h1{font-size:2rem}.sheet-main-grid{grid-template-columns:1fr}.tab-navigation{flex-wrap:wrap}.tab-button{flex:1 1 50%;font-size:.85rem;padding:14px 10px}.weapons-list{grid-template-columns:1fr}.death-saves{flex-direction:column;gap:20px}}.clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.tab-content::-webkit-scrollbar{width:10px}.tab-content::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:10px}.tab-content::-webkit-scrollbar-thumb{background:var(--accent-primary);border-radius:10px}.tab-content::-webkit-scrollbar-thumb:hover{background:var(--accent-secondary)}.temp-hp-display{display:flex;align-items:center;justify-content:center;gap:6px;padding:4px 8px;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:6px;margin-bottom:8px}.temp-hp-label{font-size:.7rem;color:#fff;font-weight:600;text-transform:uppercase}.temp-hp-input{width:50px;padding:4px;border:2px solid rgba(255,255,255,.3);border-radius:4px;background:#fff3;color:#fff;text-align:center;font-weight:700;font-size:.9rem}.btn-add-temp-hp{margin-top:8px;padding:6px 12px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-add-temp-hp:hover{transform:translateY(-2px);box-shadow:0 4px 8px #3b82f666}.exhaustion-controls{display:flex;align-items:center;justify-content:center;gap:8px}.exhaustion-button{width:24px;height:24px;border-radius:50%;border:2px solid var(--accent-primary);background:var(--bg-secondary);color:var(--accent-primary);font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.exhaustion-button:hover:not(:disabled){background:var(--accent-primary);color:#fff;transform:scale(1.1)}.exhaustion-button:disabled{opacity:.3;cursor:not-allowed}.exhaustion-value{font-size:1.1rem;font-weight:700;color:var(--text-primary);min-width:20px;text-align:center}.roll-mode-select{padding:6px 10px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease;width:100%}.roll-mode-select:hover{border-color:var(--accent-primary)}.roll-mode-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px rgba(var(--accent-primary),.1)}.roll-mode-select option[value=advantage]{color:#10b981}.roll-mode-select option[value=disadvantage]{color:#ef4444}.status-effects-bar{display:flex;flex-wrap:wrap;align-items:center;gap:12px;background:var(--bg-tertiary);padding:12px 16px;border-radius:8px;margin-bottom:16px;border:1px solid var(--border-color);min-height:48px}.concentration-indicator{display:flex;align-items:center;gap:8px;padding:8px 12px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:6px;color:#fff;font-size:.85rem;font-weight:600;box-shadow:0 2px 4px #8b5cf64d}.concentration-icon{font-size:1rem}.concentration-text{flex:1}.btn-break-concentration{background:#fff3;border:none;color:#fff;width:24px;height:24px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;font-weight:700}.btn-break-concentration:hover{background:#ffffff4d;transform:scale(1.1)}.active-conditions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.conditions-label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase}.condition-badge{padding:6px 10px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #ef44444d}.condition-badge:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-2px);box-shadow:0 4px 8px #ef444466}.add-condition-section{margin-left:auto}.condition-select{padding:6px 12px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease}.condition-select:hover{border-color:var(--accent-primary)}.exhaustion-indicator{display:flex;flex-direction:column;gap:4px;padding:8px 12px;background:linear-gradient(135deg,#f97316,#ea580c);border-radius:6px;color:#fff;font-size:.75rem;font-weight:600;box-shadow:0 2px 4px #f973164d}.exhaustion-effect{font-size:.7rem;opacity:.9;font-style:italic}.active-effects-display{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.effects-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase}.effect-badge{padding:6px 10px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #8b5cf64d}.effect-badge:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);transform:translateY(-2px);box-shadow:0 4px 8px #8b5cf680}.effect-badge.ac-bonus{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 4px #3b82f64d}.effect-badge.ac-bonus:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 8px #3b82f680}.effect-badge.roll-bonus{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 4px #10b9814d}.effect-badge.roll-bonus:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 8px #10b98180}.effect-badge.advantage{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 2px 4px #22c55e4d}.effect-badge.advantage:hover{background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 4px 8px #22c55e80}.effect-badge.disadvantage{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 4px #f59e0b4d}.effect-badge.disadvantage:hover{background:linear-gradient(135deg,#d97706,#b45309);box-shadow:0 4px 8px #f59e0b80}.modal-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .3s ease}.modal-content{background:var(--bg-primary);border:2px solid var(--border-color);border-radius:12px;box-shadow:0 8px 32px #00000080;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));padding:20px 24px;border-radius:10px 10px 0 0;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:10}.modal-header h2{margin:0;color:#fff;font-size:1.75rem;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.3)}.btn-close-modal{background:#fff3;border:2px solid rgba(255,255,255,.3);border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:#fff;font-size:1.2rem;font-weight:700}.btn-close-modal:hover{background:#ffffff4d;transform:scale(1.1)}.modal-body{padding:24px}.level-up-step{animation:fadeIn .3s ease}.level-up-step h3{color:var(--accent-primary);font-size:1.5rem;margin:0 0 8px;font-weight:700}.level-up-step>p{color:var(--text-secondary);margin:0 0 24px;font-size:1rem}.hp-choice-container{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.hp-choice-option{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:10px;padding:20px;text-align:center;transition:all .2s ease}.hp-choice-option:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:0 4px 12px #0003}.hp-choice-option h4{color:var(--text-primary);font-size:1.2rem;margin:0 0 8px;font-weight:700}.hp-choice-option p{color:var(--text-secondary);margin:0 0 16px;font-size:.95rem}.hp-result{text-align:center;padding:20px;background:#10b9811a;border:2px solid #10b981;border-radius:10px;animation:fadeIn .5s ease}.success-message{color:#10b981;font-size:1.1rem;font-weight:600;margin:0 0 16px}.success-message strong{color:#059669;font-size:1.3rem}.asi-choice-container{display:flex;flex-direction:column;gap:20px;margin-bottom:20px}.asi-option{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:10px;padding:20px;transition:all .2s ease}.asi-option:hover{border-color:var(--accent-primary)}.asi-option h4{color:var(--text-primary);font-size:1.1rem;margin:0 0 12px;font-weight:700}.asi-option select{width:100%;padding:10px;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.95rem;cursor:pointer;transition:all .2s ease}.asi-option select:hover{border-color:var(--accent-primary)}.asi-option select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #6366f11a}.double-asi{display:grid;grid-template-columns:1fr 1fr;gap:12px}.asi-result{text-align:center;padding:16px}.subclass-choice-container{margin-bottom:20px}.subclass-input{width:100%;padding:12px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:1rem;transition:all .2s ease}.subclass-input:hover{border-color:var(--accent-primary)}.subclass-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #6366f11a}.help-text{color:var(--text-secondary);font-size:.85rem;margin:8px 0 0;font-style:italic}.level-up-summary{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:10px;padding:20px;margin-bottom:20px}.summary-item{padding:12px 0;border-bottom:1px solid var(--border-color);color:var(--text-primary);font-size:1rem}.summary-item:last-child{border-bottom:none}.summary-item strong{color:var(--accent-primary);display:inline-block;min-width:200px;font-weight:700}.modal-actions{display:flex;justify-content:space-between;gap:12px;margin-top:20px}.btn-next{margin-top:16px;min-width:150px}.btn-confirm{flex:1;font-size:1.1rem;padding:14px 24px;background:linear-gradient(135deg,#10b981,#059669);border:2px solid #10b981;box-shadow:0 4px 12px #10b98166}.btn-confirm:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px);box-shadow:0 6px 16px #10b98199}.btn-confirm:disabled{opacity:.6;cursor:not-allowed}@media(max-width:992px){.sheet-header{gap:24px}.character-name{font-size:1.2rem}}@media(max-width:768px){.sheet-header{padding:12px 16px;grid-template-columns:1fr;gap:12px}.header-left{order:1;align-items:stretch}.header-right{order:2;justify-self:stretch;align-items:stretch}.character-name{font-size:1.1rem}.xp-input{max-width:100%}.hp-section{flex-direction:column;gap:8px}.detail-badge{font-size:.75rem;padding:5px 10px}}@media(max-width:768px){.modal-content{max-width:95%}.hp-choice-container,.double-asi{grid-template-columns:1fr}.modal-actions{flex-direction:column}.summary-item strong{display:block;margin-bottom:4px}}.roll-mode-selector{display:flex;flex-direction:column;gap:6px;margin-top:12px;margin-bottom:8px}.roll-mode-btn{width:100%;padding:8px 12px;background:var(--card-background);border:2px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-weight:600;font-size:.85rem;cursor:pointer;transition:all .2s;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:480px){.roll-mode-btn{font-size:.75rem;padding:8px 4px}}.roll-mode-btn:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.roll-mode-btn.active{border-color:var(--primary-color);background:var(--primary-color);color:#fff}.roll-mode-btn.advantage.active{border-color:#27ae60;background:#27ae60}.roll-mode-btn.disadvantage.active{border-color:#e74c3c;background:#e74c3c}.roll-mode-notice{background:#3498db1a;border:1px solid rgba(52,152,219,.3);border-radius:4px;padding:8px 12px;font-size:.85rem;color:var(--text-primary);margin-top:8px;text-align:center}.spell-manager{padding:20px;width:100%;box-sizing:border-box}.homebrew-badge{display:inline-flex;align-items:center;padding:2px 6px;background:#10b98126;border:1px solid rgba(16,185,129,.3);border-radius:4px;font-size:.9rem;margin:0 8px;cursor:help}.spell-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:20px;margin-bottom:30px;background:var(--card-bg);padding:20px;border-radius:8px;box-shadow:0 2px 4px var(--shadow-color)}@media(max-width:1200px){.spell-stats{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.spell-stats{grid-template-columns:repeat(2,1fr)}}.spell-stats .stat{flex:1;text-align:center}.spell-stats label{display:block;font-weight:600;color:var(--accent-primary);margin-bottom:8px;font-size:.9rem}.spell-stats .stat-value{font-size:2rem;font-weight:700;color:var(--text-secondary)}.spell-slots-section{background:var(--card-bg);padding:20px;border-radius:8px;margin-bottom:20px;box-shadow:0 2px 4px var(--shadow-color)}.slots-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.slots-header h3{margin:0;color:var(--accent-primary);font-size:1.1rem;font-weight:600}.btn-long-rest{padding:8px 16px;background:#28a745;color:#fff;border:none;border-radius:4px;font-weight:600;cursor:pointer}.btn-long-rest:hover{background:#218838}.spell-slots-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px}.spell-slot-level{text-align:center;padding:10px;background:var(--bg-tertiary);border-radius:6px;border:1px solid var(--border-color-medium)}.slot-level-label{font-weight:600;font-size:.85rem;color:var(--accent-primary);margin-bottom:6px}.slot-circles{display:flex;gap:5px;justify-content:center;flex-wrap:wrap;margin-bottom:6px}.slot-circle{width:24px;height:24px;border-radius:50%;border:2px solid var(--accent-primary);background:var(--card-bg);cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:all .2s}.slot-circle.available{background:var(--card-bg);color:var(--accent-primary)}.slot-circle.used{background:var(--border-color-medium);color:var(--text-secondary);border-color:var(--border-color-medium)}.slot-circle:hover{transform:scale(1.1)}.slot-count{font-size:.75rem;color:var(--text-secondary)}.spell-filters{display:flex;gap:15px;margin-bottom:20px;flex-wrap:wrap}.btn-toggle-spells{padding:12px 20px;border:2px solid var(--border-color-medium);border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap}.btn-toggle-spells.showing-prepared{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;border-color:var(--accent-primary)}.btn-toggle-spells.showing-prepared:hover{transform:translateY(-2px);box-shadow:0 4px 8px var(--shadow-color-medium)}.btn-toggle-spells.showing-all{background:var(--card-bg);color:var(--text-primary);border-color:var(--border-color-medium)}.btn-toggle-spells.showing-all:hover{border-color:var(--accent-primary);background:var(--bg-tertiary)}.spell-search{flex:2;min-width:200px;padding:12px;border:2px solid var(--border-color-medium);border-radius:8px;font-size:16px;background:var(--input-bg);color:var(--text-primary)}.spell-search:focus{outline:none;border-color:var(--accent-primary)}.spell-filters select{flex:1;min-width:120px;padding:12px;border:2px solid var(--border-color-medium);border-radius:8px;font-size:16px;cursor:pointer;background:var(--input-bg);color:var(--text-primary)}.spell-filters select:focus{outline:none;border-color:var(--accent-primary)}.spells-content{display:grid;grid-template-columns:1fr 1fr;gap:20px}.spells-list{display:flex;flex-direction:column;gap:0;max-height:70vh;overflow-y:auto;background:var(--card-bg);padding:15px;border-radius:8px;box-shadow:0 2px 4px var(--shadow-color)}.spell-item{padding:10px 14px;border:none;border-bottom:1px solid rgba(75,85,99,.3);border-radius:0;cursor:pointer;transition:all .2s;background:transparent}.spell-item:hover,.spell-item.selected{border-bottom-color:#dc262666;background:#dc262614}.spell-item.prepared{background:#dc26260d;border-bottom-color:#dc26264d}.spell-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.spell-item h4{margin:0;color:var(--accent-primary)}.btn-prepare{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#ffc107;transition:transform .2s}.btn-prepare:hover{transform:scale(1.2)}.spell-meta{font-size:.9rem;color:var(--text-secondary);margin:0}.spell-detail{background:var(--card-bg);padding:20px;border-radius:8px;box-shadow:0 2px 4px var(--shadow-color);max-height:70vh;overflow-y:auto;position:sticky;top:20px}.spell-detail h2{margin-top:0;color:var(--accent-primary)}.spell-detail p{line-height:1.6}@media(max-width:1024px){.spells-content{grid-template-columns:1fr}.spell-detail{position:static;max-height:none}}.spell-info-box{background:var(--bg-tertiary);border:2px solid #ffc107;border-radius:8px;padding:15px;margin-bottom:20px}.spell-info-box p{margin:5px 0;line-height:1.6}.spell-info-box strong{color:var(--accent-primary)}.spells-list-compact{display:flex;flex-direction:column;gap:0}.spell-item-compact{background:transparent;border:none;border-bottom:1px solid rgba(75,85,99,.3);border-radius:0;transition:all .2s ease}.spell-item-compact.prepared{background:#dc26260d;border-bottom-color:#dc26264d}.spell-item-compact.expanded{box-shadow:none}.spell-item-header-compact{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;cursor:pointer;-webkit-user-select:none;user-select:none}.spell-item-header-compact:hover{background:#dc262614}.spell-title-row{display:flex;align-items:center;gap:10px;flex:1}.expand-icon{color:var(--accent-primary);font-size:.8rem;width:12px}.spell-item-compact h4{margin:0;font-size:.9rem;font-weight:600;color:var(--text-primary)}.spell-level-badge{font-size:.7rem;padding:2px 6px;background:var(--accent-primary);color:#fff;border-radius:3px;font-weight:600}.btn-prepare-compact{background:transparent;border:none;font-size:1.1rem;cursor:pointer;padding:4px 8px;color:var(--accent-primary);transition:transform .2s ease}.btn-prepare-compact:hover:not(:disabled){transform:scale(1.2)}.btn-prepare-compact:disabled{opacity:.3;cursor:not-allowed}.spell-detail-compact{padding:12px;border-top:1px solid var(--border-color);background:var(--bg-tertiary)}.spell-cast-section{display:flex;align-items:center;gap:12px;margin-bottom:12px;padding:8px;background:var(--card-bg);border-radius:6px;border:1px solid var(--border-color-medium)}.btn-cast-spell{padding:8px 16px;background:linear-gradient(135deg,#8b0000,#d32f2f);color:#fff;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px var(--shadow-color)}.btn-cast-spell:hover:not(:disabled){background:linear-gradient(135deg,#a01010,#e33f3f);transform:translateY(-2px);box-shadow:0 4px 8px var(--shadow-color-medium)}.btn-cast-spell:active:not(:disabled){transform:translateY(0)}.btn-cast-spell:disabled{opacity:.5;cursor:not-allowed}.spell-slots-available{font-size:.8rem;color:var(--text-secondary);font-weight:600}.btn-activate-effect{padding:8px 16px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #8b5cf64d}.btn-activate-effect:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);transform:translateY(-2px);box-shadow:0 4px 8px #8b5cf680}.btn-activate-effect:active{transform:translateY(0)}.spell-activate-section{display:flex;flex-direction:column;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color)}.effect-description{font-size:.8rem;color:var(--text-secondary);font-style:italic}.spell-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:6px;margin-bottom:10px;font-size:.8rem}.spell-meta-grid div{padding:3px 0}.spell-materials{font-size:.8rem;font-style:italic;color:var(--text-secondary);margin:8px 0}.spell-description{font-size:.85rem;line-height:1.5;margin-top:10px}.spell-upgrade{margin-top:10px;padding-top:10px;border-top:1px solid var(--border-color);font-size:.85rem}.inventory{display:flex;flex-direction:column;gap:16px}.currency-section{background:var(--card-bg);padding:16px;border-radius:8px;border:1px solid var(--border-color)}.currency-section h3{margin:0 0 12px;color:var(--accent-primary);font-size:1.1rem;font-weight:600}.currency-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}.currency-input{display:flex;flex-direction:column;gap:4px}.currency-input label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase}.currency-input input{padding:6px 8px;border:1px solid var(--border-color);border-radius:4px;background:var(--input-bg);color:var(--text-primary);font-size:.9rem;text-align:center}.currency-note{margin:10px 0 0;font-size:.75rem;color:var(--text-secondary);font-style:italic}.weight-section{background:var(--card-bg);padding:16px;border-radius:8px;border:1px solid var(--border-color)}.weight-section h3{margin:0 0 12px;color:var(--accent-primary);font-size:1.1rem;font-weight:600}.weight-bar{height:20px;background:var(--bg-tertiary);border-radius:10px;overflow:hidden;margin-bottom:8px;border:1px solid var(--border-color)}.weight-fill{height:100%;transition:width .3s ease,background-color .3s ease}.weight-section p{margin:0;font-size:.9rem}.encumbered{color:#dc3545;font-weight:600}.equipped-section{background:var(--card-bg);padding:16px;border-radius:8px;border:1px solid var(--border-color)}.equipped-section h3{margin:0 0 14px;color:var(--accent-primary);font-size:1.1rem;font-weight:600}.equipped-section h4{margin:0 0 8px;font-size:1rem;font-weight:600;color:var(--accent-primary)}.equipped-armor,.equipped-weapons{margin-bottom:16px}.equipped-armor:last-child,.equipped-weapons:last-child{margin-bottom:0}.equipped-item,.equipped-weapon{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:transparent;border-radius:0;border:none;border-bottom:1px solid rgba(75,85,99,.3);margin-bottom:0;transition:all .2s ease}.equipped-item:hover,.equipped-weapon:hover{background:#dc262614;border-bottom-color:#dc262666}.equipped-weapon .weapon-info{display:flex;flex-direction:column;gap:4px}.weapon-properties{font-size:.75rem;color:var(--text-secondary);font-style:italic}.empty-slot{padding:10px 14px;background:transparent;border-radius:0;border:none;border-bottom:1px solid rgba(75,85,99,.3);color:var(--text-secondary);font-style:italic;font-size:.85rem}.equipped-item button,.equipped-weapon button{padding:6px 12px;background:var(--accent-primary);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.8rem;transition:background .2s ease}.equipped-item button:hover,.equipped-weapon button:hover{background:var(--accent-hover)}.quick-add-equipment{background:var(--card-bg);padding:16px;border-radius:8px;border:1px solid var(--border-color)}.quick-add-equipment h3{margin:0 0 12px;color:var(--accent-primary);font-size:1.1rem;font-weight:600}.quick-add-buttons{display:grid;grid-template-columns:1fr 1fr;gap:10px}.weapon-selector,.armor-selector{padding:8px;border:1px solid var(--border-color);border-radius:4px;background:var(--input-bg);color:var(--text-primary);font-size:.9rem;cursor:pointer}.inventory-list{background:var(--card-bg);padding:16px;border-radius:8px;border:1px solid var(--border-color)}.inventory-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.inventory-header h3{margin:0;color:var(--accent-primary);font-size:1.1rem;font-weight:600}.btn-add-item{padding:6px 12px;background:var(--accent-primary);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background .2s ease}.btn-add-item:hover{background:var(--accent-hover)}.add-item-browser{padding:12px;background:var(--bg-tertiary);border-radius:6px;margin-bottom:12px}.item-browser-select{width:100%;padding:10px 12px;border:2px solid var(--border-color);border-radius:6px;background:var(--input-bg);color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:border-color .2s ease}.item-browser-select:hover{border-color:var(--accent-primary)}.item-browser-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #dc26261a}.items-grid{display:flex;flex-direction:column;gap:0}.inventory-item{display:flex;align-items:center;gap:12px;padding:8px 12px;background:transparent;border-radius:0;border:none;border-bottom:1px solid rgba(75,85,99,.3);transition:all .2s ease}.inventory-item:hover{background:#dc262614;border-bottom-color:#dc262666}.item-header{flex:1;min-width:0}.item-header h4{margin:0;font-size:.9rem;font-weight:600;color:var(--text-primary)}.item-details{display:flex;gap:12px;align-items:center;font-size:.8rem;color:var(--text-secondary)}.item-details p{margin:0;white-space:nowrap}.item-actions{display:flex;gap:6px;align-items:center;flex-shrink:0}.quantity-controls{display:flex;align-items:center;gap:4px;background:var(--bg-tertiary);border-radius:4px;padding:2px}.quantity-controls button{width:20px;height:20px;padding:0;background:var(--accent-primary);color:#fff;border:none;border-radius:3px;cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;transition:background .2s ease;font-weight:700}.quantity-controls button:hover{background:var(--accent-hover)}.quantity-controls span{min-width:24px;text-align:center;font-size:.85rem;font-weight:600;color:var(--text-primary)}.btn-equip{padding:4px 10px;border:none;border-radius:4px;cursor:pointer;font-size:.75rem;font-weight:600;transition:all .2s ease;background:var(--accent-primary);color:#fff;white-space:nowrap}.btn-equip:hover{background:var(--accent-hover)}.btn-equip.equipped{background:#28a745}.btn-remove{width:20px;height:20px;padding:0;background:transparent;color:#dc3545;border:none;border-radius:3px;cursor:pointer;font-size:1.2rem;line-height:1;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn-remove:hover{background:#dc35451a;color:#c82333}.pack-item{background:#fb923c0d;border-left:3px solid #f97316}.pack-item:hover{background:#fb923c1a}.pack-hint{font-size:.8rem;color:#f97316;font-style:italic;margin:4px 0}.from-pack-label{font-size:.75rem;color:var(--text-secondary);font-style:italic;margin:2px 0}.btn-expand-pack{padding:6px 12px;background:linear-gradient(135deg,#f97316,#fb923c);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:600;transition:all .2s ease;white-space:nowrap}.btn-expand-pack:hover{transform:translateY(-1px);box-shadow:0 4px 12px #f973164d}@media(max-width:768px){.currency-grid{grid-template-columns:repeat(3,1fr)}.quick-add-buttons,.add-item-form{grid-template-columns:1fr}.inventory-item{grid-template-columns:1fr;gap:8px}.item-quantity,.item-actions{justify-content:flex-start}}.health-bar-component{display:flex;flex-direction:column;gap:8px}.header-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}@media(max-width:768px){.header-actions{flex-direction:column;align-items:stretch}}.hp-compact-wrapper{display:flex;gap:8px;align-items:center;flex-wrap:wrap;flex:1;min-width:0}@media(max-width:768px){.hp-compact-wrapper{flex-direction:column;align-items:stretch}}.rest-buttons-wrapper{display:flex;gap:8px;align-items:center}@media(max-width:768px){.rest-buttons-wrapper{width:100%;justify-content:stretch}.rest-buttons-wrapper button{flex:1}}.hp-compact{display:flex;align-items:center;gap:6px;background:transparent;border:1px solid rgba(255,255,255,.1);padding:8px 14px;border-radius:8px;flex:1;min-width:0}.hp-label-small{font-weight:600;font-size:.75rem;color:var(--text-secondary);text-transform:uppercase}.hp-display{font-weight:700;font-size:1rem;color:var(--text-primary);white-space:nowrap}.hp-action-buttons{display:flex;flex-direction:column;gap:4px}.btn-heal-compact,.btn-damage-compact{padding:6px 14px;border:none;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;text-transform:uppercase;letter-spacing:.3px}.btn-heal-compact{background:#28a745cc;color:#fff;border:1px solid rgba(40,167,69,1)}.btn-heal-compact:hover:not(:disabled){background:#28a745;box-shadow:0 2px 8px #28a74566}.btn-damage-compact{background:#dc3545cc;color:#fff;border:1px solid rgba(220,53,69,1)}.btn-damage-compact:hover:not(:disabled){background:#dc3545;box-shadow:0 2px 8px #dc354566}.btn-heal-compact:disabled,.btn-damage-compact:disabled{opacity:.5;cursor:not-allowed}.hp-controls{display:flex;gap:4px;align-items:center;background:transparent;border:1px solid rgba(255,255,255,.1);padding:6px;border-radius:8px}.hp-change-input{width:50px;padding:4px 6px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:var(--text-primary);font-size:.9rem;font-weight:600;text-align:center}.hp-change-input:focus{outline:none;border-color:var(--primary-color);background:#ffffff26}.btn-heal,.btn-damage{padding:4px 10px;border:none;border-radius:4px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-heal{background:#28a7454d;color:#28a745;border:1px solid rgba(40,167,69,.5)}.btn-heal:hover:not(:disabled){background:#28a74580}.btn-damage{background:#dc35454d;color:#dc3545;border:1px solid rgba(220,53,69,.5)}.btn-damage:hover:not(:disabled){background:#dc354580}.btn-heal:disabled,.btn-damage:disabled{opacity:.5;cursor:not-allowed}.hp-bar-mini{width:80px;height:6px;background:#0000004d;border-radius:3px;overflow:hidden}.hp-bar-fill{height:100%;background:linear-gradient(90deg,#28a745,#5cb85c);transition:width .3s ease,background .3s ease}.hp-bar-fill.low{background:linear-gradient(90deg,#ffc107,#ff9800)}.hp-bar-fill.critical{background:linear-gradient(90deg,#dc3545,#c82333)}.temp-hp-compact{display:flex;align-items:center;gap:6px;background:transparent;border:1px solid rgba(255,255,255,.1);padding:6px 12px;border-radius:8px;flex-shrink:0}.temp-hp-input{width:50px;padding:4px 6px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--text-primary);font-size:.9rem;font-weight:600;text-align:center}.temp-hp-input:focus{outline:none;border-color:var(--accent-primary);background:#ffffff1a}.temp-hp-text{font-size:.7rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.btn-rest-compact{padding:6px 12px;background:#3498db33;border:1px solid rgba(52,152,219,.4);border-radius:6px;color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-rest-compact:hover{background:#3498db4d;border-color:#3498db99}.btn-rest-compact:disabled{opacity:.5;cursor:not-allowed}.header-inspiration-checkbox{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#ffffff0d;border:2px solid rgba(255,215,0,.3);border-radius:8px;cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none}.header-inspiration-checkbox:has(input:checked){background:#ffd70033;border-color:#ffd700cc;box-shadow:0 0 12px #ffd7004d}.header-inspiration-checkbox:hover{background:#ffffff1a;border-color:#ffd70080}.header-inspiration-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#ffd700}.inspiration-icon{font-size:1.2rem}.inspiration-text{font-size:.85rem;font-weight:600;color:var(--text-primary)}.death-saves{background:#dc35451a;border:2px solid rgba(220,53,69,.4);border-radius:8px;padding:12px;margin-top:12px}.death-saves h4{margin:0 0 8px;font-size:.9rem;color:#dc3545;text-transform:uppercase;letter-spacing:.5px}.death-save-row{display:flex;align-items:center;gap:12px;margin-bottom:6px}.death-save-row span:first-child{font-size:.85rem;font-weight:600;min-width:80px;color:var(--text-secondary)}.death-save-boxes{display:flex;gap:6px}.death-save-box{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-radius:4px;cursor:pointer;transition:all .2s}.death-save-box:hover{border-color:#fff9;background:#ffffff1a}.death-save-box.filled{background:#28a745;border-color:#28a745}.death-save-box.filled.failure{background:#dc3545;border-color:#dc3545}.roll-history-empty{padding:24px;text-align:center;color:var(--text-secondary);font-style:italic;background:#dc26260d;border-radius:8px}.roll-history{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto;padding:16px;background:linear-gradient(135deg,#dc262614,#ef44440d);border-radius:10px;border:2px solid rgba(220,38,38,.15)}.roll-history-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.roll-history-header h3{margin:0;font-size:.9rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.btn-clear-rolls{padding:4px 12px;background:#dc354533;border:1px solid rgba(220,53,69,.4);border-radius:4px;color:#dc3545;font-size:.8rem;cursor:pointer;transition:all .2s}.btn-clear-rolls:hover{background:#dc35454d;border-color:#dc354599}.roll-history-list{display:flex;flex-direction:column;gap:8px}.roll-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--card-bg);border:2px solid rgba(220,38,38,.2);border-radius:8px;transition:all .2s;animation:rollFadeIn .3s ease;box-shadow:0 2px 4px #0000001a}@keyframes rollFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.roll-item:hover{background:#ffffff14;border-color:#fff3}.roll-item.critical-success{background:#28a7451a;border-color:#28a74566}.roll-item.critical-fail{background:#dc35451a;border-color:#dc354566}.roll-label{font-size:.85rem;color:var(--text-secondary);flex:1}.roll-result{display:flex;align-items:baseline;gap:6px}.roll-total{font-size:1.2rem;font-weight:700;color:var(--text-primary)}.critical-success .roll-total{color:#28a745}.critical-fail .roll-total{color:#dc3545}.roll-details{font-size:.8rem;color:var(--text-secondary)}.roll-badge{margin-left:8px;padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.roll-badge.crit{background:#28a7454d;color:#28a745}.roll-badge.fail{background:#dc35454d;color:#dc3545}.character-bio{padding:1.5rem;max-width:900px;margin:0 auto}.bio-section{background:var(--card-background);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.bio-section h3{margin:0 0 1rem;color:var(--text-primary);font-size:1.2rem;border-bottom:2px solid var(--primary-color);padding-bottom:.5rem}.bio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.bio-field{display:flex;flex-direction:column}.bio-field label{font-weight:600;margin-bottom:.3rem;color:var(--text-primary);font-size:.9rem}.bio-field input{padding:.5rem;border:1px solid var(--border-color);border-radius:4px;background:var(--input-background);color:var(--text-primary);font-size:.95rem;transition:border-color .2s}.bio-field input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #3498db1a}.bio-textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:4px;background:var(--input-background);color:var(--text-primary);font-size:.95rem;font-family:inherit;resize:vertical;transition:border-color .2s;line-height:1.5}.bio-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #3498db1a}.bio-textarea::placeholder{color:var(--text-muted);opacity:.7}.personality-field{margin-bottom:1.5rem}.personality-field:last-child{margin-bottom:0}.personality-field label{display:block;margin-bottom:.5rem}.personality-field strong{display:block;color:var(--text-primary);font-size:1rem;margin-bottom:.25rem}.field-hint{display:block;font-size:.85rem;color:var(--text-muted);font-weight:400;font-style:italic}@media(max-width:768px){.character-bio,.bio-section{padding:1rem}.bio-grid{grid-template-columns:1fr 1fr}}@media(max-width:480px){.bio-grid{grid-template-columns:1fr}}.character-notes{padding:1.5rem;max-width:900px;margin:0 auto}.notes-section{background:var(--card-background);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.notes-section h3{margin:0 0 1rem;color:var(--text-primary);font-size:1.2rem;border-bottom:2px solid var(--primary-color);padding-bottom:.5rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem}.section-header h3{margin:0;padding:0;border:none}.notes-textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:4px;background:var(--input-background);color:var(--text-primary);font-size:.95rem;font-family:inherit;resize:vertical;transition:border-color .2s;line-height:1.6}.notes-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #3498db1a}.notes-textarea::placeholder{color:var(--text-muted);opacity:.7}.btn-add-log{padding:.5rem 1rem;background:var(--primary-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600;font-size:.9rem;transition:all .2s;white-space:nowrap}.btn-add-log:hover{background:var(--primary-hover);transform:translateY(-1px)}.add-log-form{margin-bottom:1.5rem;padding:1rem;background:var(--input-background);border:1px solid var(--border-color);border-radius:6px}.btn-save-log{margin-top:.75rem;padding:.5rem 1.5rem;background:var(--success-color, #27ae60);color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600;font-size:.9rem;transition:all .2s}.btn-save-log:hover{background:#229954;transform:translateY(-1px)}.session-log-list{display:flex;flex-direction:column;gap:1rem}.session-log-entry{background:var(--input-background);border:1px solid var(--border-color);border-radius:6px;padding:1rem;transition:all .2s}.session-log-entry:hover{border-color:var(--primary-color);box-shadow:0 2px 4px #0000001a}.log-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.log-date{font-weight:600;color:var(--primary-color);font-size:.9rem}.btn-delete-log{background:none;border:none;cursor:pointer;font-size:1.2rem;padding:.25rem;opacity:.6;transition:all .2s}.btn-delete-log:hover{opacity:1;transform:scale(1.1)}.log-content{color:var(--text-primary);line-height:1.6;white-space:pre-wrap;word-wrap:break-word}.empty-message{text-align:center;color:var(--text-muted);font-style:italic;padding:2rem 1rem;margin:0}@media(max-width:768px){.character-notes,.notes-section{padding:1rem}.section-header{flex-direction:column;align-items:stretch}.btn-add-log{width:100%}}@media(prefers-color-scheme:dark){.session-log-entry{background:#ffffff08}.session-log-entry:hover{background:#ffffff0d}}.share-modal{max-width:500px;width:90%}.share-info{margin-bottom:1.5rem;text-align:center}.share-info h3{margin:0 0 .5rem;color:var(--text-primary);font-size:1.5rem}.share-description{color:var(--text-secondary);font-size:.95rem;line-height:1.5;margin:0}.share-error{background:#e74c3c1a;border:1px solid rgba(231,76,60,.3);border-radius:6px;padding:1rem;margin-bottom:1.5rem;color:#e74c3c;font-size:.9rem}.share-actions{display:flex;flex-direction:column;gap:1rem;align-items:center}.btn-enable-sharing{width:100%;max-width:300px;padding:.75rem 1.5rem;font-size:1rem}.share-note{font-size:.85rem;color:var(--text-muted);text-align:center;margin:0;font-style:italic}.share-active{display:flex;flex-direction:column;gap:1.5rem}.share-link-container{display:flex;flex-direction:column;gap:.5rem}.share-link-container label{font-weight:600;color:var(--text-primary);font-size:.9rem}.share-link-input-group{display:flex;gap:.5rem}.share-link-input{flex:1;padding:.75rem;border:2px solid var(--border-color);border-radius:6px;background:var(--input-background);color:var(--text-primary);font-size:.9rem;font-family:monospace;transition:border-color .2s}.share-link-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #3498db1a}.btn-copy-link{padding:.75rem 1.25rem;background:var(--primary-color);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;font-size:.9rem;transition:all .2s;white-space:nowrap}.btn-copy-link:hover{background:var(--primary-hover);transform:translateY(-1px)}.btn-copy-link:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-disable-sharing{width:100%;padding:.75rem 1.5rem;background:#e74c3c;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;font-size:.95rem;transition:all .2s}.btn-disable-sharing:hover{background:#c0392b;transform:translateY(-1px)}.btn-disable-sharing:disabled{opacity:.6;cursor:not-allowed;transform:none}@media(max-width:768px){.share-modal{max-width:95%}.share-link-input-group{flex-direction:column}.btn-copy-link{width:100%}}.avatar-editor-modal{max-width:600px;width:90%;max-height:90vh;overflow-y:auto}.avatar-preview-section{display:flex;flex-direction:column;align-items:center;margin-bottom:1.5rem;padding:1.5rem;background:var(--input-background);border-radius:8px}.avatar-preview-section h3{margin:0 0 1rem;color:var(--text-primary);font-size:1rem}.avatar-preview-large{width:150px;height:150px;border-radius:50%;overflow:hidden;border:4px solid var(--primary-color);box-shadow:0 4px 12px #00000026;margin-bottom:.75rem}.avatar-preview-large img{width:100%;height:100%;object-fit:cover}.avatar-preview-label{font-weight:600;color:var(--text-primary);font-size:1.1rem;margin:0}.avatar-tabs{display:flex;gap:8px;margin-bottom:1.5rem;border-bottom:2px solid var(--border-color)}.avatar-tab{flex:1;padding:.75rem 1rem;background:none;border:none;border-bottom:3px solid transparent;color:var(--text-secondary);font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s}.avatar-tab:hover{color:var(--text-primary);background:var(--input-background)}.avatar-tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.avatar-error{background:#e74c3c1a;border:1px solid rgba(231,76,60,.3);border-radius:6px;padding:1rem;margin-bottom:1.5rem;color:#e74c3c;font-size:.9rem}.avatar-presets{display:flex;flex-direction:column;gap:1rem}.btn-random-avatar{padding:.75rem 1.5rem;background:var(--primary-color);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;font-size:.95rem;transition:all .2s}.btn-random-avatar:hover{background:var(--primary-hover);transform:translateY(-2px)}.preset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:1rem;max-height:400px;overflow-y:auto;padding:1rem;background:var(--input-background);border-radius:8px}.preset-avatar{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem;border:2px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s;background:var(--card-background)}.preset-avatar:hover{border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.preset-avatar.selected{border-color:var(--primary-color);background:#3498db1a;box-shadow:0 0 0 3px #3498db33}.preset-avatar img{width:80px;height:80px;border-radius:50%;object-fit:cover}.preset-label{font-size:.75rem;text-align:center;color:var(--text-secondary);font-weight:500}.avatar-custom{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:var(--input-background);border-radius:8px}.avatar-custom label{font-weight:600;color:var(--text-primary);font-size:.9rem}.custom-url-input-group{display:flex;gap:.5rem}.custom-url-input{flex:1;padding:.75rem;border:2px solid var(--border-color);border-radius:6px;background:var(--card-background);color:var(--text-primary);font-size:.9rem;transition:border-color .2s}.custom-url-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #3498db1a}.btn-validate-url{padding:.75rem 1.25rem;background:var(--primary-color);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;font-size:.9rem;transition:all .2s;white-space:nowrap}.btn-validate-url:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.btn-validate-url:disabled{opacity:.6;cursor:not-allowed}.custom-url-hint{font-size:.85rem;color:var(--text-muted);margin:0;font-style:italic}.avatar-actions{display:flex;gap:1rem;margin-top:1.5rem;justify-content:flex-end}.avatar-actions .btn-primary,.avatar-actions .btn-secondary{padding:.75rem 1.5rem;border-radius:6px;font-weight:600;font-size:.95rem;transition:all .2s}.avatar-actions .btn-primary{background:var(--primary-color);color:#fff;border:none}.avatar-actions .btn-primary:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.avatar-actions .btn-secondary{background:var(--card-background);color:var(--text-primary);border:2px solid var(--border-color)}.avatar-actions .btn-secondary:hover:not(:disabled){border-color:var(--primary-color);transform:translateY(-1px)}.avatar-actions button:disabled{opacity:.6;cursor:not-allowed;transform:none}@media(max-width:768px){.avatar-editor-modal{max-width:95%}.preset-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.preset-avatar img{width:60px;height:60px}.custom-url-input-group{flex-direction:column}.btn-validate-url{width:100%}.avatar-actions{flex-direction:column-reverse}.avatar-actions button{width:100%}}.dice-roll-panel{position:fixed;bottom:20px;right:20px;width:300px;max-height:450px;background:var(--card-bg);border:1px solid var(--border-color-medium);border-radius:10px;box-shadow:0 4px 12px var(--shadow-color-medium);overflow:hidden;z-index:999;display:flex;flex-direction:column}.dice-panel-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:var(--button-text);border-bottom:1px solid var(--accent-primary)}.dice-panel-header h3{margin:0;font-size:1rem;font-weight:700}.btn-clear-rolls{background:#fff3;color:var(--button-text);border:1px solid rgba(255,255,255,.3);padding:6px 12px;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:600;transition:all .2s}.btn-clear-rolls:hover{background:#ffffff4d;transform:scale(1.05)}.no-rolls{padding:40px 20px;text-align:center;color:var(--text-secondary)}.no-rolls p{margin:0;font-size:.95rem}.rolls-list{overflow-y:auto;max-height:380px;padding:8px;display:flex;flex-direction:column;gap:6px}.roll-item{background:var(--bg-tertiary);border:1px solid var(--border-color-medium);border-radius:6px;padding:10px;transition:all .2s;animation:slideIn .25s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.roll-item.critical-success{border-color:#28a745;background:linear-gradient(135deg,var(--bg-tertiary) 0%,rgba(40,167,69,.15) 100%);box-shadow:0 0 8px #28a7454d}.roll-item.critical-fail{border-color:#dc3545;background:linear-gradient(135deg,var(--bg-tertiary) 0%,rgba(220,53,69,.15) 100%);box-shadow:0 0 8px #dc35454d}.roll-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}.roll-type{font-size:.7rem;font-weight:700;text-transform:uppercase;color:var(--accent-primary);letter-spacing:.4px}.roll-time{font-size:.65rem;color:var(--text-tertiary)}.roll-label{font-weight:600;color:var(--text-primary);margin-bottom:6px;font-size:.9rem}.roll-breakdown{display:flex;gap:6px;align-items:center;margin-bottom:5px;font-size:.85rem;color:var(--text-secondary)}.dice-part{font-family:Courier New,monospace;background:var(--card-bg);padding:2px 8px;border-radius:4px;border:1px solid var(--border-color);font-weight:600}.modifier-part{font-weight:700;color:var(--accent-primary)}.roll-total{font-size:1rem;color:var(--text-primary);padding-top:5px;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.roll-total strong{color:var(--accent-primary);font-size:1.2rem;font-weight:800}@media(max-width:768px){.dice-roll-panel{width:calc(100% - 40px);right:20px;left:20px;bottom:10px}}.confirm-dialog-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirm-dialog{background:var(--card-bg);border:2px solid var(--border-color-medium);border-radius:12px;padding:30px;max-width:450px;width:90%;box-shadow:0 12px 40px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.confirm-dialog-title{margin:0 0 15px;color:var(--accent-primary);font-size:1.4rem;font-weight:700}.confirm-dialog-message{margin:0 0 25px;color:var(--text-primary);font-size:1rem;line-height:1.6}.confirm-dialog-actions{display:flex;gap:12px;justify-content:flex-end}.btn-cancel,.btn-confirm,.btn-confirm-danger{padding:10px 20px;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 6px var(--shadow-color)}.btn-cancel{background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border-color-medium)}.btn-cancel:hover{background:var(--bg-tertiary);border-color:var(--accent-primary)}.btn-confirm{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:var(--button-text)}.btn-confirm:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-color-medium)}.btn-confirm-danger{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff}.btn-confirm-danger:hover{transform:translateY(-2px);box-shadow:0 4px 12px #dc354566}.character-list{max-width:1600px;margin:0 auto;padding:20px;min-height:100vh;background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);width:95%;box-sizing:border-box}@media(min-width:1240px){.character-list{padding:40px}}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:35px;padding:25px 30px;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);border-radius:12px;box-shadow:0 4px 6px var(--shadow-color),0 1px 3px var(--shadow-color);border:1px solid var(--border-color)}.list-header h1{margin:0;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:2.2rem;font-weight:700;letter-spacing:-.5px}.btn-create-new{padding:14px 28px;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-hover) 100%);color:var(--button-text);border:none;border-radius:10px;font-weight:700;cursor:pointer;font-size:1rem;transition:all .3s ease;box-shadow:0 2px 4px var(--shadow-color);letter-spacing:.3px}.btn-create-new:hover{transform:translateY(-2px);box-shadow:0 4px 8px var(--shadow-color-medium)}.btn-create-new:active{transform:translateY(0)}.empty-state{text-align:center;padding:80px 20px;background:var(--card-bg);border-radius:12px;box-shadow:0 4px 6px var(--shadow-color),0 1px 3px var(--shadow-color);border:1px solid var(--border-color)}.empty-state p{font-size:1.3rem;color:var(--text-secondary);margin-bottom:25px;font-weight:500}.btn-primary{padding:14px 32px;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-hover) 100%);color:var(--button-text);border:none;border-radius:10px;font-weight:700;cursor:pointer;font-size:1.1rem;transition:all .3s ease;box-shadow:0 2px 4px var(--shadow-color)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 8px var(--shadow-color-medium)}.characters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:25px}.character-card{background:var(--card-bg);border-radius:12px;padding:25px;box-shadow:0 2px 4px var(--shadow-color);transition:all .3s ease;display:flex;flex-direction:column;border:1px solid var(--border-color);position:relative;overflow:hidden}.character-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);transform:scaleX(0);transition:transform .3s ease}.character-card:hover:before{transform:scaleX(1)}.character-card:hover{transform:translateY(-8px);box-shadow:0 8px 16px var(--shadow-color-medium)}.character-card-header{display:flex;align-items:center;gap:15px;margin-bottom:18px;padding-bottom:15px;border-bottom:2px solid var(--bg-tertiary)}.character-list-avatar{width:60px;height:60px;border-radius:50%;border:3px solid var(--accent-primary);object-fit:cover;flex-shrink:0;box-shadow:0 2px 8px #00000026}.character-card-header h2{margin:0;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:1.6rem;font-weight:700;letter-spacing:-.3px;flex:1}.btn-delete{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff;border:none;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 2px 4px #dc35454d}.btn-delete:hover{transform:scale(1.15) rotate(90deg);box-shadow:0 4px 8px #dc354566}.character-info{flex:1;margin-bottom:18px}.character-class-race{font-size:1.15rem;color:var(--text-secondary);margin-bottom:18px;font-weight:500}.character-stats{display:flex;gap:12px;margin-bottom:18px}.stat{display:flex;flex-direction:column;align-items:center;padding:14px;background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-primary) 100%);border-radius:10px;flex:1;border:2px solid transparent;transition:all .3s ease}.stat:hover{border-color:var(--accent-primary);transform:translateY(-3px);box-shadow:0 4px 8px var(--shadow-color)}.stat-label{font-size:.8rem;color:var(--accent-primary);font-weight:700;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:1.8rem;font-weight:800;color:var(--text-primary);line-height:1}.btn-view-sheet{width:100%;padding:14px;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-hover) 100%);color:var(--button-text);border:none;border-radius:10px;font-weight:700;cursor:pointer;transition:all .3s ease;font-size:1rem;box-shadow:0 2px 4px var(--shadow-color);letter-spacing:.3px}.btn-view-sheet:hover{transform:translateY(-2px);box-shadow:0 4px 8px var(--shadow-color-medium)}.btn-view-sheet:active{transform:translateY(0)}@media(max-width:768px){.list-header{flex-direction:column;gap:18px;text-align:center}.list-header h1{font-size:1.8rem}.characters-grid{grid-template-columns:1fr}}.homebrew-browser{max-width:1400px;margin:0 auto;padding:2rem;background:var(--bg-primary)}.homebrew-header{text-align:center;margin-bottom:2rem;padding:2rem;background:linear-gradient(135deg,#3498db1a,#9b59b61a);border-radius:12px;border:1px solid var(--border-color)}.homebrew-header h2{margin:0 0 .5rem;color:var(--text-primary);font-size:2rem;font-weight:700}.homebrew-header p{margin:0;color:var(--text-secondary);font-size:1.1rem}.homebrew-loading{text-align:center;padding:3rem;color:var(--text-secondary);font-size:1.1rem}.homebrew-controls{margin-bottom:2rem;display:flex;flex-direction:column;gap:1rem}.homebrew-search{width:100%;padding:.875rem 1rem;border:2px solid var(--border-color);border-radius:8px;background:var(--card-background);color:var(--text-primary);font-size:1rem;transition:border-color .2s}.homebrew-search:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3498db1a}.homebrew-filters{display:flex;flex-wrap:wrap;gap:.5rem}.filter-btn{padding:.5rem 1rem;background:var(--card-background);border:2px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s}.filter-btn:hover{border-color:var(--primary-color);background:#3498db1a}.filter-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.homebrew-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.homebrew-card{background:var(--card-background);border:2px solid var(--border-color);border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .3s;display:flex;flex-direction:column;gap:1rem}.homebrew-card:hover{border-color:var(--primary-color);transform:translateY(-4px);box-shadow:0 8px 16px #00000026}.homebrew-card.expanded{border-color:var(--primary-color);box-shadow:0 4px 12px #0000001a}.homebrew-card-header{display:flex;flex-direction:column;gap:.5rem}.homebrew-title-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.homebrew-card h3{margin:0;color:var(--text-primary);font-size:1.3rem;font-weight:700;flex:1}.homebrew-type-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;flex-shrink:0}.homebrew-type-badge.spell{background:#9b59b633;color:#9b59b6}.homebrew-type-badge.race{background:#3498db33;color:#3498db}.homebrew-type-badge.class{background:#e74c3c33;color:#e74c3c}.homebrew-type-badge.background{background:#2ecc7133;color:#2ecc71}.homebrew-type-badge.item{background:#f1c40f33;color:#f1c40f}.homebrew-type-badge.feat{background:#e67e2233;color:#e67e22}.homebrew-meta{display:flex;align-items:center;gap:1rem;font-size:.85rem;color:var(--text-muted)}.homebrew-date{display:flex;align-items:center;gap:.25rem}.homebrew-description{color:var(--text-secondary);line-height:1.6}.description-preview{font-size:.95rem}.description-full{font-size:.95rem;white-space:pre-wrap;max-height:400px;overflow-y:auto;padding:1rem;background:var(--input-background);border-radius:6px}.homebrew-details{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:var(--input-background);border-radius:6px;max-height:300px;overflow-y:auto}.homebrew-property{font-size:.9rem;color:var(--text-secondary);line-height:1.5}.homebrew-property strong{color:var(--text-primary);text-transform:capitalize}.homebrew-card-footer{display:flex;justify-content:flex-end;padding-top:.5rem;border-top:1px solid var(--border-color)}.btn-view-details{padding:.5rem 1rem;background:var(--primary-color);color:#fff;border:none;border-radius:6px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s}.btn-view-details:hover{background:var(--primary-hover);transform:translateY(-1px)}.homebrew-empty{text-align:center;padding:4rem 2rem;background:var(--card-background);border:2px dashed var(--border-color);border-radius:12px;color:var(--text-secondary)}.homebrew-empty p{font-size:1.1rem;margin:0}@media(max-width:768px){.homebrew-browser{padding:1rem}.homebrew-header{padding:1.5rem 1rem}.homebrew-header h2{font-size:1.5rem}.homebrew-grid{grid-template-columns:1fr}.homebrew-filters{justify-content:center}}.homepage{max-width:1100px;margin:0 auto;padding:60px 30px 40px;animation:fadeIn .4s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.homepage-hero{text-align:center;margin-bottom:48px}.homepage-title{font-size:2.5rem;margin:0 0 12px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:800;letter-spacing:-.5px}.homepage-subtitle{font-size:1.1rem;color:var(--text-secondary);margin:0;font-weight:400}.homepage-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:48px}.action-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:32px 24px;text-align:center;cursor:pointer;transition:all .25s ease;position:relative;overflow:hidden}.action-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));transform:scaleX(0);transition:transform .25s ease}.action-card:hover:before{transform:scaleX(1)}.action-card:hover{transform:translateY(-4px);border-color:var(--accent-primary);box-shadow:0 8px 20px #00000026}.action-icon{font-size:3rem;margin-bottom:16px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.action-card h2{margin:0 0 10px;color:var(--text-primary);font-size:1.5rem;font-weight:700}.action-card p{color:var(--text-secondary);margin:0 0 20px;font-size:.95rem;line-height:1.5}.action-button{padding:10px 28px;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.3px}.action-button.primary{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff}.action-button.primary:hover{transform:scale(1.05);box-shadow:0 4px 12px #3b82f666}.action-button.secondary{background:#ef44441a;color:#ef4444;border:2px solid #ef4444}.action-button.secondary:hover{background:#ef444433;transform:scale(1.05)}.action-button.tertiary{background:#10b9811a;color:#10b981;border:2px solid #10b981}.action-button.tertiary:hover{background:#10b98133;transform:scale(1.05)}.homepage-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:48px}.stat-item{display:flex;align-items:center;gap:14px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:10px;padding:18px 16px;transition:all .2s ease}.stat-item:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.stat-icon{font-size:2rem;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.stat-content{flex:1}.stat-value{font-size:1.75rem;font-weight:800;color:var(--accent-primary);line-height:1;margin-bottom:4px}.stat-label{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;font-weight:500}.homepage-features{background:var(--card-bg);border:1px solid var(--border-color);border-radius:10px;padding:32px 28px;margin-bottom:32px}.homepage-features h3{text-align:center;margin:0 0 24px;color:var(--text-primary);font-size:1.5rem;font-weight:700}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}.feature-item{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;transition:all .2s ease}.feature-item:hover{border-color:var(--accent-primary);transform:translate(3px)}.feature-icon{font-size:1.3rem;flex-shrink:0}.feature-text{font-weight:500;color:var(--text-primary);font-size:.9rem}@media(max-width:768px){.homepage{padding:40px 16px 24px}.homepage-title{font-size:2rem}.homepage-subtitle{font-size:1rem}.homepage-actions{grid-template-columns:1fr;gap:16px}.action-card{padding:28px 20px}.action-icon{font-size:2.5rem}.action-card h2{font-size:1.4rem}.homepage-stats,.features-grid{grid-template-columns:1fr}.homepage-features{padding:24px 20px}}[data-theme=dark] .action-card{box-shadow:0 2px 8px #0000004d}[data-theme=dark] .action-card:hover{box-shadow:0 8px 20px #00000080}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-gradient-start),var(--bg-gradient-end));padding:20px}.error-boundary-content{background:var(--card-bg);border:2px solid var(--accent-primary);border-radius:12px;padding:40px;max-width:600px;width:100%;box-shadow:0 8px 24px var(--shadow-color-medium);text-align:center}.error-boundary-content h1{color:var(--accent-primary);margin:0 0 20px;font-size:2rem}.error-message{color:var(--text-primary);font-size:1.1rem;margin-bottom:30px;line-height:1.6}.error-details{text-align:left;margin:20px 0;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;padding:15px}.error-details summary{cursor:pointer;font-weight:600;color:var(--accent-primary);padding:10px;-webkit-user-select:none;user-select:none}.error-details summary:hover{background:var(--bg-secondary);border-radius:4px}.error-stack{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;padding:15px;overflow-x:auto;font-size:.85rem;color:var(--text-primary);margin:10px 0 0;max-height:300px;overflow-y:auto}.error-actions{display:flex;gap:15px;justify-content:center;margin-top:30px}.btn-reset,.btn-reload{padding:12px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px var(--shadow-color)}.btn-reset{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:var(--button-text)}.btn-reset:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-color-medium)}.btn-reload{background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border-color-medium)}.btn-reload:hover{background:var(--bg-tertiary);border-color:var(--accent-primary)}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a1a,#2d2d2d);padding:20px}.auth-card{background:var(--card-bg);border:2px solid var(--border-color-medium);border-radius:12px;padding:40px;max-width:450px;width:100%;box-shadow:0 8px 32px #00000080}.auth-header{text-align:center;margin-bottom:32px}.auth-title{font-size:2rem;font-weight:800;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 8px}.auth-subtitle{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.auth-form{display:flex;flex-direction:column;gap:20px}.auth-error{background:#ef44441a;border:2px solid #ef4444;border-radius:8px;padding:12px 16px;color:#ef4444;font-size:.9rem;font-weight:600;text-align:center}.form-label{font-size:.9rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.form-input{padding:12px 16px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:1rem;transition:all .3s ease}.form-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #8b00001a}.form-input:disabled{opacity:.6;cursor:not-allowed}.form-hint{font-size:.8rem;color:var(--text-secondary);margin:0;font-style:italic}.btn-auth{padding:14px 24px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border:none;border-radius:8px;color:#fff;font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #8b00004d;margin-top:8px}.btn-auth:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #8b000080}.btn-auth:active:not(:disabled){transform:translateY(0)}.btn-auth:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-footer{margin-top:24px;text-align:center;padding-top:24px;border-top:1px solid var(--border-color)}.auth-toggle{color:var(--text-secondary);font-size:.95rem;margin:0}.btn-toggle{background:none;border:none;color:var(--accent-primary);font-weight:700;cursor:pointer;font-size:.95rem;text-decoration:underline;padding:0;transition:color .2s ease}.btn-toggle:hover:not(:disabled){color:var(--accent-secondary)}.btn-toggle:disabled{opacity:.6;cursor:not-allowed}.user-menu{position:relative;display:flex;align-items:center;gap:12px}.user-info{display:flex;align-items:center;gap:10px;padding:8px 16px;background:var(--card-bg);border:2px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s ease}.user-info:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));display:flex;align-items:center;justify-content:center;font-weight:900;color:#fff;font-size:1.1rem}.btn-logout{padding:8px 16px;background:#ef44441a;border:2px solid #ef4444;border-radius:8px;color:#ef4444;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s ease}@media(max-width:768px){.auth-card{padding:24px}.auth-title{font-size:1.5rem}.auth-subtitle{font-size:1.25rem}}.homebrew-manager{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:1000px;max-height:90vh;background:var(--card-bg);border:2px solid var(--border-color-medium);border-radius:12px;box-shadow:0 8px 32px #0000004d;z-index:2000;display:flex;flex-direction:column}.homebrew-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:2px solid var(--border-color)}.homebrew-header h2{margin:0;color:var(--text-primary);font-size:1.5rem}.btn-close-homebrew{background:#ef44441a;border:2px solid #ef4444;color:#ef4444;width:36px;height:36px;border-radius:50%;font-size:1.2rem;cursor:pointer;transition:all .2s}.btn-close-homebrew:hover{background:#ef444433;transform:scale(1.1)}.homebrew-tabs{display:flex;gap:8px;padding:0 20px;border-bottom:2px solid var(--border-color)}.homebrew-tab{padding:12px 24px;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--text-secondary);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.homebrew-tab:hover{color:var(--text-primary);background:var(--bg-tertiary)}.homebrew-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary);background:var(--bg-tertiary)}.homebrew-content{flex:1;overflow-y:auto;padding:20px}.homebrew-loading{text-align:center;padding:40px;color:var(--text-secondary)}.homebrew-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.btn-create-homebrew{padding:10px 20px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;border:none;border-radius:8px;font-weight:700;cursor:pointer;transition:all .2s}.btn-create-homebrew:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.homebrew-count{color:var(--text-secondary);font-size:.9rem}.homebrew-empty{text-align:center;padding:60px 20px;color:var(--text-secondary)}.homebrew-empty p:first-child{font-size:1.1rem;font-weight:600;margin-bottom:8px}.homebrew-list{display:grid;gap:16px}.homebrew-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:16px;transition:all .2s}.homebrew-card:hover{border-color:var(--accent-primary);box-shadow:0 2px 8px #0003}.homebrew-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.homebrew-card-header h3{margin:0;color:var(--text-primary);font-size:1.1rem}.homebrew-card-actions{display:flex;gap:8px}.btn-edit,.btn-delete,.btn-share{background:transparent;border:none;font-size:1.2rem;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s}.btn-share:hover{background:#3498db33}.btn-share.active{background:#2ecc7133}.btn-share.active:hover{background:#2ecc714d}.btn-edit:hover{background:#3b82f633}.btn-delete:hover{background:#ef444433}.homebrew-card-body{color:var(--text-secondary)}.homebrew-meta{display:flex;gap:12px;margin-bottom:8px;flex-wrap:wrap}.homebrew-meta span{padding:4px 12px;background:var(--bg-tertiary);border-radius:12px;font-size:.85rem;font-weight:600}.spell-level{background:#9333ea33;color:#a855f7}.spell-school{background:#3b82f633;color:#3b82f6}.item-type{background:#f59e0b33;color:#f59e0b}.item-rarity{background:#10b98133;color:#10b981}.feature-source{background:#ef444433;color:#ef4444}.item-description{margin:8px 0 0;line-height:1.6}.homebrew-form{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:24px}.homebrew-form h3{margin:0 0 20px;color:var(--text-primary)}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;color:var(--text-primary);font-weight:600;font-size:.9rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.95rem;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #3b82f61a}.form-group textarea{resize:vertical;min-height:100px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.homebrew-form-actions{display:flex;gap:12px;margin-top:24px;justify-content:flex-end}.btn-save{padding:10px 24px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;border:none;border-radius:8px;font-weight:700;cursor:pointer;transition:all .2s}.btn-save:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.btn-cancel{padding:10px 24px;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:var(--bg-secondary);border-color:var(--border-color-medium)}@media(max-width:768px){.homebrew-manager{width:95%;max-height:95vh}.form-row{grid-template-columns:1fr}.homebrew-tabs{overflow-x:auto}.homebrew-tab{padding:10px 16px;font-size:.9rem;white-space:nowrap}}.bug-report-modal{max-width:600px;max-height:90vh;overflow-y:auto}.bug-report-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;color:var(--text-primary);font-size:.9rem}.required{color:var(--accent-primary)}.form-group input,.form-group textarea,.form-group select{padding:10px 12px;border:2px solid var(--border-color);border-radius:6px;background:var(--input-bg);color:var(--text-primary);font-size:.95rem;font-family:inherit;transition:border-color .2s ease}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #dc26261a}.form-group textarea{resize:vertical;min-height:80px}.bug-report-info{background:#60a5fa1a;border-left:4px solid #60a5fa;padding:12px 16px;border-radius:4px;margin:10px 0}.bug-report-info p{margin:0;color:var(--text-primary);font-size:.9rem;line-height:1.5}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:10px}.btn-cancel,.btn-submit{padding:10px 20px;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease;border:2px solid transparent;font-size:.95rem}.btn-cancel{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-color)}.btn-cancel:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--accent-primary)}.btn-submit{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.btn-submit:hover:not(:disabled){background:#b91c1c;transform:translateY(-1px);box-shadow:0 4px 8px #dc26264d}.btn-cancel:disabled,.btn-submit:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.bug-report-modal{max-width:95%;margin:20px}.modal-actions{flex-direction:column}.btn-cancel,.btn-submit{width:100%}}.subscription-manager-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;animation:fadeIn .2s ease}.subscription-manager{background:var(--card-bg);border-radius:12px;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.subscription-header{display:flex;justify-content:space-between;align-items:center;padding:24px 30px;border-bottom:1px solid var(--border-color)}.subscription-header h2{margin:0;color:var(--text-primary);font-size:1.8rem}.btn-close{background:none;border:none;font-size:2rem;color:var(--text-secondary);cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.btn-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.current-plan{text-align:center;padding:20px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.plan-badge{display:inline-block;padding:6px 16px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;border-radius:20px;font-weight:700;font-size:.9rem;margin-bottom:8px}.current-plan p{margin:0;color:var(--text-secondary);font-size:.9rem}.pricing-tiers{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;padding:30px}.pricing-card{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;padding:30px;position:relative;transition:all .3s ease}.pricing-card.active{border-color:var(--accent-primary);box-shadow:0 4px 20px #2563eb33}.pricing-card.premium{background:linear-gradient(135deg,#2563eb0d,#3b82f60d)}.popular-badge{position:absolute;top:-12px;right:20px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:700;letter-spacing:.5px}.plan-name{font-size:1.5rem;font-weight:800;color:var(--text-primary);margin-bottom:16px}.plan-price{margin-bottom:24px}.price{font-size:2.5rem;font-weight:900;color:var(--accent-primary)}.period{font-size:1rem;color:var(--text-secondary);margin-left:4px}.plan-features{margin-bottom:24px}.feature{padding:10px 0;color:var(--text-primary);font-size:.95rem;border-bottom:1px solid var(--border-color)}.feature:last-child{border-bottom:none}.current-plan-badge{text-align:center;padding:12px;background:var(--bg-tertiary);color:var(--text-secondary);border-radius:6px;font-weight:600;font-size:.9rem}.btn-upgrade,.btn-manage{width:100%;padding:14px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px}.btn-upgrade{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff}.btn-upgrade:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #2563eb66}.btn-manage{background:rgba(var(--accent-primary),.1);color:var(--accent-primary);border:2px solid var(--accent-primary)}.btn-manage:hover:not(:disabled){background:#2563eb33;transform:translateY(-2px)}.btn-upgrade:disabled,.btn-manage:disabled{opacity:.6;cursor:not-allowed;transform:none}.subscription-footer{text-align:center;padding:20px 30px 30px;color:var(--text-secondary);font-size:.85rem}.subscription-footer p{margin:5px 0}.subscription-footer p:first-child{font-weight:600;color:var(--text-primary)}.loading{text-align:center;padding:40px;color:var(--text-secondary);font-size:1rem}@media(max-width:768px){.pricing-tiers{grid-template-columns:1fr;padding:20px}.subscription-header{padding:20px}.subscription-header h2{font-size:1.4rem}.plan-price .price{font-size:2rem}}:root{--bg-primary: #f5f7fa;--bg-secondary: #ffffff;--bg-tertiary: #f8f9fa;--bg-gradient-start: #f5f7fa;--bg-gradient-end: #e8ecf1;--text-primary: #2c3e50;--text-secondary: #6c757d;--text-tertiary: #888;--border-color: rgba(0,0,0,.05);--border-color-medium: #ddd;--shadow-color: rgba(0,0,0,.08);--shadow-color-medium: rgba(0,0,0,.15);--accent-primary: #dc2626;--accent-secondary: #ef4444;--accent-hover: #b91c1c;--card-bg: #ffffff;--input-bg: #ffffff;--button-text: #ffffff}[data-theme=dark]{--bg-primary: #1a1d23;--bg-secondary: #252930;--bg-tertiary: #2d3139;--bg-gradient-start: #1a1d23;--bg-gradient-end: #252930;--text-primary: #e8eaed;--text-secondary: #b0b3b8;--text-tertiary: #8a8d93;--border-color: rgba(255,255,255,.1);--border-color-medium: #3a3f47;--shadow-color: rgba(0,0,0,.3);--shadow-color-medium: rgba(0,0,0,.5);--accent-primary: #ef4444;--accent-secondary: #f87171;--accent-hover: #dc2626;--card-bg: #252930;--input-bg: #2d3139;--button-text: #ffffff}.app{min-height:100vh;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;width:100%;padding:80px 0 0;background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);color:var(--text-primary);transition:background .3s ease,color .3s ease}.app-header{position:fixed;top:0;left:0;right:0;min-height:45px;background:var(--card-bg);border-bottom:2px solid var(--border-color-medium);box-shadow:0 2px 8px var(--shadow-color);display:flex;align-items:center;justify-content:space-between;padding:6px 16px;z-index:1000;gap:8px}@media(max-width:1024px){.app-header{flex-wrap:wrap;min-height:auto}}.header-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.header-right{display:flex;flex-direction:row;align-items:center;gap:10px;flex-wrap:nowrap;flex-shrink:0;min-width:0}@media(max-width:1200px){.header-right{gap:6px}}@media(max-width:768px){.header-right{gap:8px}}.btn-home{padding:10px 20px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:var(--button-text);border:none;border-radius:8px;font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px var(--shadow-color);display:flex;align-items:center;gap:8px}.btn-home:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-color-medium)}.btn-home:active{transform:translateY(0)}@media(max-width:1200px){.btn-home{padding:8px 14px;font-size:.9rem}}.theme-toggle{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border:none;border-radius:6px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.1rem;transition:all .3s ease;box-shadow:0 2px 8px var(--shadow-color-medium);color:var(--button-text);flex-shrink:0}.theme-toggle:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.theme-toggle:active{transform:translateY(0)}.btn-bug-report{padding:8px 16px;background:#fb923c1a;border:2px solid #f97316;border-radius:8px;color:#f97316;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px var(--shadow-color);white-space:nowrap;flex-shrink:0}.btn-bug-report:hover{background:#fb923c33;transform:translateY(-2px);box-shadow:0 4px 12px #f973164d}@media(max-width:1200px){.btn-bug-report{padding:6px 12px;font-size:.85rem}}.btn-homebrew{padding:8px 16px;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;color:#fff;font-weight:700;font-size:.9rem;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px var(--shadow-color-medium);flex-shrink:0;align-self:center;white-space:nowrap}.btn-homebrew:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.btn-homebrew:active{transform:translateY(0)}@media(max-width:1200px){.btn-homebrew{padding:6px 12px;font-size:.85rem}.theme-toggle{width:36px;height:36px;font-size:1rem}}.app>*:not(.theme-toggle){width:100%;margin:0 auto;padding:0 20px;box-sizing:border-box}header{text-align:center;margin-bottom:30px;padding:20px}h1{color:var(--accent-primary);margin-bottom:20px}.search-bar{width:100%;max-width:500px;padding:12px 20px;font-size:16px;border:2px solid var(--border-color-medium);border-radius:8px;margin:0 auto 10px;display:block;background:var(--input-bg);color:var(--text-primary);transition:border-color .3s ease}.search-bar:focus{outline:none;border-color:var(--accent-primary)}.spell-count{color:var(--text-secondary);font-size:14px}.content{display:grid;grid-template-columns:1fr 1fr;gap:20px;padding:0 20px;max-width:1400px;margin:0 auto;width:100%}@media(max-width:968px){.content{grid-template-columns:1fr}}.spell-list{display:flex;flex-direction:column;gap:10px;max-height:80vh;overflow-y:auto}.spell-card{padding:15px;border:1px solid var(--border-color-medium);border-radius:8px;cursor:pointer;transition:all .2s;background:var(--card-bg)}.spell-card:hover{border-color:var(--accent-primary);box-shadow:0 2px 8px var(--shadow-color);transform:translateY(-2px)}.spell-card h3{margin:0 0 8px;color:var(--accent-primary)}.spell-meta{color:var(--text-secondary);font-size:14px;margin:5px 0}.spell-classes{color:var(--text-tertiary);font-size:12px;font-style:italic}.spell-detail{padding:20px;border:2px solid var(--accent-primary);border-radius:8px;max-height:80vh;overflow-y:auto;position:sticky;top:20px;background:var(--card-bg)}.spell-detail button{background:var(--accent-primary);color:var(--button-text);border:none;padding:8px 16px;border-radius:4px;cursor:pointer;margin-bottom:15px;transition:background .3s ease}.spell-detail button:hover{background:var(--accent-hover)}.spell-detail h2{color:var(--accent-primary);margin-top:0}.spell-detail hr{border:none;border-top:1px solid var(--border-color-medium);margin:15px 0}.app.loading{display:flex;align-items:center;justify-content:center;min-height:100vh}.create-header{max-width:1200px;margin:0 auto;padding:20px;display:flex;align-items:center;gap:20px;justify-content:center}@media(max-width:768px){.create-header{flex-direction:column;text-align:center}}.btn-back{padding:12px 24px;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-hover) 100%);color:var(--button-text);border:none;border-radius:10px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px var(--shadow-color)}.btn-back:hover{transform:translateY(-2px);box-shadow:0 4px 8px var(--shadow-color-medium)}.create-header h1{margin:0;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:2rem;font-weight:700}.btn-upgrade-premium{padding:8px 20px;background:linear-gradient(135deg,#fbbf24,#f59e0b);border:none;border-radius:8px;color:#000;font-size:.9rem;font-weight:900;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #fbbf2466;white-space:nowrap;flex-shrink:0;margin-right:12px;text-shadow:0 1px 2px rgba(255,255,255,.3)}.btn-upgrade-premium:hover{transform:translateY(-2px);box-shadow:0 6px 16px #fbbf2499;background:linear-gradient(135deg,#fcd34d,#fbbf24)}.btn-upgrade-premium:active{transform:translateY(0);box-shadow:0 2px 8px #fbbf2466}.user-menu{display:flex;align-items:center;gap:12px;flex-wrap:nowrap;flex-shrink:0}.user-info{display:flex;align-items:center;gap:10px;padding:8px 16px;background:var(--card-bg);border:2px solid var(--border-color-medium);border-radius:8px;cursor:default;box-shadow:0 2px 8px var(--shadow-color);flex-shrink:0}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));display:flex;align-items:center;justify-content:center;font-weight:900;color:#fff;font-size:1.1rem;flex-shrink:0}.user-name{font-weight:700;color:var(--text-primary);font-size:.95rem}.btn-logout{padding:8px 16px;background:#ef44441a;border:2px solid #ef4444;border-radius:8px;color:#ef4444;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px var(--shadow-color);white-space:nowrap;flex-shrink:0}.btn-logout:hover{background:#ef444433;transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}@media(max-width:768px){.app-header{height:70px;padding:10px}.btn-home{font-size:.9rem;padding:8px 12px}.header-right{gap:8px}.user-name{display:none}.theme-toggle{width:36px;height:36px;font-size:1rem}.user-info{padding:6px 12px}.btn-logout,.btn-bug-report{padding:6px 12px;font-size:.85rem}}.btn-login,.btn-signup{padding:8px 20px;border-radius:8px;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0;display:inline-block;width:auto}.btn-login{background:transparent;border:2px solid var(--accent-primary);color:var(--accent-primary)}.btn-login:hover{background:#2563eb1a;transform:translateY(-2px)}.btn-signup{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border:none;color:#fff;box-shadow:0 2px 8px var(--shadow-color)}.btn-signup:hover{transform:translateY(-2px);box-shadow:0 4px 12px #2563eb66}@media(max-width:768px){.btn-login,.btn-signup{padding:6px 16px;font-size:.85rem}}
