.theme-switcher{width:44px;height:44px;color:inherit;cursor:pointer;background-color:#646cff1a;border:2px solid #0000;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:all .3s;display:flex}.theme-switcher:hover{background-color:#646cff33;border-color:#646cff;transform:scale(1.1)}.theme-switcher:active{transform:scale(.95)}.theme-switcher svg{transition:transform .4s}.theme-switcher:hover svg{transform:rotate(20deg)}@media (prefers-color-scheme:light){.theme-switcher{color:#213547;background-color:#7878781a}.theme-switcher:hover{background-color:#78787833;border-color:#747bff}}.sidebar{width:var(--sidebar-width);background-color:var(--color-bg);border-right:1px solid var(--color-border);z-index:900;flex-direction:column;align-items:center;padding-bottom:1rem;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:visible}.sidebar-logo-block{width:100%;height:var(--topbar-height,53px);border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-logo-mark{background-color:var(--color-primary);color:#fff;letter-spacing:.01em;-webkit-user-select:none;user-select:none;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:.75rem;font-weight:800;display:flex}.sidebar-nav{flex-direction:column;align-items:center;gap:.125rem;width:100%;margin:0;padding:.5rem 0;list-style:none;display:flex}.sidebar-divider{background-color:var(--color-border);flex-shrink:0;width:28px;height:1px;margin:.25rem 0}.sidebar-item{justify-content:center;width:100%;display:flex;position:relative}.sidebar-link{width:40px;height:40px;color:var(--color-text);opacity:.6;border-radius:10px;justify-content:center;align-items:center;text-decoration:none;transition:background-color .15s,color .15s;display:flex;position:relative}.sidebar-link:hover{color:var(--color-primary);opacity:1;background-color:#646cff1a}.sidebar-link--active{color:var(--color-primary);opacity:1;background-color:#646cff1f}.sidebar-emoji-nav{justify-content:center;align-items:center;width:20px;height:20px;font-size:1.25rem;line-height:1;display:inline-flex}.sidebar-label{display:none}.sidebar-tooltip{background-color:var(--color-text);color:var(--color-bg);white-space:nowrap;pointer-events:none;opacity:0;z-index:1200;border-radius:6px;padding:.3rem .6rem;font-size:.75rem;font-weight:600;transition:opacity .15s;position:absolute;top:50%;left:calc(100% + 12px);transform:translateY(-50%)}.sidebar-tooltip:before{content:"";border:5px solid #0000;border-right-color:var(--color-text);position:absolute;top:50%;right:100%;transform:translateY(-50%)}.sidebar-link:hover .sidebar-tooltip{opacity:1}.sidebar-overlay{display:none}@media (width<=767px){.sidebar{z-index:1100;align-items:flex-start;width:220px;transition:transform .25s;top:0;overflow-y:auto;transform:translate(-100%)}.sidebar--open{transform:translate(0)}.sidebar-nav{align-items:flex-start;padding:.5rem}.sidebar-item{justify-content:flex-start;width:100%}.sidebar-link{opacity:1;border-radius:8px;justify-content:flex-start;gap:.75rem;width:100%;height:42px;padding:0 .75rem}.sidebar-label{font-size:.9rem;font-weight:500;display:inline}.sidebar-tooltip{display:none}.sidebar-logo-block{justify-content:flex-start;width:100%;padding-left:1rem}.sidebar-overlay{z-index:1099;background-color:#0006;display:block;position:fixed;inset:0}}.not-found{box-sizing:border-box;justify-content:center;align-items:center;min-height:min(70vh,32rem);padding:2rem 0 3rem;display:flex}.not-found__inner{background:var(--color-card-bg);border:1px solid var(--color-card-border);text-align:center;border-radius:1rem;width:100%;max-width:28rem;padding:2rem 1.75rem;box-shadow:0 12px 40px #0f0f281f}:root[data-theme=dark] .not-found__inner,:root.dark .not-found__inner{box-shadow:0 12px 48px #00000059}.not-found__code{letter-spacing:.35em;text-transform:uppercase;color:var(--color-primary);opacity:.85;margin:0 0 .5rem;font-size:.75rem;font-weight:700}.not-found__title{letter-spacing:-.02em;color:var(--color-text);outline:none;margin:0 0 1rem;font-size:clamp(1.5rem,4vw,1.85rem);font-weight:700;line-height:1.2}.not-found__title:focus-visible{box-shadow:0 0 0 3px var(--color-glow);border-radius:.25rem}.not-found__lead{color:var(--color-text);opacity:.88;margin:0 0 1.75rem;font-size:1rem;line-height:1.55}.not-found__path{word-break:break-all;background:#7c3aed14;border-radius:.25rem;padding:.1em .35em;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.9em;display:inline}:root[data-theme=dark] .not-found__path,:root.dark .not-found__path{background:#a78bfa1f}.not-found__actions{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.not-found__btn{min-height:2.75rem;color:var(--color-primary);border:1px solid var(--color-border);cursor:pointer;background:0 0;border-radius:.5rem;justify-content:center;align-items:center;padding:.5rem 1.25rem;font-family:inherit;font-size:1rem;font-weight:600;line-height:1.2;text-decoration:none;transition:border-color .2s,background .2s,color .2s;display:inline-flex}.not-found__btn:hover{color:var(--color-primary-hover);border-color:var(--color-primary)}.not-found__btn:focus-visible{box-shadow:0 0 0 3px var(--color-glow);outline:none}.not-found__btn--primary{color:#fff;background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-hover) 100%);border-color:#0000}.not-found__btn--primary:hover{color:#fff;filter:brightness(1.06)}@media (prefers-reduced-motion:reduce){.not-found__btn{transition:none}}@media (width<=767px){.not-found{padding-left:0;padding-right:0}.not-found__inner{padding:1.5rem 1.25rem}}:root{--topbar-height:53px;--sidebar-width:60px}main{margin-left:var(--sidebar-width);padding-top:var(--topbar-height);box-sizing:border-box;min-height:100vh;width:calc(100% - var(--sidebar-width));padding-left:2rem;padding-right:2rem}@media (width<=767px){main{width:100%;margin-left:0}}.logo{will-change:filter;height:6em;padding:1.5em;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:20s linear infinite logo-spin}}.card{padding:2em}.read-the-docs{color:#888}.topbar{top:0;left:var(--sidebar-width,60px);height:var(--topbar-height,53px);z-index:1000;background-color:var(--color-bg);border-bottom:1px solid var(--color-border);box-sizing:border-box;justify-content:space-between;align-items:center;padding:0 1rem;display:flex;position:fixed;right:0}.topbar-leading{align-items:center;gap:.25rem;min-width:0;display:flex}.topbar-back{width:40px;height:40px;color:inherit;cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:background-color .15s;display:flex}.topbar-back:hover{background-color:#646cff14}.topbar-hamburger{width:40px;height:40px;color:inherit;cursor:pointer;visibility:hidden;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:0;transition:background-color .15s;display:none}@media (width<=767px){.topbar-hamburger{visibility:visible}}.topbar-hamburger:hover{background-color:#646cff14;border-color:#0000}@media (width<=767px){.topbar{left:0}.topbar-hamburger{display:flex}}.topbar-actions{align-items:center;gap:.75rem;margin-left:auto;display:flex}.header-auth-btn{width:44px;height:44px;color:inherit;cursor:pointer;background-color:#646cff1a;border:2px solid #0000;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:all .3s;display:flex}.header-auth-btn:hover{background-color:#646cff33;border-color:#646cff;transform:scale(1.1)}.header-auth-btn:active{transform:scale(.95)}.header-auth-btn svg{transition:transform .3s}.header-auth-btn:hover svg{transform:translate(2px)}.login-page{justify-content:center;align-items:center;min-height:80vh;display:flex}.login-card{background:var(--card-bg,#646cff0d);border:1px solid var(--card-border,#646cff1a);text-align:left;border-radius:16px;width:100%;max-width:400px;padding:2.5rem}.login-title{margin:0 0 .5rem;font-size:1.875rem;font-weight:700}.login-subtitle{opacity:.7;margin:0 0 2rem}.login-form{flex-direction:column;gap:1.25rem;display:flex}.form-field{flex-direction:column;gap:.5rem;display:flex}.form-field label{opacity:.9;font-size:.875rem;font-weight:500}.form-field input{border:1px solid var(--color-border);color:inherit;background:0 0;border-radius:8px;outline:none;padding:.75rem 1rem;font-family:inherit;font-size:1rem;transition:border-color .2s}.form-field input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-nebula)}.login-error{color:#f87171;background:#f871711a;border:1px solid #f8717133;border-radius:8px;margin:0;padding:.75rem 1rem;font-size:.875rem}.btn-full{width:100%;margin-top:.5rem}:root[data-theme=dark] .login-card{--card-bg:#646cff14;--card-border:#646cff26}:root[data-theme=light] .login-card{--card-bg:#646cff08;--card-border:#646cff1a}.starfield{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.starfield-layer{background:0 0;border-radius:50%;width:2px;height:2px;animation-timing-function:linear;animation-iteration-count:infinite;position:absolute;top:0;left:0}.starfield-layer--small{animation-name:starDrift;animation-duration:80s;box-shadow:24px 89px #c4b5fd,132px 210px #c4b5fd,290px 45px #e0e7ff,410px 320px #c4b5fd,530px 150px #e0e7ff,670px 410px #c4b5fd,50px 500px #e0e7ff,180px 650px #c4b5fd,340px 720px #e0e7ff,490px 580px #c4b5fd,620px 90px #e0e7ff,760px 260px #c4b5fd,850px 430px #e0e7ff,920px 600px #c4b5fd,1050px 150px #e0e7ff,1120px 340px #c4b5fd,1230px 520px #e0e7ff,1350px 80px #c4b5fd,1440px 290px #e0e7ff,1500px 470px #c4b5fd,95px 800px #e0e7ff,250px 860px #c4b5fd,400px 920px #e0e7ff,580px 780px #c4b5fd,700px 850px #e0e7ff,830px 750px #c4b5fd,980px 810px #e0e7ff,1100px 880px #c4b5fd,1250px 730px #e0e7ff,1400px 800px #c4b5fd,70px 300px #e0e7ff,200px 450px #c4b5fd,360px 200px #e0e7ff,520px 370px #c4b5fd,680px 550px #e0e7ff,810px 180px #c4b5fd,950px 370px #e0e7ff,1080px 50px #c4b5fd,1200px 200px #e0e7ff,1330px 400px #c4b5fd,1460px 620px #e0e7ff,1550px 150px #c4b5fd,160px 70px #e0e7ff,310px 380px #c4b5fd,460px 130px #e0e7ff,600px 250px #c4b5fd,740px 500px #e0e7ff,880px 620px #c4b5fd,1020px 270px #e0e7ff,1160px 450px #c4b5fd,1300px 620px #e0e7ff,1430px 110px #c4b5fd,1570px 350px #e0e7ff,45px 620px #c4b5fd,230px 550px #e0e7ff,380px 470px #c4b5fd,540px 690px #e0e7ff,690px 340px #c4b5fd,820px 520px #e0e7ff,960px 140px #c4b5fd,1100px 680px #e0e7ff,1260px 310px #c4b5fd,1400px 540px #e0e7ff}.starfield-layer--medium{width:2px;height:2px;animation-name:starDrift;animation-duration:120s;box-shadow:100px 120px #a78bfa,320px 300px #e0e7ff,540px 80px #a78bfa,710px 450px #e0e7ff,890px 200px #a78bfa,1050px 550px #e0e7ff,1200px 100px #a78bfa,1380px 380px #e0e7ff,60px 420px #a78bfa,230px 700px #e0e7ff,420px 580px #a78bfa,600px 740px #e0e7ff,780px 620px #a78bfa,940px 800px #e0e7ff,1100px 420px #a78bfa,1280px 700px #e0e7ff,150px 250px #a78bfa,360px 150px #e0e7ff,500px 440px #a78bfa,650px 170px #e0e7ff,830px 360px #a78bfa,1000px 510px #e0e7ff,1170px 260px #a78bfa,1340px 160px #e0e7ff,1480px 500px #a78bfa,80px 780px #e0e7ff,270px 480px #a78bfa,440px 820px #e0e7ff,620px 390px #a78bfa,810px 110px #e0e7ff,970px 680px #a78bfa,1130px 570px #e0e7ff,1300px 850px #a78bfa,1450px 270px #e0e7ff,190px 600px #a78bfa,380px 340px #e0e7ff}.starfield-layer--large{width:3px;height:3px;animation-name:starDrift,twinkle;animation-duration:160s,4s;animation-timing-function:linear,ease-in-out;animation-iteration-count:infinite,infinite;box-shadow:200px 180px #c4b5fd,480px 400px #a78bfa,780px 250px #c4b5fd,1020px 600px #a78bfa,1320px 150px #c4b5fd,60px 650px #a78bfa,350px 550px #c4b5fd,640px 100px #a78bfa,900px 450px #c4b5fd,1150px 300px #a78bfa,1420px 650px #c4b5fd,260px 50px #a78bfa,550px 700px #c4b5fd,820px 820px #a78bfa,1100px 100px #c4b5fd,1350px 480px #a78bfa,140px 380px #c4b5fd,430px 250px #a78bfa,700px 570px #c4b5fd,980px 720px #a78bfa}@keyframes starDrift{0%{transform:translateY(0)}to{transform:translateY(-100vh)}}@keyframes twinkle{0%,to{opacity:1}50%{opacity:.4}}@media (prefers-reduced-motion:reduce){.starfield-layer{animation:none!important}}.games-page{z-index:1;max-width:960px;margin:0 auto;padding:2rem 0;position:relative}.games-hero{text-align:center;margin-bottom:3rem}.games-hero h1{background:linear-gradient(135deg, var(--color-primary) 0%, #3b82f6 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 .75rem;font-size:2.5rem;font-weight:700}.games-hero p{color:var(--color-text);opacity:.7;margin:0;font-size:1.1rem}.games-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem;display:grid}.game-card{background:var(--color-card-bg);border:1px solid var(--color-card-border);-webkit-backdrop-filter:blur(12px);border-radius:16px;flex-direction:column;gap:.5rem;padding:1.75rem 1.5rem;transition:border-color .3s,box-shadow .3s,transform .3s;display:flex;position:relative}.game-card:hover{border-color:var(--color-primary);box-shadow:0 8px 32px #7c3aed1a, 0 0 24px var(--color-nebula);transform:translateY(-4px)}.game-card--coming-soon{opacity:.8}.game-card-icon{color:var(--color-primary);margin-bottom:.25rem}.game-card h2{color:var(--color-text);margin:0;font-size:1.1rem;font-weight:600}.game-card p{color:var(--color-text);opacity:.7;margin:0;font-size:.9rem;line-height:1.5}.game-badge{color:var(--color-primary);letter-spacing:.02em;text-transform:uppercase;background:linear-gradient(135deg,#7c3aed26,#3b82f61a);border-radius:20px;align-self:flex-start;margin-top:.5rem;padding:.2rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.contact-page{box-sizing:border-box;z-index:1;flex-direction:column;gap:2.5rem;width:100%;max-width:800px;margin:0 auto;padding:4rem 1rem;display:flex;position:relative}.contact-header{text-align:center}.contact-header h1{background:linear-gradient(135deg, var(--color-primary) 0%, #3b82f6 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 .75rem;font-size:2.5rem;font-weight:700}.contact-header p{opacity:.75;margin:0;font-size:1.125rem}.contact-form{text-align:left;background:var(--color-card-bg);border:1px solid var(--color-card-border);-webkit-backdrop-filter:blur(16px);border-radius:20px;flex-direction:column;gap:1.5rem;padding:2.5rem;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group--full{grid-column:1/-1}.contact-form label{opacity:.9;font-size:.875rem;font-weight:600}.contact-form input,.contact-form select,.contact-form textarea{border:1px solid var(--color-border);color:inherit;box-sizing:border-box;background:#7c3aed0a;border-radius:10px;outline:none;width:100%;padding:.75rem 1rem;font-family:inherit;font-size:1rem;transition:border-color .2s,box-shadow .2s}.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-nebula), 0 0 16px var(--color-nebula)}.contact-form select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23888' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 1rem center;background-repeat:no-repeat;padding-right:2.5rem}.contact-form textarea{resize:vertical;min-height:140px}:root[data-theme=dark] .contact-form input,:root[data-theme=dark] .contact-form select,:root[data-theme=dark] .contact-form textarea{background:#ffffff0a}:root[data-theme=dark] .contact-form select option{background:#0f0f28}.contact-form .form-error{color:#ef4444;background:#ef444414;border:1px solid #ef444433;border-radius:8px;margin:0;padding:.75rem 1rem;font-size:.9rem}.form-actions{justify-content:flex-end;gap:1rem;padding-top:.5rem;display:flex}.contact-success{text-align:center;flex-direction:column;align-items:center;gap:1rem;padding:4rem 2rem;display:flex}.success-icon{color:#fff;background:linear-gradient(135deg,#7c3aed 0%,#3b82f6 100%);border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;animation:.4s cubic-bezier(.34,1.56,.64,1) popIn;display:flex;box-shadow:0 0 40px #7c3aed59}@keyframes popIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.contact-success h2{background:linear-gradient(135deg, var(--color-primary) 0%, #3b82f6 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0;font-size:2rem}.contact-success p{opacity:.75;margin:0 0 1rem}@media (width<=640px){.contact-page{padding:2rem 1rem}.contact-header h1{font-size:2rem}.contact-form{padding:1.5rem}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.form-actions .btn{text-align:center;width:100%}}.home-page{z-index:1;flex-direction:column;gap:4rem;width:100%;min-height:100vh;padding-top:2rem;display:flex;position:relative}.hero{align-items:center;min-height:70vh;display:flex;position:relative;overflow:hidden}.hero-col{flex:1;min-width:0}.hero-col--left{align-items:center;display:flex}.hero-col--right{justify-content:center;align-items:center;display:flex}.hero.loaded .hero-content{animation:.8s ease-out fadeInUp}.hero.loaded .hero-sun{animation:1s ease-out .2s both fadeInUp}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.hero-content{z-index:10;flex:1;max-width:600px}.hero-title{letter-spacing:-1px;margin:0 0 1.5rem;font-size:3.5rem;font-weight:700;line-height:1.2}.highlight{background:linear-gradient(135deg,#a78bfa 0%,#3b82f6 50%,#818cf8 100%);-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 20px var(--color-glow));-webkit-background-clip:text;background-clip:text;animation:4s ease-in-out infinite gradientShift;display:inline-block}@keyframes gradientShift{0%,to{filter:hue-rotate(0deg) drop-shadow(0 0 20px var(--color-glow))}50%{filter:hue-rotate(20deg) drop-shadow(0 0 30px var(--color-glow))}}.hero-subtitle{opacity:.75;margin:0 0 2.5rem;font-size:1.25rem;line-height:1.7}.hero-sun{flex-shrink:0;justify-content:center;align-items:center;animation:8s ease-in-out infinite sunFloat;display:flex;position:relative}.sun-clip{z-index:1;border-radius:50%;width:300px;height:300px;position:relative;overflow:hidden}.sun-clip:before{content:"";z-index:-1;border-radius:50%;animation:3s ease-in-out infinite radiateGlow;position:absolute;inset:-40%}.sun-clip img{object-fit:cover;-webkit-user-select:none;user-select:none;width:100%;height:100%;transform:scale(1.15)}.hero-sun__skeleton{z-index:2;background:linear-gradient(90deg,#7c3aed0f 25%,#7c3aed1f 50%,#7c3aed0f 75%) 0 0/200% 100%;border-radius:50%;animation:1.5s ease-in-out infinite shimmer;position:absolute;inset:0}.hero-sun__img--loading{opacity:0}.hero-sun__img--loaded{opacity:1;animation:.4s ease-out imgFadeIn}.sun-clip--light{animation:3s ease-in-out infinite radiateLight}.sun-clip--light:before{background:radial-gradient(circle,#fbbf244d 0%,#f59e0b26 30%,#ea580c0f 55%,#0000 70%)}.sun-clip--dark{animation:3s ease-in-out infinite radiateLightBlue}.sun-clip--dark:before{background:radial-gradient(circle,#38bdf84d 0%,#0ea5e926 30%,#3b82f60f 55%,#0000 70%)}@keyframes radiateLight{0%,to{filter:drop-shadow(0 0 20px #f59e0b66)drop-shadow(0 0 50px #ea580c33)}50%{filter:drop-shadow(0 0 35px #f59e0b99)drop-shadow(0 0 80px #ea580c4d)drop-shadow(0 0 120px #fbbf2426)}}@keyframes radiateLightBlue{0%,to{filter:drop-shadow(0 0 20px #38bdf866)drop-shadow(0 0 50px #3b82f633)}50%{filter:drop-shadow(0 0 35px #38bdf899)drop-shadow(0 0 80px #3b82f64d)drop-shadow(0 0 120px #0ea5e926)}}@keyframes radiateGlow{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.12)}}:root[data-theme=dark] .sun-clip--light,:root:not([data-theme=dark]) .sun-clip--dark,:root[data-theme=light] .sun-clip--dark{display:none}@keyframes sunFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-14px)}}.shooting-star{opacity:0;background:linear-gradient(90deg,#a78bfa00,#c4b5fd 40%,#fff 100%);border-radius:2px;width:120px;height:2px;animation:6s ease-in 3s infinite shoot;position:absolute;top:15%;left:-5%;transform:rotate(-25deg)}@keyframes shoot{0%{opacity:0;transform:translate(0)translateY(0)rotate(-25deg)}2%{opacity:1}8%{opacity:0;transform:translate(80vw)translateY(30vh)rotate(-25deg)}to{opacity:0;transform:translate(80vw)translateY(30vh)rotate(-25deg)}}.cta-buttons{flex-wrap:wrap;gap:1rem;display:flex}.btn{cursor:pointer;text-transform:uppercase;letter-spacing:.5px;border:none;border-radius:8px;justify-content:center;align-items:center;padding:.875rem 2rem;font-size:1rem;font-weight:600;text-decoration:none;transition:all .3s;display:inline-flex}.btn-primary{color:#fff;background:linear-gradient(135deg,#7c3aed 0%,#3b82f6 100%);box-shadow:0 10px 30px #7c3aed4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 15px 40px #7c3aed73}.btn-secondary{color:var(--color-primary);border:2px solid var(--color-primary);background:0 0}.btn-secondary:hover{background:var(--color-primary);color:#fff}.btn-large{padding:1.125rem 3rem;font-size:1.125rem}.fun-facts{text-align:center;padding:4rem 0}.fun-facts h2{background:linear-gradient(135deg, var(--color-primary) 0%, #3b82f6 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:3rem;font-size:2.5rem}.facts-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;display:grid}.fact-card{background:var(--color-card-bg);border:1px solid var(--color-card-border);-webkit-backdrop-filter:blur(12px);text-align:left;border-radius:16px;padding:2rem;transition:all .35s;animation:.6s ease-out both cardFadeIn}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.fact-card:hover{border-color:var(--color-primary);box-shadow:0 20px 40px #7c3aed14, 0 0 30px var(--color-nebula);transform:translateY(-6px)}.fact-icon{width:56px;height:56px;color:var(--color-primary);background:linear-gradient(135deg,#7c3aed26,#3b82f61a);border-radius:14px;justify-content:center;align-items:center;margin-bottom:1rem;display:inline-flex}.fact-card h3{margin:.75rem 0 .5rem;font-size:1.25rem}.fact-card p{opacity:.7;margin:0;font-size:.95rem;line-height:1.65}.fact-card--apod{cursor:pointer;font:inherit;color:inherit;flex-direction:column;width:100%;padding:0;display:flex;overflow:hidden}.fact-card__image{aspect-ratio:16/10;background:#7c3aed0d;width:100%;position:relative;overflow:hidden}.fact-card__image .skeleton--image{z-index:1;position:absolute;inset:0}.fact-card__img--loading{opacity:0}.fact-card__img--loaded{opacity:1;animation:.4s ease-out imgFadeIn}@keyframes imgFadeIn{0%{opacity:0}to{opacity:1}}.fact-card__image img{object-fit:cover;width:100%;height:100%;transition:transform .4s}.fact-card--apod:hover .fact-card__image img{transform:scale(1.05)}.fact-card__body{flex-direction:column;flex:1;padding:1.5rem;display:flex}.fact-card__body h3{margin:0 0 .5rem}.fact-card__explanation{-webkit-line-clamp:3;-webkit-box-orient:vertical;flex:1;display:-webkit-box;overflow:hidden}.fact-card__date{opacity:.45;margin-top:.75rem;font-size:.8rem}.facts-grid--shuffling{opacity:0;transition:opacity .3s,transform .3s;transform:translateY(12px)}.btn-shuffle{border:1px solid var(--color-card-border);background:var(--color-card-bg);color:var(--color-primary);cursor:pointer;-webkit-backdrop-filter:blur(8px);border-radius:10px;align-items:center;gap:.5rem;margin-top:2rem;padding:.75rem 1.75rem;font-size:.95rem;font-weight:600;transition:all .3s;display:inline-flex}.btn-shuffle:hover:not(:disabled){border-color:var(--color-primary);box-shadow:0 0 20px var(--color-nebula);transform:translateY(-2px)}.btn-shuffle:disabled{opacity:.5;cursor:not-allowed}.btn-shuffle svg{transition:transform .4s}.btn-shuffle:hover:not(:disabled) svg{transform:rotate(180deg)}.apod-credit{opacity:.45;margin-top:1rem;font-size:.8rem}.apod-credit a{color:inherit;text-underline-offset:2px;text-decoration:underline;transition:opacity .2s}.apod-credit a:hover{opacity:1}.fact-card--skeleton{padding:0;overflow:hidden}.skeleton{background:linear-gradient(90deg,#7c3aed0f 25%,#7c3aed1f 50%,#7c3aed0f 75%) 0 0/200% 100%;border-radius:8px;animation:1.5s ease-in-out infinite shimmer}.skeleton--image{aspect-ratio:16/10;border-radius:0;width:100%}.skeleton--title{width:60%;height:1.25rem;margin:1.5rem 1.5rem .75rem}.skeleton--text{width:90%;height:.9rem;margin:.35rem 1.5rem}.skeleton--short{width:50%;margin-bottom:1.5rem}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.apod-dialog{background:0 0;border:none;width:100%;max-width:100%;height:100%;max-height:100%;margin:0;padding:0;position:fixed;inset:0;overflow:hidden}.apod-dialog::backdrop{-webkit-backdrop-filter:blur(8px);background:#000000d9}.apod-dialog[open]{animation:.3s ease-out dialogFadeIn}.apod-dialog[open]::backdrop{animation:.3s ease-out backdropFadeIn}@keyframes dialogFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}.apod-dialog__content{width:100dvw;height:100dvh;display:flex;overflow:hidden}.apod-dialog__close{z-index:10;color:#fff;cursor:pointer;background:#00000080;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:background .2s,transform .2s;display:flex;position:absolute;top:1.5rem;right:1.5rem}.apod-dialog__close:hover{background:#000000bf;transform:scale(1.1)}.apod-dialog__image{background:#000;flex:1;justify-content:center;align-items:center;min-width:0;display:flex;position:relative;overflow:hidden}.apod-dialog__skeleton{border-radius:0;position:absolute;inset:0}.apod-dialog__image img{object-fit:contain;width:100%;height:100%}.apod-dialog__body{box-sizing:border-box;background:var(--color-card-bg,#1a1a2e);border-left:1px solid var(--color-card-border,#ffffff14);width:400px;min-width:0;color:var(--color-text,#e2e8f0);flex-shrink:0;padding:4.5rem 2rem 2.5rem;overflow-y:auto}.apod-dialog__body h2{margin:0 0 .25rem;font-size:1.5rem;line-height:1.3}.apod-dialog__date{opacity:.45;margin-bottom:1.5rem;font-size:.8rem;display:block}.apod-dialog__body p{opacity:.8;overflow-wrap:break-word;word-break:break-word;margin:0;font-size:.95rem;line-height:1.75}@media (width<=768px){.apod-dialog{padding:1rem}.apod-dialog__content{border-radius:12px;flex-direction:column;width:calc(100dvw - 2rem);height:calc(100dvh - 2rem);overflow:hidden}.apod-dialog__close{top:1.75rem;right:1.75rem}.apod-dialog__image{flex:none;height:38dvh}.apod-dialog__body{border-left:none;border-top:1px solid var(--color-card-border,#ffffff14);box-sizing:border-box;flex:1;width:100%;min-width:0;padding:4rem 1.5rem 2rem;overflow-y:auto}.apod-dialog__body h2{font-size:1.2rem}.apod-dialog__body p{font-size:.9rem}}.cta-section{text-align:center;border:1px solid var(--color-card-border);-webkit-backdrop-filter:blur(8px);background:linear-gradient(135deg,#7c3aed1a 0%,#3b82f61a 100%);border-radius:16px;padding:4rem 2rem}.cta-section h2{opacity:.9;margin-bottom:.5rem;font-size:1.75rem;font-style:italic;font-weight:500}.cta-attribution{opacity:.6;margin-bottom:2rem;font-size:1rem}.cta-section .btn{margin-top:.5rem}@media (width<=768px){.hero{flex-direction:column;gap:2rem;min-height:auto;margin-bottom:2rem}.hero-col--right{order:-1}.hero-sun .sun-clip{width:200px;height:200px}.hero-title{text-align:center;font-size:2.5rem}.hero-content{text-align:center;flex-direction:column;align-items:stretch;max-width:100%;display:flex}.hero-subtitle{font-size:1rem}.cta-buttons{flex-direction:column;width:100%}.cta-buttons .btn{text-align:center;box-sizing:border-box;width:100%}.fun-facts{padding:2rem 0}.fun-facts h2{font-size:2rem}.cta-section{padding:2rem 1rem}.cta-section h2{font-size:1.35rem}}@media (width<=480px){.home-page{gap:2rem}.hero-title{font-size:1.875rem}.hero-subtitle{font-size:.95rem}.facts-grid{grid-template-columns:1fr;gap:1.25rem}.btn{padding:.75rem 1.5rem;font-size:.9rem}.hero-sun .sun-clip{width:150px;height:150px}}@media (prefers-reduced-motion:reduce){.shooting-star,.hero-sun,.sun-clip,.sun-clip:before{animation:none!important}}.admin-page{text-align:left;max-width:1000px;margin:0 auto;padding:3rem 2rem}.admin-header{margin-bottom:2.5rem}.admin-title{background:linear-gradient(135deg,#646cff 0%,#0ea5e9 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 .5rem;font-size:2rem;font-weight:700}.admin-welcome{opacity:.7;margin:0;font-size:1rem}.admin-welcome span{opacity:1;color:var(--color-primary);font-weight:500}.admin-stats{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.25rem;margin-bottom:3rem;display:grid}.stat-card{background:var(--card-bg,#646cff0d);border:1px solid var(--card-border,#646cff1a);border-radius:12px;align-items:center;gap:1rem;padding:1.5rem;transition:all .3s;display:flex}.stat-card:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 8px 24px #646cff1a}.stat-icon{font-size:2rem;line-height:1}.stat-info{flex-direction:column;display:flex}.stat-value{font-size:1.75rem;font-weight:700;line-height:1}.stat-label{opacity:.6;text-transform:uppercase;letter-spacing:.5px;margin-top:.25rem;font-size:.8rem}:root[data-theme=dark] .stat-card,:root[data-theme=dark] .action-card{--card-bg:#646cff14;--card-border:#646cff26}:root[data-theme=light] .stat-card,:root[data-theme=light] .action-card{--card-bg:#646cff08;--card-border:#646cff1a}.stat-card--link{color:inherit;cursor:pointer;text-decoration:none}.analytics-section{margin-bottom:2rem}.analytics-title{text-transform:uppercase;letter-spacing:.8px;opacity:.5;margin:0 0 .75rem;font-size:.75rem;font-weight:600}.analytics-table{flex-direction:column;gap:.5rem;display:flex}.analytics-row{background:var(--card-bg,#646cff0d);border:1px solid var(--card-border,#646cff1a);border-radius:8px;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1rem;display:flex}.analytics-path{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-family:monospace;font-size:.875rem;overflow:hidden}.analytics-count{opacity:.6;flex-shrink:0;font-size:.82rem}.submissions-list{flex-direction:column;gap:1rem;display:flex}.submission-card{background:var(--card-bg,#646cff0d);border:1px solid var(--card-border,#646cff1a);color:inherit;border-radius:12px;flex-direction:column;gap:.75rem;padding:1.5rem;text-decoration:none;transition:all .2s;display:flex}.submission-card:hover{border-color:var(--color-primary);transform:translateY(-1px);box-shadow:0 6px 20px #646cff1a}.submission-card-header{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.submission-card-identity{flex-direction:column;gap:.2rem;display:flex}.submission-name{font-size:1rem;font-weight:600}.submission-email{opacity:.6;font-size:.85rem}.submission-company{opacity:.5;font-size:.85rem}.submission-card-badges{flex-wrap:wrap;gap:.5rem;display:flex}.submission-badge{color:var(--color-primary);background:#646cff1f;border-radius:999px;padding:.25rem .65rem;font-size:.78rem;font-weight:500}.submission-badge--budget{color:#0ea5e9;background:#0ea5e91f}.submission-badge--timeline{color:#10b981;background:#10b9811f}.submission-date{opacity:.5;white-space:nowrap;flex-shrink:0;font-size:.82rem}.empty-state{opacity:.5;padding:2rem 0;font-size:.95rem}.detail-card{background:var(--card-bg,#646cff0d);border:1px solid var(--card-border,#646cff1a);border-radius:12px;margin-bottom:1.25rem;padding:1.5rem}.detail-section-title{text-transform:uppercase;letter-spacing:.8px;opacity:.5;margin:0 0 1rem;font-size:.75rem;font-weight:600}.detail-field{align-items:baseline;gap:1rem;margin-bottom:.75rem;display:flex}.detail-field:last-child{margin-bottom:0}.detail-label{opacity:.5;flex-shrink:0;min-width:80px;font-size:.8rem}.detail-value{font-size:.95rem;font-weight:500}.detail-description{white-space:pre-wrap;margin:0;font-size:.95rem;line-height:1.6}.detail-actions{gap:1rem;margin-top:.5rem;display:flex}.admin-page .btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;padding:.625rem 1.5rem;font-family:inherit;font-size:.95rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.admin-page .btn-primary{background:var(--color-primary,#646cff);color:#fff}.admin-page .btn-primary:hover{opacity:.88;transform:translateY(-1px)}@media (width<=640px){.admin-page{padding:1.5rem 1rem}.admin-title{font-size:1.5rem}.admin-stats{grid-template-columns:1fr;gap:.75rem;margin-bottom:2rem}.stat-card{gap:.75rem;padding:1rem}.stat-icon{font-size:1.5rem}.stat-value{font-size:1.4rem}.submission-row{flex-direction:column;align-items:flex-start;padding:1rem}.submission-row-meta{justify-content:flex-start}.detail-field{flex-direction:column;gap:.2rem}.detail-label{min-width:unset}.detail-actions{flex-direction:column}.admin-page .btn{text-align:center;width:100%}}.confirm-dialog-backdrop{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:1rem;animation:.15s confirm-fade-in;display:flex;position:fixed;inset:0}@keyframes confirm-fade-in{0%{opacity:0}to{opacity:1}}.confirm-dialog{background:var(--color-card-bg);border:1px solid var(--color-card-border);border-radius:16px;width:100%;max-width:400px;padding:1.75rem;animation:.15s confirm-slide-up;box-shadow:0 20px 60px #0000004d}@keyframes confirm-slide-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.confirm-dialog-title{margin:0 0 .5rem;font-size:1.1rem;font-weight:600}.confirm-dialog-message{opacity:.7;margin:0 0 1.5rem;font-size:.92rem;line-height:1.5}.confirm-dialog-actions{justify-content:flex-end;gap:.75rem;display:flex}.confirm-dialog-cancel,.confirm-dialog-confirm{cursor:pointer;border-radius:8px;padding:.55rem 1.1rem;font-family:inherit;font-size:.88rem;font-weight:500;transition:background .2s,border-color .2s,transform .15s}.confirm-dialog-cancel{border:1px solid var(--color-border);color:inherit;background:0 0}.confirm-dialog-cancel:hover{background:#646cff0f;border-color:#646cff4d}.confirm-dialog-confirm{color:#ef4444;background:#ef44441f;border:1px solid #ef44444d}.confirm-dialog-confirm:hover{background:#ef444433;border-color:#ef444480;transform:translateY(-1px)}.recipes-page{max-width:800px;margin:0 auto;padding:3rem 2rem}.recipes-header{text-align:center;margin-bottom:2rem}.recipes-header h1{background:linear-gradient(135deg,#646cff 0%,#0ea5e9 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 .5rem;font-size:2rem;font-weight:700}.recipes-header p{opacity:.7;margin:0}.recipes-section{background:var(--color-card-bg);border:1px solid var(--color-card-border);border-radius:16px;margin-bottom:1.5rem;padding:2rem}.recipes-section h2{margin:0 0 1.25rem;font-size:1.25rem;font-weight:600}.recipes-section input,.recipes-section select{border:1px solid var(--color-border);color:inherit;box-sizing:border-box;background:#7c3aed0a;border-radius:10px;outline:none;width:100%;min-width:0;padding:.75rem 1rem;font-family:inherit;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.recipes-section input:focus,.recipes-section select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-nebula)}.preferences-form{flex-wrap:wrap;align-items:flex-end;gap:.75rem;margin-bottom:1.25rem;display:flex}.preferences-form-field{flex-direction:column;flex:1;gap:.35rem;min-width:140px;display:flex}.preferences-form-field label{opacity:.85;font-size:.85rem;font-weight:500}.preferences-form input{box-sizing:border-box;width:100%}.preferences-form select{width:auto;min-width:120px}.preferences-form button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#7c3aed 0%,#3b82f6 100%);border:none;border-radius:8px;padding:.75rem 1.25rem;font-family:inherit;font-size:.95rem;font-weight:600;transition:all .3s;box-shadow:0 6px 20px #7c3aed4d}.preferences-form button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 30px #7c3aed73}.preferences-form button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.preferences-list{flex-direction:column;gap:.5rem;display:flex}.preference-item{background:#646cff0d;border:1px solid #646cff1a;border-radius:8px;align-items:center;gap:.75rem;padding:.5rem .75rem;display:flex}.preference-badge{text-transform:capitalize;border-radius:999px;padding:.2rem .6rem;font-size:.75rem;font-weight:500}.preference-badge--like{color:#10b981;background:#10b9811f}.preference-badge--dislike{color:#ef4444;background:#ef44441f}.preference-badge--allergy{color:#f59e0b;background:#f59e0b1f}.preference-name{flex:1;font-size:.95rem}.preference-delete{cursor:pointer;opacity:.5;color:inherit;background:0 0;border:none;align-items:center;padding:.25rem;transition:opacity .2s;display:flex}.preference-delete:hover{opacity:1}.preferences-empty{opacity:.5;margin:0;padding:1rem 0;font-size:.9rem}.generator-form{flex-direction:column;gap:1rem;display:flex}.generator-form-row{align-items:flex-end;gap:1rem;display:flex}.generator-form-field{flex-direction:column;flex:1;gap:.35rem;min-width:0;display:flex}.generator-form-field label{opacity:.85;font-size:.85rem;font-weight:500}.generator-form-field input{box-sizing:border-box;width:100%}.generator-form-field--servings{flex:0 0 100px}.generator-form-field--servings input[type=number]{width:100%}.generator-form button[type=submit]{color:#fff;cursor:pointer;background:linear-gradient(135deg,#7c3aed 0%,#3b82f6 100%);border:none;border-radius:8px;width:100%;padding:.75rem 1.25rem;font-family:inherit;font-size:.95rem;font-weight:600;transition:all .3s;box-shadow:0 6px 20px #7c3aed4d}.generator-form button[type=submit]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 30px #7c3aed73}.generator-form button[type=submit]:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.output-tabs{background:#646cff0f;border-radius:10px;gap:.25rem;width:fit-content;margin-top:1.5rem;padding:.25rem;display:flex}.output-tabs--saved{margin-top:0;margin-bottom:1rem}.output-tab{color:inherit;opacity:.6;cursor:pointer;background:0 0;border:none;border-radius:8px;padding:.4rem .9rem;font-family:inherit;font-size:.85rem;font-weight:500;transition:opacity .2s,background .2s}.output-tab:hover{opacity:.85}.output-tab--active{opacity:1;background:#646cff1f}.recipe-generating{margin-top:1.5rem}.recipe-output{white-space:pre-wrap;background:#646cff0d;border:1px solid #646cff1a;border-radius:12px;margin-top:1.5rem;padding:1.5rem;font-size:.95rem;line-height:1.7}.recipe-cursor{background:var(--color-primary);vertical-align:text-bottom;border-radius:2px;width:8px;height:1em;margin-left:2px;animation:.8s step-end infinite blink;display:inline-block}@keyframes blink{50%{opacity:0}}.recipes-error{color:#ef4444;background:#ef444414;border:1px solid #ef444433;border-radius:8px;margin:0 0 1rem;padding:.75rem 1rem;font-size:.9rem}.recipes-fetch-error{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.recipes-fetch-error .recipes-error{flex:1;margin:0}.recipes-retry{color:#ef4444;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #ef44444d;border-radius:8px;padding:.5rem 1rem;font-family:inherit;font-size:.85rem;font-weight:500;transition:background .2s,border-color .2s}.recipes-retry:hover{background:#ef444414;border-color:#ef444480}.cooking-loader{flex-direction:column;align-items:center;padding:2.5rem 0;display:flex}.cooking-loader-pot{width:72px;height:64px;position:relative}.cooking-loader-body{background:linear-gradient(135deg,#7c3aed 0%,#3b82f6 100%);border-radius:4px 4px 16px 16px;width:52px;height:38px;position:absolute;bottom:0;left:10px;overflow:hidden}.cooking-loader-liquid{background:#ffffff2e;border-radius:0 0 14px 14px;height:60%;animation:1.8s ease-in-out infinite liquid-wobble;position:absolute;bottom:0;left:0;right:0}@keyframes liquid-wobble{0%,to{height:60%;transform:skew(-2deg)}50%{height:65%;transform:skew(2deg)}}.cooking-loader-lid{transform-origin:bottom;background:linear-gradient(135deg,#6d28d9 0%,#2563eb 100%);border-radius:8px 8px 2px 2px;width:60px;height:8px;animation:1.8s ease-in-out infinite lid-rattle;position:absolute;top:16px;left:6px}.cooking-loader-lid:after{content:"";background:#6d28d9;border-radius:6px 6px 0 0;width:12px;height:6px;position:absolute;top:-6px;left:50%;transform:translate(-50%)}@keyframes lid-rattle{0%,to{transform:translateY(0)rotate(0)}25%{transform:translateY(-3px)rotate(1.5deg)}50%{transform:translateY(0)rotate(0)}75%{transform:translateY(-4px)rotate(-1deg)}}.cooking-loader-handles{pointer-events:none;width:100%;position:absolute;bottom:14px;left:0}.cooking-loader-handles:before,.cooking-loader-handles:after{content:"";background:linear-gradient(135deg,#7c3aed 0%,#3b82f6 100%);border-radius:2px;width:10px;height:6px;position:absolute;top:0}.cooking-loader-handles:before{left:2px}.cooking-loader-handles:after{right:2px}.cooking-loader-steam{width:36px;height:20px;position:absolute;top:0;left:50%;transform:translate(-50%)}.cooking-loader-bubble{background:#7c3aed40;border-radius:50%;width:8px;height:8px;animation:1.6s ease-out infinite steam-rise;position:absolute;bottom:0}.cooking-loader-bubble:first-child{animation-delay:0s;left:4px}.cooking-loader-bubble:nth-child(2){animation-delay:.5s;left:14px}.cooking-loader-bubble:nth-child(3){animation-delay:1s;left:24px}@keyframes steam-rise{0%{opacity:0;transform:translateY(0)scale(.6)}20%{opacity:.6}to{opacity:0;transform:translateY(-28px)scale(1.2)}}.cooking-loader-text{opacity:.5;margin:1rem 0 0;font-size:.9rem;font-weight:500}:root[data-theme=dark] .cooking-loader-bubble{background:#a78bfa4d}:root[data-theme=dark] .recipes-section input,:root[data-theme=dark] .recipes-section select{background:#ffffff0a}:root[data-theme=dark] .recipes-section select option{background:#0f0f28}@media (width<=640px){.recipes-page{padding:1.5rem 1rem}.recipes-section{padding:1.5rem}.preferences-form{flex-direction:column}.generator-form-row{flex-direction:column;align-items:stretch}.generator-form-field--servings{flex:auto;width:100%}.recipes-header h1{font-size:1.5rem}}.recipes-tabs{border-bottom:1px solid var(--color-card-border);gap:0;margin-bottom:1.5rem;display:flex}.recipes-tab{color:inherit;opacity:.6;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.75rem 1.25rem;font-family:inherit;font-size:.95rem;font-weight:500;transition:opacity .2s,border-color .2s}.recipes-tab:hover{opacity:.85}.recipes-tab--active{opacity:1;border-bottom-color:var(--color-primary)}.recipes-subtabs{background:#646cff0f;border-radius:10px;gap:.25rem;margin-bottom:1.25rem;padding:.25rem;display:flex}.recipes-subtab{color:inherit;opacity:.6;cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:.55rem .9rem;font-family:inherit;font-size:.9rem;font-weight:500;transition:opacity .2s,background .2s}.recipes-subtab:hover{opacity:.85}.recipes-subtab--active{opacity:1;background:#646cff1f}@media (width>=640px){.recipes-subtabs{width:fit-content}.recipes-subtab{flex:none;min-width:7rem}}.saved-recipes-list{flex-direction:column;gap:.75rem;display:flex}.saved-recipe-card{background:#646cff0d;border:1px solid #646cff1a;border-radius:12px;transition:border-color .2s;overflow:hidden}.saved-recipe-card:hover{border-color:#646cff40}.saved-recipe-header{align-items:stretch;display:flex}.saved-recipe-toggle{min-width:0;color:inherit;font:inherit;text-align:left;cursor:pointer;-webkit-user-select:none;user-select:none;background:0 0;border:none;flex:1;justify-content:space-between;align-items:center;gap:.75rem;padding:1rem 1.25rem;display:flex}.saved-recipe-toggle:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px;border-radius:12px}.saved-recipe-info{flex-direction:column;gap:.25rem;min-width:0;display:flex}.saved-recipe-dish{text-overflow:ellipsis;white-space:nowrap;font-size:1rem;font-weight:600;overflow:hidden}.saved-recipe-meta{opacity:.6;gap:.75rem;font-size:.8rem;display:flex}.saved-recipe-servings{color:#7c3aed;background:#7c3aed1a;border-radius:999px;padding:.1rem .5rem;font-size:.75rem;font-weight:500}:root[data-theme=dark] .saved-recipe-servings{color:#a78bfa;background:#7c3aed33}.saved-recipe-owner{font-style:italic;font-weight:500}.saved-recipe-actions{flex-shrink:0;align-items:center;gap:.5rem;padding-right:1.25rem;display:flex}.saved-recipe-delete{color:#ef4444;cursor:pointer;background:0 0;border:1px solid #ef444440;border-radius:6px;padding:.3rem .7rem;font-family:inherit;font-size:.78rem;font-weight:500;transition:background .2s,border-color .2s}.saved-recipe-delete:hover{background:#ef444414;border-color:#ef444480}.saved-recipe-chevron{opacity:.5;transition:transform .2s}.saved-recipe-chevron--open{transform:rotate(180deg)}.saved-recipe-content{white-space:pre-wrap;border-top:1px solid #646cff1a;padding:1rem 1.25rem 1.25rem;font-size:.95rem;line-height:1.7}.shopping-list{flex-direction:column;gap:.15rem;margin:0;padding:0;list-style:none;display:flex}.shopping-list-category{text-transform:uppercase;letter-spacing:.04em;opacity:.5;padding:.6rem 0 .2rem;font-size:.75rem;font-weight:600}.shopping-list-category:first-child{padding-top:0}.shopping-list-item{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:6px;align-items:center;gap:.6rem;padding:.35rem .5rem;font-size:.9rem;transition:background .15s,opacity .2s;display:flex}.shopping-list-item:hover{background:#646cff0f}.shopping-list-checkbox{color:#7c3aed;border:1.5px solid #646cff4d;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;font-size:.7rem;font-weight:700;transition:background .15s,border-color .15s;display:flex}.shopping-list-item--checked .shopping-list-checkbox{background:#7c3aed1f;border-color:#7c3aed}.shopping-list-item--checked .shopping-list-label{opacity:.45;text-decoration:line-through}.recipe-banner{border-radius:8px;align-items:center;gap:.5rem;margin-top:1rem;padding:.75rem 1rem;font-size:.85rem;font-weight:500;display:flex}.recipe-banner--success{color:#10b981;background:#10b98114;border:1px solid #10b98133}.recipe-banner--info{color:#646cff;background:#646cff14;border:1px solid #646cff33}:root[data-theme=dark] .shopping-list-checkbox{color:#a78bfa;border-color:#a78bfa59}:root[data-theme=dark] .shopping-list-item--checked .shopping-list-checkbox{background:#a78bfa26;border-color:#a78bfa}:root[data-theme=dark] .recipe-banner--success{color:#34d399;background:#10b9811a;border-color:#10b98140}:root[data-theme=dark] .recipe-banner--info{color:#818cf8;background:#646cff1a;border-color:#646cff40}@media (width<=640px){.recipes-tab{padding:.6rem .75rem;font-size:.85rem}.saved-recipe-toggle{gap:.5rem;padding:.75rem 1rem}.saved-recipe-actions{padding-right:1rem}.saved-recipe-meta{flex-wrap:wrap;gap:.4rem .6rem}.saved-recipe-content{padding:0 1rem 1rem}}.covers-page{max-width:1100px}.covers-section{margin-bottom:2.5rem}.covers-section-title{text-transform:uppercase;letter-spacing:.8px;opacity:.5;margin:0 0 1rem;font-size:.75rem;font-weight:600}.covers-grid{grid-template-columns:repeat(3,1fr);gap:1.25rem;display:grid}.cover-card{background:var(--card-bg,#646cff0d);border:1px solid var(--card-border,#646cff1a);color:inherit;cursor:pointer;font:inherit;text-align:left;border-radius:12px;flex-direction:column;padding:0;text-decoration:none;transition:all .3s;display:flex;overflow:hidden}.cover-card:hover{border-color:var(--color-primary);transform:translateY(-3px);box-shadow:0 10px 30px #646cff1f}.cover-card-image-wrapper{background:#00000008;justify-content:center;align-items:center;width:100%;min-height:200px;display:flex;position:relative}.cover-card-image{object-fit:contain;width:100%;height:auto;display:block}.cover-card-info{justify-content:center;align-items:center;padding:.75rem 1rem;display:flex}.cover-card-name{font-size:.9rem;font-weight:600}:root[data-theme=dark] .cover-card{--card-bg:#646cff14;--card-border:#646cff26}:root[data-theme=dark] .cover-card-image-wrapper{background:#ffffff08}:root[data-theme=light] .cover-card{--card-bg:#646cff08;--card-border:#646cff1a}:root[data-theme=light] .cover-card-image-wrapper{background:#00000005}.cover-dialog-backdrop{z-index:1000;background:#000000bf;justify-content:center;align-items:center;padding:1rem;animation:.2s cover-fade-in;display:flex;position:fixed;inset:0}@keyframes cover-fade-in{0%{opacity:0}to{opacity:1}}.cover-dialog{background:var(--bg,#1a1a2e);border-radius:12px;flex-direction:column;max-width:95vw;max-height:95vh;animation:.2s cover-scale-in;display:flex;overflow:hidden;box-shadow:0 24px 64px #0006}@keyframes cover-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.cover-dialog-header{border-bottom:1px solid var(--card-border,#646cff26);flex-shrink:0;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.cover-dialog-title{margin:0;font-size:1rem;font-weight:600}.cover-dialog-close{color:inherit;cursor:pointer;opacity:.6;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:.25rem;transition:opacity .2s;display:flex}.cover-dialog-close:hover{opacity:1}.cover-dialog-header-right{align-items:center;gap:.75rem;display:flex}.cover-dialog-counter{opacity:.5;font-variant-numeric:tabular-nums;font-size:.8rem}.cover-dialog-body{flex:1;justify-content:center;align-items:center;min-height:0;display:flex;position:relative;overflow:auto}.cover-dialog-arrow{z-index:2;color:#fff;cursor:pointer;opacity:.7;background:#0006;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:opacity .2s,background .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.cover-dialog-arrow:hover{opacity:1;background:#0009}.cover-dialog-arrow--prev{left:.75rem}.cover-dialog-arrow--next{right:.75rem}.cover-dialog-image{object-fit:contain;max-width:100%;max-height:85vh;display:block}:root[data-theme=light] .cover-dialog{--bg:#fff}:root[data-theme=dark] .cover-dialog{--bg:#1a1a2e}@media (width<=900px){.covers-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=540px){.covers-grid{grid-template-columns:1fr;gap:1rem}.covers-page{padding:1.5rem 1rem}.cover-dialog-backdrop{padding:0}.cover-dialog{border-radius:0;width:100%;max-width:100vw;height:100%;max-height:100vh}.cover-dialog-image{max-height:90vh}}.league-selector{flex-wrap:wrap;gap:.5rem;margin-bottom:2rem;display:flex}.league-btn{border:1px solid var(--card-border,#646cff26);color:inherit;cursor:pointer;background:0 0;border-radius:999px;padding:.4rem .85rem;font-family:inherit;font-size:.82rem;font-weight:500;transition:all .2s}.league-btn:hover:not(:disabled){border-color:var(--color-primary);background:#646cff14}.league-btn--active{background:var(--color-primary,#646cff);color:#fff;border-color:var(--color-primary,#646cff)}.league-btn--active:hover:not(:disabled){background:var(--color-primary,#646cff);color:#fff}.league-btn:disabled{opacity:.5;cursor:not-allowed}.football-tabs{border-bottom:1px solid var(--card-border,#646cff26);gap:.5rem;margin-bottom:2rem;display:flex}.football-tab{color:inherit;cursor:pointer;opacity:.5;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.6rem 1.25rem;font-family:inherit;font-size:.875rem;font-weight:500;transition:all .2s}.football-tab:hover{opacity:.8}.football-tab--active{opacity:1;border-bottom-color:var(--color-primary,#646cff);color:var(--color-primary,#646cff)}.football-loading{justify-content:center;padding:3rem 0;display:flex}.football-loader{font-size:2.5rem;line-height:1;display:inline-block}@media (prefers-reduced-motion:no-preference){.football-loader{animation:.6s ease-in-out infinite alternate football-bounce}}.football-loader:before{content:"⚽"}@keyframes football-bounce{0%{animation-timing-function:ease-in;transform:translateY(0)}to{animation-timing-function:ease-out;transform:translateY(-18px)}}.football-section{margin-bottom:3rem}.football-section-title{text-transform:uppercase;letter-spacing:.8px;opacity:.5;margin:0 0 1rem;font-size:.75rem;font-weight:600}.results-list{flex-direction:column;gap:.75rem;display:flex}.result-card{background:var(--card-bg,#646cff0d);border:1px solid var(--card-border,#646cff1a);border-radius:12px;padding:1rem 1.25rem;transition:border-color .2s}.result-card:hover{border-color:var(--color-primary)}.result-round{opacity:.5;margin-bottom:.5rem;font-size:.75rem}.result-teams{justify-content:center;align-items:center;gap:1rem;display:flex}.result-team{flex:1;align-items:center;gap:.5rem;min-width:0;display:flex}.result-team--away{text-align:right;flex-direction:row-reverse}.result-team--winner .team-name{font-weight:700}.team-logo{object-fit:contain;flex-shrink:0;width:28px;height:28px}.team-logo--sm{width:20px;height:20px}.team-name{white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;overflow:hidden}.result-score{font-variant-numeric:tabular-nums;flex-shrink:0;align-items:center;gap:.25rem;font-size:1.5rem;font-weight:700;display:flex}.result-score-sep{opacity:.3}.fixture-vs{opacity:.4;font-size:.85rem;font-weight:500}.result-meta{opacity:.5;justify-content:space-between;margin-top:.5rem;font-size:.78rem;display:flex}.result-venue{text-align:right}.standings-table-wrapper{border:1px solid var(--card-border,#646cff1a);border-radius:12px;overflow-x:auto}.standings-table{border-collapse:collapse;width:100%;font-size:.875rem}.standings-table th{text-transform:uppercase;letter-spacing:.5px;opacity:.5;text-align:left;border-bottom:1px solid var(--card-border,#646cff1a);white-space:nowrap;padding:.75rem .5rem;font-size:.7rem;font-weight:600}.standings-table td{border-bottom:1px solid var(--card-border,#646cff0d);white-space:nowrap;padding:.6rem .5rem}.standings-table tbody tr:hover{background:var(--card-bg,#646cff0d)}.standings-table tbody tr:last-child td{border-bottom:none}.col-rank{opacity:.6;width:2rem;font-weight:600;text-align:center!important}.col-team{align-items:center;gap:.5rem;display:flex}.col-num{font-variant-numeric:tabular-nums;text-align:center!important}.col-pts{font-weight:700}.col-form{min-width:90px}.form-badges{gap:3px;display:flex}.form-badge{color:#fff;border-radius:4px;justify-content:center;align-items:center;width:18px;height:18px;font-size:.65rem;font-weight:700;display:inline-flex}.form-badge--win{background:#22c55e}.form-badge--draw{background:#a3a3a3}.form-badge--loss{background:#ef4444}.team-badge-link{border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;padding:2px;text-decoration:none;transition:opacity .15s,transform .15s;display:inline-flex}.team-badge-link:hover{opacity:.75;transform:scale(1.15)}.team-badge-placeholder{background:var(--card-border,#646cff26);border-radius:4px;justify-content:center;align-items:center;width:20px;height:20px;font-size:.7rem;font-weight:700;display:inline-flex}@media (width<=640px){.hide-mobile{display:none}.result-teams{gap:.5rem}.team-name{font-size:.85rem}.result-score{font-size:1.25rem}.team-logo{width:22px;height:22px}.standings-table{font-size:.8rem}.standings-table th,.standings-table td{padding:.5rem .35rem}}.result-card-link{color:inherit;text-decoration:none;display:block}.result-card-link .result-card{cursor:pointer}.standings-team-link{color:inherit;align-items:center;gap:.5rem;text-decoration:none;transition:opacity .15s;display:flex}.standings-team-link:hover{opacity:.7}.squad-sections{flex-direction:column;gap:2.5rem;display:flex}.squad-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem;display:grid}.player-card{background:var(--card-bg,#646cff0d);border:1px solid var(--card-border,#646cff1a);border-radius:10px;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.player-jersey{font-variant-numeric:tabular-nums;text-align:center;opacity:.4;flex-shrink:0;min-width:1.75rem;font-size:1rem;font-weight:700}.player-info{flex-direction:column;gap:.2rem;min-width:0;display:flex}.player-name{white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:500;overflow:hidden}.player-meta{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.player-flag{object-fit:contain;border-radius:2px;flex-shrink:0;width:16px;height:16px}.player-nationality{opacity:.55;font-size:.75rem}.player-age{opacity:.4;font-size:.75rem}.player-age:before{content:"·";margin-right:.4rem}@media (width<=640px){.squad-grid{grid-template-columns:1fr 1fr}.player-card{padding:.6rem .75rem}}.match-detail-page{max-width:700px}.match-header{background:var(--card-bg,#646cff0d);border:1px solid var(--card-border,#646cff1a);border-radius:16px;justify-content:center;align-items:center;gap:2rem;margin-bottom:2rem;padding:2rem 1.5rem;display:flex}.match-header-team{flex-direction:column;flex:1;align-items:center;gap:.75rem;min-width:0;display:flex}.match-header-logo{object-fit:contain;width:64px;height:64px}.match-header-placeholder{background:var(--card-border,#646cff26);border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;font-size:1.5rem;font-weight:700;display:flex}.match-header-badge-link{transition:opacity .15s;display:flex}.match-header-badge-link:hover{opacity:.7}.match-header-team-name{text-align:center;color:inherit;font-size:1rem;font-weight:600;text-decoration:none;transition:opacity .15s}.match-header-team-name:hover{opacity:.7}.match-header-score{flex-direction:column;flex-shrink:0;align-items:center;gap:.25rem;display:flex}.match-header-score-value{font-variant-numeric:tabular-nums;letter-spacing:.05em;font-size:2.5rem;font-weight:700}.match-header-date{opacity:.5;text-align:center;font-size:.78rem}.match-header-venue{opacity:.4;text-align:center;font-size:.75rem}.match-section{margin-bottom:2rem}.match-section-title{text-transform:uppercase;letter-spacing:.8px;opacity:.5;margin:0 0 1rem;font-size:.75rem;font-weight:600}.match-goals{flex-direction:column;gap:.5rem;display:flex}.match-goal{background:var(--card-bg,#646cff0d);border:1px solid var(--card-border,#646cff1a);border-radius:10px;align-items:center;gap:.75rem;padding:.65rem 1rem;display:flex}.match-goal--away{text-align:right;flex-direction:row-reverse}.match-goal-minute{opacity:.6;font-variant-numeric:tabular-nums;flex-shrink:0;min-width:2.5rem;font-size:.82rem;font-weight:700}.match-goal--away .match-goal-minute{text-align:right}.match-goal-info{flex-direction:column;gap:.1rem;min-width:0;display:flex}.match-goal-scorer{font-size:.92rem;font-weight:600}.match-goal-og{opacity:.6;margin-left:.4rem;font-size:.78rem;font-weight:500}.match-goal-assist{opacity:.5;font-size:.78rem}.match-stats{flex-direction:column;gap:1rem;display:flex}.match-stat-row{align-items:center;gap:.75rem;display:flex}.match-stat-value{font-variant-numeric:tabular-nums;flex-shrink:0;width:3rem;font-size:.88rem;font-weight:600}.match-stat-value--home{text-align:right}.match-stat-value--away{text-align:left}.match-stat-center{flex-direction:column;flex:1;align-items:center;gap:.3rem;display:flex}.match-stat-label{opacity:.5;text-transform:uppercase;letter-spacing:.3px;font-size:.72rem;font-weight:500}.match-stat-bar{border-radius:3px;gap:2px;width:100%;height:6px;display:flex;overflow:hidden}.match-stat-bar-home{background:var(--color-primary,#646cff);border-radius:3px 0 0 3px;height:100%;transition:width .3s}.match-stat-bar-away{background:#646cff33;border-radius:0 3px 3px 0;height:100%;transition:width .3s}.match-header-vs{opacity:.5;text-transform:uppercase;letter-spacing:.05em;font-size:1.5rem;font-weight:700}.lineups-grid{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}.lineup-team-name{align-items:center;gap:.5rem;margin:0 0 .75rem;font-size:.88rem;font-weight:600;display:flex}.lineup-formation{opacity:.5;font-size:.78rem;font-weight:500}.lineup-players{flex-direction:column;gap:.35rem;display:flex}.lineup-player{background:var(--card-bg,#646cff0d);border:1px solid var(--card-border,#646cff1a);border-radius:8px;align-items:center;gap:.5rem;padding:.45rem .75rem;font-size:.85rem;display:flex}.lineup-jersey{font-variant-numeric:tabular-nums;opacity:.6;min-width:1.5rem;font-weight:700}.lineup-player-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:500;overflow:hidden}.lineup-position{opacity:.45;text-transform:uppercase;flex-shrink:0;font-size:.72rem;font-weight:500}.injuries-grid{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}.injuries-team-name{margin:0 0 .75rem;font-size:.88rem;font-weight:600}.injuries-list{flex-direction:column;gap:.35rem;display:flex}.injury-row{background:var(--card-bg,#646cff0d);border:1px solid var(--card-border,#646cff1a);border-radius:8px;justify-content:space-between;align-items:center;gap:.5rem;padding:.45rem .75rem;font-size:.85rem;display:flex}.injury-player{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-weight:500;overflow:hidden}.injury-details{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.injury-status{text-transform:uppercase;color:var(--color-danger,#ff5050);background:#ff50501f;border-radius:4px;padding:.15rem .45rem;font-size:.72rem;font-weight:600}.injury-detail{opacity:.5;font-size:.75rem}@media (width<=640px){.match-header{gap:1rem;padding:1.25rem 1rem}.match-header-logo{width:44px;height:44px}.match-header-placeholder{width:44px;height:44px;font-size:1.1rem}.match-header-team-name{font-size:.85rem}.match-header-score-value{font-size:1.75rem}.match-stat-value{width:2.5rem;font-size:.8rem}.match-goal{padding:.5rem .75rem}.lineups-grid,.injuries-grid{grid-template-columns:1fr;gap:1.25rem}}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}:root,:root[data-theme=light]{color:#1e1b4b;--color-primary:#7c3aed;--color-primary-hover:#6d28d9;--color-text:#1e1b4b;--color-bg:#f0f0ff;--color-border:#c7d2fe;--color-glow:#7c3aed66;--color-nebula:#3b82f626;--color-star:#a78bfa;--color-card-bg:#ffffffb3;--color-card-border:#7c3aed26;background-color:#f0f0ff}:root[data-theme=dark],:root.dark{color:#e6e6ffeb;--color-primary:#a78bfa;--color-primary-hover:#8b5cf6;--color-text:#e6e6ffeb;--color-bg:#060714;--color-border:#a78bfa33;--color-glow:#8b5cf680;--color-nebula:#3b82f61a;--color-star:#c4b5fd;--color-card-bg:#0f0f2899;--color-card-border:#a78bfa26;background-color:#060714}a{color:var(--color-primary);-webkit-text-decoration:inherit;text-decoration:inherit;font-weight:500}a:hover{color:var(--color-primary-hover)}body{min-width:320px;min-height:100vh;margin:0}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}h1{font-size:3.2em;line-height:1.1}button{color:inherit;cursor:pointer;background-color:#f9f9f9;border:1px solid #0000;border-radius:8px;padding:.6em 1.2em;font-family:inherit;font-size:1em;font-weight:500;transition:border-color .25s}:root[data-theme=dark] button,:root.dark button{background-color:#0f0f28cc}button:hover{border-color:var(--color-primary)}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}
