*{box-sizing:border-box}:root{--color-background: #1a1a2e;--color-background-secondary: #16213e;--color-highlight: #e94560;--color-button: #e94560;--color-button-hover: #d63850;--color-text: #fff;--color-text-muted: #8b8b8b;--color-border: #0f4c75;--color-success: #4caf50;--color-error: #f44336;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color:var(--color-text);background-color:var(--color-background);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}a{color:var(--color-highlight);text-decoration:none}a:hover{text-decoration:underline}button,input{font-family:inherit}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-background);padding:1rem}.login-card{background:var(--color-background-secondary);border-radius:16px;padding:2.5rem;width:100%;max-width:400px}.login-title{font-size:2.5rem;font-weight:700;color:var(--color-highlight);text-align:center;margin:0 0 .5rem}.login-subtitle{font-size:1rem;color:#8b8b8b;text-align:center;margin:0 0 2rem}.login-input{width:100%;padding:1rem;background:var(--color-background);border:none;border-radius:12px;color:var(--color-text);font-size:1rem;margin-bottom:1rem;box-sizing:border-box}.login-input::placeholder{color:#666}.login-input:focus{outline:2px solid var(--color-highlight)}.login-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem;cursor:pointer}.login-select option{background:var(--color-background);color:var(--color-text)}.timezone-hint{color:#666;font-size:.75rem;text-align:center;margin:-.5rem 0 1rem}.login-button{width:100%;padding:1rem;background:var(--color-button);border:none;border-radius:12px;color:var(--color-text);font-size:1.125rem;font-weight:600;cursor:pointer;margin-top:.5rem;transition:opacity .2s}.login-button:hover{opacity:.9}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-error{color:#f44336;text-align:center;margin:0 0 1rem;font-size:.875rem}.login-switch{width:100%;background:none;border:none;color:#0f4c75;cursor:pointer;margin-top:1.5rem;font-size:.875rem}.login-switch:hover{text-decoration:underline}.class-selection{margin-bottom:1rem}.class-label{display:block;font-size:.875rem;color:#8b8b8b;margin-bottom:.75rem;text-align:center}.class-options{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.class-option{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem .5rem;background:var(--color-background);border:2px solid transparent;border-radius:10px;cursor:pointer;transition:all .2s}.class-option:hover{border-color:#3a3a5c}.class-option.selected{border-color:var(--color-highlight);background:#e945601a}.class-icon{font-size:1.5rem}.class-name{font-size:.9rem;font-weight:600;color:#fff}.class-desc{font-size:.7rem;color:#8b8b8b;text-align:center}@media(min-width:500px){.login-card:has(.class-selection){max-width:450px}}@media(max-width:400px){.class-options{grid-template-columns:1fr}.class-option{flex-direction:row;gap:.75rem;text-align:left;padding:.75rem 1rem}.class-icon{font-size:1.75rem}.class-desc{text-align:left}}.landing{--bg-deep: #0a0a12;--bg-mid: #111120;--bg-card: #16152a;--bg-card-hover: #1c1b35;--purple-glow: #a78bfa;--purple-dim: #7c3aed;--amber-warm: #fbbf24;--amber-soft: rgba(251, 191, 36, .15);--red-damage: #ef4444;--green-heal: #34d399;--text-primary: #e8e6e3;--text-secondary: #9ca3af;--text-dim: #6b7280;--border-subtle: rgba(167, 139, 250, .12);--border-glow: rgba(167, 139, 250, .3);background:var(--bg-deep);color:var(--text-primary);font-family:Alegreya,Georgia,serif;font-size:18px;line-height:1.7;overflow-x:hidden;min-height:100vh}.landing-ambient{position:fixed;inset:0;pointer-events:none;z-index:0}.landing-ambient:before{content:"";position:absolute;top:-20%;left:-10%;width:60%;height:60%;background:radial-gradient(ellipse,rgba(124,58,237,.06) 0%,transparent 70%);animation:landing-drift 25s ease-in-out infinite alternate}.landing-ambient:after{content:"";position:absolute;bottom:-10%;right:-10%;width:50%;height:50%;background:radial-gradient(ellipse,rgba(251,191,36,.04) 0%,transparent 70%);animation:landing-drift 20s ease-in-out infinite alternate-reverse}@keyframes landing-drift{0%{transform:translate(0)}to{transform:translate(40px,30px)}}.landing:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.025;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}.landing-content-wrap{position:relative;z-index:2;max-width:820px;margin:0 auto;padding:0 24px}.landing-hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:80px 24px 60px;position:relative}.hero-tagline{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--purple-glow);margin-bottom:28px;opacity:0;animation:landing-fadeUp .8s ease .2s forwards}.landing-hero h1{font-family:Cinzel,serif;font-size:clamp(2.4rem,6vw,4rem);font-weight:700;line-height:1.15;letter-spacing:-.01em;margin-bottom:28px;opacity:0;animation:landing-fadeUp .8s ease .4s forwards}.landing-hero h1 .accent{background:linear-gradient(135deg,var(--amber-warm) 0%,#f59e0b 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-sub{font-size:1.2rem;color:var(--text-secondary);max-width:540px;margin-bottom:44px;opacity:0;animation:landing-fadeUp .8s ease .6s forwards}.hero-cta{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;opacity:0;animation:landing-fadeUp .8s ease .8s forwards}.landing-btn-primary{display:inline-flex;align-items:center;gap:8px;padding:16px 36px;background:linear-gradient(135deg,var(--purple-dim) 0%,#6d28d9 100%);color:#fff;font-family:Cinzel,serif;font-size:15px;font-weight:600;letter-spacing:1px;text-decoration:none;border-radius:12px;border:1px solid rgba(167,139,250,.3);cursor:pointer;transition:all .3s ease;box-shadow:0 4px 24px #7c3aed40}.landing-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px #7c3aed66}.landing-btn-login{display:inline-flex;align-items:center;gap:8px;padding:16px 36px;background:linear-gradient(135deg,#1a1a2e,#16213e);color:var(--text-primary);font-family:Cinzel,serif;font-size:15px;font-weight:600;letter-spacing:1px;text-decoration:none;border-radius:12px;border:1px solid var(--border-glow);cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #a78bfa26}.landing-btn-login:hover{transform:translateY(-2px);box-shadow:0 8px 24px #a78bfa4d;border-color:var(--purple-glow)}.landing-btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:16px 36px;background:transparent;color:var(--text-secondary);font-family:Cinzel,serif;font-size:15px;font-weight:600;letter-spacing:1px;text-decoration:none;border-radius:12px;border:1px solid var(--border-subtle);cursor:pointer;transition:all .3s ease}.landing-btn-secondary:hover{border-color:var(--border-glow);color:var(--text-primary)}.scroll-hint{position:absolute;bottom:32px;left:50%;transform:translate(-50%);opacity:0;animation:landing-fadeUp .8s ease 1.2s forwards}.scroll-hint span{display:block;width:2px;height:28px;margin:0 auto;background:linear-gradient(to bottom,var(--purple-glow),transparent);border-radius:2px;animation:landing-pulse-down 2s ease-in-out infinite}@keyframes landing-pulse-down{0%,to{opacity:.3;transform:scaleY(.7)}50%{opacity:.8;transform:scaleY(1)}}@keyframes landing-fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.landing section{padding:100px 0}.landing-section-label{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--purple-glow);margin-bottom:16px}.landing section h2{font-family:Cinzel,serif;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:600;line-height:1.25;margin-bottom:20px}.landing section h2 .accent{color:var(--amber-warm)}.landing-section-body{color:var(--text-secondary);font-size:1.05rem;max-width:640px}.landing-section-body p+p{margin-top:16px}.landing-divider{height:1px;background:linear-gradient(to right,transparent,var(--border-subtle),transparent);margin:0 auto;max-width:400px}.problem-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:40px}.problem-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:16px;padding:28px 24px;transition:all .3s ease}.problem-card:hover{border-color:var(--border-glow);background:var(--bg-card-hover)}.problem-card .stat{font-family:Cinzel,serif;font-size:2rem;font-weight:700;color:var(--red-damage);margin-bottom:8px}.problem-card .stat.amber{color:var(--amber-warm)}.problem-card h3{font-family:Cinzel,serif;font-size:1rem;font-weight:600;margin-bottom:8px}.problem-card p{font-size:.9rem;color:var(--text-secondary);line-height:1.6}.mechanic-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:20px;padding:40px 36px;margin-top:32px;position:relative;overflow:hidden}.mechanic-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(to right,var(--purple-dim),var(--amber-warm))}.loop-diagram{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:12px;margin:32px 0;font-family:JetBrains Mono,monospace;font-size:13px}.loop-step{padding:12px 18px;background:#a78bfa14;border:1px solid rgba(167,139,250,.15);border-radius:10px;color:var(--text-primary);text-align:center;white-space:nowrap}.loop-step.positive{border-color:#34d39940;background:#34d3990f}.loop-step.negative{border-color:#ef444440;background:#ef44440f}.loop-arrow{color:var(--text-dim);font-size:18px}.principle-list{margin-top:40px;display:flex;flex-direction:column;gap:24px}.principle{display:grid;grid-template-columns:56px 1fr;gap:20px;align-items:start}.principle-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.principle-icon.purple{background:#a78bfa1a;border:1px solid rgba(167,139,250,.2)}.principle-icon.amber{background:var(--amber-soft);border:1px solid rgba(251,191,36,.2)}.principle-icon.green{background:#34d39914;border:1px solid rgba(52,211,153,.2)}.principle-icon.red{background:#ef444414;border:1px solid rgba(239,68,68,.2)}.principle-icon.blue{background:#60a5fa14;border:1px solid rgba(96,165,250,.2)}.principle h3{font-family:Cinzel,serif;font-size:1.05rem;font-weight:600;margin-bottom:6px}.principle p{color:var(--text-secondary);font-size:.95rem;line-height:1.65}.party-section{text-align:center}.party-scenario{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:20px;padding:44px 36px;margin-top:36px;text-align:left;position:relative}.scenario-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.05)}.scenario-party-name{font-family:Cinzel,serif;font-size:.85rem;font-weight:600;color:var(--purple-glow);letter-spacing:1px}.scenario-floor{font-family:JetBrains Mono,monospace;font-size:.75rem;color:var(--text-dim)}.scenario-members{display:flex;flex-direction:column;gap:16px;margin-bottom:28px}.scenario-member{display:grid;grid-template-columns:40px 1fr auto;gap:14px;align-items:center}.landing-member-avatar{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;background:#a78bfa1a;border:1px solid rgba(167,139,250,.15)}.landing-member-info{display:flex;flex-direction:column;gap:5px}.landing-member-name{font-size:.9rem;font-weight:500}.member-bar-track{height:6px;background:#ffffff0f;border-radius:3px;overflow:hidden}.member-bar-fill{height:100%;border-radius:3px;transition:width .6s ease}.member-bar-fill.healthy{background:var(--green-heal)}.member-bar-fill.mid{background:var(--amber-warm)}.member-bar-fill.low{background:var(--red-damage)}.member-pct{font-family:JetBrains Mono,monospace;font-size:.8rem;min-width:40px;text-align:right}.scenario-message{background:linear-gradient(135deg,#fbbf240f,#fb923c08);border:1px solid rgba(251,191,36,.15);border-radius:12px;padding:16px 20px;font-size:.9rem;color:var(--amber-warm);display:flex;gap:12px;align-items:start}.scenario-message span:first-child{font-size:18px;flex-shrink:0}.comparison-table{width:100%;border-collapse:separate;border-spacing:0;margin-top:36px;font-size:.9rem}.comparison-table th,.comparison-table td{padding:14px 16px;text-align:left;border-bottom:1px solid rgba(255,255,255,.04)}.comparison-table thead th{font-family:Cinzel,serif;font-weight:600;font-size:.85rem;color:var(--text-dim);letter-spacing:.5px;padding-bottom:12px;border-bottom:1px solid var(--border-subtle)}.comparison-table thead th:last-child{color:var(--purple-glow)}.comparison-table td:first-child{color:var(--text-secondary)}.comparison-table .check{color:var(--green-heal)}.comparison-table .cross{color:var(--text-dim);opacity:.4}.comparison-table .highlight-col{background:#a78bfa0a}.rhythm-timeline{margin-top:36px;position:relative;padding-left:28px}.rhythm-timeline:before{content:"";position:absolute;left:7px;top:8px;bottom:8px;width:2px;background:linear-gradient(to bottom,var(--purple-glow),var(--amber-warm),var(--purple-dim));border-radius:1px;opacity:.3}.rhythm-step{position:relative;padding-bottom:32px}.rhythm-step:last-child{padding-bottom:0}.rhythm-dot{position:absolute;left:-24px;top:6px;width:14px;height:14px;border-radius:50%;border:2px solid var(--purple-glow);background:var(--bg-deep)}.rhythm-time{font-family:JetBrains Mono,monospace;font-size:.75rem;color:var(--purple-glow);margin-bottom:4px}.rhythm-step h3{font-family:Cinzel,serif;font-size:1rem;font-weight:600;margin-bottom:4px}.rhythm-step p{color:var(--text-secondary);font-size:.9rem}.landing-cta-section{text-align:center;padding:100px 0 120px}.landing-cta-section h2{margin-bottom:16px}.landing-cta-section .landing-section-body{margin:0 auto 40px;text-align:center}.landing-footer{border-top:1px solid rgba(255,255,255,.04);padding:40px 0;text-align:center;color:var(--text-dim);font-size:.85rem}.landing-footer a{color:var(--text-secondary);text-decoration:none}.landing-footer a:hover{color:var(--purple-glow)}@media(max-width:640px){.problem-grid{grid-template-columns:1fr}.loop-diagram{flex-direction:column}.loop-arrow{transform:rotate(90deg)}.mechanic-card{padding:28px 24px}.party-scenario{padding:28px 20px}.landing section{padding:72px 0}.comparison-table{font-size:.8rem}.comparison-table th,.comparison-table td{padding:10px 8px}.hero-cta{flex-direction:column;align-items:center}}.skill-tree{background:#1a1a2e;border-radius:8px;padding:1rem;color:#fff;position:relative}.skill-tree.loading,.skill-tree.error{text-align:center;padding:2rem;color:#888}.skill-tree-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.skill-tree-header h3{margin:0;color:gold}.skill-points-display{display:flex;gap:.75rem;align-items:center}.sp-available{background:gold;color:#1a1a2e;padding:.25rem .75rem;border-radius:4px;font-weight:700;font-size:.9rem}.sp-spent{color:#888;font-size:.85rem}.respec-btn{background:#9b59b6;color:#fff;border:none;padding:.25rem .75rem;border-radius:4px;cursor:pointer;font-size:.8rem;font-weight:600}.respec-btn:hover:not(:disabled){background:#8e44ad}.respec-btn:disabled{opacity:.6;cursor:not-allowed}.skill-tree-error{background:#f44;color:#fff;padding:.5rem;border-radius:4px;margin-bottom:1rem;text-align:center;font-size:.9rem}.class-nav{display:flex;gap:6px;margin-bottom:.75rem;flex-wrap:wrap;justify-content:center}.class-nav-btn{padding:.35rem .75rem;border-radius:6px;border:2px solid var(--cls-color, #555);background:transparent;color:var(--cls-color, #aaa);font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.class-nav-btn:hover{background:var(--cls-color, #555);color:#1a1a2e}.class-nav-btn.invested{background:#ffffff0d;border-width:2px}.class-nav-btn.fit-all{--cls-color: #888;border-style:dashed}.skill-tree-radial{width:100%;max-width:700px;margin:0 auto;aspect-ratio:1;overflow:hidden;position:relative;border-radius:8px;user-select:none;-webkit-user-select:none;touch-action:none}.skill-tree-svg{width:100%;height:100%}.radial-node-group:hover circle:first-of-type,.radial-node-group:hover polygon:first-of-type{filter:brightness(1.2)}.radial-node-group{transition:opacity .15s}.investable-glow{animation:radial-pulse-glow 2s infinite}@keyframes radial-pulse-glow{0%,to{opacity:.3}50%{opacity:.7}}.selection-ring{animation:selection-pulse 1.5s infinite}@keyframes selection-pulse{0%,to{opacity:.5}50%{opacity:.8}}.node-popup{position:absolute;z-index:100;transform:translate(-50%);pointer-events:auto;max-width:280px;min-width:220px}.node-popup.above{transform:translate(-50%) translateY(-100%)}.node-detail{background:#252540;border-radius:8px;padding:.75rem;border:1px solid #444;box-shadow:0 4px 20px #0009}.node-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.node-detail-header h4{margin:0;color:gold;font-size:.95rem}.close-btn{background:transparent;border:1px solid #666;color:#888;width:24px;height:24px;border-radius:4px;cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.close-btn:hover{border-color:#aaa;color:#fff}.node-detail-desc{color:#aaa;font-size:.85rem;margin:0 0 .5rem;line-height:1.4}.node-detail-type{color:#888;font-size:.75rem;margin-bottom:.5rem}.node-detail-ranks{display:flex;flex-direction:column;gap:3px;margin-bottom:.5rem}.rank-row{display:flex;gap:.5rem;padding:.2rem .4rem;border-radius:4px;font-size:.8rem}.rank-row.current{background:#ffd70026}.rank-row.invested{color:#4caf50}.rank-label{color:#888;min-width:50px}.rank-value{color:inherit}.node-detail-costs{display:flex;gap:.75rem;font-size:.75rem;color:#888;margin-bottom:.5rem}.node-detail-costs span{background:#ffffff1a;padding:.2rem .4rem;border-radius:3px}.invest-btn{width:100%;background:gold;color:#1a1a2e;border:none;padding:.5rem;border-radius:4px;cursor:pointer;font-weight:700;font-size:.85rem}.invest-btn:hover:not(:disabled){background:#ffed4a}.invest-btn:disabled{opacity:.6;cursor:not-allowed}.node-detail-locked{text-align:center;color:#888;font-size:.8rem;padding:.4rem}.node-detail-maxed{text-align:center;color:gold;font-weight:700;font-size:.85rem;padding:.4rem}.respec-panel{margin-top:1rem;background:#252540;border-radius:8px;padding:1rem;border:1px solid #9b59b6}.respec-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.respec-panel-header h4{margin:0;color:#9b59b6}.respec-panel-desc{color:#aaa;font-size:.85rem;margin:0 0 .75rem;line-height:1.4}.respec-warning{color:#e74c3c;font-weight:600}.respec-confirm-btn{width:100%;background:#9b59b6;color:#fff;border:none;padding:.6rem;border-radius:4px;cursor:pointer;font-weight:700;font-size:.9rem}.respec-confirm-btn:hover:not(:disabled){background:#8e44ad}.respec-confirm-btn:disabled{opacity:.6;cursor:not-allowed}.zoom-controls{position:absolute;bottom:12px;right:12px;display:flex;flex-direction:column;gap:4px;z-index:50}.zoom-btn{width:36px;height:36px;border-radius:6px;border:1px solid #555;background:#252540e6;color:#fff;font-size:1.2rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.zoom-btn:hover{background:#3c3c64e6;border-color:#888}.zoom-btn:active{background:#505078e6}.node-popup-backdrop{position:absolute;inset:0;z-index:99;background:#0000004d}@media(max-width:600px){.skill-tree-header{flex-direction:column;gap:.5rem;align-items:flex-start}.skill-points-display{flex-wrap:wrap;gap:.5rem}.skill-tree-radial{max-width:100%}.node-popup{position:absolute;bottom:0;left:0!important;right:0;top:auto!important;transform:none;max-width:100%;min-width:0;animation:slideUpSheet .2s ease-out}.node-popup.above{transform:none}}.skills-panel{background:#1a1a2e;border-radius:8px;padding:1rem;color:#fff}.skills-panel.loading{text-align:center;padding:2rem;color:#888}.skills-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.skills-header h3{margin:0;color:gold}.auto-learn-btn{background:#4caf50;border:none;color:#fff;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.85rem}.auto-learn-btn:hover{background:#45a049}.skills-error{background:#f44;color:#fff;padding:.5rem;border-radius:4px;margin-bottom:1rem;text-align:center}.attr-compact{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;padding:.5rem .75rem;background:#0003;border-radius:6px;justify-content:center}.attr-compact-item{font-size:.8rem;color:#e8e6e3;font-weight:600;white-space:nowrap}.attr-compact-item span{font-weight:700;font-size:.75rem}.attr-breakdown{margin-bottom:1rem;background:#0003;border-radius:8px;padding:.75rem}.attr-breakdown-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.attr-breakdown-item{display:flex;align-items:center;gap:6px;padding:6px 8px;background:#ffffff08;border-radius:6px}.attr-breakdown-abbr{font-weight:700;font-size:.75rem;min-width:28px}.attr-breakdown-value{font-weight:600;font-size:.85rem;color:#e8e6e3;min-width:20px}.attr-breakdown-bonuses{display:flex;flex-direction:column;gap:1px}.attr-breakdown-bonuses span{font-size:.65rem;color:#6b7280;white-space:nowrap}@media(max-width:600px){.attr-breakdown-grid{grid-template-columns:repeat(2,1fr)}.skills-tabs .tab{padding:.5rem .6rem;font-size:.85rem}}.skills-tabs{display:flex;gap:.5rem;margin-bottom:1rem;border-bottom:2px solid #333;padding-bottom:.5rem}.skills-tabs .tab{background:transparent;border:none;color:#888;padding:.5rem 1rem;cursor:pointer;font-size:1rem;border-radius:4px 4px 0 0;transition:all .2s}.skills-tabs .tab:hover{color:#fff;background:#ffffff1a}.skills-tabs .tab.active{color:gold;background:#ffd7001a;border-bottom:2px solid #ffd700;margin-bottom:-2px}.skills-content{max-height:60vh;max-height:60dvh;overflow-y:auto}.skills-list{display:flex;flex-direction:column;gap:.75rem}.no-skills{text-align:center;color:#888;padding:2rem}.skill-card{background:#252540;border-radius:6px;padding:.75rem;border-left:3px solid #666}.skill-card.passive{border-left-color:#4caf50}.skill-card.active{border-left-color:#2196f3}.skill-card.inactive{opacity:.6}.skill-card.available{border-left-color:gold}.skill-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.skill-name{font-weight:700;color:#fff}.skill-level{color:#888;font-size:.85rem}.toggle-btn{padding:.25rem .75rem;border:none;border-radius:4px;cursor:pointer;font-size:.75rem;font-weight:700}.toggle-btn.on{background:#4caf50;color:#fff}.toggle-btn.off{background:#666;color:#ccc}.skill-description{margin:0 0 .5rem;color:#aaa;font-size:.9rem;line-height:1.4}.skill-effect{background:#0003;padding:.5rem;border-radius:4px;font-size:.85rem;color:#4caf50;margin-bottom:.5rem}.skill-costs{display:flex;gap:1rem;font-size:.8rem;color:#888}.skill-costs span{background:#ffffff1a;padding:.25rem .5rem;border-radius:3px}.learn-btn{width:100%;background:gold;color:#1a1a2e;border:none;padding:.5rem;border-radius:4px;cursor:pointer;font-weight:700;margin-top:.5rem}.learn-btn:hover{background:#ffed4a}.noncombat-card{background:#252540;border-radius:6px;padding:.75rem;border-left:3px solid #9b59b6}.noncombat-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.noncombat-card-name{font-weight:700;color:#fff}.noncombat-rank{display:flex;gap:3px;align-items:center}.noncombat-rank-pip{width:8px;height:8px;border-radius:50%;background:#444;border:1px solid #666}.noncombat-rank-pip.filled{background:#9b59b6;border-color:#b07cc8}.noncombat-card .skill-description{margin:0 0 .4rem}.noncombat-effect{background:#9b59b626;padding:.4rem .5rem;border-radius:4px;font-size:.85rem;color:#b07cc8;margin-bottom:.5rem}.noncombat-meta{display:flex;gap:.5rem;margin-bottom:.5rem;flex-wrap:wrap}.noncombat-meta span{font-size:.8rem;background:#ffffff14;padding:.2rem .5rem;border-radius:3px;color:#aaa}.noncombat-meta .mana-badge{color:#3498db}.noncombat-meta .cooldown-badge{color:#e67e22}.noncombat-status{font-size:.8rem;font-weight:600;margin-bottom:.5rem}.noncombat-status.ready{color:#4caf50}.noncombat-status.cooldown{color:#e67e22}.noncombat-select{width:100%;background:#1a1a2e;color:#ccc;border:1px solid #444;border-radius:4px;padding:.4rem .5rem;font-size:.85rem;margin-bottom:.5rem}.noncombat-select:focus{border-color:#9b59b6;outline:none}.noncombat-use-btn{width:100%;background:gold;color:#1a1a2e;border:none;padding:.5rem;border-radius:4px;cursor:pointer;font-weight:700;font-size:.85rem;transition:background .2s}.noncombat-use-btn:hover{background:#ffed4a}.noncombat-use-btn.disabled{background:#555;color:#888;cursor:not-allowed}.noncombat-error{background:#f443;color:#ff6b6b;padding:.4rem .5rem;border-radius:4px;font-size:.8rem;margin-bottom:.5rem}.noncombat-success{background:#4caf5033;color:#4caf50;padding:.6rem .75rem;border-radius:4px;font-size:.85rem;margin-bottom:.75rem;border:1px solid rgba(76,175,80,.3)}.skills-content::-webkit-scrollbar{width:8px}.skills-content::-webkit-scrollbar-track{background:#1a1a2e}.skills-content::-webkit-scrollbar-thumb{background:#444;border-radius:4px}.skills-content::-webkit-scrollbar-thumb:hover{background:#555}.attr-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.attr-modal{background:var(--bg-secondary, #1a1a2e);border:1px solid var(--border-color, #333);border-radius:12px;padding:1.5rem;max-width:480px;width:100%;max-height:90vh;overflow-y:auto;color:var(--text-color, #e0e0e0)}.attr-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;flex-wrap:wrap;gap:.5rem}.attr-modal-header h2{margin:0;font-size:1.2rem}.attr-points-badge{background:var(--highlight-color, #4a90d9);color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600}.attr-list{display:flex;flex-direction:column;gap:.75rem}.attr-row{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;background:#ffffff08;border-radius:8px;gap:.75rem}.attr-label{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.attr-abbr{font-weight:700;font-size:.9rem;width:2.5rem;flex-shrink:0}.attr-name-group{display:flex;flex-direction:column;min-width:0}.attr-name{font-size:.9rem;font-weight:500}.attr-desc{font-size:.7rem;opacity:.6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.attr-controls{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.attr-btn{width:28px;height:28px;border-radius:50%;border:1px solid var(--border-color, #444);background:#ffffff0d;color:var(--text-color, #e0e0e0);font-size:1rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .15s}.attr-btn:hover:not(:disabled){background:#ffffff26}.attr-btn:disabled{opacity:.3;cursor:not-allowed}.attr-btn.plus:hover:not(:disabled){border-color:#4a90d9;color:#4a90d9}.attr-btn.minus:hover:not(:disabled){border-color:#e74c3c;color:#e74c3c}.attr-value{min-width:3rem;text-align:center;font-weight:600;font-size:1rem;font-variant-numeric:tabular-nums}.attr-added{color:#2ecc71;margin-left:2px;font-size:.85rem}.attr-preview{margin-top:1rem;padding:.75rem;background:#4a90d91a;border:1px solid rgba(74,144,217,.2);border-radius:8px}.attr-preview h3{margin:0 0 .5rem;font-size:.85rem;opacity:.8}.attr-preview-stats{display:flex;gap:1.25rem;font-size:.9rem}.attr-change{color:#2ecc71;font-weight:600}.attr-modal-actions{display:flex;gap:.75rem;margin-top:1.25rem}.attr-confirm-btn{flex:1;padding:.6rem 1rem;background:var(--highlight-color, #4a90d9);color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:opacity .15s}.attr-confirm-btn:hover:not(:disabled){opacity:.9}.attr-confirm-btn:disabled{opacity:.4;cursor:not-allowed}.attr-later-btn{padding:.6rem 1rem;background:transparent;color:var(--text-color, #e0e0e0);border:1px solid var(--border-color, #444);border-radius:8px;font-size:.95rem;cursor:pointer;transition:background .15s}.attr-later-btn:hover{background:#ffffff0d}.attr-badge{background:var(--highlight-color, #4a90d9);color:#fff;border:none;padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:600;cursor:pointer;transition:opacity .15s;animation:attr-badge-pulse 2s ease-in-out infinite}.attr-badge:hover{opacity:.85}@keyframes attr-badge-pulse{0%,to{opacity:1}50%{opacity:.7}}.chat-panel{display:flex;flex-direction:column;background:#16213e;border-radius:12px;height:400px;overflow:hidden}.chat-header{padding:.75rem 1rem;background:#1a1a2e;border-bottom:1px solid #2a2a4e}.chat-header h3{margin:0;font-size:1rem;color:#e94560}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.chat-loading,.chat-empty{text-align:center;color:#888;padding:2rem}.chat-message{max-width:85%;padding:.5rem .75rem;background:#1a1a2e;border-radius:8px;word-wrap:break-word}.chat-message.own-message{align-self:flex-end;background:#2a3f5f}.chat-message.system-message{align-self:center;background:transparent;color:#888;font-size:.85rem;font-style:italic}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem;gap:.5rem}.message-author{font-weight:600;font-size:.85rem;color:#e94560}.own-message .message-author{color:#4fc3f7}.message-time{font-size:.7rem;color:#666}.message-content{font-size:.9rem;color:#fff;line-height:1.4}.message-content em{color:#aaa}.chat-input-area{display:flex;gap:.5rem;padding:.75rem;background:#1a1a2e;border-top:1px solid #2a2a4e}.chat-input-area input{flex:1;padding:.5rem .75rem;background:#0f0f23;border:1px solid #2a2a4e;border-radius:6px;color:#fff;font-size:.9rem}.chat-input-area input:focus{outline:none;border-color:#e94560}.chat-input-area input::placeholder{color:#666}.chat-input-area button{padding:.5rem 1rem;background:#e94560;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:opacity .2s}.chat-input-area button:hover:not(:disabled){opacity:.9}.chat-input-area button:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.chat-panel{height:300px}.chat-message{max-width:90%}}.character-sprite-container{display:flex;align-items:center;justify-content:center}.character-sprite-container.small{width:40px;height:40px}.character-sprite-container.medium{width:96px;height:96px}.character-sprite{width:100%;height:100%;image-rendering:pixelated}.character-sprite-container.downed{opacity:.5;filter:grayscale(.8)}.character-sprite-container.current-user .character-sprite{filter:drop-shadow(0 0 3px rgba(255,215,0,.6))}.character-sprite-container.downed.current-user .character-sprite{filter:none}.character-sprite-container.medium .character-sprite{animation:idleBreathe 3s ease-in-out infinite}.character-sprite-container.medium.downed .character-sprite{animation:none}@keyframes idleBreathe{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.character-sprite-container.aura-faint-ember{box-shadow:0 0 6px 2px #ff572266,inset 0 0 4px #ff572226;border-radius:4px}.character-sprite-container.aura-frost-wisp{box-shadow:0 0 6px 2px #42a5f566,inset 0 0 4px #42a5f526;border-radius:4px}.character-sprite-container.aura-verdant-bloom{box-shadow:0 0 8px 3px #4caf5073,inset 0 0 5px #4caf5026;border-radius:4px}.character-sprite-container.aura-shadow-veil{box-shadow:0 0 8px 3px #37474f99,inset 0 0 5px #0000004d;border-radius:4px}.character-sprite-container.aura-golden-radiance{box-shadow:0 0 10px 4px #ffd70080,inset 0 0 6px #ffd70033;border-radius:4px;animation:auraPulse 2s ease-in-out infinite}.character-sprite-container.aura-void-rift{box-shadow:0 0 10px 4px #7c4dff80,inset 0 0 6px #7c4dff33;border-radius:4px;animation:auraPulse 2s ease-in-out infinite}.character-sprite-container.aura-phoenix-flame{box-shadow:0 0 12px 5px #ff572299,0 0 20px 8px #ff98004d;border-radius:4px;animation:auraFlicker 1.5s ease-in-out infinite}@keyframes auraPulse{0%,to{filter:brightness(1)}50%{filter:brightness(1.15)}}@keyframes auraFlicker{0%,to{opacity:1}25%{opacity:.88}50%{opacity:1}75%{opacity:.92}}.character-sprite-container.downed[class*=aura-]{box-shadow:none;animation:none}.room-grid-container{position:relative;padding:.75rem;background:#1a1a2e;border-radius:8px;--fog-color: #0d0d1a;--cell-size: 56px}.room-grid-empty{display:flex;align-items:center;justify-content:center;min-height:200px;color:#6a6a7a}.room-grid-scroll{max-height:min(65vh,480px);overflow:auto;scroll-behavior:smooth;position:relative;border-radius:4px;scrollbar-width:thin;scrollbar-color:rgba(100,80,160,.3) transparent}.room-grid-scroll::-webkit-scrollbar{width:5px;height:5px}.room-grid-scroll::-webkit-scrollbar-track{background:transparent}.room-grid-scroll::-webkit-scrollbar-thumb{background:#6450a04d;border-radius:3px}.room-grid-inner{position:relative;width:fit-content;margin:0 auto;padding:4px}.room-grid{display:grid;gap:5px;position:relative;z-index:2;width:fit-content}.room-cell{width:var(--cell-size, 56px);height:var(--cell-size, 56px);min-width:0;border-radius:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;cursor:default;transition:all .25s ease;border:1.5px solid transparent;background:#12121f;padding:1px;overflow:hidden}.room-cell.empty{background:transparent;border:none}.room-cell.hidden{visibility:hidden}.room-cell.adjacent{border-color:#6450a033}.room-cell.adjacent.unexplored{opacity:.4}.room-cell.visible{border-color:#6450a026}.room-cell.explored{opacity:1;border-color:#8c78b440}.room-cell.cleared{opacity:.6;border-color:#6450a026}.room-cell.current{border-color:#a855f7b3!important;box-shadow:0 0 12px #a855f773,0 0 24px #a855f726;transform:scale(1.06);opacity:1!important;animation:currentRoomPulse 2.5s ease-in-out infinite;z-index:3}@keyframes currentRoomPulse{0%,to{box-shadow:0 0 10px #a855f759,0 0 20px #a855f71a;border-color:#a855f799}50%{box-shadow:0 0 16px #a855f78c,0 0 30px #a855f733;border-color:#a855f7d9}}.room-cell.can-move{cursor:pointer;animation:canMovePulse 2s ease-in-out infinite}.room-cell.can-move:hover{transform:scale(1.1);box-shadow:0 0 10px #a8825059;border-color:#a8825099}@keyframes canMovePulse{0%,to{border-color:#a8825033}50%{border-color:#a8825080}}.room-cell:disabled{cursor:not-allowed}.room-cell.locked{border-color:#b4963c80!important;box-shadow:0 0 6px #b4963c33;cursor:pointer}.room-cell.locked:hover{box-shadow:0 0 10px #b4963c66;transform:scale(1.05)}.locked-popup{position:absolute;bottom:0;left:50%;transform:translate(-50%);background:#281e0ff2;border:1px solid rgba(180,150,60,.6);color:#e8d48b;padding:.5rem 1rem;border-radius:6px;font-size:.85rem;z-index:20;white-space:nowrap;cursor:pointer;animation:lockedPopupIn .25s ease-out;box-shadow:0 2px 12px #00000080}@keyframes lockedPopupIn{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.room-tile-svg{width:100%;height:auto;display:block}.room-number{font-size:.45rem;color:#b4b4c84d;position:absolute;bottom:0;left:2px;line-height:1;text-shadow:0 0 2px rgba(0,0,0,.9);font-family:monospace}.room-avatars{position:absolute;bottom:-2px;right:-2px;display:flex;gap:0px;z-index:3}.room-avatar{width:12px;height:12px;display:block}.room-avatar .character-sprite-container{width:12px!important;height:12px!important}.room-avatar .character-sprite-container svg{width:12px!important;height:12px!important}.current-indicator{position:absolute;top:-3px;right:-3px;width:14px;height:14px;z-index:3}.current-indicator .character-sprite-container{width:14px!important;height:14px!important}.current-indicator .character-sprite-container svg{width:14px!important;height:14px!important}.cleared-indicator{position:absolute;bottom:0;right:2px;font-size:.5rem;color:#4a6a4a;font-weight:700;line-height:1;text-shadow:0 0 2px rgba(0,0,0,.9)}.room-connections{position:absolute;inset:4px;pointer-events:none;z-index:1}.connection-path{stroke:#6446a033;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;fill:none}.connection-path.explored{stroke:#8c64c84d;stroke-width:3.5}.connection-path.locked{stroke:#b4963c59;stroke-width:2.5;stroke-dasharray:6 4}.room-grid-container[data-theme=crypt] .connection-path.explored{stroke:#a050c84d}.room-grid-container[data-theme=cave] .connection-path.explored{stroke:#a078504d}.room-grid-container[data-theme=forest] .connection-path.explored{stroke:#50a0644d}.room-grid-container[data-theme=fire] .connection-path.explored{stroke:#c864464d}.room-grid-container[data-theme=ice] .connection-path.explored{stroke:#508cc84d}.room-legend{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem;padding-top:.6rem;border-top:1px solid rgba(100,80,160,.15);max-width:600px;margin-left:auto;margin-right:auto;opacity:.55;transition:opacity .2s ease}.room-legend:hover{opacity:.85}.legend-item{display:flex;align-items:center;gap:.2rem;font-size:.6rem;color:#7a7a8e}.legend-tile{display:inline-block;width:14px;height:14px;border-radius:2px;overflow:hidden}.legend-tile .room-tile-svg{width:14px;height:14px}@media(max-width:768px){.room-grid-scroll{max-height:min(60vh,420px)}.room-grid{gap:4px}.room-legend{display:none}.room-avatar{width:10px;height:10px}}@media(max-width:480px){.room-grid-container{padding:.4rem;border-radius:6px}.room-grid-scroll{max-height:min(55vh,360px)}.room-grid{gap:3px}.room-cell{border-radius:3px}.room-number{font-size:.35rem}.room-avatar{width:9px;height:9px}.current-indicator{width:11px;height:11px;top:-2px;right:-2px}.cleared-indicator{font-size:.45rem;right:1px;bottom:0}}@media(max-width:360px){.room-number{display:none}.current-indicator{width:9px;height:9px;top:-1px;right:-1px}.cleared-indicator{display:none}}.item-sprite{image-rendering:pixelated;flex-shrink:0}.room-event-panel{background:#16213e;border-radius:12px;padding:1.5rem;min-height:200px}.room-event-panel.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#8b8b8b}.room-event-panel.empty h3{margin:0 0 .5rem}.room-content{text-align:center}.room-icon-large{font-size:3rem;margin-bottom:1rem}.room-content h3{margin:0 0 1rem;font-size:1.25rem}.room-content p{margin:.5rem 0;color:#ccc}.cleared-text{color:#4caf50!important;font-style:italic}.warning-text{color:#f44336!important;font-weight:600}.action-btn{margin-top:1rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.action-btn:disabled{opacity:.5;cursor:not-allowed}.treasure-btn{background:linear-gradient(135deg,#f57f17,#ff8f00);color:#fff}.treasure-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 15px #f57f1766}.rest-btn{background:linear-gradient(135deg,#1976d2,#2196f3);color:#fff}.rest-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 15px #2196f366}.treasure-info{font-size:1.5rem;margin:1rem 0;color:#ffca28}.trap-info{font-size:1.25rem;margin:1rem 0;color:#f44336}.gold-display{font-size:1.1rem;color:#ffca28!important;font-weight:600;margin-bottom:1rem!important}.shop-items{display:flex;flex-direction:column;gap:.75rem;max-height:300px;overflow-y:auto;text-align:left}.shop-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#1a1a2e;border-radius:8px}.item-info{display:flex;flex-direction:column;gap:.25rem}.item-name{font-weight:600}.item-name.rarity-common{color:#9e9e9e}.item-name.rarity-uncommon{color:#4caf50}.item-name.rarity-rare{color:#2196f3}.item-name.rarity-epic{color:#9c27b0}.item-name.rarity-legendary{color:#ff9800}.item-type{font-size:.75rem;color:#8b8b8b;text-transform:capitalize}.item-price{display:flex;align-items:center;gap:.75rem}.buy-btn{padding:.4rem .75rem;font-size:.85rem;background:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:opacity .2s}.buy-btn:hover:not(:disabled){opacity:.9}.buy-btn:disabled{background:#666;cursor:not-allowed}.pipe-flow-puzzle{width:100%;max-width:400px;margin:0 auto;aspect-ratio:1;-webkit-user-select:none;user-select:none}.pipe-grid{display:grid;gap:2px;width:100%;height:100%;background:#14142880;border-radius:8px;padding:4px}.pipe-cell{position:relative;background:#1a1a2e;border-radius:4px;cursor:pointer;transition:background .15s;aspect-ratio:1;display:flex;align-items:center;justify-content:center}.pipe-cell:hover{background:#252545}.pipe-cell.endpoint-cell,.pipe-cell.filled{cursor:grab}.pipe-cell.filled{background:#ffffff0d}.pipe-cell.complete{background:#ffffff14}.pipe-cell.solved-cell.complete{animation:solvedPulse .4s ease forwards}@keyframes solvedPulse{0%{box-shadow:none}50%{box-shadow:0 0 12px #00e5ff80}to{box-shadow:0 0 6px #00e5ff40}}.pipe-tile-svg{width:100%;height:100%;pointer-events:none}.pipe-flow-puzzle.solved .pipe-cell{cursor:default}.pipe-flow-puzzle.solved .pipe-cell:hover{background:#1a1a2e}.pipe-rotation-puzzle{width:100%;max-width:400px;margin:0 auto;aspect-ratio:1;-webkit-user-select:none;user-select:none}.pipe-rotation-grid{display:grid;gap:2px;width:100%;height:100%;background:#14142880;border-radius:8px;padding:4px}.pipe-rotation-cell{position:relative;background:#1a1a2e;border-radius:4px;cursor:pointer;transition:background .15s;aspect-ratio:1;display:flex;align-items:center;justify-content:center}.pipe-rotation-cell:hover{background:#252545}.pipe-rotation-cell.connected{background:#00e5ff14}.pipe-rotation-cell.source-cell{background:#4caf501a}.pipe-rotation-cell.drain-cell{background:#ff98001a}.pipe-rotation-cell.solved-cell{animation:rotationSolvedPulse .4s ease forwards}@keyframes rotationSolvedPulse{0%{box-shadow:none}50%{box-shadow:0 0 12px #00e5ff80}to{box-shadow:0 0 6px #00e5ff40}}.pipe-rotation-svg{width:100%;height:100%;pointer-events:none}.pipe-rotation-puzzle.solved .pipe-rotation-cell{cursor:default}.pipe-rotation-puzzle.solved .pipe-rotation-cell:hover{background:#1a1a2e}.lights-out-puzzle{width:100%;max-width:400px;margin:0 auto;aspect-ratio:1}.lights-out-grid{display:grid;gap:4px;width:100%;height:100%;background:#14142880;border-radius:8px;padding:6px}.lights-out-cell{position:relative;border-radius:6px;cursor:pointer;aspect-ratio:1;display:flex;align-items:center;justify-content:center;transition:background .15s,box-shadow .15s}.lights-out-cell.off{background:#1a1a2e;border:1px solid rgba(60,60,100,.3)}.lights-out-cell.on{background:#ffca28;box-shadow:0 0 12px #ffca2880,inset 0 0 8px #fff3;border:1px solid rgba(255,202,40,.6)}.lights-out-cell:hover{transform:scale(.95)}.lights-out-cell:active{transform:scale(.88)}.lights-out-cell.toggled{animation:lightToggle .3s ease}@keyframes lightToggle{0%{transform:scale(1)}50%{transform:scale(.85)}to{transform:scale(1)}}.lights-out-puzzle.solved .lights-out-cell{cursor:default}.lights-out-puzzle.solved .lights-out-cell:hover{transform:none}.lights-out-puzzle.solved .lights-out-cell.off{animation:lightsOutSolvedPulse .5s ease forwards}@keyframes lightsOutSolvedPulse{0%{box-shadow:none}50%{box-shadow:0 0 16px #4caf5099;background:#4caf5033}to{box-shadow:0 0 8px #4caf504d;background:#4caf501a}}.puzzle-box-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.puzzle-box-modal{position:relative;background:#16162a;border:1px solid rgba(100,80,160,.3);border-radius:12px;padding:1.5rem;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0009}.puzzle-box-close{position:absolute;top:.5rem;right:.75rem;background:none;border:none;color:#8b8b8b;font-size:1.5rem;cursor:pointer;padding:.25rem;line-height:1;transition:color .15s}.puzzle-box-close:hover{color:#fff}.puzzle-box-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.puzzle-box-header h3{margin:0;font-size:1.1rem;color:#e0e0e0}.puzzle-box-size{font-size:.8rem;color:#7c4dff;background:#7c4dff1a;padding:.2rem .5rem;border-radius:4px}.puzzle-box-hint{font-size:.75rem;color:#8b8b8b;margin:0 0 .75rem}.puzzle-box-rolling{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;gap:1rem}.rolling-box-icon{font-size:3rem;animation:rollingBounce .6s ease infinite alternate}@keyframes rollingBounce{0%{transform:translateY(0) rotate(-5deg)}to{transform:translateY(-10px) rotate(5deg)}}.rolling-text{font-size:1.1rem;color:#ccc;animation:rollingPulse .8s ease infinite}@keyframes rollingPulse{0%,to{opacity:1}50%{opacity:.5}}.rolling-spinner{width:32px;height:32px;border:3px solid rgba(124,77,255,.2);border-top-color:#7c4dff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.puzzle-box-next-layer{text-align:center;padding:2rem 1rem}.next-layer-icon{font-size:2.5rem;margin-bottom:.5rem}.puzzle-box-next-layer h3{margin:0 0 .5rem;font-size:1.2rem;color:#ce93d8}.puzzle-box-next-layer p{color:#9ca3af;margin:0 0 .5rem;font-size:.9rem}.next-layer-info{color:#7c4dff!important;font-weight:600;font-size:.85rem!important;margin-bottom:1rem!important}.solve-time-info{font-size:.8rem;color:#888;margin-bottom:.75rem}.next-layer-btn{padding:.6rem 2rem;background:#7c4dff;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:.95rem;transition:background .15s}.next-layer-btn:hover{background:#651fff}.puzzle-box-reward{text-align:center;padding:1.5rem .5rem}.reward-burst-icon{font-size:2.5rem;margin-bottom:.5rem;animation:rewardPop .5s ease}@keyframes rewardPop{0%{transform:scale(0)}60%{transform:scale(1.3)}to{transform:scale(1)}}.puzzle-box-reward h3{margin:0 0 .25rem;font-size:1.2rem;color:#ffca28}.reward-layer-bonus{font-size:.85rem;color:#ce93d8;margin-bottom:1rem;font-weight:600}.puzzle-reward-list{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.25rem}.puzzle-reward-entry{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#1a1a2ecc;border-radius:6px;font-size:.9rem}.puzzle-reward-entry.gold{color:#ffca28}.puzzle-reward-entry.no-items{color:#8b8b8b;font-style:italic}.puzzle-reward-icon{font-size:1rem}.puzzle-reward-rarity{margin-left:auto;font-size:.7rem;text-transform:capitalize;font-weight:600}.puzzle-reward-rarity.rarity-common{color:#9e9e9e}.puzzle-reward-rarity.rarity-uncommon{color:#4caf50}.puzzle-reward-rarity.rarity-rare{color:#2196f3}.puzzle-reward-rarity.rarity-epic{color:#9c27b0}.puzzle-reward-rarity.rarity-legendary{color:#ff9800}.puzzle-reward-actions{display:flex;gap:.5rem;justify-content:center}.collect-btn{padding:.6rem 2rem;background:#4caf50;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:.95rem;transition:background .15s}.collect-btn:hover{background:#43a047}.open-another-btn{padding:.6rem 1.5rem;background:#7c4dff;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:.95rem;transition:background .15s}.open-another-btn:hover{background:#651fff}.inventory-panel{padding:.5rem;max-width:100%;overflow-x:hidden;box-sizing:border-box}.inventory-panel h2{margin:0 0 1rem;text-align:center}.gold-display{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:1.25rem;font-weight:600;color:#ffca28;margin-bottom:1rem}.inventory-tabs{display:flex;gap:.5rem;margin-bottom:1rem;position:sticky;top:0;z-index:5;background:var(--color-background-secondary, #16213e);padding:.25rem 0}.tab-btn{flex:1;padding:.75rem;background:#1a1a2e;color:#8b8b8b;border:2px solid transparent;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .2s}.tab-btn:hover{background:#252545}.tab-btn.active{color:#fff;border-color:#e94560;background:#252545}.consumable-hotbar{display:flex;gap:.4rem;margin-bottom:.75rem;padding:.4rem;background:#1a1a2e99;border-radius:6px;overflow-x:auto}.hotbar-item{position:relative;display:flex;align-items:center;gap:.25rem;padding:.3rem .5rem;background:#252545;border:1.5px solid rgba(100,80,160,.25);border-radius:6px;cursor:pointer;font-size:.8rem;color:#ccc;white-space:nowrap;transition:all .15s}.hotbar-item:hover{border-color:#6450a099;background:#2e2e50}.hotbar-icon{font-size:.85rem}.hotbar-qty{font-size:.7rem;color:#9ca3af}.hotbar-puzzle{border-color:#7c4dff4d}.hotbar-puzzle:hover{border-color:#7c4dff99;background:#7c4dff1a}.filter-sort-bar{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.75rem}.filter-pills{display:flex;gap:.3rem;flex-wrap:wrap}.filter-pill{padding:.25rem .55rem;background:#1a1a2e;color:#8b8b8b;border:1.5px solid transparent;border-radius:12px;cursor:pointer;font-size:.7rem;transition:all .15s}.filter-pill:hover{color:#bbb;border-color:#6450a04d}.filter-pill.active{color:#fff;background:#352550;border-color:#7c4dff}.sort-controls{display:flex;gap:.4rem;align-items:center}.sort-select{padding:.25rem .4rem;background:#1a1a2e;color:#aaa;border:1px solid rgba(100,80,160,.2);border-radius:6px;font-size:.7rem;cursor:pointer}.sort-select:focus{outline:none;border-color:#7c4dff}.select-mode-btn{padding:.25rem .45rem;background:#1a1a2e;color:#8b8b8b;border:1.5px solid transparent;border-radius:6px;cursor:pointer;font-size:.8rem;transition:all .15s}.select-mode-btn:hover{border-color:#6450a04d}.select-mode-btn.active{color:#ff9800;border-color:#ff9800;background:#ff98001a}.bulk-actions-bar{display:flex;gap:.4rem;margin-bottom:.5rem}.bulk-select-common{padding:.3rem .6rem;background:#9e9e9e26;color:#9e9e9e;border:1px solid rgba(158,158,158,.3);border-radius:6px;cursor:pointer;font-size:.7rem;transition:all .15s}.bulk-select-common:hover{background:#9e9e9e40;color:#ccc}.bulk-clear{padding:.3rem .6rem;background:transparent;color:#8b8b8b;border:1px solid rgba(100,80,160,.2);border-radius:6px;cursor:pointer;font-size:.7rem}.batch-sell-bar{display:flex;justify-content:space-between;align-items:center;padding:.6rem .75rem;margin-top:.5rem;background:#ff98001a;border:1px solid rgba(255,152,0,.3);border-radius:8px;animation:batchBarSlideIn .2s ease}@keyframes batchBarSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.batch-sell-info{font-size:.85rem;color:#ddd}.batch-sell-btn{padding:.4rem 1rem;background:#ff9800;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;font-size:.85rem;transition:background .15s}.batch-sell-btn:hover{background:#f57c00}.inventory-content{margin-bottom:1rem}.empty-text{text-align:center;color:#8b8b8b;font-style:italic;padding:2rem}.inventory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:.5rem;max-height:300px;overflow-y:auto}.inventory-item{position:relative;background:#1a1a2e;border-radius:8px;padding:.6rem .7rem;cursor:pointer;border:2px solid transparent;transition:all .2s}.inventory-item:hover{transform:translateY(-2px)}.inventory-item.selected{border-color:#e94560}.inventory-item.select-mode{padding-left:1.6rem}.item-checkbox{position:absolute;left:.5rem;top:50%;transform:translateY(-50%);width:14px;height:14px;border:2px solid #555;border-radius:3px;transition:all .15s}.item-checkbox.checked{background:#ff9800;border-color:#ff9800}.item-checkbox.checked:after{content:"✓";position:absolute;top:-2px;left:1px;font-size:.6rem;color:#fff;font-weight:700}.inventory-item.rarity-common{border-left:3px solid #9e9e9e}.inventory-item.rarity-uncommon{border-left:3px solid #4caf50}.inventory-item.rarity-rare{border-left:3px solid #2196f3}.inventory-item.rarity-epic{border-left:3px solid #9c27b0}.inventory-item.rarity-legendary{border-left:3px solid #ff9800}.item-header{display:flex;justify-content:space-between;align-items:center;gap:.4rem;margin-bottom:.25rem}.item-name{font-weight:600;font-size:.85rem}.item-quantity{background:#e94560;padding:.1rem .4rem;border-radius:4px;font-size:.7rem}.item-meta{display:flex;justify-content:space-between;font-size:.7rem}.item-type{color:#8b8b8b;text-transform:capitalize}.item-rarity{text-transform:capitalize}.rarity-common{color:#9e9e9e}.rarity-uncommon{color:#4caf50}.rarity-rare{color:#2196f3}.rarity-epic{color:#9c27b0}.rarity-legendary{color:#ff9800}.new-item{animation:newItemGlow 2s ease-in-out infinite}@keyframes newItemGlow{0%,to{box-shadow:0 0 #4caf5000}50%{box-shadow:0 0 8px #4caf5059}}.new-badge{position:absolute;top:-4px;right:-4px;padding:.1rem .35rem;background:#4caf50;color:#fff;font-size:.55rem;font-weight:700;border-radius:4px;letter-spacing:.5px;line-height:1.2;z-index:2}.quick-use-btn{position:absolute;bottom:4px;right:4px;width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:#2196f326;border:1px solid rgba(33,150,243,.3);border-radius:50%;cursor:pointer;font-size:.6rem;transition:all .15s;padding:0;z-index:2}.quick-use-btn:hover{background:#2196f359;border-color:#2196f399;transform:scale(1.15)}.quick-target-backdrop{position:fixed;inset:0;z-index:199;background:#0000004d}.quick-target-popover{position:fixed;bottom:80px;left:50%;transform:translate(-50%);width:220px;background:#1e1e3a;border:1px solid rgba(100,80,160,.4);border-radius:10px;padding:.5rem;z-index:200;box-shadow:0 4px 20px #0009}.quick-target-header{color:#888;font-size:.75rem;padding:.2rem .4rem .3rem;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:.2rem}.quick-target-row{display:flex;justify-content:space-between;align-items:center;padding:.3rem .4rem;border-radius:4px;cursor:pointer;transition:background .1s}.quick-target-row:hover{background:#ffffff14}.quick-target-name{font-size:.7rem;color:#ddd}.quick-target-hp{font-size:.65rem;font-weight:600}.equipment-section{display:flex;flex-direction:column;gap:.75rem}.paper-doll{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem;background:#1a1a2e80;border-radius:8px}.paper-doll-slot{min-width:110px}.paper-doll-center{display:flex;align-items:center;gap:.5rem;width:100%;justify-content:center}.paper-doll-sprite{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:#6450a01a;border:2px solid rgba(100,80,160,.2);border-radius:8px;flex-shrink:0}.paper-doll-sprite .character-sprite-container{width:48px!important;height:48px!important}.paper-doll-sprite .character-sprite-container svg{width:48px!important;height:48px!important}.paper-doll-bottom{display:flex;gap:.5rem;width:100%;justify-content:center}.equipment-slot{background:#1a1a2e;border-radius:6px;padding:.5rem .6rem;min-width:100px;flex:1;max-width:140px}.equipment-slot.rarity-border-common{border-left:2px solid #9e9e9e}.equipment-slot.rarity-border-uncommon{border-left:2px solid #4caf50}.equipment-slot.rarity-border-rare{border-left:2px solid #2196f3}.equipment-slot.rarity-border-epic{border-left:2px solid #9c27b0}.equipment-slot.rarity-border-legendary{border-left:2px solid #ff9800}.slot-label{font-size:.6rem;color:#8b8b8b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.equipped-item{display:flex;justify-content:space-between;align-items:center;gap:.3rem}.equipped-name{font-size:.75rem;font-weight:600;color:#ddd;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.unequip-btn{padding:.15rem .35rem;background:#f4433633;color:#f44336;border:1px solid rgba(244,67,54,.3);border-radius:4px;font-size:.65rem;cursor:pointer;flex-shrink:0;transition:all .15s}.unequip-btn:hover{background:#f4433659}.empty-slot{color:#555;font-style:italic;font-size:.75rem}.equipment-stats{background:#252545;border-radius:8px;padding:.75rem}.equipment-stats h4{margin:0 0 .5rem;font-size:.85rem;color:#8b8b8b}.stat-row{display:flex;justify-content:space-between;padding:.2rem 0;font-size:.85rem}.stat-value{color:#4caf50;font-weight:600}.item-details-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1100;padding:1rem}.item-details{position:relative;background:#252545;border-radius:12px;padding:1.25rem;border:1px solid #3a3a5c;max-width:400px;width:90%;max-height:85vh;overflow-y:auto;box-shadow:0 8px 32px #00000080;animation:itemDetailsFadeIn .15s ease}@keyframes itemDetailsFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.item-details-close{position:absolute;top:.5rem;right:.5rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:6px;color:#aaa;font-size:.8rem;cursor:pointer;transition:all .15s;padding:0}.item-details-close:hover{background:#ffffff26;color:#fff}.item-details-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.item-details-header h4{margin:0}.item-details h4{margin:0 0 .5rem}.item-description{color:#8b8b8b;font-size:.85rem;margin:0 0 .75rem}.item-stats{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.75rem;font-size:.9rem}.special-effect{color:#ce93d8}.stat-comparison{padding:.5rem .6rem;margin-bottom:.75rem;background:#0003;border-radius:6px;border-left:3px solid rgba(100,80,160,.4)}.comparison-label{font-size:.7rem;color:#8b8b8b;margin-bottom:.3rem}.comparison-deltas{display:flex;gap:.75rem;font-size:.85rem;font-weight:600}.delta-positive{color:#4caf50}.delta-negative{color:#f44336}.delta-neutral{color:#8b8b8b;font-weight:400;font-style:italic;font-size:.8rem}.item-requirements{display:flex;gap:1rem;font-size:.8rem;color:#8b8b8b;margin-bottom:.75rem}.item-actions{display:flex;gap:.5rem}.equip-btn{flex:1;padding:.5rem;background:#4caf50;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600}.sell-btn{padding:.5rem 1rem;background:#ff9800;color:#fff;border:none;border-radius:6px;cursor:pointer}.use-btn{flex:1;padding:.5rem;background:#2196f3;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600}.open-btn{flex:1;padding:.5rem;background:#7c4dff;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600}.equip-btn:hover,.sell-btn:hover,.use-btn:hover,.open-btn:hover{opacity:.9}.use-target-selector{margin-top:.75rem;background:#0000004d;border-radius:8px;padding:.5rem}.target-selector-label{font-size:.8rem;color:#9ca3af;margin-bottom:.5rem}.target-row{display:flex;align-items:center;justify-content:space-between;padding:.5rem;border-radius:6px;cursor:pointer;transition:background .15s}.target-row:hover{background:#ffffff1a}.target-name{font-weight:600;font-size:.85rem}.target-hp{display:flex;align-items:center;gap:.5rem}.target-hp-bar{width:60px;height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden}.target-hp-fill{height:100%;border-radius:4px;transition:width .2s}.target-hp-text{font-size:.75rem;color:#9ca3af;min-width:55px;text-align:right}@media(max-width:480px){.filter-sort-bar{flex-direction:column;align-items:stretch}.filter-pills{flex-wrap:wrap;padding-bottom:2px}.filter-pill{min-height:36px;display:flex;align-items:center}.sort-controls{justify-content:flex-end}.bulk-actions-bar{flex-wrap:wrap}.inventory-grid{grid-template-columns:1fr}.paper-doll-center{flex-direction:column}.paper-doll-slot{min-width:0;width:100%}.paper-doll-bottom{flex-direction:column;gap:.4rem}.equipment-slot{min-width:0;max-width:none}.batch-sell-bar{flex-direction:column;gap:.4rem;text-align:center}.item-actions{flex-wrap:wrap}.item-actions button{min-height:44px}.item-stats{gap:.5rem;font-size:.8rem}.item-details-overlay{padding:.5rem}.item-details{max-width:95%;width:95%;max-height:80vh}.comparison-deltas{flex-wrap:wrap;gap:.4rem}.consumable-hotbar{gap:.3rem;overflow-x:visible;flex-wrap:wrap}.hotbar-item{font-size:.7rem;padding:.2rem .4rem;min-height:36px}.quick-target-popover{left:0;right:0;bottom:70px;width:auto;transform:none;border-radius:12px 12px 0 0;padding:.75rem;animation:slideUpSheet .15s ease-out}.quick-target-row{padding:.6rem .5rem;min-height:44px}.inventory-tabs{gap:.3rem}.tab-btn{padding:.5rem .3rem;font-size:.8rem;min-height:44px}}.quest-item-bar{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#ffffff08;border-radius:8px;margin:.5rem 16px;overflow-x:auto}.quest-item-bar-label{color:#888;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.quest-item-bar-items{display:flex;gap:.4rem;flex-wrap:wrap}.quest-item-btn{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border:1px solid #444;border-radius:6px;background:#1a1a2e;color:#ccc;cursor:pointer;font-size:.8rem;transition:all .15s;white-space:nowrap}.quest-item-btn:hover:not(.disabled){border-color:#888;background:#252545}.quest-item-btn.disabled{opacity:.5;cursor:not-allowed}.quest-item-btn.rarity-uncommon{border-color:#4caf50}.quest-item-btn.rarity-rare{border-color:#2196f3}.quest-item-btn.rarity-epic{border-color:#9c27b0}.quest-item-btn.rarity-legendary{border-color:#ff9800}.quest-item-icon{font-size:.9rem}.quest-item-qty{color:#aaa;font-size:.7rem}.quest-target-backdrop{position:fixed;inset:0;z-index:199;background:#0000004d}.quest-target-popover{position:fixed;bottom:80px;left:50%;transform:translate(-50%);width:220px;z-index:200;background:#1e1e3a;border:1px solid rgba(100,80,160,.4);border-radius:10px;padding:.5rem;box-shadow:0 4px 20px #0009}.quest-target-header{color:#888;font-size:.75rem;padding:.2rem .4rem .3rem;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:.2rem}.quest-target-row{display:flex;justify-content:space-between;align-items:center;padding:.3rem .5rem;border-radius:4px;cursor:pointer;font-size:.8rem;color:#ccc}.quest-target-row:hover{background:#ffffff14}.quest-target-name{color:#ddd}.quest-target-hp{font-size:.75rem;font-weight:600}@media(max-width:480px){.quest-target-popover{left:0;right:0;bottom:70px;width:auto;transform:none;border-radius:12px 12px 0 0;padding:.75rem;animation:slideUpSheet .15s ease-out}.quest-target-row{padding:.6rem .5rem;min-height:44px}}@keyframes slideUpSheet{0%{transform:translateY(100%)}to{transform:translateY(0)}}.monster-sprite-container{display:flex;align-items:center;justify-content:center;width:200px;height:200px;animation:monsterAppear .5s ease-out}.monster-sprite-container.boss{width:280px;height:280px;animation:bossAppear .8s ease-out}.monster-sprite{width:100%;height:100%;transition:transform .3s ease;image-rendering:pixelated}.monster-sprite.boss{filter:drop-shadow(0 0 20px rgba(156,39,176,.6))}.monster-sprite.hit{animation:shake .4s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}15%{transform:translate(-12px) rotate(-2deg)}30%{transform:translate(10px) rotate(2deg)}45%{transform:translate(-8px) rotate(-1deg)}60%{transform:translate(6px) rotate(1deg)}75%{transform:translate(-4px)}90%{transform:translate(2px)}}@keyframes monsterAppear{0%{opacity:0;transform:scale(.8) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes bossAppear{0%{opacity:0;transform:scale(.5) translateY(50px);filter:brightness(2)}50%{opacity:1;transform:scale(1.1) translateY(-10px);filter:brightness(1.3)}to{opacity:1;transform:scale(1) translateY(0);filter:brightness(1)}}@media(max-width:768px){.monster-sprite-container{width:150px;height:150px}.monster-sprite-container.boss{width:200px;height:200px}}@media(max-width:480px){.monster-sprite-container{width:120px;height:120px}.monster-sprite-container.boss{width:160px;height:160px}}.party-battle-status{width:100%}.party-cards{display:flex;flex-direction:column;gap:.5rem}.party-card{background:#0000004d;border:2px solid color-mix(in srgb,var(--color-highlight) 25%,transparent);border-radius:10px;padding:.5rem .75rem;display:flex;align-items:center;gap:.75rem;position:relative;transition:transform .2s,border-color .2s}.party-card.current-user{border-color:var(--color-highlight)}.party-card.downed{opacity:.6;filter:grayscale(.3)}.party-card.damage-flash{animation:damageFlash .5s ease-out}@keyframes damageFlash{0%{background:#f4433666;transform:scale(1.05)}to{background:#0000004d;transform:scale(1)}}.party-card.heal-flash{animation:healFlash .5s ease-out}@keyframes healFlash{0%{background:#4caf5066;transform:scale(1.05)}to{background:#0000004d;transform:scale(1)}}.card-icon{width:32px;height:32px;flex-shrink:0}.card-info{flex:1;min-width:0}.card-name{font-weight:600;font-size:.85rem;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.you-marker{color:var(--color-highlight);margin-left:.25rem}.card-class{font-size:.65rem;color:#8b8b8b;text-transform:capitalize}.card-health-bar{height:8px;background:#0006;border-radius:4px;overflow:hidden;margin-top:.25rem}.card-health-fill{height:100%;background:linear-gradient(90deg,#4caf50,#81c784);border-radius:5px;transition:width .3s ease}.card-health-fill.low{background:linear-gradient(90deg,#f44336,#ff7043)}.card-health-fill.downed{background:linear-gradient(90deg,#7b1fa2,#ab47bc)}.card-health-bar{position:relative}.threshold-marker{position:absolute;left:50%;top:0;bottom:0;width:2px;background:#fff6;pointer-events:none}.card-health-text{font-size:.75rem;color:#ccc}.card-health-text.low{color:#ff7043}.card-mana-bar{height:4px;background:#0006;border-radius:2px;overflow:hidden;margin-top:2px}.card-mana-fill{height:100%;background:linear-gradient(90deg,#42a5f5,#90caf9);border-radius:2px;transition:width .3s ease}.card-mana-text{font-size:.65rem;color:#90caf9}.downed-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#00000080;border-radius:10px;font-size:.8rem;font-weight:700;color:#ff9800;letter-spacing:2px}@media(max-width:700px){.party-cards{flex-direction:row;flex-wrap:wrap;justify-content:center;gap:.4rem}.party-card{flex-direction:column;text-align:center;padding:.4rem .6rem;min-width:75px;gap:.25rem}.card-icon{width:24px;height:24px}.card-name{font-size:.75rem}.card-class{display:none}.card-health-bar{height:6px;margin-top:.15rem}.card-health-text{font-size:.6rem}}.combat-actions{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1rem;width:100%}.combat-actions.cleared{justify-content:center}.victory-message{font-size:2rem;font-weight:700;color:#4caf50;text-shadow:0 0 20px rgba(76,175,80,.5);animation:victoryPulse 1s ease-in-out infinite}.attack-button{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 3rem;font-size:1.5rem;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--color-button) 0%,var(--color-button-hover) 100%);border:none;border-radius:12px;cursor:pointer;transition:all .2s;box-shadow:0 4px 15px color-mix(in srgb,var(--color-button) 40%,transparent);min-width:200px}.attack-button:hover:not(:disabled){transform:translateY(-2px) scale(1.02);box-shadow:0 6px 20px color-mix(in srgb,var(--color-button) 50%,transparent)}.attack-button:active:not(:disabled){transform:translateY(0) scale(.98)}.attack-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.attack-icon{font-size:1.75rem}.attack-text{letter-spacing:2px}.loading-text{font-size:1.25rem;letter-spacing:1px}.skill-buttons{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem}.skill-button{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem 1.25rem;background:linear-gradient(135deg,color-mix(in srgb,var(--color-highlight) 80%,#7c4dff),color-mix(in srgb,var(--color-highlight) 60%,#651fff));border:none;border-radius:8px;color:#fff;cursor:pointer;transition:all .2s;min-width:100px}.skill-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px color-mix(in srgb,var(--color-highlight) 40%,transparent)}.skill-button:disabled{opacity:.5;cursor:not-allowed}.skill-button.on-cooldown{opacity:.4;filter:grayscale(.5)}.skill-button.no-mana{opacity:.6}.skill-name{font-size:.9rem;font-weight:600}.skill-cost{font-size:.75rem;opacity:.8}.skill-cost.insufficient{color:#ef5350;opacity:1}.skill-cooldown{font-size:.7rem;color:#ffab40;font-weight:600}.downed-banner{background:#ff980026;border:1px solid rgba(255,152,0,.4);border-radius:8px;padding:.5rem 1rem;color:#ff9800;font-size:.85rem;font-weight:600;text-align:center;width:100%}.no-skills-hint{font-size:.85rem;color:#8b8b8b;font-style:italic}@media(max-width:768px){.attack-button{padding:.875rem 2rem;font-size:1.25rem;min-width:160px}.attack-icon{font-size:1.5rem}.skill-button{padding:.6rem 1rem;min-width:85px}.skill-name{font-size:.8rem}}@media(max-width:480px){.combat-actions{gap:.75rem;padding:.75rem}.attack-button{padding:.75rem 1.5rem;font-size:1rem;min-width:140px}.attack-icon{font-size:1.25rem}.skill-buttons{gap:.5rem}.skill-button{padding:.5rem .75rem;min-width:70px}.skill-name{font-size:.7rem}.skill-cost{font-size:.65rem}}.combat-log{background:#0000004d;border:1px solid color-mix(in srgb,var(--color-highlight) 25%,transparent);border-radius:8px;padding:.75rem;max-height:150px;overflow-y:auto;width:100%;max-width:500px}.combat-log::-webkit-scrollbar{width:6px}.combat-log::-webkit-scrollbar-track{background:#ffffff1a;border-radius:3px}.combat-log::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--color-highlight) 40%,transparent);border-radius:3px}.log-empty{text-align:center;color:#8b8b8b;font-style:italic;padding:1rem}.log-entries{display:flex;flex-direction:column;gap:.5rem}.log-entry{display:flex;align-items:flex-start;gap:.5rem;padding:.35rem .5rem;border-radius:4px;font-size:.85rem}.log-entry.animate-in{animation:logSlideIn .3s ease-out}@keyframes logSlideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.entry-icon{flex-shrink:0;font-size:1rem}.entry-text{color:#ccc}.entry-text strong{color:#fff}.log-entry.critical{background:#ffd70026;border-left:3px solid #ffd700}.log-entry.critical .entry-text{color:gold;font-weight:700}.log-entry.dodged{background:#2196f326;border-left:3px solid #2196f3}.log-entry.dodged .entry-text{color:#64b5f6}.log-entry.death-save{background:#9c27b026;border-left:3px solid #9c27b0}.log-entry.death-save .entry-text{color:#ce93d8}.log-entry.damage-dealt{background:#4caf501a}.log-entry.damage-dealt .entry-text strong{color:#4caf50}.log-entry.damage-taken{background:#f443361a}.log-entry.damage-taken .entry-text strong{color:#f44336}.log-entry.monster-ability{background:#f443361a;border-left:3px solid #ff5722;flex-wrap:wrap}.monster-effect-tag{background:#f4433633;color:#ff8a65;padding:.15rem .5rem;border-radius:4px;font-size:.75rem}.log-entry.effects{flex-wrap:wrap}.effects-list{display:flex;flex-wrap:wrap;gap:.35rem}.effect-tag{background:#7c4dff33;color:#b388ff;padding:.15rem .5rem;border-radius:4px;font-size:.75rem}.log-entry.hp-remaining{opacity:.7;font-size:.8rem}.log-entry.victory{background:linear-gradient(90deg,#4caf5033,#4caf500d);border-left:3px solid #4caf50}.log-entry.victory .entry-text{color:#4caf50;font-weight:700;font-size:1rem}.log-entry.loot{background:#ffc1071a}.log-entry.loot .entry-text strong{color:#ffc107}.log-entry.items{background:#9c27b01a}.log-entry.items .entry-text{color:#ce93d8}@media(max-width:768px){.combat-log{max-height:120px;padding:.5rem}.log-entry{font-size:.8rem;padding:.25rem .4rem}.entry-icon{font-size:.9rem}}@media(max-width:480px){.combat-log{max-height:100px}.log-entry{font-size:.75rem}.effect-tag{font-size:.65rem;padding:.1rem .35rem}}.fullscreen-combat{display:flex;flex-direction:column;overflow:hidden;animation:combatEnter .4s ease-out;background:linear-gradient(180deg,var(--color-background) 0%,var(--color-background-secondary) 50%,var(--color-background) 100%);min-height:80vh;position:relative}.fullscreen-combat.boss-combat{background:linear-gradient(180deg,color-mix(in srgb,var(--color-background) 80%,#2a1a3e) 0%,var(--color-background-secondary) 50%,var(--color-background) 100%)}.fullscreen-combat.boss-combat:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center top,color-mix(in srgb,var(--color-highlight) 15%,transparent) 0%,transparent 60%);pointer-events:none}@keyframes combatEnter{0%{opacity:0;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.fullscreen-combat.exiting{animation:combatExit .3s ease-in forwards}@keyframes combatExit{to{opacity:0;transform:scale(.95)}}.combat-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;background:#0000004d;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.combat-title{font-size:1.25rem;font-weight:700;color:var(--color-highlight);text-shadow:0 0 10px color-mix(in srgb,var(--color-highlight) 50%,transparent)}.fullscreen-combat.boss-combat .combat-title{color:color-mix(in srgb,var(--color-highlight) 70%,#9c27b0);text-shadow:0 0 15px color-mix(in srgb,var(--color-highlight) 40%,transparent);font-size:1.4rem}.floor-indicator{color:#8b8b8b;font-size:.9rem}.flee-button{padding:.4rem 1rem;background:transparent;border:1px solid #8b8b8b;border-radius:6px;color:#8b8b8b;cursor:pointer;transition:all .2s;font-size:.9rem}.flee-button:hover:not(:disabled){border-color:#fff;color:#fff}.flee-button:disabled{opacity:.5;cursor:not-allowed}.battle-area{flex:1;display:flex;min-height:0;overflow:hidden}.battle-left{flex:1;display:flex;flex-direction:column;padding:1rem;min-width:0;overflow-y:auto;border-right:1px solid rgba(255,255,255,.1)}.section-title{font-size:.9rem;color:#8b8b8b;text-transform:uppercase;letter-spacing:1px;margin:0 0 .75rem}.battle-right{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem;min-width:0;gap:1rem}.battle-scene{display:flex;align-items:center;justify-content:center;gap:1.5rem;width:100%}.party-formation{display:flex;flex-direction:column;gap:.5rem;align-items:center}.formation-member{display:flex;align-items:center;justify-content:center}.battle-vs{font-size:1.2rem;font-weight:700;color:#ffffff4d;letter-spacing:2px;flex-shrink:0}.battle-monster{display:flex;align-items:center;justify-content:center}.monster-section{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;width:100%;max-width:350px}.monster-info{text-align:center;width:100%}.monster-name{font-size:1.3rem;font-weight:700;color:#fff;margin:0 0 .75rem}.monster-name.boss-name{font-size:1.5rem;color:color-mix(in srgb,var(--color-highlight) 70%,#9c27b0);text-shadow:0 0 10px color-mix(in srgb,var(--color-highlight) 40%,transparent)}.monster-hp-bar{position:relative;height:22px;background:#00000080;border-radius:11px;overflow:hidden;border:2px solid #333}.monster-hp-fill{height:100%;background:linear-gradient(90deg,#f44336,#ff5252,#ff8a80);border-radius:9px;transition:width .3s ease}.monster-hp-fill.low{background:linear-gradient(90deg,#b71c1c,#c62828,#d32f2f);animation:lowHpPulse 1s ease-in-out infinite}@keyframes lowHpPulse{0%,to{opacity:1}50%{opacity:.7}}.monster-hp-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.5)}.monster-stats{margin-top:.5rem;display:flex;justify-content:center;gap:1rem}.monster-abilities{display:flex;flex-wrap:wrap;justify-content:center;gap:.35rem;margin-top:.5rem}.ability-badge{background:#ff572226;border:1px solid rgba(255,87,34,.3);color:#ff8a65;padding:.2rem .6rem;border-radius:12px;font-size:.75rem}.stat{display:flex;align-items:center;gap:.35rem;color:#ccc;font-size:.85rem}.stat-icon{font-size:.95rem}.party-section{flex-shrink:0;margin-bottom:.75rem}.log-section{flex:1;min-height:60px;margin-bottom:.75rem;overflow:hidden}.actions-section{flex-shrink:0;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.1)}.victory-overlay{display:flex;align-items:center;justify-content:center;width:100%;animation:victoryFadeIn .5s ease-out}@keyframes victoryFadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.victory-content{text-align:center;padding:1.25rem 1.5rem;background:color-mix(in srgb,var(--color-background) 95%,white);border:2px solid #4caf50;border-radius:12px;box-shadow:0 0 30px #4caf504d}.victory-title{font-size:1.5rem;color:#4caf50;margin:0 0 .75rem;text-shadow:0 0 20px rgba(76,175,80,.5);animation:victoryPulse 1s ease-in-out infinite}@keyframes victoryPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.victory-loot{margin-bottom:.5rem}.loot-gold{font-size:1.1rem;color:#ffc107;font-weight:700}.loot-bonus{font-size:.8rem;color:#ffca28;margin-left:.5rem}.victory-items{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.5rem}.loot-item{display:inline-flex;align-items:center;gap:.4rem;color:#ce93d8;font-size:.9rem}.floor-complete{font-size:.95rem;color:#64b5f6;margin-bottom:.75rem;font-weight:700}.continue-button{padding:.6rem 1.5rem;font-size:1rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#4caf50,#388e3c);border:none;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s}.continue-button:hover{transform:translateY(-2px);box-shadow:0 4px 15px #4caf5066}@media(max-width:700px){.battle-area{flex-direction:column-reverse}.battle-left{border-right:none;border-top:1px solid rgba(255,255,255,.1);flex:none;max-height:50vh}.battle-right{flex:none;padding:.75rem}.party-formation,.battle-vs{display:none}.monster-section{max-width:280px}.combat-header{padding:.5rem 1rem}.combat-title{font-size:1rem}.fullscreen-combat.boss-combat .combat-title{font-size:1.1rem}.floor-indicator{font-size:.8rem}.flee-button{padding:.3rem .75rem;font-size:.8rem}.section-title{font-size:.8rem;margin-bottom:.5rem}.monster-name{font-size:1.1rem}.monster-name.boss-name{font-size:1.25rem}.monster-hp-bar{height:18px}.monster-hp-text{font-size:.7rem}.stat{font-size:.8rem}}@media(max-width:400px){.battle-left{padding:.75rem}.battle-right{padding:.5rem}.monster-section{max-width:220px;gap:.5rem}.victory-content{padding:1rem}.victory-title{font-size:1.25rem}.loot-gold{font-size:1rem}.continue-button{padding:.5rem 1.25rem;font-size:.9rem}}.character-sheet-overlay{position:fixed;inset:0;background:#000000b3;z-index:100;display:flex;align-items:center;justify-content:center;padding:1rem}.character-sheet{background:var(--color-background-secondary, #16213e);border:1px solid rgba(255,255,255,.1);border-radius:12px;width:100%;max-width:540px;max-height:85vh;overflow-y:auto;color:#e8e6e3}.cs-header{display:flex;align-items:center;gap:1rem;padding:1.25rem;border-bottom:1px solid rgba(255,255,255,.08)}.cs-avatar{width:64px;height:64px;border-radius:8px;background:#ffffff0d;display:flex;align-items:center;justify-content:center;font-size:2rem}.cs-info{flex:1}.cs-name{font-size:1.2rem;font-weight:700;margin:0}.cs-title{color:gold;font-size:.85rem;font-style:italic;margin:2px 0}.cs-class-level{color:#aaa;font-size:.85rem}.cs-close{background:none;border:none;color:#888;font-size:1.5rem;cursor:pointer;padding:.25rem}.cs-close:hover{color:#fff}.cs-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;padding:1rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.08)}.cs-stat{text-align:center;padding:.5rem;background:#ffffff0a;border-radius:6px}.cs-stat-value{font-size:1.1rem;font-weight:700}.cs-stat-label{font-size:.7rem;color:#888;text-transform:uppercase}.cs-stat-bonus{font-size:.7rem;color:#4caf50}.cs-title-select{padding:.75rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:.5rem}.cs-title-select label{font-size:.85rem;color:#aaa;white-space:nowrap}.cs-title-select select{flex:1;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:gold;padding:.35rem .5rem;font-size:.85rem}.cs-milestones{padding:1rem 1.25rem}.cs-milestones h3{margin:0 0 .75rem;font-size:1rem}.cs-category-tabs{display:flex;gap:.25rem;margin-bottom:1rem}.cs-cat-tab{flex:1;padding:.4rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#888;cursor:pointer;font-size:.75rem;text-align:center;transition:all .15s}.cs-cat-tab.active{background:#ffd70026;border-color:#ffd7004d;color:gold}.cs-milestone-list{display:flex;flex-direction:column;gap:.75rem}.cs-milestone{background:#ffffff0a;border-radius:8px;padding:.75rem}.cs-milestone-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.cs-milestone-name{font-weight:600;font-size:.9rem}.cs-milestone-value{font-size:.8rem;color:#888}.cs-milestone-tiers{display:flex;gap:.35rem;margin-bottom:.4rem}.cs-tier{flex:1;padding:.3rem .25rem;border-radius:4px;text-align:center;font-size:.65rem;border:1px solid transparent;opacity:.4;transition:all .15s}.cs-tier.earned{opacity:1}.cs-tier.bronze{background:#cd7f3233;border-color:#cd7f3266;color:#cd7f32}.cs-tier.silver{background:#c0c0c033;border-color:#c0c0c066;color:silver}.cs-tier.gold{background:#ffd70033;border-color:#ffd70066;color:gold}.cs-tier.legendary{background:#9467bd33;border-color:#9467bd66;color:#9467bd}.cs-tier-title{font-weight:600;display:block}.cs-tier-threshold{display:block;opacity:.7;margin-top:1px}.cs-progress-bar{height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.cs-progress-fill{height:100%;background:linear-gradient(90deg,#cd7f32,gold);border-radius:2px;transition:width .3s}.cs-bonus-summary{margin-top:.3rem;font-size:.7rem;color:#4caf50}@media(max-width:600px){.character-sheet{max-height:90vh}.cs-stats{gap:.35rem}.cs-tier{font-size:.6rem;padding:.25rem .15rem}}.death-modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1100;padding:1rem}.death-modal{background:#1a0a1a;border:2px solid #7b1fa2;border-radius:12px;padding:2rem;max-width:420px;width:100%;text-align:center;color:#e0e0e0;box-shadow:0 0 40px #7b1fa266}.death-icon{font-size:4rem;margin-bottom:.5rem;filter:drop-shadow(0 0 8px rgba(123,31,162,.6))}.death-title{color:#ce93d8;font-size:1.5rem;margin:0 0 1rem}.death-body{color:#bbb;font-size:.95rem;margin:0 0 1rem;line-height:1.5}.auto-potion-info{background:#7b1fa226;border:1px solid rgba(123,31,162,.3);border-radius:8px;padding:.75rem;margin-bottom:1rem}.auto-potion-info p{margin:.25rem 0;font-size:.9rem;color:#ce93d8}.health-after{color:#999!important;font-size:.85rem!important}.death-dismiss-btn{background:#7b1fa2;color:#fff;border:none;padding:.75rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.death-dismiss-btn:hover{background:#9c27b0}.login-reward-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1050;padding:1rem;animation:lrFadeIn .3s ease-out}.login-reward-modal{background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);border:2px solid #e2b04a;border-radius:16px;padding:2rem;max-width:380px;width:100%;text-align:center;color:#e0e0e0;box-shadow:0 0 40px #e2b04a33;animation:lrSlideUp .4s ease-out}.login-reward-modal.milestone{box-shadow:0 0 60px #e2b04a59,inset 0 0 30px #e2b04a0d;border-color:#f5d680}@keyframes lrFadeIn{0%{opacity:0}to{opacity:1}}@keyframes lrSlideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.reward-header{margin-bottom:1.5rem}.reward-day-badge{display:inline-block;background:linear-gradient(135deg,#e2b04a,#f5d680);color:#1a1a2e;font-weight:700;font-size:.85rem;padding:.3rem 1rem;border-radius:20px;margin-bottom:.75rem}.reward-title{color:#f5d680;font-size:1.4rem;margin:0 0 .5rem;text-shadow:0 0 10px rgba(245,214,128,.4)}.reward-streak{color:#89a;font-size:.85rem;margin:0}.reward-contents{background:#0000004d;border:1px solid rgba(226,176,74,.2);border-radius:12px;padding:1rem;margin-bottom:1rem}.reward-contents.milestone{border-color:#e2b04a80;box-shadow:0 0 20px #e2b04a1a}.reward-entry{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;font-size:1rem}.reward-entry+.reward-entry{border-top:1px solid rgba(255,255,255,.05)}.reward-icon{font-size:1.3rem;flex-shrink:0}.reward-label{font-weight:500}.gold-reward .reward-label{color:#f5d680}.reward-entry.rarity-common .reward-label{color:#b0b0b0}.reward-entry.rarity-uncommon .reward-label{color:#4fc978}.reward-entry.rarity-rare .reward-label{color:#5b9bff}.reward-entry.rarity-epic .reward-label{color:#c850ff}.reward-progress{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem}.reward-progress .progress-bar{flex:1;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.reward-progress .progress-fill{height:100%;background:linear-gradient(90deg,#e2b04a,#f5d680);border-radius:3px;transition:width .5s ease-out}.progress-label{color:#89a;font-size:.8rem;min-width:40px}.reward-claim-btn{background:linear-gradient(135deg,#e2b04a,#c49a30);color:#1a1a2e;border:none;padding:.75rem 2rem;border-radius:10px;font-size:1rem;font-weight:700;cursor:pointer;width:100%;transition:transform .15s,box-shadow .15s}.reward-claim-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 15px #e2b04a66}.reward-claim-btn:disabled{opacity:.7;cursor:not-allowed}.reward-claim-btn.milestone{box-shadow:0 0 20px #e2b04a4d}.reward-claim-btn.claimed{background:linear-gradient(135deg,#4fc978,#3ba362);color:#fff}.yesterday-splash-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1050;padding:1rem;animation:ysFadeIn .3s ease-out}.yesterday-splash-modal{background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);border:2px solid #e2b04a;border-radius:16px;padding:2rem;max-width:420px;width:100%;color:#e0e0e0;box-shadow:0 0 40px #e2b04a33;animation:ysSlideUp .4s ease-out}@keyframes ysFadeIn{0%{opacity:0}to{opacity:1}}@keyframes ysSlideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.yesterday-splash-header{text-align:center;margin-bottom:1.5rem}.yesterday-splash-title{color:#f5d680;font-size:1.4rem;margin:0 0 .5rem;text-shadow:0 0 10px rgba(245,214,128,.4)}.yesterday-splash-subtitle{color:#89a;font-size:.85rem;margin:0;line-height:1.4}.yesterday-splash-list{background:#0000004d;border:1px solid rgba(226,176,74,.2);border-radius:12px;padding:.5rem;margin-bottom:1rem;max-height:300px;overflow-y:auto}.yesterday-daily-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .5rem;border-radius:8px;cursor:pointer;transition:background .15s}.yesterday-daily-item:hover{background:#ffffff0d}.yesterday-daily-item.checked{background:#22c55e1a}.yesterday-daily-checkbox{width:28px;height:28px;min-width:28px;border-radius:6px;border:2px solid rgba(226,176,74,.5);background:#0000004d;color:#fff;font-size:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.yesterday-daily-checkbox.checked{background:linear-gradient(135deg,#22c55e,#16a34a);border-color:#22c55e}.yesterday-daily-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.yesterday-daily-name{font-size:.9rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.yesterday-daily-meta{display:flex;align-items:center;gap:8px;font-size:.75rem}.yesterday-daily-damage{color:#f87171;font-weight:600}.yesterday-daily-todo-note{color:#fbbf24;font-size:.7rem}.yesterday-splash-empty{text-align:center;padding:1.5rem;color:#89a;font-size:.9rem}.yesterday-splash-damage-preview{text-align:center;padding:.5rem;margin-bottom:1rem;color:#f87171;font-size:.85rem;background:#f871711a;border-radius:8px;border:1px solid rgba(248,113,113,.2)}.yesterday-splash-btn{background:linear-gradient(135deg,#e2b04a,#c49a30);color:#1a1a2e;border:none;padding:.75rem 2rem;border-radius:10px;font-size:1rem;font-weight:700;cursor:pointer;width:100%;transition:transform .15s,box-shadow .15s}.yesterday-splash-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 15px #e2b04a66}.yesterday-splash-btn:disabled{opacity:.7;cursor:not-allowed}.yesterday-splash-btn.done{background:linear-gradient(135deg,#4fc978,#3ba362);color:#fff}.wr-overlay{position:fixed;inset:0;background:#000000d9;z-index:1100;display:flex;align-items:center;justify-content:center;animation:wr-fadeIn .3s ease-out;padding:16px;overflow-y:auto}@keyframes wr-fadeIn{0%{opacity:0}to{opacity:1}}@keyframes wr-slideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.wr-modal{background:linear-gradient(135deg,#1a1a2e,#0f3460);border:2px solid #e94560;border-radius:16px;max-width:420px;width:100%;padding:24px;animation:wr-slideUp .4s ease-out;box-shadow:0 0 40px #e945604d;max-height:90vh;overflow-y:auto}.wr-header{text-align:center;margin-bottom:20px}.wr-week-badge{display:inline-block;background:#e9456033;border:1px solid rgba(233,69,96,.5);border-radius:20px;padding:4px 14px;font-size:12px;color:#e94560;margin-bottom:8px}.wr-title{font-size:22px;font-weight:700;color:#fff;margin:4px 0}.wr-party-name{font-size:13px;color:#fff9}.wr-sprites{display:flex;justify-content:center;gap:12px;margin:16px 0;flex-wrap:wrap}.wr-sprite-card{text-align:center}.wr-sprite-name{font-size:11px;color:#ffffffb3;margin-top:4px}.wr-sprite-level{font-size:10px;color:#fff6}.wr-mvp{background:#e9456026;border:1px solid rgba(233,69,96,.3);border-radius:12px;padding:12px 16px;text-align:center;margin:16px 0}.wr-mvp-label{font-size:11px;color:#e94560;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}.wr-mvp-text{font-size:15px;color:#fff;font-weight:500}.wr-stats{display:flex;flex-direction:column;gap:8px;margin:16px 0}.wr-stat-row{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#ffffff0d;border-radius:8px}.wr-stat-icon{font-size:18px;width:24px;text-align:center;flex-shrink:0}.wr-stat-label{flex:1;font-size:13px;color:#ffffffb3}.wr-stat-value{font-size:15px;font-weight:700;color:#fff}.wr-rarest{text-align:center;margin:12px 0;padding:10px;background:#9333ea1a;border:1px solid rgba(147,51,234,.3);border-radius:10px}.wr-rarest-label{font-size:11px;color:#ffffff80;margin-bottom:4px}.wr-rarest-name{font-size:14px;font-weight:700}.wr-rarest-name.common{color:#9ca3af}.wr-rarest-name.uncommon{color:#22c55e}.wr-rarest-name.rare{color:#3b82f6}.wr-rarest-name.epic{color:#a855f7}.wr-rarest-name.legendary{color:#f59e0b}.wr-actions{display:flex;gap:10px;margin-top:20px}.wr-btn{flex:1;padding:12px;border-radius:10px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:transform .1s,opacity .1s}.wr-btn:active{transform:scale(.97)}.wr-btn-share{background:#e9456033;border:1px solid #e94560;color:#e94560}.wr-btn-share:hover{background:#e945604d}.wr-btn-continue{background:#e94560;color:#fff}.wr-btn-continue:hover{opacity:.9}.wr-share-overlay{position:fixed;inset:0;background:#000000e6;z-index:1200;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px;gap:16px}.wr-share-preview{max-width:360px;width:100%;border-radius:12px;overflow:hidden;box-shadow:0 0 30px #e9456066}.wr-share-preview img{width:100%;height:auto;display:block}.wr-share-actions{display:flex;gap:10px}@media(max-width:420px){.wr-modal{padding:16px;border-radius:12px}.wr-title{font-size:18px}.wr-sprites{gap:8px}}.party-event-container{position:fixed;top:1rem;left:50%;transform:translate(-50%);z-index:1050;display:flex;flex-direction:column;gap:.5rem;pointer-events:none;width:90%;max-width:400px}.party-event-popup{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:10px;cursor:pointer;pointer-events:auto;animation:party-event-slide-in .3s ease-out;box-shadow:0 4px 20px #00000080}@keyframes party-event-slide-in{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.party-event-icon{font-size:1.5rem;flex-shrink:0}.party-event-text{min-width:0}.party-event-title{font-weight:700;font-size:.95rem}.party-event-subtitle{font-size:.8rem;opacity:.8;margin-top:2px}.party-event-member_downed{background:#7b1fa2e6;border:1px solid #ab47bc;color:#f3e5f5}.party-event-floor_completed{background:#2e2e0af2;border:1px solid #ffd700;color:#fff8e1}.party-event-floor_completed .party-event-title{color:gold}.party-event-party_wipe{background:#640f0ff2;border:1px solid #ef5350;color:#ffcdd2}.party-event-party_wipe .party-event-title{color:#ef5350}.party-event-boss_discovered{background:#3c1e00f2;border:1px solid #ff9800;color:#fff3e0}.party-event-boss_discovered .party-event-title{color:#ff9800}.dashboard{min-height:100vh;background:linear-gradient(180deg,var(--color-background) 0%,var(--color-background-secondary) 50%,var(--color-background) 100%);font-family:system-ui,-apple-system,sans-serif;color:#e8e6e3;position:relative}.dashboard:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at 20% 20%,color-mix(in srgb,var(--color-highlight) 8%,transparent) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,color-mix(in srgb,var(--color-highlight) 6%,transparent) 0%,transparent 50%);pointer-events:none;z-index:0}.notification{position:fixed;top:20px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,var(--color-highlight) 0%,var(--color-button) 100%);color:#fff;padding:12px 24px;border-radius:12px;z-index:1000;font-weight:500;box-shadow:0 4px 20px color-mix(in srgb,var(--color-highlight) 40%,transparent);animation:notifPop .35s ease-out}@keyframes notifPop{0%{opacity:0;transform:translate(-50%) scale(.6)}70%{opacity:1;transform:translate(-50%) scale(1.05)}to{transform:translate(-50%) scale(1)}}.party-notifications{position:fixed;top:80px;right:20px;z-index:999;display:flex;flex-direction:column;gap:8px}.party-notification{background:#22c55ee6;color:#fff;padding:10px 16px;border-radius:10px;font-size:13px;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(100px);opacity:0}to{transform:translate(0);opacity:1}}.top-bar{display:flex;justify-content:space-between;align-items:center;padding:12px 24px;background:color-mix(in srgb,var(--color-background) 95%,white);border-bottom:1px solid color-mix(in srgb,var(--color-highlight) 15%,transparent);position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.top-bar-left{display:flex;align-items:center;gap:10px}.top-bar-identity{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:var(--color-highlight)}.top-bar-name{white-space:nowrap}.top-bar-avatar{font-size:18px}.top-bar-level{font-size:11px;color:#888;font-weight:400}.top-bar-party{font-size:11px;color:#888;font-weight:400;white-space:nowrap}.top-bar-right{display:flex;align-items:center;gap:8px}.reward-countdown{display:flex;align-items:center;gap:4px;font-size:13px;color:#89a;padding:4px 10px;border-radius:6px;background:#ffffff0d}.countdown-icon{font-size:14px}.countdown-text{font-variant-numeric:tabular-nums;min-width:50px}.reward-ready-btn{display:flex;align-items:center;gap:5px;background:linear-gradient(135deg,#e2b04a,#c49a30);color:#1a1a2e;border:none;padding:5px 12px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;animation:rewardPulse 2s ease-in-out infinite}.reward-ready-btn:hover{transform:scale(1.05)}@keyframes rewardPulse{0%,to{box-shadow:0 0 #e2b04a66}50%{box-shadow:0 0 10px 3px #e2b04a4d}}.reward-gift-icon{font-size:15px}.banner-actions{display:flex;gap:6px;align-items:center}.banner-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;transition:all .2s}.banner-btn.active{background:var(--color-highlight);border-color:var(--color-highlight);padding:6px 10px;color:#9ca3af;cursor:pointer;font-size:14px;transition:all .2s}.banner-btn:hover{background:#ffffff1a;color:#e8e6e3}.quests-layout{display:flex;flex-direction:column}.quests-status-row{display:grid;grid-template-columns:auto 1fr;gap:16px;padding:16px 24px}@media(max-width:900px){.quests-status-row{grid-template-columns:1fr}}@media(max-width:600px){.dashboard{height:100vh;height:100dvh;min-height:0;overflow-y:auto;scroll-snap-type:y proximity;scroll-padding-top:48px;scroll-padding-bottom:80px}.quests-party-slot{scroll-snap-align:start}.quests-layout>.tasks-section{scroll-snap-align:start}.tasks-grid>.task-column{display:flex;flex-direction:column;max-height:calc(100vh - 158px);max-height:calc(100dvh - 158px)}.task-column>.task-list,.task-column>.sortable-list{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;min-height:0}.quests-minimap-slot,.quests-layout>.quest-item-bar{scroll-snap-align:end}}@media(max-width:600px){.quests-status-row{display:contents}.quests-party-slot{order:1;padding:4px 16px}.quests-party-slot .party-members-card{padding:8px;border-radius:12px}.quests-party-slot .party-members-header{margin-bottom:6px}.quests-party-slot .party-members-grid{flex-wrap:nowrap;overflow-x:auto}.quests-party-slot .party-member-card{min-width:64px;max-width:80px;padding:4px}.quests-layout>.tasks-section{order:2}.quests-minimap-slot{order:3;padding:8px 16px}.quests-layout>.quest-item-bar{order:4}}.status-row{display:grid;grid-template-columns:auto 1fr;gap:16px;padding:16px 24px;position:relative;z-index:1}@media(max-width:900px){.status-row{grid-template-columns:1fr}}.party-members-card{background:#0003;border-radius:16px;padding:12px;border:1px solid rgba(255,255,255,.05)}.dungeon-party-card{margin-top:16px}.party-members-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:12px;color:#9ca3af;padding:0 4px}.party-energy{color:#fbbf24;font-weight:600}.party-streak-row{display:flex;align-items:center;gap:6px;padding:6px 8px;margin-bottom:8px;background:#fbbf240f;border:1px solid rgba(251,191,36,.12);border-radius:8px;font-size:12px}.party-streak-icon{font-size:14px}.party-streak-count{font-weight:700;color:#fbbf24;font-size:14px}.party-streak-label{color:#9ca3af}.party-streak-today{margin-left:auto;color:#9ca3af;font-size:11px}.party-members-grid{display:flex;gap:6px;flex-wrap:wrap}.party-member-card{flex:1 1 80px;min-width:80px;max-width:120px;background:#ffffff08;border-radius:8px;padding:6px;border:1px solid rgba(255,255,255,.05);transition:all .2s;display:flex;flex-direction:column;align-items:center;text-align:center}.party-member-card.current-user{background:linear-gradient(135deg,color-mix(in srgb,var(--color-highlight) 15%,transparent),color-mix(in srgb,var(--color-button) 10%,transparent));border-color:color-mix(in srgb,var(--color-highlight) 30%,transparent)}.party-member-card.downed{opacity:.6}.member-sprite{position:relative;display:inline-block;margin-bottom:2px}.member-sprite .status-dot{position:absolute;bottom:0;right:-2px;width:7px;height:7px;border-radius:50%;border:1px solid rgba(0,0,0,.3);z-index:1}.status-dot.green{background:#22c55e;box-shadow:0 0 4px #22c55e}.status-dot.blue{background:#3b82f6;box-shadow:0 0 4px #3b82f6}.status-dot.red{background:#ef4444;box-shadow:0 0 4px #ef4444}.member-info{display:flex;flex-direction:column;align-items:center;gap:0;margin-bottom:3px;width:100%}.member-name{font-size:10px;font-weight:600;color:#e8e6e3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.party-member-card.current-user .member-name{color:color-mix(in srgb,var(--color-highlight) 70%,white)}.member-level{font-size:8px;color:#6b7280;display:flex;align-items:center;gap:3px}.member-level .attr-badge{font-size:7px;padding:0 3px;line-height:1.2}.member-bars{width:100%;display:flex;flex-direction:column;gap:2px}.member-hp-bar{height:3px;background:#0006;border-radius:2px;overflow:hidden;cursor:help}.member-hp-fill{height:100%;border-radius:2px;transition:width .3s ease}.member-hp-fill.high{background:linear-gradient(90deg,#4ade80,#22c55e)}.member-hp-fill.medium{background:linear-gradient(90deg,#fbbf24,#f59e0b)}.member-hp-fill.low{background:linear-gradient(90deg,#f87171,#ef4444)}.member-mp-bar{height:2px;background:#0006;border-radius:1px;overflow:hidden;cursor:help}.member-mp-fill{height:100%;border-radius:1px;background:linear-gradient(90deg,#3b82f6,#60a5fa);transition:width .3s ease}.dungeon-party-card{margin-bottom:12px}.dungeon-room-badge{font-size:8px;padding:0 4px;margin-left:4px;border-radius:4px;background:#ffffff14;color:#6b7280}.dungeon-room-badge.same-room{background:#22c55e33;color:#4ade80}.dungeon-map-section{padding:16px 24px;background:linear-gradient(180deg,color-mix(in srgb,var(--color-highlight) 5%,transparent) 0%,transparent 100%);position:relative;z-index:1}.dungeon-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.dungeon-title{display:flex;align-items:center;gap:8px;margin:0;font-size:1.25rem;font-weight:600;color:#fff}.dungeon-icon{font-size:1.5rem}.dungeon-floor-info{display:flex;align-items:center;gap:16px}.floor-label{font-size:1rem;color:#9ca3af;font-weight:500}.floor-theme{font-size:.85rem;color:#78909c;font-style:italic;text-transform:capitalize}.key-indicator{font-size:1.1rem;cursor:help}.energy-display{font-size:1rem;color:#fbbf24;font-weight:600}@media(max-width:600px){.dungeon-header{flex-direction:column;align-items:flex-start;gap:8px}.dungeon-title{font-size:1.1rem}.dungeon-floor-info{gap:12px}.floor-label,.energy-display{font-size:.9rem}}.dungeon-map-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:900px){.dungeon-map-grid{grid-template-columns:1fr}}@media(max-width:600px){.dungeon-map-section{padding:12px}}.dungeon-panel{background:#0003;border-radius:16px;padding:16px;min-width:0;overflow:hidden}@media(max-width:600px){.dungeon-panel{padding:8px;border-radius:12px}}@media(max-width:400px){.dungeon-panel{padding:6px}}.dungeon-map-container{background:#0000004d;border-radius:16px;padding:16px;border:1px solid color-mix(in srgb,var(--color-highlight) 10%,transparent);position:relative;height:100px;overflow:hidden}.map-label{position:absolute;top:8px;left:12px;font-size:10px;text-transform:uppercase;letter-spacing:1px;color:#6b7280}.map-svg{position:absolute;top:0;left:0;width:100%;height:100%}.map-explore-btn{position:absolute;bottom:8px;right:12px;font-size:11px;color:var(--color-highlight);display:flex;align-items:center;gap:4px;cursor:pointer;background:none;border:none;padding:4px 8px;border-radius:8px;transition:all .2s}.map-explore-btn:hover{background:color-mix(in srgb,var(--color-highlight) 20%,transparent)}.task-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.tag-pill{display:inline-block;padding:3px 10px;background:color-mix(in srgb,var(--color-highlight) 15%,transparent);border:1px solid color-mix(in srgb,var(--color-highlight) 25%,transparent);border-radius:12px;color:color-mix(in srgb,var(--color-highlight) 70%,white);font-size:11px;font-weight:500;cursor:default;transition:all .15s}.tag-pill.small{padding:1px 6px;font-size:10px;border-radius:8px}.tag-pill.active{background:var(--color-highlight);border-color:var(--color-highlight);color:#fff}.tag-pill:hover{background:color-mix(in srgb,var(--color-highlight) 25%,transparent)}.tag-filter-bar{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.05)}.tasks-section{padding:20px 16px;position:relative;z-index:1}.tasks-grid{display:grid;grid-template-columns:repeat(3,minmax(200px,1fr));gap:12px}.tasks-grid.cols-1{grid-template-columns:minmax(200px,600px);justify-content:center}.tasks-grid.cols-2{grid-template-columns:repeat(2,minmax(200px,1fr))}.tasks-grid.cols-4{grid-template-columns:repeat(4,minmax(180px,1fr))}@media(max-width:1100px){.tasks-grid.cols-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:900px){.tasks-grid{grid-template-columns:repeat(2,1fr)}.tasks-grid.cols-1{grid-template-columns:minmax(200px,600px)}}.scroll-dots{display:none;justify-content:center;gap:8px;padding:0 0 8px}@media(max-width:600px){.scroll-dots{display:flex}}.scroll-dot{display:block;width:8px;height:8px;border-radius:50%;background:#ffffff4d;cursor:pointer;transition:background .2s,transform .2s;flex-shrink:0}.scroll-dot.active{background:var(--color-highlight, #fb923c);transform:scale(1.3)}@media(max-width:600px){.tasks-grid,.tasks-grid.cols-1,.tasks-grid.cols-2,.tasks-grid.cols-3,.tasks-grid.cols-4{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:0}.tasks-grid::-webkit-scrollbar{display:none}.tasks-grid>.task-column{min-width:100%;width:100%;scroll-snap-align:start;flex-shrink:0}}.task-column{background:#0003;border-radius:14px;padding:12px;border:1px solid rgba(255,255,255,.05);min-width:0}.column-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.05)}.filter-buttons{display:flex;gap:6px;margin-bottom:10px}.filter-btn{padding:4px 10px;font-size:11px;border:1px solid rgba(255,255,255,.15);background:#ffffff0d;color:#fff9;border-radius:12px;cursor:pointer;transition:all .2s}.filter-btn:hover{background:#ffffff1a;color:#fffc}.filter-btn.active{background:var(--color-highlight);border-color:var(--color-highlight);color:#fff}.column-title{display:flex;align-items:center;gap:8px}.column-title h3{font-size:14px;font-weight:600;color:#e8e6e3;margin:0}.column-count{background:color-mix(in srgb,var(--color-highlight) 30%,transparent);color:color-mix(in srgb,var(--color-highlight) 70%,white);font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px}.add-task-btn{width:28px;height:28px;border-radius:8px;border:2px solid color-mix(in srgb,var(--color-highlight) 30%,transparent);background:color-mix(in srgb,var(--color-highlight) 10%,transparent);color:var(--color-highlight);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.add-task-btn:hover{background:color-mix(in srgb,var(--color-highlight) 20%,transparent);border-color:color-mix(in srgb,var(--color-highlight) 50%,transparent)}.add-task-btn:active{transform:scale(.9)}.add-task-btn.filter-active{background:color-mix(in srgb,var(--color-highlight) 15%,transparent);border-color:color-mix(in srgb,var(--color-highlight) 40%,transparent)}.task-list,.sortable-list{display:flex;flex-direction:column;gap:8px}.sortable-list.saving{opacity:.7;pointer-events:none}.drag-handle{touch-action:none}.drag-handle:active{cursor:grabbing}.task-item{background:#ffffff08;border-radius:10px;padding:10px;border:1px solid rgba(255,255,255,.05);cursor:pointer;display:flex;align-items:center;gap:10px;transition:background .2s,border-color .2s}.task-item:hover{background:#ffffff0d;border-color:#ffffff1a}.task-item.completed{background:linear-gradient(135deg,#22c55e1a,#22c55e0d);border-color:#22c55e33}.task-item.shared-other{border-left:3px solid rgba(59,130,246,.4)}.shared-badge{margin-right:4px;font-size:16px}.task-checkbox{width:28px;height:28px;min-width:44px;min-height:44px;border-radius:6px;border:2px solid color-mix(in srgb,var(--color-highlight) 60%,white);background:#0003;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;transition:background .15s,border-color .15s,transform .1s;color:#fff;font-size:14px}.task-checkbox:hover{border-color:var(--color-highlight);background:#0000004d}.task-checkbox.checked{border-color:#22c55e;background:linear-gradient(135deg,#22c55e,#16a34a)}.task-checkbox:focus{outline:none}.task-checkbox:active:not(:disabled){transform:scale(.9)}.task-checkbox:disabled{opacity:.5;cursor:not-allowed}.task-content{flex:1;min-width:0}.task-name{font-size:14px;font-weight:500;color:#e8e6e3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-item.completed .task-name{color:#86efac;text-decoration:line-through;opacity:.7}.task-meta{font-size:11px;color:#6b7280;margin-top:2px;display:flex;align-items:center;gap:8px}.add-subtask-inline{width:28px;height:28px;min-width:28px;border-radius:6px;border:1px dashed rgba(255,255,255,.2);background:transparent;color:#fff6;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;line-height:1}.add-subtask-inline:hover{border-color:var(--color-highlight);color:var(--color-highlight);background:#ffffff0d}.streak-badge{display:flex;flex-direction:column;align-items:center;flex-shrink:0;min-width:36px;padding:2px 6px;border-radius:8px;background:#fb923c1a}.streak-icon{font-size:14px;line-height:1}.streak-count{font-size:16px;font-weight:700;color:#fb923c;line-height:1.1}.task-item.completed .streak-badge{opacity:.5}.task-difficulty{font-size:9px;text-transform:uppercase;letter-spacing:1px;padding:2px 6px;border-radius:4px;font-weight:600}.task-difficulty.trivial{color:#9ca3af;background:#9ca3af1a}.task-difficulty.easy{color:#4ade80;background:#4ade801a}.task-difficulty.medium{color:#fbbf24;background:#fbbf241a}.task-difficulty.hard{color:#f87171;background:#f871711a}.habit-item{background:#ffffff08;border-radius:10px;padding:10px;border:1px solid rgba(255,255,255,.05);display:flex;align-items:center;gap:8px}.habit-btn-slot{width:44px;min-width:44px;flex-shrink:0}.habit-btn{width:32px;height:32px;min-width:44px;min-height:44px;border-radius:6px;border:2px solid;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.habit-btn.negative{border-color:#ef44444d;background:#ef44441a;color:#f87171}.habit-btn.negative:hover{background:#ef444433;border-color:#ef444480}.habit-btn.positive{border-color:#22c55e4d;background:#22c55e1a;color:#4ade80}.habit-btn.positive:hover{background:#22c55e33;border-color:#22c55e80}.habit-btn:active:not(:disabled){transform:scale(.9)}.habit-btn:disabled{opacity:.4;cursor:not-allowed}.habit-content{flex:1;text-align:center;min-width:0}.habit-name{font-size:14px;font-weight:500;color:#e8e6e3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.habit-counts{font-size:11px;color:#6b7280;margin-top:4px;display:flex;justify-content:center;gap:12px}.habit-counts .positive{color:#4ade80}.habit-counts .negative{color:#f87171}.empty-state{text-align:center;padding:24px 16px;color:#6b7280;font-size:13px}.warning-banner{margin:16px 24px;padding:14px 16px;background:linear-gradient(135deg,#fb923c1a,#fb923c0d);border-radius:12px;border:1px solid rgba(251,146,60,.2);display:flex;align-items:center;gap:12px;position:relative;z-index:1}.warning-icon{font-size:20px}.warning-title{font-size:13px;font-weight:600;color:#fbbf24}.warning-text{font-size:12px;color:#9ca3af}.bottom-nav{position:fixed;bottom:0;left:0;right:0;padding:12px 20px;z-index:100}.bottom-nav-inner{max-width:600px;margin:0 auto;display:flex;justify-content:space-around;align-items:center;background:color-mix(in srgb,var(--color-background) 95%,white);border-radius:20px;padding:10px 8px;border:1px solid color-mix(in srgb,var(--color-highlight) 15%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;opacity:.6;cursor:pointer;padding:4px 12px;border-radius:12px;background:transparent;border:none;transition:all .2s}.nav-item:hover{opacity:.8}.nav-item.active{opacity:1;background:linear-gradient(135deg,color-mix(in srgb,var(--color-highlight) 20%,transparent),color-mix(in srgb,var(--color-button) 10%,transparent))}.nav-item.highlight{background:linear-gradient(135deg,#fbbf2433,#fb923c1a);opacity:1}.nav-icon{font-size:20px}.nav-label{font-size:10px;color:#6b7280;font-weight:400}.nav-item.active .nav-label{color:var(--color-highlight);font-weight:600}.nav-item.highlight .nav-label{color:#fbbf24}.bottom-spacer{height:80px}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:linear-gradient(135deg,var(--color-background-secondary) 0%,var(--color-background) 100%);border-radius:20px;padding:24px;width:100%;max-width:400px;max-height:85vh;overflow-y:auto;border:1px solid color-mix(in srgb,var(--color-highlight) 20%,transparent);box-shadow:0 20px 60px #00000080}.modal::-webkit-scrollbar{width:6px}.modal::-webkit-scrollbar-track{background:transparent}.modal::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.modal::-webkit-scrollbar-thumb:hover{background:#ffffff40}.modal h3{font-size:18px;font-weight:600;color:#e8e6e3;margin:0 0 20px}.modal-input{width:100%;padding:12px 16px;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#e8e6e3;font-size:14px;margin-bottom:16px;box-sizing:border-box}.modal-input:focus{outline:none;border-color:color-mix(in srgb,var(--color-highlight) 50%,transparent)}.modal-input::placeholder{color:#6b7280}.difficulty-picker{display:flex;gap:8px;margin-bottom:16px}.diff-option{flex:1;padding:10px 8px;border:2px solid transparent;border-radius:10px;cursor:pointer;font-size:11px;font-weight:500;text-align:center;transition:all .2s;background:#ffffff0d;color:#9ca3af}.diff-option:hover{background:#ffffff1a}.diff-option.selected{border-color:currentColor}.diff-option.trivial.selected{color:#9ca3af;background:#9ca3af33}.diff-option.easy.selected{color:#4ade80;background:#4ade8033}.diff-option.medium.selected{color:#fbbf24;background:#fbbf2433}.diff-option.hard.selected{color:#f87171;background:#f8717133}.schedule-picker{margin-bottom:16px}.schedule-label{font-size:12px;color:#9ca3af;margin-bottom:8px}.schedule-options{display:flex;flex-wrap:wrap;gap:6px}.schedule-option{padding:8px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#9ca3af;font-size:12px;cursor:pointer;transition:all .2s}.schedule-option:hover{background:#ffffff1a}.schedule-option.selected{background:color-mix(in srgb,var(--color-highlight) 20%,transparent);border-color:color-mix(in srgb,var(--color-highlight) 40%,transparent);color:color-mix(in srgb,var(--color-highlight) 70%,white)}.direction-picker{margin-bottom:16px}.direction-picker label{font-size:12px;color:#9ca3af;display:block;margin-bottom:8px}.direction-options{display:flex;gap:8px}.direction-btn{flex:1;padding:10px;border:2px solid rgba(255,255,255,.1);border-radius:10px;background:#ffffff0d;color:#9ca3af;font-size:13px;cursor:pointer;transition:all .2s}.direction-btn.selected{border-color:color-mix(in srgb,var(--color-highlight) 40%,transparent);background:color-mix(in srgb,var(--color-highlight) 20%,transparent);color:color-mix(in srgb,var(--color-highlight) 70%,white)}.modal-actions{display:flex;gap:12px;margin-top:20px}.cancel-btn{flex:1;padding:12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#9ca3af;font-size:14px;cursor:pointer;transition:all .2s}.cancel-btn:hover{background:#ffffff1a}.cancel-btn:active{transform:scale(.97)}.primary-btn{flex:1;padding:12px;background:linear-gradient(135deg,var(--color-button) 0%,var(--color-button-hover) 100%);border:none;border-radius:12px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.primary-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.primary-btn:active:not(:disabled){transform:scale(.97)}.primary-btn:disabled{opacity:.5;cursor:not-allowed}.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(180deg,var(--color-background) 0%,var(--color-background-secondary) 100%);color:var(--color-highlight);font-size:16px}.edit-subtask-list{max-height:200px;overflow-y:auto}@media(max-width:600px){.edit-subtask-list{max-height:40vh}}.subtask-list{background:#0003;border-radius:8px;margin-top:8px;padding:8px}.subtask-item{display:flex;align-items:center;gap:8px;padding:6px 8px;font-size:12px;color:#9ca3af}.subtask-item.completed{text-decoration:line-through;opacity:.6}.subtask-checkbox{width:22px;height:22px;min-width:36px;min-height:36px;border-radius:4px;border:2px solid color-mix(in srgb,var(--color-highlight) 60%,white);background:#0003;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;color:#fff;transition:background .15s,border-color .15s,transform .1s;flex-shrink:0}.subtask-checkbox:active{transform:scale(.9)}.subtask-checkbox.checked{background:#22c55e;border-color:#22c55e}.subtask-add{display:flex;gap:6px;margin-top:8px}.subtask-add input{flex:1;padding:6px 10px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#e8e6e3;font-size:12px}.subtask-add button{padding:6px 10px;background:color-mix(in srgb,var(--color-highlight) 20%,transparent);border:none;border-radius:6px;color:var(--color-highlight);cursor:pointer}.task-actions{display:flex;gap:4px}.expand-btn,.delete-btn{width:24px;height:24px;border-radius:6px;border:none;background:#ffffff0d;color:#6b7280;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.expand-btn:hover{background:color-mix(in srgb,var(--color-highlight) 20%,transparent);color:var(--color-highlight)}.delete-btn:hover{background:#ef444433;color:#f87171}.no-party-section{padding:40px 24px;text-align:center;position:relative;z-index:1}.no-party-card{background:#0000004d;border-radius:20px;padding:32px;border:1px solid color-mix(in srgb,var(--color-highlight) 10%,transparent);max-width:400px;margin:0 auto}.no-party-card h2{font-size:20px;color:#e8e6e3;margin:0 0 8px}.no-party-card p{color:#9ca3af;font-size:14px;margin:0 0 24px}.no-party-buttons{display:flex;gap:12px;justify-content:center}.secondary-btn{padding:12px 24px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#9ca3af;font-size:14px;cursor:pointer;transition:all .2s}.secondary-btn:hover{background:#ffffff1a;color:#e8e6e3}.chat-section{padding:0 24px 24px;position:relative;z-index:1}.inventory-modal{max-width:600px;max-height:80vh;overflow-y:auto}.modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:8px;border:none;background:#ffffff1a;color:#9ca3af;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#fff3;color:#e8e6e3}.skills-panel-container{padding:0 24px 24px;position:relative;z-index:1}.become-todo-toggle{margin-top:16px;padding:12px;background:#ffffff08;border-radius:10px}.toggle-label{display:flex;align-items:center;gap:10px;font-size:13px;color:#e8e6e3;cursor:pointer}.toggle-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-highlight)}.toggle-hint{font-size:11px;color:#6b7280;margin-top:6px;margin-left:28px}.schedule-sub-option{margin-top:12px}.schedule-sub-option label{display:block;font-size:12px;color:#9ca3af;margin-bottom:6px}.modal-select{width:100%;padding:10px 12px;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#e8e6e3;font-size:14px}.day-picker{display:flex;gap:6px;margin-top:12px}.day-btn{flex:1;padding:8px 4px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#9ca3af;font-size:11px;cursor:pointer;transition:all .2s}.day-btn.selected{background:color-mix(in srgb,var(--color-highlight) 20%,transparent);border-color:color-mix(in srgb,var(--color-highlight) 40%,transparent);color:color-mix(in srgb,var(--color-highlight) 70%,white)}.due-date-picker{margin-bottom:16px}.due-date-picker label{display:block;font-size:12px;color:#9ca3af;margin-bottom:6px}.dungeon-minimap{padding:12px;background:linear-gradient(135deg,color-mix(in srgb,var(--color-highlight) 10%,transparent),#0000004d);border-radius:16px;border:1px solid color-mix(in srgb,var(--color-highlight) 20%,transparent);cursor:pointer;transition:all .2s;align-self:start}.dungeon-minimap:hover{background:linear-gradient(135deg,color-mix(in srgb,var(--color-highlight) 15%,transparent),#0000004d);border-color:color-mix(in srgb,var(--color-highlight) 30%,transparent)}.minimap-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.minimap-title{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:500;color:#9ca3af}.minimap-icon{font-size:14px}.minimap-energy{display:none}.minimap-grid{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px;background:#0000004d;border-radius:10px}.minimap-row{display:flex;gap:2px}.minimap-cell{width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:12px;border-radius:5px;background:transparent}.minimap-cell.has-room{background:#ffffff0d;border:1px solid rgba(255,255,255,.1)}.minimap-cell.has-room.explored{background:#ffffff1a;border-color:#fff3}.minimap-cell.has-room:not(.explored){background:#0006;color:#6b7280}.minimap-cell.current{background:color-mix(in srgb,var(--color-highlight) 30%,transparent);border-color:var(--color-highlight);box-shadow:0 0 8px color-mix(in srgb,var(--color-highlight) 50%,transparent);animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 8px color-mix(in srgb,var(--color-highlight) 30%,transparent)}50%{box-shadow:0 0 16px color-mix(in srgb,var(--color-highlight) 60%,transparent)}}.minimap-legend{display:flex;justify-content:space-between;align-items:center;margin-top:8px;font-size:10px;color:#6b7280}.combat-alert{color:#f87171;font-weight:600;animation:blink 1s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}@media(max-width:600px){.minimap-cell{width:22px;height:22px;font-size:10px;border-radius:4px}.minimap-grid{padding:6px;gap:1px}.minimap-row{gap:1px}.dungeon-minimap{padding:8px;border-radius:12px}.minimap-title{font-size:10px}.minimap-icon{font-size:12px}}@media(max-width:360px){.minimap-cell{width:18px;height:18px;font-size:8px}}.event-bucket{background:#ffffff05;border-radius:8px;padding:6px 8px 8px;margin-bottom:6px;border:1px solid rgba(255,255,255,.04)}.time-bucket-divider{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:#9ca3af;padding:4px 0;margin-bottom:4px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:6px}.time-bucket-divider.past-due{color:#f87171;border-bottom-color:#f8717133}.event-date-badge{font-size:10px;color:#9ca3af;white-space:nowrap}.event-date-badge.past-due{color:#f87171;font-weight:600}.column-header-actions{display:flex;align-items:center;gap:6px}.view-toggle-btn{background:none;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#9ca3af;cursor:pointer;padding:2px 8px;font-size:14px;transition:all .15s}.view-toggle-btn:hover{border-color:#ffffff4d;color:#e8e6e3}.event-calendar{padding:4px 0}.calendar-nav{display:flex;align-items:center;justify-content:space-between;padding:4px 0 8px}.calendar-nav-btn{background:none;border:none;color:#9ca3af;cursor:pointer;font-size:18px;padding:4px 8px;border-radius:6px;transition:color .15s}.calendar-nav-btn:hover{color:#e8e6e3}.calendar-month-label{font-size:13px;font-weight:600;color:#e8e6e3}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}.calendar-header-cell{font-size:10px;font-weight:600;text-align:center;color:#6b7280;padding:4px 0;text-transform:uppercase}.calendar-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:12px;color:#9ca3af;cursor:pointer;border-radius:6px;position:relative;transition:background .15s}.calendar-day:hover{background:#ffffff0f}.calendar-day.today{border:1px solid var(--color-highlight);color:#e8e6e3}.calendar-day.selected{background:var(--color-highlight);color:#fff}.calendar-day.has-events{font-weight:600;color:#e8e6e3}.calendar-day.selected.has-events{color:#fff}.calendar-day.empty{cursor:default}.calendar-day.empty:hover{background:none}.calendar-dot{width:4px;height:4px;border-radius:50%;background:#f59e0b;position:absolute;bottom:3px}.calendar-dot.past-due{background:#f87171}.calendar-dot.multi{width:8px;border-radius:2px}.calendar-selected-events{margin-top:8px;border-top:1px solid rgba(255,255,255,.08);padding-top:8px}.calendar-selected-date-label{font-size:11px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.boss-teleport-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1200;padding:1rem;animation:bossTeleportFadeIn .3s ease}@keyframes bossTeleportFadeIn{0%{opacity:0}to{opacity:1}}.boss-teleport-modal{background:linear-gradient(135deg,#1a0a2e,#0a1628);border:2px solid #7c4dff;border-radius:16px;padding:2rem;max-width:380px;width:100%;text-align:center;color:#e0e0e0;box-shadow:0 0 60px #7c4dff4d;animation:bossTeleportPulse .4s ease}@keyframes bossTeleportPulse{0%{transform:scale(.8);opacity:0}60%{transform:scale(1.03)}to{transform:scale(1);opacity:1}}.boss-teleport-icon{font-size:3.5rem;margin-bottom:.5rem;animation:bossTeleportSpin .6s ease}@keyframes bossTeleportSpin{0%{transform:rotate(0) scale(.5);opacity:0}to{transform:rotate(360deg) scale(1);opacity:1}}.boss-teleport-title{color:#b388ff;font-size:1.4rem;margin:0 0 .75rem}.boss-teleport-body{color:#bbb;font-size:.95rem;margin:0 0 1.5rem;line-height:1.5}.boss-teleport-btn{background:#7c4dff;color:#fff;border:none;padding:.75rem 2.5rem;border-radius:8px;font-size:1.05rem;font-weight:600;cursor:pointer;transition:background .2s}.boss-teleport-btn:hover{background:#651fff}.import-modal{width:90%;max-width:500px;max-height:80vh;overflow-y:auto}.import-form .modal-input{width:100%;padding:1rem;background:#1a1a2e;border:none;border-radius:12px;color:#fff;font-size:1rem;margin-bottom:1rem;box-sizing:border-box}.import-form .modal-input:focus{outline:2px solid #e94560}.import-form .modal-input::placeholder{color:#666}.import-form .primary-btn{background:#e94560;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:.9rem;transition:background .2s;width:100%}.import-form .primary-btn:hover:not(:disabled){background:#d63850}.import-form .primary-btn:disabled{opacity:.6;cursor:not-allowed}.import-results .secondary-btn{background:transparent;color:#e94560;border:1px solid #e94560;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .2s;width:100%}.import-results .secondary-btn:hover{background:#e945601a}.import-instructions{background:#1a1a2e;padding:1rem;border-radius:8px;margin-bottom:1.5rem;font-size:.9rem}.import-instructions p{margin:0 0 .75rem;color:#ccc}.import-instructions ol{margin:0;padding-left:1.25rem;color:#aaa}.import-instructions li{margin-bottom:.5rem}.import-instructions a{color:#e94560;text-decoration:none}.import-instructions a:hover{text-decoration:underline}.import-form .form-group{margin-bottom:1rem}.import-form label{display:block;font-size:.85rem;color:#888;margin-bottom:.5rem}.import-options{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.import-option{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:#ccc;font-size:.9rem}.import-option input[type=checkbox]{width:18px;height:18px;accent-color:#e94560}.import-error{background:#f4433633;color:#f44336;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.import-results{padding-top:.5rem}.import-summary{display:flex;gap:1.5rem;justify-content:center;margin-bottom:1.5rem}.summary-stat{text-align:center;padding:1rem 1.5rem;background:#1a1a2e;border-radius:8px;min-width:100px}.summary-stat.success{border:2px solid #4caf50}.summary-stat.skipped{border:2px solid #ff9800}.stat-value{display:block;font-size:2rem;font-weight:700;color:#fff}.stat-label{font-size:.85rem;color:#888}.imported-tasks-list{margin-bottom:1rem}.imported-tasks-list h4{margin:0 0 .75rem;font-size:.9rem;color:#888}.tasks-scroll{max-height:200px;overflow-y:auto;background:#1a1a2e;border-radius:8px;padding:.5rem}.imported-task{display:flex;align-items:center;gap:.5rem;padding:.5rem;border-radius:4px;font-size:.85rem}.imported-task.success{background:#4caf501a}.imported-task.skipped{background:#ff98001a;opacity:.7}.task-icon{flex-shrink:0}.task-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#ddd}.task-status{color:#4caf50;font-weight:700}.task-error{color:#ff9800;font-size:.75rem}.import-errors{margin-bottom:1rem}.import-errors h4{margin:0 0 .5rem;font-size:.9rem;color:#f44336}.error-item{background:#f443361a;color:#f44336;padding:.5rem;border-radius:4px;font-size:.85rem;margin-bottom:.25rem}.habitica-sync-panel{padding:1rem 0}.sync-status{display:flex;align-items:center;justify-content:space-between;background:#4caf501a;border:1px solid rgba(76,175,80,.3);border-radius:8px;padding:1rem;margin-bottom:1rem}.status-connected{display:flex;align-items:center;gap:.5rem;color:#4caf50;font-weight:500}.status-icon{font-size:1.2rem}.connected-id{font-size:.8rem;color:#888}.sync-results{background:#1a1a2e;border-radius:8px;padding:1rem;margin-bottom:1rem}.sync-stat{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.1)}.sync-stat:last-child{border-bottom:none}.sync-stat .stat-label{color:#aaa;font-size:.9rem}.sync-stat .stat-value{color:#fff;font-weight:500;font-size:.9rem}.sync-errors{margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.1)}.sync-actions{display:flex;flex-direction:column;gap:.5rem}.sync-actions .primary-btn{background:#4caf50}.sync-actions .primary-btn:hover:not(:disabled){background:#43a047}.sync-actions .secondary-btn{background:transparent;color:var(--color-highlight, #e94560);border:1px solid var(--color-highlight, #e94560);padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:.9rem}.sync-actions .cancel-btn{background:transparent;color:#888;border:1px solid rgba(255,255,255,.2);padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:.9rem}.sync-actions .cancel-btn:hover{color:#f44336;border-color:#f44336}@media(max-width:480px){.import-options{flex-direction:column;gap:.75rem}.import-summary{gap:1rem}.summary-stat{min-width:80px;padding:.75rem 1rem}.stat-value{font-size:1.5rem}.sync-status{flex-direction:column;gap:.5rem;text-align:center}}.settings-page{min-height:100vh;background:var(--color-background);color:var(--color-text)}.settings-header{display:flex;align-items:center;gap:1.5rem;padding:1rem 2rem;background:var(--color-background-secondary);border-bottom:1px solid var(--color-border)}.settings-header h1{margin:0;color:var(--color-highlight);font-size:1.5rem}.back-btn{background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted);padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .2s}.back-btn:hover{border-color:var(--color-highlight);color:var(--color-highlight)}.settings-content{max-width:800px;margin:0 auto;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.settings-section{background:var(--color-background-secondary);border-radius:16px;padding:1.5rem}.settings-section h2{margin:0 0 .5rem;font-size:1.25rem;color:var(--color-text)}.section-description{color:var(--color-text-muted);font-size:.9rem;margin:0 0 1.5rem}.account-info{margin-bottom:2rem;padding:1rem;background:var(--color-background);border-radius:12px}.info-row{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid #2a2a4e}.info-row:last-child{border-bottom:none}.info-label{color:var(--color-text-muted);font-size:.9rem}.info-value{color:var(--color-text);font-weight:500}.password-change h3{margin:0 0 1rem;font-size:1rem;color:var(--color-text)}.settings-input{width:100%;padding:1rem;background:var(--color-background);border:none;border-radius:12px;color:var(--color-text);font-size:1rem;margin-bottom:1rem;box-sizing:border-box}.settings-input:focus{outline:2px solid var(--color-highlight)}.settings-input::placeholder{color:#666}.error-message{color:var(--color-error);font-size:.875rem;margin:0 0 1rem}.success-message{color:var(--color-success);font-size:.875rem;margin:0 0 1rem}.primary-btn{background:var(--color-button);color:var(--color-text);border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:.9rem;transition:background .2s}.primary-btn:hover:not(:disabled){background:var(--color-button-hover)}.primary-btn:disabled{opacity:.6;cursor:not-allowed}.secondary-btn{background:transparent;color:var(--color-button);border:1px solid var(--color-button);padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .2s}.secondary-btn:hover:not(:disabled){background:#e945601a}.secondary-btn:disabled{opacity:.5;cursor:not-allowed}.notification{position:fixed;top:1rem;right:1rem;background:var(--color-success);color:var(--color-text);padding:1rem 1.5rem;border-radius:8px;z-index:1000;animation:slideIn .3s ease-out}.theme-controls{display:flex;flex-direction:column;gap:1.25rem}.color-setting{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--color-background);border-radius:12px}.color-setting label{display:flex;flex-direction:column;gap:.25rem}.color-label{font-weight:500;color:var(--color-text)}.color-value{font-size:.8rem;color:var(--color-text-muted);font-family:monospace;text-transform:uppercase}.color-input-wrapper{display:flex;align-items:center;gap:.75rem}.color-input{width:50px;height:40px;padding:0;border:none;border-radius:8px;cursor:pointer;background:transparent}.color-input::-webkit-color-swatch-wrapper{padding:0}.color-input::-webkit-color-swatch{border:2px solid rgba(255,255,255,.2);border-radius:6px}.color-input::-moz-color-swatch{border:2px solid rgba(255,255,255,.2);border-radius:6px}.color-preview{width:40px;height:40px;border-radius:8px;border:2px solid rgba(255,255,255,.2)}.theme-actions{display:flex;justify-content:flex-end;padding-top:.5rem}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:768px){.settings-header{padding:.75rem 1rem;gap:1rem}.settings-header h1{font-size:1.25rem}.settings-content{padding:1rem;gap:1rem}.back-btn{padding:.4rem .75rem;font-size:.85rem}.settings-section{padding:1rem}}@media(max-width:480px){.settings-header{flex-direction:column;align-items:flex-start;gap:.75rem}.info-row{flex-direction:column;gap:.25rem}.color-setting{flex-direction:column;align-items:flex-start;gap:.75rem}.color-input-wrapper{width:100%;justify-content:flex-end}}.task-columns-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.task-column-row{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;background:var(--color-background);border-radius:10px;transition:opacity .2s}.task-column-row.disabled{opacity:.5}.task-column-arrows{display:flex;flex-direction:column;gap:2px}.task-column-arrow{background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted);width:26px;height:20px;border-radius:4px;cursor:pointer;font-size:.6rem;display:flex;align-items:center;justify-content:center;padding:0;transition:all .15s}.task-column-arrow:hover:not(:disabled){border-color:var(--color-highlight);color:var(--color-highlight)}.task-column-arrow:disabled{opacity:.3;cursor:not-allowed}.task-column-label{flex:1;font-weight:600;font-size:.95rem;color:var(--color-text)}.toggle-settings{display:flex;flex-direction:column;gap:1rem}.toggle-setting{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;background:var(--color-background);border-radius:10px;cursor:pointer}.toggle-label{display:flex;flex-direction:column;gap:.2rem}.toggle-title{font-weight:600;font-size:.95rem;color:var(--color-text)}.toggle-desc{font-size:.8rem;color:var(--color-text-muted)}.toggle-input{width:44px;height:24px;appearance:none;background:#333;border-radius:12px;position:relative;cursor:pointer;flex-shrink:0;transition:background .2s}.toggle-input:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#888;border-radius:50%;transition:transform .2s,background .2s}.toggle-input:checked{background:#7b1fa2}.toggle-input:checked:after{transform:translate(20px);background:#fff}.loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#1a1a2e;color:#fff;font-size:1.5rem}
