@import"https://fonts.googleapis.com/css2?family=MedievalSharp&family=Cormorant+Garamond:wght@400;500;600;700&display=swap";:root{--bg-primary: #080810;--bg-secondary: #111122;--bg-panel: #13152a;--bg-card: #1a1d38;--bg-hover: #222548;--text-primary: #e4e4f0;--text-secondary: #9090b0;--text-muted: #5a5a7a;--accent-gold: #f0c040;--accent-gold-dim: #a08020;--accent-green: #40c060;--accent-red: #d04050;--accent-blue: #4080d0;--accent-purple: #a050d0;--border-color: #252848;--border-glow: #353868;--font-title: "MedievalSharp", serif;--font-body: "Cormorant Garamond", serif;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--glass-bg: rgba(13, 15, 30, .85);--glass-border: rgba(255, 255, 255, .06);--glass-shadow: 0 4px 24px rgba(0, 0, 0, .4), inset 0 1px 0 rgba(255, 255, 255, .04);--shadow-glow-gold: 0 0 12px rgba(240, 192, 64, .15);--shadow-glow-green: 0 0 12px rgba(64, 192, 96, .15);--transition-fast: .15s ease;--transition-med: .25s ease;--zone-hollows: #c8a040;--zone-cavern: #b85030;--zone-spire: #9e4a9e;--zone-abyss: #2a5a8a;--zone-crystalveil: #2a8a6a}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;overflow:hidden}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);min-width:320px;-webkit-font-smoothing:antialiased}.app{position:fixed;inset:0;z-index:1;display:flex;flex-direction:column;overflow:hidden}.panel{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow);padding:1rem}.panel-title{font-family:var(--font-title);font-size:.85rem;color:var(--accent-gold);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem}button,.btn{font-family:var(--font-title);font-size:.8rem;letter-spacing:.04em;padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-card);color:var(--text-primary);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}button:hover:not(:disabled),.btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-glow)}button:disabled,.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{border-color:var(--accent-gold-dim);box-shadow:var(--shadow-glow-gold)}.btn-primary:hover:not(:disabled){border-color:var(--accent-gold)}.btn-danger{border-color:#d040504d;color:var(--accent-red)}.btn-danger:hover:not(:disabled){border-color:var(--accent-red);background:#d040501a}.status-bar{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem;background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--glass-border);gap:1rem;flex-wrap:wrap}.status-bar-title{font-family:var(--font-title);font-size:1rem;color:var(--accent-gold);letter-spacing:.08em}.status-bar-stats{display:flex;gap:1.25rem;font-size:.95rem;color:var(--text-secondary)}.status-bar-actions{display:flex;gap:.5rem}.tab-bar{display:flex;gap:0;background:var(--bg-panel);border-bottom:1px solid var(--border-color)}.tab{flex:1;padding:.6rem .5rem;font-family:var(--font-title);font-size:.75rem;letter-spacing:.06em;text-align:center;color:var(--text-muted);background:transparent;border:none;border-bottom:2px solid transparent;border-radius:0;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast)}.tab:hover{color:var(--text-secondary);background:transparent}.tab.active{color:var(--text-primary);border-bottom-color:var(--accent-gold)}.tab-content{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.hero-header{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.hero-name{font-family:var(--font-title);font-size:.9rem;color:var(--text-primary)}.hero-status{font-size:.85rem;color:var(--text-secondary)}.hero-status.exploring{color:var(--accent-blue)}.hero-status.returning{color:var(--accent-gold)}.hero-status.loot-ready{color:var(--accent-green)}.hero-portrait{width:40px;height:40px;border-radius:50%;border:2px solid var(--border-color);object-fit:cover}.hero-stats{display:flex;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:var(--text-secondary)}.stat-bar{width:100%;height:6px;background:var(--bg-secondary);border-radius:var(--radius-sm);overflow:hidden}.stat-bar-fill{height:100%;border-radius:var(--radius-sm);transition:width .3s ease}.stat-bar-fill.hp-high{background:var(--accent-green)}.stat-bar-fill.hp-mid{background:#ff9800}.stat-bar-fill.hp-low{background:var(--accent-red)}.hero-actions{display:flex;gap:.5rem;flex-wrap:wrap}.recipe-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.recipe-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.6rem}.recipe-card.discovered{border-color:var(--accent-gold-dim)}.recipe-card-title{font-family:var(--font-title);font-size:.8rem;color:var(--accent-gold);margin-bottom:.25rem}.recipe-card-info{font-size:.85rem;color:var(--text-secondary)}.recipe-card-undiscovered{color:var(--text-muted);font-style:italic}.ingredient-row{display:flex;align-items:center;gap:.5rem;padding:.35rem 0}.ingredient-icon{width:28px;height:28px;border-radius:var(--radius-sm)}.ingredient-name{flex:1;font-size:.9rem}.ingredient-qty{color:var(--text-secondary);font-size:.85rem}.zone-header{font-family:var(--font-title);font-size:.75rem;letter-spacing:.06em;padding:.4rem 0 .2rem;margin-top:.5rem}.zone-header:first-child{margin-top:0}.craft-panel{display:flex;flex-direction:column;gap:.75rem}.craft-selects{display:flex;flex-direction:column;gap:.5rem}.craft-selects select{width:100%;padding:.5rem;background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.9rem}.craft-selects select:focus{outline:none;border-color:var(--accent-gold-dim)}.craft-actions{display:flex;gap:.5rem;flex-wrap:wrap}.page{display:flex;flex-direction:column;height:100%;overflow:hidden}.page-center{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:1.5rem;padding:2rem;text-align:center}.page-title{font-family:var(--font-title);font-size:2rem;color:var(--accent-gold);letter-spacing:.1em}.page-scroll{flex:1;overflow-y:auto;padding:1rem}.game-list{display:flex;flex-direction:column;gap:.5rem}.game-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.75rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.game-card-info{display:flex;flex-direction:column;gap:.2rem}.games-table,.leaderboard-table{width:100%;border-collapse:collapse}.games-table th,.leaderboard-table th{font-family:var(--font-title);font-size:clamp(.7rem,1vw,.85rem);color:var(--accent-gold);letter-spacing:.06em;text-align:left;padding:clamp(.35rem,.8vw,.65rem) clamp(.4rem,1vw,.75rem);border-bottom:1px solid var(--border-color);white-space:nowrap}.games-table td,.leaderboard-table td{padding:clamp(.35rem,.8vw,.65rem) clamp(.4rem,1vw,.75rem);border-bottom:1px solid rgba(37,40,72,.5);font-size:clamp(.8rem,1.1vw,1rem)}.games-table tr:hover,.leaderboard-table tr:hover{background:#ffffff08}.leaderboard-table tr:nth-child(-n+3) td:first-child{color:var(--accent-gold);font-weight:600}.leaderboard-row-me{background:#f0c0401a}.leaderboard-row-me:hover{background:#f0c04029}.leaderboard-row-me td{color:var(--accent-gold)}.leaderboard-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;padding:.75rem 0 .25rem}.leaderboard-pagination button{font-family:var(--font-title);font-size:.85rem;padding:.3rem .75rem;border-radius:var(--radius-sm);cursor:pointer}.leaderboard-pagination button:disabled{opacity:.35;cursor:default}.leaderboard-pagination-info{font-size:.85rem;color:var(--text-secondary)}.games-table .row-active{cursor:pointer}.games-table .row-finished{opacity:.65;cursor:pointer}.games-table .row-finished:hover,.games-table .row-active:hover{opacity:1}.games-section-label{font-family:var(--font-title);font-size:clamp(.8rem,1.1vw,.95rem);color:var(--text-secondary);letter-spacing:.05em;margin:1rem 0 .35rem}.games-section-label:first-child{margin-top:0}.table-scroll{overflow-x:auto}.td-right{text-align:right}.text-gold{color:var(--accent-gold)}.text-green{color:var(--accent-green)}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.game-over-banner{background:var(--bg-panel);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1rem;text-align:center}.game-over-banner.won{border-color:var(--accent-gold-dim);box-shadow:var(--shadow-glow-gold)}.game-over-banner.lost{border-color:#d040504d}.nav-bar{display:flex;gap:.75rem;padding:.75rem 1rem;justify-content:center;background:var(--glass-bg);border-top:1px solid var(--glass-border)}@keyframes zoom-in-out{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes pulse-glow{0%,to{filter:drop-shadow(0 0 10px rgba(240,192,64,.25))}50%{filter:drop-shadow(0 0 20px rgba(240,192,64,.42))}}.home-menu{display:flex;align-items:center;justify-content:center;height:100%}.home-menu-shell{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;gap:0;background-image:linear-gradient(180deg,#08081033,#08081073 45%,#080810b8),url(/assets/backgrounds/lab-bg.webp);background-size:cover;background-position:center;background-repeat:no-repeat;border:none;border-radius:0;box-shadow:none;padding:1rem 1.25rem 1.75rem;position:relative;overflow:hidden}.ambient-particles{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:0}.ambient-particle{position:absolute;width:8px;height:8px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#ffdea0f2,#ffb45a33);opacity:0;filter:blur(.2px);animation:ambient-float 10s linear infinite}.ambient-particle:nth-child(odd){background:radial-gradient(circle at 35% 35%,#dbcaffd9,#8264dc2e)}.ambient-particle:nth-child(1){left:6%;top:84%;animation-delay:0s;animation-duration:9.8s}.ambient-particle:nth-child(2){left:13%;top:76%;animation-delay:1.1s;animation-duration:11.4s}.ambient-particle:nth-child(3){left:22%;top:88%;animation-delay:2.4s;animation-duration:10.2s}.ambient-particle:nth-child(4){left:31%;top:80%;animation-delay:.6s;animation-duration:12.1s}.ambient-particle:nth-child(5){left:42%;top:90%;animation-delay:3.1s;animation-duration:10.9s}.ambient-particle:nth-child(6){left:53%;top:82%;animation-delay:1.9s;animation-duration:9.6s}.ambient-particle:nth-child(7){left:61%;top:88%;animation-delay:.4s;animation-duration:11.8s}.ambient-particle:nth-child(8){left:69%;top:78%;animation-delay:2.2s;animation-duration:10.3s}.ambient-particle:nth-child(9){left:77%;top:86%;animation-delay:1.4s;animation-duration:9.9s}.ambient-particle:nth-child(10){left:84%;top:79%;animation-delay:2.8s;animation-duration:11.6s}.ambient-particle:nth-child(11){left:91%;top:87%;animation-delay:.9s;animation-duration:10.8s}.ambient-particle:nth-child(12){left:96%;top:81%;animation-delay:3.3s;animation-duration:12.4s}@keyframes ambient-float{0%{transform:translateZ(0) scale(.7);opacity:0}10%{opacity:.55}80%{opacity:.35}to{transform:translate3d(-8px,-62vh,0) scale(1.18);opacity:0}}.home-menu-topbar,.home-menu-center{position:relative;z-index:1}.home-menu-logo{width:clamp(12rem,32vw,22rem);max-width:80%;user-select:none;animation:float 3s ease-in-out infinite,pulse-glow 3.4s ease-in-out infinite;flex-shrink:0;filter:drop-shadow(0 2px 12px rgba(0,0,0,.6))}.home-menu-center{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.25rem;width:100%;max-width:40rem;min-height:0}.home-menu-rank-panel{display:flex;align-items:center;justify-content:center;gap:.5rem;background:linear-gradient(180deg,#26120ad6,#160a06e6);border:1px solid rgba(247,178,92,.72);border-radius:999px;padding:.45rem 1rem;box-shadow:inset 0 1px #ffe09857,0 10px 22px #00000080}.home-menu-rank-icon{font-size:1.15rem;line-height:1;flex-shrink:0}.home-menu-rank-text{font-family:var(--font-title);font-size:clamp(1rem,2.5vw,1.45rem);font-weight:400;letter-spacing:.06em;color:#2a1208;-webkit-text-stroke:1px rgba(248,196,116,.86);text-shadow:0 1px 0 rgba(255,234,188,.75),0 2px 4px rgba(0,0,0,.78),0 8px 18px rgba(0,0,0,.58);text-transform:uppercase;white-space:nowrap}.home-menu-actions{width:100%;max-width:40rem;display:grid;grid-template-columns:1fr;justify-items:center;gap:.6rem}.home-menu-button{width:min(100%,34rem);min-height:3rem;border-radius:.85rem;border:1px solid rgba(121,113,170,.35);background:linear-gradient(180deg,#2a284ad6,#1f1e39d6);color:#f2eef8;font-family:var(--font-title);font-size:clamp(1rem,2.5vw,1.45rem);letter-spacing:.05em;text-transform:uppercase}.home-menu-button:hover:not(:disabled){border-color:#f0c0408c;background:linear-gradient(180deg,#3a365bf2,#252240f2)}.home-menu-button-primary{border-color:#f0c04073;background:linear-gradient(180deg,#593f1ce0,#3a2a12e6);box-shadow:0 0 16px #f0c04033}.home-menu-button-primary:hover:not(:disabled){border-color:#ffd67bd1;background:linear-gradient(180deg,#6f4f26eb,#4a3517f0)}.home-menu-error{width:100%;max-width:40rem;color:#ffbcbc;background:#2e0e10ad;border:1px solid rgba(208,64,80,.45);border-radius:.6rem;padding:.5rem .7rem;text-align:center;font-size:1rem}.home-menu-topbar{width:100%;display:flex;align-items:flex-start;justify-content:space-between;flex-shrink:0;padding:0 .25rem}.home-menu-player-chip{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.1rem;background:linear-gradient(180deg,#2a284ad6,#1f1e39d6);border:1px solid rgba(121,113,170,.35);border-radius:.85rem;min-height:2.2rem;padding:.35rem .65rem;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast);text-align:center;font:inherit;color:inherit}.home-menu-player-chip:hover{border-color:#f0c0408c;background:linear-gradient(180deg,#3a365bf2,#252240f2)}.home-menu-player-name{font-family:var(--font-title);font-size:clamp(.85rem,2.2vw,1.1rem);color:var(--accent-gold);letter-spacing:.04em;text-transform:uppercase}.home-menu-gear{background:linear-gradient(180deg,#2a284ad6,#1f1e39d6);border:1px solid rgba(121,113,170,.35);border-radius:.85rem;color:#f2eef8;display:inline-flex;align-items:center;justify-content:center;gap:.35rem;font-family:var(--font-title);font-size:clamp(.75rem,2vw,1.1rem);letter-spacing:.05em;text-transform:uppercase;min-height:2.2rem;padding:.35rem .65rem;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast);line-height:1}.home-menu-gear:hover{border-color:#f0c0408c;background:linear-gradient(180deg,#3a365bf2,#252240f2)}.home-menu-stats{display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap;font-family:var(--font-body);font-size:clamp(.9rem,2.2vw,1.1rem);color:var(--text-secondary)}.home-menu-stats-sep{color:var(--text-muted)}.settings-overlay-backdrop{position:absolute;inset:0;background:#0000008c;z-index:10;animation:settings-fade-in .2s ease}.settings-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:11;width:min(22rem,90%);display:flex;flex-direction:column;gap:1rem;animation:settings-fade-in .2s ease}@keyframes settings-fade-in{0%{opacity:0}to{opacity:1}}.settings-overlay-title{font-family:var(--font-title);font-size:1.1rem;color:var(--accent-gold);letter-spacing:.08em;text-align:center}.settings-section{display:flex;flex-direction:column;gap:.5rem}.settings-section-label{font-family:var(--font-title);font-size:.75rem;color:var(--accent-gold-dim);letter-spacing:.06em;text-transform:uppercase}.settings-slider-row{display:flex;align-items:center;gap:.6rem}.settings-slider-label{flex:0 0 4.5rem;font-size:.9rem;color:var(--text-secondary)}.settings-slider{flex:1;-webkit-appearance:none;appearance:none;height:6px;background:#9090b040;border-radius:3px;outline:none;border:none;padding:0}.settings-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent-gold);cursor:pointer;border:2px solid var(--bg-primary);box-shadow:0 0 6px #f0c0404d}.settings-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent-gold);cursor:pointer;border:2px solid var(--bg-primary);box-shadow:0 0 6px #f0c0404d}.settings-slider-value{flex:0 0 2.5rem;text-align:right;font-size:.85rem;color:var(--text-muted);font-family:Courier New,monospace}.settings-confirm-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.settings-confirm-text{font-size:.85rem;color:var(--text-secondary);margin-right:auto}.settings-toggle-row{display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding:.2rem 0}.settings-toggle-label{font-size:.9rem;color:var(--text-secondary)}.settings-toggle{appearance:none;-webkit-appearance:none;width:36px;height:20px;background:var(--bg-secondary);border-radius:10px;border:1px solid var(--border-color);position:relative;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.settings-toggle:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:var(--text-muted);transition:transform var(--transition-fast),background var(--transition-fast)}.settings-toggle:checked{background:#f0c04033;border-color:var(--accent-gold-dim)}.settings-toggle:checked:after{transform:translate(16px);background:var(--accent-gold)}.settings-close-btn{margin-top:.25rem;min-height:2rem;font-size:.85rem;padding:.35rem 1.5rem;align-self:center;width:auto}.settings-surrender-section{border-top:1px solid rgba(255,255,255,.08);padding-top:.75rem}.settings-surrender-btn{width:100%;padding:.5rem 1rem;font-family:var(--font-title);font-size:.85rem;cursor:pointer}@media(min-width:768px){.home-menu-shell{padding:1.5rem 2.5rem 2rem}.home-menu-logo{width:clamp(14rem,24vw,24rem)}}.loading-screen{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-primary);z-index:100}.loading-bg{position:absolute;inset:0;background-size:cover;background-position:center;animation:zoom-in-out 30s ease-in-out infinite}.loading-bg:after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 40%,var(--bg-primary) 100%)}.loading-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:2rem;padding:2rem}.loading-logo{width:12rem;max-width:340px;animation:float 3s ease-in-out infinite,pulse-glow 3s ease-in-out infinite}.loading-status{font-family:var(--font-title);font-size:clamp(1rem,2.5vw,1.45rem);font-weight:400;color:#2a1208;display:inline-block;padding:.45rem .85rem;border-radius:999px;border:1px solid rgba(247,178,92,.72);background:linear-gradient(180deg,#26120ad6,#160a06e6);-webkit-text-stroke:1px rgba(248,196,116,.86);text-shadow:0 1px 0 rgba(255,234,188,.75),0 2px 4px rgba(0,0,0,.78),0 8px 18px rgba(0,0,0,.58);box-shadow:inset 0 1px #ffe09857,0 10px 22px #00000080;letter-spacing:.06em;text-transform:uppercase;text-align:center}.loading-spinner{display:inline-block;width:1.1em;height:1.1em;border:2.5px solid rgba(247,178,92,.2);border-top-color:#f7b25cd9;border-radius:50%;animation:spin .8s linear infinite;vertical-align:-.05em;margin-right:.4em}@keyframes spin{to{transform:rotate(360deg)}}.loading-error{max-width:40rem;font-family:var(--font-body);font-size:.95rem;color:#ffb3b3;background:#230a0a99;border:1px solid rgba(208,64,80,.4);border-radius:var(--radius-md);padding:.6rem .8rem;text-align:center;line-height:1.25}@media(min-width:768px){.loading-logo{width:16rem}}@media(min-width:1024px){.loading-logo{width:20rem}}.play-screen{position:fixed;inset:0;z-index:1;pointer-events:none;overflow:hidden}.play-screen>*{pointer-events:auto}.floating-panel{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow)}.status-hud{position:absolute;top:12px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:.6rem;padding:.35rem .5rem;font-family:var(--font-title);font-size:.9rem;letter-spacing:.04em;white-space:nowrap;z-index:12}.status-hud-btn{background:transparent;border:none;box-shadow:none;font-family:var(--font-title);font-size:.85rem;letter-spacing:.04em;color:var(--text-secondary);cursor:pointer;padding:.2rem .4rem;border-radius:var(--radius-sm);transition:color var(--transition-fast),background var(--transition-fast)}.status-hud-btn:hover{color:var(--text-primary);background:#ffffff0f}.status-hud-settings{font-size:1.05rem;line-height:1}.status-hud-divider{width:1px;height:1.1rem;background:var(--glass-border);flex-shrink:0}.status-hud-gold{color:var(--accent-gold);position:relative}.gold-float-anim{position:absolute;left:50%;bottom:100%;transform:translate(-50%);color:#f0c040;font-weight:700;font-size:.85rem;white-space:nowrap;pointer-events:none;animation:gold-float-up 1.2s ease-out forwards}@keyframes gold-float-up{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-1.5rem)}}.status-hud-time{color:var(--text-primary)}.status-hud-sep{color:var(--text-muted);font-size:.7rem}.status-hud-progress{position:relative;width:80px;height:18px;background:var(--bg-secondary);border-radius:var(--radius-sm);overflow:hidden}.status-hud-progress-fill{position:absolute;inset:0;width:0;background:var(--accent-green);border-radius:var(--radius-sm);transition:width .5s ease}.status-hud-progress-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:600;color:var(--text-primary);text-shadow:0 1px 2px rgba(0,0,0,.6);z-index:1}.play-left-panels{position:absolute;left:12px;top:52px;bottom:12px;width:clamp(280px,23vw,420px);z-index:10;display:flex;flex-direction:column;gap:8px;overflow-y:auto;pointer-events:auto;scrollbar-width:thin}.play-right-panels{position:absolute;right:12px;top:52px;bottom:52px;width:clamp(280px,23vw,420px);z-index:10;display:flex;flex-direction:column;gap:8px;overflow-y:auto;pointer-events:auto;scrollbar-width:thin}.side-panel{display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.side-panel-header{display:flex;align-items:center;justify-content:space-between;padding:.6rem .85rem;border:none;background:transparent;cursor:pointer;border-bottom:1px solid var(--border-color);transition:background var(--transition-fast);width:100%;text-align:left}.side-panel-header:hover{background:var(--bg-hover)}.side-panel-title{font-family:var(--font-title);font-size:1rem;color:var(--accent-gold);letter-spacing:.06em;text-transform:uppercase}.side-panel-chevron{color:var(--text-muted);font-size:.75rem;transition:transform var(--transition-fast)}.side-panel-body{padding:.85rem;display:flex;flex-direction:column;gap:.55rem;overflow-y:auto;font-size:.88rem;animation:panel-open .2s ease-out}@keyframes panel-open{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.collection-header{display:flex;align-items:center;gap:0;padding:0;cursor:default}.collection-tab{flex:1;padding:.5rem .6rem;border:1px solid transparent;border-radius:var(--radius-sm);background:transparent;cursor:pointer;font-family:var(--font-title);font-size:.8rem;color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase;transition:all var(--transition-fast)}.collection-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.collection-tab.active{color:var(--accent-gold);border-color:var(--accent-gold)}.hero-card{display:flex;flex-direction:column;gap:.35rem;padding:.55rem;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast);border:1px solid var(--border-color);background:var(--bg-card)}.hero-card:hover{background:var(--bg-hover);border-color:var(--border-glow)}.hero-card.selected{background:#f0c04014;border-color:var(--accent-gold-dim)}.hero-card-top{display:flex;align-items:center;gap:.5rem}.hero-card-portrait{width:56px;height:56px;border-radius:50%;border:2px solid var(--border-color);object-fit:cover;flex-shrink:0}.hero-card.selected .hero-card-portrait{border-color:var(--accent-gold)}.hero-card-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem;justify-content:center}.hero-card-name-row{display:flex;align-items:center;justify-content:space-between;gap:.4rem}.hero-card-name{font-family:var(--font-title);font-size:.9rem;color:var(--text-primary)}.hero-card-hp{position:relative;width:100%;height:18px;background:var(--bg-secondary);border-radius:var(--radius-sm);overflow:hidden}.hero-card-hp-fill{position:absolute;inset:0;width:0;border-radius:var(--radius-sm);transition:width .4s ease}.hero-card-hp-regen{position:absolute;top:0;bottom:0;border-radius:var(--radius-sm);opacity:.35;animation:regen-pulse 1.5s ease-in-out infinite}@keyframes regen-pulse{0%,to{opacity:.25}50%{opacity:.5}}.hero-card-power{position:relative;width:100%;height:16px;background:var(--bg-secondary);border-radius:var(--radius-sm);overflow:hidden}.hero-card-power-fill{height:100%;border-radius:var(--radius-sm);background:var(--accent-blue);transition:width .3s ease}.hero-card-bar-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-body);font-size:.8rem;font-weight:700;color:var(--text-primary);text-shadow:0 1px 1px rgba(0,0,0,.9),0 0 4px rgba(0,0,0,.6),0 0 8px rgba(0,0,0,.3);z-index:1;pointer-events:none;letter-spacing:.03em}.hero-card-regen{font-family:var(--font-body);font-size:.68rem;font-weight:600;color:var(--accent-green);letter-spacing:.03em}.hero-card-status{font-size:.68rem;color:var(--text-muted)}.hero-card-status.exploring{color:var(--accent-blue)}.hero-card-status.returning{color:var(--accent-gold)}.hero-card-status.loot-ready{color:var(--accent-green);font-weight:600}.btn-apply-inline{margin-left:auto;display:inline-flex;align-items:center;gap:4px;font-family:var(--font-title);font-size:.62rem;letter-spacing:.03em;color:var(--accent-gold);background:#f0c04014;border:1px solid rgba(240,192,64,.3);border-radius:var(--radius-sm);padding:2px 8px;cursor:pointer;transition:background .15s ease,border-color .15s ease;white-space:nowrap;flex-shrink:0}.btn-apply-icon{width:14px;height:14px;border-radius:50%;object-fit:cover}.btn-apply-inline:hover:not(:disabled){background:#f0c0402e;border-color:var(--accent-gold)}.btn-apply-inline:disabled{opacity:.4;cursor:default}.hero-bag{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap;padding:.25rem 0}.hero-bag-gold{font-size:.75rem;font-weight:600;color:var(--accent-gold)}.hero-bag-item{position:relative;display:inline-flex}.hero-bag-icon{width:22px;height:22px;border-radius:50%;object-fit:cover;border:1px solid var(--border-color)}.hero-bag-qty{position:absolute;bottom:-4px;right:-4px;font-size:.6rem;font-weight:700;color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border-color);border-radius:50%;width:14px;height:14px;display:flex;align-items:center;justify-content:center;line-height:1}.hero-card-btn-row{display:flex;gap:.35rem;justify-content:flex-end}.btn-potion{background:#4caf5026;color:var(--accent-green);border:1px solid rgba(76,175,80,.3);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.btn-potion:hover:not(:disabled){background:#4caf5040;border-color:var(--accent-green)}.btn-potion:disabled{opacity:.4;cursor:not-allowed}.hero-card-timer{font-family:var(--font-body);font-size:.78rem;color:var(--accent-blue)}.btn-sm{font-size:.78rem;padding:.3rem .7rem}.hero-card .btn-loot{border-color:var(--accent-green);box-shadow:0 0 12px #40c06033;animation:pulse-loot 1.5s ease-in-out infinite}@keyframes pulse-loot{0%,to{box-shadow:0 0 12px #40c06033}50%{box-shadow:0 0 20px #40c06066}}.panel-spinner{text-align:center;color:var(--text-muted);font-size:.85rem;padding:.75rem 0}.hero-card-locked{display:flex;flex-direction:column;align-items:center;gap:.45rem;padding:.6rem .45rem;border-style:dashed;background:var(--bg-secondary)}.hero-card-locked-icon{width:36px;height:36px;border-radius:50%;border:2px dashed var(--border-color);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:1.1rem;flex-shrink:0}.hero-card-recruit{font-size:.75rem;padding:.3rem .8rem}.hero-card-recruit.pulse-afford{animation:pulse-afford 2s ease-in-out infinite}@keyframes pulse-afford{0%,to{box-shadow:var(--shadow-glow-gold);border-color:var(--accent-gold-dim)}50%{box-shadow:0 0 18px #f0c04066;border-color:var(--accent-gold)}}.ing-cell{position:relative;display:flex;flex-direction:column;align-items:center;width:52px}.ing-cell-zero{opacity:.35}.ing-cell-clickable{cursor:pointer}.ing-cell-clickable:active .ing-icon-wrap{transform:scale(.92)}.ing-icon-wrap{transition:transform .12s ease;position:relative;border-radius:50%}.ing-icon{border-radius:50%;border:2px solid var(--border-color);object-fit:cover;background:var(--bg-card);display:block}.ing-cell:not(.ing-cell-zero) .ing-icon{border-color:var(--zone-color, var(--border-glow));box-shadow:0 0 8px color-mix(in srgb,var(--zone-color, transparent) 30%,transparent)}.ing-cell-selected .ing-icon-wrap{animation:ing-select-pop .2s ease-out}.ing-cell-selected .ing-icon{border-color:var(--accent-gold);box-shadow:0 0 12px #f0c04080}@keyframes ing-select-pop{0%{transform:scale(1)}50%{transform:scale(1.12)}to{transform:scale(1)}}.ing-cell[data-name]:after{content:attr(data-name);position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:6px;padding:3px 8px;border-radius:4px;background:#080810eb;border:1px solid var(--border-color);color:var(--text-primary);font-family:var(--font-body);font-size:.68rem;white-space:nowrap;pointer-events:none;opacity:0;z-index:20;transition:opacity .15s ease}.ing-cell[data-name]:hover:after,.ing-cell[data-name]:active:after{opacity:1}.craft-slots{display:flex;align-items:center;gap:.5rem;justify-content:center;padding-bottom:.5rem}.craft-slot{position:relative;width:46px;height:46px;border-radius:50%;border:2px dashed var(--border-color);background:var(--bg-card);display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:border-color .15s ease,box-shadow .15s ease}.craft-slot:hover{border-color:var(--border-glow)}.craft-slot-filled{border-style:solid;border-color:var(--zone-color, var(--border-glow));box-shadow:0 0 10px color-mix(in srgb,var(--zone-color, transparent) 35%,transparent);animation:slot-fill-pop .2s ease-out}@keyframes slot-fill-pop{0%{transform:scale(.85);opacity:.6}60%{transform:scale(1.06)}to{transform:scale(1);opacity:1}}.craft-slot-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.craft-slot-qty{position:absolute;bottom:-4px;right:-4px;min-width:16px;height:16px;padding:0 3px;border-radius:8px;background:var(--qty-color, var(--zone-color, var(--accent-gold)));color:var(--bg-primary);font-family:var(--font-title);font-size:.58rem;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;z-index:2;pointer-events:none}.craft-slot-qty-zero{background:var(--bg-panel);border:1px solid var(--border-color);color:var(--text-primary)}.craft-slot-empty{color:var(--text-muted);font-family:var(--font-title);font-size:1.1rem}.craft-plus,.craft-arrow{color:var(--text-muted);font-size:1rem;flex-shrink:0}.craft-result{width:46px;height:46px;border-radius:50%;border:2px dashed var(--border-color);background:var(--bg-card);display:flex;align-items:center;justify-content:center;flex-shrink:0}.craft-result-known{border:none;background:none}.craft-result-unknown{color:var(--text-muted);font-family:var(--font-title);font-size:1.1rem}.craft-result-circle{width:42px;height:42px}.craft-brew-btns{display:flex;gap:.25rem;margin-left:.35rem;align-items:center;flex-wrap:nowrap}.craft-brew-btn{white-space:nowrap}.craft-brew-all-btn{min-width:6.75rem;align-self:center}.craft-brew-btn:not(:disabled){animation:brew-ready-pulse 2s ease-in-out infinite}@keyframes brew-ready-pulse{0%,to{box-shadow:0 0 8px #8846aa4d}50%{box-shadow:0 0 16px #8846aa99}}.craft-ingredient-grid{display:flex;flex-wrap:wrap;gap:.4rem;padding:.35rem 0}.craft-ingredient-grid .ing-cell{width:44px}.craft-empty-msg{color:var(--text-muted);font-style:italic;font-size:.75rem;padding:.5rem 0}.collection-tabs{display:flex;gap:.35rem;margin:.25rem 0 .5rem}.grimoire-filters{display:flex;gap:.3rem;margin-bottom:.5rem}.grimoire-filter-btn{flex:1;padding:.25rem .4rem;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);font-family:var(--font-title);font-size:.68rem;cursor:pointer;transition:all var(--transition-fast)}.grimoire-filter-btn:hover{border-color:var(--border-glow)}.grimoire-filter-btn.active{border-color:var(--filter-color, var(--accent-gold-dim));color:var(--filter-color, var(--accent-gold));background:color-mix(in srgb,var(--filter-color, var(--accent-gold)) 10%,var(--bg-card))}.grimoire-btn-row{display:flex;gap:.5rem;margin-bottom:.5rem}.grimoire-btn-row button{flex:1}.grimoire-grid{display:flex;flex-wrap:wrap;gap:.75rem}.grimoire-separator{width:100%;height:0}.grimoire-cell{display:flex;flex-direction:column;align-items:center;gap:.3rem;transition:all var(--transition-fast);position:relative}.grimoire-cell.hinted{opacity:.65}.grimoire-cell.discovered{opacity:1}.grimoire-cell.discovered.inactive{opacity:.65}.grimoire-cell.discovered.inactive .grimoire-icon-wrap{border-style:dashed}.grimoire-cell-clickable{cursor:pointer}.grimoire-cell-clickable:hover{transform:scale(1.08)}.grimoire-cell-clickable:active{transform:scale(.94)}.grimoire-icon-wrap{position:relative;width:52px;height:52px;flex-shrink:0;border-radius:50%;border:2px solid var(--effect-color, var(--border-color));overflow:visible;background:var(--bg-card)}.grimoire-cell.hinted .grimoire-icon-wrap{border-style:dashed;border-color:var(--accent-purple)}.grimoire-icon{width:100%;height:100%;object-fit:cover;border-radius:50%}.grimoire-badge-tl{position:absolute;top:-4px;left:-4px;min-width:16px;height:16px;padding:0 2px;border-radius:8px;background:var(--accent-gold);color:var(--bg-primary);font-size:.6rem;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;z-index:2;pointer-events:none}.grimoire-badge-hint{background:var(--accent-purple)}.grimoire-badge-tr{position:absolute;top:-5px;right:-6px;font-family:var(--font-title);font-size:.55rem;font-weight:800;background:var(--effect-color, var(--accent-gold));color:var(--bg-primary);border-radius:4px;padding:1px 4px;line-height:1.4;white-space:nowrap;z-index:2;pointer-events:none}.potion-popup-backdrop{position:fixed;inset:0;background:#0009;z-index:50;display:flex;align-items:center;justify-content:center;animation:settings-fade-in .15s ease}.potion-popup{width:min(20rem,90vw);padding:1.2rem;display:flex;flex-direction:column;gap:1rem}.potion-popup-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.potion-popup-icon{width:48px;height:48px;border-radius:50%;border:2px solid;object-fit:cover;flex-shrink:0}.potion-popup-name{font-family:var(--font-title);font-size:1.1rem;letter-spacing:.04em}.potion-popup-category{font-size:.75rem;color:var(--text-secondary)}.potion-popup-section{display:flex;flex-direction:column;gap:.4rem}.potion-popup-label{font-family:var(--font-title);font-size:.75rem;color:var(--text-secondary);letter-spacing:.04em}.potion-popup-qty-control{display:flex;align-items:center;gap:.75rem}.potion-popup-qty-control button{width:28px;height:28px;border-radius:50%;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.potion-popup-qty-control button:hover:not(:disabled){border-color:var(--accent-gold-dim);background:var(--bg-hover)}.potion-popup-qty-control button:disabled{opacity:.3;cursor:not-allowed}.potion-popup-qty-control span{font-family:var(--font-title);font-size:1.1rem;color:var(--accent-gold);min-width:2rem;text-align:center}.potion-popup-heroes{display:flex;gap:.5rem}.potion-popup-hero{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-card);cursor:pointer;flex:1;transition:all var(--transition-fast)}.potion-popup-hero:hover{border-color:var(--border-glow);background:var(--bg-hover)}.potion-popup-hero.selected{border-color:var(--accent-gold-dim);background:#f0c04014}.potion-popup-hero img{width:36px;height:36px;border-radius:50%;object-fit:cover}.potion-popup-hero span{font-family:var(--font-title);font-size:.68rem;color:var(--text-secondary)}.potion-popup-hero.selected span{color:var(--accent-gold)}.potion-popup-actions{display:flex;gap:.5rem}.potion-popup-actions button{flex:1}.potion-popup-grid{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.potion-popup-grid .grimoire-cell{gap:.2rem}.potion-popup-cell-qty{display:flex;align-items:center;gap:.25rem}.potion-popup-cell-qty button{width:20px;height:20px;padding:0;border-radius:50%;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-size:.7rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.potion-popup-cell-qty button.btn-max{width:auto;border-radius:8px;padding:0 5px;font-size:.55rem;font-weight:600;text-transform:uppercase}.potion-popup-cell-qty button:hover:not(:disabled){border-color:var(--accent-gold);background:var(--bg-hover)}.potion-popup-cell-qty button:disabled{opacity:.3;cursor:default}.potion-popup-cell-qty span{font-size:.75rem;font-weight:700;min-width:1.2em;text-align:center}.inventory-zone-header{font-family:var(--font-title);font-size:.75rem;letter-spacing:.06em;padding:.35rem 0 .2rem;margin-top:.5rem}.inventory-zone-header:first-child{margin-top:0}.inventory-zone-grid{display:flex;flex-wrap:wrap;gap:.55rem;padding:.2rem 0}.log-body{max-height:180px;overflow-y:auto;gap:.2rem!important}.log-entry{display:flex;gap:.4rem;align-items:baseline;font-size:.72rem;line-height:1.35;padding:.15rem 0;border-bottom:1px solid rgba(255,255,255,.03)}.log-ts{flex-shrink:0;font-family:Courier New,monospace;font-size:.62rem;color:var(--text-muted)}.log-text{color:var(--text-secondary);font-family:var(--font-body)}.log-exploration .log-text{color:var(--text-primary)}.log-loot .log-text{color:var(--accent-gold)}.log-recipe .log-text{color:var(--accent-purple)}.log-recruit .log-text{color:var(--accent-green)}.log-potion .log-text,.log-expedition .log-text{color:var(--accent-blue)}.log-empty{font-size:.72rem;color:var(--text-muted);font-style:italic}.game-over-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:20;pointer-events:auto}.game-over-card{text-align:center;padding:2rem 3rem}.game-over-card h2{font-family:var(--font-title);font-size:1.8rem;color:var(--accent-gold);margin-bottom:.5rem}.game-over-card.won{border-color:var(--accent-gold-dim);box-shadow:var(--shadow-glow-gold)}.game-over-card.lost{border-color:#d040504d}.game-over-card.lost h2{color:var(--accent-red)}.game-over-flavor{color:var(--text-muted);font-style:italic;font-size:.9rem;margin-top:.25rem}.game-over-stats{display:flex;justify-content:center;gap:2rem;margin-top:1rem}.game-over-stat{display:flex;flex-direction:column;align-items:center;gap:.2rem}.game-over-stat-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.game-over-stat-value{font-family:var(--font-title);font-size:1.3rem;color:var(--accent-gold)}.game-over-card.won .game-over-stat-value{color:#fff}.game-over-card.lost .game-over-stat-value{color:var(--text-primary)}.game-over-actions{display:flex;gap:.75rem;justify-content:center;margin-top:1rem}.glass-page{position:fixed;inset:0;z-index:1;display:flex;align-items:center;justify-content:center;pointer-events:none;background-image:linear-gradient(180deg,#0808104d,#08081099,#080810d9),url(/assets/backgrounds/lab-bg.webp);background-size:cover;background-position:center;background-repeat:no-repeat}.glass-page>*{pointer-events:auto}.glass-page-panel{background:#0d0f1ed1;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow);width:min(48rem,94vw);max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.glass-page-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border-color);gap:.75rem}.glass-page-title{font-family:var(--font-title);font-size:clamp(1rem,1.5vw,1.5rem);color:var(--accent-gold);letter-spacing:.08em}.glass-page-body{flex:1;overflow-y:auto;padding:clamp(.75rem,2vw,1.75rem)}.htp-body{display:flex;flex-direction:column;gap:1.25rem}.htp-section{display:flex;flex-direction:column;gap:.4rem}.htp-heading{font-family:var(--font-title);font-size:1rem;color:var(--accent-gold);letter-spacing:.06em;margin:0}.htp-text{font-size:.9rem;color:var(--text-secondary);line-height:1.55;margin:0}.htp-text strong{color:var(--text-primary)}.htp-text em{color:var(--accent-gold-dim);font-style:normal}.htp-list{margin:.2rem 0 0;padding-left:1.25rem;font-size:.9rem;color:var(--text-secondary);line-height:1.6}.htp-list strong{color:var(--text-primary)}.htp-cat{font-weight:600;font-size:.85rem}.htp-cat-health{color:#d04050}.htp-cat-power{color:#4080d0}.htp-cat-regen{color:#40c060}.htp-tutorial-btn{font-family:var(--font-title);font-size:.85rem;padding:.5rem 1.2rem;background:transparent;color:var(--accent-gold);border:1px solid var(--accent-gold-dim);border-radius:var(--radius-sm);cursor:pointer;letter-spacing:.04em;transition:background var(--transition-fast),border-color var(--transition-fast)}.htp-tutorial-btn:hover{background:#f0c0401a;border-color:var(--accent-gold)}.htp-tutorial-note{font-style:italic;color:var(--accent-gold-dim)}@media(min-width:1400px){.play-left-panels,.play-right-panels,.status-hud{zoom:1.05}}@media(min-width:1700px){.play-left-panels,.play-right-panels,.status-hud{zoom:1.15}}.mobile-tab-bar{display:none}@media(max-width:767px){.mobile-tab-bar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:30;background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--glass-border);padding:.3rem 0;gap:0}.mobile-tab{flex:1;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:.35rem;padding:.5rem 0;background:none;border:none;border-radius:0;box-shadow:none;color:var(--text-muted);font-family:var(--font-title);font-size:.8rem;letter-spacing:.04em;cursor:pointer;transition:color var(--transition-fast)}.mobile-tab.active{color:var(--accent-gold)}.play-left-panels,.play-right-panels{position:fixed;inset:auto 0 0;width:100%;max-width:100%;padding-bottom:52px;max-height:65vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:none}.play-left-panels.mobile-open,.play-right-panels.mobile-open{display:flex}.mobile-panel-hidden{display:none!important}.status-hud{position:fixed;top:0;left:0;right:0;transform:none;width:100%;border-radius:0;font-size:.72rem;gap:.35rem;padding:.35rem .5rem;justify-content:center}.status-hud-btn{font-size:.72rem;padding:.15rem .3rem}.status-hud-settings{font-size:.9rem}.hero-card-portrait{width:44px;height:44px}.side-panel-header{padding:.5rem .75rem;pointer-events:none;cursor:default}.side-panel-header:hover{background:transparent}.side-panel-chevron{display:none}.side-panel-body{font-size:.82rem}}.toaster-container{position:fixed;bottom:16px;right:16px;z-index:50;display:flex;flex-direction:column-reverse;gap:8px;pointer-events:none;max-width:340px;width:100%}.toast-item{display:flex;align-items:flex-start;gap:.6rem;padding:.65rem .9rem;background:var(--glass-bg);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid var(--glass-border);border-radius:var(--radius-md);box-shadow:var(--glass-shadow);font-family:var(--font-body);font-size:.85rem;color:var(--text-primary);cursor:pointer;pointer-events:auto;animation:toast-slide-in .25s ease;transition:opacity var(--transition-fast),transform var(--transition-fast)}.toast-item:hover{opacity:.85}@keyframes toast-slide-in{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}.toast-icon{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.7rem;line-height:1;margin-top:1px}.toast-icon-loading{background:#4080d033;color:var(--accent-blue);animation:toast-spin 1.2s linear infinite}@keyframes toast-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.toast-icon-success{background:#40c06033;color:var(--accent-green);font-weight:700}.toast-icon-error{background:#d0405033;color:var(--accent-red);font-weight:700}.toast-loading{border-left:3px solid var(--accent-blue)}.toast-success{border-left:3px solid var(--accent-green)}.toast-error{border-left:3px solid var(--accent-red)}.toast-content{display:flex;flex-direction:column;gap:.15rem;min-width:0}.toast-message{font-size:.85rem;color:var(--text-primary);line-height:1.3}.toast-description{font-size:.72rem;color:var(--text-muted)}@media(max-width:767px){.toaster-container{bottom:8px;right:8px;left:8px;max-width:none}}.grimoire-cell-new .grimoire-icon-wrap{animation:grimoire-unlock .8s ease-out,grimoire-unlock-glow 1.8s ease-out}@keyframes grimoire-unlock{0%{transform:scale(1)}20%{transform:scale(1.35)}45%{transform:scale(.92)}65%{transform:scale(1.12)}to{transform:scale(1)}}@keyframes grimoire-unlock-glow{0%{box-shadow:0 0 #f0c04000}25%{box-shadow:0 0 24px 10px #f0c04099}to{box-shadow:0 0 #f0c04000}}.discovery-flash{position:fixed;inset:0;pointer-events:none;z-index:15;background:radial-gradient(ellipse at center,rgba(240,192,64,.2) 0%,transparent 70%);animation:discovery-flash-anim .8s ease-out forwards}@keyframes discovery-flash-anim{0%{opacity:0}15%{opacity:1}to{opacity:0}}.hero-card-deltas{display:flex;gap:.5rem;justify-content:center}.hero-stat-delta{font-family:var(--font-title);font-size:.78rem;font-weight:700;animation:stat-delta-float 1.4s ease-out forwards;pointer-events:none;white-space:nowrap;text-shadow:0 1px 3px rgba(0,0,0,.8)}@keyframes stat-delta-float{0%{opacity:0;transform:translateY(4px) scale(.8)}15%{opacity:1;transform:translateY(0) scale(1.1)}30%{transform:translateY(-2px) scale(1)}70%{opacity:1}to{opacity:0;transform:translateY(-12px)}}.status-hud-gold.counting{animation:gold-count-pulse .6s ease-in-out}@keyframes gold-count-pulse{0%,to{text-shadow:none}50%{text-shadow:0 0 12px rgba(240,192,64,.6),0 0 4px rgba(240,192,64,.3)}}.tutorial-overlay{position:fixed;inset:0;z-index:50;opacity:0;transition:opacity .3s ease;pointer-events:auto}.tutorial-overlay.tutorial-visible{opacity:1}.tutorial-backdrop{position:fixed;inset:0;background:#000000bf}.tutorial-spotlight{position:fixed;border-radius:var(--radius-md);box-shadow:0 0 0 9999px #000000bf;transition:top .4s ease,left .4s ease,width .4s ease,height .4s ease;pointer-events:none;z-index:51}.tutorial-tooltip{position:fixed;z-index:52;width:min(28rem,90vw);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow),0 0 20px #f0c04014;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.75rem;transition:top .4s ease,left .4s ease,right .4s ease,bottom .4s ease}.tutorial-tooltip-centered{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.tutorial-step-indicator{font-family:var(--font-body);font-size:.75rem;color:var(--text-primary);letter-spacing:.1em;text-transform:uppercase}.tutorial-tooltip-title{font-family:var(--font-title);font-size:1.15rem;color:var(--accent-gold);letter-spacing:.06em;margin:0}.tutorial-tooltip-body{font-family:var(--font-body);font-size:1rem;color:var(--text-primary);line-height:1.55;margin:0;text-align:justify}.tutorial-tooltip-body strong{color:var(--accent-gold);font-weight:600}.tutorial-tooltip-actions{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-top:.25rem}.tutorial-tooltip-nav{display:flex;gap:.5rem}.tutorial-btn-next{font-family:var(--font-title);font-size:.85rem;padding:.4rem 1.2rem;background:var(--accent-gold);color:var(--bg-primary);border:none;border-radius:var(--radius-sm);cursor:pointer;letter-spacing:.04em;transition:background var(--transition-fast),box-shadow var(--transition-fast)}.tutorial-btn-next:hover{background:transparent;color:var(--accent-gold);box-shadow:0 0 12px #f0c0404d;border:1px solid var(--accent-gold)}.tutorial-btn-back{font-family:var(--font-body);font-size:.85rem;padding:.4rem .8rem;background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast)}.tutorial-btn-back:hover{color:var(--text-primary);border-color:var(--border-glow)}.tutorial-btn-skip{font-family:var(--font-body);font-size:.8rem;padding:.3rem .6rem;background:transparent;color:var(--text-muted);border:none;cursor:pointer;transition:color var(--transition-fast)}.tutorial-btn-skip:hover{color:var(--text-secondary)}.tutorial-reactivate-note{font-family:var(--font-body);font-size:.75rem;color:var(--text-muted);font-style:italic}select::-ms-expand{display:none}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-glow)}.journey-map{position:fixed;inset:0;z-index:0;overflow:hidden}.constellation-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}.constellation-overlay{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 80%,transparent 30%,rgba(6,6,18,.6) 100%);pointer-events:none}.constellation-lines{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1}.zone-node{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:4px;z-index:2;pointer-events:auto;transition:transform .3s ease}.zone-node-hovered{transform:translate(-50%,-50%) scale(1.06)}.zone-node-glow{position:absolute;width:140px;height:140px;border-radius:50%;background:radial-gradient(circle,var(--zone-color, #c8a040) 0%,transparent 70%);opacity:.12;transition:opacity .4s ease;pointer-events:none}.zone-node-active .zone-node-glow{opacity:.5;width:170px;height:170px;animation:zone-glow-pulse 2s ease-in-out infinite}.zone-node-active .zone-node-icon{border-color:var(--zone-color, #f0c040);box-shadow:0 0 20px #0006,0 0 18px var(--zone-color, #f0c040),0 0 36px var(--zone-color, #f0c040)}.zone-node-hovered .zone-node-glow{opacity:.35}@keyframes zone-glow-pulse{0%,to{opacity:.35;transform:scale(1)}50%{opacity:.65;transform:scale(1.15)}}.zone-node-icon{width:86px;height:86px;border-radius:50%;border:2px solid var(--zone-color, #a08020);object-fit:cover;background:var(--bg-card);box-shadow:0 0 16px #000000b3,0 0 8px var(--zone-color, #a08020);transition:box-shadow .3s ease,border-color .3s ease;position:relative;z-index:1;animation:zone-float 4s ease-in-out infinite}@keyframes zone-float{0%,to{transform:translateY(0) scale(1)}35%{transform:translateY(-4px) scale(1.025)}70%{transform:translateY(2px) scale(.985)}}.zone-node-icon-clickable{cursor:pointer;pointer-events:auto}.zone-node-hovered .zone-node-icon{box-shadow:0 0 24px #0006,0 0 20px var(--zone-color, #f0c040)}.zone-node-athanor{--zone-color: #f0c040}.athanor-icon{width:106px;height:106px;border-color:var(--accent-gold-dim);box-shadow:0 0 24px #f0c04033,0 0 12px #f0c04026;animation:none}.athanor-glow{width:180px;height:180px;opacity:.2;animation:athanor-pulse 3.5s ease-in-out infinite}@keyframes athanor-pulse{0%,to{opacity:.15;transform:scale(1)}50%{opacity:.3;transform:scale(1.15)}}.zone-node-label{font-family:var(--font-title);font-size:.75rem;letter-spacing:.05em;text-shadow:0 1px 6px rgba(0,0,0,.9),0 0 12px rgba(0,0,0,.7);white-space:nowrap;text-align:center}.athanor-label{font-size:.8rem;color:var(--accent-gold)}.athanor-heroes{position:absolute;top:100%;left:50%;transform:translate(-50%);display:flex;gap:56px;justify-content:center;z-index:3;margin-top:4px}.zone-skulls{font-size:.6rem;letter-spacing:.08em;filter:drop-shadow(0 1px 3px rgba(0,0,0,.9))}.zone-action-btn{background:#080810d9;border:1px solid var(--accent-gold-dim);border-radius:6px;padding:6px 20px;cursor:pointer;transition:background .2s ease,border-color .2s ease,transform .15s ease;z-index:4;white-space:nowrap;animation:action-btn-fade-in .3s ease;box-shadow:0 2px 12px #0009;font-family:var(--font-title);font-size:.8rem;color:var(--accent-gold);letter-spacing:.05em}.zone-action-btn:hover{background:#f0c04040;border-color:var(--accent-gold);transform:scale(1.06);box-shadow:0 2px 16px #f0c0404d}.zone-action-btn:hover .zone-action-label{color:#fff;text-shadow:0 0 6px rgba(240,192,64,.5)}.zone-action-btn:active{transform:scale(.96)}@keyframes action-btn-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.zone-node-heroes{display:flex;gap:56px;justify-content:center;position:relative;z-index:3}.hero-token{display:flex;flex-direction:column;align-items:center;gap:2px;filter:drop-shadow(0 2px 10px rgba(0,0,0,.7));cursor:pointer;transition:transform .15s ease}.hero-token:hover{transform:scale(1.1)}.hero-token-frame-wrap{position:relative;width:90px;height:90px;display:flex;align-items:center;justify-content:center}.hero-token-sm .hero-token-frame-wrap{width:66px;height:66px}.hero-token-portrait{position:absolute;width:60px;height:60px;border-radius:50%;object-fit:cover;background:var(--bg-card);z-index:2}.hero-token-sm .hero-token-portrait{width:44px;height:44px}.hero-token-frame{position:absolute;width:76px;height:76px;border-radius:50%;pointer-events:none;z-index:3;opacity:.7;mix-blend-mode:screen}.hero-token-sm .hero-token-frame{width:56px;height:56px}.hero-token-selected .hero-token-frame{opacity:.9;filter:drop-shadow(0 0 6px rgba(240,192,64,.5))}.hero-token-selected .hero-token-portrait{border:2px solid var(--accent-gold);box-shadow:0 0 10px #f0c04080,inset 0 0 6px #f0c04026}.hero-token-ring{position:absolute;z-index:3;pointer-events:none}.hero-token-ring-fill{transition:stroke-dashoffset .4s ease}.hero-token-ring-selected{filter:drop-shadow(0 0 5px rgba(240,192,64,.5))}.hero-token-claim-burst{position:absolute;inset:-8px;border-radius:50%;background:radial-gradient(circle,rgba(240,192,64,.5) 0%,transparent 70%);z-index:4;pointer-events:none;animation:claim-burst .6s ease-out forwards}@keyframes claim-burst{0%{transform:scale(.6);opacity:1}50%{transform:scale(1.6);opacity:.5}to{transform:scale(2);opacity:0}}.claim-fly-particle{position:fixed;z-index:9999;pointer-events:none;animation:claim-fly .65s cubic-bezier(.25,.1,.25,1) forwards;filter:drop-shadow(0 0 8px rgba(240,192,64,.7))}.claim-fly-particle-icon{width:20px;height:20px;border-radius:50%;object-fit:cover}@keyframes claim-fly{0%{transform:translate(0) scale(1.2);opacity:1}70%{opacity:1}to{transform:translate(var(--fly-dx),var(--fly-dy)) scale(.5);opacity:0}}.hero-token-orbit{position:absolute;inset:0;pointer-events:none;transform:rotate(var(--orbit-angle, 0deg));z-index:5}.hero-token-orbit-ready{pointer-events:auto;cursor:pointer}.hero-token-orbit-ready .hero-token-orbit-inner{animation:orbit-item-glow 1.5s ease-in-out infinite}.hero-token-orbit-ready:hover .hero-token-orbit-inner{filter:drop-shadow(0 0 6px color-mix(in srgb,var(--orbit-color, #f0c040) 50%,transparent))}.hero-token-orbit-pending{opacity:.5;pointer-events:none}.hero-token-orbit-item{position:absolute}.hero-token-orbit-inner{width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid color-mix(in srgb,var(--orbit-color, #c8a040) 35%,transparent);background:#0a0804d9;box-shadow:0 1px 6px #0009;transform:rotate(calc(-1 * var(--orbit-angle, 0deg)));transition:filter .2s ease,border-color .3s ease;position:relative}@keyframes orbit-item-glow{0%,to{box-shadow:0 1px 6px #0009;border-color:color-mix(in srgb,var(--orbit-color, #c8a040) 35%,transparent)}50%{box-shadow:0 0 10px color-mix(in srgb,var(--orbit-color, #c8a040) 45%,transparent);border-color:var(--orbit-color, var(--accent-gold))}}.orbit-item-pulse .hero-token-orbit-inner{animation:orbit-item-pulse .4s ease-out}@keyframes orbit-item-pulse{0%{scale:1}30%{scale:1.35}to{scale:1}}.hero-token-orbit-icon{width:80%;height:80%;border-radius:50%;object-fit:cover}.hero-token-orbit-qty{position:absolute;bottom:-4px;right:-4px;min-width:16px;height:16px;padding:0 3px;border-radius:8px;background:var(--accent-gold);color:var(--bg-primary);font-family:var(--font-title);font-size:.58rem;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;z-index:2;pointer-events:none;white-space:nowrap}.hero-returning-wrapper{position:absolute;z-index:3;transform:translate(-50%,-50%);pointer-events:none}.hero-token-disabled{opacity:.45;pointer-events:none;filter:grayscale(.3) brightness(.8);cursor:default}.hero-token-disabled:hover{transform:none}.zone-tooltip{position:absolute;top:calc(100% + 12px);left:50%;transform:translate(-50%);background:#080810f2;border:1px solid var(--zone-color, #a08020);border-radius:8px;padding:10px 14px;display:flex;flex-direction:column;gap:6px;min-width:200px;z-index:20;pointer-events:none;box-shadow:0 4px 24px #000000e6,inset 0 1px #ffffff0a}.zone-tooltip-header{display:flex;justify-content:space-between;align-items:baseline;gap:10px}.zone-tooltip-name{font-family:var(--font-title);font-size:.95rem;letter-spacing:.04em;text-shadow:0 0 8px var(--zone-color, #a08020);white-space:nowrap}.zone-tooltip-risk{font-size:.68rem;white-space:nowrap;letter-spacing:.02em}.zone-tooltip-stats{display:flex;gap:12px;font-size:.75rem}.zone-tooltip-gold{color:var(--accent-gold)}.zone-tooltip-drain{color:var(--accent-red)}.zone-tooltip-ingredients{display:flex;gap:4px}.zone-tooltip-ingredient{width:26px;height:26px;border-radius:50%;object-fit:cover;border:1px solid rgba(255,255,255,.1);background:#0006}.journey-floating-text{position:absolute;z-index:10;font-family:var(--font-title);font-size:1.05rem;font-weight:700;text-shadow:0 1px 4px rgba(0,0,0,.95),0 0 10px rgba(0,0,0,.6);white-space:nowrap;display:flex;align-items:center;gap:.25rem}.journey-floating-icon{width:22px;height:22px;border-radius:50%;object-fit:cover}.loot-particle{position:absolute;z-index:9;pointer-events:none;filter:drop-shadow(0 0 6px rgba(240,192,64,.7))}.loot-particle-icon{width:18px;height:18px;border-radius:50%;object-fit:cover}.map-particles{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:1}.map-particle{position:absolute;width:4px;height:4px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#ffe6aa,#ffbe6466);opacity:0;animation:map-particle-drift 14s linear infinite}.map-particle:nth-child(odd){width:3px;height:3px;background:radial-gradient(circle at 35% 35%,#d2dcff,#96a0f059)}.map-particle:nth-child(3n){width:5px;height:5px}.map-particle:nth-child(1){left:5%;top:90%;animation-delay:0s;animation-duration:13.2s}.map-particle:nth-child(2){left:12%;top:78%;animation-delay:1.4s;animation-duration:15.1s}.map-particle:nth-child(3){left:20%;top:85%;animation-delay:3.2s;animation-duration:12.8s}.map-particle:nth-child(4){left:28%;top:92%;animation-delay:.7s;animation-duration:14.6s}.map-particle:nth-child(5){left:35%;top:80%;animation-delay:2.1s;animation-duration:16s}.map-particle:nth-child(6){left:42%;top:88%;animation-delay:4s;animation-duration:13.5s}.map-particle:nth-child(7){left:50%;top:93%;animation-delay:1s;animation-duration:14.2s}.map-particle:nth-child(8){left:57%;top:82%;animation-delay:2.8s;animation-duration:15.4s}.map-particle:nth-child(9){left:64%;top:87%;animation-delay:.3s;animation-duration:12.9s}.map-particle:nth-child(10){left:71%;top:91%;animation-delay:3.6s;animation-duration:14.8s}.map-particle:nth-child(11){left:78%;top:79%;animation-delay:1.7s;animation-duration:16.2s}.map-particle:nth-child(12){left:85%;top:86%;animation-delay:2.5s;animation-duration:13.1s}.map-particle:nth-child(13){left:8%;top:95%;animation-delay:4.4s;animation-duration:15.7s}.map-particle:nth-child(14){left:16%;top:70%;animation-delay:.9s;animation-duration:12.4s}.map-particle:nth-child(15){left:33%;top:96%;animation-delay:3s;animation-duration:14s}.map-particle:nth-child(16){left:47%;top:74%;animation-delay:1.5s;animation-duration:16.5s}.map-particle:nth-child(17){left:60%;top:94%;animation-delay:2.3s;animation-duration:13.8s}.map-particle:nth-child(18){left:74%;top:72%;animation-delay:4.2s;animation-duration:15s}.map-particle:nth-child(19){left:88%;top:90%;animation-delay:.5s;animation-duration:14.3s}.map-particle:nth-child(20){left:93%;top:76%;animation-delay:3.4s;animation-duration:12.6s}@keyframes map-particle-drift{0%{transform:translateZ(0) scale(.7);opacity:0}8%{opacity:.85}40%{opacity:.7}80%{opacity:.4}to{transform:translate3d(-8px,-65vh,0) scale(1.2);opacity:0}}.constellation-hint{position:relative;background:#0a0a14bf;border:1px solid var(--accent-gold-dim);border-radius:8px;padding:5px 14px;font-family:var(--font-title);font-size:.68rem;color:var(--accent-gold);letter-spacing:.04em;white-space:nowrap;z-index:5;pointer-events:none;animation:hint-fade 2s ease-in-out infinite;margin-top:2px}@keyframes hint-fade{0%,to{opacity:.7}50%{opacity:1}}@media(max-width:767px){.zone-node-icon{width:62px;height:62px}.athanor-icon{width:76px;height:76px}.zone-node-glow{width:96px;height:96px}.athanor-glow{width:130px;height:130px}.hero-token-frame-wrap{width:66px;height:66px}.hero-token-portrait{width:44px;height:44px}.hero-token-frame{width:56px;height:56px}.hero-token-sm .hero-token-frame-wrap{width:48px;height:48px}.hero-token-sm .hero-token-portrait{width:32px;height:32px}.hero-token-sm .hero-token-frame{width:42px;height:42px}.hero-token-orbit-item{border-width:1px}.hero-token-orbit-qty{font-size:.42rem}.athanor-label,.zone-skulls{font-size:.65rem}.zone-action-btn{font-size:.6rem;padding:4px 12px}.constellation-hint{font-size:.6rem;bottom:8%}.journey-floating-text{font-size:.85rem}.zone-tooltip{min-width:170px;padding:8px 10px}.zone-tooltip-name{font-size:.8rem}.zone-tooltip-ingredient{width:22px;height:22px}}
