/* =====================================================================
   The Happy Kitten - Design System
   Palette sampled from the book cover + logo:
     blush  #EBC8CC   raspberry #DA1C5C   lemon #FFD93D
     charcoal-brown #443735   cream #FFF7F4   white #FFFFFF
   ===================================================================== */

:root{
  --pink-50:#FFF7F4;
  --pink-100:#FDEBEF;
  --pink-200:#F8D7DE;
  --pink-300:#EBC8CC;   /* cover blush */
  --pink-400:#F08CAE;
  --rasp:#DA1C5C;       /* primary brand */
  --rasp-dark:#B71449;
  --rasp-700:#9C1140;
  --lemon:#FFD93D;      /* accent */
  --lemon-dark:#F2C200;
  --ink:#443735;        /* charcoal brown (kitten outline) */
  --ink-soft:#6B5B58;
  --muted:#8A7C79;
  --line:#F0DDE2;
  --white:#fff;
  --ok:#1F9D6B;

  --radius:18px;
  --radius-lg:28px;
  --radius-sm:11px;
  --shadow-sm:0 2px 8px rgba(68,55,53,.07);
  --shadow:0 14px 38px -12px rgba(218,28,92,.26);
  --shadow-lg:0 30px 70px -24px rgba(68,55,53,.32);
  --maxw:1140px;
  --font-head:"Baloo 2","Quicksand",system-ui,sans-serif;
  --font-body:"Nunito",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --ease:cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
/* offset in-page anchors so they clear the sticky header */
:where(h1,h2,h3,h4,[id]){scroll-margin-top:96px}
h1,h2,h3,h4{overflow-wrap:break-word}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
  html{scroll-behavior:auto}
  .reveal{opacity:1!important;transform:none!important}
}
body{
  margin:0;font-family:var(--font-body);color:var(--ink);
  background:var(--pink-50);font-size:18px;line-height:1.7;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
h1,h2,h3,h4{font-family:var(--font-head);line-height:1.12;color:var(--ink);font-weight:800;margin:0 0 .5em}
h1{font-size:clamp(2.1rem,5.4vw,3.7rem);letter-spacing:-.5px}
h2{font-size:clamp(1.7rem,3.6vw,2.6rem)}
h3{font-size:clamp(1.25rem,2.2vw,1.55rem)}
p{margin:0 0 1.1em}
a{color:var(--rasp);text-decoration:none;transition:color .15s}
a:hover{color:var(--rasp-dark)}
img{max-width:100%;display:block;height:auto}
strong{font-weight:800;color:var(--ink)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.narrow{max-width:780px;margin-inline:auto}
section{padding:clamp(48px,7vw,92px) 0}
.center{text-align:center}
.eyebrow{display:inline-block;font-family:var(--font-head);font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;font-size:.78rem;color:var(--rasp);background:var(--pink-100);
  padding:7px 15px;border-radius:999px;margin-bottom:18px}
.lead{font-size:1.2rem;color:var(--ink-soft)}
.tilt{display:inline-block;transform:rotate(-2deg)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--font-head);font-weight:800;
  font-size:1.05rem;line-height:1;padding:17px 30px;border-radius:999px;border:0;cursor:pointer;
  transition:transform .15s var(--ease),box-shadow .2s,background .2s;text-align:center;white-space:nowrap}
.btn-primary{background:var(--rasp);color:#fff;box-shadow:0 10px 24px -8px rgba(218,28,92,.6)}
.btn-primary:hover{background:var(--rasp-dark);color:#fff;transform:translateY(-2px);box-shadow:0 16px 30px -8px rgba(218,28,92,.7)}
.btn-lemon{background:var(--lemon);color:var(--ink);box-shadow:0 10px 22px -8px rgba(242,194,0,.7)}
.btn-lemon:hover{background:var(--lemon-dark);color:var(--ink);transform:translateY(-2px)}
.btn-ghost{background:#fff;color:var(--rasp);box-shadow:inset 0 0 0 2px var(--pink-200)}
.btn-ghost:hover{background:var(--pink-50);color:var(--rasp-dark);box-shadow:inset 0 0 0 2px var(--pink-300)}
.btn-lg{font-size:1.2rem;padding:21px 40px}
.btn-block{display:flex;width:100%;justify-content:center;white-space:normal}
.btn small{font-weight:600;opacity:.85;font-family:var(--font-body)}

/* ---------- Header / Nav ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,247,244,.86);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-head);font-weight:800;
  font-size:1.28rem;color:var(--rasp)}
.brand:hover{color:var(--rasp)}
.brand img{width:42px;height:42px;border-radius:50%;box-shadow:0 0 0 3px #fff,0 4px 10px rgba(68,55,53,.15)}
.nav-links{display:flex;align-items:center;gap:6px;list-style:none;margin:0;padding:0}
.nav-links a{font-family:var(--font-head);font-weight:700;font-size:1rem;color:var(--ink);
  padding:9px 14px;border-radius:999px}
.nav-links a:hover{background:var(--pink-100);color:var(--rasp)}
.nav-links a.cta{background:var(--rasp);color:#fff;padding:11px 20px}
.nav-links a.cta:hover{background:var(--rasp-dark)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;color:var(--ink)}
.nav-toggle svg{width:28px;height:28px}
@media(max-width:880px){
  .nav-toggle{display:block}
  .nav-links{position:absolute;top:72px;left:0;right:0;flex-direction:column;align-items:stretch;
    gap:4px;background:var(--pink-50);padding:14px 22px 22px;border-bottom:1px solid var(--line);
    box-shadow:var(--shadow);transform:translateY(-12px);opacity:0;pointer-events:none;transition:.2s}
  .nav-links.open{transform:none;opacity:1;pointer-events:auto}
  .nav-links a{padding:13px 14px}
}

/* ---------- Hero ---------- */
.hero{position:relative;background:
  radial-gradient(1200px 500px at 80% -10%,var(--pink-200),transparent 60%),
  linear-gradient(180deg,var(--pink-100),var(--pink-50));overflow:hidden}
.hero::before,.hero::after{content:"";position:absolute;border-radius:50%;filter:blur(6px);opacity:.5;z-index:0}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;
  padding:clamp(40px,6vw,86px) 0}
.hero h1{margin-bottom:.35em}
.hero .lead{font-size:1.3rem;max-width:33ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin:28px 0 18px}
.hero-art{position:relative;text-align:center}
.hero-art img{margin-inline:auto;filter:drop-shadow(0 30px 50px rgba(68,55,53,.25))}
.trust{display:flex;align-items:center;gap:16px;flex-wrap:wrap;color:var(--ink-soft);font-size:.96rem;font-weight:700}
.stars{color:#FF9F1C;letter-spacing:2px;font-size:1.1rem}
@media(max-width:820px){.hero-grid{grid-template-columns:1fr;text-align:center}
  .hero .lead{margin-inline:auto}.hero-cta{justify-content:center}.trust{justify-content:center}
  .hero-art{order:-1}.hero-art img{max-width:280px}}

/* ---------- Cards / grids ---------- */
.grid{display:grid;gap:26px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.g-3,.g-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.g-2,.g-3,.g-4{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;
  box-shadow:var(--shadow-sm);transition:transform .2s var(--ease),box-shadow .2s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .ic{width:54px;height:54px;display:grid;place-items:center;border-radius:14px;
  background:var(--pink-100);font-size:1.6rem;margin-bottom:14px}
.card h3{margin-bottom:.35em}
.card p{margin:0;color:var(--ink-soft);font-size:1rem}

/* ---------- Sections helpers ---------- */
.bg-pink{background:var(--pink-100)}
.bg-rasp{background:linear-gradient(135deg,var(--rasp),var(--rasp-700));color:#fff}
.bg-rasp h1,.bg-rasp h2,.bg-rasp h3{color:#fff}
.bg-rasp p{color:rgba(255,255,255,.92)}
.bg-cream{background:var(--pink-50)}
.section-head{max-width:640px;margin:0 auto 46px;text-align:center}
.section-head p{color:var(--ink-soft);font-size:1.12rem;margin:0}

/* ---------- Pillars / list checks ---------- */
.checks{list-style:none;margin:0;padding:0;display:grid;gap:13px}
.checks li{position:relative;padding-left:38px;font-size:1.06rem}
.checks li::before{content:"";position:absolute;left:0;top:2px;width:24px;height:24px;border-radius:50%;
  background:var(--rasp);color:#fff;
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/16px no-repeat;
  mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/16px no-repeat}
.checks.on-dark li::before{background:var(--lemon)}

/* ---------- Offer / pricing card ---------- */
.offer{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);
  border:1px solid var(--line);overflow:hidden;max-width:560px;margin-inline:auto}
.offer-head{background:var(--pink-100);padding:26px 30px;text-align:center;border-bottom:1px solid var(--line)}
.offer-body{padding:30px}
.price{font-family:var(--font-head);font-weight:800;color:var(--rasp);font-size:3rem;line-height:1}
.price s{color:var(--muted);font-size:1.3rem;font-weight:700;margin-right:10px}
.price-note{color:var(--muted);font-size:.95rem}
.badge{display:inline-block;background:var(--lemon);color:var(--ink);font-family:var(--font-head);
  font-weight:800;font-size:.85rem;padding:6px 14px;border-radius:999px;transform:rotate(-2deg)}

/* order bump */
.bump{border:2px dashed var(--rasp);background:var(--pink-50);border-radius:var(--radius-sm);
  padding:16px 18px;margin:18px 0;display:flex;gap:14px;align-items:flex-start;cursor:pointer}
.bump input{margin-top:4px;width:22px;height:22px;accent-color:var(--rasp);flex:none}
.bump b{color:var(--rasp)}
.bump .small{font-size:.92rem;color:var(--ink-soft);margin:4px 0 0}

/* guarantee strip */
.guarantee{display:flex;gap:16px;align-items:center;background:var(--pink-50);
  border:1px solid var(--line);border-radius:var(--radius);padding:18px 22px}
.guarantee .seal{flex:none;width:58px;height:58px;border-radius:50%;background:var(--lemon);
  display:grid;place-items:center;font-size:1.6rem}

/* ---------- Forms ---------- */
.field{margin-bottom:16px}
.field label{display:block;font-family:var(--font-head);font-weight:700;margin-bottom:6px;font-size:.98rem}
.field input,.field textarea,.field select{width:100%;padding:14px 16px;border:2px solid var(--line);
  border-radius:var(--radius-sm);font:inherit;background:#fff;color:var(--ink);transition:border .15s}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--rasp)}
.optin{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(26px,4vw,42px);box-shadow:var(--shadow);max-width:560px;margin-inline:auto}
.inline-form{display:flex;gap:10px}
.inline-form input{flex:1}
@media(max-width:520px){.inline-form{flex-direction:column}}
.form-note{font-size:.86rem;color:var(--muted);margin:10px 0 0;text-align:center}
.form-msg{margin-top:12px;font-weight:700;display:none}
.form-msg.ok{display:block;color:var(--ok)}
.form-msg.err{display:block;color:var(--rasp-dark)}

/* ---------- FAQ ---------- */
.faq{max-width:780px;margin-inline:auto}
.faq details{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);
  margin-bottom:12px;overflow:hidden}
.faq summary{cursor:pointer;list-style:none;padding:18px 22px;font-family:var(--font-head);
  font-weight:700;font-size:1.08rem;display:flex;justify-content:space-between;gap:16px;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--rasp);font-size:1.5rem;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .ans{padding:0 22px 20px;color:var(--ink-soft)}
.faq .ans p{margin:0}

/* ---------- Testimonials ---------- */
.quote{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;
  box-shadow:var(--shadow-sm)}
.quote .stars{margin-bottom:10px}
.quote p{font-size:1.04rem;font-style:italic;color:var(--ink)}
.quote .who{display:flex;align-items:center;gap:11px;margin-top:14px;font-weight:800;font-family:var(--font-head)}
.quote .who span{width:38px;height:38px;border-radius:50%;background:var(--pink-200);display:grid;
  place-items:center;color:var(--rasp);font-size:1rem}
.quote .who small{display:block;font-family:var(--font-body);font-weight:600;color:var(--muted)}

/* ---------- Blog ---------- */
.post-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.post-card .thumb{aspect-ratio:16/10;background:var(--pink-100) center/cover}
.post-card .pc-body{padding:22px;display:flex;flex-direction:column;flex:1}
.tag{font-family:var(--font-head);font-weight:700;font-size:.74rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--rasp);margin-bottom:8px}
.post-card h3{font-size:1.2rem;margin-bottom:.4em}
.post-card p{font-size:.97rem;color:var(--ink-soft);margin:0 0 16px}
.post-card .more{margin-top:auto;font-family:var(--font-head);font-weight:800}

/* article */
.article{background:#fff}
.article-hero{background:linear-gradient(180deg,var(--pink-100),var(--pink-50));
  padding:clamp(34px,5vw,60px) 0 clamp(28px,4vw,42px)}
.article-meta{display:flex;gap:14px;align-items:center;color:var(--muted);font-weight:700;
  font-size:.92rem;margin-top:14px;flex-wrap:wrap}
.article-body{font-size:1.12rem;line-height:1.8}
.article-body h2{margin-top:1.7em}
.article-body h3{margin-top:1.4em}
.article-body img{border-radius:var(--radius);margin:1.6em 0;box-shadow:var(--shadow-sm)}
.article-body ul,.article-body ol{padding-left:1.3em;margin:0 0 1.2em}
.article-body li{margin-bottom:.5em}
.article-body blockquote{margin:1.5em 0;padding:6px 0 6px 22px;border-left:5px solid var(--rasp);
  font-family:var(--font-head);font-style:italic;color:var(--ink);font-size:1.15rem}
.toc{background:var(--pink-50);border:1px solid var(--line);border-radius:var(--radius);padding:20px 24px;margin:0 0 30px}
.toc strong{font-family:var(--font-head)}
.toc ul{margin:8px 0 0;padding-left:18px}
.kicker-img{aspect-ratio:16/8;background:center/cover;border-radius:var(--radius);margin-top:24px}

/* in-article CTA */
.cta-box{background:linear-gradient(135deg,var(--rasp),var(--rasp-700));color:#fff;
  border-radius:var(--radius-lg);padding:clamp(26px,4vw,40px);margin:2.4em 0;box-shadow:var(--shadow);
  display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:center}
.cta-box img{width:130px;border-radius:10px;box-shadow:0 14px 30px rgba(0,0,0,.3)}
.cta-box h3{color:#fff;margin-bottom:.3em}
.cta-box p{color:rgba(255,255,255,.92);margin-bottom:1em;font-size:1rem}
@media(max-width:560px){.cta-box{grid-template-columns:1fr;text-align:center}.cta-box img{margin-inline:auto}}

/* author box */
.author{display:flex;gap:18px;align-items:center;background:var(--pink-50);border:1px solid var(--line);
  border-radius:var(--radius);padding:22px;margin:2.4em 0 0}
.author img{width:72px;height:72px;border-radius:50%;flex:none}
.author h4{margin:0 0 4px;font-family:var(--font-head)}
.author p{margin:0;font-size:.96rem;color:var(--ink-soft)}

/* ---------- Steps / funnel viz ---------- */
.steps{counter-reset:s;display:grid;gap:18px}
.step{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start;background:#fff;
  border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px}
.step::before{counter-increment:s;content:counter(s);font-family:var(--font-head);font-weight:800;
  width:46px;height:46px;border-radius:50%;background:var(--rasp);color:#fff;display:grid;place-items:center;font-size:1.3rem}
.step h3{margin:0 0 4px}
.step p{margin:0;color:var(--ink-soft);font-size:1rem}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:#EAD9D6;padding:60px 0 28px;font-size:.97rem}
.site-footer a{color:#F4C9D4}
.site-footer a:hover{color:#fff}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:36px}
.foot-grid h4{color:#fff;font-size:1.05rem;margin-bottom:14px}
.foot-grid ul{list-style:none;margin:0;padding:0;display:grid;gap:9px}
.foot-brand img{width:44px;border-radius:50%}
.foot-bottom{border-top:1px solid rgba(255,255,255,.13);margin-top:42px;padding-top:22px;
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:#C9B6B2;font-size:.86rem}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}

/* ---------- Announcement bar ---------- */
.topbar{background:var(--ink);color:#fff;text-align:center;font-size:.9rem;font-weight:700;
  padding:9px 16px;font-family:var(--font-head)}
.topbar a{color:var(--lemon);text-decoration:underline}

/* ---------- Utility ---------- */
.mt-0{margin-top:0}.mb-0{margin-bottom:0}.mt-1{margin-top:14px}.mt-2{margin-top:26px}.mt-3{margin-top:40px}
.pill-row{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:18px}
.pill{background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 16px;font-weight:700;
  font-size:.92rem;color:var(--ink-soft)}
.hide{display:none!important}
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.in{opacity:1;transform:none}
.skip{position:absolute;left:-999px}.skip:focus{left:12px;top:12px;background:#fff;padding:10px;z-index:200;border-radius:8px}
