*{margin:0;padding:0;box-sizing:border-box}:root{--color-primary: #f0a500;--color-primary-hover: #d49200;--color-primary-glow: rgba(240, 165, 0, .4);--color-danger: #c41e3a;--color-danger-light: #ff6b6b;--color-danger-glow: rgba(196, 30, 58, .4);--color-success: #4caf50;--color-success-glow: rgba(76, 175, 80, .5);--color-info: #64b5f6;--color-info-glow: rgba(100, 181, 246, .4);--color-warning: #ffc107;--color-warning-glow: rgba(255, 193, 7, .4);--color-crit: #ffd700;--color-crit-glow: rgba(255, 215, 0, .5);--bg-darkest: #0d0d0d;--bg-dark: #1a1a1a;--bg-card: #1e1e1e;--bg-input: #252525;--bg-elevated: #2a2a2a;--border-color: #333;--border-subtle: #2a2a2a;--text-primary: #e0e0e0;--text-secondary: #888;--text-muted: #666}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:var(--bg-darkest);color:var(--text-primary);padding:20px;display:flex;justify-content:center;align-items:center;min-height:100vh}#app{width:100%;max-width:1600px;padding:20px}header{display:flex;justify-content:space-between;align-items:center;padding:20px;background:var(--bg-elevated);border-radius:8px;margin-bottom:20px;border:1px solid var(--border-color)}.header-left{display:flex;flex-direction:column;gap:2px}.player-identity{font-size:.75rem;color:var(--text-muted, #888);padding-left:2px;letter-spacing:.5px}h1{color:var(--color-primary);font-size:1.5rem;text-shadow:0 0 20px var(--color-primary-glow)}h1 .fa-dice-d20{font-size:1.1em;margin-right:8px;filter:drop-shadow(0 0 8px var(--color-primary-glow))}.header-right{display:flex;align-items:center;gap:15px}#connection-status{padding:8px 16px;border-radius:4px;background:var(--bg-input);font-weight:700;font-size:.9rem;border:1px solid var(--border-color)}section{background:var(--bg-dark);padding:30px;border-radius:8px;margin-bottom:20px;border:1px solid var(--border-color)}h2{color:var(--color-primary);margin-bottom:20px;text-align:center}input,button{padding:12px;margin:10px 0;border-radius:4px;border:none;font-size:16px;width:100%}input{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-color)}input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 8px var(--color-primary-glow)}button{background:var(--color-primary);color:var(--bg-darkest);font-weight:700;cursor:pointer;transition:all .3s ease}button:hover{background:var(--color-primary-hover);box-shadow:0 0 15px var(--color-primary-glow)}.roll-toast{position:fixed;top:20px;right:20px;z-index:1000;min-width:280px;max-width:350px;background:var(--bg-elevated);border:2px solid var(--color-primary);border-radius:12px;padding:0;box-shadow:0 8px 32px #00000080,0 0 20px var(--color-primary-glow);transform:translate(400px);opacity:0;transition:transform .3s ease,opacity .3s ease;pointer-events:none}.roll-toast.show{transform:translate(0);opacity:1;pointer-events:auto}.roll-toast-content{padding:16px 20px;text-align:center}.roll-toast-header{font-size:.9rem;color:var(--color-primary);font-weight:700;margin-bottom:8px}.roll-toast-body{display:flex;align-items:center;justify-content:center;gap:8px;font-size:1.4rem}.roll-toast-dice{display:flex;align-items:center;gap:6px}.roll-toast-dice .fa-dice-d20{font-size:28px;color:var(--color-primary)}.roll-toast-dice .roll-value{font-size:1.6rem;font-weight:700;color:var(--text-primary)}.roll-toast-modifier{color:var(--text-secondary)}.roll-toast-total{font-size:2rem;font-weight:700;color:var(--color-primary)}.roll-toast.nat-20{border-color:var(--color-crit);background:linear-gradient(135deg,#2a2a1a,var(--bg-elevated));box-shadow:0 8px 32px #00000080,0 0 30px var(--color-crit-glow)}.roll-toast.nat-20 .fa-dice-d20,.roll-toast.nat-20 .roll-value{color:var(--color-crit)}.roll-toast.nat-20 .roll-toast-total{color:var(--color-crit);text-shadow:0 0 15px var(--color-crit-glow)}.roll-toast.nat-1{border-color:var(--color-danger);background:linear-gradient(135deg,#2a1a1a,var(--bg-elevated));box-shadow:0 8px 32px #00000080,0 0 20px var(--color-danger-glow)}.roll-toast.nat-1 .fa-dice-d20,.roll-toast.nat-1 .roll-value{color:var(--color-danger)}.roll-toast.nat-1 .roll-toast-total{color:var(--color-danger);text-shadow:0 0 10px var(--color-danger-glow)}.roll-toast-close{position:absolute;top:8px;right:10px;background:none;border:none;color:var(--text-muted);font-size:16px;cursor:pointer;padding:4px;line-height:1;width:auto;min-width:auto}.roll-toast-close:hover{color:var(--text-primary);background:none}.roll-toast.advantage{border-color:var(--color-success);box-shadow:0 8px 32px #00000080,0 0 20px var(--color-success-glow)}.roll-toast.disadvantage{border-color:var(--color-danger);box-shadow:0 8px 32px #00000080,0 0 20px var(--color-danger-glow)}.adv-disadv-roll{display:flex;flex-direction:column;align-items:center;gap:4px}.roll-mode-indicator{font-size:.75rem;font-weight:700;padding:2px 8px;border-radius:4px;display:flex;align-items:center;gap:4px}.roll-mode-indicator.advantage{background:var(--color-success);color:var(--bg-dark)}.roll-mode-indicator.disadvantage{background:var(--color-danger);color:#fff}.roll-pair{display:flex;align-items:center;gap:6px}.roll-pair .roll-value{font-size:1.8rem;font-weight:700}.roll-pair .roll-value.used{color:var(--color-primary)}.roll-pair .roll-value.dropped{color:var(--text-muted);font-size:1.4rem;text-decoration:line-through;opacity:.6}.roll-separator{color:var(--text-muted);font-size:1.2rem}.sheet-layout{display:grid;grid-template-columns:1fr 1fr;gap:20px}.left-column,.right-column{display:flex;flex-direction:column;gap:20px}.card{background:var(--bg-card);padding:20px;border-radius:8px;border:1px solid var(--border-color)}.card h3{color:var(--color-primary);margin-bottom:15px;text-align:center;border-bottom:1px solid var(--border-color);padding-bottom:10px}.adv-disadv-card{background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-dark) 100%);border:2px solid var(--color-primary)}.roll-mode-toggle{display:flex;gap:8px;justify-content:center}.roll-mode-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;background:var(--bg-input);border:2px solid var(--border-light);border-radius:8px;color:var(--text-muted);cursor:pointer;transition:all .2s ease;font-size:.85rem}.roll-mode-btn i{font-size:1.4rem}.roll-mode-btn:hover{background:var(--border-color);color:var(--text-primary)}.roll-mode-btn[data-mode=normal].active{background:var(--color-primary);border-color:var(--color-primary);color:var(--bg-dark);box-shadow:var(--glow-primary)}.roll-mode-btn[data-mode=advantage].active{background:var(--color-success);border-color:var(--color-success);color:var(--bg-dark);box-shadow:0 0 15px var(--color-success-glow)}.roll-mode-btn[data-mode=disadvantage].active{background:var(--color-danger);border-color:var(--color-danger);color:#fff;box-shadow:0 0 15px #c41e3a80}.roll-mode-description{text-align:center;margin-top:12px;font-size:.9rem;color:var(--text-muted);font-style:italic}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:5px;font-weight:700;color:var(--color-primary)}.form-row{display:flex;gap:15px;flex-wrap:wrap}.form-row .form-group{flex:1;min-width:150px}.hp-bar-container{margin:15px 0;padding:10px;background:var(--bg-input);border-radius:8px;border:1px solid var(--border-light)}.hp-bar-container progress{width:100%;height:20px;border-radius:4px;overflow:hidden;background:var(--border-color);border:none}.hp-bar-container progress::-webkit-progress-bar{background:var(--border-color);border-radius:4px}.hp-bar-container progress::-webkit-progress-value{background:linear-gradient(90deg,var(--color-danger) 0%,var(--color-primary) 50%,#4caf50 100%);border-radius:4px;transition:width .3s ease}.hp-bar-container progress::-moz-progress-bar{background:linear-gradient(90deg,var(--color-danger) 0%,var(--color-primary) 50%,#4caf50 100%);border-radius:4px}.hp-bar-container input[type=range]{width:100%;margin:10px 0 5px;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:8px;background:var(--border-color);border-radius:4px;outline:none}.hp-bar-container input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--color-primary);cursor:pointer;box-shadow:0 0 5px var(--color-primary-glow)}.hp-bar-container input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:none;box-shadow:0 0 5px var(--color-primary-glow)}.hp-display{display:block;text-align:center;font-weight:700;color:var(--color-primary);font-size:1.1rem}.abilities-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px;margin-top:10px}.ability{display:flex;flex-direction:column;align-items:center}.ability input{width:60px;text-align:center}.modifier{width:50px;text-align:center;font-weight:700;color:var(--color-danger-light);margin-top:5px}.saves-grid,.skills-grid{display:grid;grid-template-columns:1fr;gap:10px;margin-top:10px}.save,.skill{display:flex;align-items:center;gap:10px;justify-content:space-between}.save input,.skill input{margin:0}.total{font-weight:700;color:var(--color-primary)}.saves-table,.skills-table,.abilities-table{width:100%;border-collapse:collapse;margin-top:10px}.saves-table th,.saves-table td,.skills-table th,.skills-table td,.abilities-table th,.abilities-table td{padding:8px;text-align:left;border:1px solid var(--border-light)}.saves-table th,.skills-table th,.abilities-table th{background:var(--bg-input);font-weight:700;color:var(--color-primary)}.saves-table td,.skills-table td,.abilities-table td{background:var(--border-color)}.abilities-table input[type=number]{min-width:60px;width:70px}.saves-table input[type=checkbox],.skills-table input[type=checkbox]{margin:0}.death-saves-section{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.death-saves-section h4{color:var(--color-primary);margin-bottom:1rem;font-size:1.1rem;display:flex;align-items:center;gap:.5rem}.death-saves-section h4 .fa-skull{color:var(--color-danger)}.death-saves-tracker{display:flex;flex-direction:column;gap:.75rem}.death-saves-row{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;background:var(--border-color);border-radius:6px}.death-saves-label{font-weight:600;font-size:.9rem;min-width:80px}.death-saves-row.successes .death-saves-label{color:#22c55e}.death-saves-row.failures .death-saves-label{color:var(--color-danger)}.death-saves-checkboxes{display:flex;gap:.75rem}.death-save-checkbox{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:28px;height:28px;border-radius:50%;border:3px solid var(--border-color);background:var(--bg-card);cursor:pointer;transition:all .2s ease;position:relative}.death-save-checkbox.success{border-color:#22c55e}.death-save-checkbox.failure{border-color:var(--color-danger)}.death-save-checkbox:hover{transform:scale(1.1);box-shadow:0 0 10px #f0a5004d}.death-save-checkbox.success:checked{background:#22c55e;border-color:#22c55e;box-shadow:0 0 12px #22c55e80}.death-save-checkbox.failure:checked{background:var(--color-danger);border-color:var(--color-danger);box-shadow:0 0 12px #c41e3a80}.death-save-checkbox:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:14px;font-weight:700}.death-saves-actions{display:flex;gap:.75rem;margin-top:.5rem;justify-content:center}.death-save-roll,.death-saves-actions .reset-btn{flex:0 0 auto;width:160px;padding:.6rem 1rem!important;font-size:.9rem!important;justify-content:center}.reset-btn{background:transparent;border:1px solid var(--text-muted);border-radius:4px;padding:.5rem 1rem;cursor:pointer;transition:all .2s ease;color:var(--text-muted);font-size:.85rem;display:flex;align-items:center;gap:.4rem}.reset-btn:hover{border-color:var(--color-danger);color:var(--color-danger);box-shadow:0 0 8px #c41e3a4d}.roll-btn{background:transparent;border:1px solid var(--color-primary);border-radius:4px;padding:4px 8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:auto;min-width:32px;color:var(--text-primary);margin:0;font-size:14px;font-weight:400}.roll-btn:hover{background:var(--color-primary);transform:scale(1.1);color:var(--bg-card);box-shadow:var(--glow-primary)}.roll-btn:hover .fa-dice-d20{color:var(--bg-card)}.roll-btn:active{transform:scale(.95)}.roll-btn:disabled{opacity:.5;cursor:not-allowed}.roll-btn .fa-dice-d20{font-size:16px;color:var(--color-primary);transition:color .2s ease}.attack-btn .fa-dice-d20,.death-save-roll .fa-dice-d20,.damage-btn .fa-burst{margin-right:.4em}.reset-btn .fa-rotate-left{margin-right:.3em}.fa-dice-d20.roll-icon-large{font-size:24px;color:var(--color-primary);margin-right:6px;vertical-align:middle}.equipment-section{width:100%;margin-top:20px}.equipment-section textarea{width:100%;background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-light);padding:10px;border-radius:4px;font-family:inherit;resize:vertical}.tabs{display:flex;margin-bottom:10px}.tab-button{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-light);padding:10px 20px;cursor:pointer;flex:1;transition:background .3s}.tab-button.active{background:var(--color-primary);color:var(--bg-card)}.tab-button:hover{background:var(--border-light)}.tab-content{background:var(--border-color);padding:20px;border-radius:8px;border:1px solid var(--border-light)}.tab-pane{display:none}.tab-pane.active{display:block}.combat-tabs{display:flex;margin-bottom:10px}.combat-tab-button{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-light);padding:8px 16px;cursor:pointer;flex:1;transition:background .3s}.combat-tab-button.active{background:var(--color-primary);color:var(--bg-card)}.combat-tab-button:hover{background:var(--border-light)}.combat-tab-content{background:var(--border-color);padding:15px;border-radius:8px;border:1px solid var(--border-light)}.combat-tab-pane{display:none}.combat-tab-pane.active{display:block}.spell-slots-table{width:100%;border-collapse:collapse;margin-top:10px}.spell-slots-table th,.spell-slots-table td{padding:8px;text-align:center;border:1px solid var(--border-light)}.spell-slots-table th{background:var(--bg-input);font-weight:700;color:var(--color-primary)}.spell-slots-table td{background:var(--border-color)}.spell-slots-table input{width:60px;text-align:center;background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-light);padding:4px}.weapons-list{margin-top:10px}.weapon-item{display:flex;gap:10px;margin-bottom:10px;align-items:center}.weapon-item input{flex:1;padding:8px;background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-light);border-radius:4px}.weapons-table{width:100%;border-collapse:collapse;margin-top:10px;table-layout:fixed}.weapons-table th,.weapons-table td{padding:8px;text-align:left;border:1px solid var(--border-light);vertical-align:middle}.weapons-table th{background:var(--bg-input);font-weight:700;color:var(--color-primary);font-size:.85rem}.weapons-table td{background:var(--border-color)}.weapons-table th:nth-child(1),.weapons-table td:nth-child(1){width:20%}.weapons-table th:nth-child(2),.weapons-table td:nth-child(2){width:10%}.weapons-table th:nth-child(3),.weapons-table td:nth-child(3){width:12%}.weapons-table th:nth-child(4),.weapons-table td:nth-child(4){width:15%}.weapons-table th:nth-child(5),.weapons-table td:nth-child(5){width:17%}.weapons-table th:nth-child(6),.weapons-table td:nth-child(6){width:30%}.weapon-bonus-input{width:100%!important;text-align:center;padding:6px!important}.weapon-bonus-input::-webkit-inner-spin-button,.weapon-bonus-input::-webkit-outer-spin-button{opacity:1;position:absolute;right:2px;height:100%}.weapon-bonus-input{position:relative}.weapons-table input[type=text]{width:100%;padding:6px;background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-light);border-radius:4px}.weapons-table select{padding:6px;background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-light);border-radius:4px;width:100%}.weapon-actions{text-align:center}.weapon-actions .roll-btn{display:inline-flex;margin:2px}.attack-btn,.damage-btn{font-size:.75rem;padding:6px 10px;white-space:nowrap;color:var(--text-primary);margin:0;font-weight:400}.attack-btn{border-color:var(--color-primary)}.attack-btn:hover{background:var(--color-primary);color:var(--bg-card);box-shadow:var(--glow-primary)}.damage-btn{border-color:var(--color-danger-light)}.damage-btn:hover{background:var(--color-danger-light);color:var(--bg-card)}.damage-btn .fa-burst{color:var(--color-danger-light);margin-right:4px}.damage-btn:hover .fa-burst{color:var(--bg-card)}.inline-roll-group{display:flex;align-items:center;gap:10px}.inline-roll-group .calc{min-width:40px}.inline-roll-group input{flex:1}.combat-roll-btn{flex-shrink:0}.spell-damage-section{margin-top:20px;padding-top:15px;border-top:1px solid var(--border-light)}.spell-damage-section h4{color:var(--color-primary);margin-bottom:10px}.spell-damage-action{display:flex;align-items:flex-end}.spell-damage-btn{padding:10px 16px;font-size:.9rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:2000;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.modal-overlay.show{opacity:1;visibility:visible}.modal-content{background:var(--border-color);border:2px solid var(--color-primary);border-radius:12px;padding:24px;min-width:380px;max-width:450px;position:relative;transform:scale(.9);transition:transform .3s ease;box-shadow:0 0 30px var(--color-primary-glow)}.modal-overlay.show .modal-content{transform:scale(1)}.modal-close{position:absolute;top:12px;right:16px;background:none;border:none;color:var(--text-muted);font-size:24px;cursor:pointer;padding:4px;line-height:1;width:auto;min-width:auto}.modal-close:hover{color:var(--text-primary);background:none}.modal-content h3{color:var(--color-primary);margin-bottom:20px;text-align:center;font-size:1.3rem}.damage-modal-body{display:flex;flex-direction:column;gap:16px}.damage-section{background:var(--bg-input);padding:12px;border-radius:8px}.damage-section label{display:block;color:var(--color-primary);font-size:.85rem;margin-bottom:8px;font-weight:700}.ability-mod-section{background:#f0a5001a;border:1px solid var(--color-primary)}.ability-mod-display{display:flex;align-items:center;gap:10px;font-size:1.1rem}#damage-ability-name{color:var(--color-primary);font-weight:700}.ability-mod-value{color:var(--color-primary);font-size:1.3rem;font-weight:700}.auto-label{color:var(--text-muted);font-size:.8rem;font-style:italic}.dice-input-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.dice-input-group span{color:var(--text-muted);font-size:1.1rem}.dice-count-input{width:60px!important;text-align:center;padding:8px!important;font-size:1.1rem}.dice-type-select{width:70px;padding:8px;background:var(--border-light);color:var(--text-primary);border:1px solid #555;border-radius:4px;font-size:1.1rem}.modifier-input{width:60px!important;text-align:center;padding:8px!important;font-size:1.1rem}.extra-dice-label{font-size:.8rem!important;color:var(--text-muted)!important}.crit-section{background:#c41e3a26;border:1px solid var(--color-danger)}.crit-section label{display:flex;align-items:center;gap:10px;cursor:pointer;margin-bottom:0}.crit-section input[type=checkbox]{width:20px;height:20px;margin:0}.crit-label{color:var(--color-danger);font-weight:700}.damage-preview{background:var(--bg-dark);padding:12px;border-radius:8px;text-align:center;font-size:1.1rem}.damage-preview span:first-child{color:var(--text-muted)}#damage-preview-text{color:var(--color-primary);font-weight:700;font-size:1.2rem}.modal-actions{margin-top:20px}.modal-roll-btn{width:100%;padding:14px;font-size:1.1rem;background:var(--color-danger);border:none;border-radius:8px;color:#fff;font-weight:700;cursor:pointer;transition:background .3s,transform .2s,box-shadow .2s}.modal-roll-btn:hover{background:var(--color-danger-light);transform:scale(1.02);box-shadow:0 0 15px #c41e3a80}.modal-roll-btn:active{transform:scale(.98)}.modal-roll-btn .fa-burst{margin-right:8px}.damage-toast-body{flex-direction:column;gap:4px}.damage-dice-display{display:flex;align-items:center;gap:8px}.damage-dice-display .fa-burst{font-size:24px;color:var(--color-danger-light)}.damage-rolls{font-size:1rem;color:var(--text-muted);font-family:monospace}.damage-dice-notation{font-size:.8rem;color:var(--text-muted);margin-top:4px}.calc{font-weight:700;color:var(--color-danger-light)}#save-char-btn{grid-column:span 2;margin-top:20px}.spells-section{display:flex;flex-direction:column;gap:20px}.spellcasting-info{background:var(--bg-input);padding:15px;border-radius:8px;border:1px solid var(--border-light)}.spellcasting-info .form-row{margin-bottom:10px}.spellcasting-info .form-row:last-child{margin-bottom:0}.cantrips-section{background:var(--bg-input);padding:15px;border-radius:8px;border:1px solid var(--border-light)}.cantrips-section h4{margin:0 0 15px;color:var(--color-primary)}.cantrips-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}.cantrips-list input{padding:8px;background:var(--border-color);color:var(--text-primary);border:1px solid var(--border-light);border-radius:4px}.prepared-spells-section{display:flex;flex-direction:column;gap:15px}.spell-level{background:var(--bg-input);padding:15px;border-radius:8px;border:1px solid var(--border-light)}.spell-level h5{margin:0 0 10px;color:var(--color-primary);font-size:1.1em}.spell-slots-info{margin-bottom:10px;font-size:.9em;color:#ccc}.prepared-spells-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px}.prepared-spells-list input{padding:6px;background:var(--border-color);color:var(--text-primary);border:1px solid var(--border-light);border-radius:4px;font-size:.9em}@media (max-width: 768px){.sheet-layout{grid-template-columns:1fr}.form-row{flex-direction:column}.abilities-grid,.saves-grid,.skills-grid,.cantrips-list,.prepared-spells-list{grid-template-columns:1fr}}.room-info-bar{display:flex;justify-content:space-between;align-items:center;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem}.room-info-bar .room-name{font-size:1.1rem;font-weight:600;color:var(--color-primary)}.room-info-bar .room-code{font-size:.9rem;color:var(--text-secondary);font-family:monospace;background:var(--bg-input);padding:.25rem .5rem;border-radius:4px}.sheet-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:10px}.sheet-header h2{margin:0}.character-selector{display:flex;align-items:center;gap:10px}.character-selector label{display:flex;align-items:center;gap:6px;color:var(--text-secondary);font-size:.9rem;white-space:nowrap}.character-selector label i{color:var(--color-primary)}.character-dropdown{padding:8px 12px;border:2px solid var(--color-primary);border-radius:8px;background:var(--bg-input);color:var(--text-primary);font-size:.95rem;min-width:250px;cursor:pointer;transition:all .2s ease}.character-dropdown:hover{border-color:var(--color-secondary);box-shadow:0 0 10px var(--color-primary-glow)}.character-dropdown:focus{outline:none;border-color:var(--color-secondary);box-shadow:0 0 10px var(--color-secondary-glow)}.character-dropdown option{background:var(--bg-card);color:var(--text-primary);padding:8px}.character-dropdown option[value=new]{color:var(--color-success);font-weight:600}.character-id-display{display:flex;align-items:center;gap:8px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:6px;padding:6px 12px;font-size:.85rem}.character-id-display .id-label{color:var(--text-secondary)}.character-id-display .id-value{font-family:Consolas,Monaco,monospace;color:var(--color-primary);font-weight:600}.character-id-display .id-value.not-saved{color:var(--text-muted);font-style:italic}.sheet-actions{display:flex;gap:10px;align-items:center}.sheet-action-btn{display:flex;align-items:center;gap:.4rem;padding:.6rem 1rem;border:1px solid var(--border-light);border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;width:auto;margin:0}.export-btn{background:var(--bg-input);color:var(--text-primary);border-color:var(--color-primary)}.export-btn:hover{background:var(--color-primary);color:var(--bg-darkest);box-shadow:0 2px 8px var(--color-primary-glow)}.import-btn{background:var(--bg-input);color:var(--text-primary);border-color:var(--border-light)}.import-btn:hover{background:var(--border-color);border-color:var(--color-primary)}.save-sheet-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--color-primary);color:var(--bg-darkest);border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;width:auto;margin:0}.save-sheet-btn:hover{background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px var(--color-primary-glow)}.save-sheet-btn:active{transform:translateY(0)}.save-sheet-btn.saved{background:var(--color-success)!important;border-color:var(--color-success)!important;box-shadow:0 0 15px var(--color-success-glow);animation:pulse-success .3s ease-out}.save-sheet-btn.error{background:var(--color-warning)!important;border-color:var(--color-warning)!important;box-shadow:0 0 15px #ffc10766}.save-sheet-btn:disabled{opacity:.7;cursor:not-allowed}@keyframes pulse-success{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.save-sheet-btn i{font-size:1rem}.export-modal-content{max-width:450px}.export-modal-body{padding:10px 0}.export-warning{display:flex;gap:12px;padding:15px;background:#f0a50026;border:1px solid var(--color-primary);border-radius:8px;margin-bottom:15px}.export-warning i{color:var(--color-primary);font-size:1.5rem;flex-shrink:0}.export-warning p{margin:0;color:var(--text-primary);line-height:1.5}.export-info{color:var(--text-muted);font-size:.9rem;margin-bottom:20px}.export-actions{display:flex;gap:10px;justify-content:flex-end}.confirm-export-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--color-primary);color:var(--bg-darkest);border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease}.confirm-export-btn:hover{background:var(--color-primary-hover);box-shadow:0 2px 8px var(--color-primary-glow)}.cancel-export-btn{padding:10px 20px;background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-light);border-radius:6px;cursor:pointer;transition:all .2s ease}.cancel-export-btn:hover{background:var(--border-color)}.save-toast{position:fixed;top:20px;right:20px;padding:14px 20px;border-radius:8px;display:flex;align-items:center;gap:12px;z-index:10000;transform:translate(120%);transition:transform .3s ease;box-shadow:0 4px 20px #0006;font-weight:500;max-width:350px}.save-toast.show{transform:translate(0)}.save-toast.success{background:linear-gradient(135deg,#1a472a,#0d2818);border:1px solid var(--color-success);color:var(--color-success)}.save-toast.success i{color:var(--color-success);font-size:1.2rem}.save-toast.error{background:linear-gradient(135deg,#472a1a,#280d0d);border:1px solid var(--color-danger);color:#ff6b6b}.save-toast.error i{color:var(--color-danger);font-size:1.2rem}.save-toast.info{background:linear-gradient(135deg,#1a3a47,#0d1828);border:1px solid var(--color-info);color:var(--color-info)}.save-toast.info i{color:var(--color-info);font-size:1.2rem}.save-toast span{flex:1}.save-toast-close{background:none;border:none;color:inherit;opacity:.6;cursor:pointer;padding:4px;line-height:1;transition:opacity .2s}.save-toast-close:hover{opacity:1}
