.zone-display{position:relative;width:100%;height:100%;min-height:300px;background:linear-gradient(135deg,#1a1a2e,#16213e);overflow:hidden;display:flex;flex-direction:column}.zone-display .scene-backdrop{position:absolute;inset:0;background-size:cover;background-position:center;filter:blur(8px);z-index:0;transition:background-image .5s ease}.zone-display .scene-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,#0006,#0000001a 40% 60%,#00000080);z-index:1}.zone-display .scene-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#0f0f1a)}.zone-display .placeholder-content{text-align:center;color:#ffffff4d}.zone-display .placeholder-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.zone-display .placeholder-content p{font-size:1.25rem;font-style:italic}.zone-display .vignette{position:absolute;inset:0;pointer-events:none;box-shadow:inset 0 0 150px #000000b3;z-index:5}.zone-display .display-content{position:relative;z-index:10;flex:1;display:flex;flex-direction:row;padding:.5rem;overflow:hidden;gap:1rem}.zone-display .display-content.with-gm-controls{padding-top:2.5rem}.zone-display .zone-content-area{flex:1;min-width:0;display:flex;flex-direction:column;overflow-y:auto}.zone-display .scene-panel{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:320px;max-height:100%;padding:.5rem}.zone-display .scene-panel-inner{position:relative;width:100%;max-height:100%;border-radius:12px;overflow:hidden;box-shadow:0 4px 20px #00000080;border:2px solid rgba(255,255,255,.1);background:#0000004d}.zone-display .scene-panel-image{width:100%;height:auto;max-height:50vh;object-fit:contain;display:block}.zone-display .scene-panel-title{position:absolute;bottom:0;left:0;right:0;padding:.75rem;background:linear-gradient(to top,rgba(0,0,0,.8) 0%,transparent 100%);color:#fff;font-weight:600;font-size:.85rem;text-align:center;text-shadow:0 1px 3px rgba(0,0,0,.8)}.zone-display .scene-panel-placeholder{width:100%;aspect-ratio:3/2;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2ecc,#0f0f1acc);border-radius:12px;border:2px dashed rgba(255,255,255,.15);color:#ffffff4d}.zone-display .scene-panel-placeholder .placeholder-icon{font-size:2.5rem;margin-bottom:.5rem;opacity:.5}.zone-display .scene-panel-placeholder p{font-size:.85rem;font-style:italic}@media (max-width: 900px){.zone-display .display-content{flex-direction:column-reverse}.zone-display .scene-panel{width:100%;max-height:200px}.zone-display .scene-panel-image{max-height:180px}}.zone-display .zone-header{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;font-weight:600;font-size:.85rem;margin-bottom:.5rem}.zone-display .zone-icon{font-size:1.1rem}.zone-display .zone-header.combat{background:#e74c3c33;border:1px solid rgba(231,76,60,.4);color:#e74c3c;animation:zone-pulse-combat 3s ease-in-out infinite}@keyframes zone-pulse-combat{0%,to{box-shadow:0 0 10px #e74c3c33}50%{box-shadow:0 0 20px #e74c3c66}}.zone-display .zone-header.exploration{background:#2ecc7133;border:1px solid rgba(46,204,113,.4);color:#2ecc71;animation:zone-pulse-exploration 4s ease-in-out infinite}@keyframes zone-pulse-exploration{0%,to{box-shadow:0 0 10px #2ecc7133}50%{box-shadow:0 0 20px #2ecc7166}}.zone-display .zone-header.stealth{background:#9b59b633;border:1px solid rgba(155,89,182,.4);color:#9b59b6;animation:zone-pulse-stealth 2.5s ease-in-out infinite}@keyframes zone-pulse-stealth{0%,to{box-shadow:0 0 8px #9b59b64d}50%{box-shadow:0 0 15px #9b59b680}}.zone-display .zone-header.chase{background:#f39c1233;border:1px solid rgba(243,156,18,.4);color:#f39c12;animation:zone-pulse-chase 1.5s ease-in-out infinite}@keyframes zone-pulse-chase{0%,to{box-shadow:0 0 10px #f39c124d}50%{box-shadow:0 0 25px #f39c1280}}.zone-display .combat-header{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1rem;background:#e74c3c33;border:1px solid rgba(231,76,60,.4);border-radius:8px;color:#e74c3c;font-weight:600;font-size:1rem;margin-bottom:1rem}.zone-display .combat-icon{font-size:1.1rem}.zone-display .formations{display:flex;flex-direction:column;gap:.5rem;padding-top:0rem;max-width:700px;margin-left:0;margin-right:auto;width:100%;padding-left:.5rem;padding-right:1rem}.zone-display .formation-row{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:.5rem .75rem;transition:all .2s ease;display:flex;flex-direction:column}.zone-display .formation-row.drag-over{background:#4a9eff26;border-color:#4a9eff80}.zone-display .formation-row.can-drop{background:#4a9eff1f;border-color:#4a9eff66;box-shadow:inset 0 0 20px #4a9eff26}.zone-display .formation-row.can-drop:hover{background:#4a9eff33;border-color:#4a9eff99;box-shadow:inset 0 0 30px #4a9eff40}.zone-display .formation-row.can-drop .formation-label:after{content:"← Click to move here";margin-left:1rem;font-size:.65rem;color:#4a9effcc;font-weight:400;font-style:italic}.zone-display .formation-row.frontline{border-left:4px solid #e74c3c;animation:border-glow-frontline 3s ease-in-out infinite}.zone-display .formation-row.midline{border-left:4px solid #f39c12;animation:border-glow-midline 3s ease-in-out infinite}.zone-display .formation-row.backline{border-left:4px solid #3498db;animation:border-glow-backline 3s ease-in-out infinite}@keyframes border-glow-frontline{0%,to{box-shadow:inset 3px 0 8px -4px #e74c3c4d}50%{box-shadow:inset 3px 0 12px -4px #e74c3c99}}@keyframes border-glow-midline{0%,to{box-shadow:inset 3px 0 8px -4px #f39c124d}50%{box-shadow:inset 3px 0 12px -4px #f39c1299}}@keyframes border-glow-backline{0%,to{box-shadow:inset 3px 0 8px -4px #3498db4d}50%{box-shadow:inset 3px 0 12px -4px #3498db99}}.zone-display .formation-label{display:flex;align-items:center;gap:.4rem;margin-bottom:.3rem;padding-bottom:.3rem;border-bottom:1px solid rgba(255,255,255,.08)}.zone-display .formation-row.frontline .formation-label{animation:glow-frontline 3s ease-in-out infinite}.zone-display .formation-row.midline .formation-label{animation:glow-midline 3s ease-in-out infinite}.zone-display .formation-row.backline .formation-label{animation:glow-backline 3s ease-in-out infinite}@keyframes glow-frontline{0%,to{text-shadow:0 0 4px rgba(231,76,60,.3)}50%{text-shadow:0 0 12px rgba(231,76,60,.6)}}@keyframes glow-midline{0%,to{text-shadow:0 0 4px rgba(243,156,18,.3)}50%{text-shadow:0 0 12px rgba(243,156,18,.6)}}@keyframes glow-backline{0%,to{text-shadow:0 0 4px rgba(52,152,219,.3)}50%{text-shadow:0 0 12px rgba(52,152,219,.6)}}.zone-display .formation-icon{font-size:.85rem}.zone-display .formation-name{font-weight:600;color:#fff;font-size:.8rem}.zone-display .formation-desc{color:#ffffff59;font-size:.7rem}.zone-display .formation-desc:before{content:"—";margin-right:.4rem}.zone-display .formation-content{display:flex;align-items:center;gap:1rem;min-height:50px;padding:.25rem 0}.zone-display .formation-side{display:flex;flex-wrap:wrap;gap:.6rem;flex:1;align-content:flex-start}.zone-display .formation-side.allies{justify-content:flex-start}.zone-display .formation-side.enemies{justify-content:flex-end}.zone-display .vs-divider{color:#ffffff40;font-weight:700;font-size:1.1rem;padding:0 .75rem}.zone-display .empty-slot{color:#fff3;font-style:italic;padding:1rem}.zone-display .profile-card{position:relative;background:#0009;border:2px solid var(--accent-color, #666);border-radius:8px;padding:.5rem;width:100px;cursor:pointer;transition:all .2s ease;backdrop-filter:blur(4px);user-select:none}.zone-display .profile-card img{pointer-events:none;-webkit-user-drag:none}.zone-display .profile-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px #0006}.zone-display .profile-card.controllable{cursor:grab}.zone-display .profile-card.controllable:active{cursor:grabbing}.zone-display .profile-card.selected{border-color:gold;box-shadow:0 0 20px #ffd70066}.zone-display .profile-card.targeted{animation:pulse-target 1s ease-in-out infinite}@keyframes pulse-target{0%,to{box-shadow:0 0 10px #ef444499}50%{box-shadow:0 0 25px #ef4444e6}}.zone-display .profile-card.enemy{background:#e74c3c26}.zone-display .profile-card.compact{width:90px;padding:.4rem}.zone-display .profile-card.hidden{box-shadow:0 0 15px #2ecc714d}.zone-display .profile-card.detected{box-shadow:0 0 15px #f39c124d}.zone-display .profile-card.exposed{box-shadow:0 0 15px #e74c3c4d;animation:exposed-pulse 1.5s ease-in-out infinite}@keyframes exposed-pulse{0%,to{box-shadow:0 0 15px #e74c3c4d}50%{box-shadow:0 0 25px #e74c3c99}}.zone-display .portrait-container{position:relative;width:100%;aspect-ratio:1;border-radius:6px;overflow:hidden;margin-bottom:.4rem;background:#ffffff1a}.zone-display .portrait-image{width:100%;height:100%;object-fit:cover}.zone-display .portrait-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ffffff1f,#ffffff0d)}.zone-display .portrait-initial{font-size:1.75rem;font-weight:700;color:#ffffff80}.zone-display .compact .portrait-initial{font-size:1.5rem}.zone-display .level-badge{position:absolute;bottom:3px;right:3px;background:#000000d9;color:gold;font-size:.6rem;font-weight:600;padding:2px 5px;border-radius:3px}.zone-display .enemy-indicator{position:absolute;top:3px;right:3px;font-size:.85rem}.zone-display .profile-info{display:flex;flex-direction:column;gap:.2rem}.zone-display .character-name{font-weight:600;color:#fff;font-size:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.zone-display .character-class{color:#ffffff80;font-size:.65rem}.zone-display .hp-bar-container{position:relative;margin-top:.2rem}.zone-display .hp-bar-bg{height:7px;background:#00000080;border-radius:4px;overflow:hidden}.zone-display .hp-bar-fill{height:100%;transition:width .3s ease,background-color .3s ease;border-radius:4px}.zone-display .hp-bar-fill.healthy{background:#4ade80}.zone-display .hp-bar-fill.hurt{background:#fbbf24}.zone-display .hp-bar-fill.critical{background:#ef4444}.zone-display .hp-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.55rem;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.9)}.zone-display .ac-display{display:flex;align-items:center;gap:.2rem;margin-top:.15rem}.zone-display .ac-icon{font-size:.65rem}.zone-display .ac-value{font-size:.65rem;font-weight:600;color:#a0a0a0}.zone-display .conditions{display:flex;flex-wrap:wrap;gap:.2rem;margin-top:.2rem}.zone-display .condition-tag{background:#9b59b64d;color:#bb8fce;font-size:.5rem;padding:1px 4px;border-radius:3px}.zone-display .selection-ring{position:absolute;inset:-3px;border:2px solid #ffd700;border-radius:12px;pointer-events:none;animation:pulse-ring 1.5s ease-in-out infinite}.zone-display .target-ring{position:absolute;inset:-5px;border:3px solid #ef4444;border-radius:14px;pointer-events:none;animation:pulse-target 1s ease-in-out infinite}@keyframes pulse-ring{0%,to{opacity:1}50%{opacity:.5}}.zone-display .no-characters{flex:1;display:flex;align-items:center;justify-content:center;color:#ffffff4d;font-style:italic}@media (max-width: 768px){.zone-display .display-content.with-gm-controls{padding-top:140px}.zone-display .profile-card{width:85px;padding:.4rem}.zone-display .portrait-initial{font-size:1.4rem}.zone-display .character-name{font-size:.7rem}.zone-display .formation-content{flex-direction:column;gap:.5rem}.zone-display .formation-side{justify-content:center!important;width:100%}.zone-display .vs-divider{padding:.25rem 0}}.zone-display .display-content::-webkit-scrollbar{width:6px}.zone-display .display-content::-webkit-scrollbar-track{background:#0003;border-radius:3px}.zone-display .display-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.zone-display .display-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.zone-display .zones-container{display:flex;gap:1rem;padding:1rem;flex:1;overflow:auto;margin-left:-4.5rem}.zone-display .zones-container.split{flex-direction:row;align-items:flex-start;gap:.5rem;padding:4.5rem}.zone-display .zones-container.split .zone-wrapper{flex:1;min-width:330x;max-width:330px}.zone-display .zones-container.progression{flex-direction:column;align-items:center}.zone-display .zones-container.progression .zone-wrapper{width:100%;max-width:600px}.zone-display .zone-wrapper{display:flex;flex-direction:column;align-items:center}.zone-display .zone-card{background:#00000080;border:2px solid rgba(255,255,255,.15);border-radius:12px;overflow:hidden;backdrop-filter:blur(8px);transition:all .3s ease;width:100%}.zone-display .zone-card:hover{border-color:#ffffff40}.zone-display .zone-card.combat{border-color:#e74c3c80;box-shadow:0 0 20px #e74c3c33}.zone-display .zone-card.exploration{border-color:#2ecc7180;box-shadow:0 0 20px #2ecc7133}.zone-display .zone-card.stealth{border-color:#9b59b680;box-shadow:0 0 20px #9b59b633}.zone-display .zone-card.chase{border-color:#f39c1280;box-shadow:0 0 20px #f39c1233}.zone-display .zone-card.locked{opacity:.6;border-color:#ffffff1a}.zone-display .zone-card.empty{border-style:dashed;border-color:#fff3;background:#0000004d}.zone-display .zone-card.empty:hover{border-color:#ffffff4d;background:#0006}.zone-display .zone-card.collapsed .zone-card-content{display:none}.zone-display .zone-card.drag-over{border-color:#4a9effcc;box-shadow:0 0 30px #4a9eff80;background:#4a9eff14;transform:scale(1.02)}.zone-display .zone-card.empty.drag-over{border-style:solid;border-width:3px;background:#4a9eff1a}.zone-display .zone-card.empty.drag-over .zone-empty-content{color:#4a9effcc}.zone-display .zone-card.can-drop{cursor:pointer;border-color:#4a9eff66}.zone-display .zone-card.can-drop:hover{border-color:#4a9eff99;box-shadow:0 0 20px #4a9eff4d}.zone-display .zone-card-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#0000004d;border-bottom:1px solid rgba(255,255,255,.1);cursor:pointer;user-select:none}.zone-display .zone-card-header:hover{background:#ffffff0d}.zone-display .zone-card-icon{font-size:1.25rem}.zone-display .zone-card-info{flex:1}.zone-display .zone-card-name{font-weight:600;color:#fff;font-size:.95rem}.zone-display .zone-card-status{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#ffffff80}.zone-display .status-badge{padding:2px 8px;border-radius:4px;font-size:.65rem;font-weight:600;text-transform:uppercase}.zone-display .status-badge.combat{background:#e74c3c4d;color:#e74c3c}.zone-display .status-badge.exploration{background:#2ecc714d;color:#2ecc71}.zone-display .status-badge.stealth{background:#9b59b64d;color:#9b59b6}.zone-display .status-badge.chase{background:#f39c124d;color:#f39c12}.zone-display .status-badge.locked{background:#ffffff1a;color:#fff6}.zone-display .locked-text{font-style:italic;color:#fff6}.zone-display .zone-card-characters{display:flex;gap:-8px}.zone-display .mini-avatar{width:28px;height:28px;border-radius:50%;border:2px solid rgba(0,0,0,.5);overflow:hidden;background:#ffffff1a;margin-left:-8px}.zone-display .mini-avatar:first-child{margin-left:0}.zone-display .mini-avatar img{width:100%;height:100%;object-fit:cover}.zone-display .mini-avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;color:#fff9}.zone-display .mini-avatar.player{border-color:#4a9eff}.zone-display .mini-avatar.enemy{border-color:#e74c3c}.zone-display .mini-avatar.companion{border-color:#2ecc71}.zone-display .mini-avatar.npc{border-color:#9b59b6}.zone-display .more-count{font-size:.7rem;color:#ffffff80;margin-left:4px}.zone-display .empty-zone-label{font-size:.75rem;color:#ffffff4d;font-style:italic}.zone-display .expand-icon{font-size:.75rem;color:#fff6;transition:transform .2s ease}.zone-display .zone-card.collapsed .expand-icon{transform:rotate(-90deg)}.zone-display .zone-card-content{padding:.75rem;max-height:800px;overflow-y:auto}.zone-display .zone-locked-content,.zone-display .zone-empty-content{padding:2rem 1.5rem;text-align:center;color:#ffffff80;font-style:italic}.zone-display .zone-empty-content p{margin:.5rem 0}.zone-display .zone-empty-content p.drop-hint{margin-top:1rem;font-size:.85rem;color:#ffffff4d;padding:.5rem;border:1px dashed rgba(255,255,255,.2);border-radius:6px;background:#ffffff05}.zone-display .zone-formations{display:flex;flex-direction:column;gap:.5rem}.zone-display .zone-formations .formation-row{padding:.4rem .6rem}.zone-display .zone-formations .profile-card{width:80px}.zone-display .zone-formations .profile-card.compact{width:75px}.zone-display .zone-objective{margin-top:.75rem;padding:.5rem .75rem;background:#f39c1226;border:1px solid rgba(243,156,18,.3);border-radius:6px;color:#f39c12;font-size:.8rem}.zone-display .zone-objective.standalone{margin:1rem auto;max-width:500px}.zone-display .zone-connector{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 0;color:#fff6}.zone-display .connector-line{width:2px;height:20px;background:linear-gradient(to bottom,transparent,rgba(255,255,255,.3),transparent)}.zone-display .connector-label{font-size:.8rem;padding:.25rem .5rem;background:#0000004d;border-radius:4px}.zone-display .stealth-display{display:flex;flex-direction:column;gap:1rem;padding:1rem;width:100%;min-width:0}.zone-display .detection-level{display:flex;flex-direction:column;gap:.5rem;padding:.75rem 1rem;background:#9b59b626;border:1px solid rgba(155,89,182,.3);border-radius:8px;width:100%;min-width:0}.zone-display .detection-level-label{font-size:.8rem;font-weight:600;color:#9b59b6;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.zone-display .group-stealth-badge,.zone-display .detection-dc-badge{font-size:.7rem;font-weight:500;padding:2px 8px;border-radius:4px;background:#9b59b633;color:#9b59b6;text-transform:none;letter-spacing:normal}.zone-display .detection-threshold-line{position:absolute;top:0;bottom:0;width:2px;background:#e74c3c;transform:translate(-50%);z-index:2;animation:threshold-pulse 2s ease-in-out infinite}@keyframes threshold-pulse{0%,to{opacity:.6;box-shadow:0 0 4px #e74c3c99}50%{opacity:1;box-shadow:0 0 8px #e74c3c}}.zone-display .detection-track{display:flex;flex-direction:column;gap:.5rem;width:100%}.zone-display .detection-track-bar{position:relative;width:100%;height:25px;background:#0000004d;border-radius:12px;border:1px solid rgba(155,89,182,.4)}.zone-display .detection-marker{position:absolute;top:50%;transform:translate(-50%,-50%);width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,#9b59b6,#8e44ad);border:2px solid #fff;transition:left .5s ease;box-shadow:0 2px 8px #9b59b699;animation:detection-pulse 2s ease-in-out infinite}@keyframes detection-pulse{0%,to{box-shadow:0 2px 8px #9b59b699}50%{box-shadow:0 2px 12px #9b59b6e6}}.zone-display .detection-labels{display:flex;justify-content:space-between;width:100%;font-size:.7rem;color:#fff9;padding:0 .5rem}.zone-display .detection-labels span{font-weight:500;flex:0 0 auto;white-space:nowrap}.zone-display .detection-labels span:first-child{text-align:left}.zone-display .detection-labels span:nth-child(2){text-align:center}.zone-display .detection-labels span:last-child{text-align:right}.zone-display .stealth-row{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:#9b59b61a;border:1px dashed rgba(155,89,182,.3);border-radius:8px}.zone-display .stealth-label{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.85rem;color:#9b59b6;text-transform:uppercase;letter-spacing:.5px}.zone-display .stealth-icon{font-size:1.2rem}.zone-display .stealth-name{flex:1}.zone-display .stealth-content{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.zone-display .stealth-content .empty-slot{color:#ffffff4d;font-style:italic;padding:1rem}.zone-display .patrol-info{padding:.75rem 1rem;background:#9b59b61a;border:1px solid rgba(155,89,182,.3);border-radius:6px;color:#9b59b6;font-size:.85rem;display:flex;align-items:center;gap:.5rem}.zone-display .patrol-icon{font-size:1.1rem}.zone-display .stealth-groups{display:flex;flex-direction:column;gap:1rem}.zone-display .stealth-group{background:#0003;border-radius:8px;padding:.75rem;border:1px solid rgba(255,255,255,.1)}.zone-display .stealth-group.hidden{border-color:#2ecc714d;background:#2ecc710d}.zone-display .stealth-group.detected{border-color:#f39c124d;background:#f39c120d}.zone-display .stealth-group.exposed{border-color:#e74c3c4d;background:#e74c3c0d}.zone-display .stealth-group-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;font-weight:600;font-size:.85rem}.zone-display .stealth-group.hidden .stealth-group-header{color:#2ecc71}.zone-display .stealth-group.detected .stealth-group-header{color:#f39c12}.zone-display .stealth-group.exposed .stealth-group-header{color:#e74c3c}.zone-display .status-icon{font-size:1.1rem;flex-shrink:0}.zone-display .status-label{flex:1;text-transform:uppercase;letter-spacing:.5px}.zone-display .status-count{background:#ffffff26;padding:3px 10px;border-radius:12px;font-size:.75rem;font-weight:600;border:1px solid rgba(255,255,255,.2);min-width:24px;text-align:center}.zone-display .stealth-group-characters{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.zone-display .chase-display{display:flex;flex-direction:column;gap:1rem;padding:1rem}.zone-display .chase-distance{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f39c121a;border:1px solid rgba(243,156,18,.3);border-radius:8px}.zone-display .chase-end{display:flex;flex-direction:column;align-items:center;gap:.25rem;min-width:80px}.zone-display .chase-end-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.zone-display .chase-end.party .chase-end-label{color:#2ecc71}.zone-display .chase-end.pursuers .chase-end-label{color:#e74c3c}.zone-display .chase-end-icon{font-size:1.5rem}.zone-display .chase-track{flex:1;display:flex;flex-direction:column;gap:.5rem}.zone-display .chase-track-bar{position:relative;height:30px;background:#0000004d;border-radius:15px;border:1px solid rgba(243,156,18,.4)}.zone-display .chase-marker{position:absolute;top:50%;transform:translate(-50%,-50%);width:20px;height:20px;border-radius:50%;border:2px solid #fff;transition:left .5s ease;box-shadow:0 2px 8px #00000080}.zone-display .chase-marker.party-marker{background:#2ecc71;z-index:2}.zone-display .chase-marker.pursuer-marker{background:#e74c3c;z-index:1}.zone-display .chase-labels{display:flex;justify-content:space-between;font-size:.7rem;color:#fff9;padding:0 .5rem}.zone-display .chase-labels span{font-weight:500}.zone-display .chase-warning{text-align:center;padding:.75rem;background:#e74c3c26;border:1px solid rgba(231,76,60,.4);border-radius:6px}.zone-display .chase-progress-container{position:relative;height:40px;background:#0000004d;border-radius:20px;overflow:hidden;border:1px solid rgba(243,156,18,.3)}.zone-display .chase-progress-bar{height:100%;background:linear-gradient(90deg,#e74c3c,#f39c12,#2ecc71);transition:width .5s ease}.zone-display .chase-progress-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-weight:600;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.8)}.zone-display .chase-pursuer-info{text-align:center;color:#e74c3c;font-weight:600;animation:chase-pulse 1s ease-in-out infinite}@keyframes chase-pulse{0%,to{opacity:1}50%{opacity:.6}}.zone-display .chase-position-label{font-size:.65rem;color:#ffffff80;margin-left:.25rem}.zone-display .chase-characters{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.zone-display .chase-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#f39c121a;border:1px solid rgba(243,156,18,.3);border-radius:6px;margin-bottom:1rem}.zone-display .chase-round{font-weight:600;color:#f39c12;font-size:.9rem}.zone-display .chase-terrain{color:#ffffffb3;font-size:.85rem}.zone-display .chase-progress-fill{position:absolute;top:0;left:0;height:100%;border-radius:15px;opacity:.3;transition:width .5s ease,background .3s ease;z-index:0}.zone-display .chase-marker{z-index:1}.zone-display .marker-icon{font-size:.8rem;line-height:1}.zone-display .chase-complication{padding:.75rem 1rem;background:#e74c3c1a;border:1px solid rgba(231,76,60,.3);border-radius:6px;display:flex;align-items:center;gap:.5rem;margin-top:1rem}.zone-display .complication-icon{font-size:1.1rem;color:#e74c3c}.zone-display .complication-text{color:#ffffffe6;font-size:.85rem;font-weight:500}.zone-display .chase-positions{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.zone-display .chase-position-group{background:#0003;border-radius:8px;padding:.75rem;border:1px solid rgba(255,255,255,.1)}.zone-display .chase-position-group.far_ahead{border-color:#2ecc714d;background:#2ecc710d}.zone-display .chase-position-group.ahead{border-color:#27ae604d;background:#27ae600d}.zone-display .chase-position-group.even{border-color:#f39c124d;background:#f39c120d}.zone-display .chase-position-group.behind{border-color:#e67e224d;background:#e67e220d}.zone-display .chase-position-group.far_behind{border-color:#e74c3c4d;background:#e74c3c0d}.zone-display .position-label{font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.zone-display .position-characters{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.zone-display .chase-warning{margin-top:1rem}.zone-display .warning-icon{font-size:1.1rem;margin-right:.5rem}@media (max-width: 768px){.zone-display .zones-container.split{flex-direction:column;gap:1rem;padding:1rem}.zone-display .zones-container.split .zone-wrapper{max-width:100%;width:100%}.zone-display .zone-card-header{flex-wrap:wrap}.zone-display .zone-card-characters{order:10;width:100%;margin-top:.5rem;justify-content:flex-start}}.gm-controls-header{display:flex;flex-direction:row;align-items:center;gap:var(--spacing-xs);flex-wrap:wrap}.gm-controls-header .gm-control-btn{padding:.375rem .75rem;font-size:12px;width:auto;min-width:fit-content}.gm-controls-header .gm-premium-toggle,.gm-controls-header .gm-concise-toggle{padding:.25rem .5rem;width:auto;min-width:fit-content}.gm-controls-header .gm-zone-select{padding:.375rem .5rem;font-size:12px;width:auto;min-width:120px}.gm-controls-header .gm-zone-controls{flex-direction:row;width:auto}.gm-controls-header .gm-control-split,.gm-controls-header .gm-control-merge{padding:.375rem .75rem;font-size:12px;width:auto}.gm-controls-embedded{display:flex;flex-direction:column;gap:var(--spacing-xs);width:100%}.gm-controls{position:absolute;top:64px;left:auto!important;z-index:100;display:flex;flex-direction:column;align-items:flex-end;gap:var(--spacing-xs)}.gm-control-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);border:none;border-radius:var(--radius-md);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-md);white-space:nowrap}.gm-control-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.gm-control-btn:active{transform:translateY(0)}.gm-control-icon{font-size:14px}.gm-control-start{background:linear-gradient(135deg,var(--color-accent-green) 0%,#22c55e 100%);color:var(--color-bg-dark)}.gm-control-start:hover{background:linear-gradient(135deg,#22c55e,#16a34a)}.gm-control-pause{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:var(--color-bg-dark)}.gm-control-pause:hover{background:linear-gradient(135deg,#f59e0b,#d97706)}.gm-control-resume{background:linear-gradient(135deg,var(--color-accent-blue) 0%,#3b82f6 100%);color:var(--color-bg-dark)}.gm-control-resume:hover{background:linear-gradient(135deg,#3b82f6,#2563eb)}.gm-control-start-combat{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;margin-top:var(--spacing-sm)}.gm-control-start-combat:hover{background:linear-gradient(135deg,#dc2626,#b91c1c)}.gm-control-end-combat{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff;margin-top:var(--spacing-sm)}.gm-control-end-combat:hover{background:linear-gradient(135deg,#4b5563,#374151)}.gm-premium-toggle{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background:#14141ef2;border:1px solid rgba(212,165,116,.2);border-radius:var(--radius-sm);cursor:pointer;font-size:12px;transition:all .2s ease}.gm-premium-toggle:hover{background:#1e1e28f2;border-color:#d4a5744d}.gm-premium-toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--color-accent-gold)}.gm-premium-label{color:var(--color-text-secondary);user-select:none}.gm-concise-toggle{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background:#14141ef2;border:1px solid rgba(212,165,116,.2);border-radius:var(--radius-sm);cursor:pointer;font-size:12px;transition:all .2s ease}.gm-concise-toggle:hover{background:#1e1e28f2;border-color:#d4a5744d}.gm-concise-toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--color-accent-blue)}.gm-concise-label{color:var(--color-text-secondary);user-select:none}.gm-zone-select{padding:var(--spacing-xs) var(--spacing-sm);background:#14141ef2;border:1px solid rgba(212,165,116,.2);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:12px;cursor:pointer;transition:all .2s ease}.gm-zone-select:hover{background:#1e1e28f2;border-color:#d4a5744d}.gm-zone-select:focus{outline:none;border-color:var(--color-accent-blue)}.gm-zone-controls{display:flex;flex-direction:column;gap:var(--spacing-xs)}.gm-control-split{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;padding:var(--spacing-xs) var(--spacing-md);font-size:12px}.gm-control-split:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9)}.gm-control-merge{background:linear-gradient(135deg,#06b6d4,#0891b2);color:#fff;padding:var(--spacing-xs) var(--spacing-md);font-size:12px}.gm-control-merge:hover{background:linear-gradient(135deg,#0891b2,#0e7490)}.gm-zone-input-row{display:flex;gap:var(--spacing-xs);align-items:center}.gm-zone-name-input{padding:var(--spacing-xs) var(--spacing-sm);background:#14141ef2;border:1px solid rgba(212,165,116,.2);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:12px;flex:1;min-width:0}.gm-zone-name-input:focus{outline:none;border-color:var(--color-accent-purple)}.gm-zone-name-input::placeholder{color:var(--color-text-muted)}.gm-zone-confirm-btn,.gm-zone-cancel-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;transition:all .2s ease}.gm-zone-confirm-btn{background:var(--color-accent-green);color:var(--color-bg-dark)}.gm-zone-confirm-btn:hover:not(:disabled){background:#22c55e}.gm-zone-confirm-btn:disabled{opacity:.5;cursor:not-allowed}.gm-zone-cancel-btn{background:var(--color-bg-light);color:var(--color-text-secondary)}.gm-zone-cancel-btn:hover{background:#ef4444;color:#fff}.choice-panel{position:absolute;bottom:120px;left:50%;transform:translate(-50%);z-index:100;background:#0f0f1af2;border:1px solid var(--color-accent-gold);border-radius:var(--radius-lg);padding:var(--spacing-md);min-width:400px;max-width:600px;box-shadow:var(--shadow-lg),var(--shadow-glow);backdrop-filter:blur(8px)}.choice-panel-header{margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.choice-panel-title{font-size:14px;font-weight:600;color:var(--color-accent-gold);text-transform:uppercase;letter-spacing:.05em}.choice-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.choice-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;text-align:left;color:var(--color-text-primary);font-size:14px}.choice-button:hover{background:#d4a84626;border-color:var(--color-accent-gold);transform:translate(4px)}.choice-button:active{transform:translate(2px)}.choice-skill-check{border-color:var(--color-accent-blue)}.choice-skill-check:hover{background:#60a5fa26;border-color:var(--color-accent-blue)}.choice-skill-tag{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);background:#60a5fa33;border-radius:var(--radius-sm);font-size:11px;font-weight:700;color:var(--color-accent-blue);letter-spacing:.05em;flex-shrink:0}.choice-text{flex:1;line-height:1.4}@media (max-width: 640px){.choice-panel{min-width:calc(100% - 32px);left:16px;right:16px;transform:none}}.cs-modal-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:csFadeIn .2s ease;backdrop-filter:blur(4px)}.cs-modal-container{max-width:1400px;width:90%;max-height:90vh;overflow:hidden;animation:csSlideUp .3s ease}@keyframes csFadeIn{0%{opacity:0}to{opacity:1}}@keyframes csSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.character-sheet-unified{background:linear-gradient(180deg,#1a1a2e,#13131f);border:1px solid rgba(212,165,116,.3);border-radius:.75rem;overflow:hidden;color:#fff;display:flex;flex-direction:column;max-height:90vh}.character-sheet-unified.editing{border-color:#4ade8066;box-shadow:0 0 0 2px #4ade8026}.cs-header-bar{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#0006;border-bottom:1px solid rgba(255,255,255,.1);gap:1rem}.cs-portrait-section{flex-shrink:0}.cs-portrait-image,.cs-portrait-placeholder{width:64px;height:64px;border-radius:50%;object-fit:cover;border:2px solid rgba(212,165,116,.4)}.cs-portrait-placeholder{background:linear-gradient(135deg,#2a2a40,#1a1a2e);display:flex;align-items:center;justify-content:center}.cs-portrait-initial{font-size:1.75rem;font-weight:700;color:#d4a574cc;font-family:var(--font-display, serif)}.cs-header-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.cs-name{margin:0;font-size:1.5rem;font-weight:600;color:#d4a574;font-family:var(--font-display, serif)}.cs-name-input{background:transparent;border:1px solid rgba(212,165,116,.3);border-radius:.375rem;font-size:1.5rem;font-weight:600;color:#d4a574;font-family:var(--font-display, serif);padding:.25rem .5rem;width:300px}.cs-name-input:focus{outline:none;border-color:#d4a57499;background:#0003}.cs-subtitle{font-size:.9rem;color:#ffffffb3}.cs-experience{font-size:.875rem;color:#d4a574cc;font-weight:500;margin-top:.125rem}.cs-header-actions{display:flex;align-items:center;gap:.75rem}.cs-unsaved-badge{background:#fbbf2433;color:#fbbf24;padding:.25rem .75rem;border-radius:1rem;font-size:.75rem;font-weight:500}.cs-btn{padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.cs-btn.primary{background:linear-gradient(135deg,#d4a574,#c4956a);color:#1a1a2e}.cs-btn.primary:hover:not(:disabled){background:linear-gradient(135deg,#e4b584,#d4a574)}.cs-btn.secondary{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.cs-btn.secondary:hover:not(:disabled){background:#ffffff26}.cs-btn:disabled{opacity:.5;cursor:not-allowed}.cs-close-btn{width:32px;height:32px;border-radius:50%;background:#ffffff1a;border:none;color:#ffffffb3;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.cs-close-btn:hover{background:#fff3;color:#fff}.cs-identity-bar{display:flex;flex-wrap:wrap;gap:1rem;padding:.75rem 1.5rem;background:#0000004d;border-bottom:1px solid rgba(255,255,255,.08)}.cs-identity-field{display:flex;flex-direction:column;gap:.25rem;min-width:100px}.cs-identity-field label{font-size:.65rem;color:#ffffff80;text-transform:uppercase;letter-spacing:.05em}.cs-identity-field input{background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:.375rem;color:#fff;font-size:.9rem;padding:.375rem .625rem;width:100%}.cs-identity-field input:focus{outline:none;border-color:#d4a57480;background:#0000004d}.cs-identity-field input[type=number]{width:70px}.cs-section-tabs{display:none;overflow-x:auto;padding:.5rem 1rem;gap:.5rem;background:#0003;border-bottom:1px solid rgba(255,255,255,.05)}.cs-tab{padding:.5rem 1rem;background:#ffffff0d;border:1px solid transparent;border-radius:.375rem;color:#fff9;font-size:.8rem;white-space:nowrap;cursor:pointer;transition:all .2s}.cs-tab:hover{background:#ffffff1a;color:#fff}.cs-tab.active{background:#d4a57426;border-color:#d4a5744d;color:#d4a574}.cs-content{display:grid;grid-template-columns:200px 200px 220px 1fr;gap:1rem;padding:1.5rem;overflow-y:auto;flex:1}.cs-section{background:#0003;border:1px solid rgba(255,255,255,.08);border-radius:.5rem;padding:1rem}.cs-section-title{margin:0 0 1rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:#d4a574;font-weight:600}.cs-subsection-title{margin:1.5rem 0 .75rem;font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:#ffffff80}.cs-right-column{display:flex;flex-direction:column;gap:1rem}.cs-ability-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.cs-ability-block{background:#0000004d;border:1px solid rgba(212,165,116,.2);border-radius:.5rem;padding:.5rem;text-align:center}.cs-ability-name{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#d4a574;margin-bottom:.25rem}.cs-ability-score{font-size:1.25rem;font-weight:700;color:#fff}input.cs-ability-score{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:.25rem;width:50px;text-align:center;padding:.25rem}.cs-ability-mod{font-size:.9rem;color:#ffffffb3;margin-top:.125rem}.cs-ability-save{font-size:.65rem;color:#ffffff80;margin-top:.5rem;display:flex;align-items:center;justify-content:center;gap:.25rem}.cs-ability-save.proficient{color:#4ade80}.cs-ability-save.editable{cursor:pointer}.cs-ability-save.editable:hover{color:#d4a574}.cs-prof-indicator{font-size:.5rem}.cs-prof-bonus{margin-top:1rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:#ffffffb3}.cs-prof-value{font-weight:600;color:#d4a574}.cs-prof-input{width:4rem;padding:.25rem .5rem;background:#0000004d;border:1px solid rgba(212,165,116,.3);border-radius:.25rem;color:#d4a574;font-weight:600;text-align:center}.cs-prof-input:focus{outline:none;border-color:#d4a57499;background:#0006}.cs-combat-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:1rem}.cs-stat-block{background:#0000004d;border-radius:.5rem;padding:.5rem;text-align:center}.cs-stat-block.ac{border:2px solid rgba(212,165,116,.4)}.cs-stat-label{font-size:.6rem;text-transform:uppercase;letter-spacing:.05em;color:#ffffff80;margin-bottom:.25rem}.cs-stat-value{font-size:1.25rem;font-weight:700;color:#fff}input.cs-stat-value{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:.25rem;width:100%;text-align:center;padding:.25rem;font-size:1rem;color:#fff}.cs-hp-section{background:#0000004d;border-radius:.5rem;padding:.75rem;margin-bottom:.75rem}.cs-hp-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.05em;color:#ffffff80;margin-bottom:.5rem}.cs-hp-display{display:flex;align-items:center;justify-content:center;gap:.25rem;margin-bottom:.5rem}.cs-hp-value{font-size:1.5rem;font-weight:700;color:#fff}.cs-temp-hp{color:#60a5fa;font-size:1rem}.cs-hp-input{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:.25rem;width:50px;text-align:center;padding:.25rem;font-size:1rem;color:#fff}.cs-hp-separator{color:#ffffff80}.cs-hp-bar{height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.cs-hp-fill{height:100%;border-radius:3px;transition:width .3s,background .3s}.cs-hit-dice{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:#0003;border-radius:.375rem;font-size:.8rem;margin-bottom:.75rem}.cs-hd-label{color:#fff9}.cs-hd-value{color:#fff;font-weight:500}.cs-hd-edit{display:flex;align-items:center;gap:.25rem}.cs-hd-edit input{width:3rem;padding:.25rem;background:#0000004d;border:1px solid rgba(212,165,116,.3);border-radius:.25rem;color:#fff;text-align:center;font-size:.875rem}.cs-hd-edit input:focus{outline:none;border-color:#d4a57499;background:#0006}.cs-hd-edit span{color:#fff9;font-weight:500}.cs-death-saves{background:#0003;border-radius:.375rem;padding:.5rem}.cs-ds-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.05em;color:#ffffff80;margin-bottom:.5rem}.cs-ds-row{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:#ffffffb3;margin-bottom:.25rem}.cs-ds-boxes{display:flex;gap:.25rem}.cs-ds-box{width:14px;height:14px;border:1px solid rgba(74,222,128,.5);border-radius:2px;background:transparent}.cs-ds-box.failure{border-color:#f8717180}.cs-skills-list{display:flex;flex-direction:column;gap:.25rem}.cs-skill-row{display:flex;align-items:center;gap:.5rem;padding:.25rem .375rem;border-radius:.25rem;font-size:.75rem;transition:background .15s}.cs-skill-row.editable{cursor:pointer}.cs-skill-row.editable:hover{background:#ffffff0d}.cs-skill-prof{font-size:.5rem;color:#fff6;width:10px}.cs-skill-row.proficient .cs-skill-prof{color:#4ade80}.cs-skill-bonus{width:28px;font-weight:600;color:#fff}.cs-skill-name{flex:1;color:#fffc}.cs-skill-ability{font-size:.65rem;color:#fff6}.cs-passive-perception{margin-top:1rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:#ffffffb3}.cs-pp-value{font-weight:600;color:#fff;background:#ffffff1a;padding:.25rem .5rem;border-radius:.25rem}.cs-features-list{display:flex;flex-direction:column;gap:.75rem;max-height:200px;overflow-y:auto}.cs-feature{padding:.5rem;background:#0003;border-radius:.375rem;border-left:3px solid #d4a574}.cs-feature-header{display:flex;justify-content:space-between;align-items:center}.cs-feature-name{font-weight:600;color:#fff;font-size:.85rem}.cs-feature-desc{font-size:.75rem;color:#fff9;line-height:1.4}.cs-proficiencies{display:flex;flex-direction:column;gap:.5rem}.cs-prof-group{font-size:.75rem;color:#ffffffb3}.cs-prof-label{font-weight:600;color:#ffffff80;margin-right:.25rem}.cs-empty{font-size:.8rem;color:#fff6;font-style:italic}.cs-equipment-list{display:flex;flex-direction:column;gap:.375rem;max-height:200px;overflow-y:auto}.cs-spellcasting-stats{display:flex;gap:.75rem;margin-bottom:1rem}.cs-spell-stat{flex:1;text-align:center;padding:.5rem;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:.375rem}.cs-spell-stat-label{display:block;font-size:.6rem;text-transform:uppercase;letter-spacing:.05em;color:#8b5cf6cc;margin-bottom:.25rem}.cs-spell-stat-value{font-size:1rem;font-weight:600;color:#fff}.cs-spell-level{margin-bottom:.75rem}.cs-spell-level h4{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:#8b5cf6cc;margin:0 0 .5rem}.cs-spell-list{display:flex;flex-wrap:wrap;gap:.375rem}.cs-spell-tag{padding:.25rem .5rem;background:#8b5cf626;border:1px solid rgba(139,92,246,.3);border-radius:.25rem;font-size:.75rem;color:#ffffffe6}.cs-story-field{margin-bottom:1rem}.cs-story-field label{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:#d4a574;margin-bottom:.375rem}.cs-story-field p{font-size:.85rem;color:#fffc;line-height:1.5;margin:0}.cs-story-field textarea{width:100%;background:#0000004d;border:1px solid rgba(255,255,255,.15);border-radius:.375rem;color:#fff;font-size:.85rem;padding:.5rem;resize:vertical;font-family:inherit}.cs-story-field textarea:focus{outline:none;border-color:#d4a57480}.cs-add-row{display:flex;gap:.5rem;margin-top:.75rem}.cs-add-row input{flex:1;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:.375rem;color:#fff;font-size:.8rem;padding:.5rem .75rem}.cs-add-row input:focus{outline:none;border-color:#d4a57480}.cs-add-row.small input{padding:.375rem .5rem;font-size:.75rem}.cs-add-btn{width:32px;height:32px;background:#4ade8033;border:1px solid rgba(74,222,128,.4);border-radius:.375rem;color:#4ade80;font-size:1.25rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.cs-add-btn:hover{background:#4ade804d;border-color:#4ade80}.cs-remove-btn{width:20px;height:20px;padding:0;background:#f8717133;border:1px solid rgba(248,113,113,.3);border-radius:4px;color:#f87171;font-size:.875rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.cs-remove-btn:hover{background:#f8717166;border-color:#f87171}.cs-prof-tags{display:flex;flex-wrap:wrap;gap:.375rem;align-items:center}.cs-tag{display:inline-flex;align-items:center;gap:.25rem;padding:.125rem .5rem;background:#ffffff1a;border-radius:.25rem;font-size:.75rem;color:#ffffffe6}.cs-tag button{background:none;border:none;color:#ffffff80;cursor:pointer;padding:0;font-size:.875rem;line-height:1}.cs-tag button:hover{color:#f87171}.cs-tag-input{background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:.25rem;color:#fff;font-size:.75rem;padding:.125rem .375rem;width:80px}.cs-tag-input:focus{outline:none;border-color:#d4a57480}.cs-equipment-item{display:flex;justify-content:space-between;align-items:center;padding:.375rem .5rem;background:#0003;border-radius:.25rem;font-size:.8rem;color:#fffc}.cs-spell-select{background:#1e1e28f2;border:1px solid rgba(139,92,246,.3);border-radius:.25rem;color:#fff;font-size:.875rem;padding:.25rem;cursor:pointer}.cs-spell-select option{background:#1e1e28;color:#ffffffe6}.cs-spell-select:focus{outline:none;border-color:#8b5cf699}.cs-empty-inline{font-size:.75rem;color:#fff6;font-style:italic}.cs-ability-score.clickable,.cs-ability-mod.clickable{cursor:pointer;transition:all .15s ease}.cs-ability-score.clickable:hover,.cs-ability-mod.clickable:hover{color:#d4a574;transform:scale(1.1);text-shadow:0 0 8px rgba(212,165,116,.5)}.cs-ability-save.clickable{cursor:pointer}.cs-ability-save.clickable:hover{background:#d4a57433;border-color:#d4a57480}.cs-skill-row.rollable{cursor:pointer;transition:all .15s ease}.cs-skill-row.rollable:hover{background:#d4a57426;padding-left:.75rem}.cs-skill-row.rollable:hover .cs-skill-bonus{color:#d4a574;font-weight:700}.cs-stat-block.rollable{cursor:pointer;transition:all .15s ease}.cs-stat-block.rollable:hover{background:#d4a57426;border-color:#d4a57466;transform:scale(1.05)}.cs-stat-block.rollable:hover .cs-stat-value{color:#d4a574}.cs-weapons-section{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}.cs-weapons-list{display:flex;flex-direction:column;gap:.5rem}.cs-weapon-row{display:grid;grid-template-columns:1fr auto auto;gap:.5rem;align-items:center;padding:.5rem;background:#0003;border-radius:.375rem;border:1px solid rgba(255,255,255,.05)}.cs-weapon-name{font-size:.85rem;font-weight:500;color:#fff}.cs-weapon-attack,.cs-weapon-damage{padding:.375rem .625rem;font-size:.8rem;font-weight:600;border-radius:.25rem;border:1px solid transparent;background:#ffffff0d;color:#ffffffb3;transition:all .15s ease}.cs-weapon-attack.rollable,.cs-weapon-damage.rollable{cursor:pointer;background:#d4a5741a;border-color:#d4a5744d;color:#d4a574}.cs-weapon-attack.rollable:hover,.cs-weapon-damage.rollable:hover{background:#d4a57440;border-color:#d4a57499;transform:scale(1.05)}.cs-weapon-attack:disabled,.cs-weapon-damage:disabled{cursor:default;opacity:.6}.cs-damage-type{display:block;font-size:.6rem;font-weight:400;color:#ffffff80;text-transform:lowercase}.cs-edit-hint{font-size:.7rem;color:#fff6;font-style:italic;margin-top:.5rem}@media (max-width: 1024px){.cs-content{grid-template-columns:180px 180px 1fr}.cs-right-column{grid-column:1 / -1;display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}}@media (max-width: 768px){.cs-section-tabs{display:flex}.cs-content{display:block;padding:1rem}.cs-section{display:none;margin-bottom:1rem}.cs-section.active,.cs-right-column{display:block}.cs-right-column .cs-section{display:none}.cs-right-column .cs-section.active{display:block}.cs-ability-grid{grid-template-columns:repeat(3,1fr)}.cs-header-bar{flex-direction:column;gap:.75rem;align-items:stretch}.cs-header-actions{justify-content:flex-end}.cs-name-input{width:100%}.cs-identity-bar{padding:.75rem 1rem;gap:.75rem}.cs-identity-field{flex:1;min-width:70px}.cs-modal-container{max-height:95vh;width:95%}}@media (max-width: 480px){.cs-ability-grid,.cs-combat-stats{grid-template-columns:repeat(2,1fr)}.cs-stat-block:nth-child(3){grid-column:1 / -1}}.character-card{background:#ffffff0d;border:1px solid rgba(212,165,116,.2);border-radius:.75rem;padding:1rem;cursor:pointer;transition:all .2s}.character-card:hover{background:#ffffff14;border-color:#d4a57466;transform:translateY(-2px)}.cc-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.cc-header-right{display:flex;align-items:center;gap:.5rem}.cc-delete-btn{width:24px;height:24px;padding:0;background:#f871711a;border:1px solid rgba(248,113,113,.3);border-radius:4px;color:#f87171;font-size:1rem;font-weight:700;line-height:1;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.cc-delete-btn:hover{background:#f871714d;border-color:#f87171}.cc-name{margin:0;font-size:1.125rem;color:#d4a574;font-family:var(--font-display, serif)}.cc-level{background:#d4a57433;color:#d4a574;padding:.125rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:600}.cc-subtitle{margin:0 0 .75rem;color:#fff9;font-size:.875rem}.cc-stats{display:flex;gap:1rem;margin-bottom:.75rem;flex-wrap:wrap}.cc-stat{display:flex;flex-direction:column;gap:.125rem}.cc-stat-label{font-size:.625rem;color:#fff6;text-transform:uppercase}.cc-stat-value{font-size:1rem;font-weight:600;color:#fff}.cc-abilities{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.1)}.cc-ability{text-align:center}.cc-ability-name{display:block;font-size:.5rem;color:#fff6;text-transform:uppercase}.cc-ability-value{font-size:.875rem;font-weight:600;color:#d4a574}@media (max-width: 600px){.cc-abilities{grid-template-columns:repeat(3,1fr)}}.cs-feature-source{display:inline-block;padding:.125rem .375rem;font-size:.625rem;font-weight:600;text-transform:uppercase;border-radius:.25rem;letter-spacing:.025em}.cs-feature-source.species,.cs-feature-source.subrace{background:#22c55e33;color:#4ade80}.cs-feature-source.class{background:#d4a57433;color:#d4a574}.cs-feature-source.subclass{background:#8b5cf633;color:#a78bfa}.cs-feature-level{font-size:.625rem;color:#fff6;font-weight:500}.cs-skill-row.expertise .cs-skill-prof{color:#fbbf24;font-weight:700}.cs-skill-row.expertise{background:#fbbf241a}.cs-spell-slots{margin-top:1rem;padding:.75rem;background:#0003;border-radius:.5rem}.cs-spell-slots h4{margin:0 0 .75rem;font-size:.875rem;font-weight:600;color:#ffffffe6;text-transform:uppercase;letter-spacing:.05em}.cs-slot-level{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.cs-slot-level-label{font-size:.75rem;font-weight:600;color:#ffffffb3;min-width:4rem}.cs-slot-boxes{flex:1}.cs-slot-controls{display:flex;align-items:center;gap:.5rem}.cs-slot-input{width:3rem;padding:.25rem .5rem;background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:.25rem;color:#fff;font-size:.875rem;text-align:center}.cs-slot-separator{color:#fff6;font-size:.875rem}.cs-slot-tracker{display:flex;gap:.375rem;flex-wrap:wrap}.cs-slot-box{width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border:2px solid #d4a574;border-radius:.25rem;background:#d4a5741a;color:#d4a574;font-size:1rem;cursor:pointer;transition:all .2s}.cs-slot-box:hover{background:#d4a57433;transform:scale(1.05)}.cs-slot-box.used{background:#ef444433;border-color:#ef4444;color:#ef4444}.cs-slot-box.used:hover{background:#ef44444d}.cs-slot-box.available{background:#22c55e1a;border-color:#22c55e;color:#22c55e}.cs-slot-box.available:hover{background:#22c55e33}.turn-system{background:#141428f2;border:1px solid rgba(100,100,200,.3);border-radius:8px;padding:16px;margin-bottom:16px}.turn-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(100,100,200,.2)}.turn-title{font-size:18px;font-weight:600;color:#e0e0ff;display:flex;align-items:center;gap:8px}.turn-icon{font-size:20px}.turn-status .processing{color:orange;font-weight:500;animation:pulse 1.5s ease-in-out infinite}.turn-status .ready-count{color:#90ee90;font-weight:500}.player-ready-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.player-ready-indicator{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:6px;background:#28283c80;border:2px solid transparent;transition:all .2s ease}.player-ready-indicator.me{background:#3c3c64b3;border-color:#7878c866}.player-ready-indicator.ready{background:#28502899;border-color:#64c86466}.player-ready-indicator.submitted{background:#50502899;border-color:#c8c86466}.player-ready-indicator.waiting{opacity:.6}.player-name{font-weight:500;color:#e0e0ff}.status-icon{font-size:18px;font-weight:700}.player-ready-indicator.ready .status-icon{color:#90ee90}.player-ready-indicator.submitted .status-icon{color:gold}.waiting-dot{color:#c8c8c866}.turn-input-section{margin-bottom:16px}.turn-input-section label{display:block;margin-bottom:8px;color:#b0b0d0;font-weight:500}.turn-input-section textarea{width:100%;padding:12px;background:#1e1e32cc;border:1px solid rgba(100,100,200,.3);border-radius:6px;color:#e0e0ff;font-family:inherit;font-size:14px;resize:vertical;min-height:80px;box-sizing:border-box}.turn-input-section textarea:focus{outline:none;border-color:#7878dc99;background:#28283ce6}.turn-input-section textarea:disabled{opacity:.5;cursor:not-allowed}.turn-buttons{display:flex;gap:8px;margin-top:8px}.submit-action-btn,.ready-btn{flex:1;padding:10px 16px;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease}.submit-action-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.submit-action-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.submit-action-btn:disabled{background:#6464644d;color:#c8c8c880;cursor:not-allowed}.ready-btn{background:linear-gradient(135deg,#56ab2f,#a8e063);color:#fff}.ready-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #56ab2f66}.ready-btn:disabled{background:#6464644d;color:#c8c8c880;cursor:not-allowed}.current-action{background:#28502866;border:1px solid rgba(100,200,100,.3);border-radius:6px;padding:12px;margin-bottom:16px}.current-action-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.current-action-header strong{color:#90ee90}.edit-action-btn{padding:4px 12px;background:#6464c84d;border:1px solid rgba(120,120,220,.5);border-radius:4px;color:#e0e0ff;font-size:12px;cursor:pointer;transition:all .2s ease}.edit-action-btn:hover:not(:disabled){background:#7878dc66}.edit-action-btn:disabled{opacity:.5;cursor:not-allowed}.action-text{color:#d0d0e0;margin:0;font-style:italic;line-height:1.5}.gm-turn-controls{margin-top:16px;padding-top:16px;border-top:1px solid rgba(100,100,200,.2)}.process-turn-btn{width:100%;padding:12px 16px;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;border-radius:6px;font-weight:600;font-size:16px;cursor:pointer;transition:all .2s ease}.process-turn-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f093fb66}.process-turn-btn.auto{background:linear-gradient(135deg,#56ab2f,#a8e063);animation:pulse-glow 2s ease-in-out infinite}.turn-info{background:#6464c81a;border:1px solid rgba(100,100,200,.2);border-radius:6px;padding:10px 12px;color:#b0b0d0;font-size:13px;line-height:1.4}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes pulse-glow{0%,to{box-shadow:0 4px 12px #56ab2f66}50%{box-shadow:0 4px 20px #56ab2fb3}}@media (max-width: 768px){.turn-buttons{flex-direction:column}.submit-action-btn,.ready-btn{width:100%}}.ruleset-selector{margin-bottom:var(--spacing-xl, 1.5rem)}.ruleset-label{display:block;font-family:var(--font-display, "Cinzel", serif);font-size:1.125rem;font-weight:600;color:var(--color-accent-gold, #d4a574);margin-bottom:var(--spacing-xs, .25rem)}.ruleset-description{font-size:.875rem;color:var(--color-text-muted, rgba(255, 255, 255, .6));margin:0 0 var(--spacing-md, 1rem) 0}.ruleset-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-md, 1rem)}.ruleset-option{position:relative;display:flex;flex-direction:column;align-items:flex-start;padding:var(--spacing-lg, 1.25rem);background:var(--color-bg-medium, rgba(255, 255, 255, .05));border:2px solid var(--color-border, rgba(255, 255, 255, .1));border-radius:var(--radius-lg, .75rem);cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.ruleset-option:hover:not(:disabled){border-color:var(--color-accent-purple, #8b5cf6);background:#8b5cf61a}.ruleset-option.selected{border-color:var(--color-accent-purple, #8b5cf6);background:#8b5cf626;box-shadow:0 0 20px #8b5cf633}.ruleset-option.coming-soon{opacity:.6;cursor:not-allowed}.ruleset-option.coming-soon:hover{border-color:var(--color-border, rgba(255, 255, 255, .1));background:var(--color-bg-medium, rgba(255, 255, 255, .05))}.ruleset-option-header{display:flex;align-items:center;gap:var(--spacing-sm, .5rem);margin-bottom:var(--spacing-sm, .5rem);flex-wrap:wrap}.ruleset-name{font-family:var(--font-display, "Cinzel", serif);font-size:1.125rem;font-weight:600;color:var(--color-text-primary, rgba(255, 255, 255, .95))}.ruleset-subtitle{font-size:.75rem;padding:.125rem .5rem;background:#8b5cf633;color:var(--color-accent-purple, #a78bfa);border-radius:var(--radius-sm, .25rem);text-transform:uppercase;letter-spacing:.05em}.ruleset-badge{font-size:.625rem;padding:.125rem .5rem;background:#eab30833;color:#fbbf24;border-radius:var(--radius-sm, .25rem);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.ruleset-option-desc{font-size:.875rem;color:var(--color-text-secondary, rgba(255, 255, 255, .7));margin:0 0 var(--spacing-md, 1rem) 0;line-height:1.5}.ruleset-features{list-style:none;padding:0;margin:0;font-size:.8125rem;color:var(--color-text-muted, rgba(255, 255, 255, .6))}.ruleset-features li{position:relative;padding-left:1.25rem;margin-bottom:.25rem}.ruleset-features li:before{content:"✦";position:absolute;left:0;color:var(--color-accent-purple, #a78bfa);font-size:.625rem}.ruleset-check{position:absolute;top:var(--spacing-md, 1rem);right:var(--spacing-md, 1rem);width:24px;height:24px;background:var(--color-accent-purple, #8b5cf6);border-radius:50%;display:flex;align-items:center;justify-content:center}.ruleset-check svg{width:14px;height:14px;color:#fff}@media (max-width: 640px){.ruleset-options{grid-template-columns:1fr}}.character-creation{min-height:100vh;background:var(--color-bg-dark);display:flex;flex-direction:column}.creation-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-xl);background:var(--color-bg-medium);border-bottom:1px solid var(--color-border)}.creation-header-left{display:flex;align-items:center;gap:var(--spacing-md)}.creation-header h1{font-family:var(--font-display);font-size:1.25rem;color:var(--color-accent-gold);margin:0}.creation-layout{display:flex;flex:1;overflow:hidden}.creation-sidebar{width:280px;background:var(--color-bg-medium);border-right:1px solid var(--color-border);display:flex;flex-direction:column;padding:var(--spacing-xl) 0}.progress-steps{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:0 var(--spacing-md)}.progress-step{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;text-align:left;color:var(--color-text-muted)}.progress-step:hover:not(:disabled){background:var(--color-bg-light)}.progress-step:disabled{cursor:not-allowed;opacity:.5}.progress-step.active{background:#d4a84626;color:var(--color-accent-gold)}.progress-step.completed{color:var(--color-accent-green)}.step-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-light);border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:1.25rem;transition:all .2s ease}.progress-step.active .step-icon{background:var(--color-accent-gold);border-color:var(--color-accent-gold);color:var(--color-bg-dark)}.progress-step.completed .step-icon{background:var(--color-accent-green);border-color:var(--color-accent-green);color:var(--color-bg-dark)}.step-info{flex:1;min-width:0}.step-title{font-weight:600;font-size:.875rem;margin-bottom:2px}.step-subtitle{font-size:.75rem;opacity:.7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-preview{margin-top:auto;padding:var(--spacing-md);border-top:1px solid var(--color-border)}.preview-card{background:var(--color-bg-light);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.preview-card-header{background:linear-gradient(135deg,#d4a84633,#d4a8460d);padding:var(--spacing-md);border-bottom:1px solid var(--color-border)}.preview-card-header h3{font-family:var(--font-display);font-size:1rem;color:var(--color-accent-gold);margin:0 0 var(--spacing-xs)}.preview-card-header p{font-size:.75rem;color:var(--color-text-secondary);margin:0}.preview-card-body{padding:var(--spacing-sm)}.preview-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-xs)}.preview-stat{text-align:center;padding:var(--spacing-xs);background:var(--color-bg-medium);border-radius:var(--radius-sm)}.preview-stat-value{font-size:1rem;font-weight:700;color:var(--color-text-primary)}.preview-stat-label{font-size:.625rem;color:var(--color-text-muted);text-transform:uppercase}.preview-stat.hp .preview-stat-value{color:var(--color-accent-red)}.preview-stat.ac .preview-stat-value{color:var(--color-accent-blue)}.preview-stat.speed .preview-stat-value{color:var(--color-accent-green)}.creation-main{flex:1;overflow-y:auto;padding:var(--spacing-2xl);background:linear-gradient(180deg,var(--color-bg-dark) 0%,var(--color-bg-medium) 100%)}.creation-step{max-width:800px;margin:0 auto;animation:stepFadeIn .4s ease}@keyframes stepFadeIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.step-header{margin-bottom:var(--spacing-2xl)}.step-header h2{font-family:var(--font-display);font-size:2rem;color:var(--color-accent-gold);margin:0 0 var(--spacing-sm)}.step-header p{font-size:1rem;color:var(--color-text-secondary);margin:0;line-height:1.6}.name-input-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;text-align:center}.name-input-container .step-header{margin-bottom:var(--spacing-xl)}.character-name-input{width:100%;max-width:450px;padding:var(--spacing-lg) var(--spacing-xl);font-family:var(--font-display);font-size:1.75rem;text-align:center;background:var(--color-bg-medium);border:2px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-primary);transition:all .3s ease}.character-name-input::placeholder{color:var(--color-text-muted);font-family:var(--font-body);font-size:1rem}.character-name-input:focus{outline:none;border-color:var(--color-accent-gold);box-shadow:0 0 0 4px #d4a84626,0 8px 32px #0000004d}.selection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.selection-grid.large{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.selection-card{position:relative;display:flex;flex-direction:column;background:var(--color-bg-medium);border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);cursor:pointer;transition:all .25s ease;overflow:hidden}.selection-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:transparent;transition:background .25s ease}.selection-card:hover{transform:translateY(-4px);border-color:var(--color-text-muted);box-shadow:0 8px 24px #0000004d}.selection-card.selected{border-color:var(--color-accent-gold);background:linear-gradient(180deg,rgba(212,168,70,.1) 0%,var(--color-bg-medium) 100%)}.selection-card.selected:before{background:var(--color-accent-gold)}.card-icon{font-size:2.5rem;margin-bottom:var(--spacing-sm);filter:grayscale(.3);transition:filter .25s ease}.selection-card:hover .card-icon,.selection-card.selected .card-icon{filter:grayscale(0)}.card-name{font-weight:600;font-size:1rem;color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.card-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:auto}.card-tag{font-size:.625rem;padding:2px 6px;background:var(--color-bg-light);border-radius:var(--radius-sm);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em}.card-tag.highlight{background:#d4a84633;color:var(--color-accent-gold)}.selection-check{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);width:24px;height:24px;background:var(--color-accent-gold);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.5);transition:all .25s ease}.selection-card.selected .selection-check{opacity:1;transform:scale(1)}.selection-check svg{width:14px;height:14px;color:var(--color-bg-dark)}.details-panel{background:var(--color-bg-medium);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--spacing-xl);overflow:hidden;animation:panelSlideIn .3s ease}@keyframes panelSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.details-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:linear-gradient(90deg,rgba(212,168,70,.1) 0%,transparent 100%);border-bottom:1px solid var(--color-border)}.details-icon{font-size:2rem}.details-title h3{font-family:var(--font-display);font-size:1.25rem;color:var(--color-accent-gold);margin:0 0 var(--spacing-xs)}.details-title p{font-size:.875rem;color:var(--color-text-secondary);margin:0}.details-body{padding:var(--spacing-lg)}.details-description{color:var(--color-text-secondary);line-height:1.7;margin-bottom:var(--spacing-lg)}.stats-row{display:flex;gap:var(--spacing-xl);padding:var(--spacing-md);background:var(--color-bg-light);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg)}.stat-item{text-align:center}.stat-item .stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text-primary)}.stat-item .stat-label{font-size:.625rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.traits-section h4{font-size:.875rem;color:var(--color-accent-gold);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--spacing-md)}.traits-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.trait-item{display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-light);border-radius:var(--radius-md);border-left:3px solid var(--color-accent-gold)}.trait-name{font-weight:600;color:var(--color-text-primary);white-space:nowrap}.trait-desc{color:var(--color-text-secondary);font-size:.875rem}.sub-choice-section{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.sub-choice-section h4{font-size:.875rem;color:var(--color-text-primary);margin:0 0 var(--spacing-md)}.sub-choice-grid{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.sub-choice-btn{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-light);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease}.sub-choice-btn:hover{background:var(--color-bg-elevated);border-color:var(--color-text-muted)}.sub-choice-btn.selected{background:#d4a84633;border-color:var(--color-accent-gold);color:var(--color-accent-gold)}.skill-selection-section{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.skill-selection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.skill-selection-header h4{font-size:.875rem;color:var(--color-text-primary);margin:0}.skill-counter{font-size:.75rem;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-light);border-radius:var(--radius-sm);color:var(--color-text-muted)}.skill-counter.complete{background:#4ade8033;color:var(--color-accent-green)}.skill-grid{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.skill-btn{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-light);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease}.skill-btn:hover:not(:disabled){background:var(--color-bg-elevated)}.skill-btn.selected{background:#4ade8026;border-color:var(--color-accent-green);color:var(--color-accent-green)}.skill-btn:disabled{opacity:.4;cursor:not-allowed}.ability-method-tabs{display:flex;background:var(--color-bg-light);border-radius:var(--radius-lg);padding:var(--spacing-xs);margin-bottom:var(--spacing-xl)}.method-tab{flex:1;padding:var(--spacing-md);background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;transition:all .2s ease;font-weight:500}.method-tab:hover{color:var(--color-text-primary)}.method-tab.active{background:var(--color-accent-gold);color:var(--color-bg-dark)}.ability-method-info{padding:var(--spacing-md);background:var(--color-bg-light);border-radius:var(--radius-md);margin-bottom:var(--spacing-xl);color:var(--color-text-secondary);font-size:.875rem}.ability-assignment-grid{display:grid;gap:var(--spacing-md);max-width:500px}.ability-assign-row{display:grid;grid-template-columns:140px 1fr 60px;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm);background:var(--color-bg-medium);border-radius:var(--radius-md)}.ability-label{font-weight:500;color:var(--color-text-primary)}.ability-select{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-light);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);cursor:pointer}.ability-select:focus{outline:none;border-color:var(--color-accent-gold)}.ability-modifier-display{text-align:center;font-weight:600;color:var(--color-accent-gold);font-size:1.125rem}.points-display{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-light);border-radius:var(--radius-md);margin-bottom:var(--spacing-xl)}.points-label{color:var(--color-text-secondary)}.points-value{font-size:1.5rem;font-weight:700;color:var(--color-accent-gold)}.points-value.low{color:var(--color-accent-amber)}.points-value.empty{color:var(--color-accent-red)}.ability-adjuster-grid{display:grid;gap:var(--spacing-md);max-width:500px}.ability-adjuster-row{display:grid;grid-template-columns:140px 1fr 80px;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-medium);border-radius:var(--radius-md)}.adjuster-controls{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.adjuster-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-light);border:1px solid var(--color-border);border-radius:50%;color:var(--color-text-primary);font-size:1.25rem;cursor:pointer;transition:all .2s ease}.adjuster-btn:hover:not(:disabled){background:var(--color-bg-elevated);border-color:var(--color-accent-gold)}.adjuster-btn:disabled{opacity:.3;cursor:not-allowed}.adjuster-value{width:50px;text-align:center;font-size:1.5rem;font-weight:700;color:var(--color-text-primary)}.adjuster-cost{text-align:center}.adjuster-cost span{display:block;font-size:.75rem;color:var(--color-text-muted)}.roll-section{text-align:center}.roll-button{padding:var(--spacing-md) var(--spacing-2xl);font-size:1rem;margin-bottom:var(--spacing-xl)}.rolled-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);max-width:400px;margin:0 auto}.rolled-stat-card{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-md);background:var(--color-bg-medium);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.rolled-stat-card .stat-abbr{font-size:.625rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-xs)}.rolled-stat-card .stat-value{font-size:2rem;font-weight:700;color:var(--color-text-primary)}.rolled-stat-card .stat-mod{font-size:.875rem;color:var(--color-accent-gold)}.review-card{background:var(--color-bg-medium);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden}.review-header{background:linear-gradient(135deg,#d4a84633,#d4a8460d);padding:var(--spacing-xl);text-align:center;border-bottom:2px solid var(--color-accent-gold)}.review-header h3{font-family:var(--font-display);font-size:2rem;color:var(--color-text-primary);margin:0 0 var(--spacing-xs)}.review-header .character-class{font-size:1.125rem;color:var(--color-accent-gold)}.review-body{padding:var(--spacing-xl)}.review-section{margin-bottom:var(--spacing-xl)}.review-section:last-child{margin-bottom:0}.review-section h4{font-size:.75rem;color:var(--color-accent-gold);text-transform:uppercase;letter-spacing:.1em;margin:0 0 var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.review-abilities{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--spacing-sm)}.review-ability{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-sm);background:var(--color-bg-light);border-radius:var(--radius-md)}.review-ability .ability-abbr{font-size:.625rem;color:var(--color-text-muted);text-transform:uppercase}.review-ability .ability-score{font-size:1.25rem;font-weight:700;color:var(--color-text-primary)}.review-ability .ability-mod{font-size:.75rem;color:var(--color-accent-gold)}.review-combat-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-sm)}.review-combat-stat{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-md);background:var(--color-bg-light);border-radius:var(--radius-md)}.review-combat-stat .stat-value{font-size:1.5rem;font-weight:700}.review-combat-stat .stat-label{font-size:.625rem;color:var(--color-text-muted);text-transform:uppercase}.review-combat-stat.hp .stat-value{color:var(--color-accent-red)}.review-combat-stat.ac .stat-value{color:var(--color-accent-blue)}.review-combat-stat.speed .stat-value{color:var(--color-accent-green)}.review-combat-stat.hitdie .stat-value{color:var(--color-accent-purple)}.review-proficiencies p{color:var(--color-text-secondary);margin:var(--spacing-sm) 0;font-size:.875rem}.review-proficiencies strong{color:var(--color-text-primary)}.equipment-choices{display:flex;flex-direction:column;gap:var(--spacing-xl)}.equipment-choice-group h4{font-size:.875rem;color:var(--color-text-primary);margin:0 0 var(--spacing-md)}.equipment-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md)}.equipment-option{position:relative;display:flex;flex-direction:column;padding:var(--spacing-md);background:var(--color-bg-medium);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;text-align:left}.equipment-option:hover{border-color:var(--color-text-muted);background:var(--color-bg-light)}.equipment-option.selected{border-color:var(--color-accent-gold);background:#d4a8461a}.equipment-option .selection-check{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);width:20px;height:20px;background:var(--color-accent-gold);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.5);transition:all .2s ease}.equipment-option.selected .selection-check{opacity:1;transform:scale(1)}.equipment-option .selection-check svg{width:12px;height:12px;color:var(--color-bg-dark)}.equipment-option-content{display:flex;flex-direction:column;gap:var(--spacing-xs)}.equipment-item{color:var(--color-text-secondary);font-size:.875rem}.equipment-item:before{content:"• ";color:var(--color-accent-gold)}.equipment-fixed-list{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.equipment-fixed-item{padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-light);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:.875rem}.weapon-selector{display:flex;flex-direction:column;gap:var(--spacing-xs);width:100%}.weapon-selector .equipment-item{color:var(--color-accent-gold);font-weight:500}.weapon-select{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-dark);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:.875rem;cursor:pointer;transition:all .2s ease;width:100%}.weapon-select:hover{border-color:var(--color-accent-gold)}.weapon-select:focus{outline:none;border-color:var(--color-accent-gold);box-shadow:0 0 0 2px #d4a84633}.weapon-select option{background:var(--color-bg-dark);color:var(--color-text-primary);padding:var(--spacing-sm)}.spell-selection-section{margin-bottom:var(--spacing-2xl)}.spell-selection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.spell-selection-header h3{font-family:var(--font-display);font-size:1.25rem;color:var(--color-accent-gold);margin:0}.spell-selection-header h4{font-family:var(--font-display);font-size:1rem;color:var(--color-text-primary);margin:0}.spell-counter{font-size:.875rem;padding:var(--spacing-xs) var(--spacing-md);background:var(--color-bg-light);border-radius:var(--radius-md);color:var(--color-text-muted)}.spell-counter.complete{background:#4ade8033;color:var(--color-accent-green)}.spell-counter-small{font-size:.75rem;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-medium);border-radius:var(--radius-sm);color:var(--color-text-muted)}.spell-counter-small.complete{background:#4ade8033;color:var(--color-accent-green)}.mystic-arcanum-section{border-left:3px solid var(--color-accent-purple);padding-left:var(--spacing-md);margin-left:var(--spacing-sm)}.mystic-arcanum-section .spell-selection-header h4{color:var(--color-accent-purple)}.spell-note{font-size:.875rem;color:var(--color-text-muted);font-style:italic;margin-bottom:var(--spacing-md)}.spell-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-md)}.spell-card{position:relative;display:flex;flex-direction:column;padding:var(--spacing-md);background:var(--color-bg-medium);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;text-align:left}.spell-card:hover:not(:disabled){border-color:var(--color-accent-purple);transform:translateY(-2px);box-shadow:0 4px 12px #c084fc33}.spell-card.selected{border-color:var(--color-accent-purple);background:#c084fc1a}.spell-card:disabled{opacity:.5;cursor:not-allowed}.spell-card .selection-check{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);width:20px;height:20px;background:var(--color-accent-purple);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.5);transition:all .2s ease}.spell-card.selected .selection-check{opacity:1;transform:scale(1)}.spell-card .selection-check svg{width:12px;height:12px;color:var(--color-bg-dark)}.spell-name{font-weight:600;color:var(--color-text-primary);font-size:1rem;margin-bottom:var(--spacing-xs);display:flex;align-items:center;gap:var(--spacing-sm)}.spell-ritual{font-size:.625rem;padding:2px 4px;background:#60a5fa33;color:var(--color-accent-blue);border-radius:var(--radius-sm);font-weight:700}.spell-school{font-size:.75rem;color:var(--color-accent-purple);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-sm)}.spell-desc{font-size:.8125rem;color:var(--color-text-secondary);line-height:1.5}.step-actions{display:flex;justify-content:space-between;gap:var(--spacing-md);margin-top:var(--spacing-2xl);padding-top:var(--spacing-xl);border-top:1px solid var(--color-border)}.step-actions .btn{min-width:140px}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--color-bg-dark)}.loading-spinner{width:48px;height:48px;border:3px solid var(--color-border);border-top-color:var(--color-accent-gold);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto var(--spacing-md)}.loading-content p{color:var(--color-text-secondary)}.error-banner{padding:var(--spacing-md);background:#c9444426;border:1px solid rgba(201,68,68,.3);border-radius:var(--radius-md);color:var(--color-accent-red-light);margin-bottom:var(--spacing-lg)}@media (max-width: 1024px){.creation-sidebar{width:80px}.step-info{display:none}.progress-step{justify-content:center;padding:var(--spacing-sm)}.sidebar-preview{display:none}}@media (max-width: 768px){.creation-layout{flex-direction:column}.creation-sidebar{width:100%;flex-direction:row;padding:var(--spacing-sm);overflow-x:auto}.progress-steps{flex-direction:row;padding:0}.progress-step{flex-direction:column;padding:var(--spacing-sm);gap:var(--spacing-xs)}.step-icon{width:32px;height:32px;font-size:1rem}.creation-main{padding:var(--spacing-lg)}.selection-grid{grid-template-columns:repeat(2,1fr)}.review-abilities{grid-template-columns:repeat(3,1fr)}.review-combat-stats,.rolled-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.selection-grid{grid-template-columns:1fr}.ability-assign-row,.ability-adjuster-row{grid-template-columns:1fr;text-align:center}.step-actions{flex-direction:column}.step-actions .btn{width:100%}}.personality-form{display:flex;flex-direction:column;gap:var(--spacing-xl);max-width:700px}.personality-field{display:flex;flex-direction:column;gap:var(--spacing-sm)}.personality-field label{font-weight:600;font-size:1rem;color:var(--color-accent-gold)}.personality-field textarea{width:100%;padding:var(--spacing-md);background:var(--color-bg-medium);border:2px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-body);font-size:.9375rem;line-height:1.6;resize:vertical;min-height:80px;transition:border-color .2s ease,box-shadow .2s ease}.personality-field textarea:focus{outline:none;border-color:var(--color-accent-gold);box-shadow:0 0 0 3px #d4a84626}.personality-field textarea::placeholder{color:var(--color-text-muted);font-style:italic}.field-hint{font-size:.8125rem;color:var(--color-text-muted);font-style:italic}.personality-tip{margin-top:var(--spacing-xl);padding:var(--spacing-md);background:#d4a8461a;border:1px solid rgba(212,168,70,.2);border-radius:var(--radius-md);font-size:.875rem;color:var(--color-text-secondary)}.personality-tip strong{color:var(--color-accent-gold)}.review-personality p{margin:var(--spacing-sm) 0;font-size:.875rem;color:var(--color-text-secondary);line-height:1.5}.review-personality strong{color:var(--color-text-primary)}.level-selector-container{display:flex;flex-direction:column;gap:var(--spacing-xl);max-width:600px;margin-bottom:var(--spacing-2xl)}.level-slider-wrapper{display:flex;flex-direction:column;gap:var(--spacing-md)}.level-slider{-webkit-appearance:none;appearance:none;width:100%;height:12px;background:var(--color-bg-light);border-radius:var(--radius-full);outline:none;cursor:pointer}.level-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:28px;height:28px;background:var(--color-accent-gold);border-radius:50%;cursor:grab;box-shadow:0 2px 8px #0000004d;transition:transform .15s ease,box-shadow .15s ease}.level-slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 4px 12px #d4a84666}.level-slider::-webkit-slider-thumb:active{cursor:grabbing}.level-slider::-moz-range-thumb{width:28px;height:28px;background:var(--color-accent-gold);border:none;border-radius:50%;cursor:grab;box-shadow:0 2px 8px #0000004d}.level-markers{display:flex;justify-content:space-between;padding:0 var(--spacing-sm)}.level-marker{font-size:.75rem;color:var(--color-text-muted);cursor:pointer;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);transition:all .2s ease}.level-marker:hover{color:var(--color-accent-gold);background:var(--color-bg-light)}.level-marker.passed{color:var(--color-accent-gold);font-weight:600}.level-display-card{display:flex;align-items:center;gap:var(--spacing-xl);padding:var(--spacing-xl);background:linear-gradient(135deg,#d4a84626,#d4a8460d);border:1px solid var(--color-accent-gold);border-radius:var(--radius-lg)}.level-number{display:flex;flex-direction:column;align-items:center;padding-right:var(--spacing-xl);border-right:1px solid var(--color-border)}.level-value{font-family:var(--font-display);font-size:3.5rem;font-weight:700;color:var(--color-accent-gold);line-height:1}.level-label{font-size:.875rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.level-stats{display:flex;gap:var(--spacing-xl);flex:1;justify-content:center}.level-stat{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs)}.level-stat .stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text-primary)}.level-stat .stat-label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase}.level-unlocks{background:var(--color-bg-medium);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl)}.level-unlocks h3{font-family:var(--font-display);font-size:1.25rem;color:var(--color-accent-gold);margin:0 0 var(--spacing-lg)}.unlock-badges{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl)}.unlock-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-full);font-size:.875rem;font-weight:500}.unlock-badge.subclass{background:#8b5cf633;color:#a78bfa;border:1px solid rgba(139,92,246,.3)}.unlock-badge.asi{background:#22c55e33;color:#4ade80;border:1px solid rgba(34,197,94,.3)}.unlock-badge.combat{background:#ef444433;color:#f87171;border:1px solid rgba(239,68,68,.3)}.features-timeline h4{font-size:1rem;color:var(--color-text-primary);margin:0 0 var(--spacing-md)}.feature-list{display:flex;flex-direction:column;gap:var(--spacing-xs);max-height:250px;overflow-y:auto}.feature-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-light);border-radius:var(--radius-md);transition:all .2s ease}.feature-item.new{background:#d4a84626;border:1px solid var(--color-accent-gold)}.feature-level{font-size:.75rem;font-weight:600;color:var(--color-text-muted);min-width:45px}.feature-item.new .feature-level{color:var(--color-accent-gold)}.feature-name{font-size:.875rem;color:var(--color-text-primary)}.preview-stat.level .preview-stat-value{color:var(--color-accent-gold)}.review-features-list{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.review-feature-tag{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-light);border-radius:var(--radius-sm);font-size:.8125rem;color:var(--color-text-primary)}.review-feature-tag small{color:var(--color-text-muted);font-size:.75rem}.review-combat-stat.level .stat-value{color:var(--color-accent-gold)}.review-combat-stat.prof .stat-value{color:var(--color-accent-blue)}.selection-card .card-description{font-size:.75rem;color:var(--color-text-muted);margin-top:var(--spacing-xs);line-height:1.4}@media (max-width: 768px){.level-display-card{flex-direction:column;text-align:center}.level-number{padding-right:0;padding-bottom:var(--spacing-lg);border-right:none;border-bottom:1px solid var(--color-border)}.level-stats{padding-top:var(--spacing-lg)}.unlock-badges{justify-content:center}}.asi-scores-preview{background:var(--color-bg-medium);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.asi-scores-preview h4{font-size:.875rem;color:var(--color-text-secondary);margin:0 0 var(--spacing-md);text-transform:uppercase;letter-spacing:.05em}.asi-scores-row{display:flex;gap:var(--spacing-md);justify-content:center}.asi-score-box{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-md);background:var(--color-bg-light);border-radius:var(--radius-md);min-width:60px}.asi-score-value{font-size:1.5rem;font-weight:700;color:var(--color-text-primary)}.asi-score-label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase}.asi-choices{display:flex;flex-direction:column;gap:var(--spacing-xl)}.asi-choice-card{background:var(--color-bg-medium);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl)}.asi-choice-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);flex-wrap:wrap;gap:var(--spacing-md)}.asi-choice-header h4{font-family:var(--font-display);font-size:1.125rem;color:var(--color-accent-gold);margin:0}.asi-type-toggle{display:flex;gap:var(--spacing-xs);background:var(--color-bg-light);padding:var(--spacing-xs);border-radius:var(--radius-md)}.toggle-btn{padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:.875rem;cursor:pointer;transition:all .2s ease}.toggle-btn:hover{color:var(--color-text-primary)}.toggle-btn.active{background:var(--color-accent-gold);color:var(--color-bg-dark);font-weight:600}.asi-instruction{font-size:.875rem;color:var(--color-text-secondary);margin:0 0 var(--spacing-md)}.asi-ability-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.asi-ability-option{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-light);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all .2s ease}.asi-ability-option.selected{border-color:var(--color-accent-gold);background:#d4a8461a}.asi-ability-name{flex:1;font-weight:500;color:var(--color-text-primary)}.asi-ability-current{font-size:1.25rem;font-weight:700;color:var(--color-text-secondary);min-width:30px;text-align:center}.asi-ability-buttons{display:flex;gap:var(--spacing-xs)}.asi-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-medium);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.asi-btn:hover:not(:disabled){background:var(--color-bg-elevated);border-color:var(--color-accent-gold);color:var(--color-accent-gold)}.asi-btn.active{background:var(--color-accent-gold);border-color:var(--color-accent-gold);color:var(--color-bg-dark)}.asi-btn:disabled{opacity:.3;cursor:not-allowed}.asi-feat-selector{margin-top:var(--spacing-md)}.feat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-md);max-height:400px;overflow-y:auto;padding-right:var(--spacing-sm)}.feat-option{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-md);background:var(--color-bg-light);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;text-align:left}.feat-option:hover:not(:disabled){border-color:var(--color-accent-gold);background:#d4a8460d}.feat-option.selected{border-color:var(--color-accent-gold);background:#d4a84626}.feat-option.disabled{opacity:.5;cursor:not-allowed}.feat-option-header{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-sm)}.feat-name{font-weight:600;color:var(--color-text-primary)}.feat-asi-badge{font-size:.75rem;padding:2px 6px;background:#22c55e33;color:#4ade80;border-radius:var(--radius-sm)}.feat-desc{font-size:.8125rem;color:var(--color-text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.feat-prereq{font-size:.75rem;color:var(--color-accent-red);font-style:italic}@media (max-width: 768px){.asi-scores-row{flex-wrap:wrap}.asi-choice-header{flex-direction:column;align-items:flex-start}.asi-ability-grid,.feat-grid{grid-template-columns:1fr}}.review-asi-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.review-asi-item{display:block;font-size:.875rem;color:var(--color-text-primary);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-light);border-radius:var(--radius-sm)}.review-asi-item.feat{border-left:3px solid var(--color-accent-purple)}.review-feature-tag.subclass{background:#8b5cf633;color:#a78bfa}.review-feature-tag.species{background:#22c55e33;color:#4ade80}.spell-slots-display{background:var(--color-bg-medium);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.spell-slots-display h4{font-size:.875rem;color:var(--color-text-secondary);margin:0 0 var(--spacing-md);text-transform:uppercase;letter-spacing:.05em}.spell-slots-row{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.spell-slot-box{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-light);border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:50px}.slot-level{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase}.slot-count{font-size:1.25rem;font-weight:700;color:var(--color-accent-purple)}.no-slots{color:var(--color-text-muted);font-style:italic}.spell-level-section{margin-bottom:var(--spacing-xl);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.spell-level-section:first-of-type{border-top:none;padding-top:0}.spell-level-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.spell-level-header h4{font-family:var(--font-display);font-size:1rem;color:var(--color-accent-purple);margin:0}.spell-level-count{font-size:.8125rem;color:var(--color-text-secondary);background:var(--color-bg-medium);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm)}.spell-grid.compact{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--spacing-sm)}.spell-grid.compact .spell-card{padding:var(--spacing-sm) var(--spacing-md)}.spell-grid.compact .spell-desc{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:.75rem}.spell-note{font-size:.875rem;color:var(--color-text-secondary);font-style:italic;margin:0 0 var(--spacing-lg);padding:var(--spacing-md);background:#8b5cf61a;border-radius:var(--radius-md);border-left:3px solid var(--color-accent-purple)}@media (max-width: 768px){.spell-slots-row{justify-content:center}.spell-grid.compact{grid-template-columns:1fr}}.expertise-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin:1.5rem 0}.expertise-option{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#0003;border:2px solid rgba(255,255,255,.1);border-radius:.5rem;color:#fff;font-size:.95rem;cursor:pointer;transition:all .2s}.expertise-option:hover:not(:disabled){background:#0000004d;border-color:#d4a57480;transform:translateY(-2px)}.expertise-option.selected{background:#fbbf2433;border-color:#fbbf24}.expertise-option:disabled{opacity:.4;cursor:not-allowed}.expertise-icon{font-size:1.25rem;color:#fbbf24}.expertise-option:not(.selected) .expertise-icon{color:#ffffff4d}.expertise-name{flex:1;text-align:left;font-weight:500}.highlight-2024{color:#a78bfa;font-weight:500}.ruleset-badge{background:linear-gradient(135deg,#7c3aed,#a78bfa);color:#fff;padding:.5rem 1rem;border-radius:.5rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem;text-align:center}.background-asi-section{margin-top:2rem;padding:1.5rem;background:#a78bfa1a;border:1px solid rgba(167,139,250,.3);border-radius:.75rem}.background-asi-section h3{color:#a78bfa;margin:0 0 .5rem;font-size:1.125rem}.asi-instruction{color:#ffffffb3;margin-bottom:1rem;font-size:.875rem}.asi-selection-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}.asi-choice{display:flex;flex-direction:column;gap:.5rem}.asi-choice label{font-weight:600;color:#a78bfa;font-size:.875rem}.asi-select{padding:.75rem;background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:.5rem;color:#fff;font-size:1rem;cursor:pointer}.asi-select:focus{outline:none;border-color:#a78bfa}.origin-feat-display{background:#4ade801a;border:1px solid rgba(74,222,128,.3);border-radius:.75rem;padding:1rem}.origin-feat-display h4{color:#4ade80;margin:0 0 .5rem;font-size:1rem}.origin-feat-display p{color:#fffc;margin:0 0 .75rem;font-size:.875rem}.feat-benefits{list-style:none;padding:0;margin:0}.feat-benefits li{position:relative;padding-left:1.25rem;margin-bottom:.375rem;font-size:.8125rem;color:#ffffffb3}.feat-benefits li:before{content:"✓";position:absolute;left:0;color:#4ade80}.feat-tag{background:#4ade8033!important;color:#4ade80!important;border:1px solid rgba(74,222,128,.3)}.mastery-tag{background:#fb923c33!important;color:#fb923c!important;border:1px solid rgba(251,146,60,.3)}.mastery-selection{margin-bottom:2rem}.mastery-count{color:#fff9;font-size:.875rem;margin-bottom:1rem}.weapons-mastery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem;max-height:400px;overflow-y:auto;padding:.5rem}.weapon-mastery-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:.5rem;padding:.75rem;cursor:pointer;transition:all .2s;position:relative;text-align:left}.weapon-mastery-card:hover{background:#ffffff14;border-color:#fff3}.weapon-mastery-card.selected{background:#fb923c26;border-color:#fb923c80}.weapon-mastery-card:disabled{opacity:.4;cursor:not-allowed}.weapon-name{font-weight:600;color:#fff;margin-bottom:.25rem}.weapon-stats{font-size:.75rem;color:#fff9;margin-bottom:.5rem}.weapon-mastery-type{display:flex;justify-content:flex-start}.mastery-badge{background:#fb923c33;color:#fb923c;padding:.125rem .5rem;border-radius:.25rem;font-size:.6875rem;font-weight:600;text-transform:uppercase}.mastery-descriptions{background:#ffffff08;border-radius:.75rem;padding:1.25rem}.mastery-descriptions h3{margin:0 0 1rem;font-size:1rem;color:#fb923c}.mastery-desc-item{margin-bottom:.75rem;font-size:.8125rem;line-height:1.5;color:#ffffffb3}.mastery-desc-item strong{color:#fb923c}.lineage-spells{margin-top:1rem;padding:1rem;background:#8b5cf61a;border:1px solid rgba(139,92,246,.2);border-radius:.5rem}.lineage-spells h4{color:#8b5cf6;margin:0 0 .5rem;font-size:.875rem}.lineage-spells ul{list-style:none;padding:0;margin:0}.lineage-spells li{font-size:.8125rem;color:#ffffffb3;padding:.25rem 0}.ability-assignment-row,.ability-pointbuy-row{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.05)}.ability-label{width:100px;font-weight:500;color:#ffffffe6}.ability-select{padding:.5rem;background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:.375rem;color:#fff;width:70px;text-align:center}.bg-bonus{color:#a78bfa;font-weight:600;min-width:30px}.final-score{font-weight:700;color:#fff;min-width:40px}.modifier{color:#ffffff80;font-size:.875rem}.pointbuy-controls{display:flex;align-items:center;gap:.5rem}.pointbuy-controls button{width:28px;height:28px;border-radius:50%;border:1px solid rgba(255,255,255,.3);background:#ffffff1a;color:#fff;font-size:1.125rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.pointbuy-controls button:hover:not(:disabled){background:#fff3}.pointbuy-controls button:disabled{opacity:.3;cursor:not-allowed}.base-score{font-weight:600;min-width:30px;text-align:center}.point-cost{font-size:.75rem;color:#fff6;min-width:50px}.review-abilities{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem;margin-top:.75rem}.review-ability{text-align:center;padding:.5rem;background:#ffffff0d;border-radius:.375rem}.ability-abbr{display:block;font-size:.625rem;color:#ffffff80;text-transform:uppercase;letter-spacing:.05em}.ability-value{display:block;font-size:1.25rem;font-weight:700;color:#fff}.ability-mod{display:block;font-size:.75rem;color:#fff9}@media (max-width: 768px){.asi-selection-grid{grid-template-columns:1fr}.weapons-mastery-grid{grid-template-columns:repeat(2,1fr)}.review-abilities{grid-template-columns:repeat(3,1fr)}}.character-editor-page{min-height:100vh;background:var(--color-bg-dark)}.character-editor-page .page-content{max-width:none;padding:0}.editor-header-bar{position:sticky;top:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;background:linear-gradient(180deg,#1e1e2efa,#16161ef2);border-bottom:1px solid rgba(212,165,116,.3);backdrop-filter:blur(8px);gap:1rem}.editor-header-info h1{margin:0;font-size:1.5rem;color:#d4a574;font-family:var(--font-display)}.editor-name-input{background:transparent;border:1px solid transparent;border-radius:.375rem;font-size:1.5rem;font-weight:600;color:#d4a574;font-family:var(--font-display);padding:.125rem .5rem;margin:-.125rem -.5rem;width:auto;min-width:200px;max-width:400px}.editor-name-input:hover{border-color:#d4a5744d;background:#d4a5740d}.editor-name-input:focus{outline:none;border-color:#d4a57480;background:#0003}.editor-subtitle{color:#fff9;font-size:.875rem}.editor-header-actions{display:flex;align-items:center;gap:.75rem}.unsaved-badge{background:#fbbf2433;color:#fbbf24;padding:.25rem .75rem}.editor-portrait-section{flex-shrink:0}.portrait-upload-area{display:block;width:60px;height:60px;border-radius:8px;border:2px dashed rgba(212,165,116,.4);background:#0000004d;cursor:pointer;position:relative;overflow:hidden;transition:all .2s ease}.portrait-upload-area:hover{border-color:#d4a574b3;background:#d4a5741a}.portrait-image{width:100%;height:100%;object-fit:cover;border-radius:6px}.portrait-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}.portrait-placeholder.hidden{display:none}.portrait-initial{font-size:1.5rem;font-weight:700;color:#d4a574cc;text-transform:uppercase}.portrait-hint{font-size:.7rem;opacity:0;transition:opacity .2s}.portrait-upload-area:hover .portrait-hint{opacity:.7}.uploading-spinner{font-size:1.5rem;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.portrait-file-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.portrait-error{position:absolute;top:100%;left:0;margin-top:4px;font-size:.7rem;color:#f87171;white-space:nowrap;background:#000000e6;padding:2px 6px;border-radius:4px}border-radius: 1rem; font-size: .75rem; font-weight: 600; } .btn.accent{background:linear-gradient(135deg,#d4a574,#c4956a);color:#1a1a2e;border:none;font-weight:600}.btn.accent:hover{background:linear-gradient(135deg,#e4b584,#d4a574)}.editor-identity-bar{display:flex;flex-wrap:wrap;gap:1rem;padding:.75rem 1.5rem;background:#0000004d;border-bottom:1px solid rgba(255,255,255,.08)}.identity-field{display:flex;flex-direction:column;gap:.25rem;min-width:100px}.identity-field label{font-size:.65rem;color:#ffffff80;text-transform:uppercase;letter-spacing:.05em}.identity-field input{background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:.375rem;color:#fff;font-size:.9rem;padding:.375rem .625rem;width:100%}.identity-field input:focus{outline:none;border-color:#d4a57480;background:#0000004d}.identity-field input[type=number]{width:70px}.identity-field.experience input{width:90px}.editor-section-tabs{display:none;overflow-x:auto;background:#0000004d;border-bottom:1px solid rgba(255,255,255,.1);padding:.5rem;gap:.5rem}.section-tab{flex-shrink:0;padding:.5rem 1rem;background:transparent;border:1px solid transparent;border-radius:.5rem;color:#fff9;font-size:.8rem;cursor:pointer;transition:all .2s}.section-tab.active{background:#d4a57426;border-color:#d4a5744d;color:#d4a574}.editor-content{display:grid;grid-template-columns:280px 1fr 1fr 1fr;gap:1rem;padding:1.5rem;max-width:1600px;margin:0 auto}.editor-section{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:.75rem;padding:1.25rem}.section-title{margin:0 0 1rem;font-size:.9rem;font-weight:600;color:#d4a574;text-transform:uppercase;letter-spacing:.05em;padding-bottom:.5rem;border-bottom:1px solid rgba(212,165,116,.2)}.section-hint{font-size:.75rem;color:#fff6;margin:-.5rem 0 1rem;font-style:italic}.subsection-title{margin:1.5rem 0 .75rem;font-size:.8rem;color:#ffffffb3;text-transform:uppercase;letter-spacing:.03em}.abilities-section{grid-row:span 2}.ability-grid{display:flex;flex-direction:column;gap:.75rem}.ability-block{background:#0003;border:2px solid rgba(212,165,116,.3);border-radius:.5rem;padding:.75rem;text-align:center;position:relative}.ability-name{font-size:.65rem;font-weight:600;color:#ffffff80;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.25rem}.ability-score-input{width:60px;height:40px;background:#ffffff0d;border:1px solid rgba(255,255,255,.2);border-radius:.375rem;color:#fff;font-size:1.5rem;font-weight:700;text-align:center;font-family:var(--font-display)}.ability-score-input:focus{outline:none;border-color:#d4a574;box-shadow:0 0 0 2px #d4a57433}.ability-modifier{font-size:1.1rem;font-weight:700;color:#d4a574;margin:.25rem 0}.ability-save{display:flex;align-items:center;justify-content:center;gap:.375rem;padding:.375rem;background:#ffffff08;border-radius:.25rem;cursor:pointer;transition:all .2s;font-size:.75rem}.ability-save:hover{background:#ffffff14}.ability-save.proficient{background:#4ade801a}.ability-save.proficient .save-checkbox{color:#4ade80}.save-checkbox{color:#fff6}.save-value{font-weight:600;color:#fff}.save-label{color:#ffffff80}.prof-bonus-display{margin-top:1rem;padding:.75rem;background:#d4a5741a;border:1px solid rgba(212,165,116,.2);border-radius:.5rem;display:flex;justify-content:space-between;align-items:center}.prof-label{font-size:.75rem;color:#fff9}.prof-value{font-size:1.25rem;font-weight:700;color:#d4a574}.inspiration-box{margin-top:.75rem;padding:.625rem;background:#8b5cf61a;border:1px solid rgba(139,92,246,.2);border-radius:.5rem}.inspiration-box label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;color:#fffc}.inspiration-box input[type=checkbox]{width:18px;height:18px;accent-color:#a78bfa}.combat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.combat-stat{text-align:center}.combat-stat .stat-label{display:block;font-size:.65rem;color:#ffffff80;text-transform:uppercase;letter-spacing:.05em;margin-top:.5rem}.combat-stat .stat-value{font-size:1.5rem;font-weight:700;color:#fff}.combat-input{width:60px;height:50px;background:#ffffff0d;border:2px solid rgba(255,255,255,.2);border-radius:.5rem;color:#fff;font-size:1.5rem;font-weight:700;text-align:center}.combat-input:focus{outline:none;border-color:#d4a574}.ac-stat .stat-shield{width:70px;height:80px;margin:0 auto;background:linear-gradient(180deg,#d4a57426,#d4a5740d);border:2px solid rgba(212,165,116,.4);border-radius:0 0 35px 35px;display:flex;align-items:center;justify-content:center;clip-path:polygon(0 0,100% 0,100% 70%,50% 100%,0 70%)}.ac-stat .stat-shield .combat-input{background:transparent;border:none;width:50px}.hp-section h3,.hit-dice-section h3,.death-saves-section h3{margin:0 0 .75rem;font-size:.75rem;color:#fff9;text-transform:uppercase}.hp-grid{display:flex;align-items:center;gap:.5rem}.hp-field{flex:1}.hp-field label{display:block;font-size:.65rem;color:#fff6;text-transform:uppercase;margin-bottom:.25rem}.hp-field input{width:100%;padding:.5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.2);border-radius:.375rem;color:#fff;font-size:1.25rem;font-weight:600;text-align:center}.hp-field input:focus{outline:none;border-color:#ef4444}.hp-field.temp input{border-color:#60a5fa4d}.hp-divider{font-size:1.5rem;color:#ffffff4d;margin-top:1rem}.hit-dice-display{display:flex;align-items:center;justify-content:center;gap:.25rem;font-size:1rem;color:#fff}.hit-dice-input{width:50px;padding:.375rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.2);border-radius:.25rem;color:#fff;font-size:1rem;text-align:center}.death-saves{display:flex;flex-direction:column;gap:.5rem}.save-row{display:flex;align-items:center;justify-content:space-between;font-size:.8rem;color:#ffffffb3}.save-boxes{display:flex;gap:.25rem}.save-box{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.2);border-radius:50%;font-size:.75rem;cursor:pointer}.skills-list{display:flex;flex-direction:column;gap:.25rem}.skill-row{display:flex;align-items:center;gap:.5rem;padding:.375rem .5rem;border-radius:.25rem;cursor:pointer;transition:all .15s}.skill-row:hover{background:#ffffff0d}.skill-row.proficient{background:#4ade801a}.skill-checkbox{font-size:.75rem;color:#fff6}.skill-row.proficient .skill-checkbox{color:#4ade80}.skill-bonus{width:32px;font-weight:600;color:#fff;text-align:center}.skill-name{flex:1;font-size:.85rem;color:#ffffffe6}.skill-ability{font-size:.7rem;color:#fff6}.passive-perception{margin-top:1rem;padding:.75rem;background:#fbbf241a;border:1px solid rgba(251,191,36,.2);border-radius:.5rem;display:flex;justify-content:space-between;align-items:center}.passive-label{font-size:.75rem;color:#fff9}.passive-value{font-size:1.25rem;font-weight:700;color:#fbbf24}.features-list{display:flex;flex-direction:column;gap:.75rem;max-height:300px;overflow-y:auto}.feature-item{padding:.75rem;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:.5rem;border-left:3px solid rgba(212,165,116,.4)}.feature-header{display:flex;justify-content:space-between;align-items:center}.feature-header strong{color:#d4a574;font-size:.9rem}.feature-desc{margin:.5rem 0 0;font-size:.8rem;color:#fff9;line-height:1.5}.add-feature-form{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem}.add-feature-form input,.add-feature-form textarea{width:100%;padding:.5rem .75rem;background:#0003;border:1px solid rgba(255,255,255,.15);border-radius:.375rem;color:#fff;font-size:.875rem}.add-feature-form input:focus,.add-feature-form textarea:focus{outline:none;border-color:#d4a57480}.proficiencies-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.prof-group h4{margin:0 0 .5rem;font-size:.75rem;color:#ffffff80;text-transform:uppercase}.prof-tags{display:flex;flex-wrap:wrap;gap:.375rem;min-height:28px}.prof-tag{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:#d4a57426;border:1px solid rgba(212,165,116,.25);border-radius:.25rem;font-size:.75rem;color:#d4a574}.prof-tag button{background:none;border:none;color:#f87171cc;cursor:pointer;font-size:.875rem;padding:0;line-height:1}.add-prof{display:flex;gap:.25rem;margin-top:.5rem}.add-prof input{flex:1;padding:.25rem .5rem;background:#0003;border:1px solid rgba(255,255,255,.15);border-radius:.25rem;color:#fff;font-size:.75rem}.add-prof button{padding:.25rem .5rem;background:#4ade8033;border:1px solid rgba(74,222,128,.3);border-radius:.25rem;color:#4ade80;cursor:pointer}.equipment-list{display:flex;flex-direction:column;gap:.375rem;max-height:250px;overflow-y:auto}.equipment-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#ffffff08;border-radius:.375rem}.item-icon{color:#d4a574}.item-name{flex:1;font-size:.875rem;color:#ffffffe6}.add-item-row{display:flex;gap:.5rem;margin-top:.75rem}.add-item-row input{flex:1;padding:.5rem .75rem;background:#0003;border:1px solid rgba(255,255,255,.15);border-radius:.375rem;color:#fff;font-size:.875rem}.add-item-row button{padding:.5rem 1rem;background:#4ade8033;border:1px solid rgba(74,222,128,.3);border-radius:.375rem;color:#4ade80;font-size:1rem;cursor:pointer}.currency-section{margin-top:1.5rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}.currency-section h3{margin:0 0 .75rem;font-size:.75rem;color:#ffffff80;text-transform:uppercase}.currency-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem}.currency-field{text-align:center}.currency-field label{display:block;font-size:.65rem;color:#fbbf24;margin-bottom:.25rem}.currency-field input{width:100%;padding:.375rem;background:#fbbf241a;border:1px solid rgba(251,191,36,.2);border-radius:.25rem;color:#fff;font-size:.875rem;text-align:center}.weapons-section{margin-top:1.5rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}.weapons-section h3{margin:0 0 .25rem;font-size:.85rem;color:#f87171}.weapons-hint{font-size:.7rem;color:#fff6;margin:0 0 1rem}.weapons-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.weapon-edit-row,.add-weapon-form{display:flex;gap:.5rem;align-items:flex-end;padding:.5rem;background:#f871710d;border:1px solid rgba(248,113,113,.15);border-radius:.375rem}.weapon-edit-row:hover{background:#f871711a}.weapon-name-input{flex:1;min-width:100px;padding:.375rem .5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:.25rem;color:#fff;font-size:.85rem}.weapon-name-input:focus{outline:none;border-color:#f8717180}.weapon-stat-group{display:flex;flex-direction:column;gap:.125rem}.weapon-stat-group label{font-size:.55rem;color:#fff6;text-transform:uppercase}.weapon-bonus-input{width:50px;padding:.375rem .25rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:.25rem;color:#4ade80;font-size:.85rem;font-weight:600;text-align:center}.weapon-damage-input{width:70px;padding:.375rem .25rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:.25rem;color:#f87171;font-size:.85rem;font-weight:600;text-align:center}.weapon-type-input{width:90px;padding:.375rem .25rem;background:#1e1e28f2;border:1px solid rgba(255,255,255,.15);border-radius:.25rem;color:#ffffffb3;font-size:.75rem}.weapon-type-input option{background:#1e1e28;color:#ffffffe6;padding:.5rem}.weapon-edit-row .remove-btn,.add-weapon-form .add-btn{width:28px;height:28px;flex-shrink:0;padding:0;display:flex;align-items:center;justify-content:center;border-radius:.25rem;font-size:1rem;font-weight:700;cursor:pointer;transition:all .15s}.weapon-edit-row .remove-btn{background:#f871711a;border:1px solid rgba(248,113,113,.3);color:#f87171}.weapon-edit-row .remove-btn:hover{background:#f871714d}.add-weapon-form .add-btn{background:#4ade8033;border:1px solid rgba(74,222,128,.4);color:#4ade80}.add-weapon-form .add-btn:hover{background:#4ade804d}@media (max-width: 600px){.weapon-edit-row,.add-weapon-form{flex-wrap:wrap}.weapon-name-input{flex:1 1 100%;min-width:unset;margin-bottom:.25rem}.weapon-stat-group{flex:1}}.spellcasting-header{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid rgba(139,92,246,.2)}.spell-stat{text-align:center;padding:.5rem;background:#8b5cf61a;border-radius:.375rem}.spell-stat .stat-label{display:block;font-size:.6rem;color:#ffffff80;text-transform:uppercase;margin-bottom:.125rem}.spell-stat .stat-value{font-size:1rem;font-weight:700;color:#a78bfa}.spell-group{margin-bottom:1.25rem}.spell-group h3{margin:0 0 .5rem;font-size:.75rem;color:#a78bfa;text-transform:uppercase}.spell-list{display:flex;flex-direction:column;gap:.25rem;max-height:200px;overflow-y:auto}.spell-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#ffffff08;border-radius:.375rem;border-left:2px solid rgba(139,92,246,.3)}.spell-item.cantrip{border-left-color:#a78bfa80}.spell-icon{color:#a78bfa;font-size:.75rem}.spell-name{flex:1;font-size:.85rem;color:#ffffffe6}.story-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.story-field{display:flex;flex-direction:column}.story-field.full-width{grid-column:span 2}.story-field label{font-size:.75rem;color:#d4a574;text-transform:uppercase;letter-spacing:.03em;margin-bottom:.375rem}.story-field textarea{width:100%;padding:.75rem;background:#0003;border:1px solid rgba(255,255,255,.15);border-radius:.5rem;color:#fff;font-size:.875rem;line-height:1.6;resize:vertical;font-family:inherit}.story-field textarea:focus{outline:none;border-color:#d4a57480}.story-field textarea::placeholder{color:#ffffff4d}.remove-btn{background:#f871711a;border:1px solid rgba(248,113,113,.3);color:#f87171;width:24px;height:24px;border-radius:.25rem;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}.remove-btn:hover{background:#f8717140}@media (max-width: 1200px){.editor-content{grid-template-columns:250px repeat(3,1fr)}}@media (max-width: 1024px){.editor-content{grid-template-columns:repeat(2,1fr)}.abilities-section{grid-row:auto}.ability-grid{display:grid;grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.editor-header-bar{flex-direction:column;align-items:stretch;gap:.75rem;padding:.75rem 1rem}.editor-name-input{font-size:1.25rem;min-width:150px}.editor-header-actions{justify-content:flex-end;flex-wrap:wrap}.editor-identity-bar{padding:.75rem 1rem;gap:.75rem}.identity-field{flex:1;min-width:80px}.identity-field input{font-size:.85rem;padding:.25rem .5rem}.editor-section-tabs{display:flex}.editor-content{grid-template-columns:1fr;padding:1rem}.editor-section{display:none}.editor-section.active{display:block}.ability-grid{grid-template-columns:repeat(2,1fr)}.combat-grid{grid-template-columns:repeat(3,1fr)}.proficiencies-grid,.story-grid{grid-template-columns:1fr}.story-field.full-width{grid-column:1}.spellcasting-header{grid-template-columns:1fr}}@media (max-width: 480px){.editor-header-info h1{font-size:1.25rem}.editor-header-actions .btn{padding:.5rem .75rem;font-size:.8rem}.ability-grid{grid-template-columns:1fr 1fr}.combat-grid{grid-template-columns:1fr}.currency-grid{grid-template-columns:repeat(3,1fr)}}.skill-row.expertise .skill-checkbox{color:#fbbf24;font-weight:700}.skill-row.expertise{background:#fbbf241a}.spell-slots-grid{display:flex;flex-direction:column;gap:.75rem;margin-top:.75rem}.slot-level-row{display:flex;align-items:center;gap:1rem;padding:.5rem;background:#0003;border-radius:.375rem}.slot-level-label{font-size:.875rem;font-weight:600;color:#ffffffb3;min-width:4rem}.slot-controls{display:flex;align-items:center;gap:.5rem}.slot-input{width:3rem;padding:.25rem .5rem;background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:.25rem;color:#fff;font-size:.875rem;text-align:center}.slot-separator{color:#fff6;font-size:.875rem}.slot-tracker{display:flex;gap:.375rem;flex-wrap:wrap;flex:1}.slot-box{width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border:2px solid #d4a574;border-radius:.25rem;background:#d4a5741a;color:#d4a574;font-size:1rem;cursor:pointer;transition:all .2s}.slot-box:hover{background:#d4a57433;transform:scale(1.05)}.slot-box.used{background:#ef444433;border-color:#ef4444;color:#ef4444}.slot-box.used:hover{background:#ef44444d}.slot-box.available{background:#22c55e1a;border-color:#22c55e;color:#22c55e}.slot-box.available:hover{background:#22c55e33}.prof-tag-editable{display:inline-flex;align-items:center;gap:.5rem;margin:.25rem}.prof-tag-editable .prof-tag{margin:0}.prof-tag-editable .remove-btn{background:#ef444433;border:1px solid rgba(239,68,68,.3);color:#ef4444;width:1.5rem;height:1.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem;line-height:1;padding:0;transition:all .2s}.prof-tag-editable .remove-btn:hover{background:#ef44444d;border-color:#ef4444}.prof-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}:root{--color-bg-dark: #0f0f1a;--color-bg-medium: #1a1a2e;--color-bg-light: #25253a;--color-bg-elevated: #2d2d44;--color-text-primary: #e8e6e3;--color-text-secondary: #a8a5a0;--color-text-muted: #6b6966;--color-accent-gold: #d4a846;--color-accent-gold-hover: #e8c566;--color-accent-red: #c94444;--color-accent-green: #4ade80;--color-accent-blue: #60a5fa;--color-accent-purple: #c084fc;--color-border: #3a3a4d;--font-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-display: "Cinzel", serif;--font-mono: "Fira Code", monospace;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 2px 4px rgba(0,0,0,.2);--shadow-md: 0 4px 12px rgba(0,0,0,.3);--shadow-lg: 0 8px 24px rgba(0,0,0,.4);--shadow-glow: 0 0 20px rgba(212, 168, 70, .3)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--color-bg-dark);color:var(--color-text-primary);line-height:1.6;min-height:100vh}#root{min-height:100vh}h1,h2,h3{font-family:var(--font-display);color:var(--color-accent-gold);font-weight:600}h1{font-size:2.5rem}h2{font-size:1.75rem}h3{font-size:1.25rem}a{color:var(--color-accent-gold);text-decoration:none;transition:color .2s}a:hover{color:var(--color-accent-gold-hover)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all .2s;border:none;font-size:1rem;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background:var(--color-accent-gold);color:var(--color-bg-dark)}.btn.primary:hover:not(:disabled){background:var(--color-accent-gold-hover);box-shadow:var(--shadow-glow)}.btn.secondary{background:var(--color-bg-elevated);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn.secondary:hover:not(:disabled){background:var(--color-bg-light);border-color:var(--color-accent-gold)}.btn.danger{background:var(--color-accent-red);color:#fff}.btn.danger:hover:not(:disabled){background:#e05555}.btn.ghost{background:transparent;color:var(--color-text-secondary)}.btn.ghost:hover:not(:disabled){color:var(--color-accent-gold)}.btn.large{padding:var(--spacing-md) var(--spacing-xl);font-size:1.1rem}.btn.small{padding:var(--spacing-xs) var(--spacing-md);font-size:.875rem}.home{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center;padding:var(--spacing-xl);background:linear-gradient(135deg,var(--color-bg-dark) 0%,var(--color-bg-medium) 100%)}.home .logo{width:200px;height:auto;margin-bottom:var(--spacing-xl);filter:drop-shadow(var(--shadow-glow))}.home>p{color:var(--color-text-secondary);font-size:1.5rem;margin-bottom:var(--spacing-xl)}.home .actions{display:flex;gap:var(--spacing-md)}.home-features{display:flex;gap:var(--spacing-xl);margin-top:var(--spacing-2xl);padding-top:var(--spacing-xl);border-top:1px solid var(--color-border)}.feature{text-align:center;max-width:200px}.feature-icon{font-size:1rem;font-weight:700;display:flex;align-items:center;justify-content:center;width:60px;height:60px;margin:0 auto var(--spacing-md);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-accent-gold)}.feature h3{font-family:var(--font-body);color:var(--color-text-primary);font-size:1rem;margin-bottom:var(--spacing-xs)}.feature p{color:var(--color-text-muted);font-size:.875rem}.page{min-height:100vh;background:linear-gradient(135deg,var(--color-bg-dark) 0%,var(--color-bg-medium) 100%)}.page-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-xl);background:#0000004d;border-bottom:1px solid var(--color-border)}.page-header .logo-section{display:flex;align-items:center;gap:var(--spacing-md)}.page-header .logo-img{width:40px;height:40px}.page-header .logo-text{font-family:var(--font-display);font-size:1.25rem;color:var(--color-accent-gold)}.page-header .user-section{display:flex;align-items:center;gap:var(--spacing-md)}.page-header .user-avatar{width:36px;height:36px;border-radius:50%;border:2px solid var(--color-border)}.page-header .user-name{color:var(--color-text-primary);font-weight:500}.page-content{max-width:1200px;margin:0 auto;padding:var(--spacing-xl)}.page-title{text-align:center;margin-bottom:var(--spacing-sm)}.page-subtitle{text-align:center;color:var(--color-text-secondary);margin-bottom:var(--spacing-xl)}.dashboard-actions{display:flex;justify-content:center;gap:var(--spacing-md);margin-bottom:var(--spacing-2xl)}.campaign-section{margin-bottom:var(--spacing-2xl)}.campaign-section h2{font-size:1.25rem;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.campaign-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-lg)}.campaign-card{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all .2s}.campaign-card:hover{border-color:var(--color-accent-gold);box-shadow:var(--shadow-md)}.campaign-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-md)}.campaign-card-title{font-family:var(--font-display);font-size:1.25rem;color:var(--color-accent-gold);margin:0}.campaign-card-status{font-size:.75rem;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);text-transform:uppercase;font-weight:600}.campaign-card-status.active{background:#4ade8033;color:var(--color-accent-green)}.campaign-card-status.paused{background:#fbbf2433;color:#fbbf24}.campaign-card-description{color:var(--color-text-secondary);font-size:.875rem;margin-bottom:var(--spacing-md);line-height:1.5}.campaign-card-meta{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);font-size:.875rem;color:var(--color-text-muted)}.campaign-card-actions{display:flex;gap:var(--spacing-sm)}.campaign-card-notice{margin-top:var(--spacing-md);padding:var(--spacing-sm);background:#fbbf241a;border:1px solid rgba(251,191,36,.3);border-radius:var(--radius-sm);font-size:.875rem;color:#fbbf24;text-align:center}.empty-state{text-align:center;padding:var(--spacing-2xl);background:var(--color-bg-elevated);border:1px dashed var(--color-border);border-radius:var(--radius-lg)}.empty-state p{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.campaign-detail-header{margin-bottom:var(--spacing-xl)}.campaign-detail-meta{display:flex;gap:var(--spacing-md);flex-wrap:wrap;margin-top:var(--spacing-md)}.campaign-detail-meta .tag{font-size:.875rem;padding:var(--spacing-xs) var(--spacing-md);background:var(--color-bg-light);border-radius:var(--radius-sm);color:var(--color-text-muted)}.campaign-detail-meta .tag.success{background:#4ade8033;color:var(--color-accent-green)}.card{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.card-title{font-family:var(--font-body);font-size:1rem;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-md)}.card-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.upload-zone{border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);text-align:center;cursor:pointer;transition:all .2s}.upload-zone:hover{border-color:var(--color-accent-gold);background:#d4a8460d}.upload-zone.has-file{border-style:solid;border-color:var(--color-accent-green);background:#4ade800d}.upload-zone .upload-icon{font-size:2.5rem;color:var(--color-accent-gold);margin-bottom:var(--spacing-md)}.upload-zone p{color:var(--color-text-secondary);margin:var(--spacing-xs) 0}.upload-zone .hint{color:var(--color-text-muted);font-size:.875rem}.pdf-status{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:#4ade801a;border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.pdf-icon{width:50px;height:60px;background:linear-gradient(135deg,var(--color-accent-green),#22c55e);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--color-bg-dark);font-size:.75rem}.pdf-info{flex:1}.pdf-info .name{display:block;color:var(--color-text-primary);font-weight:500}.pdf-info .hint{font-size:.875rem;color:var(--color-text-muted)}.invite-box{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:#d4a8461a;border-radius:var(--radius-md);margin-bottom:var(--spacing-md);flex-wrap:wrap;gap:var(--spacing-md)}.invite-code{display:flex;align-items:center;gap:var(--spacing-sm)}.invite-code .label{color:var(--color-text-muted);font-size:.875rem}.invite-code .value{color:var(--color-accent-gold);font-weight:700;font-size:1.25rem;font-family:var(--font-mono)}.invite-actions{display:flex;gap:var(--spacing-sm)}.member-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.member-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-light);border-radius:var(--radius-md)}.member-item .name{color:var(--color-text-primary)}.member-item .role{color:var(--color-text-muted);font-size:.875rem;text-transform:capitalize}.import-wizard{max-width:600px;margin:0 auto}.import-steps{display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-xl);gap:var(--spacing-sm)}.step{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-xl);background:var(--color-bg-light);color:var(--color-text-muted)}.step.active{background:#d4a84633;color:var(--color-accent-gold)}.step.completed{background:#4ade8033;color:var(--color-accent-green)}.step-number{width:24px;height:24px;border-radius:50%;background:currentColor;color:var(--color-bg-dark);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem}.step-line{width:40px;height:2px;background:var(--color-border)}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;margin-bottom:var(--spacing-sm);font-weight:500;color:var(--color-text-primary)}.form-group input,.form-group textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-dark);color:var(--color-text-primary);font-size:1rem;font-family:var(--font-body)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-accent-gold)}.form-group textarea{resize:vertical;min-height:100px}.form-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end}.progress-bar{height:8px;background:var(--color-border);border-radius:var(--radius-sm);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-accent-gold),var(--color-accent-green));transition:width .3s}.success-state{text-align:center;padding:var(--spacing-2xl)}.success-icon{width:80px;height:80px;background:linear-gradient(135deg,var(--color-accent-green),#22c55e);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:var(--color-bg-dark);margin:0 auto var(--spacing-lg)}.error-banner{background:#c9444433;border:1px solid var(--color-accent-red);color:#fca5a5;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);display:flex;justify-content:space-between;align-items:center}.error-banner button{background:none;border:none;color:var(--color-accent-red);cursor:pointer}.info-box{background:var(--color-bg-light);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.info-box h4{font-size:.875rem;color:var(--color-accent-gold);margin-bottom:var(--spacing-sm)}.info-box p{font-size:.875rem;color:var(--color-text-secondary);line-height:1.5;margin:0}.session-layout{width:100vw;height:100vh;overflow:hidden;display:flex}.session-main{flex:1;height:100%;overflow:hidden}.session-sidebar{position:relative;width:320px;height:100%;background:var(--color-bg-medium);border-left:1px solid var(--color-border);transition:width .2s ease}.session-sidebar.closed{width:40px}.sidebar-toggle{position:absolute;top:12px;left:-16px;width:32px;height:32px;border-radius:50%;border:1px solid var(--color-border);background:var(--color-bg-elevated);color:var(--color-text-secondary);cursor:pointer;font-size:14px;z-index:10;display:flex;align-items:center;justify-content:center;transition:all .15s}.sidebar-toggle:hover{background:var(--color-accent-gold);color:var(--color-bg-dark);border-color:var(--color-accent-gold)}.sidebar-content{height:100%;padding:12px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.sidebar-panel{flex-shrink:0}.sidebar-panel.chat-panel-wrapper{flex:1;min-height:200px;display:flex;flex-direction:column}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-bg-dark) 0%,var(--color-bg-medium) 100%)}.loading-content{text-align:center}.loading-logo{width:80px;height:80px;margin-bottom:16px;animation:pulse 2s ease-in-out infinite}.loading-content p{color:var(--color-text-muted)}.spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-accent-gold);border-radius:50%;animation:spin 1s linear infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.95)}}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.home h1{font-size:2rem}.home .actions{flex-direction:column}.home-features{flex-direction:column;align-items:center}.page-header{flex-direction:column;gap:var(--spacing-md)}.dashboard-actions{flex-direction:column}.campaign-grid{grid-template-columns:1fr}.form-actions{flex-direction:column}.form-actions .btn{width:100%}}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:modalFadeIn .2s ease}.modal-content{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);max-width:500px;width:100%;animation:modalSlideUp .3s ease}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.btn.danger{background:#dc2626;border-color:#dc2626;color:#fff}.btn.danger:hover{background:#ef4444;border-color:#ef4444}.character-card-wrapper{display:flex;flex-direction:column;gap:.5rem}.character-card-wrapper .character-card{cursor:default}.character-card-wrapper .character-card .cc-hint{display:none}.character-card-actions{display:flex;gap:.5rem}.character-card-actions .btn{flex:1;font-size:.8rem;padding:.5rem .75rem}.chat-panel{display:flex;flex-direction:column;background:#2d2d44;border-radius:12px;border:1px solid #3a3a4d;overflow:hidden;flex:1;min-height:0}.chat-header{padding:8px 16px;background:#25253a;border-bottom:1px solid #3a3a4d;font-weight:600;font-size:18px;display:flex;align-items:center;gap:8px;flex-shrink:0}.chat-messages{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:8px}.chat-empty{text-align:center;padding:24px;color:#6b6966}.chat-empty p{margin:4px 0}.chat-hint{font-size:16px}.chat-hint code{background:#0f0f1a;padding:2px 6px;border-radius:4px;font-family:Fira Code,monospace}.gm-typing-container{padding:8px;border-radius:8px;background:#0f0f1a;opacity:.8}.gm-typing-container .message-header{display:flex;align-items:center;gap:6px;margin-bottom:4px}.gm-typing-container .message-sender{font-weight:600;color:#e8e6e3}.typing-indicator{display:flex;gap:4px;padding:4px 0}.typing-indicator span{width:8px;height:8px;background:#fbbf24;border-radius:50%;animation:typing-bounce 1.4s infinite ease-in-out both}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}.typing-indicator span:nth-child(3){animation-delay:0s}@keyframes typing-bounce{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}.chat-input-row{display:flex;gap:8px;padding:8px;border-top:1px solid #3a3a4d;flex-shrink:0}.chat-input-row input{flex:1;padding:8px;background:#0f0f1a;border:1px solid #3a3a4d;border-radius:8px;color:#e8e6e3;font-size:18px}.chat-input-row input:focus{outline:none;border-color:#d4a846}.chat-input-row input::placeholder{color:#6b6966}.chat-input-row button{padding:8px 16px;background:#d4a846;border:none;border-radius:8px;color:#0f0f1a;font-weight:600;cursor:pointer;transition:all .15s}.chat-input-row button:hover{background:#e8c566;transform:scale(1.02)}.chat-input-row input:disabled{opacity:.5;cursor:not-allowed;background:#0f0f1a}.chat-input-row button:disabled{opacity:.5;cursor:not-allowed;transform:none}.chat-input-row button:disabled:hover{transform:none}.unified-message{padding:var(--spacing-sm)!important;border-radius:var(--radius-md)!important;background:var(--color-bg-elevated)!important;font-size:17px!important;border-left:4px solid transparent!important}.unified-message.roll,.unified-message.roll_result{background:linear-gradient(135deg,#d4a84626,#d4a84614)!important;border-left-color:#d4a846!important}.unified-message.narrative,.unified-message.narration{background:linear-gradient(135deg,#d4a8461f,#d4a8460f)!important;border-left-color:#d4a846!important;font-style:italic!important}.unified-message.system{background:#25253a!important;border-left-color:#6b6966!important;font-size:16px!important}.unified-message.npc{background:linear-gradient(135deg,#c084fc26,#c084fc14)!important;border-left-color:#c084fc!important}.unified-message.chat{background:linear-gradient(135deg,#6a6a9a33,#5a5a8626)!important;border-left-color:#6a6a9a!important;border-top:1px solid #6a6a9a!important;border-right:1px solid #6a6a9a!important;border-bottom:1px solid #6a6a9a!important}.unified-message .message-header{display:flex!important;align-items:center!important;gap:6px!important;margin-bottom:6px!important}.unified-message .message-icon{font-size:14px!important;line-height:1!important}.unified-message .message-sender{font-weight:600!important;color:#e8e6e3!important}.unified-message .message-time{margin-left:auto!important;font-size:15px!important;color:#6b6966!important}.unified-message .message-content{color:#a8a5a0!important;line-height:1.4!important;word-break:break-word!important}.unified-message.roll .message-content,.unified-message.roll_result .message-content{font-family:Fira Code,monospace!important;color:#d4a846!important;font-weight:600!important}.tier-badge{font-size:11px!important;font-weight:600!important;padding:2px 6px!important;border-radius:4px!important;text-transform:uppercase!important;letter-spacing:.5px!important;white-space:nowrap!important;display:inline-block!important}.tier-badge.founder{background:linear-gradient(135deg,#4ade8033,#22c55e33)!important;color:#4ade80!important;border:1px solid rgba(74,222,128,.4)!important}.tier-badge.premium{background:linear-gradient(135deg,#fbbf2433,#f59e0b33)!important;color:#fbbf24!important;border:1px solid rgba(251,191,36,.4)!important}
