/*
Theme Name: Kozykids Grove
Theme URI: https://example.com/kozykids-grove
Author: Kozykids Grove
Author URI: https://example.com
Description: Lightweight custom landing-page theme for Kozykids Grove — premium kids fashion in Accra, Ghana. WhatsApp-driven conversions with WooCommerce-ready markup.
Version: 1.0.1
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: kozykids-grove
*/


/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root{
  --grape:#5a2d9c;
  --grape-deep:#3c1d6e;
  --grape-soft:#7a4fc0;
  --cream:#fbf4ec;
  --cream-2:#f3e7d8;
  --ink:#2a1b3d;
  --ink-soft:#5e5168;
  --coral:#ff6a4d;
  --coral-deep:#ed4f30;
  --gold:#ffc24b;
  --mint:#8fd6b4;
  --mint-deep:#3fae84;
  --blush:#ffd9ce;
  --wa:#25d366;
  --wa-deep:#128c7e;
  --white:#ffffff;

  --shadow-sm:0 4px 14px -6px rgba(60,29,110,.18);
  --shadow-md:0 18px 40px -18px rgba(60,29,110,.30);
  --shadow-lg:0 40px 80px -30px rgba(60,29,110,.42);
  --shadow-coral:0 18px 38px -14px rgba(237,79,48,.55);

  --r-sm:14px;
  --r-md:22px;
  --r-lg:34px;
  --r-xl:48px;

  --ease:cubic-bezier(.22,.68,.28,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --maxw:1200px;

  --font-display:"Fraunces",Georgia,serif;
  --font-body:"Plus Jakarta Sans",system-ui,sans-serif;
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  font-family:var(--font-body);
  background:var(--cream);
  color:var(--ink);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
input,textarea,select{font-family:inherit;font-size:1rem;}
ul{list-style:none;}
::selection{background:var(--coral);color:#fff;}

h1,h2,h3,.display{
  font-family:var(--font-display);
  font-weight:600;
  font-variation-settings:"opsz" 144,"SOFT" 50,"WONK" 0;
  line-height:1.04;
  letter-spacing:-.01em;
  color:var(--ink);
}
.wonk{font-variation-settings:"opsz" 144,"SOFT" 80,"WONK" 1;}

/* Grain overlay for premium texture */
body::after{
  content:"";position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ============================================================
   LAYOUT HELPERS
   ============================================================ */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(20px,5vw,40px);}
section{position:relative;}
.eyebrow{
  display:inline-flex;align-items:center;gap:.5em;
  font-size:.74rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--grape);
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--coral);border-radius:2px;}
.section-head{max-width:660px;margin-bottom:clamp(36px,6vw,64px);}
.section-head h2{font-size:clamp(2.1rem,5.4vw,3.6rem);margin:.35em 0 .35em;}
.section-head p{color:var(--ink-soft);font-size:clamp(1rem,2.3vw,1.12rem);}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  font-weight:700;font-size:1rem;letter-spacing:.01em;
  padding:1rem 1.7rem;border-radius:999px;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s;
  will-change:transform;position:relative;white-space:nowrap;
}
.btn svg{width:1.1em;height:1.1em;transition:transform .35s var(--ease);}
.btn:hover{transform:translateY(-3px);}
.btn:active{transform:translateY(-1px) scale(.99);}
.btn--primary{background:var(--coral);color:#fff;box-shadow:var(--shadow-coral);}
.btn--primary:hover{background:var(--coral-deep);box-shadow:0 24px 46px -14px rgba(237,79,48,.6);}
.btn--primary:hover svg{transform:translateX(4px);}
.btn--wa{background:var(--wa);color:#04331f;box-shadow:0 16px 34px -12px rgba(37,211,102,.6);}
.btn--wa:hover{background:#1ec45c;}
.btn--ghost{background:rgba(255,255,255,.55);color:var(--ink);border:1.5px solid rgba(90,45,156,.18);backdrop-filter:blur(8px);}
.btn--ghost:hover{background:#fff;border-color:var(--grape);}
.btn--lg{padding:1.15rem 2.1rem;font-size:1.06rem;}

/* ============================================================
   NAVBAR
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:background .4s,box-shadow .4s,padding .4s;
  padding:18px 0;
}
.nav.scrolled{
  background:rgba(251,244,236,.82);
  backdrop-filter:blur(16px) saturate(1.4);
  box-shadow:0 8px 30px -16px rgba(60,29,110,.35);
  padding:11px 0;
}
.nav__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--font-display);font-weight:700;font-size:1.32rem;font-variation-settings:"SOFT" 70,"WONK" 1;color:var(--grape-deep);}
.brand__mark{
  width:66px;height:66px;border-radius:17px;display:grid;place-items:center;flex:0 0 auto;
  background:#fff;padding:3px;box-shadow:var(--shadow-sm);overflow:hidden;
}
.brand__mark img{width:100%;height:100%;object-fit:contain;display:block;}
.nav__links{display:flex;align-items:center;gap:2rem;}
.nav__links a{font-weight:600;font-size:.96rem;color:var(--ink);position:relative;padding:.2rem 0;transition:color .25s;}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--coral);border-radius:2px;transition:width .3s var(--ease);}
.nav__links a:hover{color:var(--grape);}
.nav__links a:hover::after{width:100%;}
.nav__cta{display:flex;align-items:center;gap:.8rem;}
.nav__burger{display:none;width:46px;height:46px;border-radius:12px;background:rgba(255,255,255,.6);border:1.5px solid rgba(90,45,156,.16);}
.nav__burger span{display:block;width:20px;height:2px;background:var(--ink);margin:4px auto;border-radius:2px;transition:.3s;}
.nav__burger.open span:nth-child(1){transform:translateY(6px) rotate(45deg);}
.nav__burger.open span:nth-child(2){opacity:0;}
.nav__burger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg);}

/* ============================================================
   HERO
   ============================================================ */
.hero{padding:clamp(112px,13vw,142px) 0 clamp(40px,5vw,60px);position:relative;overflow:hidden;}
.hero__grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(28px,4vw,56px);align-items:center;}
.orb{position:absolute;border-radius:50%;filter:blur(46px);opacity:.5;z-index:0;pointer-events:none;animation:float 12s ease-in-out infinite;}
.orb--1{width:420px;height:420px;background:radial-gradient(circle,var(--grape-soft),transparent 70%);top:-120px;left:-120px;}
.orb--2{width:360px;height:360px;background:radial-gradient(circle,var(--gold),transparent 70%);bottom:-100px;right:8%;animation-delay:-4s;opacity:.4;}
.orb--3{width:300px;height:300px;background:radial-gradient(circle,var(--coral),transparent 70%);top:30%;right:-80px;animation-delay:-8s;opacity:.35;}
@keyframes float{0%,100%{transform:translate(0,0) scale(1);}50%{transform:translate(18px,-26px) scale(1.06);}}

.hero__copy{position:relative;z-index:2;}
.hero__pill{
  display:inline-flex;align-items:center;gap:.55rem;padding:.5rem .95rem;border-radius:999px;
  background:#fff;box-shadow:var(--shadow-sm);font-size:.82rem;font-weight:600;color:var(--grape-deep);
  margin-bottom:1.4rem;
}
.hero__pill .dot{width:8px;height:8px;border-radius:50%;background:var(--mint-deep);box-shadow:0 0 0 4px rgba(63,174,132,.2);animation:pulse-dot 2s infinite;}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 0 3px rgba(63,174,132,.25);}50%{box-shadow:0 0 0 8px rgba(63,174,132,0);}}
.hero h1{font-size:clamp(2.9rem,8vw,5.4rem);margin-bottom:.4em;}
.hero h1 .tag{color:var(--grape);position:relative;white-space:nowrap;}
.hero h1 .tag svg{position:absolute;left:0;bottom:-.12em;width:100%;height:.3em;color:var(--coral);}
.hero__sub{font-size:clamp(1.05rem,2.6vw,1.25rem);color:var(--ink-soft);max-width:30ch;margin-bottom:2rem;}
.hero__cta{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem;}
.hero__trust{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;font-size:.9rem;color:var(--ink-soft);}
.hero__avatars{display:flex;}
.hero__avatars span{
  width:38px;height:38px;border-radius:50%;border:3px solid var(--cream);margin-left:-12px;
  display:grid;place-items:center;font-weight:700;font-size:.8rem;color:#fff;
}
.hero__avatars span:first-child{margin-left:0;}
.hero__stars{color:var(--gold);letter-spacing:2px;}

/* Hero image frame */
/* order:-1 places the photo first — left column on desktop, top on mobile —
   while the headline stays first in the DOM for SEO / screen-reader order. */
.hero__visual{position:relative;z-index:2;order:-1;}
.hero__frame{
  position:relative;border-radius:var(--r-xl);overflow:hidden;
  background:linear-gradient(150deg,var(--grape),var(--grape-deep));
  box-shadow:var(--shadow-lg);aspect-ratio:4/4.6;
  border:8px solid #fff;
}
.hero__frame img{width:100%;height:100%;object-fit:cover;object-position:center 30%;}
.hero__frame::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(60,29,110,.35),transparent 40%);}
.float-card{
  position:absolute;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);
  border-radius:var(--r-md);padding:.85rem 1.05rem;box-shadow:var(--shadow-md);z-index:3;
  display:flex;align-items:center;gap:.7rem;font-weight:700;font-size:.9rem;
  animation:bob 5s ease-in-out infinite;
}
@keyframes bob{0%,100%{transform:translateY(0);}50%{transform:translateY(-9px);}}
.float-card .ic{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;color:#fff;flex:0 0 auto;}
.float-card small{display:block;font-weight:500;font-size:.72rem;color:var(--ink-soft);}
.float-card--price{top:8%;left:-22px;animation-delay:-1s;}
.float-card--ship{bottom:12%;right:-18px;animation-delay:-2.5s;}
.float-card--rating{bottom:34%;left:-30px;animation-delay:-3.5s;}

/* ============================================================
   MARQUEE STRIP
   ============================================================ */
.strip{background:var(--grape-deep);color:#fff;padding:1rem 0;overflow:hidden;position:relative;}
.strip__track{display:flex;gap:3rem;width:max-content;animation:marquee 28s linear infinite;}
.strip:hover .strip__track{animation-play-state:paused;}
.strip__item{display:flex;align-items:center;gap:.7rem;font-weight:600;font-size:1rem;white-space:nowrap;letter-spacing:.01em;}
.strip__item svg{width:18px;height:18px;color:var(--gold);}
@keyframes marquee{to{transform:translateX(-50%);}}

/* ============================================================
   PRODUCTS
   ============================================================ */
.products{padding:clamp(64px,10vw,110px) 0;}
.products__head{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;flex-wrap:wrap;}
.grid-products{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2.4vw,28px);}
.product{
  background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .45s var(--ease),box-shadow .45s var(--ease);position:relative;display:flex;flex-direction:column;
}
.product:hover{transform:translateY(-10px);box-shadow:var(--shadow-md);}
.product__media{
  position:relative;aspect-ratio:1/1.08;overflow:hidden;
  display:grid;place-items:center;
}
.product__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease);}
.product:hover .product__media img{transform:scale(1.07);}
.product__media .garment{width:62%;height:62%;transition:transform .6s var(--ease);filter:drop-shadow(0 12px 20px rgba(42,27,61,.18));}
.product:hover .product__media .garment{transform:translateY(-6px) scale(1.05) rotate(-2deg);}
.tag{
  position:absolute;top:12px;left:12px;z-index:4;
  font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  padding:.4rem .7rem;border-radius:999px;
}
.tag--new{background:var(--gold);color:#5a3c00;box-shadow:0 6px 16px -6px rgba(255,194,75,.8);}
.tag--new::before{content:"★ ";}
.product__fav{position:absolute;top:12px;right:12px;z-index:4;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.85);display:grid;place-items:center;color:var(--coral);box-shadow:var(--shadow-sm);transition:transform .3s,background .3s;}
.product__fav:hover{transform:scale(1.15);background:#fff;}
.product__fav svg{width:16px;height:16px;}
.product__cat{position:absolute;bottom:12px;left:12px;z-index:4;font-size:.72rem;font-weight:700;color:var(--grape-deep);background:rgba(255,255,255,.85);padding:.25rem .6rem;border-radius:999px;}
.product__body{padding:1.1rem 1.15rem 1.25rem;display:flex;flex-direction:column;gap:.35rem;flex:1;}
.product__body h3{font-size:1.18rem;font-variation-settings:"SOFT" 40;}
.product__age{font-size:.82rem;color:var(--ink-soft);}
.product__foot{margin-top:auto;padding-top:.75rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem;}
.price{font-family:var(--font-display);font-weight:700;font-size:1.3rem;color:var(--grape-deep);}
.price small{font-size:.72rem;font-weight:600;color:var(--ink-soft);text-decoration:line-through;margin-right:.3rem;font-family:var(--font-body);}
.btn-mini{
  display:inline-flex;align-items:center;gap:.4rem;background:var(--ink);color:#fff;
  font-weight:700;font-size:.82rem;padding:.55rem .9rem;border-radius:999px;transition:background .3s,transform .3s;
}
.btn-mini svg{width:14px;height:14px;}
.btn-mini:hover{background:var(--wa);color:#04331f;transform:scale(1.05);}

/* ============================================================
   FLASH SALE
   ============================================================ */
.flash{padding:clamp(40px,6vw,60px) 0;}
.flash__panel{
  position:relative;border-radius:var(--r-xl);overflow:hidden;color:#fff;
  background:linear-gradient(120deg,var(--coral),#ff8a3d 45%,var(--gold));
  padding:clamp(34px,6vw,60px);box-shadow:var(--shadow-lg);
  display:grid;grid-template-columns:1.3fr .9fr;gap:2rem;align-items:center;
}
.flash__panel::before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cpath d='M30 5l4 16 16 4-16 4-4 16-4-16-16-4 16-4z' fill='white' opacity='.07'/%3E%3C/svg%3E");animation:drift 30s linear infinite;}
@keyframes drift{to{background-position:600px 600px;}}
.flash__copy{position:relative;z-index:2;}
.flash__badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.22);padding:.45rem .9rem;border-radius:999px;font-weight:800;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;backdrop-filter:blur(6px);margin-bottom:1rem;animation:flash-pulse 1.6s ease-in-out infinite;}
@keyframes flash-pulse{0%,100%{opacity:1;}50%{opacity:.55;}}
.flash__copy h2{color:#fff;font-size:clamp(2rem,5.4vw,3.3rem);margin-bottom:.4em;}
.flash__copy p{font-size:1.05rem;opacity:.95;max-width:42ch;margin-bottom:1.6rem;}
.flash__list{display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;margin-bottom:1.8rem;font-weight:600;}
.flash__list li{display:flex;align-items:center;gap:.5rem;}
.flash__list svg{width:18px;height:18px;}
.countdown{position:relative;z-index:2;}
.countdown__label{font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-size:.78rem;opacity:.9;margin-bottom:.8rem;text-align:center;}
.countdown__clock{display:flex;gap:.7rem;justify-content:center;}
.cd-unit{background:rgba(255,255,255,.95);color:var(--coral-deep);border-radius:var(--r-md);padding:1rem .4rem;min-width:78px;text-align:center;box-shadow:var(--shadow-md);}
.cd-unit b{display:block;font-family:var(--font-display);font-weight:700;font-size:2.2rem;line-height:1;font-variant-numeric:tabular-nums;}
.cd-unit small{font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);}

/* ============================================================
   QUIZ
   ============================================================ */
.quiz-section{padding:clamp(64px,10vw,110px) 0;}
.quiz-section .wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(30px,5vw,60px);align-items:center;}
.quiz-intro h2{font-size:clamp(2.1rem,5.4vw,3.4rem);margin:.35em 0;}
.quiz-intro p{color:var(--ink-soft);margin-bottom:1.6rem;max-width:38ch;}
.quiz-intro .feat{display:flex;flex-direction:column;gap:.9rem;}
.quiz-intro .feat li{display:flex;align-items:center;gap:.7rem;font-weight:600;}
.quiz-intro .feat .n{width:30px;height:30px;border-radius:9px;background:var(--mint);color:#0d4d33;display:grid;place-items:center;font-weight:800;font-size:.85rem;flex:0 0 auto;}

.quiz{
  background:#fff;border-radius:var(--r-xl);box-shadow:var(--shadow-md);
  padding:clamp(26px,4vw,42px);position:relative;overflow:hidden;min-height:430px;display:flex;flex-direction:column;
  border:1px solid rgba(90,45,156,.07);
}
.quiz::before{content:"";position:absolute;top:-60px;right:-60px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,var(--blush),transparent 70%);opacity:.7;}
.quiz__top{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.4rem;position:relative;z-index:2;}
.quiz__step{font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--grape);}
.quiz__bar{height:7px;background:var(--cream-2);border-radius:99px;overflow:hidden;flex:1;margin-left:1rem;}
.quiz__progress{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--coral),var(--gold));border-radius:99px;transition:width .5s var(--ease);}
.quiz__stage{position:relative;z-index:2;flex:1;display:flex;flex-direction:column;}
.quiz__q{font-family:var(--font-display);font-weight:600;font-size:clamp(1.5rem,3.5vw,2rem);margin-bottom:1.4rem;font-variation-settings:"SOFT" 60,"WONK" 1;}
.quiz__opts{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;}
.quiz__opt{
  text-align:left;background:var(--cream);border:2px solid transparent;border-radius:var(--r-md);
  padding:1.05rem 1.15rem;font-weight:700;font-size:1.02rem;transition:.3s var(--ease);display:flex;align-items:center;gap:.8rem;
}
.quiz__opt:hover{border-color:var(--grape);background:#fff;transform:translateY(-3px);box-shadow:var(--shadow-sm);}
.quiz__opt .od{width:34px;height:34px;border-radius:10px;background:#fff;display:grid;place-items:center;color:var(--grape);flex:0 0 auto;box-shadow:var(--shadow-sm);transition:.3s;}
.quiz__opt:hover .od{background:var(--grape);color:#fff;}
.quiz__opt .od svg{width:18px;height:18px;}

.quiz-anim-in{animation:qIn .45s var(--ease-out) both;}
@keyframes qIn{from{opacity:0;transform:translateX(26px);}to{opacity:1;transform:none;}}

.quiz__back{align-self:flex-start;margin-top:1.2rem;font-weight:600;font-size:.88rem;color:var(--ink-soft);display:inline-flex;align-items:center;gap:.4rem;transition:color .25s;}
.quiz__back:hover{color:var(--grape);}
.quiz__back svg{width:15px;height:15px;}

/* Quiz result */
.quiz-result{text-align:center;}
.quiz-result .ring{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--mint),var(--mint-deep));display:grid;place-items:center;margin:0 auto 1rem;color:#fff;box-shadow:0 12px 26px -10px rgba(63,174,132,.7);animation:pop .5s var(--ease-out) both;}
.quiz-result .ring svg{width:30px;height:30px;}
@keyframes pop{0%{transform:scale(.4);opacity:0;}60%{transform:scale(1.12);}100%{transform:scale(1);opacity:1;}}
.quiz-result h3{font-size:1.7rem;margin-bottom:.3em;}
.quiz-result p{color:var(--ink-soft);margin-bottom:1.4rem;font-size:.96rem;}
.quiz-result__grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.7rem;margin-bottom:1.4rem;}
.rec{background:var(--cream);border-radius:var(--r-md);padding:.7rem;text-align:center;transition:transform .35s var(--ease);}
.rec:hover{transform:translateY(-4px);}
.rec__media{aspect-ratio:1/1;border-radius:12px;overflow:hidden;margin-bottom:.5rem;display:grid;place-items:center;position:relative;}
.rec__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.rec__media .garment{width:64%;height:64%;}
.rec h4{font-size:.86rem;font-family:var(--font-body);font-weight:700;line-height:1.2;}
.rec .price{font-size:1rem;}
.quiz-result__cta{display:flex;gap:.7rem;flex-wrap:wrap;justify-content:center;}

/* ============================================================
   WHY PARENTS LOVE
   ============================================================ */
.why{padding:clamp(64px,10vw,110px) 0;background:linear-gradient(180deg,var(--cream),#fff);}
.grid-why{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.2vw,24px);}
.why-card{
  background:#fff;border-radius:var(--r-lg);padding:1.8rem 1.6rem;box-shadow:var(--shadow-sm);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);border:1px solid rgba(90,45,156,.06);position:relative;overflow:hidden;
}
.why-card::before{content:"";position:absolute;top:-40px;right:-40px;width:110px;height:110px;border-radius:50%;opacity:.14;transition:transform .5s var(--ease);}
.why-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-md);}
.why-card:hover::before{transform:scale(1.6);}
.why-card .wi{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;color:#fff;margin-bottom:1.1rem;box-shadow:var(--shadow-sm);position:relative;z-index:2;}
.why-card .wi svg{width:26px;height:26px;}
.why-card h3{font-size:1.3rem;margin-bottom:.4em;position:relative;z-index:2;}
.why-card p{color:var(--ink-soft);font-size:.96rem;position:relative;z-index:2;}

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews{padding:clamp(64px,10vw,110px) 0;}
.grid-reviews{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(16px,2.4vw,26px);}
.review{
  background:#fff;border-radius:var(--r-lg);padding:1.8rem;box-shadow:var(--shadow-sm);position:relative;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);border:1px solid rgba(90,45,156,.06);
}
.review:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);}
.review__quote{position:absolute;top:18px;right:24px;font-family:var(--font-display);font-size:5rem;line-height:1;color:var(--blush);opacity:.8;}
.review__stars{color:var(--gold);letter-spacing:2px;margin-bottom:.8rem;font-size:1rem;}
.review__text{font-size:1.05rem;color:var(--ink);margin-bottom:1.3rem;position:relative;z-index:2;}
.review__who{display:flex;align-items:center;gap:.8rem;}
.review__av{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:800;font-size:1rem;flex:0 0 auto;}
.review__name{font-weight:700;}
.review__loc{font-size:.82rem;color:var(--ink-soft);}

/* ============================================================
   WHATSAPP CONVERSION
   ============================================================ */
.wa-convert{padding:clamp(50px,8vw,90px) 0;}
.wa-panel{
  position:relative;border-radius:var(--r-xl);overflow:hidden;color:#fff;
  background:linear-gradient(135deg,var(--wa-deep),var(--wa));
  padding:clamp(36px,6vw,66px);box-shadow:var(--shadow-lg);
  display:grid;grid-template-columns:1.2fr .8fr;gap:2.5rem;align-items:center;
}
.wa-panel::before{content:"";position:absolute;width:340px;height:340px;border-radius:50%;background:rgba(255,255,255,.1);top:-120px;left:-80px;}
.wa-panel::after{content:"";position:absolute;width:260px;height:260px;border-radius:50%;background:rgba(255,255,255,.08);bottom:-110px;right:-60px;}
.wa-copy{position:relative;z-index:2;}
.wa-copy .eyebrow{color:#d6fff0;}
.wa-copy .eyebrow::before{background:#fff;}
.wa-copy h2{color:#fff;font-size:clamp(2rem,5.2vw,3.2rem);margin:.3em 0 .5em;}
.wa-steps{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.9rem;}
.wa-step{display:flex;align-items:center;gap:1rem;font-size:1.05rem;font-weight:600;}
.wa-step .num{width:42px;height:42px;border-radius:13px;background:rgba(255,255,255,.18);display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:1.2rem;flex:0 0 auto;backdrop-filter:blur(4px);}
.wa-visual{position:relative;z-index:2;display:grid;place-items:center;}
.phone{
  width:230px;background:#fff;border-radius:34px;padding:14px;box-shadow:var(--shadow-lg);
  border:6px solid #0c3b2e;transform:rotate(3deg);animation:bob 6s ease-in-out infinite;
}
.phone__top{height:18px;display:grid;place-items:center;}
.phone__top span{width:48px;height:5px;background:#e2e2e2;border-radius:99px;}
.phone__screen{background:#e9f7ef;border-radius:22px;padding:14px;min-height:300px;display:flex;flex-direction:column;gap:.6rem;}
.bubble{padding:.65rem .85rem;border-radius:16px;font-size:.82rem;max-width:85%;color:#0c3b2e;font-weight:500;box-shadow:0 4px 10px -6px rgba(0,0,0,.2);}
.bubble--me{background:#dcf8c6;align-self:flex-end;border-bottom-right-radius:5px;}
.bubble--them{background:#fff;align-self:flex-start;border-bottom-left-radius:5px;}
.bubble small{display:block;text-align:right;font-size:.6rem;color:#6b9c82;margin-top:2px;}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{padding:clamp(64px,10vw,110px) 0;}
.contact .wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(30px,5vw,56px);align-items:start;}
.contact-info h2{font-size:clamp(2rem,5vw,3.1rem);margin:.35em 0;}
.contact-info p{color:var(--ink-soft);margin-bottom:1.8rem;max-width:36ch;}
.contact-card{display:flex;align-items:center;gap:1rem;background:#fff;border-radius:var(--r-md);padding:1.05rem 1.2rem;box-shadow:var(--shadow-sm);margin-bottom:.9rem;transition:transform .35s var(--ease);}
.contact-card:hover{transform:translateX(6px);}
.contact-card .ci{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;color:#fff;flex:0 0 auto;}
.contact-card .ci svg{width:22px;height:22px;}
.contact-card small{display:block;font-size:.76rem;color:var(--ink-soft);font-weight:600;letter-spacing:.04em;text-transform:uppercase;}
.contact-card b{font-size:1.05rem;}

.form{background:#fff;border-radius:var(--r-xl);padding:clamp(26px,4vw,42px);box-shadow:var(--shadow-md);border:1px solid rgba(90,45,156,.06);}
.form h3{font-size:1.6rem;margin-bottom:.3em;}
.form > p{color:var(--ink-soft);font-size:.92rem;margin-bottom:1.5rem;}
.field{margin-bottom:1.1rem;}
.field label{display:block;font-weight:700;font-size:.84rem;margin-bottom:.45rem;color:var(--ink);}
.field input,.field textarea{
  width:100%;padding:.9rem 1.05rem;border-radius:var(--r-sm);border:2px solid var(--cream-2);
  background:var(--cream);transition:border-color .3s,background .3s,box-shadow .3s;color:var(--ink);
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--grape);background:#fff;box-shadow:0 0 0 4px rgba(90,45,156,.1);}
.field textarea{resize:vertical;min-height:110px;}
.form .btn{width:100%;}
.form__note{text-align:center;font-size:.8rem;color:var(--ink-soft);margin-top:.9rem;}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--grape-deep);color:#e9def8;padding:clamp(54px,8vw,80px) 0 0;position:relative;overflow:hidden;}
.footer::before{content:"";position:absolute;top:-120px;left:50%;transform:translateX(-50%);width:600px;height:240px;background:radial-gradient(ellipse,var(--grape-soft),transparent 70%);opacity:.4;}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2.4rem;position:relative;z-index:2;padding-bottom:3rem;}
.footer .brand{color:#fff;margin-bottom:1.1rem;gap:.85rem;}
.footer .brand__mark{width:92px;height:92px;border-radius:22px;}
.footer__about{font-size:.94rem;opacity:.8;max-width:34ch;margin-bottom:1.3rem;}
.footer__col h4{font-family:var(--font-display);font-size:1.15rem;color:#fff;margin-bottom:1.1rem;font-variation-settings:"SOFT" 50;}
.footer__col a{display:block;opacity:.8;margin-bottom:.65rem;font-size:.94rem;transition:opacity .25s,transform .25s,color .25s;}
.footer__col a:hover{opacity:1;color:var(--gold);transform:translateX(4px);}
.socials{display:flex;gap:.7rem;}
.socials a{width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.1);display:grid;place-items:center;transition:.3s;}
.socials a:hover{background:var(--coral);transform:translateY(-4px);}
.socials a svg{width:20px;height:20px;}
.footer__bottom{border-top:1px solid rgba(255,255,255,.12);padding:1.6rem 0;text-align:center;font-size:.86rem;opacity:.7;position:relative;z-index:2;}
.footer__bottom .heart{color:var(--coral);}

/* ============================================================
   FLOATING WHATSAPP + MOBILE CTA BAR
   ============================================================ */
.wa-float{
  position:fixed;right:20px;bottom:24px;z-index:1200;
  width:62px;height:62px;border-radius:50%;background:var(--wa);
  display:grid;place-items:center;box-shadow:0 16px 34px -10px rgba(37,211,102,.7);
  transition:transform .35s var(--ease);
}
.wa-float:hover{transform:scale(1.1) rotate(6deg);}
.wa-float svg{width:32px;height:32px;color:#fff;}
.wa-float::before{content:"";position:absolute;inset:0;border-radius:50%;background:var(--wa);z-index:-1;animation:ring 2.2s ease-out infinite;}
@keyframes ring{0%{transform:scale(1);opacity:.55;}100%{transform:scale(1.9);opacity:0;}}
.wa-float__tip{position:absolute;right:74px;top:50%;transform:translateY(-50%);background:var(--ink);color:#fff;font-size:.8rem;font-weight:600;padding:.5rem .8rem;border-radius:10px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .3s;box-shadow:var(--shadow-sm);}
.wa-float:hover .wa-float__tip{opacity:1;}

.mobile-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:1150;display:none;gap:.6rem;
  padding:.7rem .8rem calc(.7rem + env(safe-area-inset-bottom));
  background:rgba(251,244,236,.92);backdrop-filter:blur(14px);
  box-shadow:0 -8px 30px -14px rgba(60,29,110,.4);
}
.mobile-cta .btn{flex:1;padding:.95rem 1rem;font-size:.95rem;}

/* ============================================================
   ECOMMERCE / WOOCOMMERCE UI  (cart icon, drawer, stock, actions)
   ============================================================ */
/* Nav cart icon + count badge (WooCommerce updates count via cart fragments) */
.nav__cart{position:relative;width:48px;height:48px;border-radius:13px;background:rgba(255,255,255,.6);border:1.5px solid rgba(90,45,156,.16);display:grid;place-items:center;color:var(--ink);transition:.3s var(--ease);}
.nav__cart:hover{background:#fff;border-color:var(--grape);transform:translateY(-2px);}
.nav__cart svg{width:22px;height:22px;}
.nav__cart-count{position:absolute;top:-7px;right:-7px;min-width:20px;height:20px;padding:0 5px;border-radius:999px;background:var(--coral);color:#fff;font-size:.68rem;font-weight:800;display:grid;place-items:center;box-shadow:var(--shadow-sm);}
.nav__cart-count[data-empty="true"]{background:var(--ink-soft);}

/* Off-canvas cart drawer (placeholder for WooCommerce mini-cart) */
.cart-overlay{position:fixed;inset:0;z-index:1300;background:rgba(42,27,61,.45);backdrop-filter:blur(3px);opacity:0;transition:opacity .35s var(--ease);}
.cart-overlay.show{opacity:1;}
.cart-drawer{position:fixed;top:0;right:0;bottom:0;z-index:1310;width:min(400px,90vw);background:var(--cream);box-shadow:-20px 0 60px -20px rgba(60,29,110,.5);transform:translateX(105%);transition:transform .42s var(--ease);display:flex;flex-direction:column;}
.cart-drawer.open{transform:none;}
.cart-drawer__head{display:flex;align-items:center;justify-content:space-between;padding:1.4rem 1.5rem;border-bottom:1px solid rgba(90,45,156,.1);}
.cart-drawer__head h3{font-size:1.4rem;}
.cart-drawer__close{width:40px;height:40px;border-radius:11px;background:#fff;display:grid;place-items:center;box-shadow:var(--shadow-sm);transition:.3s var(--ease);}
.cart-drawer__close:hover{transform:rotate(90deg);color:var(--coral);}
.cart-drawer__close svg{width:18px;height:18px;}
.cart-drawer__body{flex:1;overflow-y:auto;padding:1.5rem;}
.cart-empty{text-align:center;padding:2rem 1rem;color:var(--ink-soft);}
.cart-empty svg{width:62px;height:62px;color:var(--grape-soft);opacity:.5;margin:0 auto 1rem;}
.cart-empty p{font-family:var(--font-display);font-size:1.3rem;color:var(--ink);margin-bottom:.3rem;}
.cart-empty span{display:block;font-size:.9rem;margin-bottom:1.4rem;}
.cart-drawer__foot{padding:1.4rem 1.5rem calc(1.4rem + env(safe-area-inset-bottom));border-top:1px solid rgba(90,45,156,.1);background:#fff;}
.cart-subtotal{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;font-weight:600;}
.cart-subtotal b{font-family:var(--font-display);font-size:1.4rem;color:var(--grape-deep);}
.cart-drawer__foot .btn{width:100%;margin-bottom:.6rem;}
.cart-cont{width:100%;text-align:center;font-weight:600;font-size:.9rem;color:var(--ink-soft);padding:.4rem;transition:color .25s;}
.cart-cont:hover{color:var(--grape);}
body.cart-open{overflow:hidden;}

/* Product stock indicator + saved (wishlist) + ecommerce action buttons */
.product__stockline{padding-top:.1rem;min-height:0;}
.product__stockline:empty{display:none;}
.stock{display:inline-flex;align-items:center;gap:.4rem;font-size:.74rem;font-weight:700;}
.stock::before{content:"";width:7px;height:7px;border-radius:50%;}
.stock--low{color:var(--coral-deep);}
.stock--low::before{background:var(--coral);box-shadow:0 0 0 3px rgba(255,106,77,.2);}
.stock--out{color:var(--ink-soft);}
.stock--out::before{background:var(--ink-soft);}
.product__fav.is-saved{background:var(--coral);color:#fff;}
.product__actions{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.6rem;}
.product__actions .btn-mini{flex:1;justify-content:center;}
.btn-mini--cart{background:var(--grape);}
.btn-mini--buy{background:var(--coral);}
.btn-mini--qv{background:transparent;color:var(--grape);border:1.5px solid rgba(90,45,156,.25);}

/* ============================================================
   FAQ ACCORDION
   ============================================================ */
.faq{padding:clamp(64px,10vw,110px) 0;background:linear-gradient(180deg,#fff,var(--cream));}
.faq .section-head{margin-inline:auto;text-align:center;}
.faq .eyebrow{justify-content:center;}
.faq__list{max-width:760px;margin-inline:auto;display:flex;flex-direction:column;gap:.9rem;}
.faq__item{background:#fff;border-radius:var(--r-md);box-shadow:var(--shadow-sm);border:1px solid rgba(90,45,156,.06);overflow:hidden;}
.faq__item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.2rem 1.4rem;font-weight:700;font-size:1.04rem;color:var(--ink);transition:color .25s;}
.faq__item summary::-webkit-details-marker{display:none;}
.faq__item summary:hover{color:var(--grape);}
.faq__item[open] summary{color:var(--grape);}
.faq__ic{position:relative;width:20px;height:20px;flex:0 0 auto;}
.faq__ic::before,.faq__ic::after{content:"";position:absolute;background:var(--grape);border-radius:2px;transition:transform .3s var(--ease);}
.faq__ic::before{top:9px;left:0;width:20px;height:2px;}
.faq__ic::after{top:0;left:9px;width:2px;height:20px;}
.faq__item[open] .faq__ic::after{transform:scaleY(0);}
.faq__a{padding:0 1.4rem 1.3rem;color:var(--ink-soft);font-size:.98rem;animation:fadeDown .35s var(--ease-out);}
@keyframes fadeDown{from{opacity:0;transform:translateY(-6px);}to{opacity:1;transform:none;}}

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out);}
.reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;}
  .reveal{opacity:1;transform:none;}
  html{scroll-behavior:auto;}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .grid-products{grid-template-columns:repeat(2,1fr);}
  .grid-why{grid-template-columns:1fr 1fr;}
  .hero__grid{grid-template-columns:1fr;gap:42px;}
  .hero__visual{max-width:500px;margin-inline:auto;}
  .quiz-section .wrap,.wa-panel,.flash__panel,.contact .wrap{grid-template-columns:1fr;}
  .flash__panel,.wa-panel{text-align:left;}
  .countdown{margin-top:1rem;}
  .wa-visual{display:none;}
}
@media (max-width:760px){
  .nav__links{
    position:absolute;top:calc(100% + 8px);right:clamp(20px,5vw,40px);left:clamp(20px,5vw,40px);
    flex-direction:column;align-items:stretch;gap:.4rem;background:#fff;border-radius:var(--r-md);
    padding:1rem;box-shadow:var(--shadow-md);transform:translateY(-12px);opacity:0;pointer-events:none;transition:.3s var(--ease);
  }
  .nav__links.open{transform:none;opacity:1;pointer-events:auto;}
  .nav__links a{padding:.7rem .4rem;}
  .nav__cta .btn--wa{display:none;}
  .nav__burger{display:block;}
  .nav .brand__mark{width:56px;height:56px;}
  .grid-why,.grid-reviews{grid-template-columns:1fr;}
  .quiz__opts{grid-template-columns:1fr;}
  .quiz-result__grid{grid-template-columns:1fr 1fr;}
  .footer__grid{grid-template-columns:1fr 1fr;gap:1.8rem;}
  .mobile-cta{display:flex;}
  .wa-float{bottom:84px;width:54px;height:54px;}
  .wa-float svg{width:28px;height:28px;}
  .float-card--rating{display:none;}
  .float-card{font-size:.8rem;padding:.65rem .8rem;}
}
@media (max-width:440px){
  .brand{font-size:1.08rem;gap:.5rem;}
  .nav .brand__mark{width:50px;height:50px;border-radius:14px;}
  .footer .brand__mark{width:72px;height:72px;}
  .grid-products{grid-template-columns:1fr;}
  .quiz-result__grid{grid-template-columns:1fr;}
  .cd-unit{min-width:62px;padding:.8rem .3rem;}
  .cd-unit b{font-size:1.7rem;}
  .footer__grid{grid-template-columns:1fr;}
}
