*{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}.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}}.item-sprite{image-rendering:pixelated;flex-shrink:0}.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}.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.vertical{flex-direction:column;align-items:stretch;margin:0;padding:12px;overflow:visible;box-sizing:border-box;background:#0003;border-radius:16px;border:1px solid rgba(255,255,255,.05);height:100%}.quest-item-bar.vertical .quest-item-bar-label{text-align:center;margin-bottom:.4rem}.quest-item-bar.vertical .quest-item-bar-items{display:flex;gap:.3rem;flex:1;min-height:0}.quest-item-bar-col{display:flex;flex-direction:column;gap:.3rem}.quest-item-bar.vertical .quest-item-btn{justify-content:center}.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)}}.skills-hotbar{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#ffffff08;border-radius:8px;margin:.5rem 16px;overflow-x:auto}.skills-hotbar.vertical{flex-direction:column;align-items:stretch;margin:0;padding:12px;overflow:visible;box-sizing:border-box;background:#0003;border-radius:16px;border:1px solid rgba(255,255,255,.05);height:100%}.skills-hotbar.vertical .skills-hotbar-label{text-align:center;margin-bottom:.4rem}.skills-hotbar.vertical .skills-hotbar-items{display:flex;gap:.3rem;flex:1;min-height:0}.skills-hotbar-col{display:flex;flex-direction:column;gap:.3rem}.skills-hotbar.vertical .skills-hotbar-btn{justify-content:center}.skills-hotbar-label{color:#888;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.skills-hotbar-items{display:flex;gap:.4rem;flex-wrap:wrap}.skills-hotbar-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;position:relative}.skills-hotbar-btn:hover:not(:disabled){border-color:#8a7fbf;background:#252545}.skills-hotbar-btn.ready{border-color:#6d5db8}.skills-hotbar-btn.cooldown{opacity:.55;cursor:not-allowed;border-color:#333}.skills-hotbar-btn.mana-low{opacity:.65;cursor:not-allowed;border-color:#33506b}.skills-hotbar-btn.disabled{cursor:not-allowed}.skills-hotbar-icon{display:inline-flex;align-items:center;justify-content:center;line-height:1}.skills-hotbar-cd{color:#d88c4c;font-size:.65rem;font-weight:600}.skills-hotbar-mana{color:#6fa6e0;font-size:.65rem;font-weight:600}.skills-target-backdrop{position:fixed;inset:0;z-index:199;background:#0000004d}.skills-target-popover{position:fixed;bottom:80px;left:50%;transform:translate(-50%);width:260px;z-index:200;background:#1e1e3a;border:1px solid rgba(120,100,180,.5);border-radius:10px;padding:.75rem;box-shadow:0 4px 20px #0009}.skills-target-header{color:#e8e6e3;font-size:.9rem;font-weight:600;padding:0 0 .3rem;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:.4rem}.skills-target-desc{color:#aaa;font-size:.75rem;margin-bottom:.5rem;line-height:1.3}.skills-target-select{width:100%;padding:.4rem;background:#131327;color:#e8e6e3;border:1px solid #444;border-radius:4px;font-size:.8rem;margin-bottom:.5rem}.skills-target-error{color:#f44336;font-size:.75rem;margin-bottom:.5rem}.skills-target-actions{display:flex;gap:.4rem;justify-content:flex-end}.skills-target-cancel,.skills-target-confirm{padding:.35rem .7rem;border-radius:4px;font-size:.75rem;cursor:pointer;border:1px solid #444}.skills-target-cancel{background:transparent;color:#aaa}.skills-target-cancel:hover{background:#ffffff0d;color:#ccc}.skills-target-confirm{background:#4a3b8a;color:#fff;border-color:#6d5db8}.skills-target-confirm:hover:not(:disabled){background:#5a4ba0}.skills-target-confirm:disabled{opacity:.5;cursor:not-allowed}@media(max-width:480px){.skills-target-popover{left:0;right:0;bottom:70px;width:auto;transform:none;border-radius:12px 12px 0 0;padding:.75rem}}.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-container.large{width:128px;height:128px}.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.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}.character-sprite-container.aura-crimson-storm{box-shadow:0 0 12px 5px #f443368c,0 0 20px 8px #ffeb3b33;border-radius:4px;animation:auraFlicker 1.1s ease-in-out infinite}.character-sprite-container.aura-glacial-crown{box-shadow:0 0 10px 4px #4fc3f78c,0 0 16px 6px #e0f7fa40;border-radius:4px;animation:auraPulse 2.4s ease-in-out infinite}.character-sprite-container.aura-natures-embrace{box-shadow:0 0 10px 4px #4caf5080,inset 0 0 6px #4caf502e;border-radius:4px;animation:auraPulse 2.6s ease-in-out infinite}.character-sprite-container.aura-abyssal-mist{box-shadow:0 0 12px 5px #0d47a18c,inset 0 0 8px #5e35b140;border-radius:4px;animation:auraPulse 2.8s 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}.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}.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;transition:all .15s}.cs-tier.earned{opacity:1;box-shadow:0 0 0 1px #ffffff0f inset}.cs-tier.next{opacity:.85;border-color:#ffffff59;box-shadow:0 0 0 1px #ffffff14 inset,0 0 8px #ffffff14}.cs-tier.locked{opacity:.32;filter:saturate(.7)}.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}}.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)}}.notification-error{background:linear-gradient(135deg,#ef4444,#b91c1c);box-shadow:0 4px 20px #ef444466}.notification-success{background:linear-gradient(135deg,#22c55e,#15803d);box-shadow:0 4px 20px #22c55e59}.notification+.notification{top:72px}.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}.conn-indicator{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;white-space:nowrap;padding:2px 8px;border-radius:999px;line-height:1.4}.conn-indicator .conn-dot{width:7px;height:7px;border-radius:50%;flex:0 0 auto}.conn-indicator.offline{color:#fca5a5;background:#ef44441f}.conn-indicator.offline .conn-dot{background:#ef4444}.conn-indicator.syncing{color:#93c5fd;background:#3b82f61f}.conn-indicator.syncing .conn-dot{background:#3b82f6;animation:conn-pulse 1.1s ease-in-out infinite}@keyframes conn-pulse{0%,to{opacity:1}50%{opacity:.3}}@media(prefers-reduced-motion:reduce){.conn-indicator.syncing .conn-dot{animation:none}}@media(max-width:600px){.top-bar-party{display:none}}.top-bar-right{display:flex;align-items:center;gap:8px}.focus-mode-toggle{background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:6px;padding:4px 8px;font-size:16px;cursor:pointer;line-height:1;transition:background .15s}.focus-mode-toggle:hover{background:#ffffff26}.focus-mode-toggle.active{background:#6366f133;border-color:#6366f166}.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}.level-up-banner{display:flex;align-items:center;gap:6px;background:linear-gradient(135deg,gold,#ff8c00,gold);background-size:200% 100%;color:#1a1a2e;border:2px solid #fff3;padding:6px 16px;border-radius:8px;font-size:15px;font-weight:800;letter-spacing:.5px;cursor:pointer;animation:levelUpShimmer 1.5s ease-in-out infinite,levelUpPulse 2s ease-in-out infinite;text-shadow:0 1px 2px rgba(0,0,0,.15)}.level-up-banner:hover{transform:scale(1.05)}@keyframes levelUpShimmer{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes levelUpPulse{0%,to{box-shadow:0 0 8px 2px #ffd70080}50%{box-shadow:0 0 20px 6px #ff8c0099}}.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 auto auto auto;justify-content:start;gap:12px;padding:16px 24px;align-items:start}.quests-items-slot,.quests-skills-slot{height:var(--minimap-h, 320px)}@media(max-width:900px){.quests-status-row{grid-template-columns:1fr}.quests-items-slot,.quests-skills-slot{height:auto}.quests-items-slot .quest-item-bar.vertical,.quests-skills-slot .skills-hotbar.vertical{flex-direction:row;height:auto;overflow-x:auto;overflow-y:visible}.quests-items-slot .quest-item-bar.vertical .quest-item-bar-items,.quests-skills-slot .skills-hotbar.vertical .skills-hotbar-items{display:flex;flex-direction:row;flex-wrap:wrap;height:auto;overflow-y:visible}}@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}}@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:0;max-width:none;flex:1 1 0;padding:6px 8px;flex-direction:row;align-items:center;text-align:left;gap:8px}.quests-party-slot .party-member-card .member-sprite{flex:0 0 auto;width:56px;height:56px}.quests-party-slot .party-member-card .member-sprite .character-sprite-container.large{width:56px;height:56px}.quests-party-slot .party-member-card .member-info{flex:1 1 auto;min-width:0}.quests-layout>.tasks-section{order:2}.quests-minimap-slot{order:3;padding:8px 16px}.quests-items-slot{order:4;padding:0 16px}.quests-skills-slot{order:5;padding:0 16px}.quests-items-slot .quest-item-bar.vertical,.quests-skills-slot .skills-hotbar.vertical{height:auto;flex-direction:row}.quests-items-slot .quest-item-bar.vertical .quest-item-bar-items,.quests-skills-slot .skills-hotbar.vertical .skills-hotbar-items{display:flex;flex-direction:row;flex-wrap:wrap;height:auto}}.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 144px;min-width:144px;max-width:200px;background:#ffffff08;border-radius:12px;padding:12px 10px;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:4px;right:-2px;width:16px;height:16px;border-radius:50%;border:1.5px solid rgba(0,0,0,.55);z-index:1;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fffffff2;line-height: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:13px;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:11px;color:#6b7280;display:flex;align-items:center;gap:4px}.member-level .attr-badge{font-size:9px;padding:1px 4px;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}.poke-btn{background:none;border:1px solid rgba(255,255,255,.1);border-radius:4px;padding:1px 6px;font-size:10px;cursor:pointer;opacity:.6;transition:opacity .2s,background .2s;margin-top:2px}.poke-btn:hover:not(:disabled){opacity:1;background:#ffffff14}.poke-btn:disabled{opacity:.25;cursor:default}.party-solo-invite{display:flex;align-items:center;gap:16px;padding:16px 20px;margin-bottom:16px;background:linear-gradient(135deg,color-mix(in srgb,var(--color-highlight) 12%,transparent),color-mix(in srgb,var(--color-button) 8%,transparent));border:1px solid color-mix(in srgb,var(--color-highlight) 25%,transparent);border-radius:14px}.party-solo-invite-text{flex:1;min-width:0}.party-solo-invite-text h3{margin:0 0 4px;font-size:1rem;color:#e8e6e3}.party-solo-invite-text p{margin:0;font-size:.85rem;color:#9ca3af;line-height:1.4}.party-solo-invite-btn{flex:0 0 auto;padding:10px 16px;white-space:nowrap}@media(max-width:600px){.party-solo-invite{flex-direction:column;align-items:stretch;text-align:center;gap:10px}}.dungeon-party-card{margin-bottom:12px}@media(max-width:600px){.dungeon-party-card .party-member-card{padding:8px;flex-direction:row;align-items:center;text-align:left;gap:10px;min-width:0;max-width:none}.dungeon-party-card .member-sprite{flex:0 0 auto;width:56px;height:56px}.dungeon-party-card .member-sprite .character-sprite-container.large{width:56px;height:56px}.dungeon-party-card .member-info{flex:1 1 auto;min-width:0}.dungeon-party-card .party-members-grid{flex-direction:row;flex-wrap:nowrap;overflow-x:auto}.dungeon-party-card .party-member-card{flex:1 1 0}}.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:.7rem;color:var(--color-highlight);background:#ffffff0f;border:1px solid rgba(255,255,255,.12);padding:2px 8px;border-radius:10px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap}.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;align-items:center;gap:4px;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.05)}.tag-filter-bar:before{content:"⌕ Filter";font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:#fff6;margin-right:6px;flex:0 0 auto}.tag-filter-bar .tag-pill{cursor:pointer;background:#ffffff0a;border-color:#ffffff1f;color:#fff9}.tag-filter-bar .tag-pill:hover{background:#ffffff1a;border-color:#ffffff40;color:#ffffffd9}.tag-filter-bar .tag-pill.active{background:var(--color-highlight);border-color:var(--color-highlight);color:#fff}.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:4px;padding:4px 0 12px}@media(max-width:600px){.scroll-dots{display:flex;position:sticky;top:56px;z-index:9;background:color-mix(in srgb,var(--color-background) 92%,transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);margin:-20px -16px 8px;padding:6px 16px}}.scroll-dot{appearance:none;background:transparent;border:none;padding:0;margin:0;width:32px;height:32px;cursor:pointer;position:relative;flex-shrink:0}.scroll-dot:before{content:"";position:absolute;top:50%;left:50%;width:8px;height:8px;border-radius:50%;background:#ffffff59;transform:translate(-50%,-50%);transition:background .2s,width .2s,height .2s}.scroll-dot.active:before{background:var(--color-highlight, #fb923c);width:14px;height:14px}.scroll-dot:focus-visible{outline:none}.scroll-dot:focus-visible:before{box-shadow:0 0 0 3px color-mix(in srgb,var(--color-highlight) 40%,transparent)}@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-placeholder{display:flex;align-items:center;justify-content:center;width:32px;height:32px;color:#ffffff1a;font-size:18px;-webkit-user-select:none;user-select:none}@media(max-width:600px){.habit-item{padding:6px 8px;gap:6px}}.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}.dungeon-map-section,.skills-panel-container,.chat-section,.inventory-panel{padding-bottom:96px}.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;position:relative}.nav-badge{position:absolute;top:-4px;right:-6px;width:8px;height:8px;background:#e94560;border-radius:50%;border:1.5px solid color-mix(in srgb,var(--color-background) 95%,white);animation:navBadgePulse 2s ease-in-out infinite}@keyframes navBadgePulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.8}}.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;position:relative}.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;padding-right:36px}.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:20px -24px -24px;padding:16px 24px;position:sticky;bottom:-24px;background:linear-gradient(to bottom,transparent 0,var(--color-background) 25%,var(--color-background) 100%);border-bottom-left-radius:20px;border-bottom-right-radius:20px;z-index:2}.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)}.add-btn{flex:none;padding:8px 14px;background:transparent;border:1px solid color-mix(in srgb,var(--color-highlight) 45%,transparent);color:var(--color-highlight);border-radius:10px;font-size:18px;line-height:1;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.add-btn:hover{background:color-mix(in srgb,var(--color-highlight) 12%,transparent);border-color:var(--color-highlight)}.add-btn:disabled{opacity:.4;cursor:not-allowed}.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;display:flex;flex-direction:column;min-height:calc(100dvh - 151px)}.chat-section>.chat-panel,.chat-section>.party-solo-invite+.chat-panel{flex:1 1 auto}.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:flex-start;gap:10px;font-size:13px;color:#e8e6e3;cursor:pointer;line-height:1.4}.toggle-label>span{flex:1 1 auto;min-width:0}.toggle-label>input[type=checkbox]{margin-top:2px;flex:0 0 auto}.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}.loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#1a1a2e;color:#fff;font-size:1.5rem}.lazy-fallback{min-height:55vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:#8a8aa0;font-size:.95rem}.lazy-fallback:before{content:"";width:34px;height:34px;border-radius:50%;border:3px solid rgba(255,255,255,.12);border-top-color:var(--color-highlight, #e94560);animation:lazy-spin .8s linear infinite}@keyframes lazy-spin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.lazy-fallback:before{animation-duration:2.4s}}.error-boundary-fallback{min-height:240px;display:flex;align-items:center;justify-content:center;padding:32px 20px;color:#e8e6e3}.error-boundary-card{max-width:460px;width:100%;padding:24px;background:#16213e;border:1px solid rgba(255,255,255,.08);border-radius:14px;box-shadow:0 10px 32px #0006}.error-boundary-title{font-size:1.1rem;font-weight:600;color:#e8e6e3;margin-bottom:8px}.error-boundary-body{font-size:.9rem;color:#b3b3c3;margin-bottom:12px;line-height:1.45}.error-boundary-detail{font-size:.78rem;color:#7a7a8e;background:#00000040;padding:8px 10px;border-radius:8px;margin-bottom:16px;font-family:ui-monospace,JetBrains Mono,monospace;word-break:break-word;max-height:140px;overflow:auto}.error-boundary-actions{display:flex;gap:10px}.error-boundary-actions .primary-btn,.error-boundary-actions .cancel-btn{flex:1;padding:10px 14px;border-radius:10px;font-size:.9rem;cursor:pointer;border:none}.error-boundary-actions .primary-btn{background:#e94560;color:#fff}.error-boundary-actions .cancel-btn{background:#ffffff0f;color:#ccc;border:1px solid rgba(255,255,255,.1)}.error-boundary-stack{font-size:.7rem;color:#b3b3c3;background:#0006;padding:10px 12px;border-radius:8px;margin:0 0 14px;max-height:240px;overflow:auto;white-space:pre-wrap;word-break:break-word;font-family:ui-monospace,JetBrains Mono,monospace}.error-boundary-debug-row{display:flex;gap:16px;margin-top:12px;justify-content:center}.error-boundary-link{background:none;border:none;color:#7ea2ff;font-size:.82rem;cursor:pointer;padding:4px 6px;text-decoration:underline}
