/* Hello Sunshine — web app, full-width theme matching the marketing site. */
:root{
  --purple:#9B6BFF; --purple-d:#5B3FB0; --blue:#5B7CFA; --gold:#FFB020;
  --green:#1FA877; --pink:#FF7A9C; --ink:#2B2F55; --muted:#5B6087;
  --muted2:#9AA0BE; --line:#EEF0F8; --surface:#fff; --bg:#F7F9FF;
  --lilac:#EDE7FB; --sky:#E3ECFF; --grad:linear-gradient(120deg,#9B6BFF,#7E97FF);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:Nunito,system-ui,Arial,sans-serif;color:var(--ink);background:#fff;overflow-x:hidden}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@keyframes spinslow{to{transform:rotate(360deg)}}
a{color:inherit;text-decoration:none}
img,svg{vertical-align:middle}

/* ---- Site header (full width, sticky, matches marketing nav) ---- */
.site-head{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.88);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.site-head .inner{max-width:1180px;margin:0 auto;padding:14px 22px;display:flex;align-items:center;gap:14px}
.site-nav{display:flex;align-items:center;gap:8px;margin-left:auto}
.site-nav a{font:700 14px Nunito;color:var(--muted);padding:9px 12px;border-radius:12px;display:inline-flex;align-items:center;gap:7px}
.site-nav a.on{color:var(--purple-d);background:var(--lilac)}
.site-nav a svg{width:18px;height:18px}
.head-btn{border:none;cursor:pointer;font:700 14px Fredoka;color:#fff;background:var(--grad);
  padding:10px 18px;border-radius:14px;box-shadow:0 8px 18px rgba(155,107,255,.3)}
.head-ghost{border:none;background:none;font:700 14px Nunito;color:var(--blue);padding:9px 10px;cursor:pointer}
.icon-btn{width:42px;height:42px;border-radius:50%;background:#DCE6FF;border:none;display:flex;
  align-items:center;justify-content:center;cursor:pointer;color:var(--blue)}
.hammenu{display:none;border:none;background:none;font-size:24px;color:var(--blue);cursor:pointer}
@media(max-width:820px){ .site-nav{display:none} .hammenu{display:block;margin-left:auto} }

/* ---- Page container ---- */
.site-main{min-height:60vh}
.page{max-width:1120px;margin:0 auto;padding:34px 22px 80px}
.page.narrow{max-width:640px}
.page-head{margin-bottom:8px}
h1.title{font:700 30px Fredoka;margin:0 0 4px}
.sub{font:600 15px Nunito;color:var(--muted);margin:0 0 4px}
.center{text-align:center}
.eyebrow{font:700 12px Nunito;letter-spacing:.5px;color:var(--muted2);margin:26px 0 12px;text-transform:uppercase}
.back{display:inline-block;font:700 14px Fredoka;color:var(--blue);margin-bottom:8px}

/* Hero (full-bleed colored sections: welcome, celebration, ring, success) */
.hero{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 71px);padding:48px 22px;text-align:center}
.hero-inner{max-width:520px;width:100%;display:flex;flex-direction:column;align-items:center}

/* ---- Cards & layout ---- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:22px;padding:20px 22px;
  box-shadow:0 10px 30px rgba(80,70,140,.06)}
.card + .card{margin-top:16px}
.grid{display:grid;gap:16px}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.auto{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
@media(max-width:720px){ .grid.cols-2,.grid.cols-3{grid-template-columns:1fr} }
.row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.stack{display:flex;flex-direction:column;gap:16px}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;width:100%;text-align:center;border:none;
  cursor:pointer;font:700 16px Fredoka;padding:15px 20px;border-radius:16px;transition:transform .05s}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 10px 22px rgba(155,107,255,.32)}
.btn-purple{background:var(--grad);color:#fff;box-shadow:0 10px 22px rgba(155,107,255,.32)}
.btn-blue{background:var(--blue);color:#fff;box-shadow:0 10px 22px rgba(91,124,250,.3)}
.btn-gold{background:#FFF6DF;color:#C9971E;border:1px solid #FFE3A0}
.btn-soft{background:var(--sky);color:#2B4F86}
.btn-ghost{background:#F1F2F8;color:var(--muted)}
.btn:disabled{opacity:.6;cursor:default}
.btn-sm{font-size:14px;padding:12px 16px;border-radius:13px}
.btn.inline{width:auto}

/* ---- Forms ---- */
.field{position:relative;background:var(--bg);border:1.5px solid #E4E7F4;border-radius:13px;padding:16px 15px 13px;margin-top:20px}
.field:focus-within{border-color:var(--purple)}
.field label{position:absolute;top:-8px;left:12px;background:#fff;padding:0 6px;font:600 11px Nunito;color:var(--muted);letter-spacing:.3px;text-transform:uppercase}
.field input{border:none;outline:none;width:100%;font:700 15px Nunito;color:var(--ink);background:transparent}
.field.simple{background:#fff;border-color:#E4E7F4}
.err{color:#E0455E;font:600 13px Nunito;margin-top:10px;min-height:18px}

/* ---- Toggle ---- */
.toggle{width:46px;height:27px;border-radius:15px;position:relative;flex:none;border:none;cursor:pointer;background:#DDDAEA}
.toggle .knob{position:absolute;top:3px;left:3px;width:21px;height:21px;background:#fff;border-radius:50%;transition:.15s}
.toggle.on{background:var(--purple)} .toggle.on .knob{left:auto;right:3px}
.toggle.blue.on{background:var(--blue)}

/* ---- Progress dots ---- */
.steps{display:flex;gap:6px;margin:0 auto 18px;max-width:360px}
.steps > i{flex:1;height:5px;border-radius:3px;background:#E0DAF0}
.steps > i.on{background:var(--purple)}

/* ---- Chips / pills ---- */
.star{display:inline-flex;align-items:center;gap:6px;background:var(--lilac);padding:8px 14px;border-radius:20px;font:700 15px Fredoka;color:var(--purple-d)}
.pill{width:26px;height:26px;border-radius:8px;font:700 11px Nunito;display:flex;align-items:center;justify-content:center;background:#EEEAF8;color:#B0A5D8;cursor:pointer}
.pill.on{background:var(--purple);color:#fff}
.avatar{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;flex:none;cursor:pointer;border:3px solid transparent}
.avatar.sel{border-color:var(--purple)}

/* ---- Menu grid (all screens) ---- */
.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px}
.menu-grid a{background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px;font:700 14px Nunito;color:var(--ink);box-shadow:0 6px 18px rgba(80,70,140,.05)}
.menu-grid a:hover{border-color:var(--purple)}
.menu-grid a small{display:block;color:var(--muted2);font-weight:600;font-size:12px;margin-top:3px}
.menu-sec{grid-column:1/-1;font:700 13px Fredoka;color:var(--purple);letter-spacing:.4px;margin:14px 0 -4px}

/* ---- Footer ---- */
.app-foot{border-top:1px solid var(--line);padding:26px 22px;text-align:center;color:var(--muted2);font:600 13px Nunito}

/* Dashboard 2-col layout */
.dash{display:grid;grid-template-columns:1fr 340px;gap:24px;align-items:start;margin-top:22px}
@media(max-width:820px){ .dash{grid-template-columns:1fr} }
.kidcard{display:flex;align-items:center;gap:14px}
