@import "https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,300..900&family=Outfit:wght@300;400;600;800&family=Inter:wght@400;500;600&display=swap";:root{--riftvoid:#0b0a1f;--deep-indigo:#1b1640;--nebula:#2a2358;--rift-violet:#8a5cff;--rift-cyan:#34e0d0;--rift-magenta:#ff5cc8;--riftgold:#ffc56b;--moonmilk:#f6f1e7;--mist:#c8c3d8;--ink:#16132a;--rift-gradient:linear-gradient(135deg, var(--rift-violet) 0%, var(--rift-cyan) 100%);--rift-prismatic:linear-gradient(120deg, var(--rift-violet) 0%, var(--rift-magenta) 50%, var(--rift-cyan) 100%);--success:#5bd6a0;--warning:#ffb54d;--error:#ff5c6a;--info:var(--rift-cyan);--bg-dark:var(--riftvoid);--bg-card:#1b164099;--text-main:var(--moonmilk);--text-muted:var(--mist);--accent:var(--rift-violet);--c-cozy-surface:#f6f1e7;--c-cozy-raised:#fffdf8;--c-cozy-sunken:#ede6d8;--c-cozy-border:#ddd3c2;--c-cozy-muted:#6b6478}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--moonmilk);color:var(--text-main);background-image:url(/assets/sprites/clouds.svg);background-position:50%;background-size:cover;background-attachment:fixed;min-height:100vh;font-family:Inter,sans-serif;overflow-x:hidden}h1,h2,h3,h4{font-family:Outfit,sans-serif}#root{flex-direction:column;width:100vw;height:100vh;display:flex}.landing-wrapper{scroll-behavior:smooth;width:100%;height:100vh;overflow:hidden auto}.hero-section{grid-template-columns:1fr 1fr;align-items:center;max-width:1400px;min-height:100vh;margin:0 auto;padding:4rem;display:grid}.hero-content{z-index:2;flex-direction:column;justify-content:center;animation:.8s cubic-bezier(.16,1,.3,1) forwards slide-right;display:flex}.badge{color:var(--accent);letter-spacing:.15em;background:#8e2de226;border:1px solid #8e2de24d;border-radius:50px;width:fit-content;margin-bottom:1.5rem;padding:.4rem 1rem;font-size:.75rem;font-weight:800;display:inline-block}.logo-glow{letter-spacing:-.02em;background:var(--rift-prismatic);-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 20px #8a5cff66);-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-family:Fraunces,serif;font-size:4rem;font-weight:800}.hero-title{color:var(--ink);margin-bottom:1.5rem;font-family:Fraunces,serif;font-size:2.5rem;font-weight:600}.hero-subtitle{color:var(--c-cozy-muted);max-width:500px;margin-bottom:3rem;font-size:1.1rem;line-height:1.6}.hero-subtitle strong{color:var(--accent)}.glass-panel{-webkit-backdrop-filter:blur(12px);background:#0f111a66;border:1px solid #ffffff0d;border-top-color:#ffffff1a;border-radius:16px;box-shadow:0 30px 60px #0006,inset 0 1px #ffffff1a}.waitlist-card{max-width:450px;padding:2.5rem;transition:transform .3s cubic-bezier(.16,1,.3,1),box-shadow .3s}.waitlist-card:hover{transform:translateY(-4px);box-shadow:0 40px 80px #00000080,0 0 40px #8e2de233,inset 0 1px #ffffff1a}.login-link{text-align:center;color:var(--text-muted);margin-top:1.5rem;font-size:.9rem}.login-link a{color:var(--accent);font-weight:600;text-decoration:none;transition:color .2s}.login-link a:hover{color:#fff;text-shadow:0 0 10px var(--accent)}.canvas-wrapper{width:100%;height:600px;animation:1.5s forwards fade-in;position:relative}.canvas-glow{z-index:0;pointer-events:none;background:radial-gradient(circle,#8e2de226 0%,#0000 70%);border-radius:50%;width:400px;height:400px;animation:4s ease-in-out infinite alternate pulse-glow;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.features-section{z-index:2;max-width:1400px;margin:0 auto;padding:8rem 4rem;position:relative}.section-header{text-align:center;margin-bottom:5rem}.section-header h2{background:var(--rift-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:1rem;font-family:Fraunces,serif;font-size:3rem}.section-header p{color:var(--c-cozy-muted);font-size:1.2rem}.features-grid{grid-template-columns:repeat(3,1fr);gap:2rem;display:grid}.feature-card{text-align:center;padding:3rem 2rem}.feature-icon{filter:drop-shadow(0 0 10px #8e2de266);margin-bottom:1.5rem;font-size:3rem}.feature-card h3{color:#fff;margin-bottom:1rem;font-size:1.5rem}.feature-card p{color:var(--text-muted);font-size:.95rem;line-height:1.6}.hover-lift{transition:transform .4s cubic-bezier(.16,1,.3,1),box-shadow .4s}.hover-lift:hover{transform:translateY(-10px);box-shadow:0 20px 40px #0006,inset 0 1px #fff3}.roadmap-section{z-index:2;max-width:1400px;margin:0 auto;padding:5rem 4rem 8rem;position:relative}.roadmap-grid{grid-template-columns:repeat(3,1fr);gap:2rem;display:grid}.roadmap-card{padding:2.5rem;position:relative;overflow:hidden}.roadmap-card.active{border:1px solid #8e2de280;box-shadow:0 20px 40px #0006,inset 0 0 40px #8e2de21a}.roadmap-status{letter-spacing:.15em;border-radius:4px;margin-bottom:1.5rem;padding:.3rem .8rem;font-size:.75rem;font-weight:800;display:inline-block}.roadmap-status.current{color:var(--success);background:#2eeb9a26;border:1px solid #2eeb9a4d}.roadmap-status.upcoming{color:var(--text-muted);background:#a0a0b81a;border:1px solid #a0a0b833}.roadmap-card h3{color:#fff;margin-bottom:1.5rem;font-size:1.8rem}.roadmap-list{flex-direction:column;gap:1rem;list-style:none;display:flex}.roadmap-list li{color:var(--text-muted);align-items:center;gap:.75rem;font-size:.95rem;display:flex}.roadmap-card.active .roadmap-list li{color:#f0f0f5}.roadmap-list li span{color:var(--accent);font-weight:700}.roadmap-card.active .roadmap-list li span{color:var(--success)}.landing-footer{text-align:center;color:var(--c-cozy-muted);border-top:1px solid #ffffff0d;padding:3rem;font-size:.9rem}.waitlist-form{flex-direction:column;gap:1.5rem;display:flex}.input-group{flex-direction:column;display:flex;position:relative}.input-group label{text-transform:uppercase;letter-spacing:.05em;color:var(--accent);margin-bottom:.5rem;font-size:.85rem;font-weight:600}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-muted);position:absolute;left:1rem}input[type=email],input[type=text],input[type=password]{color:#fff;background:#0000004d;border:1px solid #ffffff1a;border-radius:12px;outline:none;width:100%;padding:1rem 1rem 1rem 3rem;font-family:Inter,sans-serif;font-size:1rem;transition:all .3s}input[type=email]:focus,input[type=text]:focus,input[type=password]:focus{border-color:var(--rift-violet);background:#00000080;box-shadow:0 0 0 2px #8e2de233}input[type=email]::placeholder,input[type=text]::placeholder,input[type=password]::placeholder{color:#a0a0b880}.submit-btn{background:var(--rift-gradient);color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:.5rem;padding:1.1rem;font-family:Outfit,sans-serif;font-size:1rem;font-weight:600;transition:all .3s;display:flex;position:relative;overflow:hidden}.submit-btn:before{content:"";background:linear-gradient(90deg,#0000,#fff3,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 10px 20px -5px #8e2de266}.submit-btn:hover:before{left:100%}.submit-btn:active{transform:translateY(1px)}.submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.message{border-radius:8px;align-items:center;gap:.5rem;padding:1rem;font-size:.9rem;animation:.3s ease-out forwards slide-up;display:flex}.message.success{color:var(--success);background:#2eeb9a1a;border:1px solid #2eeb9a33}.message.error{color:var(--error);background:#ff4a4a1a;border:1px solid #ff4a4a33}.message.warning{color:var(--warning);background:#ffb84a1a;border:1px solid #ffb84a33}@keyframes pulse-glow{0%{filter:drop-shadow(0 0 5px #8e2de24d)}to{filter:drop-shadow(0 0 15px #d0b0ff99)}}@keyframes slide-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (width<=968px){body{overflow-y:auto}#root{height:auto;min-height:100vh}.landing-container{flex-direction:column;height:auto;min-height:100vh;display:flex}.canvas-container{order:-1;height:55vh}.content-container{text-align:center;background:linear-gradient(#090a0f00,#090a0f 15%);align-items:center;margin-top:-15vh;padding:2rem 1.5rem 4rem}.logo{margin-bottom:1rem;font-size:2rem}.hero-title{font-size:2.75rem}.hero-subtitle{margin:0 auto 2rem;font-size:1rem}.waitlist-card{width:100%;padding:1.5rem}}.dashboard-root{width:100vw;height:100dvh;position:relative;overflow:hidden}.dashboard-hud{pointer-events:none;padding:2rem;position:absolute;inset:0}.dashboard-topbar{justify-content:space-between;align-items:flex-start;display:flex}.dashboard-player-info{pointer-events:auto;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#f6f1e7e6;border:1px solid #fff9;border-radius:20px;min-width:250px;padding:1rem 1.5rem;box-shadow:0 10px 30px #0000001a}.dashboard-player-name{color:var(--ink);margin:0;font-size:1.2rem;font-weight:800}.dashboard-player-level{color:var(--rift-violet);margin-top:.2rem;font-size:.9rem;font-weight:600}.dashboard-currency{pointer-events:auto;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#f6f1e7e6;border:1px solid #fff9;border-radius:20px;align-items:center;gap:2rem;padding:.5rem 1.5rem;display:flex;box-shadow:0 10px 30px #0000001a}.dashboard-currency-label{color:var(--c-cozy-muted,#6b6478);font-size:.8rem;font-weight:600}.dashboard-currency-value{color:var(--ink);font-size:1.1rem;font-weight:700}.dashboard-currency-value.gold{color:var(--riftgold)}.dashboard-sidebar{pointer-events:auto;-webkit-backdrop-filter:blur(16px);z-index:50;background:#f6f1e7f2;border:1px solid #fffc;border-top-color:#fff;border-radius:24px;flex-direction:column;gap:1rem;width:260px;padding:1.5rem;display:flex;position:absolute;top:50%;left:2rem;transform:translateY(-50%);box-shadow:0 30px 60px #00000026,inset 0 2px 4px #ffffff80}.sidebar-btn{background:var(--c-cozy-surface,#f6f1e7);border:1px solid var(--c-cozy-border,#ddd3c2);color:var(--ink);cursor:pointer;border-radius:16px;justify-content:flex-start;align-items:center;gap:1rem;margin:0;padding:1rem 1.2rem;font-family:Outfit,sans-serif;font-size:1.05rem;font-weight:600;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex;box-shadow:0 4px 10px #0000000d}.sidebar-btn:before{display:none}.sidebar-btn:hover:not(:disabled){border-color:var(--rift-violet);background:#fff;transform:translate(6px);box-shadow:0 10px 20px -5px #8a5cff33}.sidebar-btn-secondary{background:#ffffff80}.sidebar-btn-icon{filter:none;width:24px}.sidebar-hint{color:var(--c-cozy-muted);text-align:center;margin-top:.5rem;font-size:.75rem;font-style:italic}.dashboard-tooltip{color:var(--moonmilk);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none;z-index:100;background:#0a0a0fd9;border:1px solid #ffffff1a;border-radius:2rem;padding:.8rem 1.5rem;font-size:1.1rem;font-weight:700;position:absolute;bottom:4rem;left:50%;transform:translate(-50%);box-shadow:0 4px 15px #00000080}.dashboard-logout{pointer-events:auto;position:absolute;bottom:2rem;right:2rem}.dashboard-logout-btn{color:var(--mist);cursor:pointer;background:#0006;border:1px solid #ffffff1a;border-radius:8px;padding:.5rem 1rem;transition:all .2s}.dashboard-logout-btn:hover{color:var(--error)}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;pointer-events:auto;background:#05050ab3;justify-content:center;align-items:center;padding:2rem;animation:.2s forwards fade-in;display:flex;position:fixed;inset:0}.modal-content{background:linear-gradient(135deg,#1b1640f2,#0b0a1ffa);border:1px solid #ffffff14;border-radius:20px;width:100%;max-width:700px;max-height:85vh;padding:2rem;animation:.3s cubic-bezier(.16,1,.3,1) forwards slide-up;position:relative;overflow-y:auto;box-shadow:0 30px 80px #0009}.modal-close{color:var(--mist);cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;transition:all .2s;display:flex;position:absolute;top:1rem;right:1rem}.modal-close:hover{color:var(--error);background:#ff5c6a26;border-color:#ff5c6a4d}.modal-title{color:var(--moonmilk);text-align:center;margin-bottom:1.5rem;font-family:Fraunces,serif;font-size:1.8rem}.breeding-panel{max-width:600px}.breeding-slots{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.breeding-slot{flex:1}.breeding-slot-label{text-transform:uppercase;letter-spacing:.1em;color:var(--rift-cyan);text-align:center;margin-bottom:.75rem;font-size:.8rem}.breeding-divider{justify-content:center;align-items:center;padding-top:2rem;display:flex}.breeding-heart{font-size:1.5rem;animation:2s ease-in-out infinite alternate pulse-glow}.pet-selector{flex-direction:column;gap:.75rem;display:flex}.pet-selector-preview{text-align:center;background:#ffffff08;border:1px solid #ffffff14;border-radius:12px;padding:1rem}.pet-color-orb{border-radius:50%;width:48px;height:48px;margin:0 auto .5rem;box-shadow:0 0 16px #ffffff1a}.pet-selector-name{color:var(--moonmilk);font-size:.9rem;font-weight:600}.pet-selector-level{color:var(--mist);font-size:.8rem}.pet-selector-list{flex-direction:column;gap:.4rem;max-height:200px;display:flex;overflow-y:auto}.pet-option{cursor:pointer;color:var(--mist);background:#ffffff05;border:1px solid #0000;border-radius:10px;align-items:center;gap:.75rem;padding:.6rem .8rem;font-family:Inter,sans-serif;font-size:.85rem;transition:all .2s;display:flex}.pet-option:hover{color:var(--moonmilk);background:#ffffff0d}.pet-option.selected{border-color:var(--rift-violet);color:var(--moonmilk);background:#8a5cff1a}.pet-color-dot{border-radius:50%;flex-shrink:0;width:16px;height:16px}.pet-option-name{text-align:left;flex:1}.pet-option-level{color:var(--mist);font-size:.75rem}.breeding-active{text-align:center;margin-bottom:1.5rem;padding:2rem}.breeding-active-header{color:var(--rift-cyan);margin-bottom:1rem;font-family:Outfit,sans-serif;font-size:1.1rem}.breeding-egg-preview{margin:1rem 0;font-size:4rem}.egg-pulse{animation:2s ease-in-out infinite alternate pulse-glow;display:inline-block}.breeding-timer{color:var(--moonmilk);font-size:1.2rem;font-weight:700}.breeding-session-id{color:var(--mist);margin-top:.5rem;font-size:.75rem}.breeding-empty{text-align:center;color:var(--mist);padding:2rem 1rem}.breeding-hint{opacity:.7;margin-top:.5rem;font-size:.85rem}.expeditions-panel{max-width:550px}.expedition-list{flex-direction:column;gap:1rem;margin-bottom:1.5rem;display:flex}.expedition-card{background:var(--c-cozy-raised);border:1px solid var(--c-cozy-border);border-radius:16px;padding:1.5rem;transition:transform .2s}.expedition-card.soon{opacity:.85}.expedition-card.locked{opacity:.5}.expedition-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.expedition-name{color:var(--ink);font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:600}.expedition-duration{color:var(--riftgold);font-size:.85rem}.expedition-desc{color:var(--c-cozy-muted);margin-bottom:.75rem;font-size:.9rem;line-height:1.5}.expedition-status-tag{color:var(--c-cozy-muted);font-size:.8rem;font-weight:600}.expedition-footer{text-align:center;color:var(--c-cozy-muted);opacity:.9;border-top:1px solid var(--c-cozy-border);padding-top:.5rem;font-size:.85rem}@media (width<=768px){.dashboard-hud{padding:1rem}.dashboard-topbar{flex-direction:column;gap:.75rem}.dashboard-player-info{min-width:auto;padding:.75rem}.dashboard-currency{gap:1rem;padding:.5rem .75rem}.dashboard-sidebar{flex-direction:row;width:auto;max-width:95vw;top:auto;bottom:1rem;left:50%;overflow-x:auto;transform:translate(-50%)}.sidebar-btn{white-space:nowrap;padding:.75rem;font-size:.8rem}.sidebar-btn-icon{width:20px}.sidebar-hint{display:none}.modal-content{max-height:90vh;padding:1.5rem}.breeding-slots{flex-direction:column}.breeding-divider{padding-top:0}.dashboard-logout{top:1rem;bottom:auto;right:1rem}}.glow-btn{animation:2s ease-in-out infinite alternate pulse-glow}.full-screen-overlay{background:var(--moonmilk);color:var(--ink);z-index:1000;pointer-events:auto;flex-direction:column;animation:.4s cubic-bezier(.16,1,.3,1) forwards slide-up;display:flex;position:fixed;inset:0;overflow:hidden auto}.full-screen-overlay.lab-mode{background:var(--riftvoid);color:var(--moonmilk);background-image:radial-gradient(circle at 10% 90%,#34e0d00d,#0000 40%),radial-gradient(circle at 90% 10%,#8a5cff0d,#0000 40%)}.full-screen-overlay.cozy-mode{background:var(--moonmilk);color:var(--ink)}.full-screen-header{border-bottom:1px solid var(--c-cozy-border,#ddd3c2);justify-content:space-between;align-items:center;padding:2rem 4rem;display:flex}.cozy-mode .full-screen-header{border-bottom:1px solid #16132a0d}.lab-mode .full-screen-header{border-bottom:1px solid #ffffff14}.full-screen-title{margin:0;font-family:Fraunces,serif;font-size:2.5rem;font-weight:600}.full-screen-close{color:inherit;cursor:pointer;background:#16132a0d;border:1px solid #16132a1a;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.5rem;transition:all .2s;display:flex}.cozy-mode .full-screen-close{background:#16132a0d;border:1px solid #16132a1a}.lab-mode .full-screen-close{background:#ffffff14;border:1px solid #ffffff26}.full-screen-close:hover{color:var(--error);background:#ff5c6a26;border-color:#ff5c6a4d}.full-screen-content{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:2rem 4rem}.habitat-2d{background:radial-gradient(circle at 50% 34%,#fcf9f2 0%,#f3ede0 55%,#e5dbc9 100%);width:100%;height:100%;position:relative;overflow:hidden}.habitat-background{object-fit:cover;pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.pan-container{touch-action:none;cursor:grab;position:absolute;inset:0}.pan-container:active{cursor:grabbing}.world-map{will-change:transform;background-image:url(/assets/sprites/tiles/grass-tile.svg);background-repeat:repeat;position:absolute}.habitat-playable-area{position:absolute}.habitat-grid-square{background-color:#16132a14;border:4px solid #fff9;border-radius:8px;display:grid;position:relative;box-shadow:0 8px 32px #16132a2e}.grid-cell{box-sizing:border-box;cursor:pointer;border:1px solid #16132a1f;position:relative}.grid-overlay-hover{pointer-events:none;background:#ffffff40;position:absolute;inset:0}.grid-overlay-selected{border:2px solid var(--rift-cyan);pointer-events:none;background:#34e0d02e;position:absolute;inset:0;box-shadow:inset 0 0 12px #34e0d08c}.topdown-building,.topdown-decoration{pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;inset:4px}.topdown-building img{object-fit:contain;filter:drop-shadow(0 4px 6px #0000004d);width:100%;height:100%}.iso-placeholder-building{color:var(--moonmilk);text-align:center;background:#16132abf;border-radius:6px;flex-direction:column;align-items:center;gap:2px;padding:6px;font-size:10px;font-weight:700;line-height:1.1;display:flex}.topdown-decoration{color:var(--rift-violet);filter:drop-shadow(0 2px 4px #00000040)}.habitat-particles{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.habitat-particle{background:var(--rift-cyan);opacity:.4;border-radius:50%;animation:ease-in-out infinite alternate particle-float;position:absolute}@keyframes particle-float{0%{opacity:.2;transform:translate(0)}50%{opacity:.6}to{opacity:.1;transform:translate(20px,-30px)}}.habitat-portal{z-index:5;cursor:pointer;width:180px;height:180px;transition:filter .3s;position:absolute;top:50%;left:50%}.habitat-portal:hover{filter:brightness(1.3) drop-shadow(0 0 20px var(--rift-violet))}.habitat-portal img{width:100%;height:100%}.habitat-deco{pointer-events:auto;cursor:pointer;transition:transform .3s;position:absolute}.habitat-deco:hover{transform:scale(1.05)}.habitat-deco img{filter:drop-shadow(0 4px 8px #0006);width:100%;height:100%}.habitat-deco-tree-1{z-index:3;width:120px;height:120px;top:42%;left:25%}.habitat-deco-tree-2{z-index:3;width:100px;height:100px;top:40%;right:22%}.habitat-deco-rock-1{z-index:4;width:90px;height:90px;top:58%;left:18%}.habitat-deco-rock-2{z-index:4;width:80px;height:80px;top:60%;right:16%}.habitat-pet{z-index:10;cursor:pointer;width:52px;height:52px;transition:left 3s ease-in-out,top 3s ease-in-out,transform .2s;position:absolute;transform:translate(-50%,-50%)}.habitat-pet:hover{z-index:15;transform:translate(-50%,-50%)scale(1.15)}.habitat-pet img{pointer-events:none;width:100%;height:100%;animation:3s ease-in-out infinite alternate pet-idle}@keyframes pet-idle{0%{transform:translateY(0)}to{transform:translateY(-4px)}}.habitat-pet-shiny{font-size:1.2rem;animation:2s ease-in-out infinite alternate sparkle;position:absolute;top:-8px;right:-4px}@keyframes sparkle{0%{opacity:.5;transform:scale(1)rotate(0)}to{opacity:1;transform:scale(1.2)rotate(15deg)}}.egg-display{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.egg-float{filter:drop-shadow(0 20px 40px #8a5cff4d);width:200px;height:auto;animation:4s ease-in-out infinite alternate egg-float}@keyframes egg-float{0%{transform:translateY(0)rotate(-2deg)}to{transform:translateY(-20px)rotate(2deg)}}.habitat-toolbar-hud{z-index:40;justify-content:center;display:flex;position:absolute;bottom:2rem;left:50%;transform:translate(-50%)}.habitat-toolbar{-webkit-backdrop-filter:blur(12px);pointer-events:auto;background:#f6f1e7e6;border:1px solid #fff9;border-radius:24px;align-items:center;gap:1rem;padding:1rem;display:flex;position:relative;box-shadow:0 10px 30px #16132a2e}.habitat-currency-bar{border:1px solid var(--c-cozy-border,#ddd3c2);background:#fffdf8d9;border-radius:16px;align-items:center;gap:1rem;padding:.6rem 1rem;display:flex}.habitat-currency-item{align-items:center;gap:.6rem;display:flex}.habitat-currency-info{flex-direction:column;display:flex}.habitat-currency-label{color:var(--c-cozy-muted,#6b6478);font-size:.7rem;font-weight:600}.habitat-currency-value{color:var(--ink);font-variant-numeric:tabular-nums;font-size:1rem;font-weight:700}.habitat-currency-icon{width:18px;height:18px;color:var(--rift-violet)}.habitat-currency-divider{background:var(--c-cozy-border,#ddd3c2);width:1px;height:28px}.habitat-tool-group{align-items:center;gap:.6rem;display:flex}.habitat-tool-btn{background:var(--c-cozy-sunken,#ede6d8);border:1px solid var(--c-cozy-border,#ddd3c2);color:var(--ink);cursor:pointer;border-radius:14px;flex-direction:column;align-items:center;gap:.3rem;padding:.6rem 1rem;font-family:Outfit,sans-serif;font-size:.75rem;font-weight:600;transition:all .2s;display:flex}.habitat-tool-btn:hover{background:var(--c-cozy-raised,#fffdf8);border-color:var(--rift-violet);transform:translateY(-2px)}.habitat-tool-btn-active{background:var(--rift-violet);color:var(--moonmilk);border-color:var(--rift-violet);box-shadow:0 0 18px #8a5cff73}.habitat-tool-btn-active:hover{background:#9a70ff;transform:none}.habitat-tool-icon{display:flex}.habitat-tool-label{line-height:1}.habitat-submenu{-webkit-backdrop-filter:blur(16px);z-index:50;background:#f6f1e7f7;border:1px solid #ffffffb3;border-radius:20px;flex-direction:column;gap:.8rem;width:300px;padding:1.2rem;animation:.25s cubic-bezier(.22,1,.36,1) forwards submenu-slide-up;display:flex;position:absolute;bottom:calc(100% + 1rem);left:50%;transform:translate(-50%);box-shadow:0 16px 40px #16132a40}@keyframes submenu-slide-up{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}.habitat-submenu-header{border-bottom:1px solid var(--c-cozy-border,#ddd3c2);padding-bottom:.6rem}.habitat-submenu-header h4{color:var(--ink);margin:0;font-family:Outfit,sans-serif;font-size:1rem;font-weight:700}.habitat-submenu-content{flex-direction:column;gap:.5rem;max-height:320px;padding-right:.3rem;display:flex;overflow-y:auto}.habitat-submenu-content::-webkit-scrollbar{width:6px}.habitat-submenu-content::-webkit-scrollbar-thumb{background:var(--rift-violet);border-radius:999px}.habitat-building-btn,.habitat-decoration-btn{background:var(--c-cozy-raised,#fffdf8);border:1px solid var(--c-cozy-border,#ddd3c2);cursor:pointer;text-align:left;border-radius:12px;align-items:center;gap:.8rem;padding:.7rem;transition:all .2s;display:flex}.habitat-building-btn:hover:not(:disabled),.habitat-decoration-btn:hover:not(:disabled){border-color:var(--rift-cyan);background:#fff;transform:translateY(-2px);box-shadow:0 6px 14px #34e0d033}.habitat-building-btn:disabled,.habitat-decoration-btn:disabled{opacity:.45;cursor:not-allowed}.habitat-building-icon,.habitat-decoration-icon{width:24px;height:24px;color:var(--rift-violet);flex-shrink:0;justify-content:center;align-items:center;display:flex}.habitat-building-info,.habitat-decoration-info{flex-direction:column;flex:1;gap:.15rem;display:flex}.habitat-building-name,.habitat-decoration-name{color:var(--ink);font-family:Outfit,sans-serif;font-size:.9rem;font-weight:600}.habitat-building-cost,.habitat-decoration-cost{color:var(--c-cozy-muted,#6b6478);font-variant-numeric:tabular-nums;align-items:center;gap:4px;font-size:.75rem;display:flex}.habitat-hint{color:var(--error);background:#ff5c6a14;border:1px dashed #ff5c6a66;border-radius:10px;align-items:center;gap:.5rem;padding:.7rem;font-size:.8rem;font-weight:500;display:flex}.habitat-hint-icon{flex-shrink:0}@media (width<=768px){.habitat-portal{width:120px;height:120px}.habitat-deco-tree-1,.habitat-deco-tree-2{width:70px;height:70px}.habitat-deco-rock-1,.habitat-deco-rock-2{width:55px;height:55px}.habitat-pet{width:52px;height:52px}.egg-float{width:140px}.habitat-toolbar-hud{width:100%;padding:0 .5rem;bottom:1rem}.habitat-toolbar{width:100%;overflow-x:auto}.habitat-submenu{width:min(300px,90vw)}}
