/* ============================================================
   FORWARD — marketing site
   Warm editorial / soft-premium. Blush canvases, black backbone,
   wisteria + bubblegum accents.
   ============================================================ */

:root{
  /* brand */
  --ink:#0b0a0c;
  --true-black:#000;
  --wisteria:#7f95d1;
  --bubblegum:#ff82a9;
  --powder:#ffc0be;
  --blush:#ffebe7;

  /* derived neutrals (warm) */
  --paper:#fffaf8;
  --cream:#fff4f0;
  --line:rgba(11,10,12,.10);
  --line-soft:rgba(11,10,12,.06);
  --muted:rgba(11,10,12,.58);

  /* shadows — warm tinted, never grey */
  --sh-sm:0 2px 8px -2px rgba(127,149,209,.25);
  --sh-md:0 18px 40px -22px rgba(11,10,12,.45);
  --sh-pink:0 30px 60px -28px rgba(255,130,169,.55);
  --sh-blue:0 30px 60px -30px rgba(127,149,209,.55);

  --radius:22px;
  --radius-lg:34px;
  --maxw:1200px;

  --font-display:"Fraunces",Georgia,serif;
  --font-body:"Hanken Grotesk",-apple-system,system-ui,sans-serif;

  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--blush);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  position:relative;
}

/* warm gradient wash on the body */
body::before{
  content:"";position:fixed;inset:0;z-index:-3;pointer-events:none;
  background:
    radial-gradient(120% 90% at 85% -10%, rgba(255,130,169,.32), transparent 55%),
    radial-gradient(90% 80% at -10% 10%, rgba(127,149,209,.30), transparent 50%),
    radial-gradient(100% 100% at 50% 120%, rgba(255,192,190,.40), transparent 60%),
    var(--blush);
}

::selection{background:var(--bubblegum);color:#fff}
a{color:inherit;text-decoration:none}
img,svg{display:block}

/* ---------- atmosphere / grain ---------- */
.grain{
  position:fixed;inset:-50%;z-index:-1;pointer-events:none;opacity:.5;
  mix-blend-mode:soft-light;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.atmosphere{position:fixed;inset:0;z-index:-2;pointer-events:none;overflow:hidden}
.blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.5;animation:drift 22s var(--ease) infinite alternate}
.blob--a{width:38vw;height:38vw;background:var(--bubblegum);top:-8vw;right:-6vw}
.blob--b{width:32vw;height:32vw;background:var(--wisteria);bottom:6vw;left:-8vw;animation-delay:-6s}
.blob--c{width:24vw;height:24vw;background:var(--powder);top:42vh;left:46vw;animation-delay:-12s}
@keyframes drift{to{transform:translate3d(4vw,3vw,0) scale(1.12)}}

/* ---------- shared layout ---------- */
section{position:relative}
.eyebrow{
  font-size:.78rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--bubblegum);margin-bottom:1rem;
}
.eyebrow--light{color:var(--powder)}
.sec-head{max-width:760px;margin:0 auto clamp(2.5rem,6vw,4rem);padding:0 6vw}
.sec-head--center{text-align:center}
.sec-title{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(2rem,4.6vw,3.4rem);line-height:1.06;letter-spacing:-.02em;
  font-optical-sizing:auto;
}
.sec-title em{font-style:italic;color:var(--wisteria)}
.sec-title--light{color:var(--blush)}
.sec-title--light em{color:var(--bubblegum)}
.lede{font-size:clamp(1.05rem,1.8vw,1.3rem);color:var(--muted);max-width:620px}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--font-body);font-weight:600;font-size:.98rem;
  padding:.85em 1.4em;border-radius:100px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out),background .25s;
  white-space:nowrap;
}
.btn--lg{font-size:1.05rem;padding:1em 1.7em}
.btn--ink{background:var(--ink);color:var(--blush);box-shadow:var(--sh-md)}
.btn--ink:hover{transform:translateY(-3px);box-shadow:var(--sh-pink)}
.btn--ghost{background:transparent;border-color:var(--ink);color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--blush);transform:translateY(-3px)}
.btn__arr{transition:transform .35s var(--ease)}
.btn--ink:hover .btn__arr{transform:translateX(4px)}

/* ---------- NAV ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:1rem clamp(1.2rem,4vw,2.5rem);
  background:rgba(255,235,231,.7);backdrop-filter:blur(14px) saturate(1.4);
  border-bottom:1px solid transparent;transition:border-color .3s,background .3s;
}
.nav.scrolled{border-color:var(--line);background:rgba(255,244,240,.82)}
.brand{display:flex;align-items:center;gap:.55rem;font-weight:800;font-size:1.18rem;letter-spacing:-.02em}
.brand__mark{width:30px;height:30px;filter:drop-shadow(0 4px 10px rgba(255,130,169,.45))}
.brand__word{font-family:var(--font-display);font-weight:600}
.nav__links{display:flex;gap:1.6rem}
.nav__links a{font-size:.95rem;font-weight:500;color:var(--ink);opacity:.72;transition:opacity .2s;position:relative}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:2px;background:var(--bubblegum);transition:width .3s var(--ease)}
.nav__links a:hover{opacity:1}
.nav__links a:hover::after{width:100%}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.nav__burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}

/* ---------- HERO ---------- */
.hero{
  display:grid;grid-template-columns:1.05fr .95fr;gap:2rem;align-items:center;
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(2.5rem,7vw,5.5rem) clamp(1.2rem,4vw,2.5rem) clamp(3rem,7vw,5rem);
}
.hero__title{
  font-family:var(--font-display);font-weight:400;
  font-size:clamp(2.6rem,6.2vw,5rem);line-height:.98;letter-spacing:-.03em;
  margin:.4rem 0 1.4rem;font-optical-sizing:auto;
}
.hero__title span{display:block}
.hero__title em{font-style:italic;font-weight:500;color:var(--bubblegum)}
.hero__sub{font-size:clamp(1.05rem,1.6vw,1.22rem);color:var(--muted);max-width:520px;margin-bottom:2rem}
.hero__actions{display:flex;gap:.9rem;flex-wrap:wrap;margin-bottom:2.2rem}
.hero__trust{list-style:none;display:flex;gap:1.2rem;flex-wrap:wrap;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.hero__trust li{display:flex;align-items:center;gap:.5rem}
.hero__trust li::before{content:"✓";color:var(--wisteria);font-weight:800}

/* hero stage */
.hero__stage{position:relative;height:min(620px,72vw);display:flex;align-items:center;justify-content:center}

/* ---------- phone component ---------- */
.phone{width:clamp(240px,26vw,300px);}
.phone__bezel{
  position:relative;background:var(--ink);border-radius:44px;padding:11px;
  box-shadow:var(--sh-blue),inset 0 0 0 2px rgba(255,255,255,.06);
}
.phone__island{position:absolute;top:20px;left:50%;transform:translateX(-50%);width:84px;height:24px;background:#000;border-radius:14px;z-index:3}
.screen{background:linear-gradient(180deg,#fff,var(--cream));border-radius:34px;overflow:hidden;aspect-ratio:9/19.2}
.phone--hero{position:absolute;z-index:2;transform:rotate(-4deg)}

.chat{display:flex;flex-direction:column;height:100%}
.chat__head{display:flex;align-items:center;gap:.6rem;padding:2.6rem .9rem .7rem;border-bottom:1px solid var(--line-soft)}
.avatar{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:.95rem;background:linear-gradient(135deg,var(--c1),var(--c2));flex:none}
.avatar--sm{width:26px;height:26px;font-size:.8rem}
.chat__who{flex:1;line-height:1.2}
.chat__who strong{font-size:.9rem;display:block}
.chat__who small{font-size:.7rem;color:var(--muted)}
.mode-pill{font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:.3em .6em;border-radius:100px;background:var(--ink);color:var(--blush)}
.mode-pill--open{background:var(--wisteria);color:#fff}

.chat__body{flex:1;display:flex;flex-direction:column;gap:.5rem;padding:.9rem;overflow:hidden}
.bub{max-width:80%;padding:.55rem .8rem;border-radius:18px;font-size:.82rem;line-height:1.35;position:relative;animation:bubPop .5s var(--ease-out) both}
.bub--in{align-self:flex-start;background:var(--blush);border-bottom-left-radius:5px}
.bub--out{align-self:flex-end;background:var(--ink);color:var(--blush);border-bottom-right-radius:5px}
.bub--img .img-skel{display:block;width:100%;height:64px;border-radius:10px;margin-bottom:.35rem;
  background:linear-gradient(120deg,var(--powder),var(--wisteria),var(--bubblegum));background-size:200% 100%;animation:shimmer 3s linear infinite}
@keyframes bubPop{from{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:none}}
@keyframes shimmer{to{background-position:-200% 0}}
.chat__foot{padding:.7rem .9rem;font-size:.7rem;color:var(--muted);border-top:1px solid var(--line-soft);display:flex;align-items:center;gap:.4rem}

/* floating cards */
.float-card{position:absolute;background:rgba(255,255,255,.86);backdrop-filter:blur(10px);border:1px solid var(--line);border-radius:18px;padding:.8rem 1rem;box-shadow:var(--sh-md);z-index:4}
.float-card--ctrl{right:-2%;top:14%;width:210px}
.float-card--ping{left:-6%;bottom:16%;display:flex;align-items:center;gap:.6rem;width:240px}
.float-card__row{display:flex;align-items:center;gap:.55rem;margin-bottom:.7rem}
.float-card strong{font-size:.85rem;display:block;line-height:1.1}
.float-card small{font-size:.72rem;color:var(--muted)}
.dot{width:10px;height:10px;border-radius:50%;flex:none}
.dot--ok{background:#37c98b;box-shadow:0 0 0 4px rgba(55,201,139,.18)}
.mini-toggles{display:flex;gap:.35rem;flex-wrap:wrap}
.mini-tog{font-size:.66rem;font-weight:600;padding:.25em .6em;border-radius:100px;background:var(--line-soft);color:var(--muted)}
.mini-tog.on{background:var(--bubblegum);color:#fff}
.tick{margin-left:auto;width:24px;height:24px;border-radius:50%;background:var(--wisteria);color:#fff;display:grid;place-items:center;font-size:.8rem;font-weight:700}

.float{animation:floatY 6s var(--ease) infinite alternate}
.float2{animation:floatY 7s var(--ease) infinite alternate-reverse}
.float3{animation:floatY 8s var(--ease) infinite alternate}
@keyframes floatY{to{transform:translateY(-16px)}}
.phone--hero.float{animation:floatYrot 7s var(--ease) infinite alternate}
@keyframes floatYrot{from{transform:rotate(-4deg) translateY(0)}to{transform:rotate(-4deg) translateY(-16px)}}

/* ---------- MARQUEE ---------- */
.marquee{overflow:hidden;padding:1.4rem 0;border-block:1px solid var(--line);background:rgba(255,255,255,.35);
  -webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee__track{display:flex;gap:1.4rem;width:max-content;animation:scrollX 26s linear infinite;font-family:var(--font-display);font-size:clamp(1.4rem,3vw,2.4rem);font-weight:500;font-style:italic;white-space:nowrap}
.marquee__track .sep{color:var(--bubblegum);font-style:normal}
@keyframes scrollX{to{transform:translateX(-50%)}}

/* ---------- HOW ---------- */
.how{max-width:var(--maxw);margin:0 auto;padding:clamp(4rem,9vw,7rem) 0}
.steps{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;padding:0 clamp(1.2rem,4vw,2.5rem)}
.step{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:2rem 1.6rem;position:relative;overflow:hidden;transition:transform .4s var(--ease-out),box-shadow .4s}
.step:hover{transform:translateY(-6px);box-shadow:var(--sh-pink)}
.step::after{content:"";position:absolute;inset:auto -30% -40% auto;width:60%;height:60%;background:radial-gradient(circle,var(--powder),transparent 70%);opacity:.6}
.step__no{font-family:var(--font-display);font-size:2.4rem;font-weight:300;font-style:italic;color:var(--wisteria);display:block;margin-bottom:.6rem}
.step h3{font-family:var(--font-display);font-weight:500;font-size:1.3rem;margin-bottom:.5rem;position:relative}
.step p{color:var(--muted);font-size:.96rem;position:relative}
.step em{font-style:italic;color:var(--bubblegum);font-weight:600}

/* ---------- MASKING ---------- */
.masking{max-width:var(--maxw);margin:0 auto;padding:clamp(3rem,7vw,6rem) clamp(1.2rem,4vw,2.5rem);
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.masking__intro{max-width:520px}
.masking .lede{margin:1.3rem 0 2rem}
.masking .lede strong{color:var(--ink);font-weight:700}

.seg{position:relative;display:inline-flex;background:var(--cream);border:1px solid var(--line);border-radius:100px;padding:5px;margin-bottom:1.1rem}
.seg__btn{position:relative;z-index:2;border:none;background:none;cursor:pointer;font-family:var(--font-body);font-weight:600;font-size:.95rem;padding:.55em 1.5em;border-radius:100px;color:var(--muted);transition:color .3s}
.seg__btn.is-active{color:#fff}
.seg__pill{position:absolute;z-index:1;top:5px;bottom:5px;left:5px;width:calc(50% - 5px);background:var(--ink);border-radius:100px;transition:transform .4s var(--ease)}
.seg[data-mode="open"] .seg__pill{transform:translateX(100%);background:var(--wisteria)}
.masking__hint{font-size:.85rem;color:var(--muted)}
.kbd{display:inline-block;font-weight:700;background:var(--ink);color:var(--blush);padding:.1em .55em;border-radius:7px;font-size:.78rem}

.masking__stage{position:relative;display:flex;justify-content:center;align-items:center;min-height:520px}
.phone--demo{position:relative;z-index:2}
.stage-tag{position:absolute;left:50%;transform:translateX(-50%);bottom:-2.2rem;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}

/* masked bubble behaviour */
.phone--demo .bub{cursor:pointer;transition:filter .6s var(--ease),background .4s}
.phone--demo .bub .bub__txt{transition:filter .6s var(--ease)}
.bub.masked .bub__txt{filter:blur(6px);user-select:none}
.bub.masked{position:relative}
.bub.masked::after{content:"🔒";position:absolute;right:.5rem;top:50%;transform:translateY(-50%);font-size:.7rem;opacity:.45}
.bub.revealed .bub__txt{filter:none}
.bub.revealed::after{content:""}
.bub.revealed{box-shadow:0 0 0 2px var(--bubblegum),var(--sh-pink)}
.bub .seen{display:block;font-size:.62rem;font-weight:700;letter-spacing:.04em;color:var(--bubblegum);margin-top:.3rem;opacity:0;transform:translateY(4px);transition:.4s .15s}
.bub--out .seen{color:var(--powder)}
.bub.revealed .seen{opacity:1;transform:none}
/* requesting state */
.bub.requesting{animation:reqPulse 1s var(--ease) infinite}
@keyframes reqPulse{0%,100%{box-shadow:0 0 0 0 rgba(255,130,169,.5)}50%{box-shadow:0 0 0 6px rgba(255,130,169,0)}}

/* child notification device */
.child-note{position:absolute;right:-4%;bottom:-3%;z-index:3;width:230px;transform:rotate(3deg)}
.child-note__phone{background:#fff;border:1px solid var(--line);border-radius:22px;padding:.9rem;box-shadow:var(--sh-md)}
.child-note__banner{display:flex;gap:.6rem;align-items:flex-start;background:linear-gradient(135deg,#fff,var(--blush));border:1px solid var(--line);border-radius:16px;padding:.7rem;opacity:0;transform:translateY(-10px) scale(.96);transition:.5s var(--ease)}
.child-note__banner.show{opacity:1;transform:none;animation:notePop .5s var(--ease-out)}
@keyframes notePop{0%{transform:translateY(-10px) scale(.9)}60%{transform:translateY(2px) scale(1.02)}100%{transform:none}}
.child-note__banner .brand__mark.sm{width:30px;height:30px;flex:none}
.child-note__banner strong{font-size:.82rem;display:block}
.child-note__banner span{font-size:.74rem;color:var(--muted);line-height:1.25;display:block}
.child-note__cap{font-size:.72rem;color:var(--muted);text-align:center;margin-top:.6rem;font-weight:600}

/* ---------- CONTROLS ---------- */
.controls{max-width:var(--maxw);margin:0 auto;padding:clamp(4rem,9vw,7rem) 0}
.controls__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;padding:0 clamp(1.2rem,4vw,2.5rem)}
.ctrl-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;transition:transform .4s var(--ease-out),box-shadow .4s}
.ctrl-card:hover{transform:translateY(-6px);box-shadow:var(--sh-blue)}
.ctrl-card h3{font-family:var(--font-display);font-weight:500;font-size:1.25rem;margin-bottom:.4rem}
.ctrl-card p{color:var(--muted);font-size:.92rem;margin-bottom:1.3rem}
.ctrl-card--wide{grid-column:span 3;display:grid;grid-template-columns:1fr auto;align-items:center;gap:2rem}
.ctrl-card--wide p{margin-bottom:0;max-width:420px}

/* switch */
.switch{width:58px;height:32px;border-radius:100px;background:var(--line);border:none;cursor:pointer;position:relative;transition:background .3s var(--ease);vertical-align:middle}
.switch.is-on{background:var(--bubblegum)}
.switch__knob{position:absolute;top:3px;left:3px;width:26px;height:26px;border-radius:50%;background:#fff;box-shadow:0 2px 6px rgba(0,0,0,.2);transition:transform .3s var(--ease)}
.switch.is-on .switch__knob{transform:translateX(26px)}
.ctrl-card__state{margin-left:.7rem;font-weight:600;font-size:.9rem;color:var(--muted)}
.switch.is-on + .ctrl-card__state{color:var(--bubblegum)}

/* dial */
.dial{position:relative;width:180px;height:180px;flex:none;justify-self:end}
.dial svg{transform:rotate(-90deg);width:100%;height:100%}
.dial__track{fill:none;stroke:var(--line);stroke-width:14}
.dial__active{fill:none;stroke:url(#dialgrad);stroke:var(--wisteria);stroke-width:14;stroke-linecap:round;
  stroke-dasharray:100;stroke-dashoffset:100;transition:stroke-dashoffset 1.4s var(--ease)}
.dial.in .dial__active{stroke-dashoffset:46} /* ~54% of the ring lit */
.dial__center{position:absolute;inset:0;display:grid;place-content:center;text-align:center}
.dial__center strong{font-family:var(--font-display);font-size:1.5rem;color:var(--wisteria)}
.dial__center small{display:block;font-size:.78rem;color:var(--muted);font-weight:600}
.dial__moon,.dial__sun{position:absolute;font-size:1rem}
.dial__sun{top:6px;left:50%;transform:translateX(-50%)}
.dial__moon{bottom:6px;left:50%;transform:translateX(-50%)}

/* ---------- SAFETY (dark) ---------- */
.safety{background:var(--ink);color:var(--blush);margin-top:clamp(2rem,5vw,4rem);
  border-radius:clamp(28px,4vw,48px) clamp(28px,4vw,48px) 0 0;padding:clamp(4rem,9vw,7rem) 0;position:relative;overflow:hidden}
.safety::before{content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background:radial-gradient(60% 50% at 80% 0%,rgba(255,130,169,.4),transparent 60%),radial-gradient(50% 40% at 10% 100%,rgba(127,149,209,.4),transparent 60%)}
.safety__inner{max-width:var(--maxw);margin:0 auto;position:relative;padding:0 clamp(1.2rem,4vw,2.5rem)}
.safety__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:clamp(3rem,6vw,5rem)}
.safe-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:1.6rem;transition:transform .4s var(--ease-out),background .3s}
.safe-card:hover{transform:translateY(-6px);background:rgba(255,255,255,.09)}
.safe-card__ic{font-size:1.7rem;display:block;margin-bottom:.8rem}
.safe-card h3{font-family:var(--font-display);font-weight:500;font-size:1.15rem;margin-bottom:.4rem}
.safe-card p{color:rgba(255,235,231,.66);font-size:.9rem}
.pullquote{text-align:center}
.pullquote span{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:clamp(1.8rem,4.5vw,3.4rem);line-height:1.15;letter-spacing:-.02em;
  background:linear-gradient(100deg,var(--powder),var(--bubblegum),var(--wisteria));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- ACCESS ---------- */
.access{max-width:var(--maxw);margin:0 auto;padding:clamp(4rem,8vw,6rem) clamp(1.2rem,4vw,2.5rem)}
.access__card{background:linear-gradient(135deg,var(--bubblegum),var(--powder) 55%,var(--wisteria));border-radius:var(--radius-lg);padding:clamp(2.2rem,5vw,3.5rem);
  display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center;box-shadow:var(--sh-pink);position:relative;overflow:hidden}
.access__card::after{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='0.8'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.25'/%3E%3C/svg%3E");mix-blend-mode:soft-light;pointer-events:none}
.access__copy h2{font-family:var(--font-display);font-weight:500;font-size:clamp(1.8rem,3.6vw,2.7rem);line-height:1.05;color:var(--ink);margin-bottom:.6rem;position:relative}
.access__copy p{color:rgba(11,10,12,.7);max-width:380px;position:relative}
.access__form{position:relative}
.access__form input{width:100%;padding:1em 1.2em;border-radius:100px;border:1.5px solid rgba(11,10,12,.2);background:rgba(255,255,255,.85);font-family:var(--font-body);font-size:1rem;margin-bottom:.7rem;outline:none;transition:border-color .2s,box-shadow .2s}
.access__form input:focus{border-color:var(--ink);box-shadow:0 0 0 4px rgba(11,10,12,.12)}
.access__form .btn{width:100%;justify-content:center}
.access__msg{font-size:.85rem;font-weight:600;margin-top:.7rem;min-height:1.1em;color:var(--ink)}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:0 auto;padding:clamp(3rem,7vw,6rem) clamp(1.2rem,4vw,2.5rem)}
.faq__list{display:flex;flex-direction:column;gap:.7rem}
.qa{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:0 1.4rem;transition:box-shadow .3s,border-color .3s}
.qa[open]{box-shadow:var(--sh-sm);border-color:var(--wisteria)}
.qa summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.2rem 0;font-family:var(--font-display);font-weight:500;font-size:1.1rem}
.qa summary::-webkit-details-marker{display:none}
.qa__plus{position:relative;width:18px;height:18px;flex:none}
.qa__plus::before,.qa__plus::after{content:"";position:absolute;background:var(--bubblegum);border-radius:2px;transition:transform .3s var(--ease)}
.qa__plus::before{top:8px;left:0;width:18px;height:2px}
.qa__plus::after{left:8px;top:0;width:2px;height:18px}
.qa[open] .qa__plus::after{transform:rotate(90deg);opacity:0}
.qa p{color:var(--muted);padding:0 0 1.3rem;max-width:64ch;animation:fadeUp .4s var(--ease-out)}

/* ---------- FOOTER ---------- */
.footer{background:var(--ink);color:var(--blush);padding:clamp(3rem,6vw,5rem) clamp(1.2rem,4vw,2.5rem) 2rem}
.footer__big{max-width:var(--maxw);margin:0 auto 3rem;display:flex;flex-direction:column;gap:.6rem}
.brand--lg{font-size:1.8rem;color:var(--blush)}
.brand--lg .brand__mark{width:40px;height:40px}
.footer__big p{font-family:var(--font-display);font-style:italic;font-size:clamp(1.4rem,3vw,2.2rem);color:var(--powder);max-width:18ch}
.footer__cols{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.12)}
.footer__cols h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--powder);margin-bottom:1rem}
.footer__cols a{display:block;color:rgba(255,235,231,.7);font-size:.95rem;padding:.3rem 0;transition:color .2s}
.footer__cols a:hover{color:var(--blush)}
.footer__base{max-width:var(--maxw);margin:2rem auto 0;display:flex;align-items:center;justify-content:space-between;gap:1rem;font-size:.85rem;color:rgba(255,235,231,.55)}
.footer__bar{height:6px;flex:1;max-width:240px;border-radius:100px;background:linear-gradient(90deg,var(--ink),var(--wisteria),var(--bubblegum),var(--powder),var(--blush))}

/* ---------- reveal animation ---------- */
.reveal,.on-scroll{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease-out) var(--d,0s),transform .7s var(--ease-out) var(--d,0s)}
.reveal.in,.on-scroll.in{opacity:1;transform:none}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* ============================================================
   FEATURES (Check In · Stories · Group chats)
   ============================================================ */
.features{max-width:var(--maxw);margin:0 auto;padding:clamp(4rem,9vw,7rem) 0}
.features__grid{display:flex;flex-direction:column;gap:clamp(2.5rem,6vw,5rem);padding:0 clamp(1.2rem,4vw,2.5rem)}
.feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center}
.feature--rev .feature__demo{order:2}
.feature__demo{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(1.5rem,3vw,2.2rem);min-height:250px;display:flex;flex-direction:column;justify-content:center;gap:1rem;box-shadow:var(--sh-sm);position:relative;overflow:hidden}
.feature__tag{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--bubblegum);margin-bottom:.7rem}
.feature__copy h3{font-family:var(--font-display);font-weight:500;font-size:clamp(1.5rem,2.6vw,2rem);line-height:1.1;margin-bottom:.7rem}
.feature__copy p{color:var(--muted);font-size:1.02rem;max-width:46ch}
.feature__copy em{font-style:italic;color:var(--wisteria);font-weight:600}
@keyframes ringPop{from{opacity:0;transform:scale(.6)}to{opacity:1;transform:none}}
@keyframes slideIn{to{opacity:1;transform:none}}

/* Check In demo */
.mini-chat{position:relative;display:flex;flex-direction:column;gap:.55rem;padding:1.1rem;
  background:linear-gradient(180deg,#fff,var(--cream));border-radius:18px;border:1px solid var(--line);overflow:hidden;min-height:150px}
.mini-bub{height:18px;border-radius:11px;filter:blur(3px);opacity:.9}
.mini-bub.in{align-self:flex-start;width:62%;background:var(--blush)}
.mini-bub.out{align-self:flex-end;width:72%;background:var(--ink)}
.mini-bub.out.short{width:42%}
.scanner{position:absolute;left:0;right:0;top:-44px;height:44px;pointer-events:none;opacity:0;
  background:linear-gradient(180deg,transparent,rgba(127,149,209,.5),transparent);
  box-shadow:0 0 18px 2px rgba(127,149,209,.4)}
.feature.in .feature__demo--checkin .scanner{animation:scan 3.6s var(--ease) infinite}
@keyframes scan{0%{top:-44px;opacity:0}12%{opacity:1}80%{opacity:1}100%{top:100%;opacity:0}}
.checkin-alert{display:flex;gap:.6rem;align-items:center;background:#fff;border:1px solid var(--line);
  border-left:3px solid var(--bubblegum);border-radius:14px;padding:.7rem .9rem;box-shadow:var(--sh-md);opacity:0;transform:translateY(10px)}
.feature.in .checkin-alert{animation:alertIn .6s var(--ease-out) 1.2s forwards}
@keyframes alertIn{to{opacity:1;transform:none}}
.checkin-alert__ic{font-size:1.4rem;flex:none}
.checkin-alert strong{display:block;font-size:.9rem}
.checkin-alert small{font-size:.78rem;color:var(--muted)}

/* Stories demo */
.feature__demo--stories{align-items:flex-start}
.story-rings{display:flex;gap:.7rem}
.ring{width:54px;height:54px;border-radius:50%;border:3px solid transparent;
  background:linear-gradient(#fff,#fff) padding-box,conic-gradient(from 120deg,var(--r1),var(--r2),var(--r1)) border-box;
  display:grid;place-items:center;font-family:var(--font-display);font-weight:600;color:var(--ink)}
.ring--add{background:var(--cream);border:2px dashed var(--wisteria);color:var(--wisteria);font-size:1.4rem}
.feature.in .ring{animation:ringPop .5s var(--ease-out) both}
.feature.in .ring:nth-child(2){animation-delay:.08s}
.feature.in .ring:nth-child(3){animation-delay:.16s}
.feature.in .ring:nth-child(4){animation-delay:.24s}
.story-card{position:relative;width:160px;border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--sh-md)}
.story-card__img{height:120px;background:linear-gradient(135deg,var(--bubblegum),var(--powder) 50%,var(--wisteria))}
.story-card__bar{position:absolute;top:8px;left:8px;right:8px;height:4px;border-radius:4px;background:rgba(255,255,255,.45);z-index:2;overflow:hidden}
.story-card__bar span{display:block;height:100%;width:100%;background:#fff;border-radius:4px;transform-origin:left}
.feature.in .story-card__bar span{animation:deplete 5s linear infinite}
@keyframes deplete{from{transform:scaleX(1)}to{transform:scaleX(0)}}
.story-card__chips{position:absolute;bottom:7px;left:7px;z-index:2}
.chip{font-size:.66rem;font-weight:700;padding:.32em .65em;border-radius:100px;display:inline-flex;gap:.3em;align-items:center}
.chip--live{background:rgba(11,10,12,.6);color:#fff;backdrop-filter:blur(4px)}
.story-history{display:flex;gap:.5rem;flex-wrap:wrap}
.chip--ghost{background:var(--cream);border:1px solid var(--line);color:var(--muted)}
.chip--eye{background:var(--blush);color:var(--bubblegum)}

/* Group chats demo */
.feature__demo--groups{align-items:flex-start}
.group-cluster{display:flex}
.g-av{width:50px;height:50px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;
  border:3px solid var(--paper);margin-left:-14px;background:linear-gradient(135deg,var(--c1),var(--c2));font-size:1.05rem}
.g-av:first-child{margin-left:0}
.g-av--more{background:var(--ink);font-size:.85rem}
.feature.in .g-av{animation:ringPop .5s var(--ease-out) both}
.feature.in .g-av:nth-child(2){animation-delay:.08s}
.feature.in .g-av:nth-child(3){animation-delay:.16s}
.feature.in .g-av:nth-child(4){animation-delay:.24s}
.group-consent{display:flex;flex-direction:column;gap:.45rem}
.consent-row{display:flex;align-items:center;gap:.5rem;font-size:.88rem;font-weight:600;opacity:0;transform:translateX(-8px)}
.feature.in .consent-row{animation:slideIn .5s var(--ease-out) both}
.feature.in .consent-row:nth-child(1){animation-delay:.3s}
.feature.in .consent-row:nth-child(2){animation-delay:.45s}
.feature.in .consent-row:nth-child(3){animation-delay:.6s}
.consent-row .tick{width:20px;height:20px;font-size:.66rem}
.group-pill{align-self:flex-start;background:var(--ink);color:var(--blush);font-size:.78rem;font-weight:700;padding:.55em 1em;border-radius:100px;opacity:0}
.feature.in .group-pill{animation:alertIn .5s var(--ease-out) .8s forwards}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .hero{grid-template-columns:1fr;gap:1rem}
  .hero__stage{height:min(560px,90vw);margin-top:1rem}
  .phone--hero{position:relative;transform:rotate(-3deg)}
  .masking{grid-template-columns:1fr;gap:3rem}
  .masking__stage{min-height:480px;margin-bottom:1.5rem}
  .steps{grid-template-columns:1fr;max-width:520px;margin:0 auto}
  .feature{grid-template-columns:1fr;gap:1.6rem}
  .feature--rev .feature__demo{order:0}
  .controls__grid{grid-template-columns:1fr;max-width:520px;margin:0 auto}
  .ctrl-card--wide{grid-column:span 1;grid-template-columns:1fr;text-align:left}
  .dial{justify-self:start;margin-top:1rem}
  .safety__grid{grid-template-columns:1fr 1fr}
  .access__card{grid-template-columns:1fr}
}
@media (max-width:680px){
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:flex}
  .nav.open .nav__links{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:var(--cream);border-bottom:1px solid var(--line);padding:.5rem 6vw 1.2rem}
  .nav.open .nav__links a{padding:.9rem 0;border-bottom:1px solid var(--line-soft)}
  .nav.open .nav__cta{display:block;padding:0 6vw 1.2rem;background:var(--cream)}
  .nav.open .nav__cta .btn{width:100%;justify-content:center}
  .safety__grid{grid-template-columns:1fr}
  .footer__cols{grid-template-columns:1fr 1fr}
  .child-note{width:180px;right:-2%}
  .hero__actions .btn{flex:1;justify-content:center}
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal,.on-scroll{opacity:1;transform:none}
}
