:root{--primary-bg: var(--color-bg-primary);--secondary-bg: var(--color-bg-secondary);--accent-bg: var(--color-bg-accent);--panel-bg: #2d3748;--border-color: var(--color-border);--text-primary: var(--color-text-primary);--text-secondary: var(--color-text-secondary);--text-accent: #ffd700;--button-bg: var(--color-secondary);--button-hover: #3182ce;--health-color: var(--color-danger);--mana-color: #007bff;--success-color: var(--color-success);--warning-color: #ffc107;font-family:var(--font-body, "Inter", system-ui, sans-serif);line-height:var(--line-height-normal, 1.5);font-weight:var(--font-weight-normal, 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:var(--z-fixed)}.main-menu-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:linear-gradient(135deg,var(--color-bg-primary) 0%,var(--color-bg-secondary) 100%);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);font-family:var(--font-heading, "Cinzel", serif)}.main-menu-header{text-align:center;margin-bottom:40px}.game-title-main{font-family:var(--font-heading, "Cinzel", serif);font-size:3.5em;color:var(--text-accent);margin:0 0 10px;text-shadow:2px 2px 4px rgba(0,0,0,.5);font-weight:var(--font-weight-bold, 700)}.game-subtitle{font-family:var(--font-heading, "Cinzel", serif);font-size:1.3em;color:var(--text-secondary);margin:0 0 5px}.game-tagline{font-family:var(--font-heading, "Cinzel", serif);font-size:1.1em;color:var(--text-secondary);margin:0;opacity:.8}.main-menu-cold-hook{font-size:.95em;color:var(--text-secondary);margin:14px auto 0;max-width:38rem;line-height:1.45;opacity:.92}.main-menu-container{display:flex;gap:60px;max-width:1200px;width:90%;background:var(--color-surface-panel-95);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{font-family:var(--font-heading, "Cinzel", serif);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,var(--color-danger-vivid),var(--color-danger-deep))}.menu-button.primary:hover{background:linear-gradient(145deg,var(--color-danger-deep),var(--color-danger-vivid))}.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;visibility:hidden}.hud-container[data-ready="1"]{visibility:visible}.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{font-family:var(--font-mono, "Fira Code", "Consolas", monospace);font-size:var(--font-size-xs, .75rem)}.message-log--overlay{position:absolute;bottom:10px;right:10px;z-index:5;width:min(400px,calc(100% - 20px));max-height:200px;overflow:hidden;background:var(--color-surface-dark-50, rgba(45, 55, 72, .92));border:1px solid var(--color-interactive, var(--border-color));border-radius:6px;padding:28px 12px 12px;box-shadow:0 4px 12px var(--color-overlay-30);backdrop-filter:blur(5px);box-sizing:border-box}.message-log-messages{max-height:160px;overflow-y:auto}.message-log-toggle{position:absolute;top:4px;right:4px;z-index:2;padding:2px 10px;line-height:1.2;pointer-events:auto}.message-log-expand{display:none}.message-log-collapsed-label{display:none;font-size:.78em;padding-right:36px}.message-log--collapsed{max-height:none;padding:8px 12px;overflow:visible}.message-log--collapsed .message-log-minimize,.message-log--collapsed .message-log-messages{display:none}.message-log--collapsed .message-log-expand{display:inline-flex}.message-log--collapsed .message-log-collapsed-label{display:block}.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:var(--z-modal-backdrop);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.subscription-overlay{background:linear-gradient(135deg,var(--color-bg-primary) 0%,var(--color-bg-secondary) 50%,var(--color-bg-accent) 100%);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.subscription-panel{background:linear-gradient(145deg,var(--color-surface-panel-95) 0%,rgba(26,26,46,.95) 100%);border:2px solid var(--accent-bg);border-radius:20px;box-shadow:0 20px 40px var(--color-overlay-30),0 0 30px var(--color-glow-gold-10);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-family:var(--font-heading, "Cinzel", serif);font-size:3rem;font-weight:var(--font-weight-bold, 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 var(--color-overlay-50)}.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:var(--color-surface-panel-60);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;text-align:center;transition:all .3s ease}.feature-item:hover{background:var(--color-surface-panel-80);border-color:var(--text-accent);transform:translateY(-2px);box-shadow:0 8px 16px var(--color-overlay-20)}.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:var(--color-surface-primary-80);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:var(--color-surface-panel-80);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 var(--color-glow-gold-20)}.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:var(--color-surface-panel-80);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 var(--color-overlay-20)}.btn-primary:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-secondary{background:var(--color-surface-panel-80);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:var(--color-surface-panel-60);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 var(--color-danger);color:var(--color-danger);padding:.75rem;border-radius:6px;font-size:.9rem;margin-top:1rem;text-align:center}.form-success{background:#28a7451a;border:1px solid var(--color-success);color:var(--color-success);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:var(--color-surface-panel-80);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 var(--color-glow-gold-20)}.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:var(--color-surface-panel-60);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 var(--color-overlay-50);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:var(--color-danger-dark);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 var(--color-glow-gold-20)}.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:var(--z-overlay)}.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 var(--color-overlay-30)}.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,var(--color-surface-panel-95) 0%,rgba(26,26,46,.95) 100%);border:2px solid var(--accent-bg);border-radius:20px;box-shadow:0 20px 40px var(--color-overlay-30),0 0 30px var(--color-glow-gold-10);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 var(--color-overlay-40),0 0 50px var(--color-glow-gold-20);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,var(--color-surface-primary-60) 0%,rgba(15,15,30,.8) 100%);border:2px dashed var(--border-color);cursor:pointer}.empty-card:hover{background:linear-gradient(145deg,var(--color-surface-panel-80) 0%,rgba(26,26,46,.9) 100%);border-color:var(--text-accent);border-style:solid}.character-header{background:linear-gradient(135deg,var(--color-glow-gold-10) 0%,transparent 100%);padding:1.5rem;border-bottom:1px solid var(--color-glow-gold-20);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 var(--color-overlay-20);text-shadow:0 1px 2px var(--color-overlay-50)}.character-avatar{width:60px;height:60px;border-radius:50%;border:3px solid var(--text-accent);box-shadow:0 0 20px var(--color-glow-gold-30);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 var(--color-overlay-50);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:var(--color-glow-accent);padding:.8rem;border-radius:10px;border:1px solid var(--color-glow-gold-20);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:var(--color-surface-primary-80);padding:.6rem;border-radius:8px;border:1px solid var(--border-color);text-align:center;transition:all .3s ease}.stat-item:hover{background:var(--color-surface-panel-80);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 var(--color-glow-gold-10);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,var(--color-surface-primary-80),var(--color-surface-panel-60));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 var(--color-overlay-30),0 0 30px #ffd70026}.character-card[data-class=Sorcerer]{box-shadow:0 20px 40px var(--color-overlay-30),0 0 30px #8a2be226}.character-card[data-class=Archer]{box-shadow:0 20px 40px var(--color-overlay-30),0 0 30px #228b2226}.character-card[data-class=Thief]{box-shadow:0 20px 40px var(--color-overlay-30),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 var(--color-overlay-40),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,var(--color-glow-gold-10) 0%,transparent 100%);padding:2rem;border-bottom:2px solid var(--color-glow-gold-20);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,var(--color-glow-accent) 0%,rgba(26,26,46,.5) 100%);border:2px solid var(--color-glow-gold-20);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 var(--color-overlay-30),0 0 25px var(--color-glow-gold-20)}.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 var(--color-overlay-50);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,var(--color-surface-primary-80) 0%,var(--color-surface-panel-60) 100%);color:var(--text-primary);font-size:1.1rem;font-weight:600;transition:all .3s ease;box-shadow:inset 0 2px 4px var(--color-overlay-30)}.hero-name-input:focus{outline:none;border-color:var(--text-accent);box-shadow:0 0 20px var(--color-glow-gold-30),inset 0 2px 4px var(--color-overlay-30);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 var(--color-overlay-30)}.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,var(--color-surface-primary-80) 0%,var(--color-surface-panel-60) 100%);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,var(--color-glow-gold-10),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 var(--color-overlay-30),0 0 20px var(--color-glow-gold-20)}.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,var(--color-glow-gold-20) 0%,var(--color-surface-panel-80) 100%);border-color:var(--text-accent);box-shadow:0 0 30px #ffd70066,inset 0 0 20px var(--color-glow-gold-10);transform:scale(1.05)}.race-icon,.class-icon{font-size:2.5rem;margin-bottom:.5rem;filter:drop-shadow(0 2px 4px var(--color-overlay-50))}.race-name,.class-name{font-weight:700;font-size:1.2rem;color:var(--text-primary);margin-bottom:.5rem;text-shadow:0 1px 2px var(--color-overlay-50)}.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,var(--color-surface-primary-80) 0%,var(--color-surface-panel-60) 100%);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,var(--color-glow-gold-10),transparent);opacity:0;transition:opacity .3s ease}.radio-option:hover{border-color:var(--text-accent);transform:translateY(-2px);box-shadow:0 5px 10px var(--color-overlay-20)}.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,var(--color-surface-primary-60) 0%,rgba(15,15,30,.8) 100%);border:2px solid var(--color-glow-gold-30);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 var(--color-glow-gold-30);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 var(--color-overlay-50)}.attributes-editor{background:linear-gradient(145deg,var(--color-surface-primary-60) 0%,rgba(15,15,30,.8) 100%);border:2px solid var(--color-glow-gold-30);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:var(--color-glow-accent);border:1px solid var(--color-glow-gold-20);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 var(--color-overlay-20)}.manual-attr-btn:disabled{background:#666;cursor:not-allowed;opacity:.5;transform:none}.simplified-preview-section{background:linear-gradient(145deg,var(--color-surface-primary-60) 0%,rgba(15,15,30,.8) 100%);border:2px solid var(--color-glow-gold-30);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 var(--color-glow-gold-30);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 var(--color-overlay-50)}.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 var(--color-overlay-50);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:var(--color-glow-accent);border:1px solid var(--color-glow-gold-20);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 var(--color-overlay-20)}.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:var(--color-surface-primary-80);border:1px solid var(--text-accent);border-radius:8px;padding:.5rem;text-shadow:0 1px 2px var(--color-overlay-50)}.game-ui{width:100%;height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,var(--color-bg-primary) 0%,var(--color-bg-secondary) 100%)}.game-world-container{flex:1;padding:20px;overflow-y:auto}.world-view{max-width:1200px;margin:0 auto}.current-location{text-align:center;margin-bottom:40px;padding:20px;background:linear-gradient(135deg,var(--color-glow-gold-10) 0%,rgba(255,215,0,.05) 100%);border-radius:8px;border:1px solid var(--color-glow-gold-30)}.current-location h3{color:var(--text-accent);font-size:2.2rem;margin:0 0 15px;text-shadow:2px 2px 4px var(--color-overlay-50)}.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 var(--color-glow-gold-20)}.time-weather{display:flex;gap:20px;align-items:center}.time-weather span{background:var(--color-overlay-30);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 var(--color-glow-gold-30)}.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:var(--color-danger)}.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 var(--color-overlay-30)}.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:var(--z-modal-backdrop);display:flex;align-items:center;justify-content:center}.combat-container{border:2px solid var(--color-glow-gold-30);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 var(--color-overlay-30),0 0 25px var(--color-glow-gold-20)}.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 var(--color-glow-gold-20)}.random-char-portrait{width:64px;height:64px;border-radius:50%;border:3px solid var(--text-accent);box-shadow:0 0 20px var(--color-glow-gold-30);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 var(--color-overlay-50)}.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 var(--color-glow-gold-20);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:var(--color-surface-primary-80);padding:.4rem;border-radius:6px;border:1px solid var(--border-color);text-align:center;transition:all .3s ease}.random-stat-item:hover{background:var(--color-surface-panel-80);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 var(--color-glow-gold-20)}.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),var(--color-green-bright));border:2px solid var(--success-color);color:#fff}.btn-accept-team:hover:not(:disabled){background:linear-gradient(45deg,var(--color-green-bright),var(--text-accent));transform:translateY(-2px) scale(1.05);box-shadow:0 8px 16px var(--color-overlay-30)}.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 var(--color-overlay-30)}.btn-manual-creation{background:var(--color-surface-panel-80);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 var(--color-overlay-30)}@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:var(--z-overlay);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(5px)}.tutorial-message{background:linear-gradient(135deg,var(--color-bg-deep) 0%,var(--color-bg-inset) 100%);color:#fff;padding:30px;border-radius:15px;max-width:500px;text-align:center;box-shadow:0 10px 30px var(--color-overlay-50);border:2px solid var(--color-interactive);animation:tutorialSlideIn .5s ease-out}.tutorial-message h3{margin:0 0 20px;color:var(--color-interactive);font-size:24px;font-weight:700}.tutorial-message p{margin:0 0 25px;font-size:16px;line-height:1.6;color:var(--color-text-pale)}.tutorial-message button{background:linear-gradient(135deg,var(--color-interactive) 0%,var(--color-interactive-pressed) 100%);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 var(--color-glow-blue)}.tutorial-message button:hover{background:linear-gradient(135deg,var(--color-interactive-pressed) 0%,#1f5f8b 100%);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;min-height:0;background:linear-gradient(135deg,var(--color-bg-primary) 0%,var(--color-bg-secondary) 50%,var(--color-bg-accent) 100%);color:var(--color-text-light);font-family:var(--font-body, "Inter", system-ui, sans-serif)}.game-header{flex-shrink:0;background:linear-gradient(90deg,var(--color-bg-deep) 0%,var(--color-bg-inset) 100%);border-bottom:2px solid var(--color-interactive);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:var(--color-text-soft);font-weight:600}.status-value{color:var(--color-text-pale);font-weight:700}.game-navigation{display:flex;gap:4px;justify-content:center}.nav-btn{background:linear-gradient(135deg,var(--color-bg-inset) 0%,var(--color-bg-deep) 100%);border:1px solid var(--color-interactive);color:var(--color-text-pale);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,var(--color-interactive) 0%,var(--color-interactive-pressed) 100%);transform:translateY(-1px)}.nav-btn.active{background:linear-gradient(135deg,var(--color-danger-vivid) 0%,var(--color-danger-deep) 100%);border-color:var(--color-danger-vivid)}.game-main-area{display:flex;flex:1;min-height:0;position:relative}.game-view{display:none;flex:1;min-height:0;padding:20px;overflow-y:auto}.game-view.active{display:flex;flex-direction:column;min-height:0}.party-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:30px}.party-member{background:linear-gradient(135deg,var(--color-bg-inset) 0%,var(--color-bg-deep) 100%);border:2px solid var(--color-interactive);border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;transition:all .2s ease;cursor:pointer}.party-member:hover{border-color:var(--color-danger-vivid);transform:translateY(-2px);box-shadow:0 4px 12px #e74c3c4d}.member-portrait{width:60px;height:60px;background:linear-gradient(135deg,var(--color-accent-arcane) 0%,var(--color-accent-violet) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;border:2px solid var(--color-text-pale)}.member-info{flex:1}.member-name{color:var(--color-accent-warm);margin:0 0 8px;font-size:18px;font-weight:700}.member-stats{display:flex;flex-direction:column;gap:4px}.stat{color:var(--color-text-pale);font-size:14px}.hp-value{color:var(--color-danger-vivid);font-weight:700}.mp-value{color:var(--color-interactive);font-weight:700}.level-value{color:var(--color-accent-warm);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:var(--color-surface-dark-80);border-radius:8px}.inventory-slot{width:60px;height:60px;border:2px solid var(--color-interactive);border-radius:6px;background:var(--color-surface-dark-50);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.inventory-slot:hover{border-color:var(--color-danger-vivid);background:#e74c3c33}.inventory-slot.filled{background:#2ecc714d;border-color:var(--color-success-vivid)}.inventory-info{width:300px;background:var(--color-surface-dark-80);border:1px solid var(--color-interactive);border-radius:8px;padding:20px}.inventory-info h3{color:var(--color-accent-warm);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,var(--color-bg-inset) 0%,var(--color-bg-deep) 100%);border:1px solid var(--color-interactive);color:var(--color-text-pale);padding:12px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease}.spell-school:hover{background:linear-gradient(135deg,var(--color-interactive) 0%,var(--color-interactive-pressed) 100%)}.spell-school.active{background:linear-gradient(135deg,var(--color-danger-vivid) 0%,var(--color-danger-deep) 100%);border-color:var(--color-danger-vivid)}.spells-list{flex:1;background:var(--color-surface-dark-80);border:1px solid var(--color-interactive);border-radius:8px;padding:16px;overflow-y:auto;max-height:500px}.spell-item{background:var(--color-surface-dark-50);border:1px solid var(--color-interactive);border-radius:6px;padding:12px;margin-bottom:8px;cursor:pointer;transition:all .2s ease}.spell-item:hover{background:var(--color-glow-blue);border-color:var(--color-danger-vivid)}.spell-details{width:300px;background:var(--color-surface-dark-80);border:1px solid var(--color-interactive);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:var(--color-text-secondary)}.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:var(--color-text-primary)}.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:var(--color-bg-darkest);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:var(--color-text-primary)}.mastery-tier-pill.mastery-tier-grandmaster{background:linear-gradient(135deg,#fde047,var(--color-accent-amber));color:var(--color-bg-darkest);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 var(--color-highlight-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:var(--color-text-primary);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 var(--color-highlight-06);color:var(--color-text-secondary)}.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 var(--color-highlight-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:var(--color-text-primary);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.spell-school-card .spell-row-level{color:var(--color-text-muted);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:var(--color-text-muted);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:var(--color-surface-dark-80);border:1px solid var(--color-interactive);border-radius:8px;padding:16px;overflow-y:auto;max-height:500px}.quest-item{background:var(--color-surface-dark-50);border:1px solid var(--color-interactive);border-radius:6px;padding:16px;margin-bottom:12px;cursor:pointer;transition:all .2s ease}.quest-item:hover{background:var(--color-glow-blue);border-color:var(--color-danger-vivid)}.quest-item.active{background:#e74c3c4d;border-color:var(--color-danger-vivid)}.quest-details{width:400px;background:var(--color-surface-dark-80);border:1px solid var(--color-interactive);border-radius:8px;padding:20px}.map-container{display:flex;flex-direction:column;align-items:center;gap:20px}.map-legend{display:flex;gap:20px;flex-wrap:wrap;justify-content:center}.legend-item{display:flex;align-items:center;gap:8px;color:var(--color-text-pale);font-size:14px}.party-status-item{background:var(--color-surface-dark-50);border:1px solid var(--color-interactive);border-radius:6px;padding:12px;margin-bottom:8px}.party-status-item .member-name{color:var(--color-accent-warm);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,var(--color-danger-vivid) 0%,var(--color-danger-deep) 100%);transition:width .3s ease}.mp-bar .bar-fill{height:100%;background:linear-gradient(90deg,var(--color-interactive) 0%,var(--color-interactive-pressed) 100%);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}.noend-defeated-skull{display:flex;align-items:center;justify-content:center;width:100%;height:100%;min-height:2.5rem;font-size:clamp(2.25rem,6vw,4rem);line-height:1;cursor:pointer;user-select:none}.enc-picture-zoom-body .noend-defeated-skull--zoom{font-size:clamp(4.5rem,18vw,9rem);min-height:min(40vh,360px);width:100%;max-width:100%}.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:var(--color-surface-dark-50);border:1px solid var(--color-interactive);border-radius:6px;padding:12px}.message{color:var(--color-text-pale);font-size:12px;margin-bottom:4px;padding:4px 0;border-bottom:1px solid var(--color-glow-blue)}.game-footer{flex-shrink:0;background:linear-gradient(90deg,var(--color-bg-deep) 0%,var(--color-bg-inset) 100%);border-top:2px solid var(--color-interactive);padding:12px 16px}.combat-status{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px 12px;margin-bottom:12px;padding:12px;background:#e74c3c33;border:1px solid var(--color-danger-vivid);border-radius:6px}.combat-status.hidden{display:none}.initiative-tracker{display:flex;gap:4px;padding:6px 8px;overflow-x:auto;background:var(--color-overlay-30);border-radius:8px;margin:4px 0;width:100%}.initiative-tracker:empty{display:none}.init-entry{display:flex;flex-direction:column;align-items:center;min-width:40px;padding:2px;border-radius:6px;border:2px solid transparent;transition:border-color .2s,opacity .2s;cursor:default}.init-entry--active{border-color:gold;box-shadow:0 0 8px #ffd70080}.init-entry--player .init-portrait{border-color:#4caf50}.init-entry--enemy .init-portrait{border-color:#f44336}.init-entry--defeated{opacity:.35}.init-portrait{width:32px;height:32px;border-radius:50%;border:2px solid #666;object-fit:cover;background:#1a1a2e}.init-portrait--placeholder{display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:#ccc}.init-name{font-size:.6rem;color:#ccc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:48px;text-align:center}@media (prefers-reduced-motion: reduce){.init-entry{transition:none}}.combat-info{display:flex;gap:20px;color:var(--color-text-pale);font-weight:600}.combat-actions{display:flex;flex-wrap:wrap;gap:8px}.combat-btn{background:linear-gradient(135deg,var(--color-danger-vivid) 0%,var(--color-danger-deep) 100%);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,var(--color-danger-deep) 0%,var(--color-danger-vivid) 100%);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%;flex-shrink:0;max-height:min(200px,28vh);overflow-y:auto;background:#0a0e16d1;border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:8px 10px;color:var(--color-text-cool);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-list .csp-section{list-style:none;padding:10px 8px 4px;pointer-events:none;margin:0}.combat-spell-picker-body .class-skill-picker-section{padding:10px 8px 4px;pointer-events:none;margin:0}.combat-spell-picker-list .csp-section-label,.combat-spell-picker-body .csp-section-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-subdued)}.combat-spell-picker-body .csp-bonus-tag,.combat-spell-picker-list .csp-bonus-tag{display:inline-block;margin-left:6px;padding:1px 6px;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;border-radius:4px;border:1px solid rgba(241,196,15,.45);color:var(--color-accent-gold);background:#f1c40f1a;vertical-align:middle}.combat-spell-picker-body .csp-free-tag,.combat-spell-picker-list .csp-free-tag{display:inline-block;margin-left:6px;padding:1px 6px;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;border-radius:4px;border:1px solid rgba(46,204,113,.45);color:var(--color-success-vivid);background:#2ecc711a;vertical-align:middle}.combat-spell-picker-backdrop{position:fixed;inset:0;z-index:var(--z-overlay);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:var(--color-bg-deepest);border:1px solid rgba(255,255,255,.12);border-radius:12px;color:var(--color-text-cool);box-shadow:0 12px 40px #0000008c;overflow:hidden}.combat-spell-picker--fixed-size .csp-modal-frame{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;overflow:hidden}.csp-school-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:6px 8px;padding:8px 12px 6px;border-bottom:1px solid var(--color-highlight-06);background:var(--color-overlay-20);flex-shrink:0}.combat-spell-picker-search{padding:4px 12px 6px;border-bottom:1px solid rgba(255,255,255,.05)}.combat-spell-picker-search .prog-inp{width:100%;box-sizing:border-box}.csp-school-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 9px 5px 7px;border-radius:999px;border:1px solid rgba(183,148,244,.28);background:linear-gradient(165deg,#2a243af2,#121420fa);color:#e8e4f2;font-family:inherit;font-size:.72rem;font-weight:600;letter-spacing:.03em;cursor:pointer;box-shadow:inset 0 1px #ffffff0d;-webkit-appearance:none;appearance:none}.csp-school-chip__ic{font-size:1rem;line-height:1}.csp-school-chip__txt{max-width:5.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.csp-school-chip__cnt{min-width:1.1em;padding:1px 5px;border-radius:999px;font-size:.65rem;font-weight:700;font-variant-numeric:tabular-nums;color:#c9b8e8;background:#00000059;border:1px solid var(--color-highlight-08)}.csp-school-toolbar--icon-only{gap:4px 6px;padding:6px 10px 5px;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.csp-school-toolbar--icon-only .csp-school-chip{position:relative;padding:0;width:32px;height:32px;justify-content:center;gap:0;border-radius:50%}.csp-school-toolbar--icon-only .csp-school-chip__ic{font-size:1.05rem}.csp-school-toolbar--icon-only .csp-school-chip__cnt{position:absolute;top:-4px;right:-4px;min-width:.95em;padding:0 4px;font-size:.58rem;line-height:1.4;background:#0a0812eb;border-color:#b794f473;pointer-events:none}.csp-school-toolbar--icon-only .csp-school-chip.is-active .csp-school-chip__cnt{border-color:#f1c40fb3;color:#fff4dc}.csp-school-toolbar--icon-only .csp-school-chip.is-empty .csp-school-chip__cnt{display:none}.csp-school-chip:hover:not(.is-empty):not(.is-active){border-color:#f39c1273;color:#fff8ec}.csp-school-chip.is-active{border-color:#f1c40fbf;background:linear-gradient(165deg,#58341cf2,#241c30fc);color:#fff4dc;box-shadow:0 0 0 1px #f1c40f40,inset 0 1px 0 var(--color-highlight-08)}.csp-school-chip.is-empty{opacity:.38;cursor:not-allowed;border-color:var(--color-highlight-08)}.csp-school-chip:focus-visible{outline:2px solid var(--color-accent-warm);outline-offset:2px}.combat-spell-picker--fixed-size .csp-body-split{flex:1 1 auto;min-height:0;overflow:hidden}.combat-spell-picker--fixed-size .csp-list-scroll{max-height:100%;min-height:0}.combat-spell-picker--fixed-size .csp-detail-aside{max-height:none;align-self:stretch;min-height:0;overflow-x:hidden;overflow-y:auto}.combat-spell-picker--fixed-size .csp-h-preview-block{max-height:42%;overflow-y:auto;overflow-x:hidden}.combat-spell-picker.csp-with-detail,.combat-item-picker.csp-with-detail{max-width:min(880px,98vw);width:100%}.combat-spell-picker.csp-with-detail.combat-spell-picker--fixed-size{width:min(860px,96vw);max-width:min(860px,96vw);height:min(580px,90vh);max-height:min(580px,90vh);box-sizing:border-box}.csp-body-split{display:flex;flex:1 1 auto;min-height:0;align-items:stretch}.csp-list-scroll{flex:1 1 58%;min-width:0;overflow-y:auto;padding:8px}.csp-detail-hint{margin:0 0 8px;font-size:.78rem}.csp-row-outer{display:flex;align-items:stretch;gap:6px;margin-bottom:6px}.csp-row-outer .combat-spell-row{flex:1 1 auto;margin-bottom:0;min-width:0}.csp-row-detail-btn{flex:0 0 40px;width:40px;min-height:44px;border-radius:8px;border:1px solid rgba(184,160,120,.35);background:linear-gradient(165deg,#302a20f2,#121620fa);color:#d4c4a8;font-size:.95rem;font-weight:700;cursor:pointer;padding:0;font-family:inherit;line-height:1;box-shadow:inset 0 1px 0 var(--color-highlight-06)}.csp-row-detail-btn:hover{border-color:#f39c12a6;color:var(--color-accent-gold);background:linear-gradient(165deg,#3e3424fa,#1c202cfa)}.csp-row-detail-btn:focus-visible{outline:2px solid var(--color-accent-warm);outline-offset:2px}.csp-detail-aside{flex:0 0 min(300px,38vw);min-height:140px;max-height:58vh;overflow-y:auto;overflow-x:hidden;padding:10px 12px 12px;border-left:1px solid var(--color-highlight-08);background:linear-gradient(180deg,#080c148c,#0e121ceb)}.csp-detail-aside--empty{display:flex;align-items:center;justify-content:center}.cip-detail-aside{border-left-color:#2ecc7126}.csp-detail-card{font-size:.82rem;line-height:1.45;color:#dfe8ee}.csp-detail-header{display:flex;gap:10px;align-items:flex-start;margin-bottom:10px}.csp-detail-icon{font-size:1.5rem;line-height:1;filter:drop-shadow(0 1px 2px var(--color-overlay-50))}.csp-detail-name{font-weight:700;font-size:1.02rem;color:#f7f2ea;letter-spacing:.02em}.csp-detail-sub{font-size:.72rem;color:var(--color-text-subdued);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}.csp-detail-dl{margin:0;display:grid;grid-template-columns:minmax(0,auto) minmax(0,1fr);gap:4px 10px;align-items:baseline}.csp-detail-dt{margin:0;color:#7d95a8;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em}.csp-detail-dd{margin:0;font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:.8rem;color:#c5d6e4}.csp-detail-desc{margin:10px 0 0;color:#aebcc9;font-size:.78rem;overflow-wrap:anywhere;word-break:break-word;max-width:100%}.csp-detail-heighten{margin-top:10px;padding-top:8px;border-top:1px solid rgba(183,148,244,.2)}.csp-detail-section-title{font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:#c9b078;margin-bottom:6px}.csp-detail-heighten-line{margin:4px 0 0;color:#c9d4de;font-size:.76rem}.csp-detail-warn{margin-top:10px;color:var(--color-danger-vivid);font-weight:600;font-size:.82rem}.csp-detail-warn-tags{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0 4px}.csp-detail-warn-tag{display:inline-flex;align-items:center;padding:4px 8px;border-radius:6px;font-size:.68rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;border:1px solid rgba(231,76,60,.45);background:#e74c3c1f;color:#ffb3a7}.csp-h-actions{display:flex;gap:.5rem;margin-top:.75rem}.csp-h-action{flex:1;padding:10px 14px;border-radius:8px;font-weight:600;cursor:pointer;border:1px solid rgba(255,255,255,.14);background:var(--color-highlight-06);color:var(--color-text-cool);font-family:inherit;font-size:.9rem;-webkit-appearance:none;appearance:none}.csp-h-action:disabled{opacity:.45;cursor:not-allowed}.csp-h-action--primary{background:linear-gradient(180deg,#7848a8f2,#3e2662fa);border-color:#b794f48c}.csp-h-action--primary:hover:not(:disabled){border-color:#d6bdffd9}.csp-h-action--ghost{background:transparent}.csp-h-preview-block{white-space:pre-line;line-height:1.45;margin-top:.5rem}@media (max-width: 640px){.csp-body-split{flex-direction:column}.csp-detail-aside{flex:none;width:100%;max-height:36vh;border-left:none;border-top:1px solid var(--color-highlight-08)}}.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-topbar--skills{background:#3498db24}.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:var(--color-text-cool);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 var(--color-accent-warm);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 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}.csp-mastery-badge{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;font-size:.6rem;font-weight:700;line-height:1;text-transform:uppercase;flex-shrink:0}.csp-mastery--normal{background:#78788c59;color:#c8c8dcb3}.csp-mastery--expert{background:#3b82f659;color:#93bbfd}.csp-mastery--master{background:#a855f759;color:#c4b5fd}.csp-mastery--grandmaster{background:#facc1559;color:#fde047}.combat-spell-school{font-size:.8em;color:var(--color-text-subdued);text-transform:uppercase;letter-spacing:.03em}.combat-spell-dmg{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;color:var(--color-accent-gold)}.combat-spell-mana{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;color:var(--color-interactive)}.combat-spell-mana.insufficient{color:var(--color-danger-vivid);text-decoration:line-through}.csp-h-wrap{margin:.5rem 0 .35rem}.csp-h-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-subdued);margin-bottom:.35rem}.csp-h-pips{display:flex;flex-wrap:wrap;gap:.35rem;align-items:center}.csp-h-pip{min-width:2.25rem;height:2.25rem;padding:0 .35rem;border-radius:999px;border:1px solid rgba(155,89,182,.45);background:#1e1630e6;color:#d7c4ea;font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .12s ease,border-color .12s ease,box-shadow .12s ease}.csp-h-pip:hover{border-color:#b794f4d9;background:#302448f2}.csp-h-pip.is-active{border-color:#8e44adf2;background:linear-gradient(145deg,rgba(102,51,153,.55),var(--color-surface-dark-50));box-shadow:0 0 0 1px #b794f459,0 0 12px #8e44ad40;color:#fff}.csp-h-pip:focus-visible{outline:2px solid var(--color-accent-arcane);outline-offset:2px}#csp-h-preview{white-space:pre-line;line-height:1.45;margin-top:.5rem}.combat-target-row.is-selected{border-color:#9b59b6d9;box-shadow:0 0 0 1px #8e44ad59;background:#302448bf}.combat-target-picker .csp-h-confirm-row{display:flex;gap:.5rem;margin-top:.75rem;justify-content:flex-end}.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:var(--color-text-cool);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 var(--color-accent-warm);outline-offset:2px}.combat-target-row--foe{border-left:3px solid rgba(231,76,60,.45)}.combat-target-row--ally{border-left:3px solid rgba(46,204,113,.55)}.combat-target-picker--ally .combat-target-row--ally:hover{background:#2ecc711a;border-color:#2ecc7159}.combat-target-picker--foe .combat-target-row--foe:hover{background:#e74c3c24;border-color:#e74c3c59}.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:var(--color-accent-gold);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,var(--color-danger-deep) 0%,var(--color-danger-vivid) 100%);border-radius:4px}.ctp-preview-line{position:fixed;z-index:100000;height:2px;transform-origin:0 50%;pointer-events:none;opacity:.65;border-radius:1px;box-shadow:0 0 6px currentColor;transition:opacity .15s}.game-controls{display:flex;justify-content:center;gap:30px}.control-group{display:flex;align-items:center;gap:8px}.control-label{color:var(--color-text-soft);font-size:12px}.control-keys{color:var(--color-accent-warm);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 var(--color-interactive)}.character-portrait-large img{width:100%;height:100%;object-fit:cover}.character-basic-info h3{color:var(--color-accent-warm);margin:0 0 10px}.character-basic-info p{color:var(--color-text-pale);margin:5px 0;font-size:1.1em}.character-stats-section,.character-attributes-section{background:var(--color-surface-panel-50);padding:15px;border-radius:8px;margin-bottom:15px}.character-stats-section h3,.character-attributes-section h3{color:var(--color-interactive);margin:0 0 15px;border-bottom:2px solid var(--color-interactive);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:var(--color-text-soft);font-weight:700}.vital-value{color:var(--color-accent-warm);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:var(--color-text-pale);flex:1}.attribute-value{color:var(--color-accent-warm);font-weight:700;font-size:1.1em}.character-sheet-actions{text-align:center;margin-top:20px;padding-top:20px;border-top:1px solid var(--color-bg-inset)}.character-equipment-section{background:var(--color-surface-panel-50);padding:15px;border-radius:8px;margin-bottom:15px}.character-equipment-section h3{color:var(--color-interactive);margin:0 0 15px;border-bottom:2px solid var(--color-interactive);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:var(--color-text-soft);font-weight:700}.equipment-value{color:var(--color-accent-warm);font-weight:700}.character-skills-section{background:var(--color-surface-panel-50);padding:15px;border-radius:8px;margin-bottom:15px}.character-skills-section h3{color:var(--color-interactive);margin:0 0 15px;border-bottom:2px solid var(--color-interactive);padding-bottom:5px}.skills-content{display:flex;flex-direction:column;gap:15px}.race-skills h4,.class-skills h4{color:var(--color-accent-warm);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:var(--color-surface-dark-50)}.skill-icon{font-size:1.2em}.skill-name{color:var(--color-text-pale);font-weight:500}.character-lore-content{padding:5px 0}.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,var(--color-surface-panel-95) 0%,rgba(26,26,46,.95) 100%);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 var(--color-overlay-30)}.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:var(--color-glow-accent);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:var(--z-toast);padding:1rem 1.5rem;border-radius:8px;box-shadow:0 4px 12px var(--color-overlay-30);animation:slideInRight .3s ease-out}.save-load-message.success{background:linear-gradient(135deg,var(--success-color),var(--color-green-bright));color:#fff}.save-load-message.error{background:linear-gradient(135deg,var(--health-color),var(--color-danger-dark));color:#fff}.save-load-message.saving{background:linear-gradient(135deg,var(--info-color, #3498db),var(--color-blue-bright, #2980b9));color:#fff;animation:slideInRight .3s ease-out,savePulse 1.5s ease-in-out infinite}@keyframes savePulse{0%,to{opacity:1}50%{opacity:.6}}@media (prefers-reduced-motion: reduce){.save-load-message{animation:none!important}}.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:var(--color-surface-dark-80);border-radius:6px;border:1px solid var(--color-interactive)}.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 var(--color-interactive);border-radius:8px;padding:16px;transition:all .3s ease;display:flex;flex-direction:column;gap:12px}.spell-card:hover{border-color:var(--color-danger-vivid);background:var(--color-glow-blue);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:var(--color-danger-vivid)}.spell-unavailable{padding:8px;background:#e74c3c33;border-radius:4px;color:var(--color-danger-vivid);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:var(--z-fixed)}.spell-effect{position:absolute;pointer-events:none;z-index:var(--z-modal-backdrop)}@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 var(--color-accent-fire))}@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 var(--color-accent-fire))}@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 var(--color-accent-yellow-light))}@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 var(--color-accent-yellow-light))}@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 var(--color-surface-earth))}@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 var(--color-surface-earth))}@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 var(--color-accent-fire))}.spell-effect.tornado{filter:drop-shadow(0 0 20px var(--color-accent-yellow-light))}.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 var(--color-accent-arcane)}.character-lore-section{background:var(--color-surface-panel-50);padding:15px;border-radius:8px;margin-bottom:15px;border-left:3px solid var(--color-accent-arcane)}.character-lore-section h3{color:var(--color-accent-arcane);margin:0 0 12px;border-bottom:2px solid var(--color-accent-arcane);padding-bottom:5px}.character-backstory-text{color:var(--color-text-soft);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:var(--color-danger-vivid);color:var(--color-danger-vivid)}.cs-skills-subtabs{display:flex;flex-wrap:wrap;gap:6px;margin:0 0 10px}.cs-skills-subtab{font-size:.78em;padding:5px 10px;border-radius:6px;border:1px solid rgba(255,255,255,.15);background:var(--color-highlight-06);color:#cbd5e0;cursor:pointer}.cs-skills-subtab.cs-tab-active{border-color:var(--color-accent-warm);color:var(--color-accent-warm);background:#f39c121f}.cs-skills-subpanels-wrap{min-height:48px}.cs-skills-subpanel .cs-skills-list{margin-top:0}.cs-actions{display:flex;flex-wrap:wrap;gap:12px;padding:12px 20px;border-top:1px solid var(--color-highlight-10);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 var(--color-highlight-10)}.cs-portrait-metadata-notice{font-size:.85em;color:var(--color-accent-amber);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:var(--color-interactive-light);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:var(--color-text-light);font-size:.95em}.cs-party-status-text span{font-size:.82em;color:var(--color-text-muted)}.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:var(--color-accent-warm);font-size:1.1em;margin:0 0 6px}.cs-party-empty-desc{color:var(--color-text-muted);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 var(--color-highlight-08);border-radius:10px;padding:12px;transition:border-color .2s,box-shadow .2s}.cs-party-card:hover{border-color:var(--color-interactive-light);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:var(--color-highlight-12);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:var(--color-danger-vivid)}.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 var(--color-accent-warm);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:var(--color-text-muted);flex-shrink:0}.cs-party-card-name{font-weight:700;color:var(--color-accent-warm);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:var(--color-text-light);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:var(--color-highlight-05);border-radius:6px;white-space:nowrap}.cs-party-card-vitals .cs-vital-row strong{color:var(--color-text-light);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:var(--color-text-light);font-size:1em}.party-char-card{position:relative;background:#2d3748eb;border:2px solid var(--color-interactive);border-radius:12px;padding:12px;transition:border-color .2s,box-shadow .2s}.party-char-card:hover{border-color:var(--color-interactive-light);box-shadow:0 4px 16px #3498db59}.party-card-portrait{flex-shrink:0;cursor:pointer;border-radius:50%;overflow:hidden;width:64px;height:64px;border:2px solid var(--color-accent-warm)}.party-char-name{font-weight:700;color:var(--color-accent-warm);font-size:1em;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.party-char-level{font-size:.8em;color:var(--color-text-muted);margin-bottom:4px}.vital-hp{color:var(--color-danger-vivid)}.vital-mp{color:var(--color-accent-arcane)}.party-section-title{text-align:center;color:var(--color-accent-warm);font-size:1.1em;margin:0 0 12px;letter-spacing:1px;text-transform:uppercase}.gender-option{display:flex;align-items:center;gap:6px;cursor:pointer;padding:4px 10px;border-radius:6px;border:1px solid var(--color-highlight-15);background:var(--color-highlight-05);transition:background .15s,border-color .15s;font-size:.9em}.gender-option:has(input:checked){border-color:var(--color-interactive);background:#3498db26}.gender-option input[type=radio]{accent-color:var(--color-interactive)}.gender-label{color:var(--color-text-light);user-select:none}.cs-header{display:flex;align-items:center;gap:16px;padding:16px 20px 12px;border-bottom:1px solid var(--color-highlight-10);flex-shrink:0}.cs-portrait-thumb-wrap{position:relative;cursor:pointer;width:90px;height:90px;border-radius:50%;overflow:hidden;border:3px solid var(--color-accent-warm);transition:border-color .2s}.cs-name{color:var(--color-accent-warm);font-size:1.4em;margin:0 0 6px}.cs-identity-meta{font-size:.9em;color:var(--color-text-muted);margin:0 0 6px}.cs-gender-badge{font-size:1.1em;color:var(--color-text-muted)}.cs-level-badge{background:#3498db33;border:1px solid var(--color-interactive);border-radius:8px;padding:2px 8px;font-size:.85em;color:var(--color-interactive-light)}.cs-sub-info{display:flex;gap:14px;font-size:.82em;color:var(--color-text-muted)}.cs-tabs{display:flex;border-bottom:2px solid var(--color-highlight-10);flex-shrink:0}.cs-tab{flex:1;padding:10px 8px;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--color-text-muted);cursor:pointer;font-size:.85em;transition:color .15s,border-bottom-color .15s;margin-bottom:-2px}.cs-tab:hover{color:var(--color-text-light)}.cs-tab.cs-tab-active{color:var(--color-accent-warm);border-bottom-color:var(--color-accent-warm);font-weight:600}.cs-section{background:#1e283799;border-radius:10px;padding:14px;margin-bottom:14px;border:1px solid var(--color-highlight-08)}.cs-section-title{color:var(--color-interactive-light);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-respec-points-label{font-size:.8em;color:var(--color-text-muted)}.cs-vital-item{display:flex;flex-direction:column;align-items:center;background:var(--color-highlight-05);border-radius:8px;padding:8px 6px;text-align:center;cursor:default}.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-vital-label{font-size:.7em;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}.cs-vital-val{font-size:.95em;font-weight:700;color:var(--color-text-light)}.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:var(--color-text-soft)}.cs-attr-val{font-weight:700;color:var(--color-accent-warm);font-size:1em;min-width:24px;text-align:right}.cs-adj-btn{background:#3498db33;border:1px solid var(--color-interactive);color:var(--color-interactive-light);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:var(--color-danger-vivid)!important;color:var(--color-danger-vivid)!important}.cs-equip-label{font-size:.75em;color:var(--color-text-muted);min-width:46px}.cs-equip-name{font-size:.88em;color:var(--color-accent-warm)}.cs-equip-name.empty{color:var(--color-border);font-style:italic}.cs-enc-label{font-size:.8em;color:var(--color-text-muted);display:block;margin-bottom:4px}.cs-enc-bar-wrap{height:6px;background:var(--color-highlight-10);border-radius:3px;overflow:hidden}.cs-enc-bar-fill{height:100%;background:linear-gradient(90deg,var(--color-green-alt),var(--color-accent-warm),var(--color-danger-vivid));border-radius:3px;transition:width .3s}.cs-skills-subhead{font-size:.85em;color:var(--color-text-soft);margin:0 0 8px;border-bottom:1px solid var(--color-highlight-10);padding-bottom:4px}.cs-skill-item{display:flex;align-items:flex-start;gap:8px;background:#ffffff0a;border-radius:6px;padding:6px 8px;cursor:default;flex-wrap:wrap}.cs-skill-name{font-size:.85em;color:var(--color-text-light)}.cs-skill-detail{display:block;flex-basis:100%;margin-left:24px;color:var(--color-text-muted);font-size:.78em;line-height:1.35}.cs-backstory-text{color:var(--color-text-soft);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 var(--color-highlight-10);flex-shrink:0;background:#141e2d80}.cs-profession-picker{padding:12px 20px;border-top:1px solid var(--color-highlight-08);background:#1e2837cc}.cs-profession-picker p{color:var(--color-text-muted);margin:0 0 8px;font-size:.85em}.cs-profession-btns .btn.active{border-color:var(--color-accent-warm);color:var(--color-accent-warm)}.cs-portrait-popup{position:fixed;inset:0;background:#000000d9;z-index:var(--z-overlay);display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.cs-portrait-popup-img{width:300px;height:400px;object-fit:cover;border-radius:12px;border:3px solid var(--color-accent-warm);box-shadow:0 8px 40px #000000b3}.cs-portrait-popup-name{color:var(--color-accent-warm);font-size:1.3em;font-weight:700;text-shadow:0 2px 8px rgba(0,0,0,.8)}.status-text p{margin:0;font-size:.8em;color:var(--color-text-muted)}.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 var(--color-highlight-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 var(--color-highlight-10);background:var(--color-bg-void)}.exploration-scene--has-npcs:after{content:"";position:absolute;inset:0;pointer-events:none;z-index:2;background:linear-gradient(to top,rgba(8,12,22,.82) 0%,rgba(8,12,22,.35) 28%,transparent 52%)}.exploration-movement-grid{display:flex;flex-direction:column;align-items:center;gap:6px;width:100%;max-width:220px;margin:0 auto}.exploration-movement-row{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;justify-content:center;gap:6px;width:100%}.exploration-scene .cell-picture{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;background:var(--color-bg-void);z-index:0}.exploration-scene .npc-scene-layer{position:absolute;inset:0;z-index:1;display:flex;flex-direction:row;flex-wrap:wrap;align-items:flex-end;justify-content:center;gap:clamp(6px,1.5vw,18px);padding:0 6% 5%;pointer-events:none;box-sizing:border-box}.exploration-scene .npc-scene-layer[hidden]{display:none!important}.exploration-scene .npc-scene-figure{pointer-events:none}.exploration-scene .npc-scene-figure--interactive{pointer-events:auto;cursor:pointer}.exploration-scene .npc-scene-talk-row{pointer-events:auto;width:100%;display:flex;flex-wrap:wrap;gap:6px;justify-content:center;padding:4px 6% 0;align-self:flex-end}.exploration-scene .npc-scene-talk-chip{pointer-events:auto}.exploration-scene-hotspots{position:absolute;inset:0;z-index:2;pointer-events:none}.exploration-scene-hotspots[hidden]{display:none!important}.exploration-scene-hotspot{position:absolute;pointer-events:auto;max-width:42%;padding:4px 10px;font-size:.72rem;line-height:1.2;border-radius:6px;border:1px solid var(--color-highlight-25);background:#0c1220d1;color:var(--color-text-primary,#e8e0d0);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-shadow:0 2px 8px #00000059}.exploration-scene-hotspot:hover:not(:disabled){border-color:var(--color-highlight-50);background:#141c30eb}.exploration-scene-hotspot:disabled{opacity:.45;cursor:not-allowed}.exploration-scene .npc-scene-img{max-height:min(74%,52vh);width:auto;max-width:100%;object-fit:contain;object-position:bottom center;display:block;filter:drop-shadow(0 4px 12px rgba(0,0,0,.45))}.player-npc-option-dialogue .player-npc-dialogue-visual{display:flex;justify-content:center;margin:.5rem 0}.player-npc-option-dialogue .player-npc-dialogue-art{max-height:min(48vh,380px);max-width:100%;object-fit:contain;border-radius:8px}.player-npc-option-dialogue .portrait-icon-placeholder{font-size:3rem;text-align:center;padding:1rem}.player-npc-option-dialogue .player-npc-actions{display:flex;flex-wrap:wrap;gap:.4rem}.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:var(--color-text-cool);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 var(--color-highlight-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-strip .enc-foe--defeated{opacity:.55;cursor:default;pointer-events:none}.enc-foe-strip .enc-foe--defeated:hover{border-color:#e76f5159}.enc-foe-strip .enc-foe--defeated .enc-foe-portrait,.enc-foe-strip .enc-foe--defeated .enc-foe-portrait img{pointer-events:auto;cursor:pointer}.enc-foe-meta{font-size:.72em;color:var(--color-text-quiet);display:flex;align-items:center;gap:4px}.enc-dot{opacity:.6}.enc-foe-chips{margin-top:2px}.status-pill-rail{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.status-pill{display:inline-flex;align-items:center;gap:2px;padding:1px 6px;border-radius:10px;font-size:.7rem;font-weight:600;white-space:nowrap;line-height:1.5;transition:opacity .15s ease}@media (prefers-reduced-motion:reduce){.status-pill{transition:none}}.status-pill-icon{font-size:.8rem}.status-pill-rounds{opacity:.85;font-variant-numeric:tabular-nums}.status-pill--buff{background:#4caf5040;color:#4caf50;border:1px solid rgba(76,175,80,.4)}.status-pill--debuff{background:#ff980040;color:#ff9800;border:1px solid rgba(255,152,0,.4)}.status-pill--Buff{background:#4caf5040;color:#4caf50;border:1px solid rgba(76,175,80,.4)}.status-pill--Debuff{background:#ff980040;color:#ff9800;border:1px solid rgba(255,152,0,.4)}.status-pill--DamageOverTime{background:#f4433640;color:#f44336;border:1px solid rgba(244,67,54,.4)}.status-pill--HealOverTime{background:#4caf5040;color:#66bb6a;border:1px solid rgba(76,175,80,.4)}.status-pill--Stun{background:#ffeb3b40;color:#fdd835;border:1px solid rgba(255,235,59,.4)}.status-pill--Paralyze{background:#2196f340;color:#42a5f5;border:1px solid rgba(33,150,243,.4)}.status-pill--Poison{background:#9c27b040;color:#ab47bc;border:1px solid rgba(156,39,176,.4)}.status-pill--Bleed{background:#c6282840;color:#ef5350;border:1px solid rgba(198,40,40,.4)}.enc-foe-portrait{cursor:pointer}.enc-gate-foe-strip{display:flex;flex-direction:row;flex-wrap:nowrap;gap:12px;overflow-x:auto;padding:10px 0;margin:0 0 12px;justify-content:center;scrollbar-width:thin}.enc-gate-foe-card{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:80px;max-width:100px;flex-shrink:0}.enc-gate-foe-img{width:72px;height:72px;border-radius:8px;object-fit:cover;border:1px solid rgba(231,111,81,.45);background:#0c122099}.enc-gate-foe-name{font-size:.78em;font-weight:600;color:var(--color-text-primary);text-align:center;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100px}.enc-gate-foe-level{font-size:.68em;color:var(--color-text-quiet);text-align:center}.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 var(--color-highlight-15);border-top-color:var(--color-accent-warm);animation:scene-spin .9s linear infinite}@keyframes scene-spin{to{transform:rotate(360deg)}}.cell-picture{border-radius:8px;transition:filter .22s ease-out,opacity .38s 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-info{background:var(--color-surface-panel-95);border:2px solid var(--border-color);border-radius:10px;padding:15px;margin-top:10px;box-shadow:0 4px 8px var(--color-overlay-30)}.location-info h3{color:var(--text-accent);margin:0 0 10px;font-size:1.3em;text-shadow:1px 1px 2px var(--color-overlay-50)}.location-info p{color:var(--text-secondary);margin:0;line-height:1.4;font-size:.95em}.exploration-center{position:relative}.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 var(--color-highlight-08);flex-shrink:0}.minimap-coords{font-family:monospace;font-size:.78em;color:var(--color-text-subdued);margin-bottom:4px;letter-spacing:.5px}#minimap-canvas{border:1px solid var(--color-highlight-15);border-radius:4px;image-rendering:pixelated}.interactive-map-open-btn{margin-top:6px;width:100%}.interactive-world-map-view{display:flex;flex-direction:column;gap:8px;padding:10px;height:100%;box-sizing:border-box;overflow:hidden;background:#080a12f2}.interactive-map-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:10px;padding:8px 10px;background:#141c2dd9;border-radius:8px;border:1px solid var(--color-highlight-08)}.interactive-map-toolbar-hint{font-size:.82em;color:var(--color-text-steel);max-width:min(720px,100%);line-height:1.35;flex:1 1 220px}.full-map-toolbar-toggles{display:flex;flex-wrap:wrap;gap:10px 14px;align-items:center}.full-map-toggle{font-size:.78rem;color:var(--color-border-soft);cursor:pointer;display:inline-flex;align-items:center;gap:6px;user-select:none}.full-map-toggle input{accent-color:#6b8cff}.full-map-hover-hint{flex:1 1 160px;min-height:1.2em;font-size:.78rem;color:#8ec8ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.full-map-body{display:grid;grid-template-columns:minmax(100px,130px) minmax(450px,1fr) minmax(140px,200px);gap:8px;align-items:stretch;flex:1 1 0;min-height:0}@media (max-width:900px){.full-map-body{grid-template-columns:1fr}.full-map-legend-col{order:2}.full-map-canvas-col{order:1}.full-map-detail-col{order:3}}.full-map-legend-col,.full-map-detail-col{background:#0c101cbf;border:1px solid var(--color-highlight-08);border-radius:8px;padding:8px 10px;overflow-y:auto;min-height:min(480px,60vh);font-size:.75rem}.full-map-legend-title{margin:0 0 4px;font-size:.85rem;color:#e8eef8}.full-map-legend-sub{margin:6px 0 3px;font-size:.7rem;color:var(--color-text-steel);text-transform:uppercase;letter-spacing:.04em}.full-map-legend-terrain{display:flex;flex-wrap:wrap;gap:3px 6px}.full-map-legend-swatch{display:inline-flex;align-items:center;gap:3px;font-size:.68rem;color:var(--color-border-soft)}.full-map-legend-swatch-color{width:10px;height:10px;border-radius:2px;border:1px solid rgba(0,0,0,.35)}.full-map-legend-markers{list-style:none;margin:0;padding:0;font-size:.68rem;color:var(--color-border-soft);line-height:1.35}.full-map-legend-markers li{margin:1px 0}.full-map-legend-m-ic{display:inline-block;width:1.2em;text-align:center}.full-map-legend-boundary{margin:4px 0 0;font-size:.65rem;color:#8a9bb8;line-height:1.25}.full-map-canvas-col{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:0}.full-map-viewport{flex:1 1 auto;width:100%;min-height:0;overflow:hidden;position:relative;background:#05060c8c;border-radius:8px;border:1px solid var(--color-highlight-08)}.full-map-stage{position:absolute;left:0;top:0;will-change:transform}.full-map-zoom-bar{display:flex;flex-wrap:wrap;align-items:center;gap:8px 10px;margin-top:4px;padding:4px 0}.full-map-zoom-label{font-size:.8rem;color:#9ec0ff;min-width:3.5em;font-variant-numeric:tabular-nums}.full-map-zoom-btn{min-width:2.25em}.full-map-detail-col-title{margin:0 0 8px;font-size:1rem;color:#e8eef8}.full-map-detail-dl{display:grid;grid-template-columns:auto 1fr;gap:4px 10px;margin:0 0 10px;font-size:.82rem;color:var(--color-border-soft)}.full-map-detail-dl dt{color:#8a9bb8;margin:0}.full-map-detail-dl dd{margin:0;word-break:break-word}.full-map-detail-sub{margin:10px 0 4px;font-size:.82rem;color:var(--color-text-steel)}.full-map-detail-features{margin:0;padding-left:1.1rem;font-size:.82rem;color:#dce6f8}.full-map-detail-snippet{margin:0 0 8px;font-size:.82rem;color:#b8c6dc;line-height:1.4;max-height:8em;overflow:auto}.full-map-detail-muted{margin:0;font-size:.82rem;color:#6b7a92}.full-map-detail-thumb-wrap{margin-top:8px;border-radius:6px;overflow:hidden;border:1px solid var(--color-highlight-10);max-width:100%}.full-map-detail-thumb{display:block;width:100%;height:auto;max-height:min(42vh,420px);object-fit:contain;image-rendering:auto}.full-map-detail-thumb--hq{image-rendering:auto;-webkit-backface-visibility:hidden;backface-visibility:hidden}.map-cell-tooltip{position:fixed;z-index:9999;pointer-events:none;background:#0a0e1af0;color:#d4dce8;border:1px solid rgba(100,130,200,.3);border-radius:6px;padding:6px 10px;font-size:.76rem;line-height:1.4;max-width:260px;box-shadow:0 4px 16px #00000073;opacity:0;transition:opacity .12s ease-out}.map-cell-tooltip[data-visible=true]{opacity:1}.map-tooltip-region{color:#8ec8ff}.map-tooltip-biome{color:#a8b8cc}.map-tooltip-lore{color:#b0a8c8;font-style:italic}.map-tooltip-boss{color:#e85050;font-weight:600}.interactive-map-canvas-wrap{flex:0 0 auto;display:block}.interactive-world-map-canvas{display:block;outline:none;border:1px solid var(--color-highlight-12);border-radius:6px;background:#05060c;image-rendering:auto}.interactive-world-map-canvas:focus-visible{box-shadow:0 0 0 2px #6b8cff,0 0 0 4px #080a12e6}.map-legend-compact{display:flex;flex-wrap:wrap;gap:12px;font-size:.85em;color:#b8c5d4;padding:6px 8px}.admin-interactive-map-wrap{border:1px solid var(--color-highlight-10);border-radius:8px;padding:6px;background:#0a0e1899}.location-actions-panel{display:flex;flex-direction:column;gap:6px;padding:8px;background:#0f142399;border-radius:8px;border:1px solid var(--color-highlight-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}.npc-roster{display:flex;flex-direction:column;gap:4px;margin-top:4px;padding-top:6px;border-top:1px solid var(--color-highlight-08)}.npc-roster-title{font-size:.72em;font-weight:700;color:var(--color-text-steel);text-transform:uppercase;letter-spacing:.05em}.npc-roster-entry{display:flex;flex-direction:column;gap:4px}.npc-roster-row{display:flex;flex-direction:row;align-items:center;gap:8px;width:100%;padding:4px;background:#192337b3;border:1px solid var(--color-highlight-06);border-radius:8px;cursor:pointer;color:var(--color-text-light);font:inherit;text-align:left;transition:background .12s,border-color .12s}.npc-roster-row:hover{background:#233046cc;border-color:var(--color-highlight-12)}.npc-roster-row:focus-visible{outline:2px solid rgba(120,170,250,.85);outline-offset:1px}.npc-roster-row--selected{background:#233046e6;border-color:var(--color-highlight-15)}.npc-roster-thumb{width:44px;height:44px;flex-shrink:0;border-radius:6px;border:1px solid var(--color-highlight-15);object-fit:cover;object-position:top;background:#0a0e1a}.npc-roster-thumb--placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-bg-deep),#1a252f);color:var(--color-text-soft);font-size:1.1em;font-weight:700}.npc-roster-name{flex:1;min-width:0;font-size:.82em;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.npc-roster-type{flex-shrink:0;font-size:.66em;color:var(--color-text-quiet);padding:2px 5px;background:#0000004d;border-radius:4px;border:1px solid var(--color-highlight-08)}.npc-roster-actions{display:flex;flex-direction:row;gap:4px;padding-left:4px}.npc-roster-actions[hidden]{display:none}.location-actions-panel .npc-roster-action-btn{width:auto;flex:1;padding:5px 8px;font-size:.8em}.exploration-npc-bar{position:absolute;left:0;right:0;bottom:0;z-index:3;margin:0;padding:8px 10px 10px;background:linear-gradient(to top,#080c16eb,#080c168c);border:none;border-radius:0 0 8px 8px;flex-shrink:0;pointer-events:auto;box-sizing:border-box}.exploration-npc-bar[hidden]{display:none!important}.exploration-npc-bar-inner{display:flex;flex-direction:column;gap:6px;min-width:0}.npc-bar-title{font-size:.72em;font-weight:700;color:var(--color-text-steel);text-transform:uppercase;letter-spacing:.05em;text-shadow:0 1px 2px rgba(0,0,0,.6)}.exploration-npc-bar-scroll{overflow-x:auto;overflow-y:hidden;max-width:100%;scrollbar-width:thin;padding-bottom:2px}.npc-bar-entries{display:flex;flex-direction:row;flex-wrap:nowrap;gap:8px;min-width:min-content}.npc-bar-entry{display:flex;flex-direction:column;gap:4px;flex-shrink:0;min-width:88px;max-width:148px}.npc-bar-chip{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 4px;background:#192337d9;border:1px solid var(--color-highlight-08);border-radius:8px;color:var(--color-text-light);font:inherit;text-align:center;width:100%}.npc-bar-thumb{width:48px;height:48px;flex-shrink:0;border-radius:6px;border:1px solid var(--color-highlight-15);object-fit:cover;object-position:top;background:#0a0e1a}.npc-bar-thumb--unknown,.npc-bar-thumb--placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#2a2a3e);color:var(--color-text-quiet);font-size:1.2em;font-weight:700}.npc-bar-thumb--unidentified{opacity:.72;filter:grayscale(.25)}.npc-bar-name{font-size:.72em;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;text-shadow:0 1px 2px rgba(0,0,0,.5)}.npc-bar-type{font-size:.62em;color:var(--color-text-quiet);padding:1px 4px;background:#00000059;border-radius:4px}.npc-bar-actions{display:flex;flex-direction:row;flex-wrap:wrap;gap:3px;width:100%;justify-content:center}.npc-bar-action-btn{width:auto;flex:1 1 auto;min-width:0;padding:4px 5px;font-size:.68em;margin:0}.npc-bar-action-btn--identify{flex:1 1 100%}.exp-member{display:flex;flex-direction:column;align-items:stretch;gap:6px;padding:8px;background:#192337b3;border-radius:8px;border:1px solid var(--color-highlight-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 var(--color-highlight-15)}.exp-portrait img{width:100%;height:100%;object-fit:cover}.exp-portrait .noend-defeated-skull{width:100%;height:100%;min-height:0;cursor:pointer}.exp-portrait-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-bg-deep),#1a252f);color:var(--color-text-soft);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-row{display:flex;flex-direction:row;align-items:center;gap:6px;width:100%;min-width:0}.exp-level-chip{flex-shrink:0;font-size:.62em;font-weight:800;line-height:1;padding:2px 6px;border-radius:6px;background:linear-gradient(135deg,#5d4a0a,#b7950b);color:#fdf6e3;border:1px solid rgba(255,255,255,.22);letter-spacing:.02em}.exp-name{flex:1;min-width:0;font-size:.82em;font-weight:700;color:var(--color-text-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left;line-height:1.2}.exp-pending-level-badge{flex-shrink:0;font-size:.62em;font-weight:800;line-height:1;padding:2px 6px;border-radius:999px;background:linear-gradient(135deg,var(--color-accent-violet),var(--color-accent-arcane));color:#fdfefe;border:1px solid var(--color-highlight-20);box-shadow:0 0 0 1px #00000040;cursor:pointer}.exp-pending-level-badge:focus{outline:2px solid rgba(183,148,244,.9);outline-offset:1px}.exp-pending-level-up-badge{flex-shrink:0;font-size:.7em;font-weight:800;line-height:1;padding:2px 7px;border-radius:8px;background:linear-gradient(135deg,#b8860b,var(--color-accent-gold-light));color:#1a1a1a;border:1px solid rgba(255,255,255,.35);box-shadow:0 0 0 1px #0003;cursor:pointer;font-family:inherit}.exp-pending-level-up-badge:hover{filter:brightness(1.08)}.exp-pending-level-up-badge:focus{outline:2px solid rgba(244,208,63,.95);outline-offset:1px}.exp-pending-level-up-badge{border:none;margin:0 4px 0 0;padding:2px 7px}.exp-pending-level-up-badge--pulse{animation:exp-up-pulse 1.8s ease-in-out infinite}@keyframes exp-up-pulse{0%,to{box-shadow:0 0 4px #ffd7004d}50%{box-shadow:0 0 12px #ffd700b3,0 0 24px #ffd70040}}.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 var(--color-highlight-06)}.exp-bar-fill-h{height:100%;min-width:0;border-radius:3px;transition:width .3s ease}.hp-fill{background:linear-gradient(90deg,var(--color-danger-deep),var(--color-danger-vivid))}.sta-fill{background:linear-gradient(90deg,#d4ac0d,var(--color-accent-gold))}.mp-fill{background:linear-gradient(90deg,#2471a3,var(--color-interactive))}.exp-badges{display:flex;align-items:center;justify-content:center;gap:4px;flex-wrap:wrap;padding-top:2px;border-top:1px solid var(--color-highlight-06)}.exp-xp-row{display:flex;align-items:center;gap:6px;width:100%;margin-top:2px}.exp-xp-label{font-size:.68em;color:var(--color-accent-rank-gold);flex-shrink:0;width:22px;text-align:center}.exp-xp-track-wrap{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.exp-xp-text{font-size:.62em;color:var(--color-text-quiet);text-align:right;line-height:1}.exp-xp-track{height:6px}.exp-xp-fill{background:linear-gradient(90deg,#7d6608,var(--color-accent-gold-light))}.exp-badge,.exp-slot{font-size:.85em;padding:2px 4px;background:#0000004d;border-radius:4px;border:1px solid var(--color-highlight-08);cursor:default}.exp-sep{color:#5a6a7a;font-size:.75em;padding:0 2px;user-select:none}.exp-actions{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;gap:4px;width:100%;padding-top:4px;border-top:1px solid var(--color-highlight-06)}.exp-actions[hidden]{display:none}.exp-action-btn{flex-shrink:0;width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;font-size:.85em;line-height:1;padding:0;background:#00000059;color:var(--color-text-light);border:1px solid var(--color-highlight-12);border-radius:5px;cursor:pointer;transition:background .12s,border-color .12s,transform .08s}.exp-action-btn:hover:not(:disabled){background:#3c5a8c8c;border-color:#ffffff47}.exp-action-btn:active:not(:disabled){transform:scale(.94)}.exp-action-btn:focus-visible{outline:2px solid rgba(120,170,250,.85);outline-offset:1px}.exp-action-btn:disabled{opacity:.4;cursor:not-allowed;filter:grayscale(.6)}.exp-action-btn[hidden]{display: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;align-items:center}.goldenpath-quest-hint{font-size:.85em;padding:6px 10px;margin:4px 0;border-radius:6px;background:#78b4ff1f;border:1px solid rgba(120,180,255,.35);color:var(--muted,#bcd);display:flex;align-items:center;gap:6px}.goldenpath-quest-hint[hidden]{display:none}.objective-hint__icon{font-size:1.1em;flex-shrink:0}.objective-hint__text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.objective-hint__dismiss{all:unset;cursor:pointer;font-size:1.1em;line-height:1;padding:0 4px;opacity:.6;transition:opacity .15s}.objective-hint__dismiss:hover,.objective-hint__dismiss:focus-visible{opacity:1}.objective-hint__dismiss:focus-visible{outline:2px solid rgba(120,170,250,.85);outline-offset:1px;border-radius:3px}@media (prefers-reduced-motion:reduce){.goldenpath-quest-hint,.objective-hint__dismiss{transition:none}}.ctx-grid,.ctx-terrain,.ctx-feature{padding:2px 8px;border-radius:4px;cursor:default;font-size:.92em}button.ctx-lore-chip{margin:0;font:inherit;text-align:left}.ctx-lore-chip{padding:2px 8px;border-radius:4px;font-size:.92em;border:1px solid transparent;background:transparent;cursor:pointer;transition:background .12s,border-color .12s}.ctx-lore-chip:focus-visible{outline:2px solid rgba(120,170,250,.85);outline-offset:2px}.ctx-lore-chip:hover{filter:brightness(1.08)}.ctx-grid{background:#5dade21f;border:1px solid rgba(93,173,226,.28);color:#aed6f1}.ctx-terrain{background:#ecf0f114;border:1px solid var(--color-highlight-12);color:var(--color-text-soft)}.ctx-feature{background:#9b59b61f;border:1px solid rgba(155,89,182,.25);color:#d7bde2}.ctx-sep{color:#ffffff59;user-select:none}.ctx-kingdom,.ctx-region{padding:2px 8px;background:#f39c121f;border:1px solid rgba(243,156,18,.25);border-radius:4px;color:#f0c040;cursor:pointer}.ctx-region{background:#2ecc711a;border-color:#2ecc7133;color:#7dcea0}.direction-desc{font-style:italic;color:var(--color-text-muted);font-size:.88em;line-height:1.5;max-height:80px;overflow-y:auto}.exploration-picture-source-hint{font-size:.82em;color:var(--color-text-muted);margin:0 0 6px;font-style:italic}.game-dialog-lore-readout .game-dialog-lore-body{padding-top:4px}.game-dialog-lore-scroll{max-height:min(60vh,520px);overflow-y:auto;white-space:pre-wrap;word-break:break-word;color:var(--color-text-primary);font-size:.95rem;line-height:1.45;padding:4px 2px 8px}.location-description-lore{cursor:pointer;text-decoration:underline dotted rgba(255,255,255,.35);text-underline-offset:3px}.location-description-lore:hover{color:#e8f4ff}.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 var(--color-highlight-20);border-radius:10px;background:linear-gradient(180deg,#283c5ae6,#192841f2);color:#e0e8f0;cursor:pointer;box-shadow:0 2px 6px #0000004d,inset 0 1px 0 var(--color-highlight-08);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:var(--z-overlay);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:var(--color-bg-deepest);border:1px solid var(--color-highlight-12);border-radius:12px;color:var(--color-text-cool);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,var(--color-bg-deepest) 0%,var(--color-bg-deepest) 70%,rgba(18,26,40,.92) 100%)}.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 var(--color-highlight-15);background:#00000040;color:var(--color-text-cool);font-size:24px;line-height:1;cursor:pointer;padding:0;flex-shrink:0}.encounter-foe-dialog-close:hover{background:var(--color-highlight-12);border-color:#ffffff47}.encounter-foe-dialog-close:focus-visible{outline:2px solid var(--color-accent-warm);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:var(--color-text-quiet);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 var(--color-highlight-08);border-radius:8px;padding:6px 8px;display:flex;flex-direction:column;gap:2px}.enc-foe-vital-label{font-size:.68em;color:var(--color-text-subdued);text-transform:uppercase;letter-spacing:.03em}.enc-foe-vital-val{font-size:.95em;font-weight:700;color:var(--color-accent-warm)}.enc-foe-muted{color:var(--color-text-subdued);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 var(--color-highlight-08);padding:2px 0}.enc-foe-backstory{white-space:pre-wrap;line-height:1.45;font-size:.9em}.enc-picture-zoom-backdrop{position:fixed;inset:0;z-index:var(--z-max);background:#000000b8;display:flex;align-items:center;justify-content:center;padding:16px}.enc-picture-zoom-dialog{max-width:min(920px,98vw);max-height:92vh;display:flex;flex-direction:column;background:#0e1420;border:1px solid rgba(255,255,255,.14);border-radius:12px;box-shadow:0 16px 48px #0009;overflow:hidden}.enc-picture-zoom-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-bottom:1px solid var(--color-highlight-10);flex-shrink:0}.enc-picture-zoom-title{margin:0;font-size:1.1em;color:var(--color-accent-gold-light);font-weight:700}.enc-picture-zoom-close{width:40px;height:40px;border-radius:8px;border:1px solid var(--color-highlight-15);background:#0000004d;color:var(--color-text-cool);font-size:22px;line-height:1;cursor:pointer;flex-shrink:0}.enc-picture-zoom-close:hover{background:var(--color-highlight-10)}.enc-picture-zoom-body{padding:12px;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,#28375080,#0a0e16 70%)}.enc-picture-zoom-img{max-width:100%;max-height:min(78vh,860px);width:auto;height:auto;object-fit:contain;border-radius:8px;border:1px solid var(--color-highlight-10)}.cs-xp-row{margin-top:8px;padding-top:8px;border-top:1px solid var(--color-highlight-08);width:100%}.cs-xp-row .cs-xp-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px}.cs-xp-row .cs-xp-label{font-size:.78em;color:var(--color-accent-rank-gold);font-weight:600}.cs-xp-row .cs-xp-fraction{font-size:.75em;color:var(--color-text-quiet)}.cs-xp-bar-track{height:8px;background:#00000059;border-radius:4px;overflow:hidden;border:1px solid var(--color-highlight-08)}.cs-xp-bar-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#7d6608,var(--color-accent-gold-light));transition:width .25s ease}.cs-level-hint{margin-top:8px;font-size:.72em;line-height:1.35;color:var(--color-text-subdued)}.level-up-applied-callout{margin-top:14px;padding:10px 12px;border-radius:10px;border:1px solid rgba(46,204,113,.35);background:#2ecc7114}.level-up-applied-title{margin:0 0 4px;font-size:.95em;font-weight:700;color:#58d68d}.level-up-applied-body,.level-up-applied-badge-hint{margin:0 0 6px;font-size:.85em;line-height:1.45;color:#c8d6e0}.level-up-applied-badge-hint:last-child{margin-bottom:0;color:var(--color-text-quiet);font-size:.8em}.victory-dialog-backdrop,.defeat-dialog-backdrop,.combat-item-picker-backdrop,.combat-history-backdrop,.journal-backdrop{position:fixed;inset:0;z-index:var(--z-max);background:#000000a6;display:flex;align-items:center;justify-content:center;padding:16px}.victory-dialog,.defeat-dialog,.combat-item-picker,.combat-history-dialog,.journal-dialog{max-width:min(560px,96vw);max-height:90vh;overflow:auto;background:var(--color-bg-deepest);border:1px solid var(--color-highlight-12);border-radius:14px;padding:22px 24px;color:var(--color-text-cool);box-shadow:0 16px 48px #0000008c}.victory-title{font-family:var(--font-heading, Cinzel, serif);font-size:var(--font-size-3xl, 2.25rem);margin:0 0 6px;color:var(--color-accent-gold-light);text-align:center}.victory-sub{text-align:center;color:var(--color-text-quiet);margin:0 0 16px}.victory-h2,.defeat-h2{font-family:var(--font-heading, Cinzel, serif);font-size:var(--font-size-base, 1rem);margin:12px 0 8px;color:var(--color-text-soft)}.victory-xp-row,.defeat-member-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:6px 0;border-bottom:1px solid var(--color-highlight-06)}.victory-level-chip,.defeat-level-chip{font-size:.72em;padding:2px 8px;border-radius:999px;background:#2ecc7133;color:var(--color-success-vivid)}.defeat-level-chip{background:#e74c3c33;color:var(--color-danger-vivid)}.victory-loot-row{display:grid;grid-template-columns:1fr auto 140px;gap:10px;align-items:center;padding:8px 0;border-bottom:1px solid var(--color-highlight-06)}.victory-loot-select{background:#0d1118;color:var(--color-text-cool);border:1px solid var(--color-highlight-15);border-radius:8px;padding:6px 8px}.victory-gold{color:var(--color-accent-gold);margin:0 0 10px}.victory-muted,.defeat-muted{color:var(--color-text-subdued)}.victory-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;margin-top:18px}.victory-btn{border-radius:10px;padding:10px 18px;font-weight:600;cursor:pointer;border:1px solid var(--color-highlight-20)}.victory-btn-primary{background:var(--color-green-alt);color:#fff}.victory-btn-secondary{background:transparent;color:var(--color-text-cool)}.defeat-title{font-family:var(--font-heading, Cinzel, serif);font-size:var(--font-size-3xl, 2.25rem);margin:0 0 8px;color:var(--color-danger-vivid);text-align:center}.defeat-lead{text-align:center;color:var(--color-text-quiet)}.defeat-gold{color:var(--color-accent-tangerine)}.defeat-items{list-style:disc;padding-left:1.2em;margin:8px 0}.defeat-from{color:var(--color-text-subdued);font-size:.9em}.defeat-revive{font-size:.9em;color:var(--color-text-soft);margin:14px 0}.defeat-btn{width:100%;margin-top:8px;padding:12px;border-radius:10px;background:var(--color-danger-deep);color:#fff;font-weight:700;border:none;cursor:pointer}.combat-item-picker h2{margin-top:0}.combat-item-row{display:flex;width:100%;align-items:center;gap:10px;padding:10px;margin:6px 0;background:#ffffff0a;border:1px solid var(--color-highlight-08);border-radius:8px;color:inherit;cursor:pointer;font-family:inherit;text-align:left;border-width:1px}.combat-item-row:hover{background:#2ecc711a;border-color:#2ecc7147}.cip-qty-badge{display:inline-block;margin-left:6px;padding:1px 6px;border-radius:4px;font-size:.8em;font-weight:700;background:#2ecc712e;color:var(--color-accent-gold-light);vertical-align:middle}.combat-item-picker.csp-with-detail{max-width:min(880px,96vw)}.combat-item-picker--rich{overflow:hidden;display:flex;flex-direction:column;max-height:90vh}.combat-item-picker--rich .csp-body-split{flex:1;min-height:0}.cip-row-outer{display:flex;gap:6px;align-items:stretch;margin-bottom:6px}.cip-row-outer .combat-item-row{flex:1;margin:0}.combat-item-cancel{margin-top:12px;width:100%;padding:10px;border-radius:8px;background:transparent;border:1px solid var(--color-highlight-20);color:var(--color-text-cool);cursor:pointer;font-family:inherit}.combat-item-cancel:hover{border-color:#2ecc7159}.ch-title{font-family:var(--font-heading, Cinzel, serif);margin:0 0 6px}.ch-list{max-height:55vh;overflow:auto}.combat-history-row{margin:8px 0;border:1px solid var(--color-highlight-08);border-radius:8px;padding:4px 8px;background:#0003}.ch-outcome{font-weight:700;margin-right:8px}.ch-outcome--victory{color:var(--color-success-vivid)}.ch-outcome--defeat{color:var(--color-danger-vivid)}.ch-outcome--flee{color:var(--color-accent-warm)}.ch-log{font-size:.85em;padding:8px;max-height:240px;overflow:auto;background:#00000040;border-radius:6px;margin-top:6px}.ch-log-line{padding:2px 0;border-bottom:1px dashed var(--color-highlight-05)}.ch-close{margin-top:14px;width:100%;padding:10px;border-radius:8px;cursor:pointer}.journal-title-h{font-family:var(--font-heading, Cinzel, serif);margin:0 0 6px}.journal-sub{color:var(--color-text-quiet);margin:0 0 12px;font-size:.9em}.journal-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.journal-filter-chip{padding:6px 12px;border-radius:999px;border:1px solid var(--color-highlight-15);background:#00000040;color:var(--color-text-cool);cursor:pointer;font-size:.85em}.journal-filter-chip--active{background:#f1c40f33;border-color:#f1c40f73;color:var(--color-accent-gold-light)}.journal-scroll{max-height:52vh;overflow:auto}.journal-list-host{min-height:40px}.journal-row{margin:8px 0;border:1px solid var(--color-highlight-08);border-radius:8px;padding:4px 8px;background:#0003}.journal-cat{font-size:.72em;text-transform:uppercase;letter-spacing:.04em;margin-right:8px;padding:2px 6px;border-radius:4px;background:var(--color-highlight-08)}.journal-cat--combat{color:var(--color-accent-tangerine)}.journal-cat--world{color:var(--color-interactive-light)}.journal-cat--system{color:var(--color-text-soft)}.journal-cat--dialogue{color:#bb8fce}.journal-title{font-weight:600;margin-right:8px}.journal-when{font-size:.78em;color:var(--color-text-subdued)}.journal-body{font-size:.85em;padding:8px;max-height:220px;overflow:auto;background:#00000040;border-radius:6px;margin-top:6px}.journal-body-line{padding:2px 0;border-bottom:1px dashed var(--color-highlight-05)}.journal-empty{color:var(--color-text-subdued);margin:12px 0}.journal-close{margin-top:14px;width:100%;padding:10px;border-radius:8px;cursor:pointer}.cs-inv-use-btn{margin-left:6px;padding:2px 8px;font-size:.75rem;border-radius:6px;background:var(--color-secondary);color:#fff;border:none;cursor:pointer}.cs-inv-use-btn:hover{background:#3182ce}.ui-tooltip{position:absolute;z-index:var(--z-tooltip,1070);padding:6px 12px;border-radius:6px;background:#0f172af2;color:var(--color-text-secondary);font-size:.82rem;line-height:1.4;pointer-events:none;opacity:0;transition:opacity .15s ease-in-out;box-shadow:0 4px 12px #0006;border:1px solid var(--color-highlight-10)}.ui-tooltip--visible{opacity:1}@media (prefers-reduced-motion:reduce){.ui-tooltip{transition:none}}.ui-card{background:var(--color-surface-card,#1e2235);border:1px solid var(--color-border-subtle,rgba(255,255,255,.08));border-radius:10px;overflow:hidden;transition:box-shadow .2s,border-color .2s}.ui-card--clickable{cursor:pointer}.ui-card--clickable:hover{border-color:var(--color-border-default,rgba(255,255,255,.15));box-shadow:0 4px 16px #00000059}.ui-card--clickable:focus-visible{outline:2px solid var(--color-accent-primary,#e94560);outline-offset:2px}.ui-card__header{display:flex;align-items:center;gap:6px;padding:10px 14px;font-weight:600;font-size:.95rem;color:var(--color-text-primary,#e0e0e0);border-bottom:1px solid var(--color-border-subtle,rgba(255,255,255,.08))}.ui-card__icon{font-size:1.1em;line-height:1}.ui-card__body{padding:12px 14px;color:var(--color-text-secondary,#b0b0b0);font-size:.88rem;line-height:1.5}.ui-card__footer{padding:8px 14px;border-top:1px solid var(--color-border-subtle,rgba(255,255,255,.08));font-size:.82rem;color:var(--color-text-muted,#888)}.ui-card--danger{border-color:var(--color-accent-danger,#e94560)}.ui-card--success{border-color:var(--color-accent-success,#4caf50)}.ui-card--accent{border-color:var(--color-accent-primary,#e94560)}.ui-card--compact .ui-card__header{padding:6px 10px;font-size:.85rem}.ui-card--compact .ui-card__body{padding:8px 10px;font-size:.82rem}.ui-card--compact .ui-card__footer{padding:4px 10px;font-size:.75rem}@media (prefers-reduced-motion:reduce){.ui-card{transition:none}}@media (prefers-reduced-motion: reduce){.spell-effect{animation:none!important;opacity:1}.spell-animation-container{animation:none!important}.menu-overlay,.main-menu-overlay,.combat-overlay,.tutorial-overlay,.portrait-gallery-overlay,.cs-portrait-popup,.encounter-foe-dialog-backdrop,.enc-picture-zoom-backdrop,.victory-dialog-backdrop,.defeat-dialog-backdrop,.combat-item-picker-backdrop,.combat-history-backdrop,.journal-backdrop,.combat-spell-picker-backdrop{animation:none!important;transition:none!important}.skill-tree-panel,.character-card,.character-creation-step,.save-load-message,.tutorial-content,.scene-spinner-ring{animation:none!important}.character-card:before,.combat-overlay:before{animation:none!important}.cs-portrait-popup,.cs-portrait-popup-inner{animation:none!important;opacity:1}.cs-party-card,.party-char-card,.enc-foe-portrait,.btn{transition:none!important}}.immersive-service-panel{display:grid;grid-template-columns:minmax(220px,38%) 1fr;gap:0;max-width:min(960px,96vw);max-height:min(90vh,900px);overflow:hidden;padding:0}.immersive-service-hero{position:relative;min-height:280px;overflow:hidden;background:var(--color-bg-void)}.immersive-service-hero-img{width:100%;height:100%;min-height:280px;object-fit:cover;display:block}.immersive-service-body{display:flex;flex-direction:column;min-height:0;overflow:hidden;padding:1rem 1.25rem 1.25rem}.immersive-service-body .subscription-header{margin-bottom:.75rem}.inn-rest-visual{margin:0 0 .75rem;border-radius:8px;overflow:hidden;border:1px solid var(--color-highlight-10)}.inn-rest-scene-img{width:100%;max-height:min(28vh,220px);object-fit:cover;display:block}.shop-panel .shop-content,.inn-panel .inn-content,.crafting-panel .crafting-content,.dialogue-panel .dialogue-content{flex:1}@media (max-width:720px){.immersive-service-panel{grid-template-columns:1fr;max-height:95vh}.immersive-service-hero,.immersive-service-hero-img{min-height:160px;max-height:28vh}}.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}.character-sheet-readonly .cs-readonly-pending-banner{flex-shrink:0;padding:12px 20px;background:#f39c121f;border-bottom:1px solid rgba(243,156,18,.35)}.character-sheet-readonly .cs-readonly-pending-title{margin:0 0 8px;font-size:.95em;color:#f39c12}.character-sheet-readonly .cs-readonly-pending-btn{margin-top:8px;margin-right:8px}.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{position:relative;display:flex;align-items:flex-start;gap:8px;background:#ffffff0a;border-radius:6px;padding:6px 8px;cursor:default;flex-wrap:wrap}.cs-skill-item:focus{outline:2px solid rgba(243,156,18,.65);outline-offset:2px}.cs-skill-icon{font-size:1.1em;flex-shrink:0}.cs-skill-name{font-size:.85em;color:#e8e8e8}.cs-skill-meta{font-size:.76em;color:#a0aec0;margin-left:auto;text-align:right}.cs-hover-detail{display:none;flex-basis:100%;margin-left:24px;color:#d7e7ff;font-size:.78em;line-height:1.35;background:#080d1ad1;border:1px solid rgba(118,168,255,.28);border-radius:6px;padding:7px 8px;box-shadow:0 8px 22px #00000047}.cs-skill-item:hover .cs-hover-detail,.cs-skill-item:focus-within .cs-hover-detail,.cs-spell-row:hover .cs-hover-detail,.cs-spell-row:focus-within .cs-hover-detail{display:block}.cs-sp-skill-name{position:relative;min-width:120px;font-weight:600}.cs-sp-skill-name:focus{outline:2px solid rgba(243,156,18,.65);outline-offset:2px;border-radius:4px}.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-eqbonus-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.cs-eqbonus-pill{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;font-size:.82em;font-weight:600;white-space:nowrap;background:#ffffff0f;border:1px solid rgba(255,255,255,.12)}.cs-eqbonus-atk{color:#e67e22;border-color:#e67e2259}.cs-eqbonus-def{color:#3498db;border-color:#3498db59}.cs-eqbonus-spd{color:#f1c40f;border-color:#f1c40f59}.cs-eqbonus-sp{color:#9b59b6;border-color:#9b59b659}.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;flex-wrap:wrap}.cs-spell-row:hover{background:#ffffff14;border-color:#9b59b666}.cs-spell-row:focus{outline:2px solid rgba(155,89,182,.65);outline-offset:2px}.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-low-level{opacity:.72}.cs-spell-low-level .cs-spell-meta{color:#f59e0b}.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:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:8px 10px 10px;height:calc(100vh - 160px);overflow:hidden}.party-sheets-row::-webkit-scrollbar{display:none}.party-sheets-empty{color:#a0aec0;font-style:italic;padding:24px}.party-sheet-card{background:#1e2837eb;border:1px solid rgba(255,255,255,.08);border-radius:10px;display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden}@media (max-width:1200px){.party-sheets-row{grid-template-columns:repeat(2,1fr);height:auto;max-height:calc(100vh - 140px);overflow-y:auto}.party-sheet-card{max-height:calc(50vh - 80px)}}@media (max-width:640px){.party-sheets-row{grid-template-columns:1fr;height:auto;max-height:calc(100vh - 140px);overflow-y:auto}.party-sheet-card{max-height:calc(70vh - 80px)}}.party-sheet-header{display:flex;gap:8px;align-items:center;padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.08);background:#141e2d8c;flex-shrink:0;min-width:0}.party-sheet-header .cs-portrait-thumb-wrap{position:relative;width:44px;height:44px;border:0;overflow:visible;cursor:pointer;border-radius:50%;transition:transform .15s;flex-shrink:0}.party-sheet-header .cs-portrait-thumb-wrap:hover{transform:scale(1.05)}.party-sheet-header .cs-portrait-thumb{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid #f39c12;display:block}.party-sheet-header .cs-portrait-zoom-hint{width:16px;height:16px;font-size:.6em;bottom:-2px;right:-2px;border:1px solid rgba(255,255,255,.25)}.party-sheet-header .cs-identity-col{min-width:0}.party-sheet-header .cs-name{font-size:.92em;margin:0 0 2px;color:#f39c12;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.party-sheet-header .cs-badges{display:flex;gap:3px;font-size:.9em;flex-wrap:wrap}.party-sheet-header .cs-badge{padding:1px 4px;font-size:.85em}.party-sheet-header .cs-identity-meta{font-size:.78em}.party-sheet-header .cs-sub-info{font-size:.75em;gap:8px}.party-sheet-tabs{display:flex;gap:2px;padding:4px 6px;border-bottom:1px solid rgba(255,255,255,.08);background:#141e2d4d;flex-shrink:0}.party-sheet-tabs .cs-tab{flex:1;font-size:.68em;padding:4px 2px;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;overflow:hidden;text-overflow:ellipsis}.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;padding:10px}.party-sheet-panel .cs-section-title{font-size:.82em;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}.party-sheet-panel .cs-equipped-slots{grid-template-columns:repeat(2,1fr);gap:4px}.party-sheet-panel .cs-equipped-slot{min-height:52px;padding:4px 3px;font-size:.68em}.party-sheet-panel .cs-equipped-icon{font-size:1.1em}.party-sheet-panel .cs-inv-item{padding:4px 6px;font-size:.8em;gap:5px}.party-sheet-panel .cs-inv-name{font-size:.92em;min-width:0}.party-sheet-panel .cs-inv-meta{font-size:.72em}.party-sheet-panel .cs-inv-use-btn{padding:1px 6px;font-size:.7em;flex-shrink:0;white-space:nowrap}.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;display:grid;grid-template-columns:1fr 1fr;gap:3px}.party-sheet-panel .cs-bag-grid{grid-template-columns:1fr}.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;align-items:center}.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}.party-search-input{margin-left:auto;width:200px;padding:5px 10px 5px 30px;border-radius:6px;border:1px solid rgba(255,255,255,.15);background:#141c2ae6 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='%23a0aec0' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.868-3.834zm-5.242.156a5 5 0 1 1 0-10 5 5 0 0 1 0 10z'/%3E%3C/svg%3E") no-repeat 8px center;color:#e8e8e8;font-size:.82em;font-family:inherit;transition:border-color .15s}.party-search-input::placeholder{color:#6c7a89}.party-search-input:focus{outline:none;border-color:#f39c1280}.cs-sp-row{display:flex;flex-direction:column;gap:8px;margin:10px 0;padding:10px 12px;border-radius:10px;background:#00000038;border:1px solid rgba(255,255,255,.06)}.cs-sp-row-top{display:flex;align-items:flex-start;gap:10px}.cs-sp-name-block{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.cs-sp-row .cs-sp-skill-name{font-size:.88em;font-weight:600;color:#e8e8e8;line-height:1.25}.cs-sp-skill-train-meta{font-size:.74em;color:#a0aec0;line-height:1.35}.cs-sp-info-btn{flex-shrink:0;width:28px;height:28px;padding:0;margin:0;border-radius:50%;border:1px solid rgba(118,168,255,.45);background:#142337d9;color:#5dade2;cursor:pointer;font-size:0;line-height:1;display:inline-flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.cs-sp-info-btn:hover{background:#3498db40;border-color:#5dade2}.cs-sp-info-glyph{font-size:14px;line-height:1;font-style:italic;font-weight:700}.cs-sp-detail-panel{width:100%;box-sizing:border-box;margin:0;color:#d7e7ff;font-size:.78em;line-height:1.45;padding:8px 10px;border-radius:8px;background:#080d1ad1;border:1px solid rgba(118,168,255,.24)}.cs-sp-row-actions{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:2px}.cs-sp-amount-input{width:80px;min-width:72px;padding:6px 10px;border-radius:8px;background:#141c2aeb;border:1px solid rgba(243,156,18,.35);color:#f0f4ff;font-size:.9em}.cs-sp-amount-input:focus{outline:2px solid rgba(243,156,18,.45);outline-offset:1px}.cs-sp-apply-btn{background:#f39c122e!important;border:1px solid rgba(243,156,18,.55)!important;color:#f39c12!important}.cs-sp-apply-btn:hover{background:#f39c1252!important;color:#fff!important}.cs-skill-item--with-actions{display:flex;align-items:center;flex-wrap:nowrap;gap:8px}.cs-skill-item--with-actions .cs-skill-name{flex:1;min-width:0}.cs-skill-compact-line{flex:1;min-width:0;font-size:.86em;color:#e8e8e8;font-weight:600;line-height:1.3;text-align:left}.cs-skill-info-btn{flex-shrink:0;width:26px;height:26px;padding:0;margin:0;border-radius:50%;border:1px solid rgba(118,168,255,.45);background:#142337d9;color:#5dade2;cursor:pointer;font-size:0;line-height:1;display:inline-flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.cs-skill-info-btn:hover{background:#3498db40;border-color:#5dade2}.cs-skill-info-glyph{font-size:13px;line-height:1;font-style:italic;font-weight:700}.cs-skill-overlay-root{position:fixed;z-index:9500;pointer-events:auto;box-sizing:border-box}.cs-skill-overlay--full{width:100%!important;height:100%!important;inset:0!important}.cs-skill-overlay-scrim{position:absolute;inset:0;background:#0000006b;cursor:pointer}.cs-skill-overlay-card{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(92%,400px);max-height:min(70vh,420px);display:flex;flex-direction:column;gap:12px;padding:14px 16px;background:#141e30f5;border:1px solid rgba(118,168,255,.35);border-radius:10px;box-shadow:0 12px 40px #00000080}.cs-skill-overlay-body{margin:0;color:#d7e7ff;font-size:.86em;line-height:1.5;white-space:pre-wrap;overflow-y:auto;flex:1;min-height:0}.cs-skill-overlay-close{align-self:flex-end}.combat-stage{position:relative;display:flex;flex-direction:column;gap:0;background:radial-gradient(ellipse at 50% 0%,rgba(139,92,246,.06) 0%,transparent 50%),linear-gradient(180deg,var(--color-bg-void) 0%,#1a1028 40%,#1a0a14 100%);border:1px solid rgba(139,92,246,.25);border-radius:var(--radius-lg);overflow:hidden;box-shadow:inset 0 0 80px var(--color-overlay-50),inset 0 -40px 60px var(--color-overlay-30),0 4px 32px #000000d9}.combat-enemy-zone{display:flex;justify-content:center;align-items:flex-end;gap:var(--space-md);padding:var(--space-lg) var(--space-md) var(--space-sm);min-height:120px;background:radial-gradient(ellipse at 50% 90%,rgba(139,92,246,.1) 0%,transparent 55%),radial-gradient(ellipse at 50% 20%,rgba(220,38,38,.04) 0%,transparent 50%)}.combat-enemy-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-xs);border-radius:var(--radius-md);background:#0f0a1973;border:1px solid rgba(139,92,246,.12);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.combat-enemy-card:hover{transform:translateY(-3px);box-shadow:0 4px 16px #8b5cf626}.combat-enemy-card--defeated{opacity:.3;filter:grayscale(.8)}.combat-enemy-portrait{width:64px;height:64px;border-radius:var(--radius-md);border:2px solid rgba(220,53,69,.55);object-fit:cover;background:var(--color-bg-primary);box-shadow:0 0 10px #dc354540,0 2px 8px var(--color-overlay-40)}.combat-enemy-card:hover .combat-enemy-portrait{border-color:#dc3545cc;box-shadow:0 0 14px #dc354559,0 2px 10px var(--color-overlay-50)}.combat-enemy-name{font-size:var(--font-size-xs);font-family:var(--font-heading);color:var(--color-text-muted);text-align:center;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:.02em}.combat-enemy-hp{width:56px;height:4px;background:var(--color-overlay-50);border-radius:var(--radius-full);overflow:hidden}.combat-enemy-hp-fill{height:100%;background:linear-gradient(90deg,var(--color-danger),var(--color-accent-fire));border-radius:var(--radius-full);transition:width var(--transition-slow)}.initiative-tracker{display:flex;gap:var(--space-xs);align-items:center;background:linear-gradient(90deg,#0f0f1eeb,#1a1028eb);border-top:1px solid rgba(139,92,246,.18);border-bottom:1px solid rgba(139,92,246,.18);padding:var(--space-sm) var(--space-md);overflow-x:auto;scrollbar-width:thin;scrollbar-color:rgba(139,92,246,.25) transparent}.combat-stage .init-entry{opacity:.55;transition:opacity var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast)}.combat-stage .init-entry--active{opacity:1;border-color:var(--color-text-accent);box-shadow:0 0 12px var(--color-glow-gold-30),0 0 4px var(--color-glow-gold-20)}.combat-stage .init-entry--player .init-portrait{border-color:var(--color-success)}.combat-stage .init-entry--enemy .init-portrait{border-color:var(--color-danger)}.combat-stage .init-entry--defeated{opacity:.25;filter:grayscale(.6)}.combat-stage .init-name{color:var(--color-text-muted);font-size:.6rem}.combat-stage .init-entry--active .init-name{color:var(--color-text-accent);font-weight:var(--font-weight-semibold)}.combat-status{background:linear-gradient(180deg,#0f0f1ef2,#0a0a14fa);border:none;border-top:1px solid rgba(139,92,246,.15);border-radius:0 0 var(--radius-lg) var(--radius-lg);padding:var(--space-sm) var(--space-md);gap:var(--space-sm)}.combat-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-sm)}.combat-btn{position:relative;padding:var(--space-sm) 14px;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);font-family:var(--font-heading);color:#e0d0ff;background:linear-gradient(135deg,#4c1d9566,#310a6599);border:1px solid rgba(139,92,246,.4);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);text-shadow:0 1px 3px var(--color-overlay-50);letter-spacing:.03em}.combat-btn:hover:not(:disabled){background:linear-gradient(135deg,#6d28d999,#4c1d95cc);border-color:#a78bfab3;box-shadow:0 2px 16px #8b5cf673,0 0 6px #8b5cf633;transform:translateY(-1px)}.combat-btn:active:not(:disabled){transform:translateY(1px) scale(.97);box-shadow:0 1px 4px #8b5cf64d}.combat-btn:focus-visible{outline:2px solid var(--color-text-accent);outline-offset:2px}.combat-btn:disabled,.combat-btn.is-locked{opacity:.35;cursor:not-allowed;background:#1e1e3299;border-color:#5050644d;box-shadow:none}#combat-attack{background:linear-gradient(135deg,#dc262666,#991b1b99);border-color:#f8717166}#combat-attack:hover:not(:disabled){background:linear-gradient(135deg,#ef444499,#b91c1ccc);border-color:#fca5a5b3;box-shadow:0 2px 16px #ef444473,0 0 6px #ef444433}#combat-cast{background:linear-gradient(135deg,#2563eb66,#1d4ed899);border-color:#60a5fa66}#combat-cast:hover:not(:disabled){background:linear-gradient(135deg,#3b82f699,#2563ebcc);border-color:#93c5fdb3;box-shadow:0 2px 16px #3b82f673,0 0 6px #3b82f633}#combat-defend{background:linear-gradient(135deg,#654e3266,#46372399);border-color:#a0825a66}#combat-defend:hover:not(:disabled){background:linear-gradient(135deg,#785f3c99,#5a462dcc);border-color:#b49664b3;box-shadow:0 2px 16px #a0825a59,0 0 6px #a0825a26}#combat-flee{background:linear-gradient(135deg,#32324166,#23233299);border-color:#64647866}#combat-flee:hover:not(:disabled){background:linear-gradient(135deg,#41415099,#323241cc);border-color:#828296b3;box-shadow:0 2px 12px #6464784d,0 0 4px #64647826}#combat-log-overlay{max-height:120px;overflow-y:auto;padding:var(--space-sm) var(--space-md);background:#0a0a14e0;border-top:1px solid rgba(139,92,246,.1);font-size:var(--font-size-xs);color:var(--color-text-muted);scrollbar-width:thin;scrollbar-color:rgba(139,92,246,.25) transparent}.combat-log-row{padding:2px 0;border-bottom:1px solid var(--color-highlight-04)}.combat-turn-indicator{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);font-family:var(--font-heading);color:var(--color-text-accent);text-shadow:0 0 10px var(--color-glow-gold-20)}.combat-round-badge{font-size:var(--font-size-xs);color:var(--color-text-muted);background:var(--color-highlight-05);padding:2px var(--space-sm);border-radius:var(--radius-full)}@media (prefers-reduced-motion: reduce){.combat-enemy-card,.combat-enemy-hp-fill,.combat-btn,.combat-stage .init-entry{transition:none}.combat-enemy-card:hover{transform:none}.combat-btn:hover:not(:disabled){transform:none}.combat-btn:active:not(:disabled){transform:none}}.ec-card{position:relative;display:flex;flex-direction:column;align-items:center;width:110px;min-height:140px;border-radius:10px;border:1px solid rgba(139,92,246,.35);overflow:hidden;background:linear-gradient(180deg,#12101e,#1a0e24);box-shadow:0 2px 12px #0009,inset 0 0 20px #0006;transition:transform .2s,box-shadow .2s;cursor:default}.ec-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px #8b5cf640,inset 0 0 20px #0006}.ec-card[tabindex]:hover,.ec-card[tabindex]:focus-visible{border-color:#facc15b3;box-shadow:0 0 14px #facc154d,0 6px 20px #00000080;cursor:pointer;outline:none}.ec-card--defeated{opacity:.35;filter:grayscale(.8);pointer-events:none}.ec-body-bg{position:absolute;inset:0;background-size:cover;background-position:center top;background-repeat:no-repeat;opacity:0;transition:opacity .3s}.ec-body-bg--has-art{opacity:.18}.ec-card:hover .ec-body-bg--has-art{opacity:.3}.ec-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 6px 8px;width:100%}.ec-face{width:64px;height:64px;border-radius:50%;border:2px solid rgba(244,67,54,.55);object-fit:cover;background:#1a1a2e;box-shadow:0 2px 10px #f443364d,0 0 0 3px #00000080}.ec-face--defeated{display:flex;align-items:center;justify-content:center;font-size:2rem;border-color:#6464644d;box-shadow:none}.ec-face--placeholder{display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#c8c8dc66;border-color:#64648c4d}.ec-badge{position:absolute;top:6px;right:6px;font-size:.6rem;font-weight:700;color:gold;background:#000000b3;padding:1px 5px;border-radius:6px;text-shadow:0 1px 2px rgba(0,0,0,.8);letter-spacing:.3px}.ec-name{font-size:.72rem;font-weight:600;color:#ffffffd9;text-align:center;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-shadow:0 1px 3px rgba(0,0,0,.6)}.ec-subtitle{font-size:.58rem;color:#c8c8dc80;text-align:center;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ec-hp-bar{width:80%;height:4px;background:#00000080;border-radius:2px;overflow:hidden;margin-top:2px}.ec-hp-fill{height:100%;border-radius:2px;transition:width .3s}.ec-hp--green{background:linear-gradient(90deg,#22c55e,#4ade80)}.ec-hp--yellow{background:linear-gradient(90deg,#eab308,#facc15)}.ec-hp--red{background:linear-gradient(90deg,#ef4444,#f87171)}.ec-hp-text{font-size:.58rem;color:#c8c8dc99;text-align:center}@media (max-width: 480px){.ec-card{width:90px;min-height:120px}.ec-face{width:48px;height:48px}.ec-name{font-size:.65rem;max-width:80px}}@media (prefers-reduced-motion: reduce){.ec-card,.ec-body-bg,.ec-hp-fill{transition:none}.ec-card:hover{transform:none}}.ec-mount-card{position:relative;width:320px;height:480px;border-radius:10px;border:1px solid #ffd700;overflow:hidden;background:#0e0c1a}.ec-mount-body{position:absolute;inset:0;background-size:cover;background-position:center top;background-repeat:no-repeat;opacity:.15}.ec-mount-body--has-art{opacity:.35}.ec-mount-face-wrap{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:2}.ec-mount-face{width:96px;height:96px;border-radius:50%;border:2px solid #ffd700;object-fit:cover;background:#1a1a2e;box-shadow:0 2px 12px #000000b3}.ec-mount-initial{width:96px;height:96px;border-radius:50%;border:2px solid #ffd700;background:#2a1f4e;display:flex;align-items:center;justify-content:center;font-size:2.2rem;font-weight:700;color:gold;text-shadow:0 1px 4px rgba(0,0,0,.8)}.ec-mount-info{position:absolute;bottom:0;left:0;right:0;z-index:2;display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 8px;background:linear-gradient(transparent,#000000d9)}.ec-mount-name{font-size:.9rem;font-weight:600;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.7);text-align:center;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ec-mount-level{font-size:.7rem;font-weight:700;color:gold;text-shadow:0 1px 2px rgba(0,0,0,.8)}.save-card{display:flex;gap:10px;padding:10px;margin:10px 0;background:linear-gradient(135deg,#0f0f1ee6,#1a1028cc);border:1px solid rgba(139,92,246,.25);border-radius:10px;overflow:hidden}.save-card-thumb{width:96px;height:64px;object-fit:cover;border-radius:6px;border:1px solid rgba(139,92,246,.2);background:#0d0d1a;flex-shrink:0}.save-card-info{display:flex;flex-direction:column;gap:3px;justify-content:center;min-width:0}.save-card-location{font-size:.82rem;font-weight:600;color:#ffffffd9;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.save-card-stat{font-size:.7rem;color:#c8c8dca6}.save-card-mode{font-size:.62rem;color:#8b5cf699;text-transform:capitalize}.save-card-portraits{display:flex;gap:4px;align-items:center;flex-shrink:0}.save-card-portrait{width:32px;height:32px;border-radius:50%;border:1px solid rgba(139,92,246,.35);object-fit:cover;background:#1a1a2e}.save-card-portrait-initial{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;border:1px solid rgba(139,92,246,.35);background:#2a1f4e;color:gold;font-size:.75rem;font-weight:700}.save-card-time{font-style:italic;color:#c8c8dc73}@media (prefers-reduced-motion: reduce){.save-card{transition:none}}.shop-panel{position:relative}.shop-panel.immersive-service-panel{max-width:min(1080px,98vw);grid-template-columns:minmax(140px,24%) 1fr;max-height:min(92vh,860px)}.shop-panel .immersive-service-hero,.shop-panel .immersive-service-hero-img{min-height:240px}.shop-panel .shop-hero-portrait-wrap{display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#00000059,#0000008c)}.shop-panel .shop-hero-portrait{width:100%;height:100%;min-height:240px;object-fit:cover;object-position:center top}.shop-close-btn{position:absolute;top:10px;right:10px;z-index:5;width:32px;height:32px;border-radius:50%;border:1px solid var(--color-border-light,#718096);background:#0000008c;color:var(--color-text-primary,#f7fafc);font-size:16px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.shop-close-btn:hover,.shop-close-btn:focus-visible{background:#000000d9;border-color:var(--color-accent-warm,#f39c12)}.shop-immersive-body{max-height:none;flex:1;padding:.65rem .85rem .75rem;overflow:hidden}.shop-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:.35rem}.shop-title{margin:0;font-size:1.05rem;line-height:1.2;color:var(--color-text-primary,#f7fafc);font-weight:600}.shop-gold-row{display:flex;align-items:center;gap:10px;flex-shrink:0}.shop-party-gold,.shop-merchant-gold{display:flex;align-items:center;gap:4px;padding:2px 8px;border-radius:6px;background:#ffffff0d;font-size:.9em;font-weight:600}.shop-party-gold{color:var(--color-accent-gold,#f1c40f)}.shop-merchant-gold{color:var(--color-success-light,#34ce57)}.shop-rebate-badge{padding:2px 8px;border-radius:999px;font-size:.78em;font-weight:600;background:#28a74533;color:var(--color-success-light,#34ce57);border:1px solid var(--color-success,#28a745)}.shop-party-picker{display:flex;align-items:center;gap:8px;margin:0 0 .4rem;padding-bottom:.35rem;border-bottom:1px solid var(--color-border,#4a5568)}.shop-picker-label{font-size:.72em;color:var(--color-text-tertiary,#cbd5e0);text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}.shop-party-portraits{display:flex;gap:6px;flex-wrap:wrap}.shop-party-portrait{padding:2px;border-radius:50%;border:2px solid transparent;background:transparent;cursor:pointer;line-height:0}.shop-party-portrait.selected{border-color:var(--color-accent-warm,#f39c12)}.shop-party-face{border-radius:50%;object-fit:cover;display:block}.shop-trade-panels{display:grid;grid-template-columns:1fr 1fr;gap:8px;flex:1;min-height:0}.shop-trade-column{display:flex;flex-direction:column;min-height:0;min-width:0;border:1px solid var(--color-border,#4a5568);border-radius:8px;background:#141c2666;overflow:hidden}.shop-merchant-column{border-top:2px solid var(--color-interactive,#3498db)}.shop-party-column{border-top:2px solid var(--color-accent-warm,#f39c12)}.shop-column-header{display:flex;align-items:center;justify-content:space-between;gap:6px;padding:6px 8px 4px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.shop-column-header .section-title{margin:0;font-size:.78em;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary,#cbd5e0)}.shop-panel-scroll{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:4px 6px 6px;scrollbar-width:thin;scrollbar-color:var(--color-border-light,#718096) transparent}.shop-panel-scroll::-webkit-scrollbar{width:6px}.shop-panel-scroll::-webkit-scrollbar-thumb{background:var(--color-border-light,#718096);border-radius:3px}.shop-filter-chips{display:flex;gap:3px;flex-wrap:nowrap}.shop-filter-chip{width:26px;height:26px;padding:0;border-radius:6px;border:1px solid var(--color-border,#4a5568);background:#ffffff0a;cursor:pointer;display:flex;align-items:center;justify-content:center}.shop-filter-chip-icon{font-size:.85em;line-height:1}.shop-filter-chip.is-active{border-color:var(--color-interactive,#3498db);background:#3498db33}.shop-item-row{display:grid;grid-template-columns:28px 1fr auto auto;align-items:center;gap:6px;padding:4px 6px;margin-bottom:3px;border-radius:6px;background:#1e283773;border:1px solid transparent;cursor:default}.shop-item-row.sell-item-row{grid-template-columns:28px 1fr auto auto}.shop-item-row:hover{background:#283444a6}.shop-item-row.rarity-uncommon{border-color:#28a74559}.shop-item-row.rarity-uncommon .item-name{color:var(--color-success-light,#34ce57)}.shop-item-row.rarity-rare{border-color:#3498db59}.shop-item-row.rarity-rare .item-name{color:var(--color-interactive-light,#5dade2)}.shop-item-row.rarity-epic{border-color:#9b59b659}.shop-item-row.rarity-epic .item-name{color:var(--color-accent-arcane,#9b59b6)}.shop-item-row.rarity-legendary{border-color:#f39c1259}.shop-item-row.rarity-legendary .item-name{color:var(--color-accent-gold-light,#f4d03f)}.shop-item-icon{width:28px;height:28px;font-size:1.1em;display:flex;align-items:center;justify-content:center;border-radius:5px;background:#ffffff0d;flex-shrink:0}.shop-item-meta{display:flex;align-items:center;gap:5px;min-width:0;overflow:hidden}.shop-item-meta .item-name{font-size:.82em;color:var(--color-text-primary,#f7fafc);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shop-item-meta .item-level{font-size:.72em;color:var(--color-text-tertiary,#cbd5e0);font-weight:400}.shop-stock-badge{flex-shrink:0;font-size:.68em;padding:1px 5px;border-radius:4px;background:#ffffff14;color:var(--color-text-tertiary,#cbd5e0)}.shop-equipped-badge{flex-shrink:0;font-size:.85em;line-height:1;opacity:.9;cursor:help}.shop-owner-badge{flex-shrink:0;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.65em;font-weight:700;background:#f1c40f33;color:var(--color-accent-gold,#f1c40f);border:1px solid rgba(241,196,15,.35);cursor:help}.shop-item-price{display:flex;align-items:center;gap:2px;font-size:.8em;font-weight:600;color:var(--color-accent-gold,#f1c40f);white-space:nowrap}.shop-item-price .price-icon{font-size:.85em}.price-strike{text-decoration:line-through;opacity:.5;font-size:.9em}.price-discounted,.price-bonus{color:var(--color-success-light,#34ce57)}.shop-row-actions{display:flex;gap:3px}.shop-icon-btn{width:28px;height:28px;padding:0;border-radius:6px;border:1px solid var(--color-border,#4a5568);background:#ffffff0f;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.95em;line-height:1;transition:background .12s,border-color .12s}.shop-icon-btn:hover:not(:disabled){background:#ffffff24;border-color:var(--color-border-light,#718096)}.shop-icon-btn:disabled{opacity:.35;cursor:not-allowed}.shop-icon-btn--buy{border-color:#3498db80}.shop-icon-btn--buy:hover:not(:disabled){background:#3498db40}.shop-icon-btn--sell{border-color:#f39c1273}.shop-icon-btn--sell:hover:not(:disabled){background:#f39c1233}.shop-icon-btn--barter{border-color:#9b59b666}.shop-icon-btn--barter:hover:not(:disabled){background:#9b59b633}.shop-panel .empty-state{margin:8px 4px;font-size:.82em;color:var(--color-text-tertiary,#cbd5e0)}.shop-barter-options{display:flex;flex-direction:column;gap:8px;max-height:40vh;overflow-y:auto}.shop-barter-option{display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto auto;gap:4px 10px;padding:10px 12px;text-align:left;border:1px solid var(--color-border,#4a5568);border-radius:8px;background:#1e283780;color:var(--color-text-primary,#f7fafc);cursor:pointer}.shop-barter-option.is-disabled{opacity:.45;cursor:not-allowed}.shop-barter-icon{grid-row:span 2;font-size:1.4em}.shop-barter-name{font-weight:600}.shop-barter-price{color:var(--color-accent-gold,#f1c40f)}.shop-barter-delta{grid-column:2 / -1;font-size:.82em;color:var(--color-text-tertiary,#cbd5e0)}@media (max-width:720px){.shop-panel.immersive-service-panel,.shop-trade-panels{grid-template-columns:1fr}.shop-panel-scroll{max-height:min(28vh,220px)}}.crafting-modal-backdrop{z-index:var(--z-modal-backdrop, 1000)}.crafting-modal{max-width:min(1200px,96vw);max-height:min(92vh,900px)}.crafting-modal-body{display:grid;grid-template-columns:minmax(280px,48%) 1fr;gap:1rem;min-height:min(72vh,720px);align-items:stretch}@media (max-width: 768px){.crafting-modal-body{grid-template-columns:1fr;min-height:auto}}.crafting-left-column{display:flex;flex-direction:column;gap:.75rem;min-height:0}.crafting-forge-pane{flex:0 0 auto;min-height:44vh;position:relative;border-radius:var(--radius-md, 8px);background-color:#140c08e6;background-size:cover;background-position:center 8%;background-repeat:no-repeat;border:1px solid var(--color-border-subtle, rgba(255, 200, 120, .2));overflow:hidden;cursor:zoom-in;transition:box-shadow .15s ease}.crafting-forge-pane:hover,.crafting-forge-pane:focus-visible{box-shadow:inset 0 0 0 2px #c9a22773;outline:none}.crafting-forge-lightbox{position:fixed;inset:0;z-index:calc(var(--z-modal-backdrop, 1000) + 5);display:none;align-items:center;justify-content:center;background:#000000e0;padding:1rem}.crafting-forge-lightbox.open{display:flex}.crafting-forge-lightbox-inner{display:flex;flex-direction:column;align-items:center;gap:.75rem;max-width:min(96vw,1400px)}.crafting-forge-lightbox-img{max-width:90vw;max-height:82vh;width:auto;height:auto;object-fit:cover;object-position:center 8%;border-radius:12px;border:3px solid var(--color-accent, #c9a227);box-shadow:0 8px 40px #000000b3}.crafting-forge-lightbox-close{min-width:120px}.crafting-material-tree{padding:.75rem;display:flex;flex-direction:column;gap:.5rem;flex:0 0 auto}.crafting-tree-slots{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.crafting-tree-slot{width:64px;height:64px;border:2px dashed rgba(255,200,120,.35);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.7rem;text-align:center;cursor:pointer;background:#00000059;transition:border-color .15s,background .15s}.crafting-tree-slot.filled{border-style:solid;border-color:#78c87899}.crafting-tree-slot.drag-over{border-color:var(--color-accent, #c9a227);background:#c9a22726}.crafting-tree-result{align-self:center;margin-top:.25rem;padding:.35rem .75rem;border-radius:999px;background:#c9a22733;font-size:.85rem}.crafting-party-materials{display:flex;flex-wrap:wrap;gap:.35rem;padding:.5rem;background:#00000040;border-radius:8px;max-height:18vh;overflow-y:auto;flex:1 1 auto;min-height:0}.crafting-material-chip{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .45rem;border-radius:6px;background:#ffffff14;font-size:.75rem;cursor:grab;border:1px solid transparent}.crafting-material-chip:active{cursor:grabbing}.crafting-compass{padding:.5rem;border-radius:8px;background:#0000004d;border:1px solid rgba(255,200,120,.15)}.crafting-compass-title{font-size:.8rem;opacity:.85;margin-bottom:.35rem}.crafting-compass-hint{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.35rem 0;font-size:.78rem;border-bottom:1px solid rgba(255,255,255,.06)}.crafting-compass-hint:last-child{border-bottom:none}.crafting-compass-icon{flex-shrink:0;width:1.25rem;text-align:center}.crafting-right-column{display:flex;flex-direction:column;min-height:0;min-width:0}.crafting-crafter-row{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}.crafting-crafter-portrait{width:80px;padding:.5rem .35rem;border-radius:8px;border:2px solid transparent;background:#192337b3;border-color:var(--color-highlight-06, rgba(93, 173, 226, .06));cursor:pointer;text-align:center;font-size:.65rem;display:flex;flex-direction:column;align-items:center;gap:.25rem;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}.crafting-crafter-portrait:hover{background:#233046cc}.crafting-crafter-portrait.selected{border-color:var(--color-accent, #c9a227);box-shadow:0 0 0 1px #c9a22759}.crafting-crafter-face{width:48px;height:48px;border-radius:50%;object-fit:cover;display:block;background:#0006;border:1px solid var(--color-highlight-08, rgba(93, 173, 226, .08))}.crafting-crafter-name{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#fff;font-weight:600;font-size:.75rem}.crafting-crafter-capacity{font-size:.65rem;padding:2px 6px;background:#00000059;border-radius:4px;border:1px solid var(--color-highlight-08, rgba(93, 173, 226, .08));color:var(--color-interactive-light, #e8f4fc)}.crafting-category-bar{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.75rem}.crafting-category-bar .crafting-category-badge{min-width:2.25rem;padding:.35rem .5rem;font-size:.85em;background:#0000004d;border-radius:4px;border:1px solid var(--color-highlight-08, rgba(93, 173, 226, .08));cursor:pointer;color:inherit}.crafting-category-bar .crafting-category-badge.active{border-color:var(--color-accent, #c9a227);background:#c9a22726}.crafting-category-bar .category-btn .cat-label{display:none}.crafting-recipe-list{flex:1 1 auto;min-height:0;display:flex;flex-direction:column}.crafting-recipe-list .section-title{flex-shrink:0}#crafting-recipe-list-inner{flex:1 1 auto;min-height:0;max-height:42vh;overflow-y:auto}.crafting-recipe-item{padding:.5rem .65rem;border-radius:8px;margin-bottom:.35rem;cursor:pointer;border:1px solid var(--color-highlight-06, rgba(93, 173, 226, .06));background:#192337b3;transition:background .15s ease,border-color .15s ease}.crafting-recipe-item:hover{background:#233046cc}.crafting-recipe-item.selected{border-color:var(--color-accent, #c9a227)}.crafting-recipe-item.blocked{opacity:.55}.crafting-recipe-item .missing-chips{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.25rem}.crafting-missing-chip{font-size:.65rem;padding:.1rem .35rem;border-radius:4px;background:#b43c3c59}.crafting-missing-chip.ok{background:#3c8c5059}.crafting-progress-bar{height:6px;border-radius:3px;background:#ffffff1a;margin:.5rem 0;overflow:hidden}.crafting-progress-fill{height:100%;background:linear-gradient(90deg,#6a8f3a,#c9a227);transition:width .2s}.crafting-modal-footer{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-end;align-items:center}.crafting-modal-footer .crafting-footer-back{margin-right:auto}.recipe-placeholder{opacity:.75;font-size:.9rem}.crafting-recipe-details-panel{padding:.5rem 0}.crafting-recipe-details-panel .cs-section-title{margin:.75rem 0 .35rem;font-size:.95em}.crafting-ingredient-list,.crafting-requirement-list,.crafting-aptitude-list{list-style:none;padding:0;margin:0 0 .5rem}.crafting-ingredient-list .ingredient-item,.crafting-aptitude-row{display:flex;justify-content:space-between;gap:.5rem;padding:.35rem .5rem;margin-bottom:.25rem;border-radius:4px;font-size:.85rem;background:#00000040;border:1px solid var(--color-highlight-06, rgba(93, 173, 226, .06))}.crafting-ingredient-list .ingredient-item.available{border-color:#3c8c5059}.crafting-ingredient-list .ingredient-item.missing{border-color:#b43c3c59}.crafting-aptitude-row.met{border-color:#3c8c5059}.crafting-aptitude-row.warn,.crafting-aptitude-row.unmet{border-color:#c9a22773;opacity:.9}.crafting-success-label{font-size:.9rem;font-weight:600;color:var(--color-interactive-light, #e8f4fc);margin:.35rem 0}.crafting-success-bar .crafting-success-fill{background:linear-gradient(90deg,#4a7c59,#c9a227)}.crafting-meta-row{font-size:.85rem;opacity:.9}.crafting-forge-overlay{position:absolute;inset:0;pointer-events:none;display:flex;flex-direction:column;justify-content:flex-end;padding:.75rem}.crafting-forge-ingredients{display:flex;flex-wrap:wrap;gap:.35rem;align-self:flex-start;pointer-events:auto}.crafting-forge-ingredient-slot{width:52px;height:52px;border:2px dashed rgba(255,200,120,.45);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.65rem;background:#00000073;cursor:pointer;pointer-events:auto}.crafting-forge-ingredient-slot.filled{border-style:solid;border-color:#78c878a6}.crafting-forge-slot-icon{font-size:1.1rem;line-height:1}.crafting-forge-slot-count{font-weight:600}.crafting-forge-slot-have{display:none}.crafting-forge-result-slot{position:absolute;right:.75rem;bottom:.75rem;width:56px;height:56px;border-radius:10px;border:2px solid rgba(201,162,39,.55);background:#00000080;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:auto}.crafting-forge-result-icon{font-size:1.35rem}.crafting-forge-result-qty{font-size:.7rem;font-weight:600}.crafting-crafter-header{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.75rem;flex-wrap:wrap}.crafting-crafter-header .crafting-crafter-row{margin-bottom:0;flex:0 0 auto}.crafting-category-inline{display:grid;grid-template-columns:repeat(4,2.25rem);gap:.35rem;align-self:center}.crafting-category-inline .crafting-category-badge{min-width:2.25rem;min-height:2.25rem;padding:.25rem;font-size:.85em;background:#0000004d;border-radius:4px;border:1px solid var(--color-highlight-08, rgba(93, 173, 226, .08));cursor:pointer;color:inherit}.crafting-category-inline .crafting-category-badge.active{border-color:var(--color-accent, #c9a227);background:#c9a22726}.crafting-recipe-creates{margin:.5rem 0 .75rem}.crafting-result-chip{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .6rem;border-radius:8px;background:#c9a2271f;border:1px solid rgba(201,162,39,.25)}.crafting-result-unknown{color:#e8b84a;font-size:.85rem;margin:.35rem 0 0}.crafting-result-effects{margin:.25rem 0 0;padding-left:1.1rem;font-size:.85rem}.crafting-discovery-added{margin-top:.75rem;font-weight:600;color:var(--color-accent, #c9a227)}.crafting-material-tree-slot[hidden]{display:none!important}@media (max-width: 768px),(pointer: coarse){.combat-btn{min-height:44px;min-width:44px;padding:10px 16px;font-size:.9rem}.combat-status .combat-actions{width:100%;flex:1 1 100%}.init-entry{min-width:44px;min-height:44px;padding:4px}.init-portrait{width:36px;height:36px}.combat-target-row,.combat-spell-row{min-height:44px;padding:10px 12px;gap:8px}.dialogue-panel .action-buttons .btn,.dialogue-panel .dialogue-actions .btn,.player-npc-option-dialogue .player-npc-actions .btn,.player-npc-option-dialogue .player-npc-opt{flex-shrink:0;min-height:44px;min-width:44px;padding:10px 16px;font-size:.9rem;line-height:1.4}.player-npc-option-dialogue .player-npc-actions{flex-direction:column;align-items:stretch;gap:.5rem}.player-npc-option-dialogue .player-npc-actions .btn{width:100%;justify-content:center}#quest-log .quest-log-panel,#quest-log-menu .quest-log-panel{display:flex;flex-direction:column;width:min(100%,calc(100vw - 1rem));max-height:min(90vh,100dvh - 1rem);padding:1rem;overflow:hidden;box-sizing:border-box}#quest-log .quest-log-content,#quest-log-menu .quest-log-content{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}#quest-log .game-title-large,#quest-log-menu .game-title-large{font-size:clamp(1.5rem,6vw,2.25rem)}.location-row{flex-direction:column;align-items:stretch}.location-row .message-log{width:100%;max-width:100%;max-height:min(28vh,140px);position:static;pointer-events:none;box-sizing:border-box}.location-row .message-log .message-log-toggle{pointer-events:auto}.menu-overlay.subscription-overlay,#hud-container,.game-footer{max-width:100vw;overflow-x:hidden;box-sizing:border-box}.dialogue-panel{width:min(100%,calc(100vw - 1rem));max-width:calc(100vw - 1rem);box-sizing:border-box}.exploration-action-btn,.movement-btn{min-height:44px;min-width:44px;font-size:1rem}.game-menu-btn,.menu-action-btn{min-height:44px;min-width:44px;padding:8px 14px}@media (max-width: 420px){.combat-status{flex-direction:column;align-items:stretch}.combat-btn{width:100%;text-align:center}.combat-info{flex-wrap:wrap;gap:8px}}}
