/* ============================================================
   DIGITALKIDDO Learning — Conversion Funnel Stylesheet
   Premium, mobile-first, preschool-modern design system
   ============================================================ */

/* ---------- TOKENS ---------- */
:root{
  --violet:#6C4CF0; --violet-d:#5435d4; --violet-l:#8e76ff;
  --coral:#FF6A3D; --coral-d:#ee5526;
  --sun:#FFC23C; --mint:#23CFA2; --sky:#43A2FF; --pink:#FF7BAC;
  --gold:#F4A62A; --gold-d:#d98a1c; --gold-l:#FFCF5E;
  --ink:#241D3A; --slate:#5E5878; --mute:#8C87A0;
  --line:#ECE8F6; --bg:#FFFFFF;
  --cream:#FFF6EC; --lav:#F4F1FE; --mintbg:#E9FAF3;
  --radius:20px; --radius-lg:28px; --radius-sm:14px;
  --shadow-sm:0 4px 16px rgba(36,29,58,.06);
  --shadow:0 16px 44px rgba(36,29,58,.10);
  --shadow-lg:0 34px 74px rgba(36,29,58,.17);
  --maxw:1180px;
  --fd:'Fredoka',sans-serif; --fh:'Poppins',sans-serif; --fb:'Inter',sans-serif;
}

/* ---------- RESET ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--fb);color:var(--ink);background:var(--bg);
  line-height:1.65;font-size:16px;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}
svg{fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;display:block}
.stars svg,.review__stars svg,.ratingbig svg,.brand__mark svg{fill:currentColor;stroke:none}
section[id]{scroll-margin-top:84px}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}
.container--narrow{max-width:780px}

/* ---------- TYPOGRAPHY HELPERS ---------- */
h1,h2,h3,h4{font-family:var(--fh);line-height:1.2;font-weight:700;letter-spacing:-.01em}
.hl{color:var(--violet);position:relative}
.hl-u{background:linear-gradient(180deg,transparent 62%,rgba(255,194,60,.55) 62%)}
.hl-light{color:var(--sun)}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--fh);font-weight:700;font-size:15px;
  padding:14px 26px;border-radius:var(--radius-sm);
  transition:transform .18s ease,box-shadow .25s ease,background .2s ease;
  position:relative;overflow:hidden;text-align:center;line-height:1.2;
}
.btn svg{width:19px;height:19px;flex-shrink:0}
.btn:active{transform:scale(.97)}
.btn--sm{padding:11px 19px;font-size:14px}
.btn--xs{padding:11px 12px;font-size:13px;border-radius:11px}
.btn--lg{padding:17px 34px;font-size:17px;border-radius:16px}
.btn--block{width:100%}
.btn__arrow{transition:transform .2s ease}
.btn:hover .btn__arrow{transform:translateX(4px)}

.btn--primary{background:linear-gradient(135deg,#FF8254,var(--coral-d));color:#fff;
  box-shadow:0 12px 26px rgba(255,90,40,.34)}
.btn--primary:hover{transform:translateY(-3px);box-shadow:0 18px 36px rgba(255,90,40,.44)}

.btn--ghost{background:#fff;color:var(--ink);border:2px solid var(--line)}
.btn--ghost:hover{border-color:var(--violet);color:var(--violet);transform:translateY(-3px)}

/* plan 1 — clean secondary */
.btn--plan1{background:#fff;color:var(--violet);border:2px solid #DAD2FA}
.btn--plan1:hover{background:var(--violet);color:#fff;border-color:var(--violet);transform:translateY(-3px);
  box-shadow:0 14px 30px rgba(108,76,240,.32)}

/* plan 2 — high-emphasis gradient + glow pulse */
.btn--plan2{
  background:linear-gradient(135deg,var(--violet-l),var(--violet) 45%,var(--coral));
  background-size:160% 160%;color:#fff;font-size:16px;
  box-shadow:0 14px 34px rgba(108,76,240,.42);
  animation:glow2 2.6s ease-in-out infinite,grad2 6s ease infinite;
}
.btn--plan2:hover{transform:translateY(-3px) scale(1.015);
  box-shadow:0 20px 44px rgba(108,76,240,.55)}
@keyframes glow2{0%,100%{box-shadow:0 14px 34px rgba(108,76,240,.40)}
  50%{box-shadow:0 14px 40px rgba(108,76,240,.62)}}
@keyframes grad2{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* plan 3 — premium gold + shimmer sweep */
.btn--plan3{
  background:linear-gradient(135deg,var(--gold-l),var(--gold) 55%,var(--gold-d));
  color:#3a2705;text-shadow:0 1px 0 rgba(255,255,255,.3);
  box-shadow:0 14px 32px rgba(212,138,28,.46);
}
.btn--plan3::after{
  content:"";position:absolute;top:0;left:-60%;width:45%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.85),transparent);
  transform:skewX(-22deg);animation:shimmer 3.4s ease-in-out infinite;
}
.btn--plan3:hover{transform:translateY(-3px) scale(1.015);
  box-shadow:0 20px 44px rgba(212,138,28,.6)}
@keyframes shimmer{0%{left:-60%}55%,100%{left:130%}}

.btn--xs svg{width:15px;height:15px}

/* ============================================================
   ANNOUNCEMENT BAR
   ============================================================ */
.announce{background:linear-gradient(90deg,var(--violet),var(--coral));color:#fff;
  overflow:hidden;font-size:13px;font-weight:600;font-family:var(--fh)}
.announce__track{display:flex;align-items:center;white-space:nowrap;
  animation:marquee 30s linear infinite;padding:9px 0}
.announce__track span{padding:0 14px}
.announce .dot{opacity:.55;padding:0 2px}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   HEADER
   ============================================================ */
.header{position:sticky;top:0;z-index:90;background:rgba(255,255,255,.92);
  backdrop-filter:blur(12px);border-bottom:1px solid transparent;
  transition:box-shadow .25s ease,border-color .25s ease,padding .2s ease}
.header.scrolled{box-shadow:0 6px 24px rgba(36,29,58,.09);border-color:var(--line)}
.header__inner{display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:13px 0}
.header.scrolled .header__inner{padding:9px 0}

.brand{display:flex;align-items:center;gap:11px;font-family:var(--fd);
  font-weight:800;font-size:19px;color:var(--ink);flex-shrink:0;
  text-decoration:none;transition:gap .3s ease}
.brand:hover{gap:14px}
.brand__mark{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--violet) 0%,#a855f7 50%,var(--coral) 100%);
  color:#fff;box-shadow:0 6px 18px rgba(108,76,240,.38);
  transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s ease;
  animation:brandPulse 3s ease-in-out infinite}
.brand:hover .brand__mark{transform:rotate(-8deg) scale(1.12);
  box-shadow:0 10px 28px rgba(108,76,240,.52);animation-play-state:paused}
@keyframes brandPulse{0%,100%{box-shadow:0 6px 18px rgba(108,76,240,.38)}
  50%{box-shadow:0 8px 24px rgba(108,76,240,.58),0 0 0 5px rgba(108,76,240,.1)}}
.brand__name{white-space:nowrap;display:inline;line-height:1.05;
  background:linear-gradient(90deg,var(--violet),var(--coral));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;background-size:200% auto;
  transition:background-position .4s ease}
.brand:hover .brand__name{background-position:right center}
.brand__by{font-family:var(--fh);font-size:9px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;-webkit-text-fill-color:var(--violet);color:var(--violet);
  opacity:.75;margin-top:3px;background:none;-webkit-background-clip:unset;background-clip:unset}
.brand--light .brand__name{background:linear-gradient(90deg,#e0d4ff,#ffd4c2);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.brand--light .brand__by{-webkit-text-fill-color:var(--sun);color:var(--sun);opacity:.92}

.nav{display:none;gap:4px}
.nav__link{font-family:var(--fh);font-weight:500;font-size:14.5px;color:var(--slate);
  padding:8px 13px;border-radius:9px;transition:color .15s,background .15s}
.nav__link:hover{color:var(--violet);background:var(--lav)}

.header__actions{display:flex;align-items:center;gap:10px}
.lang{display:flex;align-items:center;gap:5px;border:1.6px solid var(--line);
  padding:7px 11px;border-radius:10px;font-family:var(--fh);font-weight:600;
  font-size:13px;color:var(--slate);transition:border-color .15s}
.lang:hover{border-color:var(--violet-l)}
.lang svg{width:15px;height:15px;color:var(--violet)}
.lang__opt{transition:color .15s}
.lang__opt.is-active{color:var(--violet)}
.lang__sep{opacity:.4}
.header__cta{display:none}

.burger{display:flex;flex-direction:column;gap:5px;padding:9px;border-radius:9px}
.burger span{width:22px;height:2.4px;background:var(--ink);border-radius:2px;
  transition:transform .25s,opacity .2s}
.burger.open span:nth-child(1){transform:translateY(7.4px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7.4px) rotate(-45deg)}

.mobilemenu{display:flex;flex-direction:column;gap:2px;padding:0 22px;
  max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease;
  background:#fff;border-bottom:1px solid transparent}
.mobilemenu.open{max-height:430px;padding:10px 22px 20px;border-color:var(--line)}
.mobilemenu a{font-family:var(--fh);font-weight:600;color:var(--ink);
  padding:13px 8px;border-bottom:1px solid var(--line)}
.mobilemenu a:last-child{border:none;margin-top:12px;color:#fff;justify-content:center}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;padding:34px 0 20px;overflow:hidden;
  background:linear-gradient(180deg,#FBFAFF 0%,#fff 64%)}
.hero__blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.5;z-index:0}
.hero__blob--1{width:380px;height:380px;background:#E6DEFF;top:-90px;right:-80px}
.hero__blob--2{width:320px;height:320px;background:#FFE4D6;bottom:-120px;left:-100px}
.hero__inner{position:relative;z-index:1;display:flex;flex-direction:column;gap:30px}

.pill{display:inline-flex;align-items:center;gap:8px;font-family:var(--fh);
  font-weight:600;font-size:13px;padding:7px 14px;border-radius:999px}
.pill--soft{background:#fff;border:1.5px solid var(--line);color:var(--slate);
  box-shadow:var(--shadow-sm)}
.pill__dot{width:8px;height:8px;border-radius:50%;background:var(--mint);
  box-shadow:0 0 0 4px rgba(35,207,162,.2);animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.45}}

.hero__title{font-size:clamp(2.05rem,7vw,3.5rem);margin:16px 0 14px;font-weight:800}
.hero__sub{font-size:clamp(1rem,2.4vw,1.16rem);color:var(--slate);max-width:540px}
.hero__cta{display:flex;flex-wrap:wrap;gap:13px;margin:26px 0 20px}
.hero__cta .btn{flex:1 1 auto;min-width:200px}

.hero__rating{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.stars{display:inline-flex;gap:2px;color:var(--sun)}
.stars svg{width:18px;height:18px}
.stars--lg svg{width:24px;height:24px}
.hero__rating-txt{font-size:14px;color:var(--slate)}
.hero__rating-txt strong{color:var(--ink);font-family:var(--fh)}

/* book stack mockup */
.hero__visual{display:flex;justify-content:center;align-items:center;
  perspective:1400px;padding:24px 0 8px}
.bookstack{position:relative;width:min(420px,86vw);aspect-ratio:4/3}
.bookstack__bk{position:absolute;border-radius:14px;
  box-shadow:0 18px 42px rgba(36,29,58,.32),0 4px 12px rgba(36,29,58,.18);
  border:3px solid rgba(255,255,255,.92);cursor:pointer;
  filter:brightness(1.06) contrast(1.07) saturate(1.12);
  transition:transform .45s cubic-bezier(.2,.7,.2,1),box-shadow .35s ease,filter .35s ease}
.bookstack__bk--1{width:90%;left:15%;top:4%;z-index:3;transform:rotate(-3deg);
  animation:floatBk 5s ease-in-out infinite}
.bookstack__bk--2{width:90%;left:1%;top:12%;z-index:2;transform:rotate(-15deg);
  animation:floatBk 5.4s ease-in-out infinite 1s}
.bookstack__bk--3{width:95%;right:0%;top:10%;z-index:1;transform:rotate(13deg);
  animation:floatBk 5.2s ease-in-out infinite 2s}
@keyframes floatBk{0%,100%{translate:0 0}50%{translate:0 -14px}}
/* hover the stack: pause float, lift, scale up & spread apart */
.bookstack:hover .bookstack__bk{animation-play-state:paused}
.bookstack:hover .bookstack__bk--1{transform:rotate(-1deg) translateY(-10px) scale(1.06);filter:brightness(1.1) contrast(1.08) saturate(1.15)}
.bookstack:hover .bookstack__bk--2{transform:rotate(-25deg) translate(-18px,-5px) scale(1.04);filter:brightness(1.08) contrast(1.07) saturate(1.13)}
.bookstack:hover .bookstack__bk--3{transform:rotate(23deg) translate(18px,-5px) scale(1.04);filter:brightness(1.08) contrast(1.07) saturate(1.13)}
.bookstack__bk:hover{box-shadow:0 32px 64px rgba(36,29,58,.42),0 6px 16px rgba(36,29,58,.22)}

.floatcard{position:absolute;background:#fff;border-radius:14px;
  box-shadow:var(--shadow);padding:10px 13px;display:flex;align-items:center;gap:8px;
  font-family:var(--fh);font-weight:600;font-size:12.5px;z-index:5;
  animation:bob 4s ease-in-out infinite}
.floatcard svg{width:18px;height:18px}
.floatcard--a{top:2%;left:-4%;color:var(--violet);animation-delay:0s}
.floatcard--b{bottom:12%;right:-6%;color:var(--coral);animation-delay:1.3s}
.floatcard--c{bottom:-2%;left:6%;color:var(--mint);animation-delay:.6s;flex-direction:column;gap:0;padding:10px 16px}
.floatcard--c strong{font-family:var(--fd);font-size:20px;line-height:1}
.floatcard--c span{font-size:11px;color:var(--slate)}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* trust bar */
.trustbar{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;
  margin-top:24px;padding:18px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.trustbar li{display:flex;align-items:center;gap:9px;font-family:var(--fh);
  font-weight:600;font-size:12.7px;color:var(--ink)}
.trustbar svg{width:22px;height:22px;color:var(--violet);flex-shrink:0}

/* ============================================================
   SECTION SHELL
   ============================================================ */
.section{padding:64px 0}
.section--tint-cream{background:var(--cream)}
.section--tint-lav{background:var(--lav)}
.section--tint-mint{background:var(--mintbg)}

.sectionhead{text-align:center;max-width:660px;margin:0 auto 38px}
.eyebrow{display:inline-block;font-family:var(--fh);font-weight:700;
  font-size:12.5px;letter-spacing:.09em;text-transform:uppercase;
  color:var(--violet);background:#EEEAFE;padding:6px 14px;border-radius:999px;
  margin-bottom:14px}
.eyebrow--coral{color:var(--coral-d);background:#FFE7DE}
.eyebrow--light{color:var(--sun);background:rgba(255,255,255,.14)}
.section__title{font-size:clamp(1.6rem,4.6vw,2.5rem);font-weight:800}
.section__lead{margin-top:14px;color:var(--slate);font-size:clamp(1rem,2.3vw,1.1rem)}

/* ============================================================
   GRIDS
   ============================================================ */
.grid{display:grid;gap:16px}
.grid--problems{grid-template-columns:1fr}
.grid--benefits{grid-template-columns:1fr}
.grid--why{grid-template-columns:1fr}
.grid--reviews{grid-template-columns:1fr}

/* ---------- PROBLEM CARDS ---------- */
.paincard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s}
.paincard:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.paincard__icon{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;
  background:#FFEDE6;color:var(--coral-d);margin-bottom:14px}
.paincard__icon svg{width:26px;height:26px}
.paincard h3{font-size:1.12rem;margin-bottom:6px}
.paincard p{color:var(--slate);font-size:.95rem}
.paincard--cta{background:linear-gradient(150deg,var(--violet),var(--violet-d));
  color:#fff;display:flex;flex-direction:column;justify-content:center;gap:8px;
  border:none}
.paincard__big{font-family:var(--fh);font-weight:800;
  font-size:clamp(1.3rem,2.6vw,1.55rem);line-height:1.3;letter-spacing:-.01em;color:#fff}
.paincard__link{font-family:var(--fh);font-weight:700;color:#fff;
  text-decoration:underline;text-decoration-color:var(--sun);
  text-decoration-thickness:2px;text-underline-offset:3px;
  transition:text-decoration-color .15s}
.paincard__link:hover{text-decoration-color:#fff}

/* ============================================================
   SOLUTION — how it works (3 steps)
   ============================================================ */
.steps{display:grid;grid-template-columns:1fr;gap:30px;max-width:440px;
  margin:10px auto 0}
.step{position:relative;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:34px 24px 26px;box-shadow:var(--shadow-sm);
  text-align:center;transition:transform .2s ease,box-shadow .2s ease}
.step:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.steps .reveal:nth-child(2){transition-delay:.09s}
.steps .reveal:nth-child(3){transition-delay:.18s}
.step__num{position:absolute;top:-17px;left:50%;transform:translateX(-50%);
  width:34px;height:34px;border-radius:50%;display:grid;place-items:center;
  font-family:var(--fd);font-weight:700;font-size:16px;color:#fff;
  background:linear-gradient(135deg,var(--violet),var(--coral));
  box-shadow:0 8px 18px rgba(108,76,240,.42)}
.step__ic{width:64px;height:64px;border-radius:18px;display:grid;place-items:center;
  margin:6px auto 16px}
.step__ic svg{width:31px;height:31px}
.step:nth-child(1) .step__ic{background:#EDE9FE;color:var(--violet)}
.step:nth-child(2) .step__ic{background:#FFE7DE;color:var(--coral-d)}
.step:nth-child(3) .step__ic{background:#DEF8EF;color:#11a982}
.step h3{font-size:1.14rem;margin-bottom:7px}
.step p{color:var(--slate);font-size:.95rem}
.solution__cta{text-align:center;margin-top:44px;display:flex;
  flex-direction:column;align-items:center;gap:14px}
.solution__note{font-family:var(--fh);font-weight:600;font-size:13px;color:var(--mute)}

/* ============================================================
   BENEFITS
   ============================================================ */
.benefit{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s}
.benefit:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.benefit__ic{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;
  margin-bottom:14px}
.benefit__ic svg{width:27px;height:27px}
.ic--violet{background:#EDE9FE;color:var(--violet)}
.ic--coral{background:#FFE7DE;color:var(--coral-d)}
.ic--sky{background:#E2F0FF;color:var(--sky)}
.ic--mint{background:#DEF8EF;color:#11a982}
.ic--sun{background:#FFF1CF;color:#d99a06}
.benefit h3{font-size:1.1rem;margin-bottom:6px}
.benefit p{color:var(--slate);font-size:.94rem}

/* ============================================================
   PRODUCT PREVIEW / GALLERY
   ============================================================ */
.filters{display:flex;flex-wrap:wrap;justify-content:center;gap:9px;margin-bottom:26px}
.filter{font-family:var(--fh);font-weight:600;font-size:13.5px;color:var(--slate);
  background:#fff;border:1.6px solid var(--line);padding:9px 16px;border-radius:999px;
  transition:all .16s}
.filter:hover{border-color:var(--violet-l);color:var(--violet)}
.filter.is-active{background:var(--violet);border-color:var(--violet);color:#fff;
  box-shadow:0 8px 18px rgba(108,76,240,.32)}

.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.gitem{position:relative;border-radius:var(--radius-sm);overflow:hidden;
  box-shadow:var(--shadow-sm);background:#fff;cursor:pointer;
  border:1px solid var(--line);transition:transform .2s,box-shadow .25s}
.gitem:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.gitem img{width:100%;height:230px;object-fit:cover;object-position:top center}
.gitem figcaption{position:absolute;left:9px;bottom:9px;font-family:var(--fh);
  font-weight:600;font-size:11.5px;color:var(--ink);background:rgba(255,255,255,.94);
  padding:5px 11px;border-radius:999px;box-shadow:var(--shadow-sm)}
.gitem.hide{display:none}
.gallery__hint{text-align:center;margin-top:18px;color:var(--mute);font-size:13.5px}

/* ============================================================
   PRICING
   ============================================================ */
.countdown{display:inline-flex;align-items:center;gap:8px;margin-top:18px;
  background:#fff;border:1.6px solid #FFE0B8;border-radius:999px;
  padding:8px 16px;font-family:var(--fh);font-weight:600;font-size:13.5px;
  color:var(--slate);box-shadow:var(--shadow-sm)}
.countdown svg{width:17px;height:17px;color:var(--coral-d)}
.countdown strong{font-family:var(--fd);color:var(--coral-d);font-size:15px;
  letter-spacing:.03em}

.pricing{display:grid;grid-template-columns:1fr;gap:24px;margin-top:8px;padding-top:20px}
.plan{position:relative;background:#fff;border:1.6px solid var(--line);
  border-radius:var(--radius-lg);padding:28px 24px;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column}
.plan--featured{border-color:var(--violet);
  box-shadow:0 26px 60px rgba(108,76,240,.22);
  background:linear-gradient(180deg,#FBFAFF,#fff)}
.plan--vault{border-color:var(--gold);
  box-shadow:0 26px 60px rgba(212,138,28,.20);
  background:linear-gradient(180deg,#FFFBF1,#fff)}

.plan__ribbon{position:absolute;top:0;left:50%;transform:translate(-50%,-50%);
  font-family:var(--fh);font-weight:700;font-size:12.5px;color:#fff;
  background:linear-gradient(135deg,var(--violet),var(--coral));
  padding:7px 20px;border-radius:999px;white-space:nowrap;
  box-shadow:0 10px 22px rgba(108,76,240,.4)}
.plan__ribbon--gold{background:linear-gradient(135deg,var(--gold-l),var(--gold-d));
  color:#3a2705;box-shadow:0 10px 22px rgba(212,138,28,.4)}

.plan__badge{display:inline-block;font-family:var(--fh);font-weight:700;
  font-size:11.5px;letter-spacing:.07em;text-transform:uppercase;
  padding:5px 12px;border-radius:999px;margin-bottom:12px;align-self:flex-start}
.plan__badge--starter{background:#EAF4FF;color:var(--sky)}
.plan__badge--popular{background:#EEEAFE;color:var(--violet)}
.plan__badge--vault{background:#FFF1CF;color:var(--gold-d)}

.plan__name{font-family:var(--fd);font-size:1.32rem;font-weight:700;line-height:1.25}
.plan__tag{color:var(--slate);font-size:.93rem;margin:6px 0 16px;min-height:2.6em}
.plan__price{display:flex;align-items:baseline;gap:10px}
.plan__was{font-size:1.1rem;color:var(--mute);text-decoration:line-through;
  text-decoration-color:var(--coral);text-decoration-thickness:2px}
.plan__now{font-family:var(--fd);font-weight:700;font-size:2.7rem;color:var(--ink);
  line-height:1}
.plan__save{display:inline-block;font-family:var(--fh);font-weight:700;
  font-size:12px;color:var(--coral-d);background:#FFE7DE;padding:5px 11px;
  border-radius:999px;margin:11px 0 17px;align-self:flex-start}
.plan__save--gold{color:var(--gold-d);background:#FFEFC9}

.plan .btn{margin-bottom:9px}
.plan__secure{display:flex;align-items:center;justify-content:center;gap:6px;
  font-size:11.7px;color:var(--mute);margin-bottom:18px}
.plan__secure svg{width:14px;height:14px;color:var(--mint)}

.plan__list{display:flex;flex-direction:column;gap:11px;
  border-top:1px solid var(--line);padding-top:18px;margin-bottom:18px}
.plan__list li{display:flex;align-items:flex-start;gap:9px;font-size:.91rem;
  color:var(--ink)}
.plan__list li svg{width:19px;height:19px;flex-shrink:0;margin-top:1px}
.plan__list li.yes svg{color:var(--mint)}
.plan__list li.yes.gift svg{color:var(--gold-d)}
.plan__list li.no{color:var(--mute)}
.plan__list li.no span{text-decoration:line-through;text-decoration-color:#D8D4E4}
.plan__list li.no::before{content:"—";color:#CFC9DE;font-weight:700;flex-shrink:0;
  width:19px;text-align:center}
.plan__list li.star span{font-weight:600}
.plan__foot{margin-top:auto;font-size:.86rem;color:var(--slate);
  background:var(--lav);border-radius:12px;padding:11px 13px;text-align:center;
  font-weight:500}
.plan__foot--gold{background:#FFF6E2}

/* payment trust strip */
.paytrust{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 26px;
  margin-top:30px;padding:18px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.paytrust__item{display:flex;align-items:center;gap:9px;font-family:var(--fh);
  font-weight:600;font-size:13px;color:var(--ink)}
.paytrust__item svg{width:21px;height:21px;color:var(--mint)}

/* comparison table */
.compare{margin-top:38px}
.compare__title{text-align:center;font-size:1.4rem;margin-bottom:18px}
.compare__scroll{overflow-x:auto;border-radius:var(--radius);
  border:1px solid var(--line);box-shadow:var(--shadow-sm);-webkit-overflow-scrolling:touch}
.ctable{width:100%;min-width:600px;border-collapse:collapse;background:#fff}
.ctable th,.ctable td{padding:13px 14px;text-align:center;font-size:.9rem;
  border-bottom:1px solid var(--line)}
.ctable thead th{background:#FBFAFF;font-family:var(--fh);font-size:.95rem;
  vertical-align:top;padding-top:18px;padding-bottom:16px}
.ctable thead th em{display:block;font-style:normal;font-family:var(--fd);
  font-size:1.15rem;color:var(--violet);margin-top:3px}
.ctable__feat,.ctable td:first-child{text-align:left;font-family:var(--fh);
  font-weight:600;font-size:.88rem;color:var(--ink);white-space:nowrap}
.ctable__hot{background:#F6F3FF}
.ctable thead .ctable__hot em{color:var(--violet)}
.ctable__gold{background:#FFFAEF}
.ctable thead .ctable__gold em{color:var(--gold-d)}
.ctable td svg{width:20px;height:20px;color:var(--mint);margin:0 auto}
.ctable td.ctable__gold svg{color:var(--gold-d)}
.ctable td.x{color:#C8C3D6;font-weight:700}
.ctable tbody tr:last-child td{border-bottom:none}
.ctable__cta td{padding:16px 12px;background:#fff}
.ctable__cta td.ctable__hot{background:#F6F3FF}
.ctable__cta td.ctable__gold{background:#FFFAEF}

/* ============================================================
   WHY PARENTS LOVE IT
   ============================================================ */
.whycard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s;
  text-align:center}
.whycard:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.whycard__ic{width:58px;height:58px;border-radius:50%;display:grid;place-items:center;
  margin:0 auto 14px;background:linear-gradient(135deg,#EFEBFE,#FFF0E9);color:var(--violet)}
.whycard__ic svg{width:27px;height:27px}
.whycard h3{font-size:1.08rem;margin-bottom:6px}
.whycard p{color:var(--slate);font-size:.93rem}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.ratingbig{margin-top:18px;display:flex;flex-direction:column;align-items:center;gap:6px}
.ratingbig p{font-size:14px;color:var(--slate)}
.ratingbig strong{font-family:var(--fd);font-size:17px;color:var(--ink)}

.review{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:13px}
.review__stars{display:flex;gap:2px;color:var(--sun)}
.review__stars svg{width:17px;height:17px}
.review p{font-size:.97rem;color:var(--ink);line-height:1.6}
.review__by{display:flex;align-items:center;gap:11px;margin-top:auto}
.avatar{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;
  font-family:var(--fd);font-weight:700;font-size:15px;color:#fff;flex-shrink:0}
.avatar--violet{background:linear-gradient(135deg,var(--violet),var(--violet-l))}
.avatar--coral{background:linear-gradient(135deg,var(--coral),#ff9a6b)}
.avatar--sky{background:linear-gradient(135deg,var(--sky),#7ec4ff)}
.avatar--mint{background:linear-gradient(135deg,#16b98c,var(--mint))}
.review__by strong{font-family:var(--fh);font-size:.96rem;display:block}
.review__by em{font-style:normal;font-size:.82rem;color:var(--mute)}

/* ============================================================
   FAQ
   ============================================================ */
.faq{display:flex;flex-direction:column;gap:12px}
.faq__item{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);
  box-shadow:var(--shadow-sm);overflow:hidden}
.faq__item summary{list-style:none;cursor:pointer;padding:18px 20px;
  font-family:var(--fh);font-weight:600;font-size:1rem;display:flex;
  align-items:center;justify-content:space-between;gap:14px}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";font-family:var(--fd);font-size:24px;
  color:var(--violet);flex-shrink:0;transition:transform .25s;line-height:1}
.faq__item[open] summary::after{transform:rotate(45deg)}
.faq__item[open] summary{color:var(--violet)}
.faq__a{padding:0 20px 18px;color:var(--slate);font-size:.95rem}

/* ============================================================
   FINAL CTA
   ============================================================ */
.finalcta{position:relative;overflow:hidden;padding:66px 0;
  background:linear-gradient(155deg,#2A2150,#3a2470 55%,#5a2f7a);color:#fff}
.finalcta__blob{position:absolute;width:460px;height:460px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,106,61,.4),transparent 70%);
  top:-160px;right:-120px;filter:blur(20px)}
.finalcta__inner{position:relative;z-index:1;text-align:center}
.finalcta__title{font-size:clamp(1.7rem,5vw,2.7rem);font-weight:800;margin-bottom:14px}
.finalcta__sub{color:rgba(255,255,255,.82);max-width:620px;margin:0 auto 34px;
  font-size:clamp(1rem,2.3vw,1.1rem)}

.finalcta__cards{display:grid;grid-template-columns:1fr;gap:16px;
  max-width:920px;margin:0 auto}
.ocard{position:relative;background:rgba(255,255,255,.07);
  border:1.6px solid rgba(255,255,255,.16);border-radius:var(--radius);
  padding:24px 20px;display:flex;flex-direction:column;gap:5px;text-align:center;
  transition:transform .2s,box-shadow .25s,background .2s;backdrop-filter:blur(4px)}
.ocard:hover{transform:translateY(-5px);background:rgba(255,255,255,.12)}
.ocard--2{border-color:var(--violet-l);background:rgba(142,118,255,.16);
  box-shadow:0 18px 44px rgba(108,76,240,.4)}
.ocard--3{border-color:var(--gold);background:rgba(244,166,42,.13);
  box-shadow:0 18px 44px rgba(212,138,28,.34)}
.ocard__flag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  font-family:var(--fh);font-weight:700;font-size:11.5px;color:#fff;
  background:linear-gradient(135deg,var(--violet),var(--coral));
  padding:5px 15px;border-radius:999px;white-space:nowrap}
.ocard__flag--gold{background:linear-gradient(135deg,var(--gold-l),var(--gold-d));
  color:#3a2705}
.ocard__label{font-family:var(--fh);font-weight:700;font-size:11.5px;
  letter-spacing:.08em;text-transform:uppercase;color:var(--sun)}
.ocard--2 .ocard__label{color:var(--violet-l)}
.ocard__name{font-family:var(--fd);font-size:1.16rem;font-weight:700;margin-top:2px}
.ocard__price{font-family:var(--fd);font-size:1.7rem;font-weight:700;margin:4px 0 12px}
.ocard__price s{font-size:1rem;opacity:.55;font-weight:500;margin-right:6px}
.ocard__btn{display:block;font-family:var(--fh);font-weight:700;font-size:14.5px;
  padding:13px 16px;border-radius:12px;background:#fff;color:var(--ink);
  transition:transform .18s}
.ocard--1 .ocard__btn{background:#fff;color:var(--ink)}
.ocard--2 .ocard__btn{background:linear-gradient(135deg,var(--violet-l),var(--coral));
  color:#fff;box-shadow:0 12px 26px rgba(108,76,240,.5)}
.ocard--3 .ocard__btn{background:linear-gradient(135deg,var(--gold-l),var(--gold-d));
  color:#3a2705;box-shadow:0 12px 26px rgba(212,138,28,.5)}
.ocard:hover .ocard__btn{transform:scale(1.03)}

.finalcta__trust{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 24px;
  margin-top:30px}
.finalcta__trust li{display:flex;align-items:center;gap:8px;font-size:13px;
  font-family:var(--fh);font-weight:600;color:rgba(255,255,255,.9)}
.finalcta__trust svg{width:19px;height:19px;color:var(--sun)}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:#1C1730;color:rgba(255,255,255,.7);padding:48px 0 0}
.footer__inner{display:grid;grid-template-columns:1fr;gap:30px}
.footer__brand .brand{margin-bottom:13px}
.footer__brand p{font-size:.92rem;max-width:330px}
.footer__pay{display:flex;align-items:center;gap:9px;margin-top:15px;
  font-family:var(--fh);font-weight:600;font-size:12.5px;color:rgba(255,255,255,.85)}
.footer__pay svg{width:20px;height:20px;color:var(--mint)}
.footer__col h4{font-family:var(--fh);color:#fff;font-size:1rem;margin-bottom:13px}
.footer__col a{display:block;font-size:.9rem;padding:5px 0;
  transition:color .15s}
.footer__col a:hover{color:#fff}
.footer__mail{display:flex;align-items:center;gap:7px;color:var(--sun)!important}
.footer__mail svg{width:16px;height:16px}
.footer__note{font-size:.84rem;margin-top:7px}
.footer__bar{border-top:1px solid rgba(255,255,255,.1);margin-top:40px;
  padding:18px 0}
.footer__barin{display:flex;flex-direction:column;gap:6px;
  font-size:.8rem;color:rgba(255,255,255,.5)}
.footer__disc{font-size:.76rem}

/* ============================================================
   MOBILE STICKY CTA
   ============================================================ */
.stickycta{position:fixed;left:0;right:0;bottom:0;z-index:80;
  display:flex;align-items:center;gap:12px;padding:11px 14px;
  background:rgba(255,255,255,.97);backdrop-filter:blur(10px);
  border-top:1px solid var(--line);box-shadow:0 -8px 26px rgba(36,29,58,.13);
  transform:translateY(130%);transition:transform .35s ease}
.stickycta.show{transform:translateY(0)}
.stickycta__info{display:flex;flex-direction:column;line-height:1.25;flex-shrink:0}
.stickycta__from{font-size:10.5px;font-family:var(--fh);font-weight:600;
  color:var(--slate);text-transform:uppercase;letter-spacing:.04em}
.stickycta__price{font-family:var(--fd);font-weight:700;font-size:17px;color:var(--ink)}
.stickycta__price s{font-size:12px;color:var(--mute);font-weight:500;margin-right:4px}
.stickycta__btn{flex:1;font-size:14.5px;padding:13px 14px}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(20,15,38,.9);
  display:none;align-items:center;justify-content:center;padding:30px;
  backdrop-filter:blur(4px)}
.lightbox.open{display:flex}
.lightbox img{max-width:94%;max-height:88vh;border-radius:14px;
  border:5px solid #fff;box-shadow:var(--shadow-lg)}
.lightbox__close{position:absolute;top:18px;right:22px;width:46px;height:46px;
  border-radius:50%;background:rgba(255,255,255,.16);color:#fff;font-size:30px;
  line-height:1;display:grid;place-items:center}
.lightbox__close:hover{background:rgba(255,255,255,.28)}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(28px);
  transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.grid .reveal:nth-child(2),.pricing .reveal:nth-child(2){transition-delay:.08s}
.grid .reveal:nth-child(3),.pricing .reveal:nth-child(3){transition-delay:.16s}
.grid .reveal:nth-child(4){transition-delay:.24s}
.grid .reveal:nth-child(5){transition-delay:.32s}
.grid .reveal:nth-child(6){transition-delay:.40s}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;animation-iteration-count:1!important;
    transition-duration:.001s!important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}

/* ============================================================
   RESPONSIVE — TABLET
   ============================================================ */
@media (min-width:600px){
  .container{padding:0 30px}
  .grid--problems{grid-template-columns:repeat(2,1fr)}
  .grid--benefits{grid-template-columns:repeat(2,1fr)}
  .grid--why{grid-template-columns:repeat(2,1fr)}
  .grid--reviews{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(3,1fr)}
  .trustbar{grid-template-columns:repeat(4,1fr)}
  .hero__cta .btn{flex:0 1 auto}
  .finalcta__cards{grid-template-columns:repeat(3,1fr)}
}

/* ============================================================
   RESPONSIVE — DESKTOP
   ============================================================ */
@media (min-width:960px){
  body{font-size:16.5px}
  .section{padding:92px 0}
  .nav{display:flex}
  .header__cta{display:inline-flex}
  .burger{display:none}
  .mobilemenu{display:none}
  .stickycta{display:none}

  .hero{padding:54px 0 30px}
  .hero__inner{display:grid;grid-template-columns:1.05fr .95fr;
    align-items:center;gap:40px}
  .hero__visual{padding:0}
  .bookstack{width:min(440px,42vw)}
  .trustbar{margin-top:44px}

  .grid--problems{grid-template-columns:repeat(3,1fr)}
  .grid--benefits{grid-template-columns:repeat(4,1fr)}
  .grid--why{grid-template-columns:repeat(3,1fr)}
  .grid--reviews{grid-template-columns:repeat(3,1fr)}
  .grid{gap:22px}

  .steps{grid-template-columns:repeat(3,1fr);max-width:960px;gap:24px}

  .gallery{grid-template-columns:repeat(4,1fr)}
  .gitem img{height:250px}

  .pricing{grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}
  .plan--featured{transform:scale(1.045);z-index:2}
  .plan--featured:hover{transform:scale(1.045) translateY(-4px)}
  .plan{transition:transform .2s,box-shadow .25s}
  .plan:not(.plan--featured):hover{transform:translateY(-5px);box-shadow:var(--shadow)}

  .sectionhead{margin-bottom:52px}
  .footer__inner{grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:36px}
  .footer__barin{flex-direction:row;justify-content:space-between;align-items:center}
}
