:root{--sky:#e0f2fe;--mint:#d1fae5;--butter:#fef9c3;--lavender:#ede9fe;--white:#ffffff;--ink:#1e3a5f;--ink-soft:#334155;--blue:#2563eb;--blue-hover:#1d4ed8;--teal:#0d9488;--teal-hover:#0f766e;--coral:#fb7185;--purple:#7c3aed;--radius:20px;--radius-sm:14px;--radius-pill:999px;--shadow-soft:0 8px 24px rgba(37,99,235,0.12);--shadow-card:0 12px 32px rgba(30,58,95,0.1);--shadow-hover:0 18px 40px rgba(37,99,235,0.18);--font-display:"Fredoka","Nunito",system-ui,sans-serif;--font-body:"Nunito",system-ui,sans-serif}*,:after,:before{box-sizing:border-box}html{color-scheme:only light}body{margin:0;font-family:var(--font-body);font-size:1.2rem;line-height:1.55;color:var(--ink-soft);background-color:var(--sky);background-image:radial-gradient(circle at 12% 18%,rgba(167,243,208,.45) 0,transparent 38%),radial-gradient(circle at 88% 12%,rgba(196,181,253,.35) 0,transparent 35%),radial-gradient(circle at 70% 85%,rgba(253,224,71,.25) 0,transparent 40%),radial-gradient(var(--ink) 1px,transparent 1px);background-size:100% 100%,100% 100%,100% 100%,18px 18px;background-attachment:fixed}#root,body{min-height:100svh}h1,h2,h3{font-family:var(--font-display);color:var(--ink);font-weight:700;letter-spacing:.02em}a{color:var(--blue)}.app-shell{min-height:100svh;display:flex;flex-direction:column;width:100%;max-width:none;margin:0 auto;padding:0 1.25rem 2rem}.main-content{flex:1 1}.site-footer{margin-top:2rem;padding:1.25rem;background:linear-gradient(135deg,var(--white) 0,var(--lavender) 45%,var(--mint) 100%);border:3px solid rgba(255,255,255,.9);border-radius:var(--radius);box-shadow:var(--shadow-card)}.site-footer__grid{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr));grid-gap:1rem;gap:1rem}.footer-col{display:flex;flex-direction:column;gap:.45rem}.footer-col__title{margin:0 0 .15rem;font-size:1.2rem}.footer-link{width:-moz-fit-content;width:fit-content;text-decoration:none;color:var(--ink-soft);background:rgba(255,255,255,.85);border:2px solid transparent;border-radius:var(--radius-pill);padding:.35rem .75rem;font-weight:700;font-size:.95rem;transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .2s ease,border-color .2s ease}.footer-link:hover{transform:translateY(-2px) scale(1.04);border-color:var(--blue);box-shadow:var(--shadow-soft)}.site-footer__note{margin:1rem 0 0;text-align:center;font-size:.95rem;color:var(--ink-soft);opacity:.85}@media (max-width:860px){.site-footer__grid{grid-template-columns:repeat(2,minmax(160px,1fr))}}@media (max-width:520px){.site-footer__grid{grid-template-columns:1fr}}.navbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;margin:0 -1.25rem 1.5rem;background:linear-gradient(135deg,var(--white) 0,var(--mint) 100%);border-radius:0 0 var(--radius) var(--radius);box-shadow:var(--shadow-soft)}.navbar-brand{display:inline-flex;align-items:center;gap:.65rem;text-decoration:none;color:var(--ink);transition:transform .2s ease}.navbar-brand:hover{transform:scale(1.03)}.navbar-logo{width:52px;height:52px;border-radius:18px;background:linear-gradient(145deg,#fde047,#f472b6,#60a5fa);display:grid;place-items:center;box-shadow:var(--shadow-card)}.navbar-logo__face{font-size:1.85rem;line-height:1}.navbar-title{font-family:var(--font-display);font-weight:700;font-size:1.65rem}.navbar-nav{display:flex;flex-wrap:wrap;gap:.5rem}.nav-link{font-family:var(--font-display);font-weight:600;font-size:1.1rem;padding:.65rem 1.25rem;border-radius:var(--radius-pill);text-decoration:none;color:var(--ink);background:rgba(255,255,255,.7);border:2px solid transparent;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s ease,background .2s ease}.nav-link:hover{transform:translateY(-3px) scale(1.04);box-shadow:var(--shadow-hover);background:var(--white)}.nav-link--active{background:var(--white);border-color:var(--blue);color:var(--blue);box-shadow:var(--shadow-soft)}.btn{font-family:var(--font-display);font-weight:700;font-size:1rem;border:none;cursor:pointer;border-radius:var(--radius-pill);padding:.55rem 1.2rem;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:.35rem;transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .2s ease,background .2s ease}.btn:active{transform:scale(.96)}.btn--large{font-size:1.15rem;padding:.85rem 1.75rem}.btn--primary{background:linear-gradient(135deg,var(--blue),var(--teal));color:var(--white);box-shadow:0 6px 20px rgba(37,99,235,.35)}.btn--primary:hover{transform:translateY(-4px) scale(1.03);box-shadow:var(--shadow-hover)}.btn--secondary{background:var(--white);color:var(--ink);border:3px solid var(--lavender);box-shadow:var(--shadow-soft)}.btn--secondary:hover{transform:translateY(-3px);border-color:var(--purple)}.btn--ghost{background:var(--lavender);color:var(--purple)}.btn--ghost:hover{transform:scale(1.08)}.btn--icon{width:3.25rem;height:3.25rem;padding:0;font-size:1.35rem;border-radius:50%}.btn--fav-on{background:#fce7f3;color:var(--coral)}.page{animation:fadeUp .45s ease}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.page-header{margin-bottom:1.75rem;text-align:center}.page-header__title{font-size:clamp(2rem,4vw,2.75rem);margin:0 0 .5rem}.page-header__lead{margin:0;max-width:36rem;margin-inline:auto;font-size:1.15rem}.hero-banner{display:grid;grid-template-columns:1fr auto;grid-gap:1.5rem;gap:1.5rem;align-items:center;padding:2rem 1.75rem;margin-bottom:2.5rem;background:linear-gradient(120deg,var(--white) 0,var(--butter) 45%,var(--mint) 100%);border-radius:var(--radius);box-shadow:var(--shadow-card);border:3px solid rgba(255,255,255,.9)}@media (max-width:768px){.hero-banner{grid-template-columns:1fr;text-align:center}}.hero-banner__title{font-size:clamp(1.85rem,4vw,2.5rem);margin:0 0 .75rem}.hero-banner__text{margin:0 0 1.25rem;font-size:1.15rem;max-width:32rem}.hero-banner__cta{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}@media (max-width:768px){.hero-banner__cta{justify-content:center}}.progress-pill{font-family:var(--font-display);font-weight:600;padding:.5rem 1rem;background:var(--white);border-radius:var(--radius-pill);box-shadow:var(--shadow-soft);font-size:1rem}.hero-banner__art{position:relative;width:120px;height:140px}@media (max-width:768px){.hero-banner__art{margin:0 auto}}.floaty{position:absolute;font-size:2.5rem;animation:bouncey 2.5s ease-in-out infinite}.floaty--1{left:0;top:10px;animation-delay:0s}.floaty--2{right:0;top:40px;animation-delay:.4s;font-size:2rem}.floaty--3{left:30%;bottom:0;animation-delay:.8s;font-size:2.2rem}@keyframes bouncey{0%,to{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-10px) rotate(3deg)}}.section__title{font-size:1.85rem;margin:0 0 .35rem;text-align:center}.section__lead{text-align:center;margin:0 0 1.75rem;font-size:1.1rem}.page--home .hero-banner{width:65%;min-height:180px;padding:1rem 1.25rem;margin-inline:auto;margin-bottom:1.35rem;gap:.9rem;align-content:space-between}.page--home .hero-banner__content{height:100%;display:flex;flex-direction:column;justify-content:space-between}.page--home .hero-banner__title{font-size:clamp(1.5rem,2.8vw,2rem);margin-bottom:.35rem}.page--home .hero-banner__text{font-size:1rem;margin-bottom:.7rem}.page--home .hero-banner__art{width:88px;height:88px}.page--home .floaty{font-size:1.8rem}@media (max-width:1100px){.page--home .hero-banner{width:80%}}@media (max-width:768px){.page--home .hero-banner{width:100%;min-height:auto}}.page--home .section__lead,.page--home .section__title{text-align:left}.page--home .section__lead{margin-bottom:.9rem}.game-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:1.5rem;gap:1.5rem;justify-content:start}.page--home .game-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:.85rem;justify-content:start}.game-card{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);border:3px solid rgba(255,255,255,.8);min-height:300px;transition:transform .28s cubic-bezier(.34,1.56,.64,1),box-shadow .28s ease}.game-card__link{color:inherit;text-decoration:none;display:block}.game-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:var(--shadow-hover)}.game-card:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,16,34,.1) 12%,rgba(8,16,34,.72));pointer-events:none}.game-card__thumb{display:grid;place-items:center;width:100%;height:100%;min-height:300px}.game-card__emoji{font-size:4.1rem;filter:drop-shadow(0 8px 18px rgba(0,0,0,.28));transition:transform .2s ease}.game-card:hover .game-card__emoji{transform:scale(1.08) rotate(-4deg)}.game-card__fav{position:absolute;top:10px;right:10px;z-index:3;width:2rem;height:2rem;border-radius:999px;border:0;background:rgba(255,255,255,.92);color:#e11d48;font-size:1rem;cursor:pointer;display:grid;place-items:center;box-shadow:0 4px 16px rgba(0,0,0,.24);transition:transform .18s ease}.game-card__fav:hover{transform:scale(1.08)}.game-card__fav--on{background:#ffe4e6}.game-card__body{position:absolute;inset:auto 0 0 0;z-index:2;padding:.95rem 1rem 1rem;color:#fff}.page--home .game-card__body{padding:.85rem .95rem 1rem}.page--home .game-card__title{font-size:1.15rem}.page--home .game-card__tagline{font-size:.92rem;margin-bottom:.5rem}.page--home .btn--large{font-size:.95rem;padding:.55rem 1rem}.game-card__title{font-size:1.35rem;margin:0 0 .25rem;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.45)}.game-card__tagline{margin:0 0 .65rem;font-size:1rem;opacity:.95;text-shadow:0 1px 4px rgba(0,0,0,.45)}.game-card__badges{margin:0 0 .75rem;font-size:1rem;letter-spacing:.15em}.empty-hint{text-align:center;font-size:1.15rem;padding:2rem;box-shadow:var(--shadow-soft);max-width:28rem}.empty-hint,.info-card{background:var(--white);border-radius:var(--radius);margin:0 auto}.info-card{box-shadow:var(--shadow-card);border:3px solid rgba(255,255,255,.85);padding:1.15rem 1.25rem;max-width:46rem;font-size:1.05rem}.page--legal .page-header{text-align:center;max-width:40rem;margin-inline:auto}.legal-doc__updated{margin:.35rem 0 0;font-size:.9rem;font-weight:600;color:var(--ink-soft)}.legal-doc{max-width:42rem;line-height:1.65;color:var(--ink)}.legal-doc__intro{font-size:1.06rem;margin-top:0}.legal-doc__muted{font-size:.92rem;color:var(--ink-soft);line-height:1.5}.legal-doc h2{font-family:var(--font-display);font-size:1.2rem;margin:1.75rem 0 .65rem}.legal-doc h2,.legal-doc h3{font-weight:800;color:var(--ink)}.legal-doc h3{font-size:1.02rem;margin:1.25rem 0 .5rem}.legal-doc p{margin:0 0 .85rem}.legal-doc ol,.legal-doc ul{margin:0 0 .85rem;padding-left:1.35rem}.legal-doc li{margin-bottom:.4rem}.legal-doc a{font-weight:700;color:var(--purple);text-decoration:underline;text-underline-offset:2px}.legal-doc a:hover{color:var(--ink)}.legal-doc__agent{margin:0 0 1rem;padding:1rem 1.1rem;background:rgba(124,58,237,.06);border:2px solid rgba(124,58,237,.2);border-radius:var(--radius-sm);font-style:normal;line-height:1.55}.legal-doc code{font-size:.88em;padding:.12rem .35rem;background:#f1f5f9;border-radius:4px;font-family:ui-monospace,monospace}.contact-page__soon{margin:0 0 .75rem;font-size:1.1rem;font-weight:700;color:var(--ink)}.embed-attribution{margin:0 0 .75rem;font-size:.95rem;line-height:1.45;max-width:52rem}.embed-attribution a{font-weight:700;color:var(--purple)}.embed-external{margin:1rem 0 0;text-align:center}.page--play .play-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1rem}.play-toolbar__title{flex:1 1 auto;margin:0;font-size:clamp(1.35rem,3vw,1.75rem);min-width:0}.play-toolbar__stars{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap}.play-toolbar__stars-label{font-weight:700;font-size:.95rem}.star-btn{font-size:1.5rem;line-height:1;padding:.15rem .25rem;border:none;background:transparent;cursor:pointer;opacity:.35;filter:grayscale(.5);transition:transform .2s cubic-bezier(.34,1.56,.64,1),opacity .2s ease}.star-btn:hover{transform:scale(1.25);opacity:.85}.star-btn--on{opacity:1;filter:none}.iframe-shell{background:var(--white);border-radius:var(--radius);padding:.75rem;box-shadow:var(--shadow-card);border:4px solid var(--lavender);min-height:min(72vh,640px)}.game-iframe{display:block;width:100%;height:min(72vh,640px);border:none;border-radius:var(--radius-sm);background:var(--sky)}.navbar-auth{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-left:.25rem}.navbar-auth--muted{font-family:var(--font-display);font-weight:600;color:var(--ink-soft);padding:.5rem .75rem}.navbar-auth__email{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.95rem;font-weight:700;color:var(--ink);padding:.35rem .5rem}.btn--nav{font-size:.95rem;padding:.5rem 1rem}.login-page{display:flex;justify-content:center;padding:1rem 0 2rem}.login-card{width:min(100%,420px);background:linear-gradient(145deg,var(--white) 0,var(--mint) 100%);border:3px solid rgba(255,255,255,.95);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:1.75rem 1.5rem 1.5rem;text-align:center}.login-card__title{margin:0 0 .5rem;font-size:clamp(1.65rem,3vw,2rem)}.login-card__lead{margin:0 0 1.25rem;font-size:1.05rem;color:var(--ink-soft);line-height:1.45}.login-card__error{margin:0 0 1rem;padding:.65rem .85rem;background:#fef2f2;border:2px solid #fecaca;border-radius:var(--radius-sm);color:#b91c1c;font-size:.95rem}.login-card__actions{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.btn--google{background:#fff;color:#1f2937;border:3px solid #e5e7eb;box-shadow:var(--shadow-soft)}.btn--google:hover{border-color:#93c5fd;box-shadow:var(--shadow-hover)}.login-card__hint{margin:0 0 1rem;font-size:.85rem;color:var(--ink-soft);line-height:1.4}.login-card__back{font-weight:700;font-size:.95rem;text-decoration:none;color:var(--purple)}.login-card__back:hover{text-decoration:underline}.favorites-gate{max-width:28rem;margin:0 auto;padding:1.75rem 1.5rem;text-align:center;background:var(--white);border-radius:var(--radius);border:3px solid var(--lavender);box-shadow:var(--shadow-card)}.favorites-gate__text{margin:0 0 1.25rem;font-size:1.1rem;line-height:1.5;color:var(--ink-soft)}.page--feedback .feedback-gate{max-width:28rem;margin:0 auto;text-align:center}.page--feedback .feedback-card{max-width:36rem;margin:0 auto}.feedback-form{width:100%;max-width:100%}.feedback-form__select{cursor:pointer}.profile-form__textarea{min-height:8rem;resize:vertical;font-family:inherit;line-height:1.45}.feedback-form__hint{margin:-.35rem 0 0;font-size:.85rem;color:var(--ink-soft)}.feedback-success{align-items:flex-start;gap:1rem}.feedback-success,.page--blog{display:flex;flex-direction:column}.page--blog{align-items:center}.page--blog .page-header{text-align:center;max-width:40rem;margin-inline:auto}.blog-grid,.page--blog .page-header__lead{margin-inline:auto}.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,340px));grid-gap:1.25rem;gap:1.25rem;justify-content:center;width:100%;max-width:1100px}.blog-card{display:flex;flex-direction:column;align-items:flex-start;text-align:left;text-decoration:none;color:inherit;background:var(--white);border-radius:var(--radius);border:3px solid rgba(255,255,255,.9);padding:1.25rem 1.35rem;box-shadow:var(--shadow-card);transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .22s ease,border-color .2s ease}.blog-card:hover{transform:translateY(-6px) scale(1.01);box-shadow:var(--shadow-hover);border-color:var(--lavender)}.blog-card__date{font-size:.85rem;font-weight:700;color:var(--teal);margin-bottom:.5rem}.blog-card__title{font-family:var(--font-display);font-size:1.25rem;margin:0 0 .65rem;color:var(--ink);line-height:1.25}.blog-card__excerpt{margin:0 0 1rem;font-size:1rem;line-height:1.5;color:var(--ink-soft);flex:1 1}.blog-card__cta{font-family:var(--font-display);font-weight:700;font-size:.95rem;color:var(--blue)}.page--blog-article{display:flex;flex-direction:column;align-items:center}.page--blog-article .article-nav{margin-bottom:1rem;width:100%;max-width:70rem;margin-inline:auto}.article-nav__back{font-weight:700;text-decoration:none;color:var(--purple);font-size:1rem}.article-nav__back:hover{text-decoration:underline}.article{width:100%;max-width:70rem;margin-inline:auto;background:var(--white);border-radius:var(--radius);border:3px solid rgba(255,255,255,.85);padding:1.75rem 1.85rem 2.25rem;box-shadow:var(--shadow-card)}.article__header{margin-bottom:1.5rem;padding-bottom:1.15rem;border-bottom:2px solid var(--lavender)}.article__date{display:block;font-size:1.15rem;font-weight:700;color:var(--teal);margin-bottom:.65rem}.article__title{font-size:clamp(2rem,4.5vw,2.9rem);margin:0;line-height:1.18;color:var(--ink)}.article__body{font-size:1.35rem;line-height:1.75;color:var(--ink-soft)}.article__body a{color:var(--blue);font-weight:700;text-decoration:underline;text-underline-offset:3px}.article__body a:hover{color:var(--purple)}.article__subheading{font-family:var(--font-display);font-size:clamp(1.35rem,2.5vw,1.75rem);font-weight:700;color:var(--ink);margin:2rem 0 .85rem;line-height:1.25}.article__body .article__subheading:first-child{margin-top:0}.article__paragraph{margin:0 0 1.25rem}.article__paragraph:last-child{margin-bottom:0}.article__tips{margin:0 0 1.35rem;padding:1rem 1.2rem 1.1rem;border-radius:12px;border:2px solid transparent}.article__tips--why{background:rgba(34,197,94,.09);border-color:rgba(34,197,94,.38)}.article__tips--how{background:rgba(124,58,237,.08);border-color:rgba(124,58,237,.35)}.article__tips-heading{font-family:var(--font-display);font-size:1.12rem;font-weight:800;margin:0 0 .65rem;color:var(--ink);letter-spacing:.01em}.article__tips-list{margin:0;padding-left:1.4rem;line-height:1.55}.article__tips-list li{margin-bottom:.5rem}.article__tips-list li:last-child{margin-bottom:0}.page--profile{max-width:52rem;margin:0 auto}.page--profile .page-header{text-align:center;margin-bottom:1.75rem}.profile-layout{display:grid;grid-gap:1.25rem;gap:1.25rem}@media (min-width:720px){.profile-layout{grid-template-columns:1fr 1fr;align-items:start}.profile-card--span{grid-column:1/-1}}.profile-card{background:var(--white);border-radius:var(--radius);border:3px solid var(--lavender);box-shadow:var(--shadow-card);padding:1.5rem 1.35rem 1.4rem}.profile-card--streak{border-color:rgba(34,197,94,.45);background:linear-gradient(145deg,var(--white) 0,rgba(34,197,94,.06) 100%)}.profile-card--cloak{border-color:rgba(124,58,237,.35);background:linear-gradient(145deg,var(--white) 0,rgba(124,58,237,.06) 100%)}.profile-form--cloak{max-width:28rem}.profile-cloak__icon-row{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;width:100%}.profile-cloak__preview{width:40px;height:40px;border-radius:8px;border:2px solid var(--lavender);object-fit:cover;background:#f8fafc;flex-shrink:0}.profile-cloak__file-wrap{display:flex;flex-wrap:wrap;align-items:center;gap:.65rem}.profile-cloak__file{font-size:.9rem;max-width:100%}.profile-cloak__error{margin:0;font-size:.9rem;color:#b91c1c}.profile-cloak__actions{display:flex;flex-wrap:wrap;gap:.65rem;align-items:center;margin-top:.25rem}.btn--small{font-size:.88rem;padding:.45rem .85rem}.profile-card__title{font-family:var(--font-display);font-size:1.35rem;margin:0 0 .5rem;color:var(--ink)}.profile-card__lead{margin:0 0 1rem;font-size:.98rem;line-height:1.5;color:var(--ink-soft)}.profile-form{display:flex;flex-direction:column;gap:.65rem;align-items:flex-start}.profile-form__label{font-weight:700;font-size:.95rem;color:var(--ink)}.profile-form__input{width:100%;max-width:100%;padding:.65rem .85rem;font-size:1rem;border:2px solid var(--lavender);border-radius:var(--radius-sm);background:#fff;color:var(--ink)}.profile-form__input:focus{outline:none;border-color:var(--purple);box-shadow:0 0 0 3px rgba(124,58,237,.2)}.profile-card__saved{margin:1rem 0 0;font-size:.95rem;color:var(--ink-soft)}.profile-streak{text-align:center;margin:1rem 0 .75rem}.profile-streak__value{font-family:var(--font-display);font-size:clamp(2.75rem,8vw,3.75rem);font-weight:800;line-height:1;color:var(--purple)}.profile-streak__caption{margin-top:.35rem;font-size:.95rem;font-weight:700;color:var(--ink-soft)}.profile-streak__deadline{margin:0;font-size:.95rem;line-height:1.5;color:var(--ink-soft)}