/* BestFriendFile — marketing site styles */
:root{
  /* brand fixed */
  --purple:#9B8CFF; --purple-deep:#6E5CE0; --purple-soft:#EFEBFF;
  --paper:#FBF8F3; --paper-deep:#F1ECE3; --ink:#3A2E4D; --ink-soft:#8B82A0;
  --line:#ECE6DD; --white:#fff; --pink:#F9A1C3; --sun:#FFD56B;
  --ok:#1F8A63; --ok-soft:#DFF6EC;
  --display:'Fredoka',sans-serif; --body:'Nunito',sans-serif;
  /* themeable (the app's "pick your color") — default purple */
  --theme:#9B8CFF; --theme-deep:#6E5CE0; --theme-soft:#EFEBFF; --theme-ink:#5A48C8;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--body);line-height:1.6;-webkit-font-smoothing:antialiased;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;margin:0;letter-spacing:-.5px;line-height:1.05}
p{margin:0}
.wrap{max-width:1120px;margin:0 auto;padding:0 32px}

/* ============ buttons ============ */
.btn{
  display:inline-flex;align-items:center;gap:9px;font-family:var(--display);
  font-weight:600;font-size:17px;border:none;cursor:pointer;border-radius:16px;
  padding:15px 24px;transition:transform .12s ease, box-shadow .12s ease;
}
.btn-primary{background:var(--theme);color:#fff;box-shadow:0 5px 0 var(--theme-deep)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 7px 0 var(--theme-deep)}
.btn-primary:active{transform:translateY(2px);box-shadow:0 3px 0 var(--theme-deep)}
.btn-ghost{background:#fff;color:var(--ink);border:2px solid var(--line)}
.btn-ghost:hover{border-color:var(--theme);color:var(--theme-deep)}

/* app store badge — "coming soon" placeholder */
.store-badge{
  display:inline-flex;align-items:center;gap:13px;background:var(--ink);color:#fff;
  border-radius:16px;padding:12px 22px 12px 18px;font-family:var(--body);
  box-shadow:0 6px 20px rgba(58,46,77,.22);transition:transform .12s ease;
}
.store-badge:hover{transform:translateY(-2px)}
.store-badge .apple{width:30px;height:30px;flex-shrink:0}
.store-badge>span{display:flex;flex-direction:column;align-items:flex-start}
.store-badge .sb-top{display:block;font-size:11px;font-weight:700;opacity:.72;letter-spacing:.3px;line-height:1.1}
.store-badge .sb-big{display:block;font-family:var(--display);font-weight:600;font-size:21px;line-height:1.05;margin-top:2px}
.soon-pill{
  display:inline-flex;align-items:center;gap:7px;background:var(--theme-soft);
  color:var(--theme-ink);font-weight:800;font-size:13px;padding:7px 14px;border-radius:999px;
}
.soon-pill .dot{width:8px;height:8px;border-radius:50%;background:var(--theme);box-shadow:0 0 0 4px color-mix(in srgb,var(--theme) 28%,transparent)}

/* ============ header ============ */
header.nav{
  position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--paper) 86%,transparent);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line);
}
.nav-in{display:flex;align-items:center;gap:24px;height:74px}
.wordmark{font-family:var(--display);font-weight:700;font-size:25px;letter-spacing:-.5px;display:flex;align-items:center;gap:11px;white-space:nowrap}
.wordmark .mk{width:30px;height:auto}
.wordmark .b{color:var(--theme)} .wordmark .rest{color:var(--ink)}
.nav-links{display:flex;gap:28px;margin-left:14px}
.nav-links a{font-weight:700;font-size:15.5px;color:var(--ink-soft);transition:color .15s}
.nav-links a:hover{color:var(--theme-deep)}
.nav-cta{margin-left:auto;display:flex;align-items:center;gap:14px}
.nav-cta .soon-pill{display:none}
@media(min-width:1000px){.nav-cta .soon-pill{display:inline-flex}}

/* ============ section scaffold ============ */
section{position:relative}
.eyebrow{
  font-family:var(--display);font-weight:700;font-size:13px;letter-spacing:1.3px;
  text-transform:uppercase;color:var(--theme-ink);background:var(--theme-soft);
  display:inline-block;padding:7px 14px;border-radius:10px;margin-bottom:20px;
}
.sec-pad{padding:96px 0}
.sec-head{max-width:720px}
.sec-head h2{font-size:clamp(32px,4.6vw,50px)}
.sec-head .lede{font-size:20px;color:var(--ink-soft);margin-top:18px;line-height:1.55;text-wrap:pretty}

/* ============ HERO ============ */
.hero{position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(390px,0.95fr);gap:40px;align-items:center;padding:64px 0 86px}
.hero h1{font-size:clamp(40px,6.4vw,74px);line-height:.98}
.hero h1 .tint{color:var(--theme-deep)}
.hero .promise{font-size:21px;color:var(--ink-soft);margin-top:24px;max-width:30ch;text-wrap:pretty;line-height:1.5}
.hero .cta-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:34px}
.hero .trust-line{display:flex;align-items:center;gap:9px;margin-top:26px;font-weight:700;font-size:15px;color:var(--ink-soft)}
.hero .trust-line .lock{width:18px;height:18px;flex:0 0 auto}
/* hero art — floating app icon + favorite chips */
.hero-art{position:relative;display:flex;align-items:center;justify-content:center;min-height:540px}
.hero-figure{position:relative;width:min(460px,100%);aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;margin:0 auto}
.hero-figure .halo{position:absolute;width:76%;height:76%;border-radius:50%;background:radial-gradient(circle at 50% 45%,color-mix(in srgb,var(--theme) 40%,transparent),transparent 68%);filter:blur(8px);z-index:0}
.app-badge{position:relative;z-index:2;width:174px;height:174px;border-radius:25%;overflow:hidden;box-shadow:0 26px 56px color-mix(in srgb,var(--theme-deep) 34%,transparent),0 4px 12px rgba(40,30,90,.16)}
.app-badge img{width:100%;height:100%;display:block}
.hchip{position:absolute;z-index:3;display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:15px;padding:8px 13px 8px 8px;box-shadow:0 14px 30px rgba(58,46,77,.13)}
.hchip .he{width:32px;height:32px;border-radius:10px;background:#FFE3EE;display:flex;align-items:center;justify-content:center;font-size:17px;flex:0 0 auto}
.hchip .ht{display:flex;flex-direction:column;line-height:1.2;font-family:var(--body);font-weight:700;font-size:10.5px;color:var(--ink-soft);white-space:nowrap}
.hchip .ht b{font-family:var(--display);font-weight:600;font-size:13.5px;color:var(--ink)}
.hchip-1{top:5%;left:-6%;animation:floaty 5.5s ease-in-out infinite}
.hchip-2{top:5%;right:-6%;animation:floaty 6.6s ease-in-out .5s infinite}
.hchip-3{bottom:7%;left:-4%;animation:floaty 6s ease-in-out .9s infinite}
.hchip-5{bottom:7%;right:-4%;animation:floaty 5.8s ease-in-out .7s infinite}
.hbub{position:absolute;z-index:3;width:48px;height:48px;border-radius:50%;background:#fff;border:1px solid var(--line);box-shadow:0 10px 24px rgba(58,46,77,.13);display:flex;align-items:center;justify-content:center;font-size:22px}
.hbub-1{top:42%;right:-3%;animation:floaty 5.2s ease-in-out .3s infinite}
.hbub-2{bottom:-4%;left:46%;animation:floaty 6.4s ease-in-out 1s infinite}
.hbub-3{top:-5%;left:46%;animation:floaty 5.6s ease-in-out .6s infinite}
.hbub-4{top:42%;left:-3%;animation:floaty 6.1s ease-in-out 1.2s infinite}
.float-a{animation:floaty 6s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-11px)}}

/* hero variant B — centered */
.hero[data-hero="b"] .hero-grid{grid-template-columns:1fr;text-align:center;justify-items:center;padding:56px 0 80px}
.hero[data-hero="b"] .promise{max-width:46ch}
.hero[data-hero="b"] .cta-row,.hero[data-hero="b"] .trust-line{justify-content:center}
.hero[data-hero="b"] .hero-art{margin-top:24px;width:100%;min-height:400px}

/* hero variant C — calm, light, trust-forward */
.hero[data-hero="c"]{background:#fff;border-bottom:1px solid var(--line)}
.hero[data-hero="c"] h1{font-size:clamp(38px,5.6vw,64px)}

/* trust chips (hero C) */
.trust-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.trust-chips .chip{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1.5px solid var(--line);border-radius:999px;padding:8px 15px;font-weight:800;font-size:14px;color:var(--ink)}
.trust-chips .chip svg{width:16px;height:16px;color:var(--ok)}
.hero:not([data-hero="c"]) .trust-chips{display:none}
.hero[data-hero="c"] .trust-line{display:none}

/* ============ BFF backronym strip ============ */
.bff-strip{background:var(--paper-deep);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.bff-strip .wrap{padding-top:62px;padding-bottom:72px}
.bff-head{text-align:center;margin:0 auto 40px}
.bff-head h2{font-size:clamp(25px,3.3vw,37px);color:var(--ink)}
.bff-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.bff-card{position:relative;overflow:hidden;border-radius:26px;padding:36px 30px 34px;text-align:center;color:#fff;background:linear-gradient(160deg,var(--c),var(--cd));box-shadow:0 16px 36px color-mix(in srgb,var(--cd) 32%,transparent);transition:transform .16s ease,box-shadow .16s ease}
.bff-card::before{content:"";position:absolute;top:-40px;right:-40px;width:150px;height:150px;border-radius:50%;background:rgba(255,255,255,.1);pointer-events:none}
.bff-card:hover{transform:translateY(-6px);box-shadow:0 26px 48px color-mix(in srgb,var(--cd) 42%,transparent)}
.bff-letter{position:relative;display:block;font-family:var(--display);font-weight:700;font-size:88px;line-height:1;color:#fff;text-shadow:0 6px 16px rgba(40,30,90,.22)}
.bff-card h3{position:relative;color:#fff;font-size:25px;margin-top:6px}
.bff-card p{position:relative;color:rgba(255,255,255,.94);font-size:15.5px;margin-top:11px;line-height:1.55;text-wrap:pretty}

/* ============ what-it-is ============ */
.what{text-align:center}
.what .sec-head{margin:0 auto}
.what .lede{margin-left:auto;margin-right:auto}

/* ============ features ============ */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px}
.feat{background:#fff;border:1px solid var(--line);border-radius:26px;padding:30px;box-shadow:0 5px 18px rgba(58,46,77,.05);transition:transform .15s ease, box-shadow .15s ease}
.feat:hover{transform:translateY(-4px);box-shadow:0 16px 34px rgba(58,46,77,.1)}
.feat .ic{width:56px;height:56px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:27px;background:var(--theme-soft)}
.feat h3{font-size:21px;margin-top:20px}
.feat p{color:var(--ink-soft);font-size:15.5px;margin-top:9px;text-wrap:pretty}
.feat.wide{grid-column:span 2;display:flex;gap:28px;align-items:center}
.feat.wide .ic{flex:0 0 auto}

/* feature showcase row (with device) */
.showcase{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;margin-top:64px}
.showcase.flip{direction:rtl}.showcase.flip>*{direction:ltr}
.showcase .sc-copy h3{font-size:clamp(26px,3vw,34px)}
.showcase .sc-copy .lede{font-size:18px;color:var(--ink-soft);margin-top:14px}
.sc-list{list-style:none;padding:0;margin:22px 0 0;display:flex;flex-direction:column;gap:13px}
.sc-list li{display:flex;gap:12px;align-items:flex-start;font-size:16px;font-weight:600;line-height:1.4}
.sc-list .tick{flex:0 0 auto;width:24px;height:24px;border-radius:8px;background:var(--theme-soft);color:var(--theme-deep);display:flex;align-items:center;justify-content:center;font-weight:900;font-size:13px;margin-top:1px}
.sc-art{display:flex;justify-content:center}

/* device mockup (from store frames) */
.device{width:300px;border-radius:42px;background:#1c1430;padding:12px;box-shadow:0 26px 60px rgba(40,30,90,.28)}
.device .screen{background:var(--paper);border-radius:32px;overflow:hidden;height:600px;position:relative}
.device .notch{position:absolute;top:12px;left:50%;transform:translateX(-50%);width:92px;height:26px;background:#1c1430;border-radius:14px;z-index:5}
.mini-head{padding:42px 18px 12px;display:flex;align-items:center;justify-content:space-between}
.mini-title{font-family:var(--display);font-weight:700;font-size:22px;color:var(--ink)}
.mini-sub{font-size:12px;color:var(--ink-soft)}
.mh-theme{padding:42px 18px 18px;border-radius:0 0 24px 24px}
.s-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:12px;box-shadow:0 3px 12px rgba(58,46,77,.06);display:flex;align-items:center;gap:11px}
.av{width:42px;height:42px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--display);font-weight:600;font-size:18px}
.row-name{font-family:var(--display);font-weight:600;font-size:15px;color:var(--ink);white-space:nowrap}
.row-meta{font-size:11.5px;color:var(--ink-soft);white-space:nowrap}
.row-txt{min-width:0;flex:1}
.bdg{margin-left:auto;text-align:center;background:var(--theme-soft);border-radius:12px;padding:6px 10px;flex-shrink:0}
.bdg b{font-family:var(--display);font-weight:700;font-size:15px;color:var(--theme-deep);display:block;line-height:1}
.bdg span{font-size:9px;font-weight:700;color:var(--ink-soft);text-transform:uppercase}
.sec-lbl{display:flex;align-items:center;gap:7px;margin:14px 4px 9px}
.sec-lbl .ico{width:24px;height:24px;border-radius:8px;background:var(--theme-soft);display:flex;align-items:center;justify-content:center;font-size:13px}
.sec-lbl b{font-family:var(--display);font-weight:700;font-size:14px}
.favgrid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 4px}
.fav{background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px}
.fav .e{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:15px}
.fav .k{font-size:9px;font-weight:700;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.3px;margin-top:7px}
.fav .v{font-family:var(--display);font-weight:600;font-size:13px;margin-top:1px}
.gift{background:#fff;border:1px solid var(--line);border-radius:16px;padding:11px;display:flex;align-items:center;gap:10px;margin-bottom:8px}
.gift .e{width:38px;height:38px;border-radius:11px;background:var(--theme-soft);display:flex;align-items:center;justify-content:center;font-size:18px}
.gift b{font-family:var(--display);font-weight:600;font-size:13.5px;display:block}
.gift span{font-size:11px;color:var(--ink-soft)}
.swrow{display:flex;gap:9px;justify-content:center;padding:6px 0}
.sw{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:900}

/* ============ SAFETY ============ */
.safety{background:linear-gradient(180deg,var(--theme-soft),#fff)}
.safety .badge-row{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.shield{width:46px;height:46px;flex:0 0 auto;color:var(--theme-deep)}
.safe-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:36px;margin-top:48px;align-items:start}
.promise-list{list-style:none;padding:0;margin:0;display:grid;gap:14px}
.promise-list li{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px 20px;box-shadow:0 4px 14px rgba(58,46,77,.05)}
.promise-list .pi{flex:0 0 auto;width:38px;height:38px;border-radius:12px;background:var(--ok-soft);color:var(--ok);display:flex;align-items:center;justify-content:center}
.promise-list .pi svg{width:20px;height:20px}
.promise-list b{font-family:var(--display);font-weight:600;font-size:17px;display:block}
.promise-list span{color:var(--ink-soft);font-size:14.5px}
.never-card{background:var(--ink);color:#fff;border-radius:26px;padding:30px;box-shadow:0 18px 40px rgba(58,46,77,.22)}
.never-card h3{color:#fff;font-size:22px}
.never-card p.sub{color:#cfc7dd;font-size:14.5px;margin-top:8px}
.never-list{display:flex;flex-wrap:wrap;gap:9px;margin-top:20px}
.never-list .x{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);color:#fff;border-radius:999px;padding:8px 14px;font-weight:700;font-size:13.5px}
.never-list .x svg{width:14px;height:14px;color:var(--pink)}
.never-card .footnote{margin-top:22px;padding-top:18px;border-top:1px solid rgba(255,255,255,.14);font-size:13.5px;color:#cfc7dd;display:flex;gap:10px;align-items:flex-start}

/* ============ FOR PARENTS ============ */
.parents{background:var(--paper-deep)}
.parents-card{background:#fff;border:1px solid var(--line);border-radius:30px;padding:48px;box-shadow:0 14px 40px rgba(58,46,77,.07);display:grid;grid-template-columns:.9fr 1.1fr;gap:44px;align-items:center}
.parents-pip{display:flex;flex-direction:column;align-items:center;text-align:center;gap:18px}
.parents-pip img{width:200px}
.parents-pip .quote{font-family:var(--display);font-weight:600;font-size:19px;color:var(--theme-deep);max-width:24ch;line-height:1.35}
.parents-points{display:grid;gap:18px}
.parents-points .pp{display:flex;gap:14px;align-items:flex-start}
.parents-points .pp .n{flex:0 0 auto;width:34px;height:34px;border-radius:11px;background:var(--theme-soft);color:var(--theme-deep);font-family:var(--display);font-weight:700;display:flex;align-items:center;justify-content:center;font-size:16px}
.parents-points .pp b{font-family:var(--display);font-weight:600;font-size:17.5px;display:block}
.parents-points .pp span{color:var(--ink-soft);font-size:15px}

/* ============ CTA band ============ */
.cta-band{background:linear-gradient(150deg,var(--theme),var(--theme-deep));color:#fff;text-align:center;overflow:hidden;position:relative}
.cta-band .inner{padding:84px 0;position:relative;z-index:2}
.cta-band h2{color:#fff;font-size:clamp(32px,4.4vw,50px)}
.cta-band p{font-size:20px;opacity:.94;margin-top:16px}
.cta-band .store-badge{margin-top:30px}
.cta-band .blob{position:absolute;border-radius:50%;background:rgba(255,255,255,.1);z-index:1}
.cta-band .micro{margin-top:18px;font-weight:700;font-size:14px;opacity:.86}

/* ============ FOOTER ============ */
footer.ft{background:var(--ink);color:#cfc7dd;padding:64px 0 40px}
.ft-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.12)}
.ft .wordmark .b{color:var(--theme)} .ft .wordmark .rest{color:#fff}
.ft-blurb{margin-top:16px;font-size:15px;color:#b6adc7;max-width:34ch;line-height:1.55}
.ft-col h4{color:#fff;font-size:14px;text-transform:uppercase;letter-spacing:1px;font-family:var(--display);font-weight:700}
.ft-col ul{list-style:none;padding:0;margin:16px 0 0;display:grid;gap:11px}
.ft-col a{color:#cfc7dd;font-weight:600;font-size:15px}
.ft-col a:hover{color:#fff}
.ft-bottom{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-top:26px;font-size:13.5px;color:#9a90ad;flex-wrap:wrap}
.ft-bottom .made{display:inline-flex;align-items:center;gap:7px}

/* ============ responsive ============ */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;text-align:center;justify-items:center;gap:30px;padding-bottom:60px}
  .hero-art{width:100%}
  .hero .promise{max-width:46ch}
  .hero .cta-row,.hero .trust-line,.trust-chips{justify-content:center}
  .bff-grid{grid-template-columns:1fr}
  .feat-grid{grid-template-columns:1fr 1fr}
  .feat.wide{grid-column:span 2}
  .showcase,.showcase.flip{grid-template-columns:1fr;direction:ltr;gap:34px}
  .safe-grid{grid-template-columns:1fr}
  .parents-card{grid-template-columns:1fr;padding:34px}
  .ft-top{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .wrap{padding:0 20px}
  .nav-links{display:none}
  .sec-pad{padding:66px 0}
  .feat-grid{grid-template-columns:1fr}
  .feat.wide{grid-column:span 1;flex-direction:column;align-items:flex-start}
  .bff-card .big{font-size:50px}
  .ft-top{grid-template-columns:1fr}
  .device{width:268px}.device .screen{height:540px}
}

/* reduced motion */
@media(prefers-reduced-motion:reduce){
  .float-a,.hchip,.hbub{animation:none}
  html{scroll-behavior:auto}
}

/* ===== Legal / content pages (privacy, terms, support) ===== */
.legal-hero{background:linear-gradient(180deg,var(--paper-deep),var(--paper));padding:64px 0 30px;border-bottom:1px solid var(--line)}
.legal-hero h1{font-size:clamp(32px,5vw,46px);color:var(--ink);margin-top:8px}
.legal-hero .updated{margin-top:14px;color:var(--ink-soft);font-weight:600;font-size:15px}
.legal{max-width:760px;margin:0 auto;padding:46px 32px 84px;font-family:var(--body);color:#4a4060;font-size:16.5px;line-height:1.7}
.legal>.lead{font-size:19px;color:var(--ink-soft);line-height:1.6;margin:0 0 8px}
.legal h2{font-family:var(--display);font-weight:700;font-size:24px;color:var(--ink);margin:40px 0 12px;letter-spacing:-.3px}
.legal h3{font-family:var(--display);font-weight:700;font-size:18px;color:var(--ink);margin:26px 0 8px}
.legal p{margin:0 0 14px}
.legal ul,.legal ol{margin:0 0 16px;padding-left:22px}
.legal li{margin:0 0 9px}
.legal a{color:var(--theme-ink);font-weight:700}
.legal strong{color:var(--ink);font-weight:700}
.legal hr{border:none;border-top:1px solid var(--line);margin:38px 0}
.legal .callout{background:var(--purple-soft);border:1px solid color-mix(in srgb,var(--purple) 35%,var(--line));border-radius:18px;padding:18px 20px;margin:18px 0;color:var(--ink)}
.faq-q{font-family:var(--display);font-weight:700;font-size:18px;color:var(--ink);margin:26px 0 4px}
