/* ════════════════════════════════════════════════════════════
   FAVOURITE CARE — Design v2 (Claude Design handoff port)
   Source: ecommerce-reference-build/assets/fc.css
   Loads LAST. Overrides style.css / commerce.css / tokens.css.
   Fraunces = H1/H2 · Poppins = UI/body · Dancing Script = accents
   ════════════════════════════════════════════════════════════ */
:root{
  --plum:#3D3463; --plum-deep:#332B52; --violet:#6B5396;
  --orchid:#B05F9D; --orchid-soft:#CE93BE;
  --sage:#7FA593; --sage-light:#CFE3D9;
  --ivory:#FBF8F4; --ivory-deep:#F6F1EA;
  --blush-wash:#F7EFF3; --sage-wash:#EFF4F1;
  --d2-card:#FFFFFF; --footer-bg:#332B52;
  --heading:#2E2A45; --body-c:#4A465E; --muted:#8B869C; --line:#E9E2DA;
  --success:#4E7D60; --warning:#B98A3E; --error:#B05454;
  --grad-cta:linear-gradient(120deg,#3D3463,#6B5396);
  --shadow-card:0 18px 44px -30px rgba(61,52,99,.4);
  --shadow-btn:0 14px 30px -14px rgba(61,52,99,.5);
  --font-display:"Fraunces",Georgia,serif;
  --font-ui:"Poppins",sans-serif;
  --font-script:"Dancing Script",cursive;
  --font-mono:ui-monospace,Menlo,Consolas,monospace;
}
html{scroll-behavior:smooth}
body{background:var(--ivory);color:var(--body-c);font:400 16px/1.7 var(--font-ui)}
::selection{background:var(--orchid);color:#fff}
h1,h2{font-family:var(--font-display);font-weight:600;color:var(--heading);letter-spacing:-.02em}
h1{font-size:clamp(38px,5.4vw,68px);line-height:1.06}
h2{font-size:clamp(28px,3.8vw,44px);line-height:1.14}
h1 em,h2 em{font-family:var(--font-script);font-style:normal;font-weight:700;color:var(--orchid)}
.eyebrow,.fc-eyebrow,.fch-eyebrow{margin:0 0 14px;color:var(--orchid);font:700 11px/1.2 var(--font-ui);letter-spacing:.18em;text-transform:uppercase}
.lede{margin:0 0 28px;max-width:34em;font-size:17.5px}
.d2-section{padding:88px 0}
.sec-head{max-width:640px;margin-bottom:44px}

/* ── buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:15px 32px;border:0;border-radius:999px;font:600 14px/1 var(--font-ui);text-decoration:none;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn-primary{background:var(--grad-cta);color:#fff;box-shadow:var(--shadow-btn)}
.btn-primary:hover{background:var(--grad-cta);color:#fff}
.btn-ghost,.btn-secondary{border:1.5px solid rgba(61,52,99,.28);color:var(--plum);background:rgba(255,255,255,.7)}
.btn-light{background:#fff;color:var(--plum);box-shadow:0 14px 30px -16px rgba(0,0,0,.4)}
.btn-small{padding:11px 22px;font-size:13px;background:var(--plum);color:#fff}
.btn-small:hover{background:var(--violet);color:#fff}
.btn-mid{padding:12px 24px;font-size:13px}
.btn-block{width:100%;margin-top:16px}

/* ── chips ── */
.chips{display:flex;flex-wrap:wrap;gap:10px;padding:0;margin:0;list-style:none}
.chips li{display:flex;align-items:center;gap:8px;padding:8px 16px;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.85);color:var(--plum);font:600 12px/1.2 var(--font-ui)}
.chips li::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--sage)}

/* ── ticker (replaces static trust strip) ── */
.ticker{overflow:hidden;background:var(--plum-deep)}
.ticker-track{display:flex;width:max-content;animation:fc-tick 30s linear infinite}
.ticker span{display:flex;align-items:center;gap:9px;padding:9px 26px;color:#D9D3EC;font:600 11px/1.2 var(--font-ui);letter-spacing:.16em;text-transform:uppercase;white-space:nowrap}
.ticker span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--sage)}
@keyframes fc-tick{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.ticker-track{animation:none}}

/* ── header ── */
.site-header{position:sticky;top:0;z-index:60;background:rgba(251,248,244,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);box-shadow:none}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:14px 24px}
.site-header .logo img{height:46px;width:auto;display:block}
.site-header .nav{display:flex;gap:26px}
.site-header .nav li{list-style:none}
.site-header .nav a{color:var(--heading);font:500 14px/1 var(--font-ui);text-decoration:none;white-space:nowrap;padding-bottom:4px;border-bottom:2px solid transparent;transition:color .15s;background:none}
.site-header .nav a:hover{color:var(--plum)}
.site-header .nav a.active,
.site-header .nav .current-menu-item > a,
.site-header .nav .current_page_item > a{color:var(--plum);border-bottom-color:var(--orchid)}
.header-cta{display:flex;align-items:center;gap:12px}
.header-cta .btn{padding:12px 24px;font-size:13px}
.icon-btn.fc-cart-toggle{position:relative;width:42px;height:42px;display:grid;place-items:center;border:1px solid var(--line);border-radius:50%;background:#fff;color:var(--plum);transition:transform .18s;padding:0}
.icon-btn.fc-cart-toggle:hover{transform:translateY(-2px);background:#fff}
.cart-count{position:absolute;top:-6px;right:-6px;min-width:19px;height:19px;display:grid;place-items:center;padding:0 4px;border:2px solid #fff;border-radius:999px;background:var(--orchid);color:#fff;font:700 10px/1 var(--font-ui)}
@media (prefers-reduced-motion:no-preference){
  .cart-count.pop{animation:fc-pop .35s ease}
  @keyframes fc-pop{0%{transform:scale(1)}40%{transform:scale(1.5)}100%{transform:scale(1)}}
}

/* mobile nav drawer (built by mobile-nav.js) */
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;padding:0 10px;border:1px solid var(--line);border-radius:12px;background:#fff;cursor:pointer}
.hamburger span{display:block;height:2px;border-radius:2px;background:var(--plum);transition:transform .2s,opacity .2s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
body.nav-open{overflow:hidden}
.mobile-nav-drawer{display:none;position:fixed;top:0;right:0;left:0;bottom:0;z-index:58;flex-direction:column;gap:4px;padding:120px 24px 32px;background:var(--ivory);border:0;overflow-y:auto;box-shadow:none}
.mobile-nav-drawer.open{display:flex}
.mobile-nav-drawer a{padding:13px 4px;min-height:0;color:var(--heading);font:600 16px/1.3 var(--font-ui);text-decoration:none;border-bottom:1px solid var(--line)}
.mobile-nav-drawer a.active{color:var(--orchid)}
.mobile-nav-drawer .mobile-nav-cta{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:18px}
.mobile-nav-drawer .mobile-nav-cta a{border-bottom:0;text-align:center;justify-content:center;padding:15px 18px;border-radius:999px;font-size:14px;min-height:0;height:auto}
.mobile-nav-drawer .mobile-nav-cta .btn-primary{grid-column:1/-1}
.mobile-nav-drawer .mobile-nav-cta .btn-primary{color:#fff !important;background:var(--grad-cta)}
.mobile-nav-drawer .mobile-nav-cta .btn-secondary{color:var(--plum) !important;background:#fff;border:1.5px solid rgba(61,52,99,.28)}
@media (max-width:900px){
  .site-header .nav{display:none}
  .hamburger{display:flex}
  .icon-btn.fc-cart-toggle{display:grid !important}
}

/* ── footer ── */
.site-footer{background:var(--footer-bg);color:#B9B3CE;padding:0;margin-top:0}
.site-footer .foot-news{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px;padding:44px 0;border-bottom:1px solid rgba(255,255,255,.12)}
.site-footer .foot-news h3{margin:0 0 6px;color:#fff;font:600 26px/1.2 var(--font-display)}
.site-footer .foot-news h3 em{font-family:var(--font-script);font-style:normal;font-weight:700;color:#E2B8D6}
.site-footer .foot-news p{margin:0;font-size:13.5px}
.news-form{display:flex;gap:10px;flex-wrap:wrap}
.news-form input{width:280px;min-height:48px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.08);color:#fff;padding:0 18px;font:500 14px/1.4 var(--font-ui)}
.news-form input::placeholder{color:#B9B3CE}
.news-form .news-done{color:#CFE3D9;font:600 13px/1.4 var(--font-ui)}
.site-footer .footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:36px;padding:48px 0 36px}
.site-footer h4{color:#fff;font:700 12px/1.2 var(--font-ui);letter-spacing:.1em;text-transform:uppercase}
.site-footer ul{margin:0;padding:0;list-style:none;display:grid;gap:10px}
.site-footer ul a{color:#CFC9E2;font:400 13.5px/1.4 var(--font-ui);text-decoration:none}
.site-footer ul a:hover{color:#fff}
.site-footer .footer-brand p{font-size:13px}
.pay-chips{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 0;padding:0;list-style:none}
.pay-chips b{padding:6px 12px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--muted);font:700 10px/1.2 var(--font-ui);letter-spacing:.07em;text-transform:uppercase}
.site-footer .pay-chips{display:flex;justify-content:center;margin:0;padding:22px 0 0;border-top:1px solid rgba(255,255,255,.12)}
.site-footer .pay-chips b{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.16);color:#CFC9E2}
.site-footer .fc-footer-trust{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 26px;margin:0;padding:22px 0;border-top:1px solid rgba(255,255,255,.12);border-bottom:0;list-style:none}
.site-footer .fc-footer-trust li{display:flex;align-items:center;gap:8px;color:#CFC9E2;font:600 12px/1.4 var(--font-ui)}
.site-footer .fc-footer-trust li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--sage)}
.site-footer .footer-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;padding:18px 0 26px;border-top:1px solid rgba(255,255,255,.12);font-size:12px}

/* ── hero (home) ── */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line);background:radial-gradient(circle at 88% 8%,rgba(176,95,157,.16),transparent 30rem),radial-gradient(circle at 8% 92%,rgba(127,165,147,.14),transparent 26rem),linear-gradient(180deg,#FDFAF6,#F7EFF3)}
.hero::before{content:"";position:absolute;top:-180px;right:-140px;width:560px;height:560px;border-radius:50%;background:rgba(206,147,190,.18)}
.hero-grid{position:relative;display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:48px;padding:92px 24px 104px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:28px}
.float-cards{position:relative;min-height:420px}
.float-card{position:absolute;width:212px;padding:14px;background:#fff;border:1px solid var(--line);border-radius:22px;box-shadow:0 24px 50px -24px rgba(61,52,99,.35);text-decoration:none;transition:box-shadow .2s}
.float-card:hover{box-shadow:0 30px 60px -24px rgba(61,52,99,.5)}
.float-card img{display:block;width:100%;height:148px;object-fit:contain;border-radius:14px;background:var(--blush-wash);padding:8px;box-sizing:border-box}
.float-card b{display:block;margin-top:10px;color:var(--heading);font:600 13px/1.35 var(--font-ui)}
.float-card i{display:block;margin-top:4px;color:var(--orchid);font:700 13px/1.2 var(--font-ui);font-style:normal}
.float-card i .fc-price-prefix{font-weight:600;color:var(--muted)}
.f0{top:2%;right:30%;--rot:-4deg;z-index:3}
.f1{top:32%;right:0;--rot:3deg;z-index:2;animation-delay:1.2s}
.f2{bottom:0;right:40%;--rot:-2deg;animation-delay:2.4s}
@media (prefers-reduced-motion:no-preference){
  .float-card{animation:fc-float 7s ease-in-out infinite;transform:rotate(var(--rot))}
  @keyframes fc-float{0%,100%{transform:translateY(0) rotate(var(--rot))}50%{transform:translateY(-12px) rotate(var(--rot))}}
}
@media (prefers-reduced-motion:reduce){.float-card{transform:rotate(var(--rot))}}

/* ── page hero (inner pages) ── */
.page-hero{border-bottom:1px solid var(--line);background:radial-gradient(circle at 88% 8%,rgba(176,95,157,.14),transparent 26rem),linear-gradient(180deg,#FDFAF6,#F7EFF3)}
.page-hero .container{padding:64px 24px 56px}
.page-hero h1{font-size:clamp(32px,4.4vw,52px)}
.page-hero .lede{margin-bottom:22px}

/* ── category cards ── */
.cat-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.cat-card{display:flex;align-items:center;gap:18px;padding:20px 24px;border:1px solid var(--line);border-radius:22px;text-decoration:none;transition:transform .2s,box-shadow .2s}
.cat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card)}
.cat-card.blush{background:var(--blush-wash)}
.cat-card.sage{background:var(--sage-wash)}
.cat-card .cat-media{flex:0 0 76px;width:76px;height:76px;border-radius:50%;overflow:hidden;background:#fff}
.cat-card .cat-media img{width:100%;height:100%;object-fit:cover;display:block}
.cat-card b{display:block;color:var(--heading);font:600 16.5px/1.3 var(--font-ui)}
.cat-card span{display:block;color:var(--body-c);font-size:12.5px;line-height:1.55}
.cat-card i{display:block;margin-top:5px;color:var(--orchid);font:600 12px/1.3 var(--font-ui);font-style:normal}

/* ── product cards (home grid + woo loop) ── */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.d2-card{background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow-card)}
.prod-card{display:flex;flex-direction:column;overflow:hidden;transition:transform .2s,box-shadow .2s}
.prod-card:hover{transform:translateY(-5px);box-shadow:0 26px 54px -28px rgba(61,52,99,.5)}
.prod-card .media{position:relative;display:block;padding:18px 18px 0}
.prod-card .media img{display:block;width:100%;height:248px;object-fit:contain;border-radius:160px 160px 16px 16px;background:var(--blush-wash);padding:16px;box-sizing:border-box}
.prod-card .body{display:flex;flex-direction:column;flex:1;padding:22px 24px 26px}
.prod-card .cat{margin:0 0 5px;color:var(--orchid);font:700 10.5px/1.2 var(--font-ui);letter-spacing:.14em;text-transform:uppercase}
.prod-card h3{font-family:var(--font-ui);font-size:18px;margin:0 0 8px}
.prod-card h3 a{color:var(--heading);text-decoration:none}
.prod-card h3 a:hover{color:var(--plum)}
.prod-card .benefit{margin:4px 0 16px;color:var(--muted);font-size:13px;line-height:1.6}
.prod-card .foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:auto}
.prod-card .price{color:var(--plum);font:700 16px/1.2 var(--font-ui)}
.pbadge{position:absolute;top:14px;left:50%;transform:translateX(-50%);z-index:2;padding:6px 14px;border-radius:999px;background:var(--plum);color:#fff;font:700 10px/1.2 var(--font-ui);letter-spacing:.12em;text-transform:uppercase;box-shadow:0 8px 18px -8px rgba(61,52,99,.5);white-space:nowrap}
.pbadge.new{background:var(--orchid)}

/* woo loop cards inherit the same look (li prefix outranks commerce.css) */
ul.products.fc-product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin:0;padding:0;list-style:none}
li.fc-product-card{display:flex;flex-direction:column;overflow:hidden;background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow-card);transition:transform .2s,box-shadow .2s}
li.fc-product-card:hover{transform:translateY(-5px);box-shadow:0 26px 54px -28px rgba(61,52,99,.5);border-color:var(--line)}
li.fc-product-card .fc-product-card__media{position:relative;display:block;min-height:0;padding:18px 18px 0;background:transparent}
li.fc-product-card .fc-product-card__media img{display:block;width:100%;height:248px;object-fit:contain;padding:16px;box-sizing:border-box;border-radius:160px 160px 16px 16px;background:var(--blush-wash)}
li.fc-product-card:hover .fc-product-card__media img{transform:none}
.fc-product-badge{position:absolute;top:28px;left:50%;transform:translateX(-50%);z-index:2;padding:6px 14px;border-radius:999px;background:var(--plum);color:#fff;font:700 10px/1.2 var(--font-ui);letter-spacing:.12em;text-transform:uppercase;box-shadow:0 8px 18px -8px rgba(61,52,99,.5);white-space:nowrap}
.fc-product-badge.is-new{background:var(--orchid)}
li.fc-product-card .fc-product-card__body{display:grid;grid-template-columns:1fr auto;align-items:center;gap:0 12px;flex:1;padding:22px 24px 26px}
li.fc-product-card .fc-product-card__type,
li.fc-product-card .fc-product-card__body h2,
li.fc-product-card .fc-product-card__benefit{grid-column:1/-1}
li.fc-product-card .fc-product-card__type{margin:0 0 5px;color:var(--orchid);font:700 10.5px/1.2 var(--font-ui);letter-spacing:.14em;text-transform:uppercase;min-height:0}
li.fc-product-card .fc-product-card__body h2{font:600 18px/1.4 var(--font-ui);font-family:var(--font-ui) !important;margin:0 0 8px;letter-spacing:0}
li.fc-product-card .fc-product-card__body h2 a{color:var(--heading);text-decoration:none}
li.fc-product-card .fc-product-card__body h2 a:hover{color:var(--plum)}
li.fc-product-card .fc-product-card__benefit{margin:4px 0 16px;color:var(--muted);font-size:13px;line-height:1.6;align-self:start}
li.fc-product-card .fc-product-card__meta{grid-column:1;display:flex;align-items:center;margin:0;padding:0;border:0}
li.fc-product-card .fc-product-card__meta .price{color:var(--plum);font:700 16px/1.2 var(--font-ui);margin:0}
li.fc-product-card .stock{display:none}
li.fc-product-card .fc-product-card__button{grid-column:2;width:auto;margin:0;padding:11px 22px;border-radius:999px;background:var(--plum);color:#fff;font:600 13px/1 var(--font-ui);text-align:center;box-shadow:none}
li.fc-product-card .fc-product-card__button:hover{background:var(--violet);transform:translateY(-2px)}

/* ── steps (dark band) ── */
.steps{padding:92px 0;background:radial-gradient(circle at 90% 0%,rgba(176,95,157,.25),transparent 26rem),linear-gradient(135deg,#332B52,#4A3D78)}
.steps .eyebrow{color:#E2B8D6}
.steps h2{color:#fff}
.steps h2 em{color:#E2B8D6}
.steps .sec-head p{color:rgba(255,255,255,.75)}
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin:0;padding:0;list-style:none}
.steps-grid li{position:relative;overflow:hidden;padding:28px 24px;border:1px solid rgba(255,255,255,.14);border-radius:22px;background:rgba(255,255,255,.06)}
.step-num{display:inline-grid;width:36px;height:36px;place-items:center;margin-bottom:16px;border-radius:50%;background:var(--orchid);color:#fff;font:700 14px/1 var(--font-ui)}
.step-ghost{position:absolute;top:2px;right:14px;font:700 72px/1 var(--font-display);color:rgba(255,255,255,.07)}
.steps-grid h3{color:#fff;font-family:var(--font-ui);font-size:16px;margin:0 0 8px}
.steps-grid p{margin:0;color:rgba(255,255,255,.78);font-size:13.5px}

/* ── story ── */
.story{padding:92px 0;background:var(--blush-wash);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.story-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center}
.story-media{overflow:hidden;border-radius:999px 999px 26px 26px;background:var(--sage-wash)}
.story-media img{display:block;width:100%;height:440px;object-fit:cover}
.story .chips{margin-top:22px}

/* ── FAQ ── */
.faq{padding:92px 0;background:var(--sage-wash);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.faq-inner{display:grid;grid-template-columns:.85fr 1.15fr;gap:56px;align-items:start}
.faq-list{display:grid;gap:12px}
.faq-item{border:1px solid var(--line);border-radius:18px;background:#fff;overflow:hidden}
.faq-item summary{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px;color:var(--heading);font:600 15px/1.4 var(--font-ui);cursor:pointer;list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";flex:0 0 auto;display:grid;place-items:center;width:28px;height:28px;border:1px solid var(--line);border-radius:50%;color:var(--orchid);font:600 16px/1 var(--font-ui);transition:transform .2s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{margin:0;padding:0 22px 20px;font-size:14px;color:var(--body-c)}
.acc-list{display:grid;gap:12px;max-width:760px;margin-top:8px}

/* ── trust band ── */
.band{background:var(--sage-wash);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:56px 0}
.band-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;margin:0;padding:0;list-style:none}
.band-grid li{display:grid;justify-items:start;gap:6px}
.band-grid strong{color:var(--heading);font:600 15px/1.3 var(--font-ui)}
.band-grid span{font-size:13px}

/* ── CTA panel ── */
.cta-panel{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:28px;padding:48px 56px;border-radius:30px;background:radial-gradient(circle at 88% 0%,rgba(176,95,157,.25),transparent 24rem),linear-gradient(135deg,#332B52,#4A3D78)}
.cta-panel .eyebrow{color:#E2B8D6}
.cta-panel h2{color:#fff;margin-bottom:10px}
.cta-panel h2 em{color:#E2B8D6}
.cta-panel p{margin:0;max-width:38em;color:rgba(255,255,255,.82);font-size:15px}

/* ── shop filters ── */
.filter-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px;margin:0 0 30px}
.filter-chips{display:flex;flex-wrap:wrap;gap:8px}
.fchip{padding:10px 20px;border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--plum);font:600 12.5px/1.2 var(--font-ui);cursor:pointer;text-decoration:none;transition:background .15s,color .15s,border-color .15s}
.fchip:hover{background:var(--blush-wash)}
.fchip.active{background:var(--plum);border-color:var(--plum);color:#fff}
.sort-wrap{display:flex;align-items:center;gap:14px}
.shop-count,.woocommerce-result-count{color:var(--muted);font:600 12.5px/1.2 var(--font-ui);white-space:nowrap;margin:0}
.woocommerce-ordering select{width:auto;min-width:190px;min-height:44px;border:1px solid var(--line);border-radius:12px;padding:0 14px;background:#fff;color:var(--heading);font:500 13px/1.4 var(--font-ui)}
.fc-shop-toolbar{display:flex;align-items:center;gap:14px;flex-wrap:wrap}

/* ── PDP buy box ── */
.fc-product-summary{background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow-card);padding:34px;position:sticky;top:96px}
.fc-product-summary .product_title{font-family:var(--font-display);font-size:clamp(30px,3.4vw,40px);line-height:1.08;color:var(--heading);margin:0 0 12px;letter-spacing:-.02em}
.fc-product-summary .price{margin:14px 0;color:var(--heading);font:700 26px/1.2 var(--font-ui)}
.stock-line{display:flex;align-items:center;gap:8px;margin:0 0 8px;color:var(--success);font:600 12.5px/1.4 var(--font-ui)}
.stock-line::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--success)}
.pdp-sku{margin:10px 0 0;color:var(--muted);font:500 10.5px/1.4 var(--font-mono);letter-spacing:.06em;text-transform:uppercase}
.secure-line{display:flex;align-items:center;gap:8px;margin:16px 0 0;color:var(--muted);font:600 11.5px/1.5 var(--font-ui)}

/* qty stepper (JS wraps woo qty input) */
.stepper{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:999px;background:var(--ivory-deep);overflow:hidden}
.stepper button{width:40px;height:48px;border:0;background:transparent;color:var(--plum);font:600 18px/1 var(--font-ui);cursor:pointer;border-radius:0;box-shadow:none;padding:0}
.stepper button:hover{background:rgba(61,52,99,.07);transform:none}
.stepper input.qty,.stepper input{width:44px;min-height:48px;border:0;border-radius:0;background:transparent;text-align:center;padding:0;font-weight:600}
.stepper input:focus{outline:none}

/* ── checkout / cart detail layer ── */
.steps-ind{display:flex;flex-wrap:wrap;gap:8px;margin:22px 0 0;padding:0;list-style:none}
.steps-ind li{display:flex;align-items:center;gap:9px;padding:9px 18px 9px 10px;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.8);color:var(--muted);font:600 12px/1.2 var(--font-ui)}
.steps-ind li span{display:grid;place-items:center;width:22px;height:22px;border-radius:50%;background:var(--ivory-deep);color:var(--muted);font-size:10.5px}
.steps-ind li.cur{border-color:var(--orchid-soft);color:var(--plum)}
.steps-ind li.cur span{background:var(--orchid);color:#fff}
.steps-ind li.done{color:var(--success)}
.steps-ind li.done span{background:var(--sage-wash);color:var(--success)}
.woocommerce-checkout #payment{background:transparent !important;border:0 !important;box-shadow:none !important;padding:0 !important;border-radius:0}
ul.wc_payment_methods{margin:12px 0 2px !important;padding:0 !important;list-style:none;display:grid;gap:10px;background:transparent !important;border:0 !important}
ul.wc_payment_methods li.wc_payment_method{position:relative;padding:14px 16px !important;border:1.5px solid var(--line) !important;border-radius:14px;background:#fff;transition:border-color .15s,background .15s;margin:0}
ul.wc_payment_methods li.wc_payment_method:has(input:checked),ul.wc_payment_methods li.wc_payment_method.checked{border-color:var(--orchid) !important;background:var(--blush-wash)}
.wc_payment_method label{display:inline;color:var(--heading);font:600 14px/1.4 var(--font-ui);cursor:pointer;margin:0;padding:0}
.wc_payment_method .payment_box{margin:6px 0 0;padding:0;background:transparent !important;border:0 !important;color:var(--muted);font-size:12.5px}
.wc_payment_method .payment_box p{margin:0;color:var(--muted);font-size:12.5px}
.wc_payment_method .payment_box::before{display:none}
.trust-mini{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 18px;margin:16px 0 0;padding:0;list-style:none}
.trust-mini li{display:flex;align-items:center;gap:6px;color:var(--muted);font:600 11px/1.4 var(--font-ui)}
.trust-mini li::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--sage)}
.privacy,.woocommerce-privacy-policy-text p{color:var(--muted);font-size:12px}

/* ── WhatsApp float / back-to-top ── */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:70;display:flex;align-items:center;gap:10px;width:56px;height:56px;justify-content:center;border-radius:999px;background:var(--success);color:#fff;font-size:22px;text-decoration:none;box-shadow:0 16px 34px -12px rgba(78,125,96,.7);transition:transform .18s}
.wa-float:hover{transform:translateY(-3px)}
.wa-float small{display:none;font:600 12.5px/1 var(--font-ui);white-space:nowrap}
@media (min-width:900px){
  .wa-float:hover{width:auto;padding:0 22px}
  .wa-float:hover small{display:block}
}
.to-top{position:fixed;right:24px;bottom:92px;z-index:69;width:46px;height:46px;border:1px solid var(--line);border-radius:50%;background:#fff;color:var(--plum);font-size:17px;cursor:pointer;box-shadow:var(--shadow-card);opacity:0;pointer-events:none;transform:translateY(8px);transition:opacity .25s,transform .25s}
.to-top.show{opacity:1;pointer-events:auto;transform:none}
body.single-product .wa-float{bottom:92px}
body.single-product .to-top{bottom:152px}
@media (min-width:769px){
  body.single-product .wa-float{bottom:22px}
  body.single-product .to-top{bottom:92px}
}

/* ── scroll reveal ── */
html.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
html.js .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){html.js .reveal{opacity:1;transform:none;transition:none}}

/* ── responsive ── */
@media (max-width:1020px){
  .hero-grid{grid-template-columns:1fr;gap:64px;padding:64px 24px 80px}
  .float-cards{min-height:400px;max-width:520px}
  .story-grid{grid-template-columns:1fr;gap:40px}
  .story-media img{height:320px}
  .faq-inner{grid-template-columns:1fr;gap:32px}
  .steps-grid{grid-template-columns:1fr 1fr}
  .prod-grid,.cat-cards{grid-template-columns:1fr 1fr}
  ul.products.fc-product-grid{grid-template-columns:1fr 1fr}
  .fc-product-summary{position:static}
}
@media (max-width:680px){
  .prod-grid,.cat-cards,.steps-grid{grid-template-columns:1fr}
  ul.products.fc-product-grid{grid-template-columns:1fr}
  .band-grid{grid-template-columns:1fr 1fr}
  .site-footer .footer-grid{grid-template-columns:1fr 1fr}
  .d2-section{padding:64px 0}
  .cta-panel{padding:36px 28px}
  .news-form input{width:100%;min-width:0;flex:1}
  .float-card{width:172px}
  .float-card img{height:116px}
  .f0{right:auto;left:0}
  /* hero cards become a swipeable row */
  .float-cards{display:flex;gap:14px;overflow-x:auto;min-height:0;max-width:none;padding:6px 2px 14px;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory}
  .float-card{position:static;flex:0 0 200px;width:200px;animation:none;transform:none;scroll-snap-align:start}
  .float-card img{height:130px}
  .hero-grid{padding-bottom:52px;gap:36px}
  .fc-product-summary{padding:26px 22px}
}
@media (max-width:420px){
  .band-grid,.site-footer .footer-grid{grid-template-columns:1fr}
}

/* ════ AUDIT FIX PASS (mobile polish) ════ */

/* variation lists everywhere: one compact muted line */
dl.variation{display:flex !important;flex-wrap:wrap;align-items:baseline;gap:2px 12px;margin:6px 0 0;font-size:12px;line-height:1.5;grid-template-columns:none}
dl.variation dt{margin:0;padding:0;float:none;width:auto;color:var(--muted);font:600 11px/1.5 var(--font-ui)}
dl.variation dd{margin:0 0 0 -8px;padding:0;float:none;width:auto;color:var(--body-c)}
dl.variation dd p{margin:0;display:inline;font-size:12px}

/* cat-card media: contain, no awkward crops (air purifier logo) */
.cat-card .cat-media{background:#fff}
.cat-card .cat-media img{object-fit:contain;padding:8px;box-sizing:border-box}

/* footer address: plain text, not a pill */
.site-footer .footer-bottom .parent-mark{background:none;border:0;padding:0;border-radius:0;color:#B9B3CE;font-size:11.5px;line-height:1.6;max-width:100%}

/* cart totals: clean rows, no beige label blocks */
.cart_totals table th,.cart_totals table td{background:transparent !important;border:0;border-bottom:1px solid var(--line);padding:12px 0;font-size:14px;vertical-align:top}
.cart_totals table tr:last-child th,.cart_totals table tr:last-child td{border-bottom:0}
.cart_totals table th{color:var(--muted);font:600 12px/1.5 var(--font-ui);letter-spacing:.06em;text-transform:uppercase;text-align:left;width:40%}
.cart_totals .order-total th,.cart_totals .order-total td{color:var(--heading);font-weight:700}
.woocommerce-shipping-calculator,.woocommerce-shipping-destination{display:none}
.woocommerce-shipping-methods{margin:0;padding:0;list-style:none}

@media (max-width:900px){
  /* WhatsApp float off cart/checkout: it covered steppers and inputs */
  body.woocommerce-cart .wa-float,
  body.woocommerce-checkout .wa-float{display:none}
  body.woocommerce-cart .to-top,
  body.woocommerce-checkout .to-top{bottom:22px}

  /* cart rows as tidy cards: thumb left, name+variation right,
     qty bottom-left, line total bottom-right */
  .woocommerce-cart table.shop_table.cart thead{display:none}
  .woocommerce-cart table.shop_table.cart,
  .woocommerce-cart table.shop_table.cart tbody{display:block}
  .woocommerce-cart table.shop_table.cart tr.cart_item{display:grid;grid-template-columns:76px 1fr auto;grid-template-areas:"thumb name remove" "thumb price price" "qty qty total";align-items:start;gap:4px 14px;padding:16px 0;border-bottom:1px solid var(--line);margin:0}
  .woocommerce-cart table.cart td{display:block;border:0;padding:0;background:transparent}
  .woocommerce-cart table.cart td.product-thumbnail{grid-area:thumb;display:block}
  .woocommerce-cart table.cart td.product-thumbnail img{width:76px;height:76px;object-fit:contain;border:1px solid var(--line);border-radius:14px;background:var(--blush-wash);padding:6px;box-sizing:border-box}
  .woocommerce-cart table.cart td.product-name{grid-area:name;font:600 14px/1.45 var(--font-ui)}
  .woocommerce-cart table.cart td.product-name a{color:var(--heading);text-decoration:none}
  .woocommerce-cart table.cart td.product-remove{grid-area:remove;justify-self:end}
  .woocommerce-cart table.cart td.product-remove a{display:grid;place-items:center;width:30px;height:30px;border:1px solid var(--line);border-radius:50%;background:#fff;color:var(--error) !important;font-size:15px;text-decoration:none}
  .woocommerce-cart table.cart td.product-price{grid-area:price;color:var(--orchid);font:600 12.5px/1.4 var(--font-ui)}
  .woocommerce-cart table.cart td.product-quantity{grid-area:qty;margin-top:8px}
  .woocommerce-cart table.cart td.product-subtotal{grid-area:total;justify-self:end;align-self:center;margin-top:8px;color:var(--heading);font:700 15px/1.3 var(--font-ui)}
  .woocommerce-cart table.cart td.product-subtotal::before{content:none}
  .woocommerce-cart table.cart td.actions{display:flex;flex-wrap:wrap;gap:10px;padding:16px 0 0;border:0}
  .woocommerce-cart table.cart td.actions .coupon{display:flex;flex:1 1 100%;gap:10px}
  .woocommerce-cart table.cart td.actions .coupon input{flex:1;min-width:0}

  /* checkout: order summary first, then billing form */
  body.woocommerce-checkout form.checkout{display:flex !important;flex-direction:column}
  body.woocommerce-checkout form.checkout #order_review_heading{order:1;margin-top:0}
  body.woocommerce-checkout form.checkout #order_review{order:2}
  body.woocommerce-checkout form.checkout #customer_details{order:3;margin-top:26px}

  /* "Ship to a different address?" reads like a row, not a broken heading */
  #ship-to-different-address{display:flex;align-items:center;gap:10px;font:600 15px/1.4 var(--font-ui);color:var(--heading);margin:18px 0 6px}
  #ship-to-different-address label{display:flex;align-items:center;gap:10px;margin:0;font:inherit;color:inherit}
  #ship-to-different-address input{width:18px;height:18px;min-height:0;accent-color:var(--orchid)}
}
