:root{--color-ink:#030712;--color-board:#111638;--color-panel:rgba(6,9,31,.88);--color-grid-line:hsla(0,0%,100%,.08);--color-highlight:#facc15;--color-primary:#4ade80;--color-secondary:#38bdf8;--color-tertiary:#f472b6;--color-accent:#f97316;--block-vidrio:#34f5c5;--block-papel:#60a5fa;--block-metal:#fcd34d;--block-aceite:#fb923c;--block-envases:#c084fc;--font-display:"Space Grotesk","Rajdhani","Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--shadow-panel:0 20px 60px rgba(3,7,18,.45)}*,:after,:before{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:var(--font-display);background:radial-gradient(circle at 20% 20%,#1e3a8a 0,#111827 35%) fixed,linear-gradient(120deg,#0f172a,#030712) fixed;color:#f8fafc;line-height:1.5;overflow-x:hidden}body:before{background-image:linear-gradient(var(--color-grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--color-grid-line) 1px,transparent 1px),radial-gradient(circle at 10% 20%,rgba(250,204,21,.15),transparent 45%),radial-gradient(circle at 80% 10%,rgba(56,189,248,.2),transparent 40%);background-size:40px 40px,40px 40px,auto,auto;z-index:-2}body:after,body:before{content:"";position:fixed;inset:0}body:after{background:radial-gradient(circle,rgba(15,118,110,.25),transparent 60%);mix-blend-mode:lighten;z-index:-1}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-shell__content{flex:1 1;display:flex;flex-direction:column}.skip-link{position:absolute;top:.5rem;left:.5rem;padding:.5rem 1rem;border-radius:999px;background:#f8fafc;color:#030712;font-weight:600;transform:translateY(-120%);transition:transform .2s ease;z-index:1000}.skip-link:focus{transform:translateY(0);outline:2px solid var(--color-secondary)}a{color:inherit}:focus-visible{outline:3px solid var(--color-secondary);outline-offset:3px}.site-footer{background:rgba(9,12,32,.95);border-top:1px solid hsla(0,0%,100%,.08);padding:1.5rem 2rem;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.25rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.site-footer--inline{border-radius:24px;border:1px solid hsla(0,0%,100%,.12);margin-top:2rem;padding:1.5rem}.site-footer__brand{display:flex;align-items:center;gap:.75rem}.site-footer__logo{border-radius:8px;box-shadow:0 8px 18px rgba(3,7,18,.45)}.site-footer__title{margin:0;font-size:1rem}.site-footer__subtitle{margin:0;font-size:.85rem;color:rgba(248,250,252,.65)}.site-footer__links{display:flex;gap:1.5rem;flex-wrap:wrap;font-size:.9rem}.site-footer__links a{color:rgba(248,250,252,.85);text-decoration:none;transition:color .15s ease}.site-footer__links a:hover{color:var(--color-secondary)}.auth-nav{margin-bottom:2rem}.auth-nav__links{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}.auth-nav__link{padding:.45rem 1.4rem;border-radius:999px;border:1px solid rgba(248,250,252,.3);color:rgba(248,250,252,.85);text-decoration:none;font-weight:600;transition:border .16s ease,color .16s ease,background .16s ease}.auth-nav__link:hover{border-color:rgba(248,250,252,.6)}.auth-nav__link--active{border-color:rgba(248,250,252,.85);color:#f8fafc;background:rgba(56,189,248,.12)}.auth-nav__link--back{border-color:var(--color-primary);color:var(--color-primary);background:rgba(74,222,128,.1)}.auth-nav__link--back:hover{border-color:var(--color-primary);background:rgba(74,222,128,.2)}.auth-nav__loading{color:rgba(248,250,252,.5);padding:.45rem 1rem}.leaderboard-callout{display:flex;justify-content:space-between;align-items:center;gap:1rem}.leaderboard-button{border:none;border-radius:999px;padding:.65rem 1.5rem;font-weight:600;background:linear-gradient(120deg,var(--color-primary),var(--color-secondary));color:#030712;border:2px solid rgba(3,7,18,.3);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.leaderboard-button:hover{transform:translateY(-1px);box-shadow:0 12px 25px rgba(56,189,248,.35)}.leaderboard-shell{max-width:1100px;margin:0 auto;padding:clamp(1.5rem,4vw,3rem) 1.5rem 3rem;display:flex;flex-direction:column;gap:1.5rem}.leaderboard-hero{background:var(--color-panel);border-radius:28px;padding:clamp(1.5rem,4vw,2.5rem);border:1px solid hsla(0,0%,100%,.1);box-shadow:var(--shadow-panel)}.leaderboard-hero__eyebrow{text-transform:uppercase;letter-spacing:.25em;font-size:.75rem;color:rgba(248,250,252,.6)}.leaderboard-hero h1{margin:.5rem 0;font-size:clamp(1.8rem,5vw,2.6rem)}.leaderboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));grid-gap:1rem;gap:1rem}.leaderboard-card{background:rgba(9,12,32,.9);border-radius:24px;border:1px solid hsla(0,0%,100%,.08);padding:1.25rem;display:flex;flex-direction:column;gap:.75rem}.leaderboard-card header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid hsla(0,0%,100%,.08);padding-bottom:.75rem}.leaderboard-card header div{display:flex;align-items:center;gap:.5rem}.leaderboard-card header span{width:12px;height:12px;border-radius:4px;display:inline-block}.leaderboard-card header h2{margin:0;font-size:1rem}.leaderboard-card header p{margin:0;font-size:.85rem;color:rgba(248,250,252,.88)}.leaderboard-card ol{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.leaderboard-card li{display:grid;grid-template-columns:auto 1fr auto;grid-gap:.75rem;gap:.75rem;align-items:center}.leaderboard-position{width:32px;height:32px;border-radius:999px;border:1px solid hsla(0,0%,100%,.15);display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem}.leaderboard-card li p{margin:0;font-weight:600}.leaderboard-card li small{color:rgba(248,250,252,.82)}.leaderboard-card li strong{font-size:1rem}.leaderboard-card__empty{margin:0;color:rgba(248,250,252,.88);font-style:italic}.star-progress__head{display:flex;justify-content:space-between;gap:1rem;align-items:center;margin-bottom:1rem}.star-progress__eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;color:rgba(248,250,252,.6);margin:0 0 .35rem}.star-progress__summary{text-align:right}.star-progress__summary span{display:block;font-size:.85rem;color:rgba(248,250,252,.65)}.star-progress__summary strong{display:block;font-size:1.8rem;color:var(--color-primary)}.star-progress__summary small{font-size:.8rem;color:rgba(248,250,252,.85)}.star-lab--dashboard{background:rgba(9,12,32,.8);border-radius:24px;padding:1.5rem;border:1px solid hsla(0,0%,100%,.08);box-shadow:0 20px 45px rgba(3,7,18,.45);margin-bottom:1rem}.star-lab--complete .star-assembly{animation:starOrbit 12s linear infinite}.star-block--inactive{filter:grayscale(1);opacity:.3;animation:none}.star-progress__note{margin:0;text-align:center;font-size:.9rem;color:rgba(248,250,252,.9)}.star-progress__legend{list-style:none;margin:1rem 0 0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:.75rem;gap:.75rem}.star-progress__legend li{display:grid;grid-template-columns:auto 1fr;grid-gap:.75rem;gap:.75rem;align-items:center;background:rgba(9,12,32,.7);border-radius:16px;padding:.65rem .75rem;border:1px solid hsla(0,0%,100%,.08)}.star-progress__legend span{width:30px;height:30px;border-radius:10px;box-shadow:0 8px 20px rgba(0,0,0,.35)}.star-progress__legend p{margin:0;font-weight:600}.star-progress__legend small{color:rgba(248,250,252,.82)}@keyframes starOrbit{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.star-assembly,.star-block,.star-block--active,.star-lab,.star-lab--complete{animation:none!important}.btn,.btn-action,.btn-primary,.leaderboard-button,.recycling-graph__loading span,.star-game__loading span,.wallet-copy:hover{transition:none!important}}.home-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:4rem 1.5rem 5rem}.hero-panel{width:min(1100px,100%);background:var(--color-panel);border:1px solid hsla(0,0%,100%,.08);border-radius:36px;box-shadow:var(--shadow-panel);display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:2.5rem;gap:2.5rem;padding:clamp(2rem,4vw,3.5rem);position:relative;overflow:hidden}.hero-panel:before{content:"";position:absolute;top:-35%;right:-15%;width:350px;height:350px;background:conic-gradient(from 90deg,var(--color-primary),var(--color-secondary),var(--color-tertiary),var(--color-accent),var(--color-primary));opacity:.25;filter:blur(25px);z-index:0}.hero-copy,.hero-insights{position:relative;z-index:1}.hero-insights{display:flex;flex-direction:column;gap:1.5rem}.auth-shell{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:clamp(1rem,2vw,2rem)}.auth-panel{width:min(440px,100%);background:rgba(9,12,32,.9);border-radius:28px;padding:clamp(1.5rem,3vw,2rem);border:1px solid hsla(0,0%,100%,.08);box-shadow:0 25px 65px rgba(2,6,23,.65);display:flex;flex-direction:column;gap:1rem}.auth-heading{text-align:center}.auth-heading h1{margin:0;font-size:1.5rem}.auth-heading p{margin:.25rem 0 0;color:rgba(248,250,252,.7);font-size:.9rem}.auth-form{gap:.75rem}.auth-field,.auth-form{display:flex;flex-direction:column}.auth-field{gap:.2rem}.auth-label{font-size:.875rem;color:rgba(248,250,252,.85)}.auth-input{border-radius:10px;border:1px solid rgba(148,163,184,.4);background:rgba(15,23,42,.85);color:#f8fafc;padding:.6rem .85rem;font-size:.95rem;transition:border .16s ease,box-shadow .16s ease}select.auth-input{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394a3b8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.25rem;cursor:pointer;max-height:42px}select.auth-input:disabled{opacity:.5;cursor:not-allowed;background-color:rgba(15,23,42,.5)}select.auth-input option{background:#0f172a;color:#f8fafc;padding:.5rem}.auth-input:focus{border-color:var(--color-secondary);outline:none;box-shadow:0 0 0 3px rgba(56,189,248,.25)}.auth-button{border:none;border-radius:999px;padding:.7rem;background:linear-gradient(120deg,var(--color-primary),var(--color-secondary));color:#030712;border:2px solid rgba(3,7,18,.25);font-weight:700;font-size:.95rem;cursor:pointer;margin-top:.25rem;transition:transform .2s ease,box-shadow .2s ease}.auth-button:disabled{opacity:.65;cursor:not-allowed;border-color:rgba(3,7,18,.35)}.auth-button:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 18px 40px rgba(59,130,246,.35)}.auth-error{background:hsla(0,91%,71%,.25);border:1px solid hsla(0,91%,71%,.6);color:#fee2e2;border-radius:16px;padding:.85rem 1rem;text-align:center;font-weight:500}.auth-link{text-align:center;color:rgba(248,250,252,.8);font-size:.85rem;margin-top:.25rem}.auth-link a{color:var(--color-secondary);font-weight:600;text-decoration:none}.auth-link a:hover{text-decoration:underline}.auth-consents{border:1px solid rgba(148,163,184,.25);border-radius:12px;padding:1rem;margin:0;display:flex;flex-direction:column;gap:.75rem}.auth-consents legend{padding:0 .5rem;font-weight:600;font-size:.95rem;color:rgba(248,250,252,.9)}.auth-consent-item{display:flex;align-items:flex-start;gap:.6rem;cursor:pointer;font-size:.875rem;color:rgba(248,250,252,.85)}.auth-consent-item input[type=checkbox]{width:18px;height:18px;margin-top:2px;accent-color:var(--color-primary);cursor:pointer;flex-shrink:0}.auth-consent-item span{line-height:1.4}.auth-consent-note{margin:.5rem 0 0;font-size:.8rem;color:rgba(248,250,252,.6);font-style:italic}.home-tag{display:inline-flex;align-items:center;gap:.4rem;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;background:rgba(250,204,21,.15);color:var(--color-highlight);padding:.35rem .9rem;border-radius:999px;border:1px solid rgba(250,204,21,.3)}.home-title{font-size:clamp(2.5rem,5vw,3.75rem);margin:1rem 0;line-height:1.1;font-weight:700}.home-lead{color:rgba(248,250,252,.8);font-size:1.15rem;margin-bottom:2rem;max-width:45ch}.home-cta{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.75rem}.btn{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;border-radius:999px;padding:.85rem 1.85rem;font-weight:600;transition:transform .22s ease,box-shadow .22s ease,color .22s ease,background .22s ease;border:1px solid transparent}.btn-primary{background:linear-gradient(120deg,var(--color-primary),var(--color-secondary));color:#030712;border:2px solid rgba(3,7,18,.25);box-shadow:0 15px 40px rgba(59,130,246,.35)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px rgba(59,130,246,.45)}.btn-ghost{background:transparent;border-color:rgba(248,250,252,.6);color:#fefefe}.btn-ghost:hover{border-color:#fff;background:hsla(0,0%,100%,.08);transform:translateY(-2px)}.home-footnote{font-size:.9rem;color:rgba(248,250,252,.75)}.star-lab{background:rgba(15,23,42,.92);border-radius:1.75rem;padding:1.5rem;border:1px solid rgba(148,163,184,.3);box-shadow:0 20px 45px rgba(2,6,23,.55)}.star-lab__head{margin-bottom:1.25rem}.star-lab__label{font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(248,250,252,.65);margin-bottom:.35rem}.star-lab__head h2{margin:0 0 .35rem;font-size:1.4rem}.star-lab__head p{margin:0;color:rgba(248,250,252,.75)}.star-assembly{position:relative;width:min(260px,80vw);height:min(260px,80vw);margin:0 auto 1.25rem}.star-outline{position:absolute;inset:5%;border:2px dashed rgba(248,250,252,.2);-webkit-clip-path:polygon(50% 0,61% 35%,98% 35%,68% 57%,79% 91%,50% 72%,21% 91%,32% 57%,2% 35%,39% 35%);clip-path:polygon(50% 0,61% 35%,98% 35%,68% 57%,79% 91%,50% 72%,21% 91%,32% 57%,2% 35%,39% 35%);border-radius:12px;animation:outlinePulse 6s ease-in-out infinite;pointer-events:none}.star-block{position:absolute;top:50%;left:50%;width:54px;height:54px;border-radius:14px;background:var(--block-color,var(--color-primary));box-shadow:0 16px 35px rgba(3,7,18,.45);transform:translate(calc(-50% + var(--tx, 0px)),calc(-50% + var(--ty, 0px))) scale(1);opacity:.25;animation:none}.star-block:after{content:"";position:absolute;inset:15%;border-radius:12px;background:hsla(0,0%,100%,.15);mix-blend-mode:screen}.star-block--vidrio{--block-color:var(--block-vidrio);--tx:0px;--ty:-110px}.star-block--papel{--block-color:var(--block-papel);--tx:95px;--ty:-20px}.star-block--metal{--block-color:var(--block-metal);--tx:58px;--ty:95px}.star-block--aceite{--block-color:var(--block-aceite);--tx:-58px;--ty:95px}.star-block--envases{--block-color:var(--block-envases);--tx:-95px;--ty:-20px}.star-block--active{opacity:1}.star-lab--complete .star-block--active{animation:assembleStar 6s ease-in-out infinite alternate;animation-fill-mode:both}.star-legend{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.9rem}.star-legend li{display:grid;grid-template-columns:auto 1fr;grid-gap:.85rem;gap:.85rem;align-items:start}.legend-swatch{width:30px;height:30px;border-radius:10px;box-shadow:0 8px 20px rgba(0,0,0,.35)}.legend-label{font-weight:600;margin:0}.legend-description{color:rgba(248,250,252,.7);margin:.15rem 0 0;font-size:.9rem}.hero-cards{display:grid;grid-gap:1rem;gap:1rem;position:relative;z-index:1}.tetris-card{background:rgba(15,23,42,.85);border-radius:1.5rem;padding:1.5rem;border:1px solid rgba(148,163,184,.2);position:relative;overflow:hidden}.tetris-card:before{content:"";position:absolute;top:1rem;right:1rem;width:70px;height:70px;background-image:linear-gradient(var(--color-grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--color-grid-line) 1px,transparent 1px);background-size:16px 16px;opacity:.35}.tetris-card__score{font-size:.9rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(248,250,252,.65);margin-bottom:.6rem}.tetris-card__title{font-size:1.25rem;margin-bottom:.35rem}.tetris-card__body{color:rgba(248,250,252,.75);font-size:.95rem}@keyframes assembleStar{0%{opacity:0;transform:translate(-50%,-50%) scale(.2)}40%{opacity:.9;transform:translate(-50%,-50%) scale(.75)}to{opacity:1;transform:translate(calc(-50% + var(--tx, 0px)),calc(-50% + var(--ty, 0px))) scale(1)}}@keyframes outlinePulse{0%{opacity:.4;transform:scale(.95)}50%{opacity:.9;transform:scale(1)}to{opacity:.4;transform:scale(.95)}}.auth-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:.75rem;gap:.75rem}.auth-panel--wide{width:min(520px,100%)}.dashboard-shell{min-height:100vh}.dashboard-header{background:rgba(9,12,32,.95);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid hsla(0,0%,100%,.08);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.dashboard-logo{margin:0;font-size:1.5rem;background:linear-gradient(120deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dashboard-logo a{color:inherit;text-decoration:none;-webkit-text-fill-color:inherit}.dashboard-user{display:flex;align-items:center;gap:1rem}.dashboard-user span{color:rgba(248,250,252,.85)}.dashboard-logout{padding:.5rem 1rem;background:transparent;border:1px solid rgba(248,250,252,.3);border-radius:8px;color:#f8fafc;cursor:pointer;transition:all .2s ease}.dashboard-logout:hover{border-color:var(--color-accent);color:var(--color-accent)}.dashboard-content{max-width:1100px;margin:0 auto;padding:2rem}.dashboard-section{background:rgba(9,12,32,.85);border:1px solid hsla(0,0%,100%,.08);border-radius:20px;padding:1.5rem;margin-bottom:1.5rem}.dashboard-section h2{margin:0 0 .5rem;font-size:1.35rem}.dashboard-section h3{margin:0 0 .75rem;font-size:1.1rem;color:rgba(248,250,252,.9)}.dashboard-section p{margin:0;color:rgba(248,250,252,.7)}.wallet-card{background:linear-gradient(135deg,#22c55e,#4ade80 50%,#34d399);border-radius:24px;padding:2px;margin-bottom:1.5rem;box-shadow:0 20px 50px rgba(74,222,128,.35)}.wallet-card__content{background:linear-gradient(145deg,rgba(22,101,52,.97),rgba(21,128,61,.95));border-radius:22px;padding:1.5rem;display:grid;grid-template-columns:auto 1fr;grid-gap:1.5rem;gap:1.5rem;align-items:center}.wallet-card__qr-section{position:relative}.wallet-card__qr{background:#fff;border-radius:16px;padding:.75rem;overflow:hidden;box-shadow:0 0 20px rgba(74,222,128,.5),0 0 40px rgba(74,222,128,.3),0 0 60px rgba(74,222,128,.15);animation:qr-glow 2s ease-in-out infinite alternate}@keyframes qr-glow{0%{box-shadow:0 0 20px rgba(74,222,128,.5),0 0 40px rgba(74,222,128,.3),0 0 60px rgba(74,222,128,.15)}to{box-shadow:0 0 25px rgba(74,222,128,.7),0 0 50px rgba(74,222,128,.45),0 0 75px rgba(74,222,128,.25)}}.wallet-card__qr svg{display:block;border-radius:8px}.wallet-card__qr--loading{width:160px;height:160px;display:flex;align-items:center;justify-content:center;color:hsla(0,0%,100%,.5)}.wallet-card__info{display:flex;flex-direction:column;gap:.5rem}.wallet-card__label{text-transform:uppercase;letter-spacing:.15em;font-size:.7rem;color:hsla(0,0%,100%,.6);font-weight:500}.wallet-card__title{margin:0;font-size:1.4rem;color:#fff;font-weight:700}.wallet-card__hint{margin:0;font-size:.9rem;color:hsla(0,0%,100%,.75);max-width:280px}.wallet-card__code-box{display:flex;align-items:center;gap:.75rem;background:rgba(0,0,0,.25);border-radius:12px;padding:.75rem 1rem;margin-top:.5rem}.wallet-card__code{font-family:JetBrains Mono,Fira Code,monospace;font-size:.85rem;color:hsla(0,0%,100%,.9);flex:1 1}.wallet-card__copy{padding:.5rem 1rem;background:hsla(0,0%,100%,.15);border:1px solid hsla(0,0%,100%,.3);border-radius:8px;color:#fff;font-weight:600;font-size:.8rem;cursor:pointer;transition:all .2s ease;white-space:nowrap}.wallet-card__copy:hover{background:hsla(0,0%,100%,.25);border-color:hsla(0,0%,100%,.5)}@media (max-width:640px){.wallet-card__content{grid-template-columns:1fr;justify-items:center;text-align:center}.wallet-card__hint{max-width:100%}.wallet-card__code-box{flex-direction:column;gap:.5rem}.wallet-card__copy{width:100%}}.wallet-box{display:flex;align-items:center;gap:.75rem;background:rgba(74,222,128,.1);border:1px solid var(--color-primary);border-radius:14px;padding:1rem;width:100%}.wallet-code{font-family:JetBrains Mono,Fira Code,monospace;font-size:.9rem;flex:1 1;word-break:break-all;color:var(--color-primary)}.wallet-copy{padding:.5rem 1rem;background:var(--color-primary);color:#030712;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:.875rem;white-space:nowrap;transition:transform .2s ease}.wallet-copy:hover{transform:scale(1.02)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:2rem}.stat-card{background:rgba(15,23,42,.7);border:1px solid hsla(0,0%,100%,.06);border-radius:16px;padding:1.25rem;text-align:center}.stat-card h3{margin:0;font-size:2rem;background:linear-gradient(120deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-card p{margin:.6rem 0 0;font-size:.9rem;color:rgba(248,250,252,.65)}.credentials-header{display:flex;align-items:flex-start;gap:1rem;justify-content:space-between}.settings-button{border:1px solid rgba(248,250,252,.35);background:rgba(15,23,42,.8);color:rgba(248,250,252,.85);border-radius:50%;width:48px;height:48px;font-size:1.2rem;cursor:pointer;transition:border .2s ease,transform .2s ease}.settings-button:hover{border-color:var(--color-secondary);transform:rotate(10deg)}.settings-panel{margin-top:1rem;padding:1rem;border-radius:16px;border:1px solid rgba(148,163,184,.3);background:rgba(6,11,42,.8);display:flex;flex-direction:column;gap:.75rem}.settings-panel__warning{margin:0;font-size:.9rem;color:rgba(250,204,21,.85)}.settings-panel__form{display:flex;flex-direction:column;gap:.5rem}.settings-panel__form label{font-size:.85rem;color:rgba(248,250,252,.8)}.settings-panel__form input{border-radius:10px;border:1px solid rgba(148,163,184,.4);background:rgba(15,23,42,.85);color:#f8fafc;padding:.6rem .85rem;font-size:.95rem}.settings-panel__form input:focus{border-color:var(--color-secondary);outline:none;box-shadow:0 0 0 3px rgba(56,189,248,.25)}.settings-panel__error{margin:0;color:hsla(0,91%,71%,.9);font-size:.85rem}.settings-panel__actions{display:flex;flex-wrap:wrap;gap:.5rem}.settings-panel__actions button{border:none;border-radius:12px;padding:.65rem 1.25rem;cursor:pointer;font-weight:600}.settings-panel__actions button[type=submit]{background:linear-gradient(120deg,var(--color-primary),var(--color-secondary));color:#030712}.settings-panel__close{background:transparent;border:1px solid rgba(248,250,252,.35);color:rgba(248,250,252,.85)}.settings-panel__key{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;border-radius:12px;background:rgba(15,23,42,.9);border:1px solid rgba(74,222,128,.4)}.settings-panel__key code{font-family:JetBrains Mono,Fira Code,monospace;word-break:break-all;color:var(--color-primary)}.settings-panel__key button{align-self:flex-start;border:none;border-radius:999px;padding:.4rem 1rem;font-weight:600;background:rgba(74,222,128,.15);color:var(--color-primary);cursor:pointer}.settings-panel__consents{border:1px solid rgba(148,163,184,.25);border-radius:12px;padding:1rem;margin:1rem 0 0;display:flex;flex-direction:column;gap:.6rem}.settings-panel__consents legend{padding:0 .5rem;font-weight:600;font-size:.95rem;color:rgba(248,250,252,.9)}.settings-panel__consents legend small{font-weight:400;color:var(--color-secondary);font-size:.75rem}.settings-consent-item{display:flex;align-items:flex-start;gap:.6rem;cursor:pointer;font-size:.875rem;color:rgba(248,250,252,.85)}.settings-consent-item input[type=checkbox]{width:18px;height:18px;margin-top:2px;accent-color:var(--color-primary);cursor:pointer;flex-shrink:0}.settings-consent-item span{line-height:1.4}.settings-panel__save-consents{margin-top:.75rem;padding:.6rem 1.25rem;border:none;border-radius:10px;background:linear-gradient(120deg,var(--color-primary),var(--color-secondary));color:#030712;font-weight:600;font-size:.875rem;cursor:pointer;transition:transform .2s ease,opacity .2s ease}.settings-panel__save-consents:hover:not(:disabled){transform:translateY(-1px)}.settings-panel__save-consents:disabled{opacity:.5;cursor:not-allowed}.star-game__head{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}.star-game__eyebrow{text-transform:uppercase;letter-spacing:.1em;font-size:.75rem;margin:0 0 .35rem;color:rgba(248,250,252,.7)}.star-game__progress{text-align:right;font-size:.85rem;color:rgba(248,250,252,.75)}.star-game__progress small,.star-game__progress span{display:block}.star-game__progress small{margin-top:.1rem}.star-game__progress-bar{width:160px;height:6px;border-radius:999px;background:rgba(248,250,252,.1);margin-top:.35rem;overflow:hidden}.star-game__progress-bar div{height:100%;background:linear-gradient(120deg,var(--color-primary),var(--color-secondary));border-radius:inherit}.star-game__container{display:grid;grid-template-columns:minmax(220px,1fr) 300px;grid-gap:1.5rem;gap:1.5rem;margin-top:1.5rem;align-items:center}.star-game__star{position:relative;width:min(320px,60vw);height:min(320px,60vw);margin:0 auto;display:grid;grid-template-columns:repeat(6,1fr);grid-gap:8px;gap:8px;padding:1.5rem;-webkit-clip-path:polygon(50% 0,61% 35%,98% 35%,68% 57%,79% 91%,50% 72%,21% 91%,32% 57%,2% 35%,39% 35%);clip-path:polygon(50% 0,61% 35%,98% 35%,68% 57%,79% 91%,50% 72%,21% 91%,32% 57%,2% 35%,39% 35%);background:rgba(15,23,42,.6);border:1px dashed rgba(248,250,252,.2)}.star-game__block{width:100%;aspect-ratio:1;border-radius:8px;box-shadow:0 8px 20px rgba(3,7,18,.6);animation:pulseBlock 1.6s ease-in-out infinite alternate}.star-game__legend{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.star-game__legend li{display:grid;grid-template-columns:auto 1fr;grid-gap:.75rem;gap:.75rem;align-items:center}.star-game__legend span{width:20px;height:20px;border-radius:6px}.star-game__legend p{margin:0;font-weight:600}.star-game__legend small{color:rgba(248,250,252,.65)}.star-game__empty,.star-game__loading{margin-top:1rem;color:rgba(248,250,252,.8)}.star-game__loading{display:flex;align-items:center;gap:.75rem}.star-game__loading span{width:42px;height:6px;border-radius:999px;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.5),transparent);animation:shimmer 1.2s infinite}@keyframes pulseBlock{0%{transform:translateY(0);opacity:.85}to{transform:translateY(-3px);opacity:1}}.recycling-graph{overflow:hidden}.recycling-graph__head{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;margin-bottom:1.25rem}.recycling-graph__eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;color:rgba(248,250,252,.65);margin:0 0 .35rem}.recycling-graph__summary{text-align:right;color:rgba(248,250,252,.8)}.recycling-graph__summary strong{display:block;font-size:1.5rem;color:var(--color-primary)}.recycling-graph__chart{border-radius:16px;border:1px solid hsla(0,0%,100%,.08);background:rgba(15,23,42,.65);padding:1rem}.recycling-graph__chart svg{width:100%;height:auto}.recycling-graph__legend{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:.75rem;gap:.75rem;margin-top:1.25rem}.recycling-graph__legend-item{display:flex;align-items:center;gap:.65rem;padding:.65rem .75rem;border-radius:12px;background:rgba(15,23,42,.55);border:1px solid hsla(0,0%,100%,.05)}.recycling-graph__legend-item p{margin:0;font-weight:600;font-size:.95rem}.recycling-graph__legend-item small{color:rgba(248,250,252,.7)}.recycling-graph__legend-swatch{width:14px;height:14px;border-radius:4px;flex-shrink:0}.recycling-graph__timeline{margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid hsla(0,0%,100%,.08);display:flex;flex-direction:column;gap:1rem}.recycling-graph__timeline-title{margin:0;font-size:.95rem;letter-spacing:.04em;text-transform:uppercase;color:rgba(248,250,252,.65)}.recycling-graph__timeline-list{display:flex;flex-direction:column;gap:.85rem}.recycling-graph__timeline-item{border-radius:18px;border:1px solid hsla(0,0%,100%,.08);background:rgba(9,12,32,.75);padding:.85rem 1rem 1rem;box-shadow:inset 0 0 15px rgba(0,0,0,.25)}.recycling-graph__timeline-meta{display:flex;flex-wrap:wrap;gap:.5rem 1rem;align-items:baseline;justify-content:space-between;margin-bottom:.75rem;font-size:.9rem;color:rgba(248,250,252,.75)}.recycling-graph__timeline-meta time{font-weight:600;color:#f8fafc}.recycling-graph__timeline-meta span{text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;color:rgba(248,250,252,.6)}.recycling-graph__timeline-meta strong{font-size:1rem;color:var(--color-secondary)}.recycling-graph__cubes{display:grid;grid-template-columns:repeat(auto-fit,minmax(14px,18px));grid-gap:.35rem;gap:.35rem}.recycling-graph__cube{width:18px;height:18px;border-radius:3px;box-shadow:inset 0 0 4px rgba(0,0,0,.35),0 2px 4px rgba(0,0,0,.35);border:1px solid hsla(0,0%,100%,.15);animation:cubeRise .5s ease forwards}.recycling-graph__cube-more{align-self:center;padding:.2rem .5rem;border-radius:999px;border:1px solid hsla(0,0%,100%,.25);font-size:.75rem;color:rgba(248,250,252,.8);background:rgba(15,23,42,.75)}@keyframes cubeRise{0%{transform:translateY(4px);opacity:0}to{transform:translateY(0);opacity:1}}.recycling-graph__empty{margin:0;padding:.5rem 0;color:rgba(248,250,252,.7)}.recycling-graph__loading{display:flex;align-items:center;gap:.75rem;padding:.5rem 0}.recycling-graph__loading span{width:40px;height:6px;border-radius:999px;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.5),transparent);animation:shimmer 1.2s infinite}@keyframes shimmer{0%{transform:translateX(-40px);opacity:.2}50%{opacity:.8}to{transform:translateX(40px);opacity:.2}}.points-tracker__head{display:flex;justify-content:space-between;gap:1rem}.points-tracker__eyebrow{text-transform:uppercase;letter-spacing:.1em;font-size:.75rem;color:rgba(248,250,252,.7);margin:0 0 .35rem}.points-tracker__total{text-align:right;color:rgba(248,250,252,.85)}.points-tracker__total strong{display:block;font-size:1.35rem}.points-tracker__milestone{margin:1rem 0 1.25rem}.points-tracker__milestone-bar{width:100%;height:8px;border-radius:999px;background:rgba(248,250,252,.1);overflow:hidden;margin-bottom:.35rem}.points-tracker__milestone-bar div{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary))}.points-tracker__leaderboard{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));grid-gap:1rem;gap:1rem}.points-tracker__leaderboard article{background:rgba(15,23,42,.7);border-radius:16px;padding:.85rem;border:1px solid hsla(0,0%,100%,.06)}.points-tracker__leaderboard header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.points-tracker__leaderboard header span{width:12px;height:12px;border-radius:50%}.points-tracker__leaderboard header p{margin:0;font-weight:600}.points-tracker__leaderboard header small{margin-left:auto;color:var(--color-primary);text-transform:uppercase;font-size:.7rem;letter-spacing:.08em}.points-tracker__leaderboard-bar{width:100%;height:6px;border-radius:999px;background:hsla(0,0%,100%,.08);margin-bottom:.4rem;overflow:hidden}.points-tracker__leaderboard-bar div{height:100%;border-radius:inherit}.points-tracker__leaderboard-points{margin:0;color:rgba(248,250,252,.8);font-size:.85rem}.dashboard-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1rem}.btn-action{padding:.75rem 1.5rem;border-radius:12px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.btn-action--primary{background:linear-gradient(120deg,var(--color-primary),var(--color-secondary));color:#030712;border:2px solid rgba(3,7,18,.25)}.btn-action--primary:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(74,222,128,.3)}.btn-action--secondary{background:rgba(15,23,42,.85);border:2px solid var(--color-primary);color:var(--color-primary)}.btn-action--secondary:hover{background:rgba(74,222,128,.15)}.collector-form{gap:1rem}.collector-field,.collector-form{display:flex;flex-direction:column}.collector-field{gap:.35rem}.collector-label{font-size:.95rem;color:rgba(248,250,252,.85)}.collector-input,.collector-select{border-radius:12px;border:1px solid rgba(148,163,184,.4);background:rgba(15,23,42,.85);color:#f8fafc;padding:.85rem 1rem;font-size:1rem;transition:border .16s ease,box-shadow .16s ease}.collector-input:focus,.collector-select:focus{border-color:var(--color-secondary);outline:none;box-shadow:0 0 0 3px rgba(56,189,248,.25)}.collector-submit{padding:.95rem;border-radius:12px;border:2px solid rgba(3,7,18,.3);background:linear-gradient(120deg,#1e3a8a,#2563eb);color:#030712;font-weight:700;font-size:1rem;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.collector-submit:disabled{opacity:.65;cursor:not-allowed;border-color:rgba(3,7,18,.45)}.collector-submit:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 15px 35px rgba(37,99,235,.45)}.transactions-table{width:100%;border-collapse:collapse;margin-top:1rem}.transactions-table td,.transactions-table th{padding:.85rem 1rem;text-align:left;border-bottom:1px solid hsla(0,0%,100%,.06)}.transactions-table th{color:rgba(248,250,252,.65);font-weight:500;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}.transactions-table td{color:rgba(248,250,252,.9)}.transactions-table tr:hover td{background:hsla(0,0%,100%,.02)}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:999px;font-size:.8rem;font-weight:600;border:1px solid transparent}.status-badge--pending{background:rgba(250,204,21,.25);color:#422006;border-color:rgba(250,204,21,.65)}.status-badge--confirmed{background:rgba(74,222,128,.22);color:#0f1b10;border-color:rgba(74,222,128,.65)}.collector-header{background:#0f172a!important}.collector-badge{font-size:.75rem;background:hsla(0,0%,100%,.15);padding:.25rem .75rem;border-radius:999px;margin-left:.5rem;color:#f8fafc}.collector-success{background:rgba(74,222,128,.25);border:1px solid rgba(74,222,128,.6);color:#022c22;border-radius:16px;padding:.85rem 1rem;margin-bottom:1rem;font-weight:500}.loading-shell{min-height:100vh;display:flex;align-items:center;justify-content:center}.loading-text{color:rgba(248,250,252,.7);font-size:1.1rem}.custom-select{position:relative;width:100%}.custom-select__trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:.5rem;border-radius:10px;border:1px solid rgba(148,163,184,.4);background:rgba(15,23,42,.85);color:#f8fafc;padding:.6rem .85rem;font-size:.95rem;cursor:pointer;text-align:left;transition:border .16s ease,box-shadow .16s ease}.custom-select__trigger:hover:not(:disabled){border-color:rgba(148,163,184,.6)}.custom-select__trigger--open{border-color:var(--color-secondary);box-shadow:0 0 0 3px rgba(56,189,248,.25)}.custom-select__trigger--disabled{opacity:.5;cursor:not-allowed;background-color:rgba(15,23,42,.5)}.custom-select__placeholder{color:rgba(148,163,184,.7)}.custom-select__arrow{flex-shrink:0;color:rgba(148,163,184,.8);transition:transform .2s ease}.custom-select__arrow--open{transform:rotate(180deg)}.custom-select__dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:rgba(15,23,42,.98);border:1px solid rgba(148,163,184,.3);border-radius:10px;box-shadow:0 10px 40px rgba(0,0,0,.5);z-index:100;overflow:hidden}.custom-select__search{width:100%;padding:.65rem .85rem;border:none;border-bottom:1px solid rgba(148,163,184,.2);background:rgba(30,41,59,.5);color:#f8fafc;font-size:.9rem;outline:none}.custom-select__search::placeholder{color:rgba(148,163,184,.6)}.custom-select__options{list-style:none;margin:0;padding:0;max-height:200px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.3) transparent}.custom-select__options::-webkit-scrollbar{width:6px}.custom-select__options::-webkit-scrollbar-track{background:transparent}.custom-select__options::-webkit-scrollbar-thumb{background:rgba(148,163,184,.3);border-radius:3px}.custom-select__options::-webkit-scrollbar-thumb:hover{background:rgba(148,163,184,.5)}.custom-select__option{padding:.6rem .85rem;cursor:pointer;transition:background .12s ease;font-size:.9rem}.custom-select__option:hover{background:rgba(56,189,248,.15)}.custom-select__option--selected{background:rgba(74,222,128,.15);color:var(--color-primary)}.custom-select__option--empty{color:rgba(148,163,184,.6);cursor:default;text-align:center;font-style:italic}.custom-select__option--empty:hover{background:transparent}@media (max-width:640px){.hero-panel{border-radius:24px}.home-cta{flex-direction:column}.star-legend{gap:.75rem}.auth-row{grid-template-columns:1fr}.dashboard-header{padding:1rem;flex-direction:column;gap:1rem}.stats-grid{grid-template-columns:1fr}.custom-select__dropdown{position:fixed;top:auto;bottom:0;left:0;right:0;border-radius:16px 16px 0 0;max-height:60vh}.custom-select__options{max-height:calc(60vh - 50px)}}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.25rem;padding-top:1rem;border-top:1px solid hsla(0,0%,100%,.08)}.pagination-btn{padding:.5rem 1rem;border-radius:8px;border:1px solid rgba(148,163,184,.4);background:rgba(15,23,42,.85);color:#f8fafc;font-weight:500;cursor:pointer;transition:border .16s ease,background .16s ease}.pagination-btn:hover:not(:disabled){border-color:var(--color-secondary);background:rgba(56,189,248,.1)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-info{color:rgba(248,250,252,.75);font-size:.9rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.legal-page{min-height:100vh;max-width:900px;margin:0 auto;padding:clamp(1.5rem,4vw,3rem) 1.5rem 3rem}.legal-content{background:var(--color-panel);border-radius:28px;padding:clamp(1.5rem,4vw,2.5rem);border:1px solid hsla(0,0%,100%,.1);box-shadow:var(--shadow-panel)}.legal-content h1{margin:0 0 1.5rem;font-size:clamp(1.8rem,5vw,2.4rem);background:linear-gradient(120deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.legal-content h2{margin:2rem 0 1rem;font-size:1.35rem;color:#f8fafc}.legal-content h3{margin:1.5rem 0 .75rem;font-size:1.1rem;color:rgba(248,250,252,.95)}.legal-content p{margin:0 0 1rem;color:rgba(248,250,252,.8);line-height:1.7}.legal-content ol,.legal-content ul{margin:0 0 1rem;padding-left:1.5rem;color:rgba(248,250,252,.8)}.legal-content li{margin-bottom:.5rem;line-height:1.6}.legal-content a{color:var(--color-secondary);text-decoration:none;transition:color .15s ease}.legal-content a:hover{color:var(--color-primary);text-decoration:underline}.legal-content strong{color:#f8fafc}.legal-content em{color:rgba(248,250,252,.9)}.legal-scroll{max-height:60vh;overflow-y:auto;padding-right:1rem;scrollbar-width:thin;scrollbar-color:rgba(74,222,128,.4) hsla(0,0%,100%,.05)}.legal-scroll::-webkit-scrollbar{width:8px}.legal-scroll::-webkit-scrollbar-track{background:hsla(0,0%,100%,.05);border-radius:4px}.legal-scroll::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--color-primary),var(--color-secondary));border-radius:4px}.legal-scroll::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,var(--color-secondary),var(--color-primary))}@media (max-width:640px){.legal-content{border-radius:20px}.legal-scroll{max-height:70vh;padding-right:.5rem}}