:root{--primary-bg: #1a1a2e;--secondary-bg: #16213e;--accent-bg: #0f3460;--panel-bg: #2d3748;--border-color: #4a5568;--text-primary: #f7fafc;--text-secondary: #e2e8f0;--text-accent: #ffd700;--button-bg: #2b6cb0;--button-hover: #3182ce;--health-color: #dc3545;--mana-color: #007bff;--success-color: #28a745;--warning-color: #ffc107;font-family:Cinzel,Times New Roman,serif;line-height:1.5;font-weight:400;color:var(--text-primary);background-color:var(--primary-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;padding:0;min-width:100vw;min-height:100vh;background:linear-gradient(135deg,var(--primary-bg) 0%,var(--secondary-bg) 100%);overflow:hidden}#app{width:100vw;height:100vh;position:relative;display:flex;flex-direction:column}#game-container{flex:1;position:relative;background-color:var(--primary-bg);border:2px solid var(--border-color);border-radius:8px;overflow:hidden}#game-container canvas{display:block;width:100%;height:100%}.ui-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:100}.main-menu-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e);display:flex;align-items:center;justify-content:center;z-index:1000;font-family:Cinzel,Times New Roman,serif}.main-menu-header{text-align:center;margin-bottom:40px}.game-title-main{font-size:3.5em;color:var(--text-accent);margin:0 0 10px;text-shadow:2px 2px 4px rgba(0,0,0,.5);font-weight:700}.game-subtitle{font-size:1.3em;color:var(--text-secondary);margin:0 0 5px}.game-tagline{font-size:1.1em;color:var(--text-secondary);margin:0;opacity:.8}.main-menu-container{display:flex;gap:60px;max-width:1200px;width:90%;background:#2d3748f2;border:2px solid var(--border-color);border-radius:15px;padding:40px;box-shadow:0 15px 40px #00000080}.main-menu-left,.main-menu-right{flex:1}.section-title{color:var(--text-accent);font-size:1.8em;margin-bottom:25px;text-align:center;border-bottom:2px solid var(--border-color);padding-bottom:10px}.features-list{display:flex;flex-direction:column;gap:20px}.feature-item{display:flex;align-items:center;gap:15px;padding:15px;background:#16213e99;border:1px solid var(--border-color);border-radius:8px;transition:all .3s ease}.feature-item:hover{background:#16213ecc;border-color:var(--text-accent);transform:translate(5px)}.feature-icon{font-size:2em;min-width:40px;text-align:center}.feature-content h3{color:var(--text-primary);margin:0 0 5px;font-size:1.2em}.feature-content p{color:var(--text-secondary);margin:0;font-size:.9em;line-height:1.4}.menu-buttons{display:flex;flex-direction:column;gap:15px}.menu-button{display:flex;align-items:center;gap:15px;padding:20px;background:linear-gradient(145deg,var(--button-bg),var(--button-hover));color:#fff;border:none;border-radius:10px;cursor:pointer;font-family:inherit;font-size:1.1em;font-weight:600;transition:all .3s ease;box-shadow:0 4px 15px #0000004d;text-align:left}.menu-button:hover{transform:translateY(-3px);box-shadow:0 8px 25px #0006;background:linear-gradient(145deg,var(--button-hover),var(--button-bg))}.menu-button.primary{background:linear-gradient(145deg,#e74c3c,#c0392b)}.menu-button.primary:hover{background:linear-gradient(145deg,#c0392b,#e74c3c)}.button-icon{font-size:1.5em;min-width:30px}.button-text{font-weight:700;font-size:1.2em}.button-subtitle{font-size:.9em;opacity:.8;font-weight:400}.version-info{text-align:center;margin-top:30px;padding-top:20px;border-top:1px solid var(--border-color)}.version-info p{color:var(--text-secondary);font-size:.9em;margin:0}@media (max-width: 768px){.main-menu-container{flex-direction:column;gap:30px;padding:20px}.game-title-main{font-size:2.5em}.main-menu-left{order:2}.main-menu-right{order:1}.btn,button,.menu-button,.action-btn,.movement-btn{min-height:44px;min-width:44px;padding:.875rem 1.25rem}.menu-buttons{flex-direction:column;gap:1rem}.menu-button{width:100%;padding:1rem}}.ui-container>*{pointer-events:auto}.hud-container{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column}.party-panel{position:absolute;top:10px;left:10px;width:300px;background:#2d3748e6;border:2px solid var(--border-color);border-radius:8px;padding:15px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.party-panel h3{margin:0 0 10px;color:var(--text-accent);font-size:18px;text-align:center;border-bottom:1px solid var(--border-color);padding-bottom:5px}.party-members{display:flex;flex-direction:column;gap:8px}.party-member{background:#16213ecc;border:1px solid var(--border-color);border-radius:4px;padding:8px;cursor:pointer;transition:all .2s ease}.party-member:hover{background:#16213e;border-color:var(--text-accent);transform:translate(2px)}.member-name{font-weight:700;color:var(--text-primary);font-size:14px}.member-class{font-size:12px;color:var(--text-secondary);margin:2px 0}.member-hp,.member-mp{font-size:11px;margin:1px 0}.member-hp{color:var(--health-color)}.member-mp{color:var(--mana-color)}.action-panel{position:absolute;bottom:10px;left:10px;width:300px;background:#2d3748e6;border:2px solid var(--border-color);border-radius:8px;padding:15px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.action-panel h3{margin:0 0 10px;color:var(--text-accent);font-size:18px;text-align:center;border-bottom:1px solid var(--border-color);padding-bottom:5px}.exploration-actions,.combat-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.message-log{position:absolute;bottom:10px;right:10px;width:400px;height:200px;background:#2d3748e6;border:2px solid var(--border-color);border-radius:8px;padding:10px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);overflow-y:auto;font-family:Courier New,monospace;font-size:12px}.message{margin:2px 0;padding:2px 4px;border-radius:2px}.message-info{color:var(--text-secondary)}.message-combat{color:var(--warning-color);background:#ffc1071a}.message-system{color:var(--success-color);background:#28a7451a}.menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.subscription-overlay{background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.subscription-panel{background:linear-gradient(145deg,#2d3748f2,#1a1a2ef2);border:2px solid var(--accent-bg);border-radius:20px;box-shadow:0 20px 40px #0000004d,0 0 30px #ffd7001a;max-width:900px;max-height:90vh;overflow-y:auto;padding:2rem;animation:slideInScale .6s ease-out}.subscription-header{text-align:center;margin-bottom:2rem;border-bottom:2px solid var(--accent-bg);padding-bottom:1.5rem}.game-title-large{font-size:3rem;font-weight:700;background:linear-gradient(45deg,var(--text-accent),#fff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 .5rem;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.subscription-subtitle{font-size:1.2rem;color:var(--text-secondary);margin:0;font-style:italic}.subscription-content{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}.features-section h2{color:var(--text-accent);font-size:1.8rem;margin-bottom:1.5rem;text-align:center}.feature-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}.feature-item{background:#2d374899;border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;text-align:center;transition:all .3s ease}.feature-item:hover{background:#2d3748cc;border-color:var(--text-accent);transform:translateY(-2px);box-shadow:0 8px 16px #0003}.feature-icon{font-size:2.5rem;margin-bottom:1rem;display:block}.feature-item h3{color:var(--text-accent);font-size:1.2rem;margin:0 0 .5rem}.feature-item p{color:var(--text-secondary);font-size:.95rem;margin:0;line-height:1.4}.signup-section{background:#1a1a2ecc;border:1px solid var(--accent-bg);border-radius:15px;padding:2rem}.signup-section h3{color:var(--text-accent);font-size:1.6rem;margin:0 0 1.5rem;text-align:center}.subscription-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:var(--text-primary);font-size:.95rem}.form-group input[type=text],.form-group input[type=email]{background:#2d3748cc;border:2px solid var(--border-color);border-radius:8px;padding:.75rem 1rem;color:var(--text-primary);font-size:1rem;transition:all .3s ease}.form-group input[type=text]:focus,.form-group input[type=email]:focus{border-color:var(--text-accent);background:#2d3748;outline:none;box-shadow:0 0 10px #ffd70033}.checkbox-group{flex-direction:row!important;align-items:center;gap:.75rem!important}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem;color:var(--text-secondary)}.checkbox-label input[type=checkbox]{appearance:none;width:18px;height:18px;border:2px solid var(--border-color);border-radius:4px;background:#2d3748cc;cursor:pointer;transition:all .3s ease}.checkbox-label input[type=checkbox]:checked{background:var(--text-accent);border-color:var(--text-accent)}.checkbox-label input[type=checkbox]:checked:after{content:"✓";display:block;text-align:center;color:var(--primary-bg);font-weight:700;font-size:12px;line-height:14px}.field-error{color:var(--health-color);font-size:.8rem;margin-top:.25rem;display:none}.form-buttons{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-align:center;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:44px;min-width:44px}.btn-primary{background:linear-gradient(45deg,var(--button-bg),var(--button-hover));color:#fff;border:2px solid transparent}.btn-primary:hover:not(:disabled){background:linear-gradient(45deg,var(--button-hover),var(--text-accent));transform:translateY(-2px);box-shadow:0 8px 16px #0003}.btn-primary:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-secondary{background:#2d3748cc;border:2px solid var(--border-color);color:var(--text-secondary)}.btn-secondary:hover:not(:disabled){background:#2d3748;border-color:var(--text-accent);color:var(--text-primary)}.btn-large{padding:1rem 2rem;font-size:1.1rem}.btn-loading{display:none}.success-panel{text-align:center;max-width:600px}.success-header{margin-bottom:2rem}.success-icon{font-size:4rem;margin-bottom:1rem;display:block}.success-header h1{color:var(--text-accent);font-size:2.5rem;margin:0 0 .5rem}.success-subtitle{color:var(--text-secondary);font-size:1.1rem;margin:0;font-style:italic}.benefits-section{margin-bottom:2rem;text-align:left}.benefits-section h2{color:var(--text-accent);font-size:1.5rem;margin-bottom:1rem;text-align:center}.benefits-list{display:flex;flex-direction:column;gap:1rem}.benefit-item{display:flex;align-items:center;gap:1rem;background:#2d374899;padding:1rem;border-radius:8px;border:1px solid var(--border-color)}.benefit-icon{font-size:1.5rem;flex-shrink:0}.success-actions{text-align:center}.success-note{color:var(--text-secondary);font-size:.9rem;margin:1rem 0 0;font-style:italic}.form-error{background:#dc35451a;border:1px solid #dc3545;color:#dc3545;padding:.75rem;border-radius:6px;font-size:.9rem;margin-top:1rem;text-align:center}.form-success{background:#28a7451a;border:1px solid #28a745;color:#28a745;padding:.75rem;border-radius:6px;font-size:.9rem;margin-top:1rem;text-align:center}.form-actions{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}.login-section{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color);text-align:center}.login-prompt{color:var(--text-secondary);margin-bottom:1rem;font-size:.9rem}.btn-link{background:transparent;border:none;color:var(--text-accent);cursor:pointer;text-decoration:underline;padding:.5rem;font-size:.9rem;transition:color .3s ease}.btn-link:hover{color:var(--text-primary)}.login-panel{max-width:450px}.login-content{padding:0}.login-options{margin-top:1.5rem;text-align:center;padding-top:1rem;border-top:1px solid var(--border-color)}.form-group input[type=password]{background:#2d3748cc;border:2px solid var(--border-color);border-radius:8px;padding:.75rem 1rem;color:var(--text-primary);font-size:1rem;transition:all .3s ease}.form-group input[type=password]:focus{border-color:var(--text-accent);background:#2d3748;outline:none;box-shadow:0 0 10px #ffd70033}.success-content{display:flex;flex-direction:column;gap:2rem;text-align:left}.success-message{text-align:center;margin-bottom:2rem}.success-message h2{color:var(--text-accent);font-size:1.8rem;margin:1rem 0 .5rem}.success-message p{color:var(--text-secondary);font-size:1.1rem;margin:0}.success-benefits h3{color:var(--text-accent);font-size:1.4rem;margin-bottom:1rem;text-align:center}.benefits-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.benefits-list li{background:#2d374899;padding:.75rem 1rem;border-radius:6px;border-left:4px solid var(--text-accent);color:var(--text-secondary);font-size:.95rem}.success-actions{text-align:center;margin-top:1rem}.feature-details h3{color:var(--text-accent);font-size:1.1rem;margin:0 0 .5rem;font-weight:600}.feature-details p{color:var(--text-secondary);font-size:.9rem;margin:0;line-height:1.4}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}@media (max-width: 768px){.subscription-content{grid-template-columns:1fr;gap:2rem}.login-panel,.success-panel{margin:1rem;padding:1.5rem}.form-actions{gap:.75rem}.benefits-list{gap:.5rem}}.char-creation-panel{background:var(--panel-bg);border:2px solid var(--border-color);border-radius:12px;width:90vw;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #00000080;position:relative}.char-creation-header{background:linear-gradient(135deg,var(--accent-bg),var(--secondary-bg));padding:20px;border-bottom:2px solid var(--border-color);border-radius:10px 10px 0 0;display:flex;justify-content:space-between;align-items:center}.char-creation-header h2{margin:0;color:var(--text-accent);font-size:1.8rem;font-weight:700}.close-btn{background:var(--health-color);border:none;color:#fff;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center}.close-btn:hover{background:#c82333;transform:scale(1.1)}.char-creation-content{padding:24px;display:grid;grid-template-columns:2fr 1fr;gap:32px;align-items:start}.char-form{display:flex;flex-direction:column;gap:20px}.form-section{display:flex;flex-direction:column;gap:8px}.form-section label{font-weight:700;color:var(--text-accent);font-size:1.1rem}.form-section input,.form-section select{padding:10px;border:2px solid var(--border-color);border-radius:6px;background:var(--secondary-bg);color:var(--text-primary);font-size:1rem;transition:border-color .3s ease}.form-section input:focus,.form-section select:focus{outline:none;border-color:var(--text-accent);box-shadow:0 0 0 2px #ffd70033}.attributes-section{background:var(--secondary-bg);border:2px solid var(--border-color);border-radius:8px;padding:20px;margin-top:16px}.attributes-section h3{margin:0 0 16px;color:var(--text-accent);text-align:center;font-size:1.3rem}.points-display{background:var(--accent-bg);color:var(--text-accent);padding:8px 16px;border-radius:20px;text-align:center;font-weight:700;font-size:1.1rem;margin-bottom:20px;border:2px solid var(--text-accent)}.attribute-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border-color)}.attribute-row:last-child{border-bottom:none}.attr-label{flex:1;font-weight:700;color:var(--text-secondary);min-width:100px}.attr-btn{width:32px;height:32px;border:2px solid var(--border-color);background:var(--button-bg);color:#fff;border-radius:4px;cursor:pointer;font-size:1.1rem;font-weight:700;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.attr-btn:hover:not(:disabled){background:var(--button-hover);transform:scale(1.1)}.attr-btn:disabled{background:#666;cursor:not-allowed;opacity:.5}.attr-value{min-width:32px;text-align:center;font-weight:700;font-size:1.2rem;color:var(--text-accent);margin:0 12px}.char-preview{background:var(--secondary-bg);border:2px solid var(--border-color);border-radius:8px;padding:20px;display:flex;flex-direction:column;gap:16px;position:sticky;top:0}.portrait-preview{width:128px;height:128px;border:3px solid var(--text-accent);border-radius:8px;background:var(--primary-bg);display:flex;align-items:center;justify-content:center;margin:0 auto;overflow:hidden}.portrait-preview img{width:100%;height:100%;object-fit:cover}.portrait-placeholder{color:var(--text-secondary);font-size:.9rem;text-align:center}.portrait-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:8px}.portrait-gallery-overlay{z-index:10000}.portrait-gallery-panel{max-width:900px;max-height:90vh;display:flex;flex-direction:column}.portrait-gallery-panel .subscription-header{display:flex;justify-content:space-between;align-items:center}.btn-close-gallery{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-primary);padding:4px 12px}.btn-close-gallery:hover{color:var(--text-accent)}.portrait-gallery-toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-color)}.gallery-filter,.gallery-search{padding:6px 10px;border-radius:4px;border:1px solid var(--border-color);background:var(--primary-bg);color:var(--text-primary)}.gallery-search{min-width:200px}.portrait-gallery-count{margin:8px 0;font-size:.9rem;color:var(--text-secondary)}.portrait-gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;padding:8px 0;overflow-y:auto;flex:1;min-height:200px}.portrait-gallery-card{cursor:pointer;border:2px solid transparent;border-radius:8px;overflow:hidden;background:var(--accent-bg);transition:border-color .2s,transform .2s}.portrait-gallery-card:hover{border-color:var(--text-accent);transform:scale(1.02)}.portrait-gallery-thumb{width:100%;aspect-ratio:1;object-fit:cover;display:block}.portrait-gallery-label{display:block;font-size:.7rem;padding:4px;text-align:center;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.portrait-gallery-load-more-wrap{padding:8px 0;text-align:center}.preview-stats{display:flex;flex-direction:column;gap:8px}.preview-stats>div{display:flex;justify-content:space-between;padding:6px 12px;background:var(--accent-bg);border-radius:4px;font-weight:700}.char-creation-actions{grid-column:1 / -1;display:flex;gap:16px;justify-content:center;padding-top:20px;border-top:2px solid var(--border-color)}.create-btn,.cancel-btn{padding:12px 32px;border:2px solid;border-radius:6px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s ease;min-width:140px}.create-btn{background:var(--success-color);border-color:var(--success-color);color:#fff}.create-btn:hover:not(:disabled){background:#218838;transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.create-btn:disabled{background:#666;border-color:#666;cursor:not-allowed;opacity:.6}.cancel-btn{background:transparent;border-color:var(--border-color);color:var(--text-secondary)}.cancel-btn:hover{background:var(--border-color);color:var(--text-primary);transform:translateY(-2px)}.character-face{width:64px;height:64px;border-radius:4px;object-fit:cover;image-rendering:auto}@media (max-width: 768px){.char-creation-content{grid-template-columns:1fr;gap:20px}.char-creation-panel{width:95vw;margin:20px auto}.attribute-row{flex-wrap:wrap;gap:8px}.attr-label{min-width:80px;flex:none}}.character-card{background:linear-gradient(145deg,#2d3748f2,#1a1a2ef2);border:2px solid var(--accent-bg);border-radius:20px;box-shadow:0 20px 40px #0000004d,0 0 30px #ffd7001a;transition:all .4s ease;overflow:hidden;position:relative;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.character-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 30px 60px #0006,0 0 50px #ffd70033;border-color:var(--text-accent)}.character-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--text-accent),#fff,var(--text-accent));opacity:0;transition:opacity .3s ease}.character-card:hover:before{opacity:1}.filled-card{background:linear-gradient(145deg,#2d3748fa,#1a1a2efa);border-color:var(--success-color)}.filled-card:hover{border-color:var(--text-accent);box-shadow:0 25px 50px #00000059,0 0 40px #28a7454d}.empty-card{background:linear-gradient(145deg,#1a1a2e99,#0f0f1ecc);border:2px dashed var(--border-color);cursor:pointer}.empty-card:hover{background:linear-gradient(145deg,#2d3748cc,#1a1a2ee6);border-color:var(--text-accent);border-style:solid}.character-header{background:linear-gradient(135deg,rgba(255,215,0,.1) 0%,transparent 100%);padding:1.5rem;border-bottom:1px solid rgba(255,215,0,.2);display:flex;align-items:center;gap:1rem;position:relative}.character-header:after{content:"";position:absolute;bottom:0;left:1rem;right:1rem;height:1px;background:linear-gradient(90deg,transparent,var(--text-accent),transparent)}.slot-number{background:linear-gradient(45deg,var(--accent-bg),var(--button-bg));color:var(--text-accent);font-weight:700;font-size:1.1rem;padding:.5rem .8rem;border-radius:12px;border:1px solid var(--text-accent);box-shadow:0 4px 8px #0003;text-shadow:0 1px 2px rgba(0,0,0,.5)}.character-avatar{width:60px;height:60px;border-radius:50%;border:3px solid var(--text-accent);box-shadow:0 0 20px #ffd7004d;background:linear-gradient(45deg,var(--accent-bg),var(--secondary-bg));display:flex;align-items:center;justify-content:center;font-size:1.8rem;position:relative;overflow:hidden}.character-avatar:before{content:"";position:absolute;inset:-2px;background:linear-gradient(45deg,var(--text-accent),#fff,var(--text-accent));border-radius:50%;z-index:-1;animation:shimmer 3s ease-in-out infinite}@keyframes shimmer{0%,to{opacity:.5}50%{opacity:1}}.character-body{padding:1.5rem;flex:1}.character-name{color:var(--text-accent);font-size:1.4rem;font-weight:700;margin:0 0 .5rem;text-shadow:0 2px 4px rgba(0,0,0,.5);background:linear-gradient(45deg,var(--text-accent),#fff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.character-details{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin:1rem 0}.character-detail{background:#0f34604d;padding:.8rem;border-radius:10px;border:1px solid rgba(255,215,0,.2);text-align:center;transition:all .3s ease}.character-detail:hover{background:#0f346080;border-color:var(--text-accent);transform:translateY(-2px)}.character-detail-label{color:var(--text-secondary);font-size:.8rem;margin-bottom:.3rem;text-transform:uppercase;letter-spacing:.5px}.character-detail-value{color:var(--text-primary);font-weight:700;font-size:1rem}.character-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;margin-top:1rem}.stat-item{background:#1a1a2ecc;padding:.6rem;border-radius:8px;border:1px solid var(--border-color);text-align:center;transition:all .3s ease}.stat-item:hover{background:#2d3748cc;border-color:var(--text-accent);transform:scale(1.05)}.stat-label{color:var(--text-secondary);font-size:.7rem;margin-bottom:.2rem;text-transform:uppercase;letter-spacing:.3px}.stat-value{color:var(--text-primary);font-weight:700;font-size:1.1rem}.character-actions{padding:1rem 1.5rem;background:linear-gradient(135deg,rgba(15,52,96,.2) 0%,transparent 100%);border-top:1px solid rgba(255,215,0,.1);display:flex;gap:.8rem}.character-actions .btn{flex:1;padding:.6rem 1rem;font-size:.9rem;border-radius:10px;position:relative;overflow:hidden}.character-actions .btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.character-actions .btn:hover:before{left:100%}.empty-content{padding:3rem 2rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem;min-height:200px;justify-content:center}.empty-slot-number{background:linear-gradient(45deg,#1a1a2ecc,#2d374899);color:var(--text-secondary);font-weight:700;padding:.5rem .8rem;border-radius:12px;border:2px dashed var(--border-color);margin-bottom:1rem}.add-character-icon{font-size:3rem;color:var(--border-color);transition:all .3s ease;background:linear-gradient(45deg,var(--border-color),var(--text-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.empty-card:hover .add-character-icon{color:var(--text-accent);background:linear-gradient(45deg,var(--text-accent),#fff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transform:scale(1.1)}.empty-title{color:var(--text-secondary);font-size:1.2rem;font-weight:600;margin:0;transition:color .3s ease}.empty-card:hover .empty-title{color:var(--text-primary)}.empty-subtitle{color:var(--border-color);font-size:.9rem;margin:0;transition:color .3s ease}.empty-card:hover .empty-subtitle{color:var(--text-secondary)}@media (max-width: 768px){.character-card{border-radius:15px;box-shadow:0 15px 30px #00000040,0 0 20px #ffd70014}.character-header{padding:1rem;flex-direction:column;text-align:center;gap:.8rem}.character-body{padding:1rem}.character-details{grid-template-columns:1fr;gap:.6rem}.character-stats{grid-template-columns:repeat(2,1fr);gap:.6rem}.character-actions{padding:1rem;flex-direction:column;gap:.6rem}.empty-content{padding:2rem 1rem;min-height:150px}.add-character-icon{font-size:2.5rem}}@keyframes slideInScale{0%{opacity:0;transform:translateY(30px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.character-card{animation:slideInScale .6s ease-out}.character-card[data-class=Paladin]{box-shadow:0 20px 40px #0000004d,0 0 30px #ffd70026}.character-card[data-class=Sorcerer]{box-shadow:0 20px 40px #0000004d,0 0 30px #8a2be226}.character-card[data-class=Archer]{box-shadow:0 20px 40px #0000004d,0 0 30px #228b2226}.character-card[data-class=Thief]{box-shadow:0 20px 40px #0000004d,0 0 30px #69696926}.char-creation-panel{background:linear-gradient(145deg,#2d3748fa,#1a1a2efa);border:2px solid var(--accent-bg);border-radius:25px;box-shadow:0 30px 60px #0006,0 0 50px #ffd70026;width:95vw;max-width:1200px;max-height:95vh;overflow-y:auto;position:relative;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);animation:slideInScale .6s ease-out}.char-creation-panel:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--text-accent),#fff,var(--text-accent));border-radius:25px 25px 0 0}.char-creation-header{background:linear-gradient(135deg,rgba(255,215,0,.1) 0%,transparent 100%);padding:2rem;border-bottom:2px solid rgba(255,215,0,.2);text-align:center;position:relative}.char-creation-header:after{content:"";position:absolute;bottom:0;left:2rem;right:2rem;height:1px;background:linear-gradient(90deg,transparent,var(--text-accent),transparent)}.char-creation-content{padding:2rem;display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}.creation-section{background:linear-gradient(145deg,#0f34604d,#1a1a2e80);border:2px solid rgba(255,215,0,.2);border-radius:18px;padding:2rem;margin-bottom:2rem;position:relative;transition:all .4s ease;overflow:hidden}.creation-section:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--text-accent),transparent);opacity:0;transition:opacity .3s ease}.creation-section:hover{border-color:var(--text-accent);transform:translateY(-5px);box-shadow:0 15px 30px #0000004d,0 0 25px #ffd70033}.creation-section:hover:before{opacity:1}.creation-section h3{color:var(--text-accent);font-size:1.4rem;font-weight:700;margin:0 0 1.5rem;text-align:center;text-shadow:0 2px 4px rgba(0,0,0,.5);background:linear-gradient(45deg,var(--text-accent),#fff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.name-input-container{display:flex;gap:1rem;align-items:center}.hero-name-input{flex:1;padding:1rem 1.5rem;border:2px solid var(--border-color);border-radius:12px;background:linear-gradient(145deg,#1a1a2ecc,#2d374899);color:var(--text-primary);font-size:1.1rem;font-weight:600;transition:all .3s ease;box-shadow:inset 0 2px 4px #0000004d}.hero-name-input:focus{outline:none;border-color:var(--text-accent);box-shadow:0 0 20px #ffd7004d,inset 0 2px 4px #0000004d;transform:scale(1.02)}.btn-generate-name{padding:1rem 1.5rem;background:linear-gradient(45deg,var(--accent-bg),var(--button-bg));border:2px solid var(--text-accent);border-radius:12px;color:var(--text-primary);font-weight:700;cursor:pointer;transition:all .3s ease;white-space:nowrap;position:relative;overflow:hidden}.btn-generate-name:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.btn-generate-name:hover{background:linear-gradient(45deg,var(--button-hover),var(--text-accent));transform:translateY(-2px) scale(1.05);box-shadow:0 8px 16px #0000004d}.btn-generate-name:hover:before{left:100%}.race-grid,.class-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.race-card,.class-card{position:relative;transition:all .3s ease}.race-card input[type=radio],.class-card input[type=radio]{position:absolute;opacity:0;cursor:pointer}.race-card-label,.class-card-label{display:block;background:linear-gradient(145deg,#1a1a2ecc,#2d374899);border:2px solid var(--border-color);border-radius:15px;padding:1.5rem;cursor:pointer;transition:all .4s ease;text-align:center;position:relative;overflow:hidden;min-height:120px;display:flex;flex-direction:column;justify-content:center;gap:.5rem}.race-card-label:before,.class-card-label:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,transparent,rgba(255,215,0,.1),transparent);opacity:0;transition:opacity .3s ease}.race-card-label:hover,.class-card-label:hover{border-color:var(--text-accent);transform:translateY(-5px) scale(1.02);box-shadow:0 10px 20px #0000004d,0 0 20px #ffd70033}.race-card-label:hover:before,.class-card-label:hover:before{opacity:1}.race-card input[type=radio]:checked+.race-card-label,.class-card input[type=radio]:checked+.class-card-label{background:linear-gradient(145deg,#ffd70033,#2d3748cc);border-color:var(--text-accent);box-shadow:0 0 30px #ffd70066,inset 0 0 20px #ffd7001a;transform:scale(1.05)}.race-icon,.class-icon{font-size:2.5rem;margin-bottom:.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.race-name,.class-name{font-weight:700;font-size:1.2rem;color:var(--text-primary);margin-bottom:.5rem;text-shadow:0 1px 2px rgba(0,0,0,.5)}.race-bonuses,.class-description{font-size:.9rem;color:var(--text-secondary);line-height:1.3;opacity:.9}.attribute-mode-selector{display:flex;gap:1rem;margin-bottom:2rem;justify-content:center}.radio-option{display:flex;align-items:center;gap:.5rem;background:linear-gradient(145deg,#1a1a2ecc,#2d374899);border:2px solid var(--border-color);border-radius:12px;padding:1rem 1.5rem;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.radio-option:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,transparent,rgba(255,215,0,.1),transparent);opacity:0;transition:opacity .3s ease}.radio-option:hover{border-color:var(--text-accent);transform:translateY(-2px);box-shadow:0 5px 10px #0003}.radio-option:hover:before{opacity:1}.radio-option input[type=radio]:checked+span{color:var(--text-accent);font-weight:700}.radio-option input[type=radio]:checked{accent-color:var(--text-accent)}.attributes-display{background:linear-gradient(145deg,#1a1a2e99,#0f0f1ecc);border:2px solid rgba(255,215,0,.3);border-radius:15px;padding:2rem}.attributes-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:1.5rem;font-style:italic}.attributes-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.attribute-item{background:#0f346066;border:1px solid rgba(255,215,0,.3);border-radius:10px;padding:1rem;text-align:center;transition:all .3s ease}.attribute-item:hover{background:#0f346099;border-color:var(--text-accent);transform:translateY(-2px) scale(1.02)}.attribute-icon{font-size:1.5rem;margin-bottom:.5rem;display:block}.attribute-details{display:flex;flex-direction:column;gap:.3rem}.attribute-name{font-weight:700;color:var(--text-primary)}.attribute-value{font-size:1.2rem;font-weight:700;color:var(--text-accent);text-shadow:0 1px 2px rgba(0,0,0,.5)}.attributes-editor{background:linear-gradient(145deg,#1a1a2e99,#0f0f1ecc);border:2px solid rgba(255,215,0,.3);border-radius:15px;padding:2rem}.attributes-manual-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:2rem}.manual-attribute-row{display:flex;align-items:center;justify-content:space-between;background:#0f34604d;border:1px solid rgba(255,215,0,.2);border-radius:10px;padding:1rem;transition:all .3s ease}.manual-attribute-row:hover{background:#0f346080;border-color:var(--text-accent)}.manual-attr-name{font-weight:700;color:var(--text-primary);flex:1}.manual-attr-controls{display:flex;align-items:center;gap:1rem}.manual-attr-btn{width:35px;height:35px;border:2px solid var(--border-color);background:linear-gradient(45deg,var(--button-bg),var(--button-hover));color:#fff;border-radius:8px;cursor:pointer;font-size:1.2rem;font-weight:700;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.manual-attr-btn:hover:not(:disabled){background:linear-gradient(45deg,var(--button-hover),var(--text-accent));transform:scale(1.1);box-shadow:0 4px 8px #0003}.manual-attr-btn:disabled{background:#666;cursor:not-allowed;opacity:.5;transform:none}.simplified-preview-section{background:linear-gradient(145deg,#1a1a2e99,#0f0f1ecc);border:2px solid rgba(255,215,0,.3);border-radius:15px;padding:1.5rem;margin-bottom:2rem}.simplified-preview{display:flex;flex-direction:column;gap:1.5rem;align-items:center}.simplified-preview .preview-vitals{width:100%;max-width:300px}.attribute-showcase{background:#0f346066;border:1px solid rgba(255,215,0,.3);border-radius:10px;padding:1rem;text-align:center;transition:all .3s ease;display:flex;flex-direction:column;gap:.5rem}.attribute-showcase:hover{background:#0f346099;border-color:var(--text-accent);transform:translateY(-2px) scale(1.02)}.attr-label{font-weight:700;color:var(--text-primary);font-size:.9rem;text-shadow:0 1px 2px rgba(0,0,0,.5)}.attr-value-container{display:flex;flex-direction:column;align-items:center;gap:.3rem}.attr-value{font-size:1.3rem;font-weight:700;color:var(--text-accent);text-shadow:0 1px 2px rgba(0,0,0,.5);line-height:1}.bonus-part{font-size:.85em;font-weight:700;margin-left:.2em}.bonus-part.positive{color:#4ade80;text-shadow:0 0 4px rgba(74,222,128,.5)}.bonus-part.negative{color:#f87171;text-shadow:0 0 4px rgba(248,113,113,.5)}.attributes-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;align-items:stretch}.attribute-showcase{min-height:80px;justify-content:center}.attribute-editor-item{background:#0f34604d;border:1px solid rgba(255,215,0,.2);border-radius:10px;padding:1rem;display:flex;align-items:center;justify-content:space-between;transition:all .3s ease;gap:1rem}.attribute-editor-item:hover{background:#0f346080;border-color:var(--text-accent)}.attr-controls{display:flex;align-items:center;gap:1rem}.attr-btn{width:35px;height:35px;border:2px solid var(--border-color);background:linear-gradient(45deg,var(--button-bg),var(--button-hover));color:#fff;border-radius:8px;cursor:pointer;font-size:1.2rem;font-weight:700;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.attr-btn:hover:not(:disabled){background:linear-gradient(45deg,var(--button-hover),var(--text-accent));transform:scale(1.1);box-shadow:0 4px 8px #0003}.attr-btn:disabled{background:#666;cursor:not-allowed;opacity:.5;transform:none}.attr-value{min-width:50px;text-align:center;font-weight:700;font-size:1.3rem;color:var(--text-accent);background:#1a1a2ecc;border:1px solid var(--text-accent);border-radius:8px;padding:.5rem;text-shadow:0 1px 2px rgba(0,0,0,.5)}.game-ui{width:100%;height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#1a1a2e,#16213e)}.game-world-container{flex:1;padding:20px;overflow-y:auto}.world-view{max-width:1200px;margin:0 auto}.world-map{background:#2d3748e6;border:2px solid var(--border-color);border-radius:12px;padding:30px;backdrop-filter:blur(10px)}.current-location{text-align:center;margin-bottom:40px;padding:20px;background:linear-gradient(135deg,#ffd7001a,#ffd7000d);border-radius:8px;border:1px solid rgba(255,215,0,.3)}.current-location h3{color:var(--text-accent);font-size:2.2rem;margin:0 0 15px;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.current-location p{color:var(--text-secondary);font-size:1.1rem;margin:0 0 20px;line-height:1.6}.location-details{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px;margin-top:20px;padding-top:20px;border-top:1px solid rgba(255,215,0,.2)}.time-weather{display:flex;gap:20px;align-items:center}.time-weather span{background:#0000004d;padding:8px 12px;border-radius:6px;font-size:.9rem;color:var(--text-secondary)}.party-gold{font-weight:700;color:var(--text-accent);font-size:1.1rem}.world-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px;margin-top:30px}.action-section{background:#10346099;border:1px solid var(--border-color);border-radius:12px;padding:25px;backdrop-filter:blur(5px)}.action-section h4{color:var(--text-accent);font-size:1.3rem;margin:0 0 20px;text-align:center;padding-bottom:12px;border-bottom:1px solid rgba(255,215,0,.3)}.action-btn{width:100%;padding:12px 20px;margin:8px 0;background:linear-gradient(135deg,var(--button-bg) 0%,#1e40af 100%);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .3s ease;position:relative;overflow:hidden}.action-btn:hover{background:linear-gradient(135deg,var(--button-hover) 0%,#2563eb 100%);transform:translateY(-2px);box-shadow:0 8px 25px #3b82f666}.action-btn:active{transform:translateY(0);box-shadow:0 4px 15px #3b82f64d}.modal-content{background:linear-gradient(135deg,var(--panel-bg) 0%,var(--secondary-bg) 100%);border:2px solid var(--border-color);border-radius:12px;padding:30px;max-width:90vw;max-height:90vh;overflow-y:auto;position:relative}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:15px;border-bottom:2px solid var(--border-color)}.modal-header h3{color:var(--text-accent);font-size:1.8rem;margin:0}.close-btn{background:none;border:none;color:var(--text-secondary);font-size:2rem;cursor:pointer;padding:5px 10px;border-radius:50%;transition:all .3s ease}.close-btn:hover{background:#dc354533;color:#dc3545}.travel-modal{min-width:600px}.travel-locations{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.location-card{background:#10346066;border:1px solid var(--border-color);border-radius:8px;padding:20px;cursor:pointer;transition:all .3s ease}.location-card:hover{background:#103460b3;border-color:var(--text-accent);transform:translateY(-3px);box-shadow:0 8px 25px #0000004d}.location-card h4{color:var(--text-accent);margin:0 0 10px;font-size:1.2rem}.location-card p{color:var(--text-secondary);margin:0 0 15px;line-height:1.5}.travel-time{color:var(--warning-color);font-size:.9rem;font-weight:500}.combat-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000e6;z-index:1000;display:flex;align-items:center;justify-content:center}.combat-container{border:2px solid rgba(255,215,0,.3);border-radius:18px;padding:1.5rem;position:relative;transition:all .4s ease;overflow:hidden}.random-character-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--text-accent),transparent);opacity:0;transition:opacity .3s ease}.random-character-card:hover{border-color:var(--text-accent);transform:translateY(-5px) scale(1.02);box-shadow:0 15px 30px #0000004d,0 0 25px #ffd70033}.random-character-card:hover:before{opacity:1}.random-char-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,215,0,.2)}.random-char-portrait{width:64px;height:64px;border-radius:50%;border:3px solid var(--text-accent);box-shadow:0 0 20px #ffd7004d;background:linear-gradient(45deg,var(--accent-bg),var(--secondary-bg));display:flex;align-items:center;justify-content:center;font-size:1.5rem;position:relative;overflow:hidden;flex-shrink:0}.random-char-portrait:before{content:"";position:absolute;inset:-2px;background:linear-gradient(45deg,var(--text-accent),#fff,var(--text-accent));border-radius:50%;z-index:-1;animation:shimmer 3s ease-in-out infinite}.random-char-portrait canvas{width:100%;height:100%;border-radius:50%}.random-char-info{flex:1}.random-char-name{color:var(--text-accent);font-size:1.3rem;font-weight:700;margin:0 0 .3rem;text-shadow:0 2px 4px rgba(0,0,0,.5)}.random-char-details{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:1rem}.random-char-detail{background:#0f346066;padding:.5rem;border-radius:8px;border:1px solid rgba(255,215,0,.2);text-align:center;transition:all .3s ease}.random-char-detail:hover{background:#0f346099;border-color:var(--text-accent);transform:translateY(-2px)}.random-char-detail-label{color:var(--text-secondary);font-size:.7rem;margin-bottom:.2rem;text-transform:uppercase;letter-spacing:.5px}.random-char-detail-value{color:var(--text-primary);font-weight:700;font-size:.9rem}.random-char-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.random-stat-item{background:#1a1a2ecc;padding:.4rem;border-radius:6px;border:1px solid var(--border-color);text-align:center;transition:all .3s ease}.random-stat-item:hover{background:#2d3748cc;border-color:var(--text-accent);transform:scale(1.05)}.random-stat-label{color:var(--text-secondary);font-size:.6rem;margin-bottom:.1rem;text-transform:uppercase;letter-spacing:.3px}.random-stat-value{color:var(--text-primary);font-weight:700;font-size:.9rem}.random-team-actions{display:flex;justify-content:center;gap:1rem;padding-top:1.5rem;border-top:2px solid rgba(255,215,0,.2)}.random-team-actions .btn{padding:.8rem 2rem;font-size:1rem;border-radius:12px;font-weight:600;transition:all .3s ease;position:relative;overflow:hidden;min-width:140px}.random-team-actions .btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.random-team-actions .btn:hover:before{left:100%}.btn-accept-team{background:linear-gradient(45deg,var(--success-color),#20a743);border:2px solid var(--success-color);color:#fff}.btn-accept-team:hover:not(:disabled){background:linear-gradient(45deg,#20a743,var(--text-accent));transform:translateY(-2px) scale(1.05);box-shadow:0 8px 16px #0000004d}.btn-reroll-team{background:linear-gradient(45deg,var(--button-bg),var(--button-hover));border:2px solid var(--button-bg);color:#fff}.btn-reroll-team:hover:not(:disabled){background:linear-gradient(45deg,var(--button-hover),var(--text-accent));transform:translateY(-2px) scale(1.05);box-shadow:0 8px 16px #0000004d}.btn-manual-creation{background:#2d3748cc;border:2px solid var(--border-color);color:var(--text-secondary)}.btn-manual-creation:hover:not(:disabled){background:var(--border-color);color:var(--text-primary);transform:translateY(-2px) scale(1.05);box-shadow:0 8px 16px #0000004d}@media (max-width: 768px){.random-team-dialog{width:95vw;margin:10px;border-radius:18px}.random-team-header{padding:1.5rem}.random-team-title{font-size:1.8rem}.random-team-content{padding:1.5rem}.random-team-preview{grid-template-columns:1fr;gap:1rem}.random-character-card{padding:1rem}.random-char-header{flex-direction:column;text-align:center;gap:.8rem}.random-char-portrait{width:48px;height:48px;font-size:1.2rem}.random-char-details{grid-template-columns:1fr;gap:.3rem}.random-char-stats{grid-template-columns:repeat(2,1fr);gap:.3rem}.random-team-actions{flex-direction:column;gap:.8rem}.random-team-actions .btn{padding:.7rem 1.5rem;font-size:.9rem}}@media (max-width: 480px){.random-team-header{padding:1rem}.random-team-title{font-size:1.5rem}.random-team-subtitle{font-size:1rem}.random-team-content{padding:1rem}.random-char-name{font-size:1.1rem}.random-char-stats{grid-template-columns:1fr}}.tutorial-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;z-index:10000;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(5px)}.tutorial-message{background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;padding:30px;border-radius:15px;max-width:500px;text-align:center;box-shadow:0 10px 30px #00000080;border:2px solid #3498db;animation:tutorialSlideIn .5s ease-out}.tutorial-message h3{margin:0 0 20px;color:#3498db;font-size:24px;font-weight:700}.tutorial-message p{margin:0 0 25px;font-size:16px;line-height:1.6;color:#ecf0f1}.tutorial-message button{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:700;margin:0 10px;transition:all .3s ease;box-shadow:0 4px 15px #3498db4d}.tutorial-message button:hover{background:linear-gradient(135deg,#2980b9,#1f5f8b);transform:translateY(-2px);box-shadow:0 6px 20px #3498db66}.tutorial-message button:last-child{background:linear-gradient(135deg,#95a5a6,#7f8c8d)}.tutorial-message button:last-child:hover{background:linear-gradient(135deg,#7f8c8d,#6c7b7d)}@keyframes tutorialSlideIn{0%{opacity:0;transform:translateY(-50px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 768px){.tutorial-message{margin:20px;padding:20px;max-width:calc(100% - 40px)}.tutorial-message h3{font-size:20px}.tutorial-message p{font-size:14px}.tutorial-message button{padding:10px 20px;font-size:13px;margin:5px}}.game-interface{display:flex;flex-direction:column;height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);color:#e8e8e8;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.game-header{background:linear-gradient(90deg,#2c3e50,#34495e);border-bottom:2px solid #3498db;padding:8px 16px}.status-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:14px}.status-item{display:flex;align-items:center;gap:8px}.status-label{color:#bdc3c7;font-weight:600}.status-value{color:#ecf0f1;font-weight:700}.game-navigation{display:flex;gap:4px;justify-content:center}.nav-btn{background:linear-gradient(135deg,#34495e,#2c3e50);border:1px solid #3498db;color:#ecf0f1;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease}.nav-btn:hover{background:linear-gradient(135deg,#3498db,#2980b9);transform:translateY(-1px)}.nav-btn.active{background:linear-gradient(135deg,#e74c3c,#c0392b);border-color:#e74c3c}.game-main-area{display:flex;flex:1;position:relative}.game-view{display:none;flex:1;padding:20px;overflow-y:auto}.game-view.active{display:flex;flex-direction:column}.visual-exploration-container{display:flex;flex-direction:column;align-items:center;gap:20px}.world-map-container{display:flex;flex-direction:column;align-items:center;gap:20px}#world-map{border:2px solid #3498db;border-radius:8px;background:#2c3e50;box-shadow:0 4px 8px #0000004d}.party-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:30px}.party-member{background:linear-gradient(135deg,#34495e,#2c3e50);border:2px solid #3498db;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;transition:all .2s ease;cursor:pointer}.party-member:hover{border-color:#e74c3c;transform:translateY(-2px);box-shadow:0 4px 12px #e74c3c4d}.member-portrait{width:60px;height:60px;background:linear-gradient(135deg,#9b59b6,#8e44ad);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;border:2px solid #ecf0f1}.member-info{flex:1}.member-name{color:#f39c12;margin:0 0 8px;font-size:18px;font-weight:700}.member-stats{display:flex;flex-direction:column;gap:4px}.stat{color:#ecf0f1;font-size:14px}.hp-value{color:#e74c3c;font-weight:700}.mp-value{color:#3498db;font-weight:700}.level-value{color:#f39c12;font-weight:700}.party-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.inventory-container{display:flex;gap:20px;height:100%}.inventory-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:8px;flex:1;max-height:400px;overflow-y:auto;padding:16px;background:#2c3e50cc;border-radius:8px}.inventory-slot{width:60px;height:60px;border:2px solid #3498db;border-radius:6px;background:#34495e80;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.inventory-slot:hover{border-color:#e74c3c;background:#e74c3c33}.inventory-slot.filled{background:#2ecc714d;border-color:#2ecc71}.inventory-info{width:300px;background:#2c3e50cc;border:1px solid #3498db;border-radius:8px;padding:20px}.inventory-info h3{color:#f39c12;margin:0 0 16px}.spells-container{display:flex;gap:20px;height:100%}.spell-schools{display:flex;flex-direction:column;gap:8px;width:200px}.spell-school{background:linear-gradient(135deg,#34495e,#2c3e50);border:1px solid #3498db;color:#ecf0f1;padding:12px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease}.spell-school:hover{background:linear-gradient(135deg,#3498db,#2980b9)}.spell-school.active{background:linear-gradient(135deg,#e74c3c,#c0392b);border-color:#e74c3c}.spells-list{flex:1;background:#2c3e50cc;border:1px solid #3498db;border-radius:8px;padding:16px;overflow-y:auto;max-height:500px}.spell-item{background:#34495e80;border:1px solid #3498db;border-radius:6px;padding:12px;margin-bottom:8px;cursor:pointer;transition:all .2s ease}.spell-item:hover{background:#3498db4d;border-color:#e74c3c}.spell-details{width:300px;background:#2c3e50cc;border:1px solid #3498db;border-radius:8px;padding:20px}.spellbook-mastery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;padding:12px 4px 18px}.spell-school-card{--school-color: #4a90e2;background:#0f172ac7;border:1px solid color-mix(in srgb,var(--school-color) 55%,transparent);border-left:4px solid var(--school-color);border-radius:10px;padding:14px;display:flex;flex-direction:column;gap:10px;box-shadow:0 2px 6px #00000059;color:#e2e8f0}.spell-school-card .school-header{display:flex;align-items:center;gap:8px}.spell-school-card .school-icon{font-size:22px;line-height:1}.spell-school-card .school-name{flex:1;margin:0;font-size:16px;font-weight:700;color:#f7fafc}.mastery-tier-pill{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:3px 8px;border-radius:999px;border:1px solid rgba(255,255,255,.2);color:#1a202c;background:#cbd5e0}.mastery-tier-pill.mastery-tier-expert{background:linear-gradient(135deg,#38bdf8,#0284c7);color:#0c1424}.mastery-tier-pill.mastery-tier-master{background:linear-gradient(135deg,#c084fc,#7c3aed);color:#f7fafc}.mastery-tier-pill.mastery-tier-grandmaster{background:linear-gradient(135deg,#fde047,#f59e0b);color:#1a202c;box-shadow:0 0 0 1px #fde047 inset,0 0 8px #fde04773}.mastery-progress{position:relative;height:18px;border-radius:9px;background:#0f172ab3;border:1px solid rgba(255,255,255,.08);overflow:hidden}.mastery-progress-fill{position:absolute;inset:0 auto 0 0;background:var(--school-color);opacity:.55;transition:width .24s ease-out}.mastery-progress-label{position:relative;z-index:1;display:block;text-align:center;font-size:11px;line-height:18px;color:#f7fafc;text-shadow:0 1px 1px rgba(0,0,0,.7)}.mastery-mod-chips{list-style:none;display:flex;gap:6px;padding:0;margin:0;flex-wrap:wrap}.mastery-mod-chip{font-size:12px;font-weight:600;padding:3px 8px;border-radius:6px;background:#2d3748d9;border:1px solid rgba(255,255,255,.06);color:#e2e8f0}.mastery-mod-chip.mastery-mod-power{color:#fda4af}.mastery-mod-chip.mastery-mod-mana{color:#93c5fd}.mastery-mod-chip.mastery-mod-duration{color:#fcd34d}.spell-school-card .school-spells{list-style:none;padding:8px 0 0;margin:4px 0 0;display:flex;flex-direction:column;gap:4px;border-top:1px dashed rgba(255,255,255,.08)}.spell-school-card .spell-row{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;font-size:13px;padding:2px 0}.spell-school-card .spell-row-name{color:#f7fafc;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.spell-school-card .spell-row-level{color:#a0aec0;font-size:11px;font-variant-numeric:tabular-nums}.spell-school-card .spell-row-mana{color:#93c5fd;font-variant-numeric:tabular-nums}.spell-school-card .spell-row-mana-reduced{color:#34d399}.spell-school-card .spell-row-mana-base{color:#718096;margin-left:4px;font-size:11px}.spell-school-card .school-empty{margin:0;color:#a0aec0;font-style:italic;font-size:12px}@media (max-width: 720px){.spellbook-mastery-grid{grid-template-columns:1fr}}.quests-container{display:flex;gap:20px;height:100%}.quests-list{flex:1;background:#2c3e50cc;border:1px solid #3498db;border-radius:8px;padding:16px;overflow-y:auto;max-height:500px}.quest-item{background:#34495e80;border:1px solid #3498db;border-radius:6px;padding:16px;margin-bottom:12px;cursor:pointer;transition:all .2s ease}.quest-item:hover{background:#3498db4d;border-color:#e74c3c}.quest-item.active{background:#e74c3c4d;border-color:#e74c3c}.quest-details{width:400px;background:#2c3e50cc;border:1px solid #3498db;border-radius:8px;padding:20px}.map-container{display:flex;flex-direction:column;align-items:center;gap:20px}#world-map-large{border:2px solid #3498db;border-radius:8px;background:#2c3e50;box-shadow:0 4px 8px #0000004d}.map-legend{display:flex;gap:20px;flex-wrap:wrap;justify-content:center}.legend-item{display:flex;align-items:center;gap:8px;color:#ecf0f1;font-size:14px}.party-status-item{background:#34495e80;border:1px solid #3498db;border-radius:6px;padding:12px;margin-bottom:8px}.party-status-item .member-name{color:#f39c12;font-weight:600;margin-bottom:8px}.status-bars{display:flex;flex-direction:column;gap:4px}.hp-bar,.mp-bar{height:8px;background:#34495ecc;border-radius:4px;overflow:hidden}.hp-bar .bar-fill{height:100%;background:linear-gradient(90deg,#e74c3c,#c0392b);transition:width .3s ease}.mp-bar .bar-fill{height:100%;background:linear-gradient(90deg,#3498db,#2980b9);transition:width .3s ease}.combatant-card .combat-portrait-wrap{position:relative;width:100%;aspect-ratio:3 / 4;margin-bottom:6px;background:#0f172a;border-radius:6px;overflow:hidden}.combatant-card .combat-portrait{width:100%;height:100%;object-fit:cover;display:block}.combatant-card .combat-portrait-badge{position:absolute;top:4px;right:4px;background:#000000a6;color:#f0f4f8;padding:2px 6px;border-radius:10px;font-size:.72em;font-weight:600;letter-spacing:.2px}.combatant-card .combat-stats-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px;font-size:.82em;color:#cbd5e1}.combatant-card .combat-stat-chip{display:inline-flex;align-items:center;gap:4px;padding:1px 6px;background:#0f172a99;border:1px solid rgba(148,163,184,.3);border-radius:999px}.message-log{max-height:200px;overflow-y:auto;background:#34495e80;border:1px solid #3498db;border-radius:6px;padding:12px}.message{color:#ecf0f1;font-size:12px;margin-bottom:4px;padding:4px 0;border-bottom:1px solid rgba(52,152,219,.3)}.game-footer{background:linear-gradient(90deg,#2c3e50,#34495e);border-top:2px solid #3498db;padding:12px 16px}.combat-status{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding:12px;background:#e74c3c33;border:1px solid #e74c3c;border-radius:6px}.combat-status.hidden{display:none}.combat-info{display:flex;gap:20px;color:#ecf0f1;font-weight:600}.combat-actions{display:flex;gap:8px}.combat-btn{background:linear-gradient(135deg,#e74c3c,#c0392b);border:none;color:#fff;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease}.combat-btn:hover:not(:disabled){background:linear-gradient(135deg,#c0392b,#e74c3c);transform:translateY(-1px)}.combat-btn:disabled,.combat-btn.is-locked{opacity:.5;cursor:not-allowed;background:linear-gradient(135deg,#5a5a5a,#3d3d3d);transform:none}.combat-log-overlay{position:relative;width:100%;max-height:160px;overflow-y:auto;background:#0a0e16d1;border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:8px 10px;color:#e8eef5;font-size:12px;line-height:1.4;font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;box-shadow:0 6px 18px #0000008c;z-index:1;pointer-events:auto}.combat-log-overlay[hidden]{display:none}.combat-log-row{padding:2px 0;border-bottom:1px dashed rgba(255,255,255,.06);word-break:break-word}.combat-log-row:last-child{border-bottom:none}.combat-spell-picker-backdrop{position:fixed;inset:0;z-index:12100;background:#0000008c;display:flex;align-items:center;justify-content:center;padding:16px}.combat-spell-picker{position:relative;display:flex;flex-direction:column;max-width:min(520px,96vw);max-height:80vh;background:#121a28;border:1px solid rgba(255,255,255,.12);border-radius:12px;color:#e8eef5;box-shadow:0 12px 40px #0000008c;overflow:hidden}.combat-spell-picker-topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.08);background:#e74c3c1f}.combat-spell-picker-topbar h2{margin:0;font-size:1.05em}.combat-spell-picker-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:#00000040;color:#e8eef5;font-size:22px;line-height:1;cursor:pointer;padding:0}.combat-spell-picker-close:hover{background:#ffffff1f}.combat-spell-picker-close:focus-visible{outline:2px solid #f39c12;outline-offset:2px}.combat-spell-picker-body{overflow-y:auto;padding:8px}.combat-spell-row{display:grid;grid-template-columns:24px 1fr auto auto auto;align-items:center;gap:10px;width:100%;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:8px;padding:8px 10px;margin-bottom:6px;color:inherit;text-align:left;cursor:pointer;font-size:.92em}.combat-spell-row:hover:not(.is-disabled){background:#e74c3c24;border-color:#e74c3c59}.combat-spell-row.is-disabled,.combat-spell-row:disabled{opacity:.45;cursor:not-allowed}.combat-spell-icon{font-size:1.05em;text-align:center}.combat-spell-name{font-weight:600}.combat-spell-school{font-size:.8em;color:#8ba5b5;text-transform:uppercase;letter-spacing:.03em}.combat-spell-dmg{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;color:#f1c40f}.combat-spell-mana{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;color:#3498db}.combat-spell-mana.insufficient{color:#e74c3c;text-decoration:line-through}.combat-target-row{display:grid;grid-template-columns:24px 1fr auto 80px;gap:10px;align-items:center;width:100%;padding:8px 10px;margin:4px 0;background:#141a28d9;border:1px solid rgba(255,255,255,.08);border-radius:8px;color:#e8eef5;cursor:pointer;transition:background .12s ease,border-color .12s ease,transform .08s ease}.combat-target-row:hover{background:#e74c3c24;border-color:#e74c3c59;transform:translateY(-1px)}.combat-target-row:focus-visible{outline:2px solid #f39c12;outline-offset:2px}.combat-target-icon{font-size:1.1em}.combat-target-name{font-weight:600;text-align:left}.combat-target-hp{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;color:#f1c40f;font-size:.9em}.combat-target-bar{position:relative;display:block;width:80px;height:8px;background:#ffffff14;border-radius:4px;overflow:hidden}.combat-target-bar-fill{position:absolute;inset:0 auto 0 0;background:linear-gradient(90deg,#c0392b,#e74c3c);border-radius:4px}.game-controls{display:flex;justify-content:center;gap:30px}.control-group{display:flex;align-items:center;gap:8px}.control-label{color:#bdc3c7;font-size:12px}.control-keys{color:#f39c12;font-size:12px;font-weight:600;background:#f39c1233;padding:2px 6px;border-radius:3px}@media (max-width: 1200px){.party-grid{grid-template-columns:1fr}}@media (max-width: 768px){.game-interface,.game-main-area{flex-direction:column}.status-bar{flex-direction:column;gap:8px}.game-navigation{flex-wrap:wrap}.nav-btn{font-size:12px;padding:6px 12px}}.party-slots-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:0 auto;max-width:600px}.compact-slot{min-width:0}.character-card.compact-card{background:#2d3748eb;border:2px solid var(--border-color);border-radius:10px;padding:12px;display:flex;flex-direction:column;align-items:center;min-height:160px;box-shadow:0 3px 12px #00000026}.character-header{display:flex;flex-direction:column;align-items:center;margin-bottom:8px}.character-avatar{width:48px;height:48px;border-radius:50%;overflow:hidden;background:#222;margin-bottom:4px;display:flex;align-items:center;justify-content:center}.character-avatar img,.character-avatar svg{width:100%;height:100%;object-fit:cover}.character-name{font-weight:700;color:var(--text-accent);font-size:1em;margin-bottom:2px}.character-stats{width:100%;margin-bottom:6px}.stat-row{display:flex;justify-content:space-between;font-size:.85em;color:var(--text-secondary);margin-bottom:1px}.stat{font-weight:400;color:var(--text-secondary)}.character-actions{display:flex;gap:6px;margin-top:6px}.btn-small{font-size:.85em;padding:4px 10px;border-radius:5px}.party-empty-state{text-align:center;padding:40px 20px;color:var(--text-secondary)}.party-empty-state .empty-icon{font-size:3em;margin-bottom:16px}.party-empty-state h3{color:var(--text-primary);margin-bottom:8px}.party-empty-state p{margin-bottom:20px}@media (max-width: 600px){.party-slots-grid{grid-template-columns:1fr;gap:16px}}.character-sheet-panel{max-width:800px;max-height:90vh;overflow-y:auto}.character-sheet-content{display:grid;grid-template-columns:1fr 2fr;gap:20px;margin:20px 0}.character-details-section{display:flex;flex-direction:column;gap:15px}.character-portrait-section{text-align:center}.character-portrait-large{width:120px;height:120px;margin:0 auto 15px;border-radius:50%;overflow:hidden;border:3px solid #3498db}.character-portrait-large img{width:100%;height:100%;object-fit:cover}.character-basic-info h3{color:#f39c12;margin:0 0 10px}.character-basic-info p{color:#ecf0f1;margin:5px 0;font-size:1.1em}.character-stats-section,.character-attributes-section{background:#2d374880;padding:15px;border-radius:8px;margin-bottom:15px}.character-stats-section h3,.character-attributes-section h3{color:#3498db;margin:0 0 15px;border-bottom:2px solid #3498db;padding-bottom:5px}.vitals-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.vital-item{display:flex;justify-content:space-between;padding:5px 0}.vital-label{color:#bdc3c7;font-weight:700}.vital-value{color:#f39c12;font-weight:700}.attributes-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.attribute-item{display:flex;align-items:center;gap:8px;padding:8px;background:#34495e4d;border-radius:5px}.attribute-icon{font-size:1.2em}.attribute-name{color:#ecf0f1;flex:1}.attribute-value{color:#f39c12;font-weight:700;font-size:1.1em}.character-sheet-actions{text-align:center;margin-top:20px;padding-top:20px;border-top:1px solid #34495e}.character-equipment-section{background:#2d374880;padding:15px;border-radius:8px;margin-bottom:15px}.character-equipment-section h3{color:#3498db;margin:0 0 15px;border-bottom:2px solid #3498db;padding-bottom:5px}.equipment-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.equipment-item{display:flex;justify-content:space-between;padding:5px 0}.equipment-label{color:#bdc3c7;font-weight:700}.equipment-value{color:#f39c12;font-weight:700}.character-skills-section{background:#2d374880;padding:15px;border-radius:8px;margin-bottom:15px}.character-skills-section h3{color:#3498db;margin:0 0 15px;border-bottom:2px solid #3498db;padding-bottom:5px}.skills-content{display:flex;flex-direction:column;gap:15px}.race-skills h4,.class-skills h4{color:#f39c12;margin:0 0 10px;font-size:1.1em}.skills-list{display:flex;flex-direction:column;gap:8px}.skill-item{display:flex;align-items:center;gap:8px;padding:8px;background:#34495e4d;border-radius:5px;transition:background .2s ease}.skill-item:hover{background:#34495e80}.skill-icon{font-size:1.2em}.skill-name{color:#ecf0f1;font-weight:500}.character-lore-content{padding:5px 0}.visual-exploration-container{position:relative;width:100%;height:100%;display:flex;flex-direction:column;gap:10px;padding:15px;background:#1a1a2ee6;border-radius:10px}.scene-info-overlay{position:absolute;top:10px;left:10px;right:10px;background:#000000b3;color:#fff;padding:10px;border-radius:5px;font-size:.9em;z-index:10}.scene-name{font-weight:700;color:var(--text-accent);margin-bottom:5px}.scene-description{color:var(--text-secondary);font-size:.8em;line-height:1.3}.scene-elements{position:absolute;bottom:10px;left:10px;right:10px;display:flex;gap:10px;flex-wrap:wrap;z-index:10}.scene-element{background:#000000b3;color:#fff;padding:5px 10px;border-radius:15px;font-size:.8em;cursor:pointer;transition:all .3s ease}.scene-element:hover{background:#ffd7004d;color:var(--text-accent)}.movement-controls{display:flex;flex-direction:column;gap:5px;align-items:center;margin-top:10px}.movement-row{display:flex;gap:5px}.movement-btn{width:60px;height:60px;border:2px solid var(--border-color);background:linear-gradient(145deg,var(--panel-bg),var(--accent-bg));color:var(--text-primary);border-radius:50%;cursor:pointer;transition:all .3s ease;font-size:1.2em;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 8px #0000004d}.movement-btn:hover{background:linear-gradient(145deg,var(--button-hover),var(--button-bg));border-color:var(--text-accent);transform:translateY(-2px);box-shadow:0 6px 12px #0006}.movement-btn:active{transform:translateY(0);box-shadow:0 2px 4px #0000004d}.action-btn{padding:8px 16px;border:2px solid var(--border-color);background:linear-gradient(145deg,var(--panel-bg),var(--accent-bg));color:var(--text-primary);border-radius:20px;cursor:pointer;transition:all .3s ease;font-size:.9em;font-weight:500;box-shadow:0 2px 4px #0000004d}.action-btn:hover{background:linear-gradient(145deg,var(--button-hover),var(--button-bg));border-color:var(--text-accent);transform:translateY(-1px);box-shadow:0 4px 8px #0006}.action-btn:active{transform:translateY(0);box-shadow:0 1px 2px #0000004d}.location-info{background:#2d3748f2;border:2px solid var(--border-color);border-radius:10px;padding:15px;margin-top:10px;box-shadow:0 4px 8px #0000004d}.location-info h3{color:var(--text-accent);margin:0 0 10px;font-size:1.3em;text-shadow:1px 1px 2px rgba(0,0,0,.5)}.location-info p{color:var(--text-secondary);margin:0;line-height:1.4;font-size:.95em}@media (max-width: 768px){.visual-exploration-container{padding:10px}.movement-btn{width:50px;height:50px;font-size:1em}.action-btn{padding:6px 12px;font-size:.8em}.scene-info-overlay{font-size:.8em;padding:8px}.scene-elements{gap:5px}.scene-element{padding:4px 8px;font-size:.7em}}.save-load-panel{max-width:900px;max-height:90vh;overflow-y:auto}.save-load-content{padding:2rem}.save-slots-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.save-slot{background:linear-gradient(145deg,#2d3748f2,#1a1a2ef2);border:2px solid var(--border-color);border-radius:15px;padding:1.5rem;transition:all .3s ease;min-height:200px;display:flex;flex-direction:column}.save-slot:hover{border-color:var(--text-accent);transform:translateY(-3px);box-shadow:0 10px 25px #0000004d}.save-slot.filled{border-color:var(--success-color)}.save-slot.empty{border-style:dashed;opacity:.7}.save-slot-content{flex:1;display:flex;flex-direction:column;gap:1rem}.save-slot-info{flex:1}.save-slot-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.save-slot-header h3{color:var(--text-accent);margin:0;font-size:1.2rem}.save-slot-date{color:var(--text-secondary);font-size:.85rem}.save-slot-details{display:flex;flex-direction:column;gap:.5rem}.save-slot-detail{display:flex;justify-content:space-between;padding:.5rem;background:#0f34604d;border-radius:6px}.detail-label{color:var(--text-secondary);font-size:.9rem}.detail-value{color:var(--text-primary);font-weight:700;font-size:.9rem}.save-slot-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--text-secondary)}.empty-slot-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.save-slot-empty h3{color:var(--text-secondary);margin:0 0 .5rem}.save-slot-empty p{margin:0;font-size:.9rem}.save-slot-btn{width:100%;margin-top:auto}.save-load-actions{display:flex;justify-content:center;gap:1rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.save-load-message{position:fixed;top:20px;right:20px;z-index:10000;padding:1rem 1.5rem;border-radius:8px;box-shadow:0 4px 12px #0000004d;animation:slideInRight .3s ease-out}.save-load-message.success{background:linear-gradient(135deg,var(--success-color),#20a743);color:#fff}.save-load-message.error{background:linear-gradient(135deg,var(--health-color),#c82333);color:#fff}.message-content{display:flex;align-items:center;gap:.75rem}.message-icon{font-size:1.5rem}.message-text{font-weight:600;font-size:1rem}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 768px){.save-slots-grid{grid-template-columns:1fr;gap:1rem}.save-load-panel{max-width:95vw;margin:1rem}.save-load-content{padding:1rem}}.spell-selection-panel{max-width:800px;max-height:90vh;overflow-y:auto}.spell-selection-content{display:flex;flex-direction:column;gap:20px}.spell-mana-display{display:flex;align-items:center;gap:10px;padding:12px;background:#2c3e50cc;border-radius:6px;border:1px solid #3498db}.mana-label{font-weight:600;color:var(--text-secondary)}.mana-amount{font-weight:700;color:var(--mana-color);font-size:1.1rem}.spell-school-filter{display:flex;flex-wrap:wrap;gap:8px;padding:12px;background:#2c3e5099;border-radius:6px}.spell-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;max-height:500px;overflow-y:auto;padding:12px}.spell-card{background:#34495eb3;border:2px solid #3498db;border-radius:8px;padding:16px;transition:all .3s ease;display:flex;flex-direction:column;gap:12px}.spell-card:hover{border-color:#e74c3c;background:#3498db4d;transform:translateY(-2px);box-shadow:0 4px 12px #e74c3c4d}.spell-card.disabled{opacity:.5;cursor:not-allowed}.spell-header{display:flex;justify-content:space-between;align-items:center}.spell-name{margin:0;font-size:1.2rem;font-weight:700;color:var(--text-accent)}.spell-level{background:#e74c3c4d;padding:4px 8px;border-radius:4px;font-size:.85rem;font-weight:600}.spell-info{display:flex;flex-direction:column;gap:8px}.spell-description{margin:0;font-size:.9rem;color:var(--text-secondary);line-height:1.4}.spell-details{display:flex;flex-wrap:wrap;gap:12px}.spell-stat{display:flex;align-items:center;gap:6px;font-size:.9rem}.stat-icon{font-size:1.1rem}.stat-label{color:var(--text-secondary);font-weight:500}.stat-value{color:var(--text-primary);font-weight:700}.stat-value.insufficient{color:#e74c3c}.spell-unavailable{padding:8px;background:#e74c3c33;border-radius:4px;color:#e74c3c;font-size:.85rem;text-align:center}.no-spells{text-align:center;padding:40px;color:var(--text-secondary)}.spell-animation-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1000}.spell-effect{position:absolute;pointer-events:none;z-index:1001}@keyframes fireball{0%{transform:scale(0) translate(-50px);opacity:0}50%{transform:scale(1.2) translate(0);opacity:1}to{transform:scale(.8) translate(50px);opacity:0}}.spell-effect.fireball{animation:fireball .8s ease-out;font-size:3rem;filter:drop-shadow(0 0 10px #ff6b35)}@keyframes flame-strike{0%{transform:translateY(-100px) scale(0);opacity:0}50%{transform:translateY(0) scale(1.5);opacity:1}to{transform:translateY(20px) scale(.8);opacity:0}}.spell-effect.flame-strike{animation:flame-strike 1s ease-out;font-size:4rem;filter:drop-shadow(0 0 15px #ff6b35)}@keyframes ice-bolt{0%{transform:rotate(0) translate(-100px);opacity:0}50%{transform:rotate(180deg) translate(0);opacity:1}to{transform:rotate(360deg) translate(100px);opacity:0}}.spell-effect.ice-bolt{animation:ice-bolt .9s ease-out;font-size:2.5rem;filter:drop-shadow(0 0 10px #4fc3f7)}@keyframes blizzard{0%,to{opacity:0;transform:scale(0)}50%{opacity:1;transform:scale(1.5)}}.spell-effect.blizzard{animation:blizzard 1.2s ease-in-out;font-size:4rem;filter:drop-shadow(0 0 20px #4fc3f7)}@keyframes lightning-bolt{0%{transform:translateY(-200px) scaleY(0);opacity:0}30%{opacity:1}50%{transform:translateY(0) scaleY(1);opacity:1}to{transform:translateY(200px) scaleY(0);opacity:0}}.spell-effect.lightning-bolt{animation:lightning-bolt .7s ease-out;font-size:3.5rem;filter:drop-shadow(0 0 15px #fff176)}@keyframes chain-lightning{0%{transform:scale(0) rotate(0);opacity:0}50%{transform:scale(1.3) rotate(180deg);opacity:1}to{transform:scale(.5) rotate(360deg);opacity:0}}.spell-effect.chain-lightning{animation:chain-lightning 1s ease-out;font-size:3rem;filter:drop-shadow(0 0 20px #fff176)}@keyframes stone-spike{0%{transform:translateY(100px) scale(0);opacity:0}50%{transform:translateY(0) scale(1.2);opacity:1}to{transform:translateY(-20px) scale(.8);opacity:0}}.spell-effect.stone-spike{animation:stone-spike .8s ease-out;font-size:3rem;filter:drop-shadow(0 0 10px #8d6e63)}@keyframes earthquake{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(-10px) rotate(-2deg)}50%{transform:translate(10px) rotate(2deg)}75%{transform:translate(-5px) rotate(-1deg)}}.spell-effect.earthquake{animation:earthquake 1.5s ease-in-out;font-size:4rem;filter:drop-shadow(0 0 15px #8d6e63)}@keyframes heal{0%{transform:translateY(0) scale(0);opacity:0}50%{transform:translateY(-30px) scale(1.5);opacity:1}to{transform:translateY(-60px) scale(.8);opacity:0}}.spell-effect.heal,.spell-effect.greater-heal,.spell-effect.holy-light{animation:heal 1s ease-out;font-size:3rem;filter:drop-shadow(0 0 15px #4caf50)}@keyframes dark-bolt{0%{transform:scale(0) rotate(0);opacity:0}50%{transform:scale(1.3) rotate(180deg);opacity:1}to{transform:scale(.5) rotate(360deg);opacity:0}}.spell-effect.dark-bolt,.spell-effect.shadow-strike,.spell-effect.void-bolt{animation:dark-bolt .9s ease-out;font-size:3rem;filter:drop-shadow(0 0 15px #424242)}@keyframes spirit-bolt{0%{transform:scale(0);opacity:0}50%{transform:scale(1.5);opacity:1}to{transform:scale(.8);opacity:0}}.spell-effect.spirit-bolt,.spell-effect.soul-drain{animation:spirit-bolt 1s ease-out;font-size:3rem;filter:drop-shadow(0 0 15px #9c27b0)}@keyframes area-effect{0%{transform:scale(0);opacity:0}50%{transform:scale(2);opacity:1}to{transform:scale(1.5);opacity:0}}.spell-effect.meteor-strike,.spell-effect.tornado,.spell-effect.healing-waters{animation:area-effect 1.2s ease-out;font-size:4rem}.spell-effect.meteor-strike{filter:drop-shadow(0 0 20px #ff6b35)}.spell-effect.tornado{filter:drop-shadow(0 0 20px #fff176)}.spell-effect.healing-waters{filter:drop-shadow(0 0 20px #4caf50)}.character-lore-section{background:#2d374880;padding:15px;border-radius:8px;margin-bottom:15px;border-left:3px solid #9b59b6}.character-lore-section h3{color:#9b59b6;margin:0 0 12px;border-bottom:2px solid #9b59b6;padding-bottom:5px}.character-backstory-text{color:#bdc3c7;font-style:italic;line-height:1.6;margin:0;font-size:.95em}.cs-identity-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.cs-identity-col{flex:1;min-width:0;min-height:90px;display:flex;flex-direction:column;align-items:flex-start;justify-content:center}.cs-identity-row .cs-name{margin:0}.cs-badges{display:flex;gap:8px;align-items:center;flex-wrap:wrap}button.cs-respec-btn.respec-active,#cs-respec-btn.respec-active{border-color:#e74c3c;color:#e74c3c}.cs-actions{display:flex;flex-wrap:wrap;gap:12px;padding:12px 20px;border-top:1px solid rgba(255,255,255,.1);flex-shrink:0;background:#141e2d80}.cs-actions.cs-actions-centered{justify-content:center}.party-management-panel.cs-panel-wrap{max-width:800px;display:flex;flex-direction:column;max-height:90vh;overflow:hidden}.party-management-panel .cs-party-content{flex:1;overflow-y:auto;padding:0 0 16px}.party-management-panel .cs-party-header{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.cs-portrait-metadata-notice{font-size:.85em;color:#f59e0b;margin:0 0 .75rem;padding:6px 10px;background:#f59e0b1a;border-radius:6px;border:1px solid rgba(245,158,11,.25)}.cs-portrait-metadata-notice code{font-size:.9em}.party-management-panel .cs-section{margin-bottom:14px}.party-management-panel .cs-section-title{color:#5dade2;font-size:.95em;margin:0 0 12px;text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid rgba(93,173,226,.3);padding-bottom:6px}.cs-party-hero-actions{display:flex;justify-content:center;gap:12px;margin-top:14px;flex-wrap:wrap}.cs-party-ready,.cs-party-incomplete{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:8px}.cs-party-ready{background:#27ae601f;border:1px solid rgba(39,174,96,.3)}.cs-party-incomplete{background:#e74c3c1a;border:1px solid rgba(231,76,60,.3)}.cs-party-status-icon{font-size:1.4em;flex-shrink:0}.cs-party-status-text{display:flex;flex-direction:column;gap:2px}.cs-party-status-text strong{color:#e8e8e8;font-size:.95em}.cs-party-status-text span{font-size:.82em;color:#a0aec0}.cs-party-empty{text-align:center;padding:24px 16px}.cs-party-empty-icon{font-size:3em;margin-bottom:8px;opacity:.8}.cs-party-empty-title{color:#f39c12;font-size:1.1em;margin:0 0 6px}.cs-party-empty-desc{color:#a0aec0;font-size:.9em;margin:0 0 16px}.cs-party-cards-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:0 auto;max-width:640px}.cs-party-card{position:relative;background:#1e283799;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:12px;transition:border-color .2s,box-shadow .2s}.cs-party-card:hover{border-color:#5dade2;box-shadow:0 4px 16px #3498db33}.cs-party-card-actions{position:absolute;top:8px;left:8px;display:flex;gap:2px;z-index:2}.cs-party-card-action-btn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;padding:0;border:none;border-radius:4px;background:transparent;color:#ffffffbf;cursor:pointer;font-size:1em;line-height:1;transition:color .15s,background .15s}.cs-party-card-action-btn:hover{background:#ffffff1f;color:#fff}.cs-party-card-action-btn.cs-party-card-action-delete{color:#e74c3ce6}.cs-party-card-action-btn.cs-party-card-action-delete:hover{background:#e74c3c40;color:#e74c3c}.cs-party-card-body{display:flex;flex-direction:column;gap:8px;align-items:stretch;cursor:pointer}.cs-party-card-top{display:flex;align-items:stretch;gap:14px;min-height:96px}.cs-party-card-portrait{flex-shrink:0;border-radius:50%;overflow:hidden;width:96px;height:96px;border:3px solid #f39c12;transition:border-color .2s;align-self:flex-start}.cs-party-card-portrait img{width:96px;height:96px;object-fit:cover;border-radius:50%;display:block}.cs-party-card:hover .cs-party-card-portrait{border-color:#fff}.cs-party-card-info{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:6px;align-items:flex-start}.cs-party-card-identity-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.cs-party-card-gender{font-size:1.1em;color:#a0aec0;flex-shrink:0}.cs-party-card-name{font-weight:700;color:#f39c12;font-size:1em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0}.cs-party-card-badges{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.cs-party-card-badges .cs-badge{font-size:1.1em}.cs-random-party-btn{display:inline-flex;align-items:center;gap:16px;min-width:220px;padding:12px 20px 12px 24px}.cs-random-party-btn .btn-icon{font-size:1.1em;margin-right:4px}.cs-random-party-btn .btn-text{font-weight:600}.cs-party-card-vitals{display:flex;flex-wrap:wrap;gap:8px;font-size:.82em}.cs-party-card-vitals.cs-vitals-inline{flex-direction:row;flex-wrap:nowrap;gap:10px;align-items:center}.cs-party-card-vitals .cs-vital-item{display:inline-flex;align-items:center;gap:4px;font-size:.9em;white-space:nowrap}.cs-party-card-vitals .cs-vital-item strong{color:#e8e8e8;font-size:1em}.cs-party-card-vitals .cs-vital-row{display:flex;align-items:center;gap:6px;padding:6px 8px;font-size:.9em;min-width:0;background:#ffffff0d;border-radius:6px;white-space:nowrap}.cs-party-card-vitals .cs-vital-row strong{color:#e8e8e8;font-size:1em}.cs-party-card-vitals .cs-vital-label{color:#fff9;font-size:.85em;min-width:2.2em}.btn-icon-only{padding:5px 8px;min-width:28px;line-height:1}.character-quick-stats{display:flex;flex-wrap:wrap;gap:8px;font-size:.9em}.character-quick-stats.character-quick-stats-inline{flex-wrap:nowrap;gap:10px;align-items:center}.character-quick-stats .quick-stat-item{display:inline-flex;align-items:center;gap:4px;white-space:nowrap}.character-quick-stats .quick-stat-item strong{color:#e8e8e8;font-size:1em}.cs-header{display:flex;align-items:center;gap:16px;padding:16px 20px 12px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.cs-party-card-vitals.cs-vitals-inline .cs-vital-item{display:inline-flex!important;flex-direction:row!important;align-items:center;gap:4px;font-size:.9em;white-space:nowrap}.cs-attrs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.cs-attr-item{display:flex;align-items:center;gap:6px;background:#ffffff0a;border-radius:8px;padding:7px 10px;cursor:default}.cs-attr-icon{font-size:1.1em;flex-shrink:0}.cs-attr-name{flex:1;font-size:.82em;color:#bdc3c7}.cs-attr-val{font-weight:700;color:#f39c12;font-size:1em;min-width:24px;text-align:right}.cs-adj-btn{background:#3498db33;border:1px solid #3498db;color:#5dade2;border-radius:4px;width:22px;height:22px;font-size:1em;line-height:1;cursor:pointer;padding:0;flex-shrink:0;transition:background .15s}#cs-respec-btn.respec-active{border-color:#e74c3c!important;color:#e74c3c!important}.exploration-layout{display:grid;grid-template-columns:220px 1fr 220px;gap:8px;height:100%;min-height:0;overflow:hidden;flex:1}.exploration-party-panel{overflow-y:auto;padding:6px;display:flex;flex-direction:column;gap:6px;background:#0f142399;border-radius:8px;border:1px solid rgba(255,255,255,.08)}.exploration-center{display:flex;flex-direction:column;gap:10px;overflow-y:auto;min-height:0}.exploration-scene{position:relative;width:100%;aspect-ratio:16/9;max-height:60vh;min-height:180px;overflow:hidden;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:#0d0d1a}.exploration-scene .cell-picture{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;background:#0d0d1a}.encounter-overlay{position:absolute;inset:0;z-index:4;display:flex;flex-direction:column;justify-content:flex-start;align-items:stretch;pointer-events:none;padding:8px 8px 0}.encounter-overlay[hidden]{display:none!important}.encounter-overlay-inner{pointer-events:auto;display:flex;flex-direction:column;gap:8px;width:100%;max-height:100%}.encounter-banner{background:#0c1220e0;backdrop-filter:blur(6px);border:1px solid rgba(231,111,81,.45);border-radius:8px;padding:8px 10px;box-shadow:0 4px 18px #00000059}.encounter-banner-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px;justify-content:space-between}.encounter-banner-text{flex:1;min-width:120px;font-size:.88em;color:#e8eef5;line-height:1.35}.encounter-banner-actions{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.enc-action-btn{background:#23324ef2;border:1px solid rgba(255,255,255,.12);color:#f0f4f8;border-radius:6px;padding:6px 10px;font-size:.82em;cursor:pointer}.enc-action-btn:hover{background:#324464fa}.enc-action-flee{border-color:#e76f5180}.enc-disposition-chip{display:inline-block;padding:2px 10px;border-radius:999px;font-size:.72em;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.enc-disposition-chip.aggressive{background:#c0392b59;color:#ffb4a8;border:1px solid rgba(231,76,60,.6)}.enc-disposition-chip.neutral{background:#f1c40f33;color:#fdebd0;border:1px solid rgba(241,196,15,.45)}.enc-disposition-chip.friendly{background:#27ae6040;color:#d5f5e3;border:1px solid rgba(39,174,96,.55)}.enc-foe-strip{display:flex;flex-direction:row;flex-wrap:nowrap;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:thin}.enc-foe-strip .enc-foe{min-width:200px;max-width:240px;flex-shrink:0;border-color:#e76f5159;cursor:pointer}.enc-foe-strip .enc-foe:hover{border-color:#e76f51a6}.enc-foe-meta{font-size:.72em;color:#a8b8c8;display:flex;align-items:center;gap:4px}.enc-dot{opacity:.6}.enc-foe-chips{margin-top:2px}.enc-foe-portrait{cursor:pointer}.scene-spinner{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0d0d1a8c;pointer-events:none;z-index:2}.scene-spinner[hidden]{display:none}.scene-spinner-ring{width:48px;height:48px;border-radius:50%;border:3px solid rgba(255,255,255,.15);border-top-color:#f39c12;animation:scene-spin .9s linear infinite}@keyframes scene-spin{to{transform:rotate(360deg)}}.cell-picture{border-radius:8px;transition:filter .22s ease-out}.cell-picture.cell-picture-loading{filter:blur(6px);transition:filter 0ms}.location-row{display:flex;gap:12px;align-items:stretch}.location-row .location-info{flex:1;min-width:0}.location-row .movement-controls{flex-shrink:0}.exploration-right{display:flex;flex-direction:column;gap:8px;min-height:0;overflow-y:auto}.exploration-minimap{display:flex;flex-direction:column;align-items:center;padding:6px;background:#0f142399;border-radius:8px;border:1px solid rgba(255,255,255,.08);flex-shrink:0}.minimap-coords{font-family:monospace;font-size:.78em;color:#8ba5b5;margin-bottom:4px;letter-spacing:.5px}#minimap-canvas{border:1px solid rgba(255,255,255,.15);border-radius:4px;image-rendering:pixelated}.location-actions-panel{display:flex;flex-direction:column;gap:6px;padding:8px;background:#0f142399;border-radius:8px;border:1px solid rgba(255,255,255,.08)}.location-actions-panel:empty{display:none}.location-actions-panel .action-btn{width:100%;margin:0;text-align:center;border-radius:8px;padding:8px 10px;font-size:.88em}.exp-member{display:flex;flex-direction:column;align-items:stretch;gap:6px;padding:8px;background:#192337b3;border-radius:8px;border:1px solid rgba(255,255,255,.06);cursor:pointer}.exp-member:hover{background:#233046cc}.exp-card-top{display:flex;flex-direction:row;align-items:flex-start;gap:8px;width:100%}.exp-portrait-wrap{flex-shrink:0;display:flex;justify-content:flex-start}.exp-portrait{width:72px;height:72px;flex-shrink:0;border-radius:8px;overflow:hidden;border:1px solid rgba(255,255,255,.15)}.exp-portrait img{width:100%;height:100%;object-fit:cover}.exp-portrait-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2c3e50,#1a252f);color:#bdc3c7;font-size:1.4em;font-weight:700}.exp-card-right{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px;align-items:flex-start;justify-content:flex-start}.exp-name{font-size:.82em;font-weight:700;color:#e8e8e8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;text-align:left;line-height:1.2}.exp-bars-col-stacked{display:flex;flex-direction:column;gap:4px;width:100%;align-items:stretch}.exp-bar-row{display:grid;grid-template-columns:24px 1fr;align-items:center;column-gap:6px;width:100%;min-width:0}.exp-bar-icon{font-size:.75em;width:100%;text-align:center;line-height:1;display:flex;align-items:center;justify-content:center;overflow:hidden}.exp-bar-track-h{min-width:0;height:10px;background:#0006;border-radius:4px;overflow:hidden;border:1px solid rgba(255,255,255,.06)}.exp-bar-fill-h{height:100%;min-width:0;border-radius:3px;transition:width .3s ease}.hp-fill{background:linear-gradient(90deg,#c0392b,#e74c3c)}.sta-fill{background:linear-gradient(90deg,#d4ac0d,#f1c40f)}.mp-fill{background:linear-gradient(90deg,#2471a3,#3498db)}.exp-badges{display:flex;align-items:center;justify-content:center;gap:4px;flex-wrap:wrap;padding-top:2px;border-top:1px solid rgba(255,255,255,.06)}.exp-badge,.exp-slot{font-size:.85em;padding:2px 4px;background:#0000004d;border-radius:4px;border:1px solid rgba(255,255,255,.08);cursor:default}.exp-sep{color:#5a6a7a;font-size:.75em;padding:0 2px;user-select:none}.character-sheet-readonly .cs-badge{cursor:default}.cs-attr-item.cs-attr-readonly{display:grid;grid-template-columns:auto 1fr auto auto}.cs-attr-item.cs-attr-readonly .cs-adj-btn{display:none}.location-context{display:flex;gap:8px;flex-wrap:wrap;font-size:.8em;padding:4px 0}.ctx-kingdom,.ctx-region{padding:2px 8px;background:#f39c121f;border:1px solid rgba(243,156,18,.25);border-radius:4px;color:#f0c040;cursor:default}.ctx-region{background:#2ecc711a;border-color:#2ecc7133;color:#7dcea0}.direction-desc{font-style:italic;color:#a0aec0;font-size:.88em;line-height:1.5;max-height:80px;overflow-y:auto}.movement-controls{flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:4px}.movement-diamond{display:flex;flex-direction:column;align-items:center;gap:4px}.movement-mid{display:flex;gap:4px}.movement-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1.3em;line-height:1;border:1px solid rgba(255,255,255,.2);border-radius:10px;background:linear-gradient(180deg,#283c5ae6,#192841f2);color:#e0e8f0;cursor:pointer;box-shadow:0 2px 6px #0000004d,inset 0 1px #ffffff14;transition:transform .1s,box-shadow .1s}.movement-btn:hover:not(:disabled){background:linear-gradient(180deg,#375578f2,#233755fa);transform:scale(1.05);box-shadow:0 3px 8px #0006}.movement-btn:active:not(:disabled){transform:scale(.98);box-shadow:0 1px 3px #0000004d}.movement-btn.blocked,.movement-btn:disabled{opacity:.35;cursor:not-allowed;pointer-events:none}@media (max-width:900px){.exploration-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr auto}.exploration-party-panel{flex-direction:row;overflow-x:auto;overflow-y:hidden}.exploration-right{flex-direction:row;align-items:flex-start;gap:8px;overflow-x:auto;overflow-y:hidden}.exploration-minimap{flex-direction:row}.location-actions-panel{flex:1;min-width:0}}.encounter-foe-dialog-backdrop{position:fixed;inset:0;z-index:12000;background:#0000008c;display:flex;align-items:center;justify-content:center;padding:16px}.encounter-foe-dialog{position:relative;display:flex;flex-direction:column;max-width:min(640px,96vw);max-height:90vh;background:#121a28;border:1px solid rgba(255,255,255,.12);border-radius:12px;color:#e8eef5;box-shadow:0 12px 40px #00000080;overflow:hidden}.encounter-foe-dialog-topbar{position:sticky;top:0;z-index:2;display:flex;justify-content:flex-end;padding:8px 8px 0;background:linear-gradient(180deg,#121a28 0% 70%,#121a28eb)}.encounter-foe-dialog-scroll{overflow-y:auto;padding:4px 18px 20px}.encounter-foe-dialog-close{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:#00000040;color:#e8eef5;font-size:24px;line-height:1;cursor:pointer;padding:0;flex-shrink:0}.encounter-foe-dialog-close:hover{background:#ffffff1f;border-color:#ffffff47}.encounter-foe-dialog-close:focus-visible{outline:2px solid #f39c12;outline-offset:2px}.encounter-foe-dialog-close:active{background:#ffffff2e}.enc-foe-dialog-header{display:flex;gap:14px;align-items:flex-start;margin-bottom:12px;padding-right:8px}.enc-foe-dialog-portrait{width:96px;height:96px;border-radius:10px;overflow:hidden;border:1px solid rgba(231,111,81,.4);flex-shrink:0}.enc-foe-dialog-portrait img{width:100%;height:100%;object-fit:cover}.enc-foe-dialog-title{margin:0 0 4px;font-size:1.25em}.enc-foe-dialog-sub{font-size:.85em;color:#a8b8c8;margin-bottom:6px}.enc-foe-vitals-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.enc-foe-vital-cell{background:#00000038;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:6px 8px;display:flex;flex-direction:column;gap:2px}.enc-foe-vital-label{font-size:.68em;color:#8ba5b5;text-transform:uppercase;letter-spacing:.03em}.enc-foe-vital-val{font-size:.95em;font-weight:700;color:#f39c12}.enc-foe-muted{color:#8ba5b5;font-size:.88em}.enc-foe-ability-list{margin:0;padding-left:1.1em}.enc-foe-ability-list li{margin-bottom:8px}.enc-foe-resist-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px;font-size:.88em}.enc-foe-resist-row{display:flex;justify-content:space-between;border-bottom:1px dashed rgba(255,255,255,.08);padding:2px 0}.enc-foe-backstory{white-space:pre-wrap;line-height:1.45;font-size:.9em}.death-recovery-panel{background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid #ff6b6b;border-radius:12px;padding:2rem;color:#e2e8f0;max-width:800px;margin:2rem auto}.death-info{background:#ff6b6b1a;border-left:4px solid #ff6b6b;padding:1rem;margin:1rem 0;border-radius:4px}.recovery-options-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-top:1rem}.recovery-option{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:1rem;transition:all .3s ease}.recovery-option:hover{background:#ffffff1a;border-color:#4a9eff;transform:translateY(-2px)}.trade-window,.shop-browser,.marketplace-browser{background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid #4a9eff;border-radius:12px;padding:2rem;color:#e2e8f0;max-width:1000px;margin:2rem auto}.trade-sides{display:grid;grid-template-columns:1fr auto 1fr;gap:2rem;margin:2rem 0}.trade-side{background:#ffffff0d;border-radius:8px;padding:1.5rem}.trade-items{display:flex;flex-direction:column;gap:.5rem;margin:1rem 0}.trade-item{background:#ffffff0d;padding:.75rem;border-radius:4px}.trade-divider{font-size:2rem;display:flex;align-items:center;justify-content:center}.chat-window{background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid #4a9eff;border-radius:12px;padding:1.5rem;color:#e2e8f0;max-width:600px;margin:2rem auto;display:flex;flex-direction:column;height:500px}.chat-messages{flex:1;overflow-y:auto;margin:1rem 0;padding:1rem;background:#0000004d;border-radius:8px}.chat-message{margin:.5rem 0;padding:.5rem;border-radius:4px;background:#ffffff0d}.chat-input-area{display:flex;gap:.5rem}.chat-input{flex:1;padding:.75rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#e2e8f0;font-size:1rem}.chat-channels{display:flex;gap:.5rem;margin-bottom:1rem}.chat-channel-btn{padding:.5rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:4px;color:#e2e8f0;cursor:pointer;transition:all .3s ease}.chat-channel-btn.active{background:#4a9eff;border-color:#4a9eff}.guild-panel{background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid #ffd700;border-radius:12px;padding:2rem;color:#e2e8f0;max-width:900px;margin:2rem auto}.guild-member{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#ffffff0d;border-radius:8px;margin:.5rem 0}.member-info{display:flex;flex-direction:column;gap:.25rem}.member-rank{color:gold;font-size:.9rem}.arena-queue-panel{background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid #ff6b6b;border-radius:12px;padding:2rem;color:#e2e8f0;max-width:800px;margin:2rem auto}.mode-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:1rem}.mode-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:1.5rem;text-align:center}.raid-browser-panel{background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid #9b59b6;border-radius:12px;padding:2rem;color:#e2e8f0;max-width:1000px;margin:2rem auto}.raids-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-top:1rem}.raid-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:1.5rem;transition:all .3s ease}.raid-card:hover{background:#ffffff1a;border-color:#9b59b6;transform:translateY(-2px)}.raid-difficulty{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:700}.difficulty-easy{background:#27ae60;color:#fff}.difficulty-normal{background:#3498db;color:#fff}.difficulty-hard{background:#e67e22;color:#fff}.difficulty-epic{background:#9b59b6;color:#fff}.vendor-management-panel{background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid #f39c12;border-radius:12px;padding:2rem;color:#e2e8f0;max-width:1000px;margin:2rem auto}.vendor-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#ffffff0d;border-radius:8px;margin:.5rem 0}.achievement-card{display:flex;gap:1rem;padding:1.5rem;background:#ffffff0d;border-radius:8px;margin:.5rem 0;border:1px solid rgba(255,255,255,.1)}.achievement-card.unlocked{border-color:gold;background:#ffd7001a}.achievement-card.locked{opacity:.6}.achievement-icon{font-size:2.5rem}.emote-menu-panel{background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid #1abc9c;border-radius:12px;padding:2rem;color:#e2e8f0;max-width:800px;margin:2rem auto}.emotes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;margin-top:1rem}.emote-item{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:1.5rem;text-align:center;transition:all .3s ease}.emote-item:hover{background:#ffffff1a;border-color:#1abc9c;transform:scale(1.05)}.emote-icon{font-size:3rem;margin-bottom:.5rem}.leaderboards-panel{background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid #e74c3c;border-radius:12px;padding:2rem;color:#e2e8f0;max-width:900px;margin:2rem auto}.leaderboard-categories{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.category-btn{padding:.5rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:4px;color:#e2e8f0;cursor:pointer;transition:all .3s ease}.category-btn.active{background:#e74c3c;border-color:#e74c3c}.leaderboard-entry{display:flex;align-items:center;gap:1rem;padding:1rem;background:#ffffff0d;border-radius:8px;margin:.5rem 0}.rank-badge{font-size:1.5rem;min-width:3rem;text-align:center}.player-name{flex:1;font-weight:700}.score{color:gold;font-weight:700}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid rgba(255,255,255,.1)}.panel-header h2{margin:0;color:#e2e8f0}.btn-close{background:#ff6b6b33;border:1px solid #ff6b6b;border-radius:4px;color:#ff6b6b;cursor:pointer;font-size:1.5rem;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.btn-close:hover{background:#ff6b6b;color:#fff}.multiplayer-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.multiplayer-actions .quick-btn{padding:.75rem;font-size:.9rem;background:#4a9eff1a;border:1px solid rgba(74,158,255,.3);border-radius:6px;color:#e2e8f0;cursor:pointer;transition:all .3s ease}.multiplayer-actions .quick-btn:hover{background:#4a9eff33;border-color:#4a9eff;transform:translateY(-2px)}.empty-state{text-align:center;padding:3rem;color:#e2e8f080;font-style:italic}@media (max-width: 768px){.trade-sides{grid-template-columns:1fr}.trade-divider{transform:rotate(90deg)}.raids-grid,.emotes-grid,.mode-cards,.multiplayer-actions{grid-template-columns:1fr}}.party-cards-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:0 auto;max-width:640px}.party-char-card{position:relative;background:#2d3748eb;border:2px solid #3498db;border-radius:12px;padding:12px;transition:border-color .2s,box-shadow .2s}.party-char-card:hover{border-color:#5dade2;box-shadow:0 4px 16px #3498db59}.party-card-actions{position:absolute;top:8px;right:8px;display:flex;gap:4px;z-index:2}.party-card-body{display:flex;align-items:flex-start;gap:12px}.party-card-portrait{flex-shrink:0;cursor:pointer;border-radius:50%;overflow:hidden;width:64px;height:64px;border:2px solid #f39c12}.party-card-portrait img{width:64px;height:64px;object-fit:cover;border-radius:50%;display:block}.party-card-info{flex:1;min-width:0;padding-top:2px}.party-char-name{font-weight:700;color:#f39c12;font-size:1em;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.party-char-level{font-size:.8em;color:#a0aec0;margin-bottom:4px}.party-char-vitals{display:flex;gap:10px;font-size:.82em;margin-bottom:4px}.vital-hp{color:#e74c3c}.vital-mp{color:#9b59b6}.party-char-icons{display:flex;gap:6px;font-size:1.1em}.race-icon,.class-icon,.gender-icon{cursor:default;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}.party-section-title{text-align:center;color:#f39c12;font-size:1.1em;margin:0 0 12px;letter-spacing:1px;text-transform:uppercase}.party-hero-actions{display:flex;justify-content:center;gap:12px;margin-top:14px}.btn-xs{padding:3px 8px;font-size:.72em;border-radius:4px;line-height:1.4}.gender-selector,.gender-selector-row{display:flex;gap:12px;margin-top:8px}.gender-option{display:flex;align-items:center;gap:6px;cursor:pointer;padding:4px 10px;border-radius:6px;border:1px solid rgba(255,255,255,.15);background:#ffffff0d;transition:background .15s,border-color .15s;font-size:.9em}.gender-option:has(input:checked){border-color:#3498db;background:#3498db26}.gender-option input[type=radio]{accent-color:#3498db}.gender-label{color:#e8e8e8;user-select:none}.cs-panel-wrap{display:flex;flex-direction:column;max-height:90vh;overflow:hidden}.cs-header{display:flex;align-items:flex-start;gap:16px;padding:16px 20px 12px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.cs-portrait-col{flex-shrink:0}.cs-portrait-thumb-wrap{position:relative;cursor:pointer;width:90px;height:90px;border-radius:50%;overflow:hidden;border:3px solid #f39c12;transition:border-color .2s}.cs-portrait-thumb-wrap:hover{border-color:#fff}.cs-portrait-thumb{width:90px;height:90px;object-fit:cover;display:block;border-radius:50%}.cs-portrait-zoom-hint{position:absolute;bottom:4px;right:4px;font-size:.75em;background:#0009;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center}.cs-identity-col{flex:1;display:flex;flex-direction:column;align-items:flex-start;justify-content:center}.cs-name{color:#f39c12;font-size:1.4em;margin:0 0 6px}.cs-identity-meta{font-size:.9em;color:#a0aec0;margin:0 0 6px}.cs-badges{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:6px}.cs-badge{font-size:1.3em;cursor:default;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}.cs-gender-badge{font-size:1.1em;color:#a0aec0}.cs-level-badge{background:#3498db33;border:1px solid #3498db;border-radius:8px;padding:2px 8px;font-size:.85em;color:#5dade2}.cs-sub-info{display:flex;gap:14px;font-size:.82em;color:#a0aec0}.cs-tabs{display:flex;border-bottom:2px solid rgba(255,255,255,.1);flex-shrink:0}.cs-tab{flex:1;padding:10px 8px;background:transparent;border:none;border-bottom:3px solid transparent;color:#a0aec0;cursor:pointer;font-size:.85em;transition:color .15s,border-bottom-color .15s;margin-bottom:-2px}.cs-tab:hover{color:#e8e8e8}.cs-tab.cs-tab-active{color:#f39c12;border-bottom-color:#f39c12;font-weight:600}.cs-tab-panel{flex:1;overflow-y:auto;padding:16px 20px}.cs-section{background:#1e283799;border-radius:10px;padding:14px;margin-bottom:14px;border:1px solid rgba(255,255,255,.08)}.cs-section-title{color:#5dade2;font-size:.95em;margin:0 0 12px;text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid rgba(93,173,226,.3);padding-bottom:6px}.cs-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.cs-section-header .cs-section-title{margin-bottom:0;border-bottom:none;padding-bottom:0}.cs-respec-controls{display:flex;align-items:center;gap:8px}.cs-vitals-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.cs-vital-item{display:flex;flex-direction:column;align-items:center;background:#ffffff0d;border-radius:8px;padding:8px 6px;text-align:center;cursor:default}.cs-party-card-vitals.cs-vitals-inline .cs-vital-item{flex-direction:row!important;display:inline-flex!important;align-items:center;gap:4px}.cs-vital-icon{font-size:1.3em;margin-bottom:3px}.cs-vital-label{font-size:.7em;color:#a0aec0;text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}.cs-vital-val{font-size:.95em;font-weight:700;color:#e8e8e8}.cs-attrs-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px}.cs-attr-item{display:grid;grid-template-columns:1.4em minmax(0,1fr) 22px 28px 22px 36px;align-items:center;gap:4px;background:#ffffff0a;border-radius:8px;padding:6px 8px;cursor:default}.cs-attr-icon{font-size:1em;text-align:center}.cs-attr-name{font-size:.78em;color:#bdc3c7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.cs-attr-val{font-weight:700;color:#f39c12;font-size:.95em;text-align:center}.cs-bonus-chips{width:36px;display:flex;justify-content:flex-end;flex-wrap:nowrap;overflow:hidden}.cs-adj-btn{background:#3498db33;border:1px solid #3498db;color:#5dade2;border-radius:4px;width:22px;height:22px;font-size:.9em;line-height:1;cursor:pointer;padding:0;flex-shrink:0;transition:background .15s;display:flex;align-items:center;justify-content:center}.cs-adj-btn:hover{background:#3498db66}.cs-equip-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:12px}.cs-equip-item{display:flex;align-items:center;gap:8px;background:#ffffff0a;border-radius:8px;padding:8px 10px;cursor:default}.cs-equip-icon{font-size:1.1em;flex-shrink:0}.cs-equip-label{font-size:.75em;color:#a0aec0;min-width:46px}.cs-equip-name{font-size:.88em;color:#f39c12}.cs-equip-name.empty{color:#4a5568;font-style:italic}.cs-encumbrance{margin-top:8px}.cs-enc-label{font-size:.8em;color:#a0aec0;display:block;margin-bottom:4px}.cs-enc-bar-wrap{height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.cs-enc-bar-fill{height:100%;background:linear-gradient(90deg,#27ae60,#f39c12,#e74c3c);border-radius:3px;transition:width .3s}.cs-skills-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.cs-skills-subhead{font-size:.85em;color:#bdc3c7;margin:0 0 8px;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:4px}.cs-skills-list{display:flex;flex-direction:column;gap:6px}.cs-skill-item{display:flex;align-items:center;gap:8px;background:#ffffff0a;border-radius:6px;padding:6px 8px;cursor:default}.cs-skill-icon{font-size:1.1em;flex-shrink:0}.cs-skill-name{font-size:.85em;color:#e8e8e8}.cs-backstory-text{color:#bdc3c7;font-style:italic;line-height:1.7;font-size:.92em;margin:0}.cs-actions{display:flex;flex-wrap:wrap;gap:8px;padding:12px 20px;border-top:1px solid rgba(255,255,255,.1);flex-shrink:0;background:#141e2d80}.cs-profession-picker{padding:12px 20px;border-top:1px solid rgba(255,255,255,.08);background:#1e2837cc}.cs-profession-picker p{color:#a0aec0;margin:0 0 8px;font-size:.85em}.cs-profession-btns{display:flex;flex-wrap:wrap;gap:8px}.cs-profession-btns .btn.active{border-color:#f39c12;color:#f39c12}.cs-portrait-popup{position:fixed;inset:0;background:#000000d9;z-index:9999;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.cs-portrait-popup-inner{display:flex;flex-direction:column;align-items:center;gap:14px}.cs-portrait-popup-img{width:300px;height:400px;object-fit:cover;border-radius:12px;border:3px solid #f39c12;box-shadow:0 8px 40px #000000b3}.cs-portrait-popup-name{color:#f39c12;font-size:1.3em;font-weight:700;text-shadow:0 2px 8px rgba(0,0,0,.8)}.cs-portrait-popup-close{min-width:120px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.party-status{margin-bottom:14px}.party-ready,.party-incomplete{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:8px;background:#27ae601f;border:1px solid rgba(39,174,96,.3)}.party-incomplete{background:#e74c3c1a;border-color:#e74c3c4d}.status-icon{font-size:1.4em}.status-text h3{margin:0 0 2px;font-size:.95em}.status-text p{margin:0;font-size:.8em;color:#a0aec0}.character-sheet-panel.cs-panel-wrap{width:640px;min-width:640px;max-width:640px;height:92vh;max-height:800px;min-height:560px;overflow:hidden}.cs-tab-panel{overflow-y:auto;max-height:calc(92vh - 250px);scrollbar-width:none;-ms-overflow-style:none}.cs-tab-panel::-webkit-scrollbar{display:none}.cs-header{position:relative}.cs-header-random-btn{position:absolute;top:8px;right:8px;background:#f39c121f;border:1px solid rgba(243,156,18,.4);border-radius:8px;padding:4px 8px;font-size:1.1em;cursor:pointer;line-height:1;transition:background .15s;letter-spacing:-2px}.cs-header-random-btn:hover{background:#f39c124d}.cs-portrait-col{position:relative;flex-shrink:0}.cs-portrait-new-btn{position:absolute;bottom:0;right:-8px;background:#1e2837d9;border:1px solid rgba(255,255,255,.2);border-radius:50%;width:26px;height:26px;display:flex;align-items:center;justify-content:center;font-size:.95em;cursor:pointer;padding:0;transition:background .15s;z-index:3}.cs-portrait-new-btn:hover{background:#3498db80}.cs-badge-clickable{cursor:pointer;border-radius:6px;padding:2px 4px;transition:background .15s}.cs-badge-clickable:hover{background:#3498db40}.cs-vitals-compact{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:4px}.cs-vital-row{display:flex;align-items:center;gap:6px;background:#ffffff0d;border-radius:8px;padding:8px 10px;font-size:.9em;white-space:nowrap}.cs-vital-row strong{color:#e8e8e8;font-size:1em}.cs-bonus-chip{font-size:.72em;font-weight:700;border-radius:4px;padding:1px 5px;margin-left:4px;line-height:1.4}.cs-bonus-pos{background:#27ae6033;color:#2ecc71;border:1px solid rgba(39,174,96,.4)}.cs-bonus-neg{background:#e74c3c33;color:#e74c3c;border:1px solid rgba(231,76,60,.4)}.cs-respec-points-label{font-size:.8em;color:#a0aec0}.cs-respec-points-label strong{color:#f39c12}.cs-inline-picker{padding:10px 20px;background:#1e2837e6;border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08)}.cs-picker-label{font-size:.8em;color:#a0aec0;display:block;margin-bottom:6px}.cs-picker-btns{display:flex;flex-wrap:wrap;gap:8px}.cs-picker-btns .btn.active{border-color:#f39c12;color:#f39c12}.cs-inv-weight-label{font-size:.8em;color:#a0aec0}.cs-inv-weight-label strong{color:#f39c12}.cs-inv-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}.cs-inv-empty{color:#a0aec0;font-style:italic;padding:12px;text-align:center;background:#ffffff08;border-radius:6px}.cs-inv-item{display:flex;align-items:center;gap:8px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:6px 8px;font-size:.85em;cursor:default}.cs-inv-item:hover{background:#ffffff14;border-color:#3498db66}.cs-inv-icon{font-size:1.1em;flex-shrink:0}.cs-inv-name{flex:1;color:#e8e8e8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cs-inv-meta{font-size:.75em;color:#a0aec0;flex-shrink:0}.cs-inv-rarity-uncommon .cs-inv-name{color:#2ecc71}.cs-inv-rarity-rare .cs-inv-name{color:#3498db}.cs-inv-rarity-epic .cs-inv-name{color:#9b59b6}.cs-inv-rarity-legendary .cs-inv-name{color:#f39c12}.cs-inv-rarity-artifact .cs-inv-name{color:#e74c3c}.cs-spell-schools{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0 12px}.cs-spell-school{background:#ffffff0a;border:1px solid rgba(255,255,255,.12);color:#e8e8e8;border-radius:6px;padding:4px 10px;font-size:.8em;cursor:pointer;transition:background .15s,border-color .15s}.cs-spell-school:hover{background:#3498db26;border-color:#3498db66}.cs-spell-school-active{background:#3498db40;border-color:#3498db;color:#fff}.cs-spells-list{display:flex;flex-direction:column;gap:6px}.cs-spells-empty{color:#a0aec0;font-style:italic;padding:12px;text-align:center;background:#ffffff08;border-radius:6px}.cs-spell-row{display:flex;align-items:center;gap:8px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:6px 10px;font-size:.85em}.cs-spell-row:hover{background:#ffffff14;border-color:#9b59b666}.cs-spell-icon{font-size:1.1em;flex-shrink:0}.cs-spell-name{flex:1;color:#e8e8e8;font-weight:600}.cs-spell-meta{font-size:.75em;color:#a0aec0}.cs-spell-locked{opacity:.5}.cs-spell-locked .cs-spell-name{color:#95a5a6}.cs-spell-low-mana{opacity:.75}.cs-spell-low-mana .cs-spell-meta{color:#e74c3c}.cs-spell-school-readonly{display:inline-flex;align-items:center;gap:4px;cursor:default;background:#f39c122e;border:1px solid #f39c12;color:#f39c12;border-radius:6px;padding:4px 10px;font-size:.8em;pointer-events:none}.party-sheets-row{display:flex;gap:12px;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;padding:12px;align-items:flex-start;height:calc(100vh - 160px)}.party-sheets-row::-webkit-scrollbar{height:10px}.party-sheets-row::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:5px}.party-sheets-empty{color:#a0aec0;font-style:italic;padding:24px}.party-sheet-card{flex:0 0 340px;scroll-snap-align:start;background:#1e2837eb;border:1px solid rgba(255,255,255,.08);border-radius:10px;display:flex;flex-direction:column;max-height:100%;min-height:420px;overflow:hidden}.party-sheet-header{display:flex;gap:10px;align-items:center;padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.08);background:#141e2d8c;flex-shrink:0}.party-sheet-header .cs-portrait-thumb-wrap{position:relative;width:56px;height:56px;border:0;overflow:visible;cursor:pointer;border-radius:50%;transition:transform .15s}.party-sheet-header .cs-portrait-thumb-wrap:hover{transform:scale(1.05)}.party-sheet-header .cs-portrait-thumb{width:56px;height:56px;border-radius:50%;object-fit:cover;border:2px solid #f39c12;display:block}.party-sheet-header .cs-portrait-zoom-hint{width:18px;height:18px;font-size:.65em;bottom:-2px;right:-2px;border:1px solid rgba(255,255,255,.25)}.party-sheet-header .cs-name{font-size:1em;margin:0 0 4px;color:#f39c12}.party-sheet-header .cs-badges{display:flex;gap:4px;font-size:1em}.party-sheet-header .cs-badge{padding:2px 6px;font-size:.9em}.party-sheet-tabs{display:flex;gap:2px;padding:6px 8px;border-bottom:1px solid rgba(255,255,255,.08);background:#141e2d4d;flex-shrink:0}.party-sheet-tabs .cs-tab{flex:1;font-size:.72em;padding:5px 4px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);color:#bdc3c7;border-radius:4px;cursor:pointer;white-space:nowrap;text-align:center;transition:background .15s,color .15s,border-color .15s}.party-sheet-tabs .cs-tab:hover{background:#ffffff14;color:#fff}.party-sheet-tabs .cs-tab.cs-tab-active{background:#f39c1226;border-color:#f39c12;color:#f39c12}.party-sheet-panel{flex:1;overflow-y:auto;padding:10px 12px;scrollbar-width:thin}.party-sheet-panel::-webkit-scrollbar{width:6px}.party-sheet-panel::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.party-sheet-panel .cs-section{margin-bottom:10px}.party-sheet-panel .cs-section-title{font-size:.85em;margin:0 0 6px}.party-sheet-panel .cs-attrs-grid{grid-template-columns:1fr 1fr;gap:4px}.party-sheet-panel .cs-attr-item{padding:4px 6px;font-size:.8em}.party-sheet-panel .cs-vitals-compact{flex-wrap:wrap;gap:6px 10px;font-size:.82em}.cs-equipped-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:6px}.cs-equipped-slot{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px;background:#ffffff0a;border:1px dashed rgba(255,255,255,.12);border-radius:6px;font-size:.72em;text-align:center;cursor:default;transition:background .15s,border-color .15s;min-height:62px}.cs-equipped-slot.filled{border-style:solid;background:#f39c1214}.cs-equipped-slot.filled[draggable=true]{cursor:grab}.cs-equipped-icon{font-size:1.3em;line-height:1}.cs-equipped-label{color:#a0aec0;font-size:.88em}.cs-equipped-name{color:#e8e8e8;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.cs-equipped-slot.empty{border-style:dashed}.cs-equipped-slot.empty .cs-equipped-name{color:#6c7a89;font-weight:400}.cs-equipped-placeholder{color:#6c7a89;font-style:italic;font-weight:400}.cs-equipped-slot.cs-inv-rarity-uncommon .cs-equipped-name{color:#2ecc71}.cs-equipped-slot.cs-inv-rarity-rare .cs-equipped-name{color:#3498db}.cs-equipped-slot.cs-inv-rarity-epic .cs-equipped-name{color:#9b59b6}.cs-equipped-slot.cs-inv-rarity-legendary .cs-equipped-name{color:#f39c12}.cs-equipped-slot.cs-inv-rarity-artifact .cs-equipped-name{color:#e74c3c}.cs-bag-grid{min-height:60px;padding:4px;border:1px dashed transparent;border-radius:6px;transition:border-color .15s,background .15s}.cs-bag-grid.cs-drop-hover{border-color:#3498db;background:#3498db14}.cs-equipped-slot.cs-drop-hover{border-color:#3498db;background:#3498db24}.cs-inv-item[draggable=true]{cursor:grab}.cs-inv-item.dragging,.cs-equipped-slot.dragging{opacity:.4}.cs-bag-empty{grid-column:1/-1;padding:18px;text-align:center;color:#6c7a89;font-style:italic;border:1px dashed rgba(255,255,255,.12);border-radius:6px}.party-master-tabs{display:flex;gap:6px;padding:8px 14px 0;flex-wrap:wrap}.party-master-tabs .party-master-tab{flex:0 0 auto;font-size:.85em;padding:6px 14px;background:#ffffff0a;border:1px solid rgba(255,255,255,.12);color:#bdc3c7;border-radius:6px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.party-master-tabs .party-master-tab:hover{background:#ffffff14;color:#fff}.party-master-tabs .party-master-tab.cs-tab-active{background:#f39c1233;border-color:#f39c12;color:#f39c12}
