/* =========================================================
   Drape & Define — Stylesheet
   Single CSS file. Mobile-first. Tokens in :root.
   ========================================================= */

/* ---------- Tokens ---------- */
:root{
  --c-bg:#FFFBF6;
  --c-cream:#F5EBDD;
  --c-peach:#FCE7D8;
  --c-peach-2:#F8D2BB;
  --c-maroon:#7A1F2B;
  --c-maroon-2:#5A1620;
  --c-gold:#C9A24B;
  --c-gold-2:#A6822F;
  --c-ink:#2A1B1E;
  --c-muted:#6B5A5C;
  --c-line:#EADFD0;
  --f-display:'Fraunces', Georgia, serif;
  --f-ui:'Inter', system-ui, -apple-system, sans-serif;
  --nav-h:72px;
  --section-v:96px;
  --gutter:clamp(20px, 4vw, 48px);
  --r-sm:8px; --r-md:14px; --r-lg:22px; --r-xl:32px;
  --shadow-sm:0 2px 6px rgba(42,27,30,.06);
  --shadow-md:0 12px 28px rgba(42,27,30,.10);
  --shadow-lg:0 24px 60px rgba(42,27,30,.14);
  --maxw:1200px;
  --t-fast:200ms ease-out;
  --t-mid:300ms ease-out;
  --t-slow:400ms ease-out;
}

/* ---------- Base / Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--f-ui);
  font-size:16px;
  line-height:1.6;
  color:var(--c-ink);
  background:var(--c-bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg,video{display:block;max-width:100%;height:auto}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
a{color:var(--c-maroon);text-decoration:none;transition:color var(--t-fast)}
a:hover{color:var(--c-maroon-2)}
ul{margin:0;padding:0;list-style:none}
input,select,textarea{font:inherit;color:inherit}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--f-display);font-weight:600;color:var(--c-ink);margin:0 0 .4em;line-height:1.15;letter-spacing:-.01em}
h1{font-size:clamp(2.2rem,5.4vw,3.8rem);font-style:italic;font-weight:600}
h2{font-size:clamp(1.8rem,3.6vw,2.6rem)}
h3{font-size:clamp(1.2rem,2vw,1.45rem)}
h4{font-size:1.05rem;font-weight:600}
p{margin:0 0 1em}
.muted{color:var(--c-muted)}
.eyebrow{
  display:inline-block;
  font-family:var(--f-ui);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--c-gold-2);
  margin-bottom:.75rem;
}
.lead{font-size:1.1rem;color:var(--c-muted);max-width:60ch}

/* ---------- Layout helpers ---------- */
.container{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:var(--section-v);position:relative}
.section--cream{background:var(--c-cream)}
.section--peach{background:linear-gradient(180deg,var(--c-peach) 0%,var(--c-peach-2) 100%)}
.section--maroon{background:var(--c-maroon);color:#fff}
.section--maroon h1,.section--maroon h2,.section--maroon h3{color:#fff}

.section-head{max-width:680px;margin:0 auto 3rem;text-align:center}
.section-head .lead{margin-inline:auto}

.grid{display:grid;gap:1.25rem}

/* ---------- Skip link & Focus ---------- */
.skip-link{
  position:absolute;left:-9999px;top:0;
  background:var(--c-maroon);color:#fff;
  padding:.6rem 1rem;border-radius:0 0 var(--r-sm) 0;
  z-index:1000;
}
.skip-link:focus{left:0;color:#fff}
:focus-visible{outline:2px solid var(--c-gold);outline-offset:2px;border-radius:4px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--f-ui);font-weight:600;font-size:.95rem;line-height:1;
  padding:.95rem 1.6rem;border-radius:999px;
  border:1.5px solid transparent;
  cursor:pointer;text-align:center;
  transition:transform var(--t-fast),box-shadow var(--t-fast),background-color var(--t-fast),color var(--t-fast),border-color var(--t-fast);
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn:active{transform:translateY(0)}
.btn-primary{background:var(--c-maroon);color:#fff;border-color:var(--c-maroon)}
.btn-primary:hover{background:var(--c-maroon-2);color:#fff;border-color:var(--c-maroon-2)}
.btn-gold{background:var(--c-gold);color:var(--c-ink);border-color:var(--c-gold)}
.btn-gold:hover{background:var(--c-gold-2);color:var(--c-ink);border-color:var(--c-gold-2)}
.btn-ghost{background:transparent;color:var(--c-maroon);border-color:var(--c-maroon)}
.btn-ghost:hover{background:var(--c-maroon);color:#fff}
.btn-block{width:100%;display:flex}
.btn-sm{padding:.6rem 1.1rem;font-size:.85rem}
.btn-lg{padding:1.1rem 2rem;font-size:1rem}
.section--maroon .btn-ghost{color:#fff;border-color:#fff}
.section--maroon .btn-ghost:hover{background:#fff;color:var(--c-maroon)}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;left:0;right:0;z-index:60;
  background:rgba(255,251,246,.8);
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid transparent;
  transition:background var(--t-fast),box-shadow var(--t-fast),border-color var(--t-fast);
}
.site-header[data-elevated="true"]{
  background:rgba(255,251,246,.96);
  border-bottom-color:var(--c-line);
  box-shadow:var(--shadow-sm);
}
.nav-row{
  height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
}
.brand{display:inline-flex;align-items:center;gap:.6rem;color:var(--c-ink)}
.brand:hover{color:var(--c-maroon)}
.brand-mark{
  display:inline-grid;place-items:center;
  width:38px;height:38px;border-radius:10px;
  background:var(--c-maroon);color:#fff;
  font-family:var(--f-display);font-weight:600;font-size:.9rem;
  letter-spacing:-.02em;
}
.brand-name{font-family:var(--f-display);font-weight:600;font-size:1.15rem;letter-spacing:-.01em}

.nav-primary{display:none;gap:1.6rem;align-items:center}
.nav-primary a{
  color:var(--c-ink);font-weight:500;font-size:.95rem;
  position:relative;padding:.4rem 0;
}
.nav-primary a::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;
  height:2px;background:var(--c-gold);
  transform:scaleX(0);transform-origin:center;
  transition:transform var(--t-fast);
}
.nav-primary a:hover,.nav-primary a.active{color:var(--c-maroon)}
.nav-primary a:hover::after,.nav-primary a.active::after{transform:scaleX(1)}

.nav-actions{display:flex;align-items:center;gap:.6rem}
.cart-link{
  position:relative;display:inline-grid;place-items:center;
  width:42px;height:42px;border-radius:50%;
  color:var(--c-ink);
  transition:background var(--t-fast),color var(--t-fast);
}
.cart-link:hover{background:var(--c-cream);color:var(--c-maroon)}
.cart-count{
  position:absolute;top:2px;right:2px;
  background:var(--c-maroon);color:#fff;
  font-size:.65rem;font-weight:700;
  min-width:18px;height:18px;border-radius:999px;
  display:grid;place-items:center;
  padding:0 4px;line-height:1;
}
.hide-sm{display:none}

.hamburger{
  display:inline-flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;
  width:42px;height:42px;border-radius:10px;
  transition:background var(--t-fast);
}
.hamburger:hover{background:var(--c-cream)}
.hamburger span{
  width:22px;height:2px;background:var(--c-ink);border-radius:2px;
  transition:transform var(--t-fast),opacity var(--t-fast);
}
.hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- Drawer ---------- */
.drawer-scrim{
  position:fixed;inset:0;z-index:90;
  background:rgba(42,27,30,.5);
  opacity:0;transition:opacity var(--t-mid);
}
.drawer-scrim.is-open{opacity:1}
.nav-drawer{
  position:fixed;top:0;right:0;bottom:0;z-index:100;
  width:min(86vw,360px);
  background:var(--c-bg);
  padding:1.5rem 1.5rem 2rem;
  display:flex;flex-direction:column;gap:1.5rem;
  transform:translateX(105%);
  transition:transform var(--t-mid);
  box-shadow:var(--shadow-lg);
}
.nav-drawer.is-open{transform:translateX(0)}
.drawer-head{display:flex;justify-content:space-between;align-items:center}
.drawer-close{
  font-size:1.8rem;line-height:1;
  width:38px;height:38px;border-radius:10px;
  display:grid;place-items:center;color:var(--c-ink);
  transition:background var(--t-fast);
}
.drawer-close:hover{background:var(--c-cream)}
.nav-drawer nav{display:flex;flex-direction:column}
.nav-drawer nav a{
  display:block;padding:.95rem 0;
  color:var(--c-ink);font-size:1.05rem;font-weight:500;
  border-bottom:1px solid var(--c-line);
}
.nav-drawer nav a.active{color:var(--c-maroon);font-weight:600}
.nav-drawer nav a:hover{color:var(--c-maroon)}

body.no-scroll{overflow:hidden}

/* ---------- Hero ---------- */
.hero{
  position:relative;overflow:hidden;
  padding-block:clamp(60px,9vw,120px);
  background:linear-gradient(165deg,var(--c-peach) 0%,var(--c-bg) 60%);
}
.hero-grid{display:grid;gap:2.5rem;align-items:center}
.hero-copy h1{margin-bottom:1rem}
.hero-copy .lead{margin-bottom:1.75rem}
.hero-ctas{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.75rem}
.hero-trust{display:flex;flex-wrap:wrap;gap:.5rem .75rem}
.hero-trust .trust-pill{font-size:.78rem}
.hero-media{position:relative}
.hero-media img{
  border-radius:var(--r-xl);
  box-shadow:var(--shadow-lg);
  aspect-ratio:4/5;object-fit:cover;
  width:100%;
}
.hero-media::before{
  content:"";position:absolute;inset:auto -16px -16px auto;
  width:60%;height:60%;
  background:radial-gradient(closest-side,var(--c-gold) 0%,transparent 70%);
  opacity:.18;border-radius:50%;z-index:0;
  filter:blur(20px);
}

/* ---------- Marquee strip ---------- */
.marquee-strip{
  background:var(--c-maroon);color:#fff;
  padding:.9rem 0;
  overflow:hidden;
}
.marquee-strip .container{
  display:flex;flex-wrap:wrap;justify-content:center;gap:1rem 2.4rem;
  font-size:.85rem;letter-spacing:.06em;
}
.marquee-strip span{display:inline-flex;align-items:center;gap:.5rem;color:#fff}
.marquee-strip span::before{
  content:"";width:6px;height:6px;border-radius:50%;background:var(--c-gold);
  display:inline-block;
}

/* ---------- Trust pills ---------- */
.trust-pill{
  display:inline-flex;align-items:center;gap:.4rem;
  background:var(--c-bg);color:var(--c-ink);
  font-size:.82rem;font-weight:500;
  padding:.4rem .8rem;border-radius:999px;
  border:1px solid var(--c-line);
}

/* ---------- Cards ---------- */
.card{
  background:#fff;border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm);padding:1.6rem;
  transition:transform var(--t-mid),box-shadow var(--t-mid);
  border:1px solid var(--c-line);
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}

.icon{width:24px;height:24px;flex-shrink:0}
.icon-circle{
  display:grid;place-items:center;
  width:52px;height:52px;border-radius:14px;
  background:var(--c-peach);color:var(--c-maroon);
  margin-bottom:1rem;
}

/* ---------- Benefits grid ---------- */
.benefits-grid{
  display:grid;grid-template-columns:1fr;gap:1.25rem;
}
.benefit-card h3{margin-bottom:.4rem}
.benefit-card p{margin:0;color:var(--c-muted)}

/* ---------- How it works ---------- */
.steps-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;counter-reset:step}
.step-card{
  position:relative;background:#fff;border-radius:var(--r-lg);
  padding:2rem 1.6rem 1.6rem;
  border:1px solid var(--c-line);
  box-shadow:var(--shadow-sm);
}
.step-card::before{
  counter-increment:step;
  content:counter(step,decimal-leading-zero);
  position:absolute;top:-18px;left:1.4rem;
  font-family:var(--f-display);font-weight:600;font-size:1.4rem;
  color:#fff;background:var(--c-maroon);
  width:48px;height:48px;border-radius:50%;
  display:grid;place-items:center;
  box-shadow:var(--shadow-sm);
}
.step-card h3{margin-bottom:.5rem}
.step-card p{color:var(--c-muted);margin:0}

/* ---------- Before / After ---------- */
.ba-grid{display:grid;grid-template-columns:1fr;gap:1.25rem}
.ba-card{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-md);background:#fff;
}
.ba-card img{width:100%;aspect-ratio:4/5;object-fit:cover}
.ba-label{
  position:absolute;top:1rem;left:1rem;
  background:rgba(255,251,246,.95);
  color:var(--c-ink);font-weight:600;font-size:.8rem;
  letter-spacing:.1em;text-transform:uppercase;
  padding:.4rem .8rem;border-radius:999px;
}
.ba-card--after .ba-label{background:var(--c-maroon);color:#fff}

/* ---------- Featured product ---------- */
.feature-product{
  display:grid;grid-template-columns:1fr;gap:2.5rem;align-items:center;
  background:#fff;border-radius:var(--r-xl);
  padding:clamp(1.5rem,3vw,2.5rem);
  box-shadow:var(--shadow-md);border:1px solid var(--c-line);
}
.feature-product .fp-media img{
  border-radius:var(--r-lg);aspect-ratio:4/5;object-fit:cover;width:100%;
}
.fp-copy h2{margin-bottom:.5rem}
.fp-rating{display:flex;align-items:center;gap:.4rem;color:var(--c-gold-2);font-weight:600;margin-bottom:.75rem}
.fp-rating small{color:var(--c-muted);font-weight:500}
.fp-price{display:flex;align-items:baseline;gap:.6rem;margin-bottom:1rem}
.fp-price .amount{font-family:var(--f-display);font-size:2rem;font-weight:600;color:var(--c-ink)}
.fp-price .strike{color:var(--c-muted);text-decoration:line-through;font-size:1.05rem}
.fp-price .save{
  background:var(--c-peach);color:var(--c-maroon-2);
  font-size:.75rem;font-weight:700;letter-spacing:.06em;
  padding:.25rem .55rem;border-radius:999px;
}
.fp-bullets{margin:1rem 0 1.5rem}
.fp-bullets li{
  display:flex;gap:.6rem;align-items:flex-start;
  margin-bottom:.55rem;color:var(--c-ink);
}
.fp-bullets svg{color:var(--c-gold-2);margin-top:2px}
.fp-ctas{display:flex;flex-wrap:wrap;gap:.6rem}

/* ---------- Testimonials ---------- */
.testimonials-grid{display:grid;grid-template-columns:1fr;gap:1.25rem}
.testimonial{
  background:#fff;border-radius:var(--r-lg);
  padding:1.75rem;border:1px solid var(--c-line);
  box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;gap:1rem;
  transition:transform var(--t-mid),box-shadow var(--t-mid);
}
.testimonial:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.t-stars{color:var(--c-gold);letter-spacing:.1em;font-size:.95rem}
.t-quote{color:var(--c-ink);font-style:italic;margin:0;flex:1}
.t-author{display:flex;align-items:center;gap:.75rem}
.t-author img{
  width:48px;height:48px;border-radius:50%;object-fit:cover;
  border:2px solid var(--c-cream);
}
.t-author strong{display:block;font-weight:600;font-size:.95rem}
.t-author small{color:var(--c-muted);font-size:.8rem}

/* ---------- Trust row ---------- */
.trust-row-cards{
  display:grid;grid-template-columns:repeat(2,1fr);gap:.9rem;
}
.trust-card{
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
  padding:1.4rem 1rem;text-align:center;
  background:#fff;border-radius:var(--r-md);
  border:1px solid var(--c-line);
  transition:transform var(--t-fast),border-color var(--t-fast);
}
.trust-card:hover{transform:translateY(-2px);border-color:var(--c-gold)}
.trust-card .icon-circle{margin-bottom:.2rem}
.trust-card span{font-weight:500;font-size:.85rem;color:var(--c-ink)}

/* ---------- CTA banner ---------- */
.cta-banner{
  position:relative;overflow:hidden;
  background:var(--c-maroon);color:#fff;
  border-radius:var(--r-xl);
  padding:clamp(2.5rem,5vw,4rem);
  text-align:center;
}
.cta-banner::before{
  content:"";position:absolute;
  top:-30%;right:-20%;width:60%;height:160%;
  background:radial-gradient(closest-side,var(--c-gold) 0%,transparent 70%);
  opacity:.15;
}
.cta-banner h2{color:#fff;position:relative;z-index:1}
.cta-banner p{color:rgba(255,255,255,.85);max-width:520px;margin-inline:auto;position:relative;z-index:1}
.cta-banner .btn{position:relative;z-index:1;margin-top:1rem}

/* ---------- Footer ---------- */
.site-footer{
  background:var(--c-ink);color:rgba(255,255,255,.8);
  padding-block:4rem 2rem;margin-top:4rem;
}
.footer-grid{
  display:grid;grid-template-columns:1fr;gap:2.5rem;
  padding-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.1);
}
.footer-brand .brand-name{color:#fff;display:block;margin-bottom:.6rem;font-size:1.3rem}
.footer-brand p{margin-bottom:1rem;font-size:.9rem;color:rgba(255,255,255,.7)}
.footer-brand .trust-row{display:flex;flex-wrap:wrap;gap:.45rem}
.footer-brand .trust-pill{
  background:rgba(255,255,255,.08);color:#fff;
  border-color:rgba(255,255,255,.15);font-size:.72rem;
}
.site-footer h4{color:#fff;font-family:var(--f-ui);font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:1rem}
.site-footer ul li{margin-bottom:.55rem}
.site-footer ul a{color:rgba(255,255,255,.75);font-size:.92rem}
.site-footer ul a:hover{color:var(--c-gold)}
.footer-base{
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:.75rem;
  padding-top:1.5rem;
}
.footer-base small{color:rgba(255,255,255,.55);font-size:.8rem}

/* ---------- WhatsApp float ---------- */
.wa-float{
  position:fixed;right:18px;bottom:18px;z-index:50;
  background:#25D366;color:#fff;
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.85rem 1.05rem;border-radius:999px;
  box-shadow:var(--shadow-lg);
  font-weight:600;font-size:.9rem;
  transition:transform var(--t-fast),box-shadow var(--t-fast);
}
.wa-float:hover{transform:translateY(-3px);color:#fff;box-shadow:0 30px 70px rgba(37,211,102,.4)}
.wa-label{display:none}

/* ---------- Scroll Reveal ---------- */
[data-reveal]{
  opacity:0;transform:translateY(24px);
  transition:opacity 600ms ease-out,transform 600ms ease-out;
  will-change:opacity,transform;
}
[data-reveal].is-visible{opacity:1;transform:none}
[data-reveal][data-delay="1"]{transition-delay:80ms}
[data-reveal][data-delay="2"]{transition-delay:160ms}
[data-reveal][data-delay="3"]{transition-delay:240ms}
[data-reveal][data-delay="4"]{transition-delay:320ms}

/* ---------- Product page ---------- */
.pdp{padding-top:2.5rem;padding-bottom:2rem}
.pdp-grid{display:grid;grid-template-columns:1fr;gap:2.5rem}
.gallery{display:flex;flex-direction:column;gap:.75rem}
.gallery-main{
  border-radius:var(--r-lg);overflow:hidden;
  background:var(--c-cream);aspect-ratio:1/1;
  box-shadow:var(--shadow-sm);
}
.gallery-main img{width:100%;height:100%;object-fit:cover}
.gallery-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem}
.gallery-thumbs button{
  border-radius:var(--r-md);overflow:hidden;aspect-ratio:1/1;
  border:2px solid transparent;background:var(--c-cream);
  transition:border-color var(--t-fast);padding:0;
}
.gallery-thumbs button img{width:100%;height:100%;object-fit:cover}
.gallery-thumbs button.is-active{border-color:var(--c-gold)}

.pdp-details .badge{
  display:inline-block;background:var(--c-gold);color:var(--c-ink);
  font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:.3rem .7rem;border-radius:999px;margin-bottom:1rem;
}
.pdp-tagline{color:var(--c-muted);margin-bottom:1.25rem}

.swatches{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem}
.swatch{
  display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:50%;
  border:2px solid var(--c-line);cursor:pointer;
  transition:border-color var(--t-fast),transform var(--t-fast);
}
.swatch:hover,.swatch.is-active{border-color:var(--c-gold);transform:scale(1.08)}
.swatch[data-color="beige"]{background:#E8D2B5}
.swatch[data-color="black"]{background:#1f1f1f}
.swatch[data-color="maroon"]{background:var(--c-maroon)}
.swatch[data-color="skin"]{background:#D9A87C}

.size-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.5rem}
.size-row a{font-size:.85rem}
.sizes{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem}
.size-btn{
  min-width:46px;padding:.55rem .85rem;
  border-radius:var(--r-sm);border:1.5px solid var(--c-line);
  background:#fff;font-weight:600;font-size:.9rem;
  transition:all var(--t-fast);
}
.size-btn:hover{border-color:var(--c-maroon)}
.size-btn.is-active{background:var(--c-ink);color:#fff;border-color:var(--c-ink)}

.qty-row{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem}
.qty-stepper{
  display:inline-flex;align-items:center;
  border:1.5px solid var(--c-line);border-radius:999px;overflow:hidden;
}
.qty-stepper button{
  width:38px;height:38px;display:grid;place-items:center;
  font-size:1.1rem;color:var(--c-ink);
  transition:background var(--t-fast);
}
.qty-stepper button:hover{background:var(--c-cream)}
.qty-stepper input{
  width:44px;text-align:center;border:0;background:transparent;
  font-weight:600;
}

/* ---------- Tabs ---------- */
.tabs-bar{
  display:flex;flex-wrap:wrap;gap:.5rem;
  border-bottom:1px solid var(--c-line);margin-bottom:1.5rem;
}
.tab{
  padding:.85rem 1rem;font-weight:600;font-size:.95rem;
  color:var(--c-muted);position:relative;
  transition:color var(--t-fast);
}
.tab::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;
  background:var(--c-maroon);transform:scaleX(0);transform-origin:center;
  transition:transform var(--t-fast);
}
.tab:hover{color:var(--c-ink)}
.tab.is-active{color:var(--c-maroon)}
.tab.is-active::after{transform:scaleX(1)}
[data-panel]{display:none}
[data-panel].is-active{display:block;animation:fadeIn var(--t-mid)}

@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ---------- Reviews ---------- */
.review-summary{
  display:grid;grid-template-columns:1fr;gap:2rem;
  background:#fff;border:1px solid var(--c-line);
  border-radius:var(--r-lg);padding:1.75rem;margin-bottom:2rem;
}
.review-avg{text-align:center}
.review-avg .num{font-family:var(--f-display);font-size:3rem;font-weight:600;line-height:1;color:var(--c-ink)}
.review-avg .stars{color:var(--c-gold);font-size:1.1rem;letter-spacing:.1em;margin:.4rem 0}
.review-avg small{color:var(--c-muted)}
.review-bars{display:flex;flex-direction:column;gap:.5rem}
.review-bar{display:flex;align-items:center;gap:.6rem;font-size:.85rem;color:var(--c-muted)}
.review-bar .label{width:36px;flex-shrink:0}
.review-bar .track{flex:1;height:8px;background:var(--c-cream);border-radius:999px;overflow:hidden}
.review-bar .fill{height:100%;background:var(--c-gold);border-radius:999px;transition:width var(--t-slow)}
.review-bar .pct{width:38px;text-align:right;flex-shrink:0}

.review-cards{display:grid;grid-template-columns:1fr;gap:1rem}
.review-card{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);
  padding:1.4rem;
}
.review-head{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem;margin-bottom:.6rem}
.review-head strong{display:block}
.review-head small{color:var(--c-muted)}
.verified{
  display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.06em;
  color:#1a7a4d;background:#E6F4EC;padding:.18rem .5rem;border-radius:999px;
  margin-left:.4rem;
}

/* ---------- Sticky mobile buy bar ---------- */
.sticky-buy{
  position:fixed;left:0;right:0;bottom:0;z-index:55;
  background:#fff;border-top:1px solid var(--c-line);
  box-shadow:0 -4px 20px rgba(42,27,30,.08);
  padding:.7rem var(--gutter);
  display:flex;align-items:center;justify-content:space-between;gap:.75rem;
  transform:translateY(110%);transition:transform var(--t-mid);
}
.sticky-buy.is-visible{transform:translateY(0)}
.sticky-buy .price{font-family:var(--f-display);font-weight:600;font-size:1.2rem;color:var(--c-ink)}
.sticky-buy .btn{flex:1}

/* ---------- Modal ---------- */
.modal{
  position:fixed;inset:0;z-index:120;
  display:none;align-items:center;justify-content:center;
  padding:1rem;
}
.modal.is-open{display:flex}
.modal-scrim{position:absolute;inset:0;background:rgba(42,27,30,.6);animation:fadeIn var(--t-fast)}
.modal-dialog{
  position:relative;z-index:1;background:#fff;
  border-radius:var(--r-xl);max-width:520px;width:100%;
  max-height:92vh;overflow:auto;
  padding:2rem;box-shadow:var(--shadow-lg);
  animation:popIn var(--t-mid);
}
@keyframes popIn{from{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:none}}
.modal-close{
  position:absolute;top:.6rem;right:.8rem;
  width:38px;height:38px;border-radius:50%;
  display:grid;place-items:center;font-size:1.4rem;
  transition:background var(--t-fast);
}
.modal-close:hover{background:var(--c-cream)}
.modal-steps{display:flex;gap:.5rem;margin-bottom:1.25rem}
.modal-step{
  flex:1;padding:.4rem .5rem;text-align:center;
  font-size:.78rem;color:var(--c-muted);
  border-bottom:2px solid var(--c-line);
}
.modal-step.is-active{color:var(--c-maroon);border-bottom-color:var(--c-maroon);font-weight:600}

/* ---------- FAQ accordion ---------- */
.faq-list{display:flex;flex-direction:column;gap:.6rem}
.faq{
  background:#fff;border:1px solid var(--c-line);
  border-radius:var(--r-md);overflow:hidden;
  transition:border-color var(--t-fast);
}
.faq[open]{border-color:var(--c-gold)}
.faq summary{
  list-style:none;cursor:pointer;
  padding:1.1rem 1.2rem;display:flex;justify-content:space-between;
  align-items:center;gap:1rem;font-weight:600;color:var(--c-ink);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";font-family:var(--f-display);font-size:1.5rem;font-weight:400;
  color:var(--c-maroon);
  transition:transform var(--t-fast);
}
.faq[open] summary::after{content:"−"}
.faq-body{padding:0 1.2rem 1.2rem;color:var(--c-muted)}

/* ---------- Size table ---------- */
.size-table-wrap{overflow-x:auto;border-radius:var(--r-md);border:1px solid var(--c-line);background:#fff}
.size-table{width:100%;border-collapse:collapse;font-size:.95rem;min-width:520px}
.size-table thead{background:var(--c-cream);position:sticky;top:0}
.size-table th,.size-table td{padding:.85rem 1rem;text-align:left;border-bottom:1px solid var(--c-line)}
.size-table th{font-family:var(--f-ui);font-weight:600;letter-spacing:.04em}
.size-table tr:last-child td{border-bottom:0}
.size-table tbody tr:hover{background:var(--c-bg)}

/* ---------- Forms ---------- */
.form{display:grid;gap:1rem}
.form .field{display:flex;flex-direction:column;gap:.4rem}
.form label{font-size:.88rem;font-weight:500;color:var(--c-ink)}
.form input,.form textarea,.form select{
  width:100%;padding:.85rem 1rem;
  background:#fff;border:1.5px solid var(--c-line);
  border-radius:var(--r-md);
  transition:border-color var(--t-fast),box-shadow var(--t-fast);
}
.form input:focus,.form textarea:focus,.form select:focus{
  outline:none;border-color:var(--c-gold);
  box-shadow:0 0 0 3px rgba(201,162,75,.2);
}
.form textarea{min-height:140px;resize:vertical}
.form [aria-invalid="true"]{border-color:#c0392b}

.toast{
  position:fixed;left:50%;bottom:24px;
  transform:translate(-50%,120%);z-index:130;
  background:var(--c-ink);color:#fff;
  padding:.85rem 1.4rem;border-radius:999px;
  font-size:.92rem;font-weight:500;
  box-shadow:var(--shadow-lg);
  transition:transform var(--t-mid);
}
.toast.is-visible{transform:translate(-50%,0)}

/* ---------- Press strip ---------- */
.press-strip{display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem 2.5rem}
.press-logo{
  font-family:var(--f-display);font-weight:600;font-size:1.05rem;
  color:var(--c-muted);letter-spacing:.04em;
  filter:grayscale(1);opacity:.75;
}

/* ---------- Quote block (about) ---------- */
.quote-block{
  background:#fff;border-radius:var(--r-xl);
  padding:clamp(1.75rem,4vw,3rem);
  border-left:4px solid var(--c-gold);
  box-shadow:var(--shadow-sm);
  font-family:var(--f-display);font-style:italic;
  font-size:clamp(1.15rem,2vw,1.4rem);
  color:var(--c-ink);line-height:1.5;
}

/* ---------- Breakpoints ---------- */
@media (min-width:720px){
  .hide-sm{display:inline-flex}
  .hero-grid{grid-template-columns:1.05fr 1fr}
  .benefits-grid{grid-template-columns:repeat(2,1fr)}
  .steps-grid{grid-template-columns:repeat(3,1fr)}
  .ba-grid{grid-template-columns:repeat(2,1fr)}
  .feature-product{grid-template-columns:1fr 1fr;gap:3rem}
  .testimonials-grid{grid-template-columns:repeat(3,1fr)}
  .trust-row-cards{grid-template-columns:repeat(5,1fr)}
  .pdp-grid{grid-template-columns:1.05fr 1fr;gap:3rem}
  .footer-grid{grid-template-columns:2fr 1fr 1fr 1.2fr}
  .review-summary{grid-template-columns:200px 1fr;align-items:center}
  .review-cards{grid-template-columns:repeat(2,1fr)}
  .wa-label{display:inline}
}

@media (min-width:1024px){
  .nav-primary{display:flex}
  .hamburger{display:none}
  .hero{padding-block:140px}
  .benefits-grid{grid-template-columns:repeat(3,1fr)}
  .sticky-buy{display:none}
}

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