/*
Theme Name:  Milky Tallow
Theme URI:   https://milkytallow.com
Author:      Milky Tallow
Description: Barrier-first skincare brand theme — Kinetic Editorial Design System v4.6
Version:     4.6
License:     GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: milky-tallow
Tags:        e-commerce, custom-menu, full-width-template, sticky-post
*/

/* ==========================================================
   Milky Tallow — "Kinetic Editorial" Design System v4
   On-brand milk/amber · oversized type · scroll-driven motion
   ========================================================== */
:root{
  --bg:#FAF5EB;
  --bg2:#F4E7D0;
  --bg3:#EBDCBF;
  --ink:#504E4E;
  --soft:#6C6765;
  --amber:#6B7282;
  --amber-soft:#809282;
  --grad:linear-gradient(95deg,#6B7282,#809282);
  --line:rgba(80,78,78,.16);
  --line-soft:rgba(80,78,78,.08);
  --dark:#2E333D;
  --dark-soft:#A9AEB8;
  --glow:0 24px 70px -28px rgba(90,96,110,.3);
  --radius:20px;
  --font-display:"Instrument Sans",Helvetica,-apple-system,sans-serif;
  --font-body:"Instrument Sans",Helvetica,-apple-system,sans-serif;
  --font-mono:"Instrument Sans",Helvetica,-apple-system,sans-serif;
  --font-hero:"Fraunces","Instrument Sans",Georgia,serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--font-body);font-size:16px;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:radial-gradient(900px 600px at 88% -5%, rgba(232,216,185,.4), transparent 60%),
             radial-gradient(800px 700px at -10% 35%, rgba(128,146,130,.08), transparent 60%);}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
::selection{background:var(--amber);color:#FFF8EE}
::-webkit-scrollbar{width:10px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:#D8CCBA;border-radius:5px}
.wrap{max-width:1200px;margin:0 auto;padding:0 24px}

/* ---------- Scroll progress ---------- */
#scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--grad);z-index:200;transition:width .1s linear}

/* ---------- Typography ---------- */
h1,h2,h3{font-family:var(--font-display);font-weight:600;letter-spacing:-.018em;line-height:1.08}
h1{font-size:clamp(2.7rem,6vw,4.8rem)}
h2{font-size:clamp(2rem,4.2vw,3.4rem)}
h3{font-size:1.25rem;line-height:1.3}
.mega{font-family:var(--font-hero);font-optical-sizing:auto;font-weight:430;font-size:clamp(2.8rem,8vw,6.8rem);line-height:1.04;letter-spacing:-.02em}
.mega span{display:block;padding-bottom:.06em}
/* Artsy editorial treatment: light-weight serif with an italic accent line.
   padding-bottom gives the italic descenders (y, g) room so background-clip:text doesn't clip them. */
.mega .ital{font-style:italic;font-weight:400;letter-spacing:-.01em}
.mega .grad-text{font-weight:500;font-style:italic;padding-bottom:.16em}
.outline-text{color:transparent;-webkit-text-stroke:1.5px var(--ink);text-stroke:1.5px var(--ink)}
.outline-amber{color:transparent;-webkit-text-stroke:1.5px var(--amber);text-stroke:1.5px var(--amber)}
.grad-text,.logo span{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.eyebrow{display:block;font-family:var(--font-mono);font-size:.72rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--amber);margin-bottom:16px}
.eyebrow{letter-spacing:.28em}
.lede{font-size:1.15rem;color:var(--soft);max-width:58ch;line-height:1.75}
.center{text-align:center}
.center .lede{margin-inline:auto}

/* ---------- Buttons ---------- */
.btn{display:inline-block;padding:15px 32px;border-radius:999px;font-family:var(--font-body);font-weight:600;font-size:.93rem;letter-spacing:.02em;transition:all .3s cubic-bezier(.2,.7,.3,1);border:1px solid var(--ink);cursor:pointer}
.btn-solid{background:var(--ink);color:var(--bg)}
.btn-solid:hover{background:var(--amber);border-color:var(--amber);box-shadow:0 14px 38px -12px rgba(107,114,130,.45);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--amber);color:var(--amber);transform:translateY(-2px)}
.btn-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.textlink{font-family:var(--font-mono);font-size:.78rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--amber);display:inline-flex;align-items:center;gap:4px}
.textlink .tl-arrow{display:inline-block;transition:transform .2s ease}
.textlink:not(:has(.tl-arrow)):hover{text-decoration:underline;text-underline-offset:3px}
.textlink:hover .tl-text{text-decoration:underline;text-underline-offset:3px}
.textlink:hover .tl-arrow{transform:translateX(5px)}
/* .atc-mini shown on product-card hover — do NOT add display:none here */

/* ---------- Announcement + Header ---------- */
/* Standard accessibility helper — hides screen-reader-only text (e.g. WooCommerce's
   "Price range: $x through $y" label) visually while keeping it for assistive tech. */
.screen-reader-text{border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute!important;width:1px;word-wrap:normal!important}
.screen-reader-text:focus{background:#f1f1f1;clip:auto!important;clip-path:none;display:block;height:auto;left:5px;top:5px;padding:15px 23px 14px;width:auto;z-index:100000}

.announce{border-bottom:1px solid var(--line-soft);color:var(--soft);text-align:center;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;padding:10px 16px}
.announce strong{color:var(--amber);font-weight:500}
header.site{position:sticky;top:0;z-index:50;display:flex;flex-direction:column}
header.site::before{content:"";position:absolute;inset:0;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);z-index:-1;pointer-events:none;background:rgba(248,244,237,.85)}
/* ── Top bar ── */
.nav-topbar{border-bottom:1px solid var(--line-soft);position:relative;z-index:3;order:1}
.nav-topbar .wrap{display:flex;align-items:center;gap:16px;height:70px}
.logo{display:flex;align-items:center;flex-shrink:0;text-decoration:none}
.logo img{height:40px;width:auto;display:block;margin-left:-5px}
.nav-topsearch{display:flex;align-items:center;gap:10px;flex:1;max-width:460px;margin:0 auto;background:#fff;border:1.5px solid var(--line);border-radius:99px;padding:9px 16px}
.nav-topsearch svg{flex:none;color:var(--soft)}
.nav-topsearch input{background:none;border:none;outline:none;font-family:var(--font-body);font-size:.88rem;color:var(--ink);width:100%}
.nav-topsearch input::placeholder{color:var(--soft)}
.nav-actions{display:flex;align-items:center;gap:12px;margin-left:auto}
.nav-burger{display:none;cursor:pointer;flex:none;background:none;border:none;padding:6px;color:var(--ink);touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.nav-burger span{display:block;height:2px;width:22px;background:currentColor;margin:4px 0;transition:.3s;border-radius:2px}
/* ── Bottom bar (nav-links on desktop) ── */
.nav-links{display:flex;flex-direction:row;align-items:center;gap:0;background:var(--amber);height:44px;position:relative;z-index:1;order:2;padding-left:max(10px,calc((100vw - 1200px) / 2 + 10px))}
.nav-links>.nav-item>a{font-family:var(--font-mono);font-size:.71rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.82);transition:color .25s;position:relative;padding:0 14px;height:44px;display:flex;align-items:center}
.nav-links>.nav-item>a:hover,.nav-links>.nav-item>a.active{color:#fff}
.nav-links>.nav-item>a::after{content:"";position:absolute;left:14px;bottom:0;width:calc(100% - 28px);height:2px;background:#fff;transform:scaleX(0);transform-origin:left;transition:transform .28s}
.nav-links>.nav-item>a:hover::after,.nav-links>.nav-item>a.active::after{transform:scaleX(1)}
.nav-drawer-logo:hover{color:#fff}
.nav .btn{display:none}
.nav-toggle{display:none}

/* ---------- Dropdown nav ---------- */
.nav-item{position:relative;display:flex;align-items:center;margin-left:7px}
.nav-item>a{display:flex;align-items:center;gap:5px}
/* caret */
.nav-item.has-drop>a::before{content:"";display:inline-block;width:5px;height:5px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg) translateY(-2px);transition:transform .25s;flex:none;order:2;margin-left:1px}
.nav-item.has-drop:hover>a::before{transform:rotate(-135deg) translateY(-2px)}
/* remove the underline pseudo on .has-drop top link — use caret instead */
.nav-item.has-drop>a::after{display:none}
/* invisible bridge that fills the gap between nav item and dropdown panel,
   so moving the cursor into the panel doesn't momentarily lose the hover */
.nav-item.has-drop::after{content:"";position:absolute;top:100%;left:-20px;right:-20px;height:22px;z-index:99}
/* dropdown panel */
.drop-menu{
  position:absolute;top:calc(100% + 18px);left:50%;transform:translateX(-50%);
  background:rgba(250,246,240,.97);backdrop-filter:blur(20px);
  border:1px solid var(--line);border-radius:16px;
  box-shadow:0 24px 60px -20px rgba(60,50,30,.18);
  padding:20px 0;min-width:200px;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .22s ease,transform .22s ease,visibility .22s;
  transform:translateX(-50%) translateY(8px);
  z-index:100;white-space:nowrap}
.nav-item:hover .drop-menu,
.nav-item:focus-within .drop-menu{
  opacity:1;visibility:visible;pointer-events:auto;
  transform:translateX(-50%) translateY(0)}
/* multi-column drop (Shop) */
.drop-menu.wide{display:flex;gap:0;min-width:520px;padding:24px 0}
.drop-col{flex:1;padding:0 24px;border-right:1px solid var(--line-soft)}
.drop-col:last-child{border-right:none}
.drop-col .drop-head{
  display:block;font-family:var(--font-mono);font-size:.62rem;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;color:var(--amber);
  margin-bottom:12px;padding:0 0 8px;border-bottom:1px solid var(--line-soft)}
/* drop links */
.drop-menu a{
  display:block;padding:8px 24px;font-family:var(--font-mono);font-size:.72rem;
  font-weight:500;letter-spacing:.08em;text-transform:none;color:var(--soft);
  transition:color .2s,background .2s;border-radius:0;position:relative}
.drop-menu a::after{display:none}
.drop-menu a:hover{color:var(--ink);text-decoration:underline;text-underline-offset:3px}
.drop-col a{padding:7px 0;background:transparent}
.drop-col a:hover{color:var(--ink);text-decoration:underline;text-underline-offset:3px}
/* drop divider */
.drop-divider{height:1px;background:var(--line-soft);margin:10px 24px}
/* view-all link at bottom of a drop */
.drop-all{display:block;padding:10px 24px 0;font-family:var(--font-mono);font-size:.64rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--amber);border-top:1px solid var(--line-soft);margin-top:10px}
.drop-all:hover{color:var(--ink);background:transparent}
/* pointer triangle */
.drop-menu::before{
  content:"";position:absolute;top:-6px;left:50%;transform:translateX(-50%) rotate(45deg);
  width:10px;height:10px;background:rgba(250,246,240,.97);
  border-left:1px solid var(--line);border-top:1px solid var(--line);border-radius:2px}
/* wide drop — align left instead of center */
.nav-item.align-left .drop-menu{left:0;transform:translateX(0) translateY(8px)}
.nav-item.align-left:hover .drop-menu,
.nav-item.align-left:focus-within .drop-menu{transform:translateX(0) translateY(0)}
.nav-item.align-left .drop-menu::before{left:32px;transform:translateX(0) rotate(45deg)}

/* ---------- Marquee ---------- */
.marquee{border-block:1px solid var(--line-soft);overflow:hidden;padding:18px 0}
.marquee .track{display:flex;gap:52px;width:max-content;animation:scroll 30s linear infinite;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--soft);white-space:nowrap}
.marquee .track b{color:var(--amber);font-weight:500}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- Hero v4 (kinetic, asymmetric) ---------- */
.hero{padding-top:clamp(64px,6vw,90px)!important;padding-bottom:90px;min-height:86vh;display:flex;align-items:center}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center;width:100%}
.hero h1{margin-bottom:34px}
.hero .lede{margin-bottom:34px;max-width:46ch}
.hero-img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--glow);position:relative;transform:rotate(1.5deg)}
.hero-img img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/4.8;transform:scale(1.14)}
.hero-img::after{content:"BATCH 0626 · SMALL-BATCH · MADE IN BC";position:absolute;bottom:18px;left:18px;font-family:var(--font-mono);font-size:.62rem;letter-spacing:.2em;color:var(--ink);background:rgba(248,244,237,.85);backdrop-filter:blur(8px);border-radius:999px;padding:9px 16px}
.chip-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:36px}
.chip{font-family:var(--font-mono);font-size:.66rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;padding:9px 16px;border:1px solid var(--line);border-radius:999px;color:var(--soft)}
.scroll-cue{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--soft);margin-top:48px;display:flex;align-items:center;gap:14px}
.scroll-cue::after{content:"";width:1px;height:42px;background:linear-gradient(var(--amber),transparent);animation:cue 1.8s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);opacity:.4}50%{transform:scaleY(1);opacity:1}}

/* ---------- Sections ---------- */
section{padding:100px 0}
section.alt{background:var(--bg2)}
.sec-head{margin-bottom:64px;max-width:760px}
.sec-head.center{margin-inline:auto;text-align:center}

/* ---------- Stats strip (counters) ---------- */
.stats-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;padding:64px 0;border-block:1px solid var(--line-soft)}
.stat{text-align:center}
.stat .num{font-family:var(--font-display);font-size:clamp(2.4rem,4.5vw,3.6rem);font-weight:600;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .label{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--soft);margin-top:8px}

/* ---------- Horizontal product rail ---------- */
.rail{display:flex;gap:0;overflow-x:auto;scroll-snap-type:x mandatory;padding:12px 0 20px;margin-bottom:56px;scrollbar-width:none;-ms-overflow-style:none}
.rail::-webkit-scrollbar{display:none}
.rail>a.product-card{flex:0 0 min(350px,78vw);scroll-snap-align:start;margin-right:36px}
.rail-spacer{flex:0 0 24px;pointer-events:none;scroll-snap-align:start}
.rail-hint{font-family:var(--font-mono);font-size:.64rem;letter-spacing:.24em;text-transform:uppercase;color:var(--soft);display:flex;align-items:center;gap:12px;margin-bottom:8px}
.rail-hint::after{content:"⟶";color:var(--amber);animation:nudge 1.6s ease-in-out infinite}
@keyframes nudge{0%,100%{transform:translateX(0)}50%{transform:translateX(10px)}}

/* ---------- Open grids (boxless) ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:48px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:48px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:40px}
.card{border-top:1px solid var(--line);padding:28px 0 0;transition:border-color .3s;background:transparent}
.card:hover{border-top-color:var(--amber)}
.card h3{margin-bottom:12px}
.card p{color:var(--soft);font-size:1rem;line-height:1.7}
.card .eyebrow{margin-bottom:12px}

/* ---------- Product cards ---------- */
.product-card{display:flex;flex-direction:column;position:relative}
.product-card .img{background:var(--bg2);border-radius:var(--radius);padding:40px;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:box-shadow .35s}
.product-card:hover .img{box-shadow:var(--glow)}
.product-card .img img{max-height:240px;object-fit:contain;mix-blend-mode:multiply;transition:transform .5s cubic-bezier(.2,.7,.3,1)}
.product-card:hover .img img{transform:scale(1.07) translateY(-5px) rotate(-1deg)}
.product-card .body{padding:22px 4px 0;display:flex;flex-direction:column;flex:1}
.product-card .cat{font-family:var(--font-mono);font-size:.64rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--amber);margin-bottom:10px}
.product-card h3{font-size:1.15rem;margin-bottom:8px}
.product-card .price{font-family:var(--font-mono);font-size:.9rem;margin-bottom:12px}
.product-card .price small{color:var(--soft);font-weight:400}
.product-card p{color:var(--soft);font-size:.9rem;flex:1;margin-bottom:18px}
.badge{position:absolute;top:16px;left:16px;z-index:2;background:var(--ink);color:var(--bg);font-family:var(--font-mono);font-size:.6rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;padding:7px 14px;border-radius:999px}
.badge.new{background:var(--amber);color:#FFF8EE}

/* ---------- Sticky stacking panels ---------- */
.stack{position:relative;padding-bottom:12vh}
.panel{position:sticky;top:140px;border-radius:calc(var(--radius) + 6px);padding:clamp(40px,6vw,80px);margin-bottom:0;display:grid;grid-template-columns:auto 1fr auto;gap:clamp(28px,5vw,72px);align-items:center;border:1px solid var(--line);box-shadow:0 -16px 50px -30px rgba(60,40,15,.25)}
/* Each panel sticks lower than the last, so the deck peeks as it stacks */
.panel.p1{top:140px}
.panel.p2{top:212px}
.panel.p3{top:284px}
.panel .big-n{font-family:var(--font-display);font-weight:700;font-size:clamp(3rem,7vw,5.5rem);font-weight:700;color:transparent;-webkit-text-stroke:2px var(--amber);line-height:1}
.panel h3{font-size:clamp(1.5rem,2.6vw,2.2rem);margin-bottom:14px}
.panel p{color:var(--soft);font-size:1.02rem;max-width:56ch}
.panel.p1,.panel.p2,.panel.p3{background:var(--bg2)}

/* ---------- Drift strips (scroll-driven type) ---------- */
.drift-strip{overflow:hidden;padding:56px 0;border-block:1px solid var(--line-soft)}
.drift-strip .line{font-family:var(--font-display);font-weight:700;font-size:clamp(2.8rem,7.5vw,6.5rem);text-transform:uppercase;letter-spacing:-.02em;white-space:nowrap;line-height:1.08;will-change:transform}

/* ---------- Parallax media ---------- */
.hero-img,.split .img{overflow:hidden}
.split .img img,.hero-img img{will-change:transform}

/* ---------- Feature split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.split .img{border-radius:var(--radius);box-shadow:var(--glow)}
.split .img img{width:100%;height:100%;object-fit:cover;transform:scale(1.14)}
/* Contain variant: show the whole image (e.g. product lineups) — no crop, no zoom */
.split .img.img-contain{overflow:visible;box-shadow:none;border-radius:0;background:transparent}
.split .img.img-contain img{height:auto;object-fit:contain;transform:none;border-radius:var(--radius)}
.split h2{margin-bottom:20px}
.split .lede{margin-bottom:28px}
.checklist{display:grid;grid-template-columns:auto auto 1fr;list-style:none;margin:0;padding:0}
.checklist li{display:contents}
.checklist .cl-mark{color:var(--amber);padding:11px 8px 11px 0;border-bottom:1px solid var(--line-soft);font-size:.97rem;line-height:1.6}
.checklist li strong{color:var(--ink);padding:11px 16px 11px 0;border-bottom:1px solid var(--line-soft);font-size:.97rem;white-space:nowrap}
.checklist li span:not(.cl-mark){color:var(--soft);padding:11px 0;border-bottom:1px solid var(--line-soft);font-size:.97rem}
.checklist li span:not(.cl-mark)::before{content:"— "}
.checklist li:last-child .cl-mark,.checklist li:last-child strong,.checklist li:last-child span{border-bottom:none}

/* ---------- For / Not for ---------- */
.fit-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px}
.fit h3{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.fit.yes h3{border-bottom-color:var(--amber)}
.fit li{padding:11px 0;font-size:.96rem;display:flex;gap:14px;color:var(--soft);border-bottom:1px solid var(--line-soft)}
.fit li:last-child{border-bottom:none}
.fit.yes li::before{content:"✓";color:var(--amber);font-weight:700}
.fit.no li::before{content:"✕";color:#B0A293;font-weight:700}

/* ---------- Testimonials ---------- */
.quote-card{border-top:1px solid var(--line);padding:30px 4px 0;transition:border-color .3s}
.quote-card:hover{border-top-color:var(--amber)}
.quote-card .stars{color:var(--amber);letter-spacing:4px;margin-bottom:16px;font-size:.85rem}
.quote-card p{font-size:1rem;color:var(--soft);margin-bottom:20px;line-height:1.7}
.quote-card .who{font-family:var(--font-display);font-weight:600;font-size:.92rem}
.quote-card .where{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--soft)}

/* ---------- FAQ / accordions ---------- */
details{border-top:1px solid var(--line)}
details:last-of-type{border-bottom:1px solid var(--line)}
details summary{
  cursor:pointer;list-style:none;padding:22px 8px;
  font-family:var(--font-display);font-weight:600;font-size:1.02rem;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  transition:color .25s}
details summary:hover{color:var(--amber)}
details summary::-webkit-details-marker{display:none}
/* animated ＋/× icon using two pseudo-lines */
details summary::after{
  content:"";flex:none;width:18px;height:18px;position:relative;
  background:
    linear-gradient(currentColor,currentColor) center/18px 1.5px no-repeat,
    linear-gradient(currentColor,currentColor) center/1.5px 18px no-repeat;
  color:var(--amber);
  transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .3s}
details[open] summary::after{transform:rotate(45deg)}
/* answer body — JS drives height; CSS provides opacity + padding easing */
details .ans{
  overflow:hidden;
  padding:0 8px 0;
  color:var(--soft);font-size:.96rem;max-width:70ch;
  transition:opacity .35s ease}
details[open] .ans{padding-bottom:28px}
details .ans a{color:var(--amber)}

/* ---------- Steps ---------- */
.step{display:flex;gap:24px;align-items:flex-start;padding:28px 0;border-bottom:1px solid var(--line-soft)}
.step:last-child{border-bottom:none}
.step .n{flex:none;width:46px;height:46px;border-radius:50%;border:1px solid var(--amber);color:var(--amber);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.95rem}
.step h3{margin-bottom:6px}
.step p{color:var(--soft);font-size:1rem;line-height:1.7}
.step .tip{display:inline-block;margin-top:10px;font-family:var(--font-mono);font-size:.64rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--amber)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;background:var(--dark);color:#EDE4D7;border-radius:calc(var(--radius) + 8px);padding:88px 56px;text-align:center;overflow:hidden}
.cta-band::before,.cta-band::after{content:"";position:absolute;pointer-events:none;border-radius:50%}
.cta-band::before{
  width:140%;height:160%;
  top:-30%;left:-20%;
  background:radial-gradient(ellipse 55% 40% at 35% 55%,rgba(222,186,118,.18) 0%,transparent 65%),
             radial-gradient(ellipse 40% 55% at 75% 35%,rgba(251,246,238,.12) 0%,transparent 65%);
  filter:blur(32px);
  animation:milkyDrift 11s ease-in-out infinite
}
.cta-band::after{
  width:120%;height:120%;
  bottom:-20%;right:-15%;
  background:radial-gradient(ellipse 45% 50% at 60% 50%,rgba(201,173,138,.14) 0%,transparent 60%);
  filter:blur(24px);
  animation:milkyDrift 15s ease-in-out infinite reverse
}
@keyframes milkyDrift{
  0%,100%{transform:translate(0,0) scale(1)}
  30%{transform:translate(-6%,4%) scale(1.06)}
  60%{transform:translate(5%,-5%) scale(.96)}
}
@keyframes spin{to{transform:rotate(1turn)}}
.cta-band>*{position:relative}
.cta-band h2{color:#FBF6EE;margin-bottom:16px}
.cta-band p{color:var(--dark-soft);max-width:56ch;margin:0 auto 34px}
.cta-band .eyebrow{color:var(--amber-soft)}
.cta-band .btn-solid{background:var(--amber);border-color:var(--amber);color:#FFF8EE}
.cta-band .btn-solid:hover{background:#FBF6EE;border-color:#FBF6EE;color:var(--ink)}
.cta-band .btn-ghost{border-color:rgba(251,246,238,.35);color:#FBF6EE}
.cta-band .btn-ghost:hover{border-color:var(--amber-soft);color:var(--amber-soft)}
/* Full-bleed newsletter band (homepage) — flush, edge-to-edge, no rounded corners */
.cta-band-section{padding:0}
.cta-band-section .cta-band{border-radius:0}
/* On-brand inline newsletter form — matches the order-confirmation input */
.mt-cta-form{max-width:460px;margin:26px auto 0}
.mt-cta-input-row{display:flex;gap:8px;justify-content:center}
.mt-cta-input-row input[type="email"]{flex:1;min-width:0;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:13px 20px;font-family:var(--font-body);font-size:.9rem;color:var(--bg);outline:none;transition:border-color .2s}
.mt-cta-input-row input[type="email"]::placeholder{color:var(--dark-soft)}
.mt-cta-input-row input[type="email"]:focus{border-color:rgba(255,255,255,.4)}
.mt-cta-input-row .btn-solid{flex:0 0 auto;border-radius:999px;white-space:nowrap}
.mt-cta-disclaimer{margin-top:14px;font-size:.68rem;color:var(--dark-soft);text-align:center}
.mt-form-msg{margin-top:10px;font-size:.82rem;text-align:center}

/* ---------- Trust bar ---------- */
.trust{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:48px 0;border-top:1px solid var(--line-soft)}
.trust-flush{border-top:none}
.trust div{text-align:center}
.trust strong{display:block;font-family:var(--font-display);font-size:.95rem;margin-bottom:5px}
.trust span{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--soft)}

/* ---------- Footer ---------- */
footer.site{background:var(--dark);color:var(--dark-soft);padding:80px 0 40px;font-size:.92rem}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:60px}
.foot-grid .logo{color:#FBF6EE;margin-bottom:16px;display:block}
.foot-logo img{height:40px;width:auto;display:block;margin-left:0}
.foot-grid h4{font-family:var(--font-mono);color:var(--amber-soft);font-size:.66rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;margin-bottom:20px}
.foot-grid li{margin-bottom:12px}
.foot-grid a{transition:.25s}
.foot-grid a:hover{color:#FBF6EE}
.foot-bottom{border-top:1px solid rgba(251,246,238,.12);padding-top:30px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase}
.foot-bottom .social a{margin-left:20px}
.foot-bottom .social a:hover{color:var(--amber-soft)}

/* ---------- Product detail page ---------- */
.crumbs{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--soft);margin-top:10px;margin-bottom:16px}
.crumbs a:hover{color:var(--amber)}
.pdp{padding-top:48px;padding-bottom:88px}
.pdp-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.pdp-img{background:var(--bg2);border-radius:var(--radius);padding:56px;display:flex;align-items:center;justify-content:center;position:sticky;top:100px;box-shadow:var(--glow)}
.pdp-img img{max-height:460px;object-fit:contain;mix-blend-mode:multiply}
.pdp-info .cat{font-family:var(--font-mono);font-size:.68rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--amber);margin-bottom:12px}
.pdp-info h1{font-size:clamp(2rem,3.8vw,2.9rem);margin-bottom:14px}
.pdp-info .price{font-family:var(--font-mono);font-size:1.2rem;font-weight:700;color:var(--amber);margin-bottom:8px}
.pdp-info .price small{font-size:.78rem;color:var(--soft)}
.pdp-info .tagline{color:var(--soft);font-size:1.04rem;margin:18px 0 26px}
.pdp-info .chip-row{margin:0 0 30px}
.pdp-info .btn-row{margin-bottom:16px}
.pdp-note{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--soft);margin-bottom:20px}
/* PDP additional information (WooCommerce attributes + ingredients) */
.pdp-addinfo{margin-bottom:36px;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.pdp-acc-sum{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;padding:16px 0;font-family:var(--font-display);font-weight:600;font-size:.92rem;color:var(--ink)}
.pdp-acc-sum::-webkit-details-marker{display:none}
.pdp-acc-panel{padding:0 0 16px;color:var(--soft);font-size:.84rem;line-height:1.65}
.size-static{display:inline-block;padding:9px 18px;border:1px solid var(--line);border-radius:999px;font-size:.9rem;color:var(--ink);background:transparent}

/* ── Product purchase block ── */
.pdp-purchase{display:flex;flex-direction:column;gap:20px;margin-bottom:28px}

/* Variants */
.pdp-variants{display:flex;flex-direction:column;gap:10px}
.pdp-variants-label{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--soft)}
.pdp-variant-pills{display:flex;flex-wrap:wrap;gap:8px}
.var-pill{padding:9px 20px;border:1.5px solid var(--line);border-radius:999px;background:transparent;font-family:var(--font-mono);font-size:.74rem;letter-spacing:.06em;color:var(--ink);cursor:pointer;transition:border-color .18s,background .18s,color .18s}
.var-pill:hover{border-color:var(--ink)}
.var-pill.active{background:var(--ink);border-color:var(--ink);color:var(--bg)}

/* Buy row */
.pdp-buy-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}

/* Qty */
.pdp-qty{display:flex;align-items:center;gap:0;border:1.5px solid var(--line);border-radius:999px;overflow:hidden;flex:none}
.qty-btn{background:none;border:none;width:42px;height:44px;font-size:1.2rem;cursor:pointer;color:var(--ink);transition:background .18s;display:flex;align-items:center;justify-content:center;line-height:1}
.qty-btn:hover{background:var(--bg2)}
.qty-val{font-family:var(--font-mono);font-size:.88rem;min-width:32px;text-align:center;color:var(--ink);user-select:none}

/* ATC button */
.pdp-atc-btn{flex:none;min-width:200px;max-width:320px}

@media(max-width:500px){.pdp-buy-row{flex-direction:row;align-items:center;flex-wrap:wrap}.pdp-atc-btn{min-width:0;width:auto}.pdp-qty{justify-content:flex-start}}
.ing-list{font-size:.9rem;color:var(--soft);line-height:1.9}

/* ---------- Shop filters ---------- */
.filter-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:52px}
.filter-row a{font-family:var(--font-mono);font-size:.7rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;padding:10px 22px;border-radius:999px;border:1px solid var(--line);color:var(--soft);transition:.3s}
.filter-row a.on,.filter-row a:hover{background:var(--ink);border-color:var(--ink);color:var(--bg)}

/* ---------- Page hero (interior) ---------- */
.page-hero{padding-top:clamp(60px,6vw,90px)!important;padding-bottom:clamp(60px,6vw,90px)!important;border-bottom:1px solid var(--line-soft)}
.page-hero h1{font-family:var(--font-display);font-weight:600;font-size:clamp(2.4rem,6vw,4.6rem);text-transform:none;letter-spacing:-.02em;line-height:1.06}
.page-hero .lede{margin-top:20px;margin-bottom:0}
.page-hero p{margin-bottom:0}
.page-hero .chip-row{margin-top:32px;margin-bottom:0}

/* ---------- Tables ---------- */
table.clean{width:100%;border-collapse:collapse;font-size:.94rem}
table.clean th{text-align:left;padding:14px 16px;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);border-bottom:1px solid var(--line)}
table.clean td{padding:15px 16px;border-bottom:1px solid var(--line-soft);color:var(--soft);vertical-align:top}
table.clean td strong{color:var(--ink)}

/* ---------- Scroll reveal ---------- */
.rv{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.2,.7,.3,1),transform .8s cubic-bezier(.2,.7,.3,1)}
.rv.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .rv{opacity:1;transform:none;transition:none}
  .marquee .track,.cta-band::before,.scroll-cue::after,.rail-hint::after{animation:none}
  .drift-strip .line,[data-prlx]{transform:none!important}
}

/* ---------- Cursor glow ---------- */
#cursor-glow{position:fixed;width:540px;height:540px;border-radius:50%;pointer-events:none;z-index:0;
  background:radial-gradient(circle,rgba(201,173,138,.10) 0%,transparent 65%);
  transform:translate(-50%,-50%);transition:opacity .4s;opacity:0}
body:hover #cursor-glow{opacity:1}
@media(hover:none){#cursor-glow{display:none}}


/* ---------- Editorial images ---------- */
.editorial-img{position:relative;border-radius:var(--radius);overflow:hidden;line-height:0;box-shadow:var(--glow)}
.editorial-img img{width:100%;object-fit:cover;display:block;transition:transform .8s cubic-bezier(.2,.7,.3,1)}
.editorial-img:hover img{transform:scale(1.03)}
.editorial-img .img-caption{position:absolute;bottom:0;left:0;right:0;padding:20px 24px;font-family:var(--font-mono);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.75);background:linear-gradient(transparent,rgba(30,25,20,.55));pointer-events:none}
.img-float-right{float:right;width:42%;margin:0 0 32px 48px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--glow)}
.img-float-right img{width:100%;object-fit:cover}
.clearfix::after{content:"";display:table;clear:both}

/* ---------- Image grid ---------- */
.img-grid{display:grid;gap:16px;border-radius:var(--radius);overflow:hidden}
.img-grid-2{grid-template-columns:1fr 1fr}
.img-grid-3{grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr}
.img-grid-3 :first-child{grid-row:1 / 3}
.img-grid img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s cubic-bezier(.2,.7,.3,1)}
.img-grid img:hover{transform:scale(1.04)}

/* ---------- PDP gallery ---------- */
.pdp-media{display:flex;flex-direction:column;gap:12px;position:sticky;top:100px}
.pdp-main-img{background:transparent;border-radius:var(--radius);overflow:hidden;box-shadow:none;aspect-ratio:1;display:flex;align-items:center;justify-content:center}
.pdp-main-img img{width:100%;height:100%;object-fit:cover}
.pdp-thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.pdp-thumb{background:var(--bg2);border-radius:12px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:.25s;aspect-ratio:1}
.pdp-thumb:hover,.pdp-thumb.active{border-color:var(--amber)}
.pdp-thumb img{width:100%;height:100%;object-fit:cover;display:block}

/* ---------- Review component ---------- */
.review-bar{display:flex;align-items:center;gap:28px;padding:40px 0;border-bottom:1px solid var(--line-soft);margin-bottom:52px}
.review-bar .big-score{font-family:var(--font-display);font-size:5rem;font-weight:700;line-height:1;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.review-bar-detail{flex:1}
.review-bar .stars-lg{color:var(--amber);font-size:1.3rem;letter-spacing:3px;margin-bottom:6px}
.review-bar .total{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--soft)}
.review-card{border-top:1px solid var(--line);padding:28px 0 0}
.review-card .stars{color:var(--amber);letter-spacing:3px;font-size:.9rem;margin-bottom:12px}
.review-card .review-text{color:var(--soft);line-height:1.75;margin-bottom:18px;font-size:.98rem}
.review-card .reviewer-name{font-family:var(--font-display);font-weight:600;font-size:.9rem;margin-bottom:2px}
.review-card .reviewer-meta{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--soft)}
.verified-badge{display:inline-block;font-family:var(--font-mono);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;background:rgba(107,114,130,.1);color:var(--amber);padding:3px 8px;border-radius:999px;margin-left:8px}

/* ---------- Visual stat cards ---------- */
.big-stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--line);border-radius:var(--radius);overflow:hidden;margin:48px 0}
.big-stat{background:var(--bg);padding:44px 36px;text-align:center}
.big-stat .n{font-family:var(--font-display);font-size:clamp(3rem,5vw,4.5rem);font-weight:700;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1;margin-bottom:8px}
.big-stat .l{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--soft)}

/* ---------- Pull quote ---------- */
.pull-quote{border-left:3px solid var(--amber);padding:20px 0 20px 32px;margin:40px 0}
.pull-quote p{font-family:var(--font-display);font-size:clamp(1.3rem,2.5vw,1.9rem);font-weight:600;line-height:1.3;color:var(--ink)}
.pull-quote cite{display:block;margin-top:14px;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--amber)}

/* ---------- Ingredient tag cloud ---------- */
.tag-cloud{display:flex;flex-wrap:wrap;gap:10px;margin:20px 0}
.tag-cloud .tag{font-family:var(--font-mono);font-size:.68rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:9px 18px;border:1px solid var(--line);border-radius:999px;color:var(--soft);background:var(--bg);transition:.25s}
.tag-cloud .tag:hover{border-color:var(--amber);color:var(--ink);background:transparent}

/* ---------- Feature band with image ---------- */
.feature-band{position:relative;border-radius:calc(var(--radius)+8px);overflow:hidden;min-height:420px;display:flex;align-items:flex-end;padding:52px}
.feature-band img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.feature-band::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(30,25,20,.0) 20%,rgba(30,25,20,.72) 100%);z-index:1}
.feature-band-content{position:relative;z-index:2;color:#FBF6EE;max-width:56ch}
.feature-band-content .eyebrow{color:rgba(201,173,138,.85)}
.feature-band-content h2{color:#FBF6EE;margin-bottom:14px}
.feature-band-content p{color:rgba(251,246,238,.72);margin-bottom:28px}

/* ---------- Icon card (card with leading icon) ---------- */
.icon-card{display:flex;gap:22px;align-items:flex-start;padding:28px 0;border-bottom:1px solid var(--line-soft)}
.icon-card:last-child{border-bottom:none}
.icon-card .icon-wrap{flex:none;width:44px;height:44px;border-radius:12px;background:var(--bg2);display:flex;align-items:center;justify-content:center;font-size:1.2rem}
.icon-card h3{margin-bottom:6px;font-size:1.08rem}
.icon-card p{color:var(--soft);font-size:.96rem}

/* ---------- Responsive extras ---------- */
@media(max-width:960px){
  .pdp-media{position:static}
  .img-grid-3{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .img-grid-3 :first-child{grid-row:auto}
  .big-stat-grid{grid-template-columns:1fr}
  .review-bar{flex-direction:column;align-items:flex-start;gap:12px}
}
@media(max-width:680px){
  .img-float-right{float:none;width:100%;margin:0 0 28px 0}
  .pdp-thumbs{grid-template-columns:repeat(3,1fr)}
  .feature-band{min-height:320px;padding:32px 24px}
  .big-stat-grid{grid-template-columns:1fr 1fr;gap:2px}
}

/* ---------- Responsive ---------- */
@media(max-width:960px){
  .hero{min-height:auto}
  .hero-grid,.split,.pdp-grid{grid-template-columns:1fr;gap:44px}
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr);gap:36px}
  .fit-grid{grid-template-columns:1fr;gap:44px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .trust,.stats-strip{grid-template-columns:repeat(2,1fr)}
  .pdp-img{position:static}
  .panel{grid-template-columns:1fr;gap:20px}
}
@media(max-width:680px){
  section{padding:64px 0}
  .hero{padding-bottom:64px}
  .grid-3,.grid-4,.grid-2{grid-template-columns:1fr}
  .cta-band{padding:60px 28px}
  .nav-burger{display:inline-flex;flex-direction:column;justify-content:center;gap:0;width:26px}
  .nav-links>.nav-item>a{color:var(--ink);height:auto;padding:12px 0}
  .nav-links>.nav-item>a:hover,.nav-links>.nav-item>a.active{color:var(--amber)}
  .nav-links>.nav-item>a::after{display:none}
  .drop-menu a,.drop-col a{color:var(--soft);opacity:1}
  .drop-menu a:hover,.drop-col a:hover{color:var(--ink);opacity:1;text-decoration:underline;text-underline-offset:3px}
  .drop-head{color:var(--soft)}
  .nav-topsearch{display:none}
  .nav-topbar .wrap{gap:12px;position:relative}
  .nav-topbar .logo{position:absolute;left:50%;transform:translateX(-50%)}
  .nav-links{display:none}/* drawer overrides this below */
  /* ── Side-drawer overlay ── */
  .nav-overlay{display:none;position:fixed;inset:0;background:rgba(30,25,20,.38);z-index:149;cursor:pointer;backdrop-filter:blur(2px)}
  .nav-toggle:checked ~ .nav-overlay{display:block}
  /* ── Side drawer ── */
  .nav-links{
    display:flex!important;position:fixed!important;
    top:0;left:0;bottom:0;
    width:min(300px,85vw);
    background:var(--bg);z-index:150;
    transform:translateX(-100%);
    transition:transform .38s cubic-bezier(.4,0,.2,1);
    flex-direction:column;align-items:stretch;padding:0 28px 48px;gap:0;
    overflow-y:auto;border-right:1px solid var(--line);
    box-shadow:8px 0 32px rgba(0,0,0,.10)
  }
  .nav-toggle:checked ~ .nav-links{transform:translateX(0)}
  .nav .btn{display:none}
  /* mobile: flatten dropdowns into accordion */
  .nav-item{flex-direction:column;align-items:flex-start;width:100%;gap:0}
  .nav-item>a{padding:12px 0;width:100%;border-bottom:1px solid var(--line-soft);font-size:.78rem}
  .nav-item.has-drop>a::before{margin-left:auto;order:2}
  .drop-menu,.drop-menu.wide{
    position:static;transform:none;opacity:1;visibility:visible;pointer-events:auto;
    box-shadow:none;border:none;background:transparent;backdrop-filter:none;
    padding:4px 0 8px 12px;border-radius:0;min-width:0;width:100%;
    display:none;flex-direction:column}
  .drop-menu::before{display:none}
  .drop-menu.wide{flex-direction:column}
  .drop-col{border-right:none;padding:0}
  .drop-col .drop-head{margin-bottom:6px;padding-bottom:4px;margin-top:10px}
  .drop-menu a,.drop-col a{padding:8px 0;font-size:.74rem;border-bottom:none;background:transparent}
  .drop-all{padding:8px 0;border-top:none;margin-top:0}
  /* kill desktop hover transform so touch-:hover can't shift dropdown off-screen */
  .nav-item:hover .drop-menu,
  .nav-item:focus-within .drop-menu,
  .nav-item.align-left:hover .drop-menu,
  .nav-item.align-left:focus-within .drop-menu{transform:none;position:static}
  /* toggle open state via JS class */
  .nav-item.open .drop-menu{display:flex}
}

/* ==========================================================
   v4.1 — Apple-style motion + placeholder image polish
   ========================================================== */
/* hero keynote-style intro: rise + de-blur, staggered */
.mega span{opacity:0;animation:riseIn 1.1s cubic-bezier(.16,1,.3,1) forwards}
.mega span:nth-child(1){animation-delay:.05s}
.mega span:nth-child(2){animation-delay:.18s}
.mega span:nth-child(3){animation-delay:.31s}
.hero .eyebrow{opacity:0;animation:riseIn .9s cubic-bezier(.16,1,.3,1) .0s forwards}
.hero .lede{opacity:0;animation:riseIn 1s cubic-bezier(.16,1,.3,1) .45s forwards}
.hero .btn-row{opacity:0;animation:riseIn 1s cubic-bezier(.16,1,.3,1) .58s forwards}
.hero .scroll-cue{opacity:0;animation:riseIn 1s cubic-bezier(.16,1,.3,1) .75s forwards}
.hero-img{opacity:0;animation:heroImgIn 1.3s cubic-bezier(.16,1,.3,1) .3s forwards}
@keyframes riseIn{from{opacity:0;transform:translateY(44px);filter:blur(10px)}to{opacity:1;transform:none;filter:blur(0)}}
@keyframes heroImgIn{from{opacity:0;transform:rotate(4deg) translateY(60px) scale(.94);filter:blur(12px)}to{opacity:1;transform:rotate(1.5deg);filter:blur(0)}}
/* scroll-scrub targets */
.hero-grid>div:first-child,.hero-img{will-change:transform,opacity}

/* reveal-on-scroll now de-blurs (Apple-style) */
.rv{filter:blur(8px)}
.rv.in{filter:blur(0)}

/* pinned zoom section — pulled up behind milk-band's fading bottom edge */
.zoom-sec{height:230vh;position:relative;z-index:1;margin-top:-130px}
.zoom-pin{position:sticky;top:0;height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.zoom-pin [data-zoom]{width:min(94vw,1160px);height:auto;transform:scale(.52);border-radius:40px;will-change:transform;box-shadow:var(--glow)}
.zoom-caption{position:absolute;left:0;right:0;bottom:1.5vh;margin-left:auto;margin-right:auto;width:min(560px,calc(100vw - 32px));text-align:center;opacity:0;padding:clamp(18px,3.5vw,30px) clamp(20px,4.5vw,38px);will-change:transform,opacity;background:rgba(250,245,235,.34);-webkit-backdrop-filter:blur(9px) saturate(1.1);backdrop-filter:blur(9px) saturate(1.1);border:1px solid rgba(255,255,255,.4);border-radius:26px;box-shadow:0 16px 44px rgba(40,26,12,.16)}
.zoom-caption .eyebrow{text-shadow:0 1px 5px rgba(255,250,242,.85)}
.zoom-caption h2{margin-bottom:12px;text-shadow:0 2px 10px rgba(255,250,242,.9),0 1px 2px rgba(255,250,242,.7)}
.zoom-caption .lede{margin-bottom:0;text-shadow:0 1px 6px rgba(255,250,242,.9)}
/* soften the bottom clip of the pinned photo into the page background */
.zoom-pin::after{content:"";position:absolute;left:0;right:0;bottom:0;height:42vh;background:linear-gradient(to bottom,rgba(250,245,235,0) 0%,rgba(250,245,235,.35) 45%,rgba(250,245,235,.78) 75%,var(--bg) 100%);pointer-events:none;z-index:2}
.zoom-caption{z-index:3}
@supports not ((-webkit-backdrop-filter:blur(1px)) or (backdrop-filter:blur(1px))){.zoom-caption{background:rgba(250,245,235,.74)}}

/* buttons: Apple-ish press + smooth spring */
.btn{transition:transform .45s cubic-bezier(.16,1,.3,1),background .3s,border-color .3s,color .3s,box-shadow .45s}
.btn:active{transform:scale(.96)}
.product-card .img img{transition:transform .7s cubic-bezier(.16,1,.3,1)}

/* placeholder SVGs: no blend tricks needed, but keep them seated */
.product-card .img img,.pdp-img img{mix-blend-mode:normal}
.product-card .img,.pdp-img{background:transparent;padding:0}
.product-card .img img{max-height:none;width:100%;border-radius:var(--radius)}
/* Rail cards: contain so full product is visible on all screen sizes */
.rail .product-card .img img{height:240px;object-fit:contain;object-position:center center}
.pdp-img{box-shadow:none}
.pdp-img img{max-height:none;width:100%;border-radius:var(--radius);box-shadow:var(--glow)}

/* gentle float on hero badge line */
.hero-img::after{animation:floaty 5s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

@media(prefers-reduced-motion:reduce){
  .mega span,.hero .eyebrow,.hero .lede,.hero .btn-row,.hero .scroll-cue,.hero-img{animation:none;opacity:1}
  .rv{filter:none}
  .zoom-sec{height:auto}
  .zoom-pin{position:static;height:auto}
  .zoom-pin [data-zoom]{transform:none;border-radius:var(--radius)}
  .zoom-caption{position:static;opacity:1;margin-top:24px}
  .hero-img::after{animation:none}
}
@media(max-width:680px){
  .zoom-sec{height:170vh}
  .zoom-caption{bottom:4vh}
}

/* reveal transition includes the de-blur */
.rv{transition:opacity .8s cubic-bezier(.2,.7,.3,1),transform .8s cubic-bezier(.2,.7,.3,1),filter .8s cubic-bezier(.2,.7,.3,1)}

/* ==========================================================
   v4.2 — Milk band (replaces drift strip)
   ========================================================== */
.milk-band{position:relative;z-index:2;overflow:hidden;padding:150px 24px 170px;text-align:center;
  background:linear-gradient(180deg,var(--bg) 0%,#FBF6EA 40%,#F2E4C9 100%);
  -webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 7%,black 87%,transparent 100%);
  mask-image:linear-gradient(to bottom,transparent 0%,black 7%,black 87%,transparent 100%)}
.milk-wave{position:absolute;left:-30%;width:160%;pointer-events:none;will-change:transform;line-height:0}
.milk-wave svg{width:100%;height:120px;display:block}
.w1{top:-1px;opacity:.95}
.w1 svg{transform:rotate(180deg)}
.w2{bottom:-1px}
.w3{bottom:24px;opacity:.6}
.milk-band-content{position:relative;z-index:2;max-width:680px;margin:0 auto}
.milk-band h2{text-transform:none;font-weight:600;letter-spacing:-.02em;margin-bottom:14px;
  background:linear-gradient(100deg,#504E4E,#6B7282 60%,#809282);-webkit-background-clip:text;background-clip:text;color:transparent}
.milk-band .lede{margin:0 auto;font-size:1.02rem}
.drop{position:absolute;z-index:1;border-radius:53% 47% 48% 52%/55% 48% 52% 45%;
  background:linear-gradient(160deg,#FFFEFB 20%,#F2E8D4);
  box-shadow:inset -7px -9px 16px rgba(168,137,93,.14),0 12px 26px -14px rgba(140,110,70,.3);
  animation:bob 6.5s ease-in-out infinite}
.d1{width:56px;height:56px;left:13%;top:26%}
.d2{width:30px;height:30px;right:17%;top:32%;animation-delay:1.3s}
.d3{width:42px;height:42px;left:23%;bottom:20%;animation-delay:2.2s;animation-duration:7.5s}
.d4{width:22px;height:22px;right:26%;bottom:26%;animation-delay:.7s;animation-duration:5.6s}
@keyframes bob{0%,100%{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-16px) rotate(4deg)}}
@media(max-width:680px){
  .milk-band{padding:110px 24px 130px}
  .d1,.d3{display:none}
}
@media(prefers-reduced-motion:reduce){.drop{animation:none}.milk-wave{transform:none!important}}

/* v4.3 — elegant serif touches */
.ital{font-style:italic;font-weight:400;color:var(--soft)}
.logo{font-weight:700}
summary{letter-spacing:.01em}

/* ==========================================================
   v4.4 — Milk band: full-height, living motion
   ========================================================== */
.milk-band{min-height:57vh;display:flex;align-items:center;justify-content:center;padding:132px 24px}
.milk-wave svg{height:190px}
.w1 svg{animation:swayA 8s ease-in-out infinite}
.w2 svg{animation:swayBtm 10s ease-in-out infinite;transform-origin:bottom center}
.w3 svg{animation:swayB 13s ease-in-out infinite reverse}
@keyframes swayA{0%,100%{transform:rotate(180deg) translateY(0)}50%{transform:rotate(180deg) translateY(14px)}}
@keyframes swayB{0%,100%{transform:translateY(0) scaleY(1)}50%{transform:translateY(-14px) scaleY(1.07)}}
/* swayBtm: scale only, anchored to bottom — no upward lift, no gap */
@keyframes swayBtm{0%,100%{transform:scaleY(1) scaleX(1)}50%{transform:scaleY(1.14) scaleX(1.04)}}

/* bigger, shimmering headline with word-by-word reveal */
.milk-band h2{font-size:clamp(2.6rem,6vw,4.8rem);
  background:linear-gradient(100deg,#504E4E,#6B7282 38%,#809282 62%,#504E4E);
  background-size:220% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;
  animation:shimmer 7s ease-in-out infinite}
@keyframes shimmer{0%,100%{background-position:0% 0}50%{background-position:100% 0}}
.milk-band h2 .w{display:inline-block;opacity:0;transform:translateY(30px);filter:blur(8px);
  transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1),filter .9s cubic-bezier(.16,1,.3,1)}
.milk-band-content.in h2 .w:nth-child(1){transition-delay:.1s}
.milk-band-content.in h2 .w:nth-child(2){transition-delay:.28s}
.milk-band-content.in h2 .w:nth-child(3){transition-delay:.46s}
.milk-band-content.in h2 .w{opacity:1;transform:none;filter:none}
.milk-band .lede{font-size:1.12rem}

/* extra drops */
.d5{width:36px;height:36px;left:8%;top:55%;animation-delay:1.8s;animation-duration:8s}
.d6{width:18px;height:18px;right:10%;top:58%;animation-delay:2.6s;animation-duration:6s}

/* rising cream bubbles */
.bubble{position:absolute;bottom:-40px;border-radius:50%;z-index:1;pointer-events:none;
  background:radial-gradient(circle at 35% 30%,#FFFEFB 30%,#EFE3CC);
  box-shadow:inset -4px -6px 10px rgba(168,137,93,.14);opacity:0;animation:risefloat 11s linear infinite}
.b1{width:22px;height:22px;left:18%;animation-delay:0s}
.b2{width:14px;height:14px;left:38%;animation-delay:2.5s;animation-duration:9s}
.b3{width:28px;height:28px;left:58%;animation-delay:5s;animation-duration:13s}
.b4{width:12px;height:12px;left:74%;animation-delay:1.4s;animation-duration:8s}
.b5{width:18px;height:18px;left:88%;animation-delay:3.8s;animation-duration:10s}
@keyframes risefloat{
  0%{opacity:0;transform:translateY(0) translateX(0) scale(.8)}
  10%{opacity:.9}
  50%{transform:translateY(-42vh) translateX(14px) scale(1)}
  80%{opacity:.6}
  100%{opacity:0;transform:translateY(-82vh) translateX(-10px) scale(1.15)}}

@media(max-width:680px){
  .milk-band{min-height:78vh;padding:150px 24px}
  .milk-wave svg{height:120px}
  .b3,.b5{display:none}
}
@media(prefers-reduced-motion:reduce){
  .w1 svg,.w2 svg,.w3 svg{animation:none}
  .w1 svg{transform:rotate(180deg)}
  .milk-band h2{animation:none}
  .milk-band h2 .w{opacity:1;transform:none;filter:none;transition:none}
  .bubble{animation:none;opacity:0}
}

/* ==========================================================
   v4.5 — Amazon-style PDP (open content, sticky buy bar)
   ========================================================== */
.stars-row{display:flex;gap:10px;align-items:center;font-size:.88rem;color:var(--soft);margin:0 0 14px}
.stars-row .stars{color:#D9A444;letter-spacing:2px;font-size:1rem}
/* Gold rounded stars — unified across product pages (matches order-confirmation) */
.mt-stars{display:inline-flex;align-items:center;gap:.12em;color:#f5c540;line-height:0;vertical-align:middle}
.mt-star{width:1em;height:1em;display:inline-block;flex:none;vertical-align:middle}
.mt-star.is-empty{color:rgba(80,78,78,.26)}
.pdp-sub{font-size:1rem;margin:18px 0 4px}
.pdp-bullets li{padding:7px 0;font-size:.95rem}
.pdp-info .chip-row{margin:18px 0 28px}
.pdp-info h1{margin-bottom:6px}
.buybar{position:fixed;left:0;right:0;bottom:0;z-index:60;display:flex;align-items:center;justify-content:center;gap:20px;
  background:var(--amber);border-top:1px solid rgba(255,255,255,.12);
  box-shadow:0 -6px 24px rgba(0,0,0,.18);
  padding:12px 24px;transform:translateY(110%);transition:transform .45s cubic-bezier(.16,1,.3,1)}
.buybar.show{transform:none}
.buybar .bb-name{font-family:var(--font-display);font-weight:700;font-size:.95rem;color:#fff}
.buybar .bb-price{color:rgba(255,255,255,.85);font-weight:600}
.buybar .btn{padding:10px 26px;font-size:.88rem}
.buybar .btn-solid{background:#fff;color:var(--ink);border-color:#fff}
@media(max-width:680px){
  .buybar{gap:12px;padding:10px 16px}
  .buybar .bb-name{display:none}
}

/* ==========================================================
   v4.6 — illustration placements + readability
   ========================================================== */
/* ========================================
   TESTIMONIAL CAROUSEL
   ======================================== */
.carousel-wrap{position:relative}
.carousel{display:flex;gap:28px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:4px}
.carousel::-webkit-scrollbar{display:none}
.carousel>.quote-card,.carousel>.review-card{flex:0 0 calc(33.333% - 19px);scroll-snap-align:start;min-width:260px}
.carousel-controls{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:36px}
.carousel-btn{width:44px;height:44px;border-radius:50%;border:1px solid var(--line);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .25s,color .25s,transform .2s;color:var(--soft)}
.carousel-btn:hover{border-color:var(--amber);color:var(--amber);transform:scale(1.08)}
.carousel-dots{display:flex;gap:8px;align-items:center}
.carousel-dot{width:6px;height:6px;border-radius:50%;border:none;background:var(--line);cursor:pointer;padding:0;transition:width .3s,background .3s,border-radius .3s}
.carousel-dot.active{width:22px;border-radius:3px;background:var(--amber)}
@media(max-width:680px){
  .carousel>.quote-card,.carousel>.review-card{flex:0 0 calc(85vw)}
}

/* ========================================
   NAV ACTIONS (account + cart)
   ======================================== */

.nav-icon-label{display:block;font-family:var(--font-mono);font-size:.6rem;letter-spacing:.06em;text-transform:uppercase;color:inherit;margin-top:2px}
.nav-icon-btn{display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--ink);text-decoration:none;transition:color .2s;cursor:pointer;min-width:52px}
.nav-icon-btn svg{width:22px;height:22px}
.nav-cart-icon-wrap svg{width:20px;height:20px}
.nav-icon-btn:hover{color:var(--amber)}
.nav-icon-btn:hover .nav-icon-label{text-decoration:underline;text-underline-offset:3px}
/* ========================================
   CART ICON (header)
   ======================================== */
.cart-btn{display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;cursor:pointer;color:var(--soft);position:relative;transition:color .2s;padding:0}
.cart-btn:hover{background:var(--line-soft)}
.cart-badge{position:absolute;top:-7px;right:-7px;min-width:17px;height:17px;border-radius:999px;background:var(--amber);color:#fff;font-family:var(--font-mono);font-size:.6rem;font-weight:700;display:none;align-items:center;justify-content:center;padding:0 4px;pointer-events:none;line-height:1;box-shadow:0 0 0 2px var(--bg)}
.cart-badge.pop{animation:badge-pop .3s cubic-bezier(.3,1.5,.5,1)}
@keyframes badge-pop{0%{transform:scale(1)}40%{transform:scale(1.5)}100%{transform:scale(1)}}
/* Nav cart button (bag + price + badge) */
.nav-cart-btn{flex-direction:row;align-items:center;gap:7px;min-width:0;background:none;border:none;padding:3px 0}
.nav-cart-icon-wrap{position:relative;display:flex;align-items:center;justify-content:center;width:38px;height:38px;border:1.5px solid var(--line);border-radius:8px;transition:border-color .2s,background .2s;flex:none}
.nav-cart-btn:hover .nav-cart-icon-wrap{border-color:var(--amber);background:var(--cream)}
.nav-cart-price{font-family:var(--font-mono);font-size:.76rem;font-weight:600;color:var(--ink);display:none;white-space:nowrap;transition:color .2s}
.nav-cart-btn:hover .nav-cart-price{color:var(--amber)}

/* ========================================
   CART DRAWER
   ======================================== */
.cart-overlay{position:fixed;inset:0;background:rgba(46,51,61,.45);z-index:200;opacity:0;pointer-events:none;transition:opacity .35s ease;backdrop-filter:blur(4px)}
.cart-overlay.open{opacity:1;pointer-events:auto}
.cart-drawer{position:fixed;top:0;right:0;bottom:0;width:min(400px,100vw);background:#fff;z-index:201;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .38s cubic-bezier(.4,0,.2,1);box-shadow:-24px 0 80px -20px rgba(46,51,61,.22)}
.cart-drawer.open{transform:translateX(0)}
/* Header */
.cart-header{display:flex;align-items:center;justify-content:space-between;padding:22px 24px 18px;border-bottom:1px solid var(--line-soft)}
.cart-title{font-family:var(--font-display);font-size:1.08rem;font-weight:700;color:var(--ink)}
.cart-close-btn{background:none;border:none;width:32px;height:32px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--soft);transition:color .2s;border-radius:6px;padding:0}
.cart-close-btn:hover{color:var(--ink)}
/* Shipping progress bar */
.cart-ship-bar{padding:14px 24px 12px;border-bottom:1px solid var(--line-soft);background:var(--cream)}
.cart-ship-track{height:4px;background:var(--line-soft);border-radius:2px;overflow:hidden;margin-bottom:8px}
.cart-ship-fill{height:100%;background:#4caf50;border-radius:2px;transition:width .4s ease}
.cart-ship-msg{font-size:.78rem;color:var(--soft);margin:0;line-height:1.4}
.cart-ship-msg strong{color:var(--ink)}
.cart-ship-msg.achieved{color:#2e7d32}
/* Body */
.cart-body{flex:1;overflow-y:auto;padding:0 24px}
.cart-item-count{display:none}
.cart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;gap:16px;color:var(--soft)}
.cart-empty svg{opacity:.25}
.cart-empty p{font-size:.95rem}
.cart-empty a{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--amber)}
/* Cart line items — WooCommerce style: trash | info | image */
.cart-item{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--line-soft)}
.cart-item:last-child{border-bottom:none}
/* Image — left */
.cart-item-img{width:68px;height:68px;border-radius:10px;object-fit:cover;background:var(--bg2);flex:none;align-self:center}
.cart-item-img-placeholder{width:68px;height:68px;border-radius:10px;background:var(--bg2);flex:none}
/* Info — middle, takes all remaining space */
.cart-item-info{flex:1;min-width:0}
.cart-item-name{font-size:.88rem;font-weight:600;color:var(--ink);line-height:1.35;margin-bottom:6px}
.cart-item-var{opacity:.6;font-size:.8em;font-weight:400}
.cart-item-meta{display:flex;align-items:center;gap:10px}
/* Qty stepper */
.cart-item-qty-ctrl{display:flex;align-items:center;border:1.5px solid var(--line);border-radius:8px;overflow:hidden}
.cart-item-qty-ctrl button{background:none;border:none;width:28px;height:28px;cursor:pointer;font-size:1.05rem;color:var(--ink);display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}
.cart-item-qty-ctrl button:hover{background:var(--amber);color:#fff}
.cart-item-qty-ctrl span{font-family:var(--font-mono);font-size:.76rem;min-width:24px;text-align:center;line-height:28px}
.cart-item-price{font-family:var(--font-mono);font-size:.8rem;color:var(--ink);font-weight:600}
/* Trash — right */
.cart-remove{background:none;border:none;cursor:pointer;color:#ccc;padding:6px;display:flex;align-items:center;flex:none;align-self:center;border-radius:6px;transition:color .2s,background .2s}
.cart-remove:hover{color:#c0392b;background:rgba(192,57,43,.08)}
/* Footer */
.cart-footer{padding:16px 24px 24px;border-top:1px solid var(--line-soft)}
.cart-subtotal{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.cart-subtotal span:first-child{font-size:.84rem;color:var(--soft);font-weight:500}
.cart-subtotal span:last-child{font-family:var(--font-display);font-weight:700;font-size:1.1rem;color:var(--ink)}
.cart-footer-btns{display:flex;flex-direction:column;gap:8px}
.cart-view-btn{display:block;text-align:center;padding:12px;border:1.5px solid var(--line);border-radius:8px;font-size:.88rem;font-weight:600;color:var(--ink);background:#fff;transition:border-color .2s,background .2s}
.cart-view-btn:hover{border-color:var(--ink);background:var(--cream)}
.cart-checkout-btn{display:flex;align-items:center;justify-content:center;gap:7px;padding:13px;background:var(--ink);color:#fff;border-radius:8px;font-size:.9rem;font-weight:700;transition:background .2s}
.cart-checkout-btn:hover{background:var(--amber)}
/* add-to-cart mini floating button on product cards */
.atc-mini{position:absolute;bottom:14px;right:14px;width:36px;height:36px;border-radius:50%;background:var(--ink);color:var(--bg);border:none;cursor:pointer;font-size:1.2rem;line-height:1;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.8) translateY(4px);transition:opacity .25s,transform .25s,background .2s}
.product-card:hover .atc-mini{opacity:1;transform:scale(1) translateY(0)}
.atc-mini:hover{background:var(--amber)}
.btn-atc{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;background:var(--ink);color:var(--bg);border:none;border-radius:999px;font-family:var(--font-display);font-weight:600;font-size:.92rem;cursor:pointer;transition:background .25s,transform .2s,box-shadow .25s}
.btn-atc:hover{background:var(--amber);transform:translateY(-2px);box-shadow:0 14px 36px -12px rgba(107,114,130,.4)}
/* ========================================
   REVIEW SECTION — modern e-com redesign
   ======================================== */
.reviews-section{padding:96px 0;background:var(--bg)}

/* ── Header row ── */
.rv-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:56px;flex-wrap:wrap;gap:20px}
.rv-header h2{margin:.4rem 0 0;font-size:clamp(1.8rem,3.5vw,2.6rem)}
.rv-write-btn{flex:none;border-radius:999px;padding:13px 28px;font-size:.85rem;letter-spacing:.04em}

/* ── Summary panel ── */
.rv-summary{display:grid;grid-template-columns:auto 1fr;gap:0;background:var(--bg2);border-radius:24px;overflow:hidden;margin-bottom:52px;border:1px solid var(--line-soft)}
.rv-score-block{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 52px;background:var(--ink);color:var(--bg);gap:8px;min-width:180px}
.rv-big-score{font-family:var(--font-display);font-size:4.5rem;font-weight:700;line-height:1;color:#fff}
.rv-score-stars{font-size:1.1rem;letter-spacing:4px;color:var(--amber-soft);margin:2px 0}
.rv-score-count{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-top:4px}
.rv-dist{display:flex;flex-direction:column;justify-content:center;gap:11px;padding:40px 48px}
.rv-dist-row{display:flex;align-items:center;gap:14px}
.rv-dist-label{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.04em;color:var(--soft);width:30px;flex:none;text-align:right;white-space:nowrap}
.rv-dist-bar{flex:1;height:7px;background:var(--bg3);border-radius:999px;overflow:hidden}
.rv-dist-fill{height:100%;background:var(--grad);border-radius:999px;width:0;transition:width .9s cubic-bezier(.2,1,.3,1)}
.rv-dist-pct{font-family:var(--font-mono);font-size:.64rem;color:var(--soft);width:34px;flex:none;font-variant-numeric:tabular-nums}

/* ── Sort bar ── */
.rv-divider{display:none}
.rv-sort-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;flex-wrap:wrap;gap:12px;padding-bottom:20px;border-bottom:1px solid var(--line-soft)}
.rv-count-label{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--soft)}
.rv-sort{display:flex;align-items:center;gap:10px}
.rv-sort-label{font-family:var(--font-mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--soft)}
.rv-sort-select{font-family:var(--font-mono);font-size:.7rem;border:1px solid var(--line);border-radius:999px;padding:7px 32px 7px 16px;background:var(--bg);color:var(--ink);cursor:pointer;outline:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236B7282'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;transition:border-color .2s}
.rv-sort-select:focus{border-color:var(--amber);outline:none}

/* ── Review cards — 2-column grid ── */
.rv-list{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:8px}
.rv-card{background:var(--bg2);border:1px solid var(--line-soft);border-radius:20px;padding:28px 28px 24px;display:flex;flex-direction:column;gap:0;transition:box-shadow .25s,transform .25s;position:relative;overflow:hidden}
.rv-card::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.06) 0%,transparent 60%);pointer-events:none;border-radius:20px}
.rv-card:hover{box-shadow:0 12px 40px -16px rgba(80,78,78,.14);transform:translateY(-2px)}

/* Avatar + meta row */
.rv-card-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:16px}
.rv-avatar{width:42px;height:42px;border-radius:50%;background:var(--grad);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:.95rem;flex:none;letter-spacing:-.01em}
.rv-card-meta-col{flex:1;min-width:0}
.rv-card-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:4px}
.rv-name{font-family:var(--font-display);font-weight:600;font-size:.92rem;color:var(--ink)}
.rv-location{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;color:var(--soft)}
.rv-date{font-family:var(--font-mono);font-size:.58rem;letter-spacing:.06em;color:var(--soft);opacity:.7}
.rv-card-stars{color:var(--amber);font-size:.82rem;letter-spacing:2px;line-height:1}

/* Review body */
.rv-card-title{font-family:var(--font-display);font-weight:600;font-size:.97rem;margin-bottom:8px;line-height:1.3;color:var(--ink)}
.rv-card-body{color:var(--soft);line-height:1.72;font-size:.9rem;margin:0;flex:1}

/* Photo thumbnails inside card */
.rv-card-img{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}
.rv-card-img img{width:68px;height:68px;object-fit:cover;border-radius:10px;border:1px solid var(--line-soft)}
.rv-card-title{font-family:var(--font-display);font-weight:600;font-size:1rem;color:var(--ink);margin:12px 0 4px}
.rv-card-video{margin-top:16px}
.rv-video-thumb{position:relative;display:inline-block;width:100%;max-width:340px;border-radius:12px;overflow:hidden;border:1px solid var(--line-soft);cursor:pointer;background:#000;line-height:0}
.rv-video-thumb video{width:100%;display:block;pointer-events:none}
.rv-video-thumb .rv-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:54px;height:54px;border-radius:50%;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;transition:background .2s}
.rv-video-thumb:hover .rv-play{background:rgba(0,0,0,.72)}
.rv-video-thumb .rv-play::before{content:"";border-style:solid;border-width:9px 0 9px 15px;border-color:transparent transparent transparent #fff;margin-left:3px}
.rv-card-img img{cursor:pointer}
.rv-lightbox{position:fixed;inset:0;z-index:9999;background:rgba(20,18,16,.9);display:flex;align-items:center;justify-content:center;padding:24px}
.rv-lightbox[hidden]{display:none}
.rv-lightbox-inner{display:flex;max-width:92vw;max-height:90vh}
.rv-lightbox-inner img,.rv-lightbox-inner video{max-width:92vw;max-height:90vh;border-radius:10px;display:block;box-shadow:0 24px 60px -20px rgba(0,0,0,.6)}
.rv-lightbox-close{position:absolute;top:18px;right:22px;width:46px;height:46px;border:none;border-radius:50%;background:rgba(255,255,255,.14);color:#fff;font-size:1.7rem;line-height:1;cursor:pointer;transition:background .2s}
.rv-lightbox-close:hover{background:rgba(255,255,255,.26)}
.rv-empty{color:var(--soft);font-size:.95rem;padding:24px 0}
.rv-name-row{display:flex;gap:14px}
.rv-name-row .rv-name-col{flex:1;min-width:0}
@media(max-width:560px){.rv-name-row{flex-direction:column;gap:0}.rv-name-row .rv-name-col:first-child{margin-bottom:18px}}
.rv-addr-field{position:relative}
.rv-addr-suggest{position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:30;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 14px 36px -14px rgba(46,51,61,.28);overflow:hidden;max-height:260px;overflow-y:auto}
.rv-addr-opt{padding:10px 14px;font-size:.9rem;line-height:1.35;color:var(--ink);cursor:pointer;border-bottom:1px solid var(--line-soft)}
.rv-addr-opt:last-child{border-bottom:none}
.rv-addr-opt:hover{background:var(--bg2)}
.rv-addr-resolved{margin-top:8px;font-size:.92rem;color:var(--ink);font-weight:600}
.rv-addr-hint{margin-top:8px;font-size:.72rem;color:var(--soft);line-height:1.5}

/* Verified badge - refined */
.verified-badge{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-mono);font-size:.54rem;letter-spacing:.1em;text-transform:uppercase;background:rgba(107,114,130,.1);color:var(--amber);padding:3px 8px;border-radius:999px;margin-left:4px;white-space:nowrap}
.verified-badge::before{content:"✓";font-size:.6rem}

/* Load more */
.rv-load-more{text-align:center;padding:44px 0 0}

/* ── Write-a-Review Modal ── */
.rv-modal-overlay{position:fixed;inset:0;background:rgba(30,28,26,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .3s}
.rv-modal-overlay.open{opacity:1;pointer-events:all}
.rv-modal{background:var(--bg);border-radius:28px;padding:0;max-width:580px;width:100%;max-height:92vh;overflow-y:auto;transform:translateY(28px) scale(.98);transition:transform .35s cubic-bezier(.2,1,.3,1),opacity .3s;box-shadow:0 40px 100px -30px rgba(40,36,30,.35),0 0 0 1px var(--line-soft)}
.rv-modal-overlay.open .rv-modal{transform:translateY(0) scale(1)}

/* Modal inner padding wrapper */
.rv-modal-inner{padding:44px 44px 40px}

/* Modal top bar with gradient accent */
.rv-modal-accent{height:4px;background:var(--grad);border-radius:28px 28px 0 0;flex:none}
.rv-modal-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:36px}
.rv-modal-head h3{font-family:var(--font-display);font-size:1.6rem;font-weight:700;margin:0;line-height:1.1}
.rv-modal-head .eyebrow{margin-bottom:8px}
.rv-modal-close{background:var(--bg2);border:1px solid var(--line-soft);cursor:pointer;color:var(--soft);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s,transform .2s;flex:none;margin-top:2px}
.rv-modal-close:hover{background:var(--bg3);color:var(--ink);transform:rotate(90deg)}

/* Star picker */
.rv-star-picker{margin-bottom:32px;background:var(--bg2);border-radius:16px;padding:20px 24px}
.rv-star-picker-label{font-family:var(--font-mono);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--soft);display:block;margin-bottom:14px}
.rv-stars-input{display:flex;gap:4px;flex-direction:row-reverse;justify-content:flex-end}
.rv-stars-input input{display:none}
.rv-stars-input label{font-size:2.4rem;cursor:pointer;color:rgba(107,114,130,.18);transition:color .12s,transform .15s;line-height:1;display:block}
.rv-stars-input label:hover{transform:scale(1.15)}
.rv-stars-input label:hover,.rv-stars-input label:hover~label,.rv-stars-input input:checked~label{color:#f5c540}
.rv-star-hint{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.08em;color:var(--soft);margin-top:10px;min-height:1em}
#rvStarError,#rvFormError{font-family:var(--font-mono);font-size:.64rem;letter-spacing:.06em;color:#c0392b;display:none;margin-top:6px}

/* Form fields */
.rv-field{margin-bottom:18px}
.rv-field label{display:block;font-family:var(--font-mono);font-size:.63rem;letter-spacing:.14em;text-transform:uppercase;color:var(--soft);margin-bottom:8px}
.rv-field input[type=text],.rv-field textarea,.rv-field input[type=email]{width:100%;padding:14px 18px;border:1.5px solid var(--line);border-radius:14px;font-family:var(--font-body,sans-serif);font-size:.95rem;background:var(--bg);color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s;resize:vertical;box-sizing:border-box;-webkit-appearance:none}
.rv-field input[type=text]:focus,.rv-field textarea:focus,.rv-field input[type=email]:focus{border-color:var(--amber);box-shadow:0 0 0 3px rgba(107,114,130,.1)}
.rv-field textarea{min-height:116px;line-height:1.65}
.rv-field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* Image upload */
.rv-img-upload{border:2px dashed var(--line);border-radius:14px;padding:28px 20px;text-align:center;cursor:pointer;transition:border-color .25s,background .25s;position:relative;overflow:hidden}
.rv-img-upload:hover{border-color:var(--amber);background:var(--bg2)}
.rv-img-upload input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.rv-img-upload-icon{font-size:1.6rem;opacity:.3;margin-bottom:10px}
.rv-img-upload-title{font-family:var(--font-display);font-weight:600;font-size:.9rem;color:var(--ink);margin-bottom:4px}
.rv-img-upload p{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--soft);margin:0}
.rv-img-preview{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.rv-img-preview img{width:76px;height:76px;object-fit:cover;border-radius:10px;border:2px solid var(--bg);box-shadow:0 2px 8px rgba(0,0,0,.1)}
.rv-char-hint{font-family:var(--font-mono);font-size:.58rem;letter-spacing:.08em;color:var(--soft);text-align:right;margin-top:5px}

/* Submit */
.rv-modal-submit{width:100%;padding:17px;background:var(--ink);color:var(--bg);border:none;border-radius:999px;font-family:var(--font-display);font-weight:600;font-size:.98rem;letter-spacing:.01em;cursor:pointer;transition:background .25s,transform .2s,box-shadow .25s;margin-top:24px}
.rv-modal-submit:hover{background:var(--amber);transform:translateY(-2px);box-shadow:0 14px 36px -12px rgba(107,114,130,.45)}

/* Success screen */
.rv-success-msg{text-align:center;padding:60px 40px}
.rv-success-icon{width:72px;height:72px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;margin:0 auto 24px;animation:successPop .5s cubic-bezier(.3,1.5,.4,1)}
.rv-success-icon svg{color:#fff}
@keyframes successPop{0%{transform:scale(.4);opacity:0}100%{transform:scale(1);opacity:1}}
.rv-success-msg h3{font-family:var(--font-display);font-size:1.6rem;font-weight:700;margin-bottom:10px}
.rv-success-msg p{color:var(--soft);font-size:.97rem;line-height:1.6;margin-bottom:32px}

/* Responsive */
@media(max-width:900px){.rv-list{grid-template-columns:1fr}}
@media(max-width:700px){
  .rv-summary{grid-template-columns:1fr}
  .rv-score-block{flex-direction:row;justify-content:flex-start;padding:28px;gap:20px}
  .rv-big-score{font-size:3rem}
  .rv-dist{padding:24px 28px}
  .rv-header{flex-direction:column;align-items:flex-start}
  .rv-modal-inner{padding:28px 22px 24px}
  .rv-field-row{grid-template-columns:1fr}
  .rv-modal{border-radius:20px}
  .rv-card{padding:22px 20px}
}

/* ========================================
   REVIEW FORM — inline wrap + trigger
   ======================================== */
.rv-inline-wrap{margin-top:52px;border:1px solid var(--line-soft);border-radius:24px;overflow:hidden;background:var(--bg2)}
.rv-inline-trigger{display:flex;align-items:center;justify-content:space-between;padding:22px 28px;cursor:pointer;background:var(--bg2);transition:background .2s;gap:16px;user-select:none}
.rv-inline-trigger:hover{background:var(--bg3)}
.rv-inline-trigger-left{display:flex;align-items:center;gap:14px}
.rv-inline-stars-prompt{display:flex;gap:3px}
.rv-inline-stars-prompt span{font-size:1.3rem;color:rgba(107,114,130,.22);transition:color .15s}
.rv-inline-trigger:hover .rv-inline-stars-prompt span{color:#f5c540}
.rv-inline-prompt-text{font-family:var(--font-display);font-weight:600;font-size:.97rem;color:var(--ink)}
.rv-inline-toggle-label{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--soft);flex:none;display:flex;align-items:center;gap:6px;transition:color .2s}
.rv-inline-trigger:hover .rv-inline-toggle-label{color:var(--ink)}
.rv-inline-wrap.open .rv-inline-trigger{display:none}

/* ── Form panels */
.rv-inline-form{display:none;flex-direction:column;gap:0}
.rv-inline-form.is-open{display:flex}
.rv-form-section{padding:24px 24px 24px;border-top:1px solid var(--line-soft);margin-top:0}
.rv-form-section:first-child{border-top:none;padding-top:28px}
.rv-form-section:last-of-type{padding-bottom:8px}
.rv-section-label{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--soft);margin-bottom:14px;display:flex;align-items:center;gap:8px}

/* Star row inside form */
.rv-star-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding-bottom:4px}
.rv-stars-input{display:flex;gap:3px;flex-direction:row-reverse}
.rv-stars-input input{display:none}
.rv-stars-input label{font-size:2rem;cursor:pointer;color:rgba(107,114,130,.18);transition:color .12s,transform .15s;line-height:1;display:block}
.rv-stars-input label:hover{transform:scale(1.15)}
.rv-stars-input label:hover,.rv-stars-input label:hover~label,.rv-stars-input input:checked~label{color:#f5c540}
.rv-star-hint{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;color:var(--amber);min-width:60px;font-weight:500}

/* Pill selectors (radio + checkbox) */
.rv-pill-group{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:4px}
.rv-pill{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border:1.5px solid var(--line);border-radius:999px;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.06em;cursor:pointer;transition:border-color .18s,background .18s,color .18s;user-select:none;line-height:1;white-space:nowrap}
.rv-pill input{display:none}
.rv-pill:hover{border-color:var(--amber);color:var(--ink)}
.rv-pill:has(input:checked){background:var(--ink);border-color:var(--ink);color:var(--bg)}
.rv-pill-check:has(input:checked){background:var(--amber);border-color:var(--amber);color:#fff}

/* Fields grid */
.rv-field-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.rv-field-span{grid-column:1/-1}
.rv-field{display:flex;flex-direction:column;gap:7px}
.rv-field label{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--soft)}
.rv-optional{opacity:.5;font-size:.58rem;text-transform:none;letter-spacing:.04em}
.rv-field input[type=text],
.rv-field input[type=email],
.rv-field textarea,
.rv-select{width:100%;padding:12px 16px;border:1.5px solid var(--line);border-radius:12px;font-family:var(--font-body,sans-serif);font-size:.92rem;background:var(--bg);color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s;box-sizing:border-box;-webkit-appearance:none;appearance:none}
.rv-field input:focus,.rv-field textarea:focus,.rv-select:focus{border-color:var(--amber);box-shadow:0 0 0 3px rgba(107,114,130,.08)}
.rv-field textarea{min-height:120px;resize:vertical;line-height:1.65}
.rv-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236B7282'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;cursor:pointer;padding-right:36px;cursor:pointer}
.rv-char-hint{font-family:var(--font-mono);font-size:.58rem;color:var(--soft);text-align:right;margin-top:4px}
.rv-field-error{font-family:var(--font-mono);font-size:.64rem;letter-spacing:.06em;color:#c0392b;margin-top:6px;display:none}

/* Photo upload */
.rv-img-upload{border:1.5px dashed var(--line);border-radius:12px;padding:20px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;position:relative}
.rv-img-upload:hover{border-color:var(--amber);background:var(--bg2)}
.rv-img-upload input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.rv-img-upload-icon{font-size:1.4rem;opacity:.3;margin-bottom:6px}
.rv-img-upload-title{font-family:var(--font-display);font-weight:600;font-size:.85rem;color:var(--ink);margin-bottom:3px}
.rv-img-upload p{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--soft);margin:0}
.rv-img-preview{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.rv-img-preview img{width:68px;height:68px;object-fit:cover;border-radius:8px;border:1px solid var(--line-soft)}

/* Actions */
.rv-inline-actions{display:flex;align-items:center;gap:16px;padding:20px 24px;border-top:1px solid var(--line-soft);margin-top:20px}
.rv-submit-btn{padding:14px 36px;background:var(--ink);color:var(--bg);border:none;border-radius:999px;font-family:var(--font-display);font-weight:600;font-size:.92rem;cursor:pointer;transition:background .25s,transform .2s,box-shadow .25s}
.rv-submit-btn:hover{background:var(--amber);transform:translateY(-1px);box-shadow:0 10px 28px -10px rgba(107,114,130,.4)}
.rv-inline-cancel{background:none;border:none;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--soft);cursor:pointer;padding:8px;transition:color .2s}
.rv-inline-cancel:hover{color:var(--ink)}

@media(max-width:900px){.rv-list{grid-template-columns:1fr}}
@media(max-width:700px){
  .rv-summary{grid-template-columns:1fr}
  .rv-score-block{flex-direction:row;justify-content:flex-start;padding:28px;gap:20px}
  .rv-big-score{font-size:3rem}
  .rv-dist{padding:24px 28px}
  .rv-header{flex-direction:column;align-items:flex-start}
  .rv-card{padding:22px 20px}
}

/* Required / optional markers */
.rv-required{color:#c0392b;margin-left:2px;font-style:normal}

/* Error banner */
.rv-error-banner{display:flex;align-items:center;gap:12px;background:rgba(192,57,43,.07);border:1px solid rgba(192,57,43,.18);border-radius:12px;padding:14px 20px;margin:20px 24px 0;color:#c0392b;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.04em}
.rv-error-banner svg{flex:none;color:#c0392b}

/* Spinner */
.rv-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:rvSpin .6s linear infinite;vertical-align:middle;margin-right:6px}
@keyframes rvSpin{to{transform:rotate(360deg)}}
.rv-submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none!important}

/* Load more button */
.rv-load-more{text-align:center;padding:40px 0 0}
.rv-load-more .btn-ghost{display:inline-flex;align-items:center;gap:8px;min-width:200px;justify-content:center}

/* Inline success state */
.rv-inline-success{display:flex;align-items:center;gap:16px;padding:28px 32px;background:var(--bg2)}
.rv-inline-success .rv-success-icon{width:44px;height:44px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;flex:none}
.rv-inline-success .rv-success-icon svg{color:#fff}
.rv-inline-success strong{display:block;font-family:var(--font-display);font-weight:600;font-size:.97rem;color:var(--ink);margin-bottom:2px}
.rv-inline-success span{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.04em;color:var(--soft)}

/* Review card extras */
.rv-card-tags{display:flex;flex-wrap:wrap;gap:6px;margin:10px 0 12px}
.rv-tag{font-family:var(--font-mono);font-size:.58rem;letter-spacing:.08em;text-transform:uppercase;background:var(--bg3);color:var(--soft);padding:4px 10px;border-radius:999px}
.rv-card-recommend{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;padding:5px 12px;border-radius:999px;margin-bottom:12px}
.rv-recommend-yes{background:rgba(107,114,130,.1);color:var(--amber)}
.rv-recommend-no{background:rgba(192,57,43,.08);color:#c0392b}

/* ── Product purchase block ── */
.pdp-purchase{display:flex;flex-direction:column;gap:20px;margin-bottom:28px}
.pdp-variants{display:flex;flex-direction:column;gap:10px}
.pdp-variants-label{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--soft)}
.pdp-variant-pills{display:flex;flex-wrap:wrap;gap:8px}
.var-pill{padding:9px 20px;border:1.5px solid var(--line);border-radius:999px;background:transparent;font-family:var(--font-mono);font-size:.74rem;letter-spacing:.06em;color:var(--ink);cursor:pointer;transition:border-color .18s,background .18s,color .18s}
.var-pill:hover{border-color:var(--ink)}
.var-pill.active{background:var(--ink);border-color:var(--ink);color:var(--bg)}
.pdp-buy-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.pdp-qty{display:flex;align-items:center;gap:0;border:1.5px solid var(--line);border-radius:999px;overflow:hidden;flex:none}
.qty-btn{background:none;border:none;width:42px;height:44px;font-size:1.2rem;cursor:pointer;color:var(--ink);transition:background .18s;display:flex;align-items:center;justify-content:center;line-height:1}
.qty-btn:hover{background:var(--bg2)}
.qty-val{font-family:var(--font-mono);font-size:.88rem;min-width:32px;text-align:center;color:var(--ink);user-select:none}
.pdp-atc-btn{flex:none;min-width:200px;max-width:320px}

/* ── Gallery upgrades ── */
.pdp-thumbs{grid-template-columns:repeat(4,1fr)}
.pdp-main-img{position:relative;cursor:zoom-in}
.pdp-main-img img{transition:transform .3s}
.pdp-main-img:hover img{transform:scale(1.025)}
.pdp-zoom-btn{position:absolute;bottom:14px;right:14px;background:rgba(255,255,255,.92);border:none;border-radius:50%;width:38px;height:38px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink);box-shadow:0 2px 12px rgba(0,0,0,.12);transition:background .2s,transform .2s;backdrop-filter:blur(4px)}
.pdp-zoom-btn:hover{background:#fff;transform:scale(1.1)}
.pdp-video-wrap{width:100%;height:100%;aspect-ratio:1;background:#000;border-radius:var(--radius);overflow:hidden}
.pdp-video-wrap iframe{width:100%;height:100%;border:none;display:block}
.pdp-thumb-video{position:relative}
.pdp-thumb-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:1}

/* Lightbox */
.pdp-lightbox{position:fixed;inset:0;background:rgba(10,10,10,.92);z-index:3000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(10px)}
.pdp-lightbox.open{opacity:1;pointer-events:all}
.pdp-lb-inner{position:relative;max-width:min(90vw,900px);max-height:90vh;display:flex;align-items:center;justify-content:center}
.pdp-lb-inner img{max-width:100%;max-height:90vh;border-radius:16px;object-fit:contain;display:block;box-shadow:0 40px 120px rgba(0,0,0,.5)}
.pdp-lb-close{position:fixed;top:20px;right:24px;background:rgba(255,255,255,.12);border:none;color:#fff;width:44px;height:44px;border-radius:50%;font-size:1.4rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;backdrop-filter:blur(4px);z-index:10}
.pdp-lb-close:hover{background:rgba(255,255,255,.22)}
.pdp-lb-prev,.pdp-lb-next{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:none;color:#fff;width:48px;height:48px;border-radius:50%;font-size:1.8rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;backdrop-filter:blur(4px);z-index:5;line-height:1}
.pdp-lb-prev{left:-64px}
.pdp-lb-next{right:-64px}
.pdp-lb-prev:hover,.pdp-lb-next:hover{background:rgba(255,255,255,.22)}

/* ── Customers Also Viewed ── */
.also-viewed-section{padding:80px 0;background:var(--bg2)}
.av-header{margin-bottom:44px}
.av-header .eyebrow{margin-bottom:10px}
.av-header h2{font-size:clamp(1.7rem,3vw,2.4rem);margin:0}
.av-track{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.av-card{display:flex;flex-direction:column;text-decoration:none;color:inherit;border-radius:20px;overflow:hidden;background:var(--bg);border:1px solid var(--line-soft);transition:transform .25s,box-shadow .25s}
.av-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px -16px rgba(46,51,61,.15)}
.av-img-wrap{position:relative;aspect-ratio:1;overflow:hidden;background:var(--bg3)}
.av-img-wrap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.av-card:hover .av-img-wrap img{transform:scale(1.04)}
.av-badge{position:absolute;top:12px;left:12px;background:var(--ink);color:var(--bg);font-family:var(--font-mono);font-size:.56rem;letter-spacing:.14em;text-transform:uppercase;padding:5px 10px;border-radius:999px}
.av-info{padding:18px 18px 20px;display:flex;flex-direction:column;gap:6px}
.av-name{font-family:var(--font-display);font-weight:600;font-size:.97rem;color:var(--ink);line-height:1.3}
.av-score-row{display:flex;align-items:center;gap:8px}
.av-stars{color:#E8A020;font-size:.8rem;letter-spacing:2px}
.av-score{font-family:var(--font-mono);font-size:.65rem;color:var(--soft);letter-spacing:.04em}
.av-price{font-family:var(--font-mono);font-size:.82rem;color:var(--amber);font-weight:500;margin-top:2px}

/* Required / optional */
.rv-required{color:#c0392b;margin-left:2px;font-style:normal}

/* ==========================================================
   RESPONSIVE SYSTEM — full overhaul
   Breakpoints: 1024 / 768 / 640 / 480 / 380
   ========================================================== */
@media(max-width:1024px){
  .wrap{padding:0 32px}
  .rail-spacer{flex-basis:32px}
  .pdp-grid{gap:48px}
  .grid-3{grid-template-columns:repeat(3,1fr);gap:32px}
  .grid-4{grid-template-columns:repeat(2,1fr);gap:32px}
  .stats-strip{grid-template-columns:repeat(4,1fr);gap:20px}
  .av-track{grid-template-columns:repeat(4,1fr);gap:16px}
  .rv-list{grid-template-columns:1fr 1fr;gap:16px}
}
@media(max-width:768px){
  .wrap{padding:0 20px}
  section{padding:72px 0}
  .rail-spacer{flex-basis:20px}
  /* Rail cards: contain so full product is visible, description stays */
  .rail .product-card .img img{height:200px;width:100%;object-fit:contain;object-position:center center}
  .rail .product-card .body{padding-top:14px}
  .rail .product-card .price{margin-bottom:12px}
  .nav{height:64px}
  .hero{padding-bottom:72px;min-height:auto}
  .hero-grid{grid-template-columns:1fr;gap:36px}
  .hero-img{transform:none}
  .hero h1{margin-bottom:20px}
  .hero .lede{margin-bottom:24px;max-width:100%}
  .pdp-grid{grid-template-columns:1fr;gap:36px}
  .pdp-media{position:static}
  .pdp-thumbs{grid-template-columns:repeat(4,1fr);gap:8px}
  .pdp-info h1{font-size:clamp(1.7rem,4vw,2.4rem)}
  .pdp-buy-row{flex-direction:row;align-items:center;flex-wrap:wrap}
  .pdp-qty{justify-content:flex-start}
  .pdp-atc-btn{width:auto;min-width:0}
  .grid-3{grid-template-columns:1fr 1fr;gap:28px}
  .grid-2{grid-template-columns:1fr;gap:28px}
  .stats-strip{grid-template-columns:repeat(2,1fr);gap:20px;padding:44px 0}
  .trust{grid-template-columns:1fr 1fr;gap:16px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:36px}
  .rv-header{flex-direction:column;align-items:flex-start;gap:14px;margin-bottom:36px}
  .rv-summary{grid-template-columns:1fr;border-radius:18px}
  .rv-score-block{flex-direction:row;align-items:center;padding:28px;gap:24px;min-width:0}
  .rv-big-score{font-size:3.4rem}
  .rv-dist{padding:24px 28px}
  .rv-list{grid-template-columns:1fr;gap:14px}
  .rv-card{padding:22px 20px}
  .also-viewed-section{padding:60px 0}
  .av-track{grid-template-columns:repeat(2,1fr);gap:16px}
  .buybar{padding:10px 20px;gap:14px}
  .carousel>.quote-card,.carousel>.review-card{flex:0 0 calc(50% - 14px)}
  .pdp-lb-prev{left:-44px}
  .pdp-lb-next{right:-44px}
}
@media(max-width:640px){
  .wrap{padding:0 20px}
  section{padding:56px 0}
  .hero{padding-bottom:56px}
  .hero-img::after{font-size:.52rem;padding:7px 12px}
  .scroll-cue{display:none}
  .pdp-thumbs{gap:6px}
  .pdp-main-img{border-radius:16px}
  .pdp-purchase{gap:16px}
  .pdp-buy-row{flex-direction:row;align-items:center;flex-wrap:wrap}
  .pdp-qty{justify-content:flex-start}
  .pdp-atc-btn{width:auto;min-width:0}
  .grid-3,.grid-4{grid-template-columns:1fr;gap:24px}
  .stats-strip{padding:36px 0;gap:16px}
  .trust{grid-template-columns:1fr;gap:12px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:28px 24px}
  .foot-grid>div:first-child{grid-column:1/-1}
  .foot-grid .logo,.foot-logo{position:static;transform:none;text-align:left}
  footer.site{padding:52px 0 40px}
  .foot-bottom{flex-direction:column;gap:8px}
  .foot-bottom .social a:first-child{margin-left:0}
  .rv-sort-bar{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:20px}
  .rv-inline-trigger{padding:18px 16px;gap:10px}
  .rv-form-section{padding:18px 16px 18px}
  .rv-inline-actions{padding:16px 16px}
  .rv-field-grid{grid-template-columns:1fr}
  .rv-pill{font-size:.64rem;padding:7px 12px}
  .rv-stars-input label{font-size:1.7rem}
  .rv-load-more{padding:28px 0 0}
  .also-viewed-section{padding:48px 0}
  .av-header{margin-bottom:28px}
  .sec-head{margin-bottom:40px}
  .page-hero{padding-bottom:40px}
  .buybar{padding:8px 16px;gap:10px}
  .buybar .bb-price{display:none}
  .buybar .btn{padding:9px 20px;font-size:.82rem}
  .pdp-lb-prev{left:-36px;width:40px;height:40px;font-size:1.4rem}
  .pdp-lb-next{right:-36px;width:40px;height:40px;font-size:1.4rem}
  .pdp-lb-close{top:12px;right:12px;width:38px;height:38px}
  .milk-band{min-height:60vh;padding:100px 16px}
  .chip{font-size:.6rem;padding:7px 12px}
  .cart-page-grid{grid-template-columns:1fr!important;gap:28px}
  .cart-summary-box{position:static!important}
}
@media(max-width:480px){
  .wrap{padding:0 18px}
  section{padding:48px 0}
  .logo{font-size:1.15rem}
  .nav{height:56px}
  .stats-strip{grid-template-columns:1fr 1fr;gap:12px;padding:28px 0}
  .av-track{grid-template-columns:1fr 1fr;gap:10px}
  .av-info{padding:12px 12px 14px;gap:4px}
  .av-name{font-size:.84rem}
  .rv-card{padding:18px 14px}
  .rv-avatar{width:36px;height:36px;font-size:.8rem}
  .rv-card-body{font-size:.86rem}
  .rv-inline-wrap{border-radius:14px;margin-top:28px}
  .var-pill{font-size:.68rem;padding:8px 14px}
  .btn{padding:13px 24px;font-size:.88rem}
  .buybar{padding:7px 14px}
  .announce{font-size:.62rem;padding:8px 12px}
}
@media(max-width:380px){
  .wrap{padding:0 16px}
  section{padding:40px 0}
  .logo{font-size:1rem}
  .nav{height:52px}
  .av-track{gap:8px}
  .rv-card{padding:14px 12px}
  .btn{padding:12px 20px;font-size:.84rem}
  .stat .num{font-size:clamp(1.7rem,8vw,2.4rem)}
}

/* ==========================================================
   CONTACT PAGE
   ========================================================== */
.contact-grid{display:grid;grid-template-columns:minmax(0,320px) minmax(0,1fr);gap:48px;align-items:start}

/* Sidebar */
.contact-sidebar{position:sticky;top:110px;display:flex;flex-direction:column;gap:36px}
.contact-tips-head h3{font-size:1.3rem;margin-top:8px;margin-bottom:0}
.contact-tips{display:flex;flex-direction:column;gap:0;margin-top:24px}
.contact-tips li{display:flex;gap:16px;align-items:flex-start;padding:18px 0;border-bottom:1px solid var(--line-soft)}
.contact-tips li:first-child{border-top:1px solid var(--line-soft)}
.ct-icon{font-size:1.2rem;flex:none;width:36px;height:36px;background:var(--bg2);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-top:2px}
.contact-tips strong{font-family:var(--font-display);font-weight:600;font-size:.94rem;display:block;margin-bottom:3px}
.contact-tips p{font-size:.88rem;color:var(--soft);margin:0;line-height:1.55}
.contact-channels{display:flex;flex-direction:column;gap:10px;padding-top:4px}
.contact-channel-link{display:flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.06em;color:var(--soft);transition:color .2s}
.contact-channel-link:hover{color:var(--ink)}
.contact-channel-link svg{flex:none;opacity:.5}

/* Form column */
.contact-form-col{background:var(--bg2);border:1px solid var(--line-soft);border-radius:24px;overflow:hidden}
.contact-form-head{padding:32px 36px 28px;border-bottom:1px solid var(--line-soft)}
.contact-form-head h3{font-size:1.35rem;margin-bottom:8px}
.contact-response-note{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--soft);margin:0}
.contact-response-note svg{flex:none;color:var(--amber)}

/* Form fields */
.contact-form{padding:28px 36px 36px;display:flex;flex-direction:column;gap:20px}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.cf-field{display:flex;flex-direction:column;gap:7px}
.cf-field-full{grid-column:1/-1}
.cf-field label{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--soft)}
.cf-req{color:#c0392b;margin-left:2px}
.cf-opt{opacity:.5;font-size:.58rem;text-transform:none;letter-spacing:.04em}
.cf-field input,.cf-field select,.cf-field textarea{width:100%;padding:13px 16px;border:1.5px solid var(--line);border-radius:12px;font-family:var(--font-body);font-size:.94rem;background:var(--bg);color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s;box-sizing:border-box;-webkit-appearance:none;appearance:none}
.cf-field input:focus,.cf-field select:focus,.cf-field textarea:focus{border-color:var(--amber);box-shadow:0 0 0 3px rgba(107,114,130,.08)}
.cf-field textarea{min-height:140px;resize:vertical;line-height:1.65}
.cf-field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236B7282'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;cursor:pointer}
.cf-err{font-family:var(--font-mono);font-size:.63rem;letter-spacing:.06em;color:#c0392b;display:none}
.cf-footer{display:flex;align-items:center;gap:20px;flex-wrap:wrap;padding-top:4px}
.cf-submit{flex:none}
.cf-privacy{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.04em;color:var(--soft);line-height:1.5;max-width:36ch}
.cf-privacy a{color:var(--amber);text-decoration:underline;text-underline-offset:2px}

/* Success state */
.contact-success{align-items:center;gap:20px;padding:36px;background:var(--bg2)}.contact-success:not([hidden]){display:flex}
.contact-success-icon{width:52px;height:52px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;flex:none;color:#fff}
.contact-success strong{display:block;font-family:var(--font-display);font-weight:600;font-size:1.05rem;margin-bottom:4px}
.contact-success p{font-size:.9rem;color:var(--soft);margin:0}

/* FAQ */
.contact-faq{max-width:760px}
.contact-faq .ans{padding:0 8px 22px;color:var(--soft);line-height:1.72;font-size:.97rem;overflow:hidden}
.contact-faq .ans p{margin:0}

/* Responsive contact */
@media(max-width:900px){
  .contact-grid{grid-template-columns:1fr;gap:44px}
  .contact-sidebar{position:static}
}
@media(max-width:640px){
  .contact-form-head{padding:24px 22px 20px}
  .contact-form{padding:20px 22px 28px;gap:16px}
  .cf-row{grid-template-columns:1fr;gap:16px}
  .cf-footer{flex-direction:column;align-items:flex-start;gap:14px}
  .cf-submit{width:100%}
  .cf-privacy{max-width:100%}
  .contact-success{padding:24px 22px}
}

/* ==========================================================
   MOBILE NAV DRAWER
   ========================================================== */
/* Hidden on desktop — only shown inside the mobile drawer */
.nav-close,.nav-search,.nav-social,.nav-drawer-logo,.nav-drawer-cur,.nav-drawer-account{display:none}

@media(max-width:680px){
  /* ── Close button ── */
  .nav-close{
    display:flex;align-items:center;justify-content:center;
    position:absolute;top:20px;right:24px;
    background:none;border:none;
    cursor:pointer;color:var(--soft);transition:color .2s;padding:4px
  }
  .nav-close:hover{color:var(--ink)}

  /* ── Search bar ── */
  .nav-search{
    display:flex;align-items:center;gap:10px;
    background:#fff;border:1.5px solid var(--line);
    border-radius:12px;padding:10px 14px;
    margin:0 0 24px
  }
  .nav-search svg{flex:none;color:var(--soft)}
  .nav-search input{
    background:none;border:none;outline:none;
    font-family:var(--font-body);font-size:.9rem;
    color:var(--ink);width:100%
  }
  .nav-search input::placeholder{color:var(--soft)}

  /* ── Social section ── */
  .nav-social{
    display:flex;flex-direction:column;gap:2px;
    align-items:flex-start;text-align:left;
    margin-top:auto;padding-top:28px;
    border-top:1px solid var(--line-soft)
  }
  .nav-social-head{
    font-family:var(--font-mono);font-size:.6rem;
    letter-spacing:.18em;text-transform:uppercase;
    color:var(--soft);margin-bottom:10px;
    align-self:flex-start
  }
  .nav-social a{
    font-family:var(--font-mono);font-size:.74rem;
    letter-spacing:.06em;color:var(--soft);
    padding:6px 0;transition:color .2s;text-align:left;
    display:block;width:100%
  }
  .nav-social a:hover{color:var(--ink)}

  /* ── Drawer logo ── */
  .nav-drawer-logo{
    display:block;font-family:var(--font-display);font-size:1.2rem;
    font-weight:600;letter-spacing:-.02em;color:var(--ink);
    line-height:1;padding:20px 0 24px;
    padding-right:48px  /* clear the X button */
  }
  .nav-drawer-logo img{height:41px;width:auto}

  /* ── Drawer currency switcher + account (moved from the top bar) ── */
  .nav-topbar .nav-actions .nav-cur{display:none}   /* remove overlap with the logo on mobile */
  .nav-topbar .nav-actions > a.nav-icon-btn{display:none}   /* account icon → moved into drawer */
  .nav-drawer-cur{
    display:flex;justify-content:center;
    margin:0 0 24px
  }
  .nav-drawer-cur .nav-cur.rc-switcher{
    display:inline-flex;gap:8px;
    background:#fff;border:1.5px solid var(--line);
    border-radius:999px;padding:5px
  }
  .nav-drawer-cur .rc-opt{
    padding:8px 18px;border-radius:999px;
    font-family:var(--font-mono);font-size:.74rem;letter-spacing:.04em;
    color:var(--soft);transition:background .2s,color .2s
  }
  .nav-drawer-cur .rc-opt.is-active{background:var(--ink);color:#fff}

  .nav-drawer-account{
    display:flex;align-items:center;justify-content:center;gap:9px;
    margin:0 0 12px;padding:12px 16px;
    background:#fff;border:1.5px solid var(--line);border-radius:12px;
    font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
    color:var(--ink);transition:background .2s,color .2s,border-color .2s
  }
  .nav-drawer-account svg{flex:none;color:var(--soft);transition:color .2s}
  .nav-drawer-account:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
  .nav-drawer-account:hover svg{color:#fff}
  /* ── Drawer item refinements ── */
  .nav-item{display:flex}
  .nav-item>a{
    font-family:var(--font-mono);font-size:.72rem;
    letter-spacing:.14em;text-transform:uppercase;
    color:var(--ink);font-weight:500
  }
  .nav-links{height:100dvh;height:100vh}
}

/* ── Texture image (product Science section) ── */
.tex-img{width:100%;border-radius:20px;display:block;margin-top:28px;object-fit:cover;aspect-ratio:16/9}


/* ── Predictive Search Dropdown ── */
.mt-search-wrap{position:relative;flex:1;display:contents}
.nav-topsearch .mt-search-wrap{display:flex;align-items:center;gap:10px;flex:1;width:100%}
.nav-search .mt-search-wrap{display:flex;align-items:center;flex:1;width:100%}
.mt-search-drop{
  position:absolute;top:calc(100% + 8px);left:0;right:0;
  background:#fff;border:1.5px solid var(--line);border-radius:14px;
  box-shadow:0 16px 48px -12px rgba(60,50,30,.18);
  z-index:9999;overflow:hidden;display:none}
.mt-search-drop.open{display:block}
.mt-search-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 16px;text-decoration:none;
  color:var(--ink);cursor:pointer;
  border-bottom:1px solid var(--line-soft);transition:background .15s}
.mt-search-item:last-child{border-bottom:none}
.mt-search-item:hover,.mt-search-item.active{background:var(--bg2)}
.mt-si-icon{flex:none;color:var(--soft);display:flex;align-items:center}
.mt-si-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.mt-si-title{font-family:var(--font-mono);font-size:.78rem;font-weight:600;
  letter-spacing:.04em;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mt-si-desc{font-family:var(--font-body);font-size:.72rem;color:var(--soft);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mt-si-cat{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--soft);flex:none}
.mt-search-empty{padding:12px 16px;font-size:.85rem;color:var(--soft);font-style:italic}
.mt-search-drop mark{background:rgba(222,186,118,.25);color:inherit;border-radius:2px;padding:0 1px}

/* ── Spotlight Search (desktop) ────────────────────────────────────────────────
   Box-shadow on the search bar dims the entire page + nav links bar.
   The results panel is set to position:fixed by JS (left:0;right:0) so it
   spans the full viewport width regardless of the search bar's own width.
   Search bar pill shape is preserved — no border-radius change on open. ── */
@media(min-width:681px){
  .nav-topsearch{
    position:relative;
    box-shadow:0 0 0 0 rgba(18,16,14,0);   /* transparent base — enables transition */
    transition:box-shadow .22s ease;
  }
  /* Dim everything around the search bar when results are open */
  .nav-topsearch:has(.mt-search-drop.open){
    box-shadow:0 0 0 2000px rgba(18,16,14,.60);
    z-index:9998;
    /* pill corners are intentionally NOT changed — bar keeps its shape */
  }
  /* Results panel — full-width via JS (position:fixed;left:0;right:0;top:Xpx).
     These rules style the panel itself; position/coords are set as inline styles. */
  .nav-topsearch .mt-search-drop{
    border-radius:14px;
    box-shadow:0 24px 64px -16px rgba(30,20,10,.3);
    z-index:9999;
  }
  .nav-topsearch .mt-search-item{padding:11px 20px;gap:14px}
  .nav-topsearch .mt-si-title{font-size:.8rem}
}

/* ══════════════════════════════════════════════════════════════
   Mobile: search dropdown spans full drawer width
   ══════════════════════════════════════════════════════════════ */
@media(max-width:680px){
  /* dropdown breaks out of nav-search to span the full drawer width */
  /* .nav-links has padding:0 28px, so offset by -28px on each side */
  .nav-search{position:relative}
  .nav-search .mt-search-wrap{position:static}
  .nav-search .mt-search-drop{
    left:-28px;right:-28px;
    top:calc(100% + 8px);
    border-radius:12px;
    box-shadow:0 8px 32px -8px rgba(60,50,30,.18)
  }
}

/* ══════════════════════════════════════════════════════════════
   My Account page
   ══════════════════════════════════════════════════════════════ */
/* Remove Wordfence 2FA nav item */
.woocommerce-MyAccount-navigation-link--wordfence-2fa{display:none!important}

/* Page layout — override default wrap (keep .page-hero padding intact) */
.woocommerce-account .site-main>.wrap:not(.page-hero){max-width:none!important;padding:0!important}
/* Account header: smaller + refined (the global page-hero is oversized here) */
.woocommerce-account .page-hero{padding-top:44px!important;padding-bottom:28px!important}
.woocommerce-account .page-hero h1{font-size:clamp(1.9rem,3.2vw,2.7rem);letter-spacing:-.02em}
.woocommerce-account .woocommerce{
  display:flex;gap:28px;align-items:flex-start;
  max-width:1140px;margin:0 auto;
  padding:48px 24px 88px
}

/* Sidebar */
.woocommerce-MyAccount-navigation{
  flex:0 0 224px;width:224px;
  background:#fff;border:1px solid var(--line);
  border-radius:16px;padding:8px;
  position:sticky;top:90px
}
.woocommerce-MyAccount-navigation ul{list-style:none;margin:0;padding:0}
.woocommerce-MyAccount-navigation-link a{
  display:flex;align-items:center;gap:10px;
  padding:11px 14px;border-radius:10px;
  font-family:var(--font-body);font-size:.875rem;
  color:var(--ink);text-decoration:none;
  transition:background .18s,color .18s
}
.woocommerce-MyAccount-navigation-link a:hover{background:var(--amber);color:#fff}
.woocommerce-MyAccount-navigation-link a:hover::before{filter:brightness(10)}
.woocommerce-MyAccount-navigation-link--customer-logout a:hover{background:rgba(190,75,65,.12);color:#a8443c}
.woocommerce-MyAccount-navigation-link--customer-logout a:hover::before{filter:none;opacity:.85}
.woocommerce-MyAccount-navigation-link.is-active a{
  background:#3d3832;color:#fff
}

/* Nav icons */
.woocommerce-MyAccount-navigation-link a::before{
  content:'';display:inline-block;flex:none;
  width:16px;height:16px;
  background:no-repeat center/16px;opacity:.55
}
.woocommerce-MyAccount-navigation-link.is-active a::before{opacity:1;filter:brightness(10)}

.woocommerce-MyAccount-navigation-link--dashboard a::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23333' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round' viewBox='0 0 24 24'%3E%3Crect x='3' y='3' width='7' height='7'/%3E%3Crect x='14' y='3' width='7' height='7'/%3E%3Crect x='3' y='14' width='7' height='7'/%3E%3Crect x='14' y='14' width='7' height='7'/%3E%3C/svg%3E")}
.woocommerce-MyAccount-navigation-link--orders a::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23333' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round' viewBox='0 0 24 24'%3E%3Cpath d='M14 2H6a2 2 0 00-2 2v16a2 2 0 002 2h12a2 2 0 002-2V8z'/%3E%3Cpolyline points='14 2 14 8 20 8'/%3E%3Cline x1='16' y1='13' x2='8' y2='13'/%3E%3Cline x1='16' y1='17' x2='8' y2='17'/%3E%3C/svg%3E")}
.woocommerce-MyAccount-navigation-link--downloads a::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23333' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round' viewBox='0 0 24 24'%3E%3Cpath d='M21 15v4a2 2 0 01-2 2H5a2 2 0 01-2-2v-4'/%3E%3Cpolyline points='7 10 12 15 17 10'/%3E%3Cline x1='12' y1='15' x2='12' y2='3'/%3E%3C/svg%3E")}
.woocommerce-MyAccount-navigation-link--edit-address a::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23333' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round' viewBox='0 0 24 24'%3E%3Cpath d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0118 0z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E")}
.woocommerce-MyAccount-navigation-link--payment-methods a::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23333' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round' viewBox='0 0 24 24'%3E%3Crect x='1' y='4' width='22' height='16' rx='2'/%3E%3Cline x1='1' y1='10' x2='23' y2='10'/%3E%3C/svg%3E")}
.woocommerce-MyAccount-navigation-link--edit-account a::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23333' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round' viewBox='0 0 24 24'%3E%3Cpath d='M20 21v-2a4 4 0 00-4-4H8a4 4 0 00-4 4v2'/%3E%3Ccircle cx='12' cy='7' r='4'/%3E%3C/svg%3E")}
.woocommerce-MyAccount-navigation-link--wishlist a::before,
.woocommerce-MyAccount-navigation-link--yith-wcwl-my-wishlist a::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23333' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round' viewBox='0 0 24 24'%3E%3Cpath d='M20.84 4.61a5.5 5.5 0 00-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 00-7.78 7.78l1.06 1.06L12 21.23l7.78-7.78 1.06-1.06a5.5 5.5 0 000-7.78z'/%3E%3C/svg%3E")}
.woocommerce-MyAccount-navigation-link--customer-logout a::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23333' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round' viewBox='0 0 24 24'%3E%3Cpath d='M9 21H5a2 2 0 01-2-2V5a2 2 0 012-2h4'/%3E%3Cpolyline points='16 17 21 12 16 7'/%3E%3Cline x1='21' y1='12' x2='9' y2='12'/%3E%3C/svg%3E")}

/* Content area */
.woocommerce-MyAccount-content{
  flex:1;min-width:0;
  background:#fff;border:1px solid var(--line);
  border-radius:16px;padding:32px 36px
}
.woocommerce-MyAccount-content p:first-child{margin-top:0}
.woocommerce-MyAccount-content h2,.woocommerce-MyAccount-content h3{
  font-family:var(--font-display);font-size:1.25rem;margin-bottom:16px
}

/* Branded account dashboard */
.mt-dash-head{margin-bottom:24px}
.mt-dash-head h2{margin:6px 0}
.mt-dash-head p{color:var(--soft);margin:0;font-size:.95rem}
.mt-dash-order{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;border:1px solid var(--line-soft);border-radius:14px;padding:18px 20px;margin-bottom:26px;background:#faf4ea}
.mt-dash-label{display:block;font-family:var(--font-mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--soft);margin-bottom:5px}
.mt-dash-order strong{font-size:1.05rem;margin-right:8px}
.mt-dash-meta{color:var(--soft);font-size:.9rem}
.mt-dash-order .btn{padding:10px 22px;font-size:.85rem}
.mt-dash-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:34px}
.mt-dash-card{display:block;border:1px solid var(--line);border-radius:14px;padding:18px 20px;text-decoration:none;transition:border-color .2s,background .2s}
.mt-dash-card:hover{background:var(--bg2);border-color:var(--ink)}
.mt-dash-card-t{display:block;font-family:var(--font-display);font-weight:600;color:var(--ink);margin-bottom:4px}
.mt-dash-card-d{display:block;color:var(--soft);font-size:.86rem;line-height:1.5}
.mt-dash-routine-head{margin-bottom:16px}
.mt-dash-routine-head h3{margin:4px 0 0}
.mt-dash-picks{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:16px}
.mt-dash-pick{display:block;text-decoration:none;text-align:center}
.mt-dash-pick-img{display:block;background:var(--bg2);border-radius:12px;overflow:hidden;aspect-ratio:1;margin-bottom:10px}
.mt-dash-pick-img img{width:100%;height:100%;object-fit:cover}
.mt-dash-pick-name{display:block;font-size:.86rem;color:var(--ink);font-weight:600;line-height:1.35}
.mt-dash-pick-price{display:block;font-size:.82rem;color:var(--soft);margin-top:2px}
.mt-dash-help{margin-top:30px;padding-top:18px;border-top:1px solid var(--line-soft);color:var(--soft);font-size:.9rem}
.mt-dash-help a{color:var(--amber);text-decoration:underline;text-underline-offset:2px}

/* Dashboard points highlight */
.mt-dash-points{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;background:#faf4ea;border:1px solid var(--line-soft);border-radius:14px;padding:16px 20px;margin-bottom:26px}
.mt-dash-points-num{font-family:var(--font-display);font-weight:700;font-size:1.6rem;color:var(--ink);line-height:1}
.mt-dash-points-label{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--soft)}
.mt-dash-points a{margin-left:auto;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--amber);text-decoration:none}

/* Rewards tab */
.mt-rewards-balance{display:flex;align-items:baseline;gap:12px;padding:24px 26px;background:#faf4ea;border:1px solid var(--line-soft);border-radius:14px;margin-bottom:18px}
.mt-rewards-num{font-family:var(--font-display);font-weight:700;font-size:2.6rem;color:var(--ink);line-height:1}
.mt-rewards-label{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--soft)}
.mt-rewards-how{color:var(--soft);font-size:.95rem;line-height:1.6;margin-bottom:26px}
.mt-rewards-how strong{color:var(--ink)}
.woocommerce-MyAccount-navigation-link--rewards a::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23333' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round' viewBox='0 0 24 24'%3E%3Cpolygon points='12 2 15.09 8.26 22 9.27 17 14.14 18.18 21.02 12 17.77 5.82 21.02 7 14.14 2 9.27 8.91 8.26 12 2'/%3E%3C/svg%3E")}
/* My reviews endpoint (mt-product-reviews): comment bubble with a star */
.woocommerce-MyAccount-navigation-link--my-reviews a::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23333' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round' viewBox='0 0 24 24'%3E%3Cpath d='M21 11.5a8.38 8.38 0 0 1-.9 3.8 8.5 8.5 0 0 1-7.6 4.7 8.38 8.38 0 0 1-3.8-.9L3 21l1.9-5.7a8.38 8.38 0 0 1-.9-3.8 8.5 8.5 0 0 1 4.7-7.6 8.38 8.38 0 0 1 3.8-.9h.5a8.48 8.48 0 0 1 8 8v.5z'/%3E%3Cpolygon points='12 8 12.9 9.9 15 10.1 13.4 11.5 13.9 13.6 12 12.5 10.1 13.6 10.6 11.5 9 10.1 11.1 9.9 12 8'/%3E%3C/svg%3E")}
.mt-rewards .shop_table td.mt-pts-pos{color:#1f7a3d;font-weight:600}
.mt-rewards .shop_table td.mt-pts-neg{color:#a8443c;font-weight:600}
@media(max-width:560px){.mt-dash-grid{grid-template-columns:1fr}}

/* Checkout — reward points redemption toggle */
.mt-redeem{background:#faf4ea;border:1px solid var(--line-soft);border-radius:14px;padding:16px 18px;margin:0 0 22px}
.mt-redeem-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:.95rem;color:var(--ink);line-height:1.4}
.mt-redeem-label input{margin-top:3px;width:16px;height:16px;accent-color:var(--amber);flex:0 0 auto}
.mt-redeem-label strong{display:block;margin-top:4px;font-weight:600;color:var(--amber)}
.mt-redeem-note{margin:8px 0 0 26px;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--soft)}
/* Cart — reward points apply/remove */
.mt-cart-redeem th{font-weight:600}
.mt-cart-redeem-link{color:var(--amber);text-decoration:underline;font-weight:600}
.mt-cart-redeem-link:hover{color:var(--ink)}
.mt-cart-redeem-on{color:#1f7a3d;font-weight:600}

/* ── Account tabs — on-brand content (orders, downloads, addresses, forms) ── */
.woocommerce-MyAccount-content a.button,
.woocommerce-MyAccount-content button:not(.mt-acc-plain):not(.show-password-input),
.woocommerce-MyAccount-content input[type=submit]{
  display:inline-block;background:var(--ink);color:var(--bg);border:1px solid var(--ink);
  border-radius:999px;padding:11px 24px;font-family:var(--font-body);font-weight:600;
  font-size:.85rem;letter-spacing:.02em;text-decoration:none;cursor:pointer;transition:opacity .2s}
.woocommerce-MyAccount-content a.button:hover,
.woocommerce-MyAccount-content button:not(.mt-acc-plain):not(.show-password-input):hover,
.woocommerce-MyAccount-content input[type=submit]:hover{opacity:.88}

/* Password show/hide eye — inside the field, on theme */
.woocommerce-MyAccount-content .password-input{position:relative;display:block;width:100%}
.woocommerce-MyAccount-content .password-input input{padding-right:44px}
.woocommerce-MyAccount-content .show-password-input{
  position:absolute;right:12px;top:50%;transform:translateY(-50%);
  width:26px;height:26px;padding:0!important;margin:0!important;
  background:transparent!important;border:none!important;border-radius:0!important;
  display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:.55;transition:opacity .18s}
.woocommerce-MyAccount-content .show-password-input:hover{opacity:1}
.woocommerce-MyAccount-content .show-password-input::before{margin:0}
.woocommerce-MyAccount-content .show-password-input.display-password{opacity:1}
.mt-default-badge{display:inline-block;margin-left:8px;font-family:var(--font-mono);font-size:.56rem;letter-spacing:.1em;text-transform:uppercase;background:rgba(107,114,130,.12);color:var(--amber);padding:3px 9px;border-radius:999px;vertical-align:middle}
.woocommerce-MyAccount-content .mt-add-pay{margin-top:20px}
.woocommerce-MyAccount-content .payment-method-actions{text-align:right;white-space:nowrap}
.woocommerce-MyAccount-content .payment-method-actions .button{margin-left:8px}

/* Add payment method form — on brand (remove lavender gateway boxes) */
.woocommerce-account #payment,
.woocommerce-account .woocommerce-Payment{background:transparent!important;border:none!important;border-radius:0!important;padding:0!important}
.woocommerce-account ul.payment_methods,
.woocommerce-account .woocommerce-PaymentMethods{border:none!important;margin:0!important;padding:0!important;list-style:none}
.woocommerce-account li.wc_payment_method>label,
.woocommerce-account li.woocommerce-PaymentMethod>label{font-family:var(--font-display);font-weight:600;color:var(--ink);font-size:.98rem;padding-left:0!important;margin-left:0!important}
.woocommerce-account li.wc_payment_method>input[type=radio],
.woocommerce-account li.woocommerce-PaymentMethod>input[type=radio],
.woocommerce-account .woocommerce-PaymentMethods input.input-radio{display:none!important}
.woocommerce-account .woocommerce-PaymentBox,
.woocommerce-account .payment_box{
  background:var(--bg)!important;border:1px solid var(--line-soft)!important;border-radius:12px!important;
  color:var(--soft)!important;padding:18px 20px!important;margin-top:14px!important;box-shadow:none!important}
.woocommerce-account .woocommerce-PaymentBox::before,
.woocommerce-account .payment_box::before{display:none!important}
.woocommerce-account #payment .form-row,
.woocommerce-account .woocommerce-PaymentBox .form-row{margin-bottom:14px}
.woocommerce-account #payment #place_order,
.woocommerce-account #payment button[type=submit]{margin-top:6px}

/* Empty-state notices (Downloads, Payment methods, etc.) — on brand */
.woocommerce-MyAccount-content .woocommerce-info,
.woocommerce-MyAccount-content .woocommerce-Message,
.woocommerce-MyAccount-content .woocommerce-notice{
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  background:transparent!important;border:none!important;
  border-radius:0!important;padding:4px 0!important;margin:0!important;
  color:var(--soft)!important;font-size:.95rem;box-shadow:none!important}
.woocommerce-MyAccount-content .woocommerce-info::before,
.woocommerce-MyAccount-content .woocommerce-Message::before{display:none!important}
.woocommerce-MyAccount-content .woocommerce-info a.button,
.woocommerce-MyAccount-content .woocommerce-Message a.button{margin:0!important;flex:0 0 auto}

.woocommerce-MyAccount-content table{
  width:100%;border-collapse:collapse;font-size:.9rem;margin:0;background:transparent!important;border:none!important;border-radius:0!important}
.woocommerce-MyAccount-content table th{
  text-align:left;font-family:var(--font-mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--soft);padding:0 16px 12px;background:transparent;border-bottom:1px solid var(--line)}
.woocommerce-MyAccount-content table td{
  padding:15px 16px;background:transparent;border-bottom:1px solid var(--line-soft);color:var(--ink);vertical-align:middle}
.woocommerce-MyAccount-content table tr:last-child td{border-bottom:none}
.woocommerce-MyAccount-content table th:first-child,
.woocommerce-MyAccount-content table td:first-child{padding-left:0}
.woocommerce-MyAccount-content table th:last-child,
.woocommerce-MyAccount-content table td:last-child{padding-right:0}
.woocommerce-MyAccount-content table td.woocommerce-orders-table__cell-order-actions{text-align:right}
.woocommerce-MyAccount-content table .button{padding:8px 18px;font-size:.78rem}

.woocommerce-MyAccount-content form .woocommerce-form-row,
.woocommerce-MyAccount-content form p.form-row{margin-bottom:16px}
.woocommerce-MyAccount-content label{display:block;font-size:.8rem;font-weight:600;color:var(--ink);margin-bottom:6px}
.woocommerce-MyAccount-content input:not([type=submit]):not([type=checkbox]):not([type=radio]),
.woocommerce-MyAccount-content textarea,
.woocommerce-MyAccount-content select{
  width:100%;padding:11px 14px;border:1px solid var(--line);border-radius:10px;
  font-family:var(--font-body);font-size:.92rem;color:var(--ink);background:#fff;transition:border-color .2s}
.woocommerce-MyAccount-content input:focus,
.woocommerce-MyAccount-content textarea:focus,
.woocommerce-MyAccount-content select:focus{outline:none;border-color:var(--amber)}
.woocommerce-MyAccount-content input[readonly]{background:var(--bg);color:var(--soft);cursor:default}
.woocommerce-MyAccount-content input[readonly]:focus{border-color:var(--line)}
.mt-name-note{clear:both;text-align:left;margin:-8px 0 18px;font-size:.8rem;color:var(--soft)}
.mt-name-note a{color:var(--amber);text-decoration:underline;text-underline-offset:2px}
.woocommerce-MyAccount-content fieldset{border:1px solid var(--line-soft);border-radius:12px;padding:16px 20px;margin:22px 0}
.woocommerce-MyAccount-content fieldset legend{font-family:var(--font-display);font-weight:600;padding:0 8px}
.woocommerce-MyAccount-content .woocommerce-Input em,
.woocommerce-MyAccount-content span.description{font-style:normal;color:var(--soft);font-size:.78rem}

.woocommerce-MyAccount-content .woocommerce-Addresses{display:grid!important;grid-template-columns:1fr 1fr!important;gap:18px;margin-top:10px;align-items:start;direction:ltr!important}
.woocommerce-MyAccount-content .woocommerce-Address{float:none!important;width:auto!important;margin:0!important;border:1px solid var(--line);border-radius:12px;padding:20px 22px}
/* Pin billing to the left column, shipping to the right — one row */
.woocommerce-MyAccount-content .woocommerce-Address.col-1,
.woocommerce-MyAccount-content .woocommerce-Address.u-column1{grid-column:1!important;grid-row:1!important}
.woocommerce-MyAccount-content .woocommerce-Address.col-2,
.woocommerce-MyAccount-content .woocommerce-Address.u-column2{grid-column:2!important;grid-row:1!important}
.woocommerce-MyAccount-content .woocommerce-Address address{font-style:normal;color:var(--soft);line-height:1.65;font-size:.92rem}
.woocommerce-MyAccount-content .woocommerce-Address-title{display:flex!important;align-items:baseline;gap:12px;margin-bottom:12px;text-align:left}
.woocommerce-MyAccount-content .woocommerce-Address-title::before,
.woocommerce-MyAccount-content .woocommerce-Address-title::after{display:none!important}
.woocommerce-MyAccount-content .woocommerce-Address-title h2,
.woocommerce-MyAccount-content .woocommerce-Address-title h3{margin:0!important;padding:0;font-size:1.05rem;text-align:left;flex:0 1 auto}
.woocommerce-MyAccount-content .woocommerce-Address-title .edit{margin-left:auto;flex:0 0 auto;white-space:nowrap;font-family:var(--font-mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--amber);text-decoration:none}
.woocommerce-MyAccount-content .woocommerce-Address-title .edit:hover{color:var(--ink)}
@media(max-width:600px){.woocommerce-MyAccount-content .woocommerce-Addresses{grid-template-columns:1fr!important}
  .woocommerce-MyAccount-content .woocommerce-Address.col-1,
  .woocommerce-MyAccount-content .woocommerce-Address.col-2,
  .woocommerce-MyAccount-content .woocommerce-Address.u-column1,
  .woocommerce-MyAccount-content .woocommerce-Address.u-column2{grid-column:1!important;grid-row:auto!important}}

.woocommerce-MyAccount-content .form-row-first{width:48%;float:left;margin-right:4%}
.woocommerce-MyAccount-content .form-row-last{width:48%;float:left}
.woocommerce-MyAccount-content .form-row-wide{clear:both}
.woocommerce-MyAccount-content form{overflow:hidden}

@media(max-width:600px){
  .woocommerce-MyAccount-content .woocommerce-Addresses{grid-template-columns:1fr}
  .woocommerce-MyAccount-content .form-row-first,
  .woocommerce-MyAccount-content .form-row-last{width:100%;float:none;margin-right:0}
  .woocommerce-MyAccount-content table thead{display:none}
  .woocommerce-MyAccount-content table tr{display:block;padding:8px 0;border-bottom:1px solid var(--line)}
  .woocommerce-MyAccount-content table tr:last-child{border-bottom:none}
  .woocommerce-MyAccount-content table td{display:flex;justify-content:space-between;gap:16px;border:none;padding:6px 16px}
  .woocommerce-MyAccount-content table td::before{content:attr(data-title);font-weight:600;color:var(--soft)}
  .woocommerce-MyAccount-content table td.woocommerce-orders-table__cell-order-actions{justify-content:flex-end}
}

/* Tablet: tighten sidebar */
@media(max-width:900px){
  .woocommerce-account .woocommerce{gap:20px}
  .woocommerce-MyAccount-navigation{flex:0 0 190px;width:190px}
}
/* Mobile: stack sidebar above content */
@media(max-width:680px){
  .woocommerce-account .woocommerce{
    flex-direction:column;gap:16px;
    padding:24px 20px 60px
  }
  .woocommerce-MyAccount-navigation{
    flex:none;width:100%;position:static;
    border-radius:14px
  }
  .woocommerce-MyAccount-content{
    padding:20px;border-radius:14px
  }
  .woocommerce-account .page-hero{
    padding-top:32px;padding-bottom:32px
  }
  .woocommerce-account .page-hero h1{
    font-size:clamp(2rem,10vw,3.5rem)
  }
}

/* ══════════════════════════════════════════════════════════════
   Newsletter popup
   ══════════════════════════════════════════════════════════════ */
.mt-popup-overlay{
  position:fixed;inset:0;z-index:9000;
  background:rgba(30,25,20,.55);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
  padding:20px;opacity:0;pointer-events:none;
  transition:opacity .35s ease
}
.mt-popup-overlay.open{opacity:1;pointer-events:auto}

/* ── Popup card ─────────────────────────────────────────────── */
.mt-popup{
  background:var(--bg);border:1px solid var(--line);
  border-radius:20px;max-width:460px;width:100%;
  padding:48px 44px 44px;position:relative;
  box-shadow:0 32px 80px -16px rgba(30,20,10,.22);
  transform:translateY(20px) scale(.97);
  transition:transform .35s cubic-bezier(.16,1,.3,1)
}
.mt-popup-overlay.open .mt-popup{transform:none}

.mt-popup-close{
  position:absolute;top:16px;right:16px;
  background:none;border:none;cursor:pointer;
  color:var(--soft);padding:4px;
  border-radius:6px;transition:color .15s
}
.mt-popup-close:hover{color:var(--ink)}

.mt-popup-eyebrow{
  font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--soft);margin-bottom:10px
}
.mt-popup h2{
  font-size:clamp(1.4rem,3vw,1.75rem);margin-bottom:10px;line-height:1.15
}
.mt-popup-sub{font-size:.875rem;color:var(--soft);margin-bottom:24px}

.mt-popup-form{display:flex;flex-direction:column;gap:10px}
.mt-popup-form input[type="email"]{
  width:100%;background:var(--bg2);
  border:1px solid var(--line);border-radius:10px;
  padding:13px 16px;font-family:var(--font-body);
  font-size:.875rem;color:var(--ink);outline:none;
  transition:border-color .18s
}
.mt-popup-form input[type="email"]:focus{border-color:var(--amber);background:#fff}
.mt-popup-form button{
  background:var(--dark);color:#fff;border:none;
  border-radius:100px;padding:14px 20px;
  font-family:var(--font-display);font-size:.9rem;font-weight:600;
  letter-spacing:.025em;cursor:pointer;transition:opacity .18s
}
.mt-popup-form button:hover{opacity:.85}
.mt-popup-form button:disabled{opacity:.55;cursor:default}

.mt-popup-disclaimer{
  font-size:.72rem;color:var(--soft);margin-top:12px;text-align:center
}

.mt-popup-success{
  display:none;text-align:center;padding:12px 0
}
.mt-popup-success svg{margin:0 auto 12px;color:var(--amber-soft)}
.mt-popup-success p{font-size:.9rem;color:var(--ink)}

@media(max-width:680px){
  .mt-popup{padding:36px 24px 28px}
  .mt-popup h2{font-size:1.4rem}
}

/* ══════════════════════════════════════════════════════════════
   Cart / Checkout / Confirmation — WooCommerce Blocks  v5.8
   ══════════════════════════════════════════════════════════════ */

/* ── Step indicator ─────────────────────────────────────────── */
.mt-checkout-steps{
  display:flex;align-items:center;justify-content:center;
  padding:40px 24px 0;max-width:560px;margin:0 auto 52px
}
.mt-cs-step{
  display:flex;flex-direction:column;align-items:center;gap:7px;flex:none
}
.mt-cs-num{
  width:34px;height:34px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.78rem;font-weight:600;font-family:var(--font-display);
  border:2px solid var(--line);color:var(--soft);background:#fff;
  transition:background .22s,border-color .22s,color .22s
}
.mt-cs-label{
  font-size:.7rem;font-family:var(--font-display);
  color:var(--soft);letter-spacing:.03em;white-space:nowrap;
  transition:color .22s
}
.mt-cs-step.active .mt-cs-num{background:var(--dark);border-color:var(--dark);color:#fff}
.mt-cs-step.active .mt-cs-label{color:var(--ink);font-weight:600}
.mt-cs-step.done .mt-cs-num{background:var(--dark);border-color:var(--dark);color:#fff}
/* Completed steps are <a> tags — keep same visual, add pointer */
a.mt-cs-step{text-decoration:none;cursor:pointer}
a.mt-cs-step:hover .mt-cs-num{opacity:.75}
a.mt-cs-step:hover .mt-cs-label{color:var(--ink)}
.mt-cs-line{
  flex:1;min-width:44px;height:2px;
  background:var(--line);margin-bottom:26px;transition:background .22s
}
.mt-cs-line.done{background:var(--dark)}

/* ── Page container ─────────────────────────────────────────── */
.woocommerce-cart .wp-block-woocommerce-cart,
.woocommerce-checkout .wp-block-woocommerce-checkout{
  padding:0 0 80px
}

/* ── Sidebar-layout: add gap, align top ─────────────────────── */
.woocommerce-cart .wc-block-components-sidebar-layout,
.woocommerce-checkout .wc-block-components-sidebar-layout{
  gap:24px!important;align-items:start!important;padding-top:28px;
  flex-wrap:nowrap!important
}
/* Force side-by-side columns: main grows, sidebar stays fixed */
.woocommerce-cart .wc-block-cart__main,
.woocommerce-checkout .wc-block-checkout__main{flex:1 1 0!important;min-width:0!important}
.woocommerce-cart .wc-block-cart__sidebar,
.woocommerce-checkout .wc-block-checkout__sidebar{flex:0 0 264px!important;width:264px!important;min-width:0!important}

/* ── Card panels ────────────────────────────────────────────── */
.woocommerce-cart .wc-block-cart__main,
.woocommerce-checkout .wc-block-checkout__main{
  background:#fff;border:1px solid var(--line);
  border-radius:20px;padding:28px 32px;min-width:0
}
.woocommerce-cart .wc-block-cart__sidebar,
.woocommerce-checkout .wc-block-checkout__sidebar{
  background:#fff;border:1px solid var(--line);
  border-radius:20px;padding:24px 28px;
  position:sticky;top:88px
}

/* ── Cart: hide column headers ──────────────────────────────── */
.wc-block-cart-items__header{display:none!important}

/* ── Cart item rows ─────────────────────────────────────────── */
.wc-block-cart-items__row{
  padding:18px 0;border-top:1px solid var(--line-soft)
}
.wc-block-cart-items__row:first-child{border-top:none!important}
.wc-block-cart-item__wrap{
  display:grid;grid-template-columns:80px 1fr;gap:14px;align-items:start
}
.wc-block-cart-item__image img{
  width:80px!important;height:80px!important;object-fit:cover;
  border-radius:12px;border:1px solid var(--line)
}
.wc-block-cart-item__product{display:flex;flex-direction:column;gap:6px}
.wc-block-components-product-name a{
  font-family:var(--font-display);font-size:.9rem;
  font-weight:600;color:var(--ink)
}
.wc-block-components-product-metadata__description{
  font-size:.78rem;color:var(--soft)
}
.wc-block-cart-item__remove-link{margin-top:2px}
.wc-block-cart-item__remove-link a{
  font-size:.73rem;color:var(--soft);text-decoration:underline;
  transition:color .15s
}
.wc-block-cart-item__remove-link a:hover{color:var(--ink)}

/* ── Quantity selector — white, minimal, premium ────────────── */
.wc-block-components-quantity-selector{
  display:inline-flex!important;align-items:center;
  border:1px solid var(--line)!important;border-radius:100px!important;
  overflow:hidden;background:#fff!important;height:34px;gap:0
}
.wc-block-components-quantity-selector__button{
  width:32px;height:34px;border:none!important;background:none!important;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--ink);font-size:1rem;
  transition:background .15s;flex-shrink:0
}
.wc-block-components-quantity-selector__button:hover{
  background:var(--line)!important
}
.wc-block-components-quantity-selector__input{
  width:32px;text-align:center;border:none!important;background:none!important;
  font-family:var(--font-display);font-size:.85rem;font-weight:600;
  color:var(--ink);padding:0;-moz-appearance:textfield
}
.wc-block-components-quantity-selector__input::-webkit-outer-spin-button,
.wc-block-components-quantity-selector__input::-webkit-inner-spin-button{-webkit-appearance:none}

/* ── Item total price ───────────────────────────────────────── */
.wc-block-cart-item__total .wc-block-components-product-price__value,
.wc-block-cart-item__prices .wc-block-components-product-price__value{
  font-family:var(--font-display);font-weight:600;
  font-size:.9rem;color:var(--ink)
}

/* ── Cart totals sidebar ────────────────────────────────────── */
.wc-block-cart__totals-title{
  font-family:var(--font-display);font-weight:600;
  font-size:1rem;color:var(--ink);
  margin-bottom:14px;padding-bottom:14px;
  border-bottom:1px solid var(--line)
}
.wc-block-components-totals-item{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:10px 0;border-bottom:1px solid var(--line-soft);
  font-size:.875rem;color:var(--ink)
}
.wc-block-components-totals-footer-item{
  border-bottom:none!important;padding-top:14px;
  font-weight:700;font-family:var(--font-display);font-size:1rem
}
.wc-block-components-panel{margin-top:10px}
.wc-block-components-panel__button{
  background:none;border:none;padding:0;
  font-size:.78rem;color:var(--soft);cursor:pointer;
  text-decoration:underline;transition:color .15s
}
.wc-block-components-panel__button:hover{color:var(--ink)}

/* Coupon row */
.wc-block-components-totals-coupon__form{display:flex;gap:8px;margin-top:10px}
.wc-block-components-totals-coupon .wc-block-components-text-input input{
  background:#fff!important;border:1px solid rgba(0,0,0,.12)!important;
  border-radius:8px!important;padding:9px 12px!important;
  font-size:.83rem!important;outline:none!important;
  box-shadow:0 1px 2px rgba(0,0,0,.04)!important
}
.wc-block-components-totals-coupon .wc-block-components-text-input input:focus{
  border-color:var(--dark)!important;
  box-shadow:0 0 0 3px rgba(46,51,61,.08)!important
}

/* ── Proceed to checkout / Place order buttons ──────────────── */
.wc-block-cart__submit-container{margin-top:20px}
.wc-block-cart__submit-button.wc-block-components-button,
.wc-block-components-checkout-place-order-button{
  display:block!important;width:100%!important;
  background:var(--dark)!important;color:#fff!important;
  border:none!important;border-radius:100px!important;
  padding:15px 28px!important;
  font-family:var(--font-display)!important;
  font-size:.9rem!important;font-weight:600!important;
  letter-spacing:.025em!important;cursor:pointer!important;
  transition:opacity .18s!important;text-align:center!important
}
.wc-block-cart__submit-button.wc-block-components-button:hover,
.wc-block-components-checkout-place-order-button:hover{opacity:.8!important}
.wc-block-cart__payment-options{
  margin-top:12px;display:flex;justify-content:center;
  gap:8px;flex-wrap:wrap;opacity:.55;filter:grayscale(.4)
}

/* ── Checkout form step sections ────────────────────────────── */
.wc-block-components-checkout-step{
  padding:22px 0;border-bottom:1px solid var(--line-soft)
}
.wc-block-components-checkout-step:last-child{border-bottom:none}
.wc-block-components-checkout-step__heading-container{margin-bottom:14px}
.wc-block-components-title.wc-block-components-checkout-step__title{
  font-family:var(--font-display)!important;
  font-size:1rem!important;font-weight:600!important;color:var(--ink)!important
}

/* ── Text inputs (checkout) — white, clean, premium ─────────── */
.wc-block-components-text-input{position:relative;margin-bottom:10px}
.wc-block-components-text-input input{
  width:100%;
  background:#fff!important;
  border:1px solid rgba(0,0,0,.12)!important;
  border-radius:10px!important;
  padding:13px 14px 7px!important;
  font-family:var(--font-body)!important;
  font-size:.875rem!important;color:var(--ink)!important;
  transition:border-color .18s,box-shadow .18s!important;outline:none!important;
  box-shadow:0 1px 2px rgba(0,0,0,.04)!important
}
.wc-block-components-text-input input:focus{
  border-color:var(--dark)!important;
  box-shadow:0 0 0 3px rgba(46,51,61,.08)!important
}
.wc-block-components-text-input label{
  font-size:.7rem!important;color:var(--soft)!important;
  font-family:var(--font-display)!important;letter-spacing:.02em!important;
  text-transform:uppercase!important
}

/* Select (country/state) */
.wc-blocks-components-select__select,
.wc-block-components-select select{
  width:100%;background:#fff!important;
  border:1px solid rgba(0,0,0,.12)!important;border-radius:10px!important;
  padding:12px 36px 12px 14px!important;font-family:var(--font-body)!important;
  font-size:.875rem!important;color:var(--ink)!important;
  outline:none!important;cursor:pointer;
  box-shadow:0 1px 2px rgba(0,0,0,.04)!important;
  transition:border-color .18s,box-shadow .18s!important;
  appearance:none!important;-webkit-appearance:none!important
}
.wc-blocks-components-select__select:focus,
.wc-block-components-select select:focus{
  border-color:var(--dark)!important;
  box-shadow:0 0 0 3px rgba(46,51,61,.08)!important
}
.wc-blocks-components-select__label,
.wc-block-components-select label{
  font-size:.7rem!important;color:var(--soft)!important;display:block;
  margin-bottom:4px;font-family:var(--font-display)!important;
  letter-spacing:.02em!important;text-transform:uppercase!important
}

/* Checkbox */
.wc-block-components-checkbox{display:flex;align-items:center;gap:8px;margin:10px 0}
.wc-block-components-checkbox__input{width:16px;height:16px;accent-color:var(--dark)}
.wc-block-components-checkbox__label{font-size:.83rem!important;color:var(--ink)!important}

/* Terms */
.wc-block-checkout__terms{font-size:.78rem;color:var(--soft);padding-top:14px}

/* Order notes textarea */
.wc-block-checkout__add-note textarea,
.wc-block-checkout__order-notes textarea{
  width:100%;background:#fff!important;
  border:1px solid rgba(0,0,0,.12)!important;border-radius:10px!important;
  padding:12px 14px!important;font-family:var(--font-body)!important;
  font-size:.83rem!important;color:var(--ink)!important;
  resize:vertical;outline:none!important;min-height:80px;
  box-shadow:0 1px 2px rgba(0,0,0,.04)!important;
  transition:border-color .18s,box-shadow .18s!important
}
.wc-block-checkout__add-note textarea:focus,
.wc-block-checkout__order-notes textarea:focus{
  border-color:var(--dark)!important;
  box-shadow:0 0 0 3px rgba(46,51,61,.08)!important
}

/* Privacy / personal data notice — remove cream bg */
.wc-block-checkout__privacy-policy-notice,
.wc-block-checkout__terms,
.wc-block-components-checkout-return-to-cart-button,
.wc-block-checkout__privacy-policy-notice p{
  background:transparent!important;
  font-size:.78rem!important;color:var(--soft)!important;
  border:none!important;padding:0!important;margin:0 0 10px!important
}
.wc-block-checkout__privacy-policy-notice a,
.wc-block-checkout__terms a{
  color:var(--ink)!important;text-decoration:underline!important;
  text-underline-offset:2px!important
}

/* Shipping method radio option */
.wc-block-components-shipping-rates-control__package{margin:6px 0}
.wc-block-components-radio-control__option{
  display:flex!important;align-items:center!important;
  background:#fff!important;border:1px solid rgba(0,0,0,.12)!important;
  border-radius:10px!important;padding:11px 14px!important;
  margin-bottom:6px!important;cursor:pointer!important;
  transition:border-color .18s!important;gap:10px!important;
  box-shadow:0 1px 2px rgba(0,0,0,.04)!important
}
.wc-block-components-radio-control__option:has(input:checked){
  border-color:var(--dark)!important;
  box-shadow:0 0 0 2px rgba(46,51,61,.1)!important
}
.wc-block-components-radio-control__option-layout{flex:1 1 0}
.wc-block-components-radio-control-accordion-option{
  background:#fff!important;border:1px solid rgba(0,0,0,.12)!important;
  border-radius:10px!important;overflow:hidden!important
}

/* ── Checkout sidebar: order summary ────────────────────────── */
.wc-block-components-checkout-order-summary__title-text,
.wc-block-components-checkout-order-summary__title-price{
  font-family:var(--font-display)!important;
  font-weight:600!important;font-size:.9rem!important;color:var(--ink)!important
}
.wc-block-components-order-summary__content{padding-top:10px}
.wc-block-components-order-summary-item{
  display:flex;gap:10px;align-items:center;
  padding:10px 0;border-bottom:1px solid var(--line-soft)
}
.wc-block-components-order-summary-item:last-child{border-bottom:none}
/* Remove inner divider between items and totals in sidebar */
.wc-block-checkout__sidebar .wc-block-components-order-summary,
.wc-block-cart__sidebar .wc-block-components-order-summary,
.wp-block-woocommerce-checkout-order-summary-cart-items-block,
.wc-block-components-checkout-order-summary__content{
  border-bottom:none!important;border-top:none!important
}
.wc-block-checkout__sidebar hr,
.wc-block-cart__sidebar hr{display:none!important}
/* ── Hide redundant page hero/title on cart/checkout ─────────── */
.woocommerce-cart .entry-title,
.woocommerce-checkout .entry-title,
.woocommerce-cart .page-title,
.woocommerce-checkout .page-title,
.woocommerce-cart .page-hero,
.woocommerce-checkout .page-hero{display:none!important}

/* Override table display so items get full sidebar width */
.wc-block-components-order-summary__content{display:block!important;width:100%!important}
/* Order summary items: hide metadata + redundant in-column price */
.wc-block-components-order-summary-item .wc-block-components-product-metadata,
.wc-block-components-order-summary-item .wc-block-cart-item__prices{display:none!important}
/* Row layout */
.wc-block-components-order-summary-item{
  display:flex!important;flex-direction:row!important;
  align-items:flex-start!important;gap:10px!important;width:100%!important
}
/* Small image */
.wc-block-components-order-summary-item__image{flex:0 0 44px!important;width:44px!important}
.wc-block-components-order-summary-item__image img{
  width:44px!important;height:44px!important;object-fit:cover;
  border-radius:8px;border:1px solid var(--line);display:block!important
}
/* Description column — block, zero out WC's 24px+12px internal padding */
.wc-block-components-order-summary-item__description{
  flex:1 1 0!important;min-width:0!important;
  display:block!important;overflow:hidden!important;
  padding:0!important
}
/* WC Blocks checkout.css sets max-width:max-content which shrinks the name —
   override with double-class specificity to win the cascade */
.wc-block-components-order-summary-item .wc-block-components-product-name,
.wp-block-woocommerce-checkout-order-summary-block .wc-block-components-product-name,
.wc-block-checkout__sidebar .wc-block-components-product-name{
  font-family:var(--font-display)!important;font-size:.82rem!important;font-weight:600!important;
  color:var(--ink)!important;line-height:1.35!important;
  white-space:normal!important;overflow-wrap:anywhere!important;
  display:block!important;width:100%!important;max-width:100%!important
}
/* Total price pinned right, no wrap */
.wc-block-components-order-summary-item__total-price{flex:0 0 auto!important}
.wc-block-components-order-summary-item__total-price .wc-block-components-product-price__value,
.wc-block-components-order-summary-item__total-price bdi{
  font-family:var(--font-display)!important;font-size:.85rem!important;font-weight:600!important;
  color:var(--ink)!important;white-space:nowrap!important
}

/* ── WC notices & address card ────────────────�
/* ── Free shipping progress bar ─────────────────────────────── */
.mt-fsb{
  padding:14px 16px 12px;margin-bottom:4px;
  background:var(--bg);border-radius:12px;
  border:1px solid var(--line)
}
.mt-fsb-msg{
  font-family:var(--font-display);font-size:.78rem;color:var(--soft);
  margin-bottom:8px;line-height:1.4
}
.mt-fsb-msg strong{color:var(--ink)}
.mt-fsb-msg.mt-fsb-done{color:var(--ink);display:flex;align-items:center;gap:6px}
.mt-fsb-msg.mt-fsb-done svg{flex-shrink:0;color:var(--dark)}
.mt-fsb-track{
  height:5px;background:var(--line);border-radius:100px;overflow:hidden
}
.mt-fsb-fill{
  height:100%;background:var(--dark);border-radius:100px;
  transition:width .5s cubic-bezier(.4,0,.2,1)
}

/* ── Checkout / Cart simplified header ──────────────────────── */
/* Hide announcement bar, nav drawer, burger, search, actions */
.woocommerce-checkout .announce,
.woocommerce-cart .announce,
.woocommerce-checkout .nav-links,
.woocommerce-cart .nav-links,
.woocommerce-checkout .nav-burger,
.woocommerce-cart .nav-burger,
.woocommerce-checkout .nav-topsearch,
.woocommerce-cart .nav-topsearch,
.woocommerce-checkout .nav-actions,
.woocommerce-cart .nav-actions,
.woocommerce-checkout .nav-toggle,
.woocommerce-cart .nav-toggle,
.woocommerce-checkout .nav-overlay,
.woocommerce-cart .nav-overlay{
  display:none!important
}
/* Topbar wrap: logo left, label right */
.woocommerce-checkout .nav-topbar .wrap,
.woocommerce-cart .nav-topbar .wrap{
  display:flex!important;align-items:center!important;
  justify-content:space-between!important
}
/* "Checkout" / "Cart" label top-right via pseudo */
.woocommerce-checkout .nav-topbar .wrap::after{
  content:"Checkout";
  font-family:var(--font-display);font-size:1rem;font-weight:500;
  color:var(--ink);letter-spacing:.01em
}
.woocommerce-cart .nav-topbar .wrap::after{
  content:"Cart";
  font-family:var(--font-display);font-size:1rem;font-weight:500;
  color:var(--ink);letter-spacing:.01em
}
/* Keep logo link visible */
.woocommerce-checkout .nav-topbar .logo,
.woocommerce-cart .nav-topbar .logo{display:block!important}

/* ── Fix: radio button overlapping shipping label ────────────── */
/* Ensure input renders inline, not absolutely positioned */
.wc-block-components-radio-control__option input[type="radio"],
.wc-block-components-radio-control__input{
  position:relative!important;top:0!important;flex-shrink:0!important;
  width:18px!important;height:18px!important;margin:0!important;
  align-self:center!important;cursor:pointer!important;accent-color:var(--dark)
}
/* Label group gets a small left nudge away from the radio circle */
.wc-block-components-radio-control__label-group{
  padding-left:4px!important
}
/* Price label on the right */
.wc-block-components-radio-control__secondary-label{
  margin-left:auto!important;white-space:nowrap!important;
  font-size:.875rem!important;color:var(--ink)!important
}

/* ── Mobile: hide order summary accordion on checkout ────────── */
@media(max-width:767px){
  .wc-block-checkout__order-summary,
  .wc-block-checkout__sidebar,
  .wc-block-components-checkout-order-summary,
  .wc-block-components-sidebar-layout__sidebar{
    display:none!important
  }
}
/* ── Remove inner divider lines inside order summary ─────────── */
.wp-block-woocommerce-checkout-order-summary-block{
  border:none!important
}
.wp-block-woocommerce-checkout-order-summary-coupon,
.wp-block-woocommerce-checkout-order-summary-totals,
.wc-block-components-totals-wrapper,
.wc-block-components-panel__button{
  border-top:none!important
}
/* Keep subtle per-item separator but remove last one */
.wc-block-components-order-summary-item{
  border-bottom:1px solid var(--line)!important
}
.wc-block-components-order-summary-item:last-child{
  border-bottom:none!important
}


/* =============================================================
   ORDER CONFIRMATION -- FULL WIDTH RESPONSIVE           ver 7.8
   ============================================================= */

/* -- Hide step progress, remove narrow container ------------- */
.woocommerce-order-received .mt-checkout-steps{display:none!important}
.woocommerce-order-received .entry-content{padding:0}
.woocommerce-order-received .woocommerce-order{
  max-width:none;width:100%;padding:0;margin:0
}
.woocommerce-order-received .woocommerce{padding:0;margin-top:-40px}

/* -- Hero: compact, centered --------------------------------- */
.woocommerce-order-received .woocommerce-notice--success{
  background:none;border:none;box-shadow:none;
  padding:6px 24px 20px!important;text-align:center
}
.mt-oc-stars{
  display:flex;align-items:center;justify-content:center;
  gap:10px;margin-bottom:3px;padding-top:4px
}
.woocommerce-order-received .woocommerce-notice--success::before{
  display:none
}
.woocommerce-order-received .woocommerce-thankyou-order-received{
  font-family:var(--font-display);
  font-size:clamp(1.3rem,2.8vw,1.9rem);
  font-weight:600;letter-spacing:-.022em;line-height:1.08;
  color:var(--dark);display:block;margin:0
}
.woocommerce-order-received .woocommerce-notice--success::after{
  content:"Your ritual is on its way.";display:block;
  font-size:.8rem;color:var(--soft);margin-top:8px;letter-spacing:.01em
}

/* -- Order meta: single-row stat bar, no borders ------------- */
.woocommerce-order-received .woocommerce-order-overview.order_details{
  list-style:none!important;
  display:flex!important;flex-wrap:nowrap!important;flex-direction:row!important;
  gap:0!important;padding:0 24px 24px!important;margin:0 auto!important;
  border:none!important;background:none;
  justify-content:flex-start;max-width:1200px;box-sizing:border-box
}
/* Hide email from stat bar — redundant on confirmation page */
.woocommerce-order-received .woocommerce-order-overview.order_details li.email{
  display:none!important
}
.woocommerce-order-received .woocommerce-order-overview.order_details li{
  flex:1 1 0!important;min-width:0;
  padding:0;
  display:flex!important;flex-direction:column!important;gap:3px;
  border:none!important;width:auto!important;float:none!important
}
.woocommerce-order-received .woocommerce-order-overview.order_details li + li:not(.email){
  border:none!important;margin-left:24px!important
}
/* li itself = label — matches ORDER DETAILS header */
.woocommerce-order-received .woocommerce-order-overview.order_details li{
  font-family:var(--font-mono);font-size:.56rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--soft);font-weight:500;
}
/* strong = VALUE */
.woocommerce-order-received .woocommerce-order-overview.order_details li strong{
  font-family:var(--font-display);font-size:clamp(.8rem,1.6vw,.95rem);
  letter-spacing:-.01em;text-transform:none;color:var(--dark);
  font-weight:600;white-space:nowrap;display:block;margin-top:2px
}
/* Links/time/price inside strong inherit strong styling */
.woocommerce-order-received .woocommerce-order-overview.order_details li strong a,
.woocommerce-order-received .woocommerce-order-overview.order_details li strong time,
.woocommerce-order-received .woocommerce-order-overview.order_details li strong .woocommerce-Price-amount{
  font-family:inherit;font-size:inherit;font-weight:inherit;
  color:inherit;text-decoration:none;white-space:nowrap
}

/* -- Main body: 2-column grid -------------------------------- */
.woocommerce-order-received .mt-oc-body-grid{
  display:grid;
  grid-template-columns:1fr 300px;
  gap:0;
  max-width:1200px;margin:0 auto
}

/* Order details: left col */
.woocommerce-order-details{
  padding:24px 32px 32px 24px;
  border:none!important;box-shadow:none!important;background:none!important
}
.woocommerce-order-details__title{
  font-family:var(--font-mono);font-size:.56rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--soft);font-weight:500;
  padding-bottom:10px;margin-bottom:0;border:none
}
.woocommerce-table.woocommerce-table--order-details{
  width:100%;border-collapse:collapse;font-size:.84rem
}
.woocommerce-table--order-details thead tr th{
  font-family:var(--font-mono);font-size:.54rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--soft);font-weight:500;
  padding:10px 0;border:none!important;text-align:left
}
.woocommerce-table--order-details thead tr th:last-child{text-align:right}
.woocommerce-table--order-details tbody tr td{
  padding:11px 0;border:none!important;
  box-shadow:0 1px 0 rgba(80,78,78,.11)!important;
  color:var(--ink);font-size:.84rem
}
.woocommerce-table--order-details tbody tr td.product-total{
  text-align:right;color:var(--dark);font-weight:500
}
.woocommerce-table--order-details tfoot tr th,
.woocommerce-table--order-details tfoot tr td{
  padding:8px 0;border:none!important;
  box-shadow:0 1px 0 rgba(80,78,78,.11)!important;
  color:var(--soft);font-size:.8rem
}
.woocommerce-table--order-details tfoot tr td{text-align:right;color:var(--ink)}
.woocommerce-table--order-details tfoot tr:last-child th,
.woocommerce-table--order-details tfoot tr:last-child td{
  border:none!important;border-bottom:none!important;
  border-top:1px solid var(--ink)!important;
  box-shadow:none!important;
  padding-top:14px;
  font-family:var(--font-display);font-size:.94rem;
  font-weight:700;color:var(--dark)
}

/* Hide email icon ::before in customer details */
.woocommerce-customer-details--email::before{
  display:none!important
}
/* Hide email icon in customer details */
.woocommerce-customer-details address .email::before,
.woocommerce-customer-details .email-address::before,
.woocommerce-customer-details address a[href^="mailto"] .icon,
.woocommerce-customer-details .woocommerce-customer-details--email .woocommerce-icon{
  display:none!important
}
.woocommerce-customer-details .woocommerce-customer-details--email{
  list-style:none!important;padding-left:0!important
}

/* Customer details: right col */
.woocommerce-customer-details{
  padding:24px 24px 32px;background:none
}
.woocommerce-columns--addresses{
  display:block;
  padding:0!important;margin:0!important;overflow:hidden
}
.woocommerce-order-received .woocommerce-columns--addresses .col-1,
.woocommerce-order-received .woocommerce-columns--addresses .col-2{
  margin-bottom:24px
}
.woocommerce-order-received .woocommerce-columns--addresses .col-2{
  margin-bottom:0
}
.woocommerce-column__title{
  font-family:var(--font-mono);font-size:.56rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--soft);font-weight:500;
  border:none!important;padding-bottom:10px;margin:0 0 8px;display:block
}
.woocommerce-customer-details address,
.woocommerce-order-received .woocommerce-column address{
  font-style:normal;font-size:.82rem;line-height:1.7;color:var(--ink);
  border:none!important;background:none!important;
  border-radius:0!important;padding:0!important;
  box-shadow:none!important;margin:0!important
}
/* Kill WC default column/address box + fix float-based width */
.woocommerce-order-received .woocommerce-column,
.woocommerce-order-received .woocommerce-column--billing,
.woocommerce-order-received .woocommerce-column--shipping,
.woocommerce-order-received .woocommerce-column--billing-address,
.woocommerce-order-received .woocommerce-column--shipping-address,
.woocommerce-order-received .woocommerce-columns--addresses .col-1,
.woocommerce-order-received .woocommerce-columns--addresses .col-2{
  border:none!important;background:none!important;
  padding:0!important;box-shadow:none!important;
  float:none!important;width:100%!important;max-width:none!important
}

/* -- "Complete Your Ritual" ---------------------------------- */
.mt-oc-ritual{
  padding:48px 24px 0;
  max-width:1200px;margin:0 auto
}
.mt-oc-ritual-header{
  display:flex;flex-direction:column;align-items:flex-start;
  margin-bottom:24px;gap:6px
}
.mt-oc-ritual-header-text{}
.mt-oc-eyebrow{
  font-family:var(--font-mono);font-size:.56rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--soft);display:block;margin-bottom:6px
}
.mt-oc-title{
  font-family:var(--font-display);font-size:clamp(1.1rem,2vw,1.5rem);
  letter-spacing:-.02em;font-weight:600;color:var(--dark);
  line-height:1.1;margin:0
}
.mt-oc-sub{display:none}
.mt-oc-shop-link{
  display:block;width:fit-content;
  margin:28px auto 0;
  font-size:.78rem;padding:9px 24px
}
.mt-oc-products{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:0
}
.mt-oc-card{
  text-decoration:none;border-radius:12px;overflow:hidden;background:none;
  border:1px solid var(--line);
  display:flex;flex-direction:column;
  transition:transform .3s cubic-bezier(.2,.7,.3,1),box-shadow .3s
}
.mt-oc-card:hover{transform:translateY(-4px);box-shadow:var(--glow)}
.mt-oc-card-img{aspect-ratio:1;overflow:hidden;flex-shrink:0}
.mt-oc-card-img img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .5s cubic-bezier(.2,.7,.3,1)
}
.mt-oc-card:hover .mt-oc-card-img img{transform:scale(1.04)}
.mt-oc-card-meta{
  padding:12px 14px 14px;display:flex;
  justify-content:space-between;align-items:flex-end;gap:8px
}
.mt-oc-card-name{
  font-family:var(--font-display);font-size:.8rem;
  font-weight:500;color:var(--dark);line-height:1.3
}
.mt-oc-card-price{
  font-size:.76rem;color:var(--soft);white-space:nowrap;flex-shrink:0
}

/* -- Newsletter band ----------------------------------------- */
.mt-oc-newsletter{
  background:var(--dark);
  padding:48px 32px;text-align:center;
  margin-top:40px;
  border-radius:20px;
  max-width:1200px;margin-left:auto;margin-right:auto
}
.mt-oc-nl-title{
  font-family:var(--font-display);
  font-size:clamp(1.1rem,2.2vw,1.5rem);
  letter-spacing:-.02em;font-weight:600;
  color:var(--bg);line-height:1.1;margin:0 0 8px
}
.mt-oc-nl-sub{
  color:var(--dark-soft);font-size:.82rem;line-height:1.6;
  max-width:44ch;margin:0 auto 20px
}
.mt-oc-nl-form{
  display:flex;gap:8px;max-width:380px;margin:0 auto
}
.mt-oc-nl-input{
  flex:1;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);border-radius:999px;
  padding:10px 18px;font-family:var(--font-body);font-size:.84rem;
  color:var(--bg);outline:none;transition:border-color .2s;min-width:0
}
.mt-oc-nl-input::placeholder{color:var(--dark-soft)}
.mt-oc-nl-input:focus{border-color:rgba(255,255,255,.38)}
.mt-oc-nl-btn{
  background:var(--bg);color:var(--dark);border:none;
  border-radius:999px;padding:10px 22px;font-family:var(--font-body);
  font-size:.82rem;font-weight:600;cursor:pointer;white-space:nowrap;
  transition:opacity .2s
}
.mt-oc-nl-btn:hover{opacity:.85}
.mt-oc-nl-note{
  display:block;font-size:.68rem;color:var(--dark-soft);
  margin-top:12px;letter-spacing:.04em
}

/* Strip all WC default table borders on order-received */
.woocommerce-order-received .woocommerce-table,
.woocommerce-order-received .woocommerce-table td,
.woocommerce-order-received .woocommerce-table th,
.woocommerce-order-received .woocommerce-table tr,
.woocommerce-order-received table.shop_table,
.woocommerce-order-received table.shop_table td,
.woocommerce-order-received table.shop_table th,
.woocommerce-order-received table.shop_table tr,
.woocommerce-order-received table.shop_table tfoot,
.woocommerce-order-received table.shop_table tbody,
.woocommerce-order-received table.shop_table thead{
  border:none!important
}
/* Strip section-level border from order details */
.woocommerce-order-received section.woocommerce-order-details,
.woocommerce-order-received .woocommerce-order-details{
  border:none!important;background:none!important;box-shadow:none!important
}

/* -- Restore full nav on confirmation page ------------------- */
.woocommerce-order-received .announce{display:block!important}
.woocommerce-order-received .nav-links{display:flex!important}
.woocommerce-order-received .nav-topsearch{display:flex!important}
.woocommerce-order-received .nav-actions{display:flex!important}
.woocommerce-order-received .nav-burger{display:none!important}
.woocommerce-order-received .nav-toggle{display:none!important}
.woocommerce-order-received .nav-topbar .wrap{
  display:flex!important;align-items:center!important;
  gap:16px!important;height:70px!important;justify-content:initial!important
}
.woocommerce-order-received .nav-topbar .wrap::after{content:none!important}

/* -- Mobile-first: stack to single column -------------------- */
@media(max-width:767px){
  .woocommerce-order-received .woocommerce-notice--success{
    padding:28px 16px 16px
  }
  .woocommerce-order-overview.order_details{
    flex-wrap:wrap;justify-content:flex-start;padding:0 16px 16px!important
  }
  .woocommerce-order-overview.order_details li{
    flex:1 1 45%;padding:0 0 14px
  }
  .woocommerce-order-overview.order_details li + li{
    border-left:none!important
  }
  .woocommerce-order-overview.order_details li.method{
    flex:1 1 100%
  }
  .woocommerce-order-received .mt-oc-body-grid{
    grid-template-columns:1fr
  }
  .woocommerce-order-received .woocommerce-customer-details{order:-1}
  .woocommerce-order-received .woocommerce-order-details{order:1}
  .woocommerce-order-details{
    padding:20px 16px
  }
  .woocommerce-customer-details{padding:24px 0;margin-bottom:0!important}
  .woocommerce-columns--addresses{
    display:flex!important;flex-direction:row;gap:16px
  }
  .woocommerce-order-received .woocommerce-columns--addresses .col-1,
  .woocommerce-order-received .woocommerce-columns--addresses .col-2{
    flex:1 1 0!important;width:auto!important;min-width:0;margin-bottom:0!important
  }
  .mt-oc-ritual{padding:32px 16px 0}
  .mt-oc-ritual-header{flex-direction:column;align-items:flex-start;gap:12px}
  .mt-oc-products{grid-template-columns:1fr 1fr;gap:12px}
  .mt-oc-newsletter{padding:32px 20px;margin-top:32px;border-radius:16px}
  .mt-oc-nl-form{flex-direction:column;gap:8px}
  .woocommerce-order-received .nav-burger{display:inline-flex!important}
  .woocommerce-order-received .nav-topsearch{display:none!important}
  .woocommerce-order-received .nav-links{display:none!important}
}

/* =============================================================
   CLASSIC CART + CHECKOUT — Milky Tallow redesign        ver 18
   ============================================================= */

/* Widen the content wrap (page.php caps at 860px inline) */
.woocommerce-cart main .wrap:not(.page-hero),
.woocommerce-checkout main .wrap:not(.page-hero){
  max-width:1200px!important;padding-top:30px!important;padding-bottom:96px!important
}
.woocommerce-cart .entry-content,
.woocommerce-checkout .entry-content{font-size:1rem}

/* Notices — flat, on-brand (kills default green/purple accent bars) */
.woocommerce-cart .woocommerce-info,
.woocommerce-checkout .woocommerce-info,
.woocommerce-cart .woocommerce-message,
.woocommerce-checkout .woocommerce-message,
.woocommerce-cart .woocommerce-error,
.woocommerce-checkout .woocommerce-error{
  background:#FFFDF9!important;border:1px solid var(--line)!important;
  border-radius:12px!important;padding:14px 18px!important;color:var(--ink)!important;
  font-size:.9rem!important;box-shadow:none!important;list-style:none!important;
  display:flex;align-items:center;gap:10px;flex-wrap:wrap
}
.woocommerce-cart .woocommerce-info::before,
.woocommerce-checkout .woocommerce-info::before,
.woocommerce-cart .woocommerce-message::before,
.woocommerce-checkout .woocommerce-message::before,
.woocommerce-cart .woocommerce-error::before,
.woocommerce-checkout .woocommerce-error::before{display:none!important}
.woocommerce-cart .woocommerce-info a,
.woocommerce-checkout .woocommerce-info a{color:var(--amber);font-weight:600}
.woocommerce-checkout .woocommerce-message,
.woocommerce-cart .woocommerce-message{border-left:3px solid var(--amber-soft)!important}

/* ── On-brand WooCommerce notices (site-wide: account, forms, shop, etc.) ─────── */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
ul.woocommerce-error{
  background:#FFFDF9!important;border:1px solid var(--line)!important;border-left-width:3px!important;
  border-radius:12px!important;padding:15px 18px!important;margin:0 0 24px!important;color:var(--ink)!important;
  font-family:var(--font-body)!important;font-size:.92rem!important;line-height:1.55!important;
  box-shadow:none!important;list-style:none!important;display:flex!important;align-items:flex-start!important;gap:11px!important;
  text-transform:none!important;letter-spacing:normal!important
}
.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before{
  content:""!important;flex:none;width:20px;height:20px;position:static!important;
  margin:1px 0 0!important;padding:0!important;top:auto;left:auto;color:transparent!important;
  background-repeat:no-repeat;background-position:center;background-size:20px 20px!important;font-size:0
}
/* Success — muted sage */
.woocommerce-message{border-left-color:#7c8a5a!important;background:#f6f7ef!important}
.woocommerce-message::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%237c8a5a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpath d='M8 12.5l2.5 2.5 5-6'/%3E%3C/svg%3E")!important}
/* Info — brand amber */
.woocommerce-info{border-left-color:var(--amber)!important;background:#fdf8ef!important}
.woocommerce-info::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23c98a3a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cline x1='12' y1='16' x2='12' y2='11'/%3E%3Cline x1='12' y1='8' x2='12.01' y2='8'/%3E%3C/svg%3E")!important}
/* Error — terracotta (include ul.* to beat the base group selector's specificity) */
.woocommerce-error,
ul.woocommerce-error{border-left-color:#b4553b!important;background:#fbf1ee!important}
.woocommerce-error::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23b4553b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cline x1='12' y1='8' x2='12' y2='13'/%3E%3Cline x1='12' y1='16.5' x2='12.01' y2='16.5'/%3E%3C/svg%3E")!important}
.woocommerce-message a,.woocommerce-info a,.woocommerce-error a{color:var(--amber)!important;font-weight:600}
.woocommerce-error li{list-style:none!important;margin:0!important;padding:0!important}
.woocommerce-message .button,.woocommerce-info .button,.woocommerce-error .button{margin-left:auto}

/* Newer block notices (checkout/account blocks) */
.wc-block-components-notice-banner{border-radius:12px!important;font-family:var(--font-body)!important;background:#FFFDF9!important;color:var(--ink)!important}
.wc-block-components-notice-banner.is-success{border-color:#7c8a5a!important;background:#f6f7ef!important}
.wc-block-components-notice-banner.is-error{border-color:#b4553b!important;background:#fbf1ee!important}
.wc-block-components-notice-banner.is-info{border-color:var(--amber)!important;background:#fdf8ef!important}
.wc-block-components-notice-banner.is-success svg{fill:#7c8a5a!important}
.wc-block-components-notice-banner.is-error svg{fill:#b4553b!important}
.wc-block-components-notice-banner.is-info svg{fill:#c98a3a!important}

/* ── CART layout ─────────────────────────────────────────────── */
.mt-cart{
  display:grid;grid-template-columns:minmax(0,1fr) 360px;
  gap:clamp(28px,4vw,56px);align-items:start;margin-top:6px
}
.mt-cart-items{min-width:0}
.mt-cart .shop_table.cart{
  width:100%;border-collapse:collapse;background:transparent;border:none;margin:0
}
.mt-cart .shop_table.cart thead th{
  background:transparent;border:none;border-bottom:1px solid var(--line);
  font-family:var(--font-mono);font-size:.66rem;font-weight:600;letter-spacing:.14em;
  text-transform:uppercase;color:var(--soft);text-align:left;padding:0 0 14px
}
.mt-cart .shop_table.cart thead th.product-price,
.mt-cart .shop_table.cart thead th.product-quantity,
.mt-cart .shop_table.cart thead th.product-subtotal{text-align:right}
.mt-cart .shop_table.cart thead th.product-remove,
.mt-cart .shop_table.cart thead th.product-thumbnail{width:0}
.mt-cart .cart_item td{
  background:transparent!important;border:none!important;
  border-bottom:1px solid var(--line-soft)!important;
  padding:20px 0;vertical-align:middle;font-size:.95rem;color:var(--ink)
}
.mt-cart .cart_item td.product-price,
.mt-cart .cart_item td.product-subtotal{text-align:right;white-space:nowrap}
.mt-cart .cart_item td.product-subtotal{font-weight:600}
.mt-cart td.product-remove{width:30px;padding-right:8px}
.mt-cart td.product-remove a.remove{
  display:inline-flex;align-items:center;justify-content:center;
  width:24px;height:24px;border-radius:50%;border:1px solid var(--line);
  color:var(--soft)!important;font-size:18px;line-height:1;text-decoration:none;
  background:transparent!important;transition:all .2s
}
.mt-cart td.product-remove a.remove:hover{
  background:rgba(168,68,61,.1)!important;color:#a8443c!important;border-color:transparent
}
.mt-cart td.product-thumbnail{width:84px;padding-right:18px}
.mt-cart td.product-thumbnail img{
  width:72px;height:72px;object-fit:cover;border-radius:12px;
  background:var(--bg2);display:block
}
.mt-cart td.product-name a{
  font-family:var(--font-display);font-size:1.02rem;font-weight:500;
  color:var(--ink);text-decoration:none;line-height:1.3;transition:color .2s
}
.mt-cart td.product-name a:hover{color:var(--amber)}
.mt-cart .quantity{display:inline-flex;justify-content:flex-end}
.mt-cart .quantity .qty{
  width:64px;height:42px;text-align:center;
  background:#FFFDF9;border:1px solid var(--line);border-radius:10px;
  font-family:var(--font-body);font-size:.95rem;color:var(--ink);
  -moz-appearance:textfield
}
.mt-cart .quantity .qty:focus{outline:none;border-color:var(--ink)}
/* Cart actions row (coupon + update) */
.mt-cart td.actions{
  border:none!important;border-bottom:none!important;background:transparent!important;
  padding:24px 0 0!important
}
.mt-cart td.actions::before,.mt-cart td.actions::after{content:"";display:table}
.mt-cart td.actions .coupon{float:left;display:flex;gap:8px;align-items:center}
.mt-cart td.actions .coupon #coupon_code{
  width:170px;height:46px;background:#FFFDF9;border:1px solid var(--line);
  border-radius:999px;padding:0 18px;font-family:var(--font-body);font-size:.9rem;color:var(--ink)
}
.mt-cart td.actions .coupon #coupon_code:focus{outline:none;border-color:var(--ink)}
.mt-cart td.actions button[name="update_cart"]{float:right}
/* Cart buttons */
.woocommerce-cart .mt-cart button.button,
.woocommerce-cart .mt-cart .coupon button{
  background:transparent;color:var(--ink);border:1px solid var(--ink);
  border-radius:999px;padding:0 26px;height:46px;font-family:var(--font-body);
  font-weight:600;font-size:.86rem;letter-spacing:.02em;cursor:pointer;
  transition:all .25s;text-transform:none
}
.woocommerce-cart .mt-cart button.button:hover,
.woocommerce-cart .mt-cart .coupon button:hover{
  background:var(--ink);color:var(--bg)
}
.woocommerce-cart .mt-cart button[name="update_cart"]:disabled,
.woocommerce-cart .mt-cart button[name="update_cart"][disabled]{opacity:.4;cursor:default}

/* Cart totals card */
.mt-cart-side .cart_totals{
  background:transparent;border:none;border-radius:0;
  padding:0;position:sticky;top:24px;box-shadow:none
}
.mt-cart-side .cart_totals h2{
  font-family:var(--font-display);font-size:1.3rem;font-weight:600;
  letter-spacing:-.01em;color:var(--ink);margin:0 0 18px;padding-bottom:16px;
  border-bottom:1px solid var(--line)
}
.mt-cart-side .cart_totals .shop_table{
  width:100%;border-collapse:collapse;background:transparent;border:none
}
.mt-cart-side .cart_totals .shop_table th,
.mt-cart-side .cart_totals .shop_table td{
  background:transparent!important;border:none!important;
  padding:12px 0;font-size:.92rem;vertical-align:top
}
.mt-cart-side .cart_totals .shop_table tr+tr th,
.mt-cart-side .cart_totals .shop_table tr+tr td{border-top:none!important}
.mt-cart-side .cart_totals th{
  font-family:var(--font-mono);font-size:.68rem;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;color:var(--soft);text-align:left;font-weight:600
}
.mt-cart-side .cart_totals td{text-align:right;color:var(--ink);font-weight:500}
.mt-cart-side .cart_totals .order-total th{color:var(--ink);font-family:var(--font-display);
  font-size:.95rem;letter-spacing:0;text-transform:none}
.mt-cart-side .cart_totals .order-total td{font-size:1.25rem;font-weight:700;font-family:var(--font-display)}
.mt-cart-side .cart_totals .shipping td{font-weight:500}
.mt-cart-side .cart_totals .woocommerce-shipping-destination{font-size:.78rem;color:var(--soft);font-weight:400}
/* Proceed to checkout */
.mt-cart-side .wc-proceed-to-checkout{padding-top:20px}
.woocommerce-cart .mt-cart-side .wc-proceed-to-checkout a.checkout-button{
  display:flex;align-items:center;justify-content:center;width:100%;
  background:var(--ink);color:var(--bg);border:1px solid var(--ink);border-radius:999px;
  padding:16px;font-family:var(--font-body);font-weight:700;font-size:.95rem;
  letter-spacing:.01em;text-decoration:none;transition:all .25s;text-transform:none;margin:0
}
.woocommerce-cart .mt-cart-side .wc-proceed-to-checkout a.checkout-button:hover{
  background:var(--amber);border-color:var(--amber);transform:translateY(-1px)
}
/* Continue shopping — secondary outline button above Proceed to checkout */
.woocommerce-cart .mt-cart-side .wc-proceed-to-checkout a.mt-continue-shopping{
  display:flex;align-items:center;justify-content:center;width:100%;
  background:transparent;color:var(--ink);border:1px solid var(--ink);border-radius:999px;
  padding:15px;font-family:var(--font-body);font-weight:600;font-size:.92rem;letter-spacing:.01em;
  text-decoration:none;margin:0 0 12px;transition:all .25s;text-transform:none
}
.woocommerce-cart .mt-cart-side .wc-proceed-to-checkout a.mt-continue-shopping:hover{
  background:var(--ink);color:var(--bg);transform:translateY(-1px)
}

/* ── CHECKOUT layout ─────────────────────────────────────────── */
.mt-checkout-grid{
  display:grid;grid-template-columns:minmax(0,1fr) 380px;
  gap:clamp(28px,4vw,56px);align-items:start
}
.mt-checkout-main{min-width:0}
.mt-checkout-main #customer_details{display:block}
.mt-checkout-main #customer_details .col-1,
.mt-checkout-main #customer_details .col-2{width:auto;float:none;padding:0;margin:0}
.mt-checkout-main #customer_details .col-2{margin-top:8px}
/* Section headings */
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout .woocommerce-additional-fields h3,
.woocommerce-checkout #order_review_heading{
  font-family:var(--font-display);font-size:1.35rem;font-weight:600;
  letter-spacing:-.01em;color:var(--ink);margin:0 0 18px;padding:0
}
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout .woocommerce-additional-fields h3{
  margin-top:30px;padding-top:26px;border-top:1px solid var(--line-soft)
}
.woocommerce-checkout .woocommerce-additional-fields h3{font-size:1.05rem}
/* Ship-to-different-address toggle row */
.woocommerce-checkout #ship-to-different-address{
  display:flex;align-items:center;gap:10px;font-family:var(--font-display);
  font-size:1.05rem;font-weight:500
}
.woocommerce-checkout #ship-to-different-address label{margin:0;cursor:pointer;font-weight:500}
.woocommerce-checkout #ship-to-different-address-checkbox{width:18px;height:18px;accent-color:var(--amber)}

/* Form fields */
.woocommerce-checkout .form-row{margin:0 0 16px;padding:0}
.woocommerce-checkout .form-row label{
  display:block;font-family:var(--font-mono);font-size:.68rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;color:var(--soft);margin-bottom:7px
}
.woocommerce-checkout .form-row label .required{color:var(--amber);border:none;text-decoration:none}
.woocommerce-checkout .form-row .woocommerce-input-wrapper{width:100%}
.woocommerce-checkout .input-text,
.woocommerce-checkout .form-row input.input-text,
.woocommerce-checkout .form-row textarea,
.woocommerce-checkout .select2-container .select2-selection,
.woocommerce-checkout .form-row select{
  width:100%;background:#FFFDF9;border:1px solid var(--line);border-radius:10px;
  padding:13px 15px;font-family:var(--font-body);font-size:.95rem;color:var(--ink);
  line-height:1.4;box-shadow:none;transition:border-color .2s
}
.woocommerce-checkout .input-text:focus,
.woocommerce-checkout textarea:focus,
.woocommerce-checkout select:focus{outline:none;border-color:var(--ink)}
.woocommerce-checkout .form-row textarea{min-height:96px;resize:vertical}
/* select2 polish */
.woocommerce-checkout .select2-container--default .select2-selection--single{height:auto!important;display:flex;align-items:center}
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered{padding:0;color:var(--ink);line-height:1.4}
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow{top:50%;transform:translateY(-50%);right:10px}
/* Two-up rows */
.woocommerce-checkout .form-row-first,
.woocommerce-checkout .form-row-last{width:calc(50% - 8px);float:none;display:inline-block;vertical-align:top}
.woocommerce-checkout .form-row-first{margin-right:14px}
@media(max-width:480px){
  .woocommerce-checkout .form-row-first,
  .woocommerce-checkout .form-row-last{width:100%;margin-right:0;display:block}
}

/* Checkout — predictive address search */
.woocommerce-checkout .mt-co-addr{margin:0 0 26px;padding-bottom:24px;border-bottom:1px solid var(--line-soft)}
.woocommerce-checkout .mt-co-addr label{
  display:block;font-family:var(--font-mono);font-size:.68rem;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;color:var(--soft);margin-bottom:7px
}
.woocommerce-checkout .mt-co-input-wrap{position:relative;display:block}
.woocommerce-checkout .mt-co-suggest{
  position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:40;background:#fff;
  border:1px solid var(--line);border-radius:10px;box-shadow:0 14px 36px -14px rgba(46,51,61,.28);
  overflow:hidden;max-height:260px;overflow-y:auto;text-align:left
}
.woocommerce-checkout .mt-co-opt{
  padding:11px 15px;font-size:.92rem;color:var(--ink);cursor:pointer;border-bottom:1px solid var(--line-soft);line-height:1.4
}
.woocommerce-checkout .mt-co-opt:last-child{border-bottom:none}
.woocommerce-checkout .mt-co-opt:hover{background:var(--bg2)}
.woocommerce-checkout .mt-co-hint{display:block;margin-top:8px;font-size:.74rem;color:var(--soft);line-height:1.5}
/* Predictive dropdown anchored to the Street Address field */
.woocommerce-checkout #billing_address_1_field,
.woocommerce-checkout .mt-co-addr-field{position:relative}

/* Coupon + login bars before the form */
.woocommerce-checkout .woocommerce-form-coupon-toggle{margin-bottom:18px}
.woocommerce-checkout form.checkout_coupon,
.woocommerce-checkout form.login{
  background:#FFFDF9;border:1px solid var(--line);border-radius:14px;
  padding:22px 24px;margin-bottom:22px
}
.woocommerce-checkout form.checkout_coupon .button,
.woocommerce-checkout form.login .button{
  background:var(--ink);color:var(--bg);border:1px solid var(--ink);border-radius:999px;
  padding:0 24px;height:46px;font-weight:600;font-size:.86rem;cursor:pointer;text-transform:none;transition:all .25s
}
.woocommerce-checkout form.checkout_coupon .button:hover,
.woocommerce-checkout form.login .button:hover{background:var(--amber);border-color:var(--amber)}

/* Order summary card (aside) */
.mt-checkout-aside{min-width:0}
.mt-checkout-aside #order_review_heading{margin-bottom:16px}
/* Order summary — borderless, flex rows (values right-aligned) */
.mt-checkout-aside #order_review{
  background:transparent;border:none;border-radius:0;padding:0;position:sticky;top:24px;box-shadow:none
}
.mt-checkout-aside .shop_table,
.mt-checkout-aside .shop_table thead,
.mt-checkout-aside .shop_table tbody,
.mt-checkout-aside .shop_table tfoot{display:block;width:100%;border:none;background:transparent}
.mt-checkout-aside .shop_table tr{display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.mt-checkout-aside .shop_table th,
.mt-checkout-aside .shop_table td{
  display:block;padding:0!important;border:none!important;background:transparent!important;font-size:.9rem
}
.mt-checkout-aside .shop_table td::before{content:none!important;display:none!important}
.mt-checkout-aside .shop_table thead tr{border-bottom:1px solid var(--line);padding-bottom:14px;margin-bottom:4px}
.mt-checkout-aside .shop_table thead th{
  font-family:var(--font-mono);font-size:.66rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--soft)
}
.mt-checkout-aside .shop_table tbody .cart_item{padding:13px 0;border-bottom:1px solid var(--line-soft)}
.mt-checkout-aside .shop_table .product-name{flex:1;text-align:left;font-family:var(--font-display);font-weight:500;color:var(--ink)}
.mt-checkout-aside .shop_table .product-quantity{color:var(--soft);font-weight:400}
.mt-checkout-aside .shop_table .product-total{flex:0 0 auto;text-align:right;font-weight:600;white-space:nowrap;color:var(--ink)}
.mt-checkout-aside .shop_table tfoot tr{padding:12px 0;border-top:1px solid var(--line-soft)}
.mt-checkout-aside .shop_table tfoot th{
  flex:0 0 auto;font-family:var(--font-mono);font-size:.68rem;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;color:var(--soft);text-align:left
}
.mt-checkout-aside .shop_table tfoot td{flex:1;text-align:right;color:var(--ink);font-weight:500;min-width:0}
.mt-checkout-aside .shop_table tfoot tr.order-total th{
  font-family:var(--font-display);font-size:.98rem;letter-spacing:0;text-transform:none;color:var(--ink)
}
.mt-checkout-aside .shop_table tfoot tr.order-total td{
  font-family:var(--font-display);font-size:1.3rem;font-weight:700
}
.mt-checkout-aside .shop_table tfoot tr.fee th,
.mt-checkout-aside .shop_table tfoot tr.fee td{color:#1f7a3d}
/* Force-remove the all-around border boxes (WC table + Stripe fieldsets) */
.mt-checkout-aside table.shop_table,
.woocommerce-checkout .mt-checkout-aside table.shop_table{border:none!important;border-radius:0!important;box-shadow:none!important}
.woocommerce-checkout #payment fieldset,
.woocommerce-checkout #payment .wc-payment-form,
.woocommerce-checkout #payment .wc-upe-form,
.woocommerce-checkout #payment .payment_box fieldset{
  border:none!important;padding:0!important;margin:0!important;box-shadow:none!important;background:transparent!important
}

/* Redemption box inside the summary card */
.mt-checkout-aside .mt-redeem{margin:18px 0}

/* Payment box */
.woocommerce-checkout #payment{background:transparent!important;border:none!important;border-radius:0;margin-top:22px;padding-top:22px;border-top:1px solid var(--line)!important}
.woocommerce-checkout #payment ul.payment_methods{border:none!important;padding:0!important;margin:0 0 8px!important;list-style:none}
.woocommerce-checkout #payment ul.payment_methods li{margin:0 0 8px;padding:0;background:transparent}
.woocommerce-checkout #payment ul.payment_methods li label{
  display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);
  font-weight:600;font-size:.92rem;color:var(--ink);margin:0;letter-spacing:0;text-transform:none
}
.woocommerce-checkout #payment ul.payment_methods li input[type="radio"]{width:17px;height:17px;accent-color:var(--amber);margin-right:2px}
.woocommerce-checkout #payment .payment_box{
  background:transparent!important;border:none!important;border-radius:0!important;
  margin:6px 0 0!important;padding:8px 0 0!important;font-size:.86rem;color:var(--soft);box-shadow:none!important
}
.woocommerce-checkout #payment .payment_box::before{display:none!important}
.woocommerce-checkout #payment .wc-terms-and-conditions{font-size:.8rem;color:var(--soft)}
.woocommerce-checkout #payment .place-order{padding:6px 0 0!important;margin:0}
.woocommerce-checkout #payment .woocommerce-privacy-policy-text{
  margin:4px 0 22px!important;font-size:.8rem;color:var(--soft);line-height:1.6
}
.woocommerce-checkout #payment .woocommerce-privacy-policy-text p{margin:0!important}
.woocommerce-checkout #place_order{
  display:block;width:100%;background:var(--ink)!important;color:var(--bg)!important;
  border:1px solid var(--ink)!important;border-radius:999px!important;padding:17px!important;
  font-family:var(--font-body)!important;font-weight:700!important;font-size:.98rem!important;
  letter-spacing:.01em;cursor:pointer;transition:all .25s!important;text-transform:none!important;float:none!important
}
.woocommerce-checkout #place_order:hover{background:var(--amber)!important;border-color:var(--amber)!important;transform:translateY(-1px)}

/* ── Responsive: stack to single column ──────────────────────── */
@media(max-width:900px){
  .mt-cart,.mt-checkout-grid{grid-template-columns:1fr}
  .mt-cart-side .cart_totals,
  .mt-checkout-aside #order_review{position:static}
  .mt-checkout-aside{margin-top:8px}
}
@media(max-width:600px){
  .mt-cart .shop_table.cart thead{display:none}
  .mt-cart .cart_item{display:grid;grid-template-columns:72px 1fr;gap:4px 16px;
    padding:18px 0;border-bottom:1px solid var(--line-soft)}
  .mt-cart .cart_item td{border:none!important;padding:2px 0!important;text-align:left!important}
  .mt-cart .cart_item td.product-thumbnail{grid-row:1 / span 4;width:72px}
  .mt-cart .cart_item td.product-remove{position:absolute;right:0}
  .mt-cart .cart_item td.product-price::before,
  .mt-cart .cart_item td.product-quantity::before,
  .mt-cart .cart_item td.product-subtotal::before{
    content:attr(data-title) ": ";font-family:var(--font-mono);font-size:.62rem;
    letter-spacing:.1em;text-transform:uppercase;color:var(--soft);margin-right:6px
  }
  .mt-cart .quantity{justify-content:flex-start}
  .mt-cart td.actions .coupon,
  .mt-cart td.actions button[name="update_cart"]{float:none;width:100%}
  .mt-cart td.actions .coupon{margin-bottom:10px}
  .mt-cart td.actions .coupon #coupon_code{flex:1}
}

/* Cart totals — force full width (WC floats it narrow by default) (ver 18.1) */
.mt-cart-side.cart-collaterals,
.mt-cart-side .cross-sells{width:100%!important;float:none!important}
.mt-cart-side .cart_totals{width:100%!important;float:none!important}
.mt-cart-side .cart_totals .shop_table,
.mt-cart-side .cart_totals .shop_table tbody{display:block;width:100%!important}
.mt-cart-side .cart_totals .shop_table tr{
  display:flex;justify-content:space-between;align-items:baseline;gap:14px;
  padding:13px 0;border-top:1px solid var(--line-soft)
}
.mt-cart-side .cart_totals .shop_table tr:first-child{border-top:none}
.mt-cart-side .cart_totals .shop_table th,
.mt-cart-side .cart_totals .shop_table td{
  display:block;padding:0!important;border:none!important;background:transparent!important
}
.mt-cart-side .cart_totals .shop_table th{flex:0 0 auto;text-align:left;white-space:normal}
.mt-cart-side .cart_totals .shop_table td{flex:1;text-align:right;min-width:0}
/* Kill WooCommerce mobile responsive data-title labels (they duplicated our labels) */
.mt-cart-side .cart_totals .shop_table td::before{content:none!important;display:none!important}
/* Keep the divider line above the shipment block (between Subtotal and Shipment) */
.mt-cart-side .cart_totals .woocommerce-shipping-totals{border-top:1px solid var(--line-soft)!important}
/* Reward points redemption row — proper pill button */
.mt-cart-side .cart_totals .mt-cart-redeem{align-items:center}
.mt-cart-side .cart_totals .mt-cart-redeem td{text-align:right;display:flex;align-items:center;justify-content:flex-end;gap:10px}
.mt-cart-side .cart_totals a.mt-cart-redeem-link{
  display:inline-block;background:var(--amber);color:#fff!important;border:1px solid var(--amber);
  border-radius:999px;padding:8px 18px;font-size:.8rem;font-weight:600;letter-spacing:.01em;
  text-decoration:none;white-space:nowrap;transition:all .2s
}
.mt-cart-side .cart_totals a.mt-cart-redeem-link:hover{background:var(--ink);border-color:var(--ink);color:#fff!important}
.mt-cart-side .cart_totals .mt-cart-redeem-on{color:#1f7a3d;font-weight:600;font-size:.85rem}
/* Shipment row — stacked + centered in the white card (ver 19.4) */
.mt-cart-side .cart_totals .woocommerce-shipping-totals{flex-direction:column;align-items:stretch;text-align:center}
.mt-cart-side .cart_totals .woocommerce-shipping-totals th{text-align:left;margin-bottom:10px}
.mt-cart-side .cart_totals .woocommerce-shipping-totals td{flex:none;width:100%;text-align:center}
.mt-cart-side .cart_totals #shipping_method{list-style:none;margin:0;padding:0;text-align:center}
.mt-cart-side .cart_totals #shipping_method li{
  display:flex;align-items:center;justify-content:center;gap:9px;margin:0 0 7px;
  font-size:.95rem;color:var(--ink);font-weight:500;line-height:1.35
}
.mt-cart-side .cart_totals #shipping_method li:last-child{margin-bottom:0}
.mt-cart-side .cart_totals #shipping_method li input[type="radio"]{
  width:17px;height:17px;accent-color:var(--amber);margin:0;flex:0 0 auto;order:-1
}
.mt-cart-side .cart_totals #shipping_method li label{margin:0;font-weight:500}
.mt-cart-side .cart_totals #shipping_method .woocommerce-Price-amount,
.mt-cart-side .cart_totals #shipping_method bdi{font-weight:600;white-space:nowrap}
.mt-cart-side .cart_totals .woocommerce-shipping-destination{
  display:block;margin-top:12px;font-size:.92rem;color:var(--ink);line-height:1.6;text-align:center
}
.mt-cart-side .cart_totals .woocommerce-shipping-destination strong{color:var(--ink);font-weight:600}
.mt-cart-side .cart_totals .shipping-calculator-button{
  display:inline-block;margin-top:8px;color:var(--amber);font-size:.9rem;font-weight:600;text-decoration:underline
}
/* "Change address" — text only, remove WooCommerce truck/cart icon */
.woocommerce-cart .shipping-calculator-button::after,
.woocommerce-cart .shipping-calculator-button::before{content:none!important;display:none!important;background:none!important}
/* "Change address" shipping calculator — branded form (ver 19.0) */
.woocommerce-cart .shipping-calculator-form{
  margin-top:14px;padding:0!important;text-align:center;width:100%;margin-left:0
}
.woocommerce-cart .shipping-calculator-form .form-row{margin:0 0 13px;padding:0}
.woocommerce-cart .shipping-calculator-form label{
  display:block;font-family:var(--font-mono);font-size:.64rem;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;color:var(--soft);margin-bottom:6px;text-align:center
}
/* Manual fields stay left-aligned for usability */
.woocommerce-cart .mt-ship-fields,
.woocommerce-cart .mt-ship-fields label{text-align:left}
.woocommerce-cart .shipping-calculator-form label .required,
.woocommerce-cart .shipping-calculator-form label abbr{color:var(--amber);border:none;text-decoration:none}
.woocommerce-cart .shipping-calculator-form .input-text,
.woocommerce-cart .shipping-calculator-form input.input-text,
.woocommerce-cart .shipping-calculator-form select,
.woocommerce-cart .shipping-calculator-form .select2-container .select2-selection{
  width:100%;background:#fff;border:1px solid var(--line);border-radius:10px;
  padding:11px 14px;font-family:var(--font-body);font-size:.92rem;color:var(--ink);
  line-height:1.4;box-shadow:none;transition:border-color .2s;box-sizing:border-box
}
.woocommerce-cart .shipping-calculator-form .input-text:focus,
.woocommerce-cart .shipping-calculator-form select:focus{outline:none;border-color:var(--ink)}
/* select2 polish inside the calculator */
.woocommerce-cart .shipping-calculator-form .select2-container--default .select2-selection--single{height:auto!important;display:flex;align-items:center}
.woocommerce-cart .shipping-calculator-form .select2-container--default .select2-selection--single .select2-selection__rendered{padding:0;color:var(--ink);line-height:1.4}
.woocommerce-cart .shipping-calculator-form .select2-container--default .select2-selection--single .select2-selection__arrow{top:50%;transform:translateY(-50%);right:12px}
/* Update button — brand pill, full width */
.woocommerce-cart .shipping-calculator-form button[name="calc_shipping"],
.woocommerce-cart .shipping-calculator-form .button{
  width:100%;background:var(--ink)!important;color:var(--bg)!important;border:1px solid var(--ink)!important;
  border-radius:999px!important;padding:13px!important;font-family:var(--font-body)!important;
  font-weight:700!important;font-size:.9rem!important;letter-spacing:.01em;cursor:pointer;
  transition:all .25s!important;text-transform:none!important;margin-top:4px
}
.woocommerce-cart .shipping-calculator-form button[name="calc_shipping"]:hover,
.woocommerce-cart .shipping-calculator-form .button:hover{background:var(--amber)!important;border-color:var(--amber)!important}
/* Predictive address search (geolocator) */
.woocommerce-cart .mt-ship-search-row{position:relative;margin-bottom:4px}
.woocommerce-cart .mt-ship-fields{display:none}
.woocommerce-cart .mt-ship-fields.is-visible{display:block;margin-top:8px}
.woocommerce-cart .mt-ship-update{display:none}
.woocommerce-cart .mt-ship-fields.is-visible ~ .mt-ship-update{display:block}
.woocommerce-cart .mt-ship-suggest{
  position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:30;background:#fff;
  border:1px solid var(--line);border-radius:10px;box-shadow:0 14px 36px -14px rgba(46,51,61,.28);
  overflow:hidden;max-height:240px;overflow-y:auto;text-align:left
}
.woocommerce-cart .mt-ship-opt{
  padding:10px 14px;font-size:.9rem;color:var(--ink);cursor:pointer;border-bottom:1px solid var(--line-soft);line-height:1.4
}
.woocommerce-cart .mt-ship-opt:last-child{border-bottom:none}
.woocommerce-cart .mt-ship-opt:hover{background:var(--bg2)}
.woocommerce-cart .mt-ship-resolved{display:block;margin-top:8px;font-size:.9rem;color:var(--ink);font-weight:600}
.woocommerce-cart .mt-ship-hint{display:block;margin-top:8px;font-size:.72rem;color:var(--soft);line-height:1.5}
.woocommerce-cart .mt-ship-manual{display:inline-block;margin-top:8px;background:none!important;border:none!important;padding:0!important;color:var(--amber)!important;font-size:.82rem;font-weight:600;text-decoration:underline;cursor:pointer;font-family:var(--font-body);width:auto!important;border-radius:0!important;letter-spacing:0}
.woocommerce-cart .mt-ship-manual:hover{color:var(--ink)!important;background:none!important;transform:none!important}

/* Empty cart — on-brand (ver 18.8) */
.mt-cart-empty{max-width:600px;margin:8px auto 0;text-align:center}
.mt-cart-empty .eyebrow{display:block;text-align:center;margin-bottom:14px}
.mt-cart-empty h2{
  font-family:var(--font-display);font-size:clamp(1.9rem,4vw,2.7rem);font-weight:600;
  letter-spacing:-.02em;color:var(--ink);margin:0 0 14px;line-height:1.05
}
.mt-cart-empty p{color:var(--soft);font-size:1rem;line-height:1.65;margin:0 auto 30px;max-width:44ch}
.mt-cart-empty-btn{
  display:inline-block;background:var(--ink);color:var(--bg);border:1px solid var(--ink);
  border-radius:999px;padding:15px 36px;font-family:var(--font-body);font-weight:700;
  font-size:.95rem;letter-spacing:.01em;text-decoration:none;transition:all .25s
}
.mt-cart-empty-btn:hover{background:var(--amber);border-color:var(--amber);transform:translateY(-1px)}
.mt-cart-empty-picks{margin-top:60px;border-top:1px solid var(--line-soft);padding-top:40px}
.mt-cart-empty-picks-label{
  display:block;font-family:var(--font-mono);font-size:.7rem;font-weight:500;letter-spacing:.16em;
  text-transform:uppercase;color:var(--amber);margin-bottom:24px
}
.mt-cart-empty-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.mt-cart-empty-card{text-decoration:none;display:flex;flex-direction:column;gap:9px;text-align:left}
.mt-cart-empty-card-img{aspect-ratio:1;border-radius:14px;overflow:hidden;background:var(--bg2);display:block}
.mt-cart-empty-card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s cubic-bezier(.2,.7,.3,1)}
.mt-cart-empty-card:hover .mt-cart-empty-card-img img{transform:scale(1.05)}
.mt-cart-empty-card-name{font-family:var(--font-display);font-size:.95rem;font-weight:500;color:var(--ink);line-height:1.3}
.mt-cart-empty-card-price{font-size:.85rem;color:var(--soft)}
.mt-cart-empty-card-price .woocommerce-Price-amount{color:var(--soft)}
@media(max-width:600px){
  .mt-cart-empty-picks{margin-top:44px;padding-top:30px}
  .mt-cart-empty-grid{grid-template-columns:1fr 1fr;gap:14px}
}

/* Small-screen polish for cart/checkout cards (ver 18.2) */
@media(max-width:600px){
  .woocommerce-cart main .wrap:not(.page-hero),
  .woocommerce-checkout main .wrap:not(.page-hero){padding-left:16px!important;padding-right:16px!important}
  .mt-cart-side .cart_totals,
  .mt-checkout-aside #order_review{padding:0}
  .mt-checkout-aside #order_review_heading,
  .woocommerce-checkout .woocommerce-billing-fields h3{font-size:1.2rem}
  .woocommerce-checkout form.checkout_coupon,
  .woocommerce-checkout form.login{padding:18px}
  .mt-cart-side .cart_totals h2{font-size:1.15rem}
}

/* ── Persistent video hero (ver 21.1) ──────────────────────────────── */
.hero-video-hero{position:relative;overflow:hidden;min-height:88vh;display:flex;align-items:center;padding-top:0!important;padding-bottom:0}
.hero-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center}
.hero-bg-media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transform:none!important;animation:none!important;opacity:1!important}
/* YouTube background embed scaled to cover the hero (16:9 over-sized, centered). */
.hero-bg-yt{pointer-events:none}
.hero-bg-yt iframe{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100vw;height:56.25vw;min-width:177.78vh;min-height:100vh;border:0}
/* Scrim keeps the overlaid text legible over the video. */
.hero-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(100deg,rgba(26,16,7,.74) 0%,rgba(26,16,7,.52) 40%,rgba(26,16,7,.18) 72%,rgba(26,16,7,0) 100%)}
.hero-vh-inner{position:relative;z-index:2;width:100%}
/* Light text for legibility over the video. */
.hero-video-hero .eyebrow{color:rgba(255,255,255,.82)}
.hero-video-hero .mega{color:#fff}
.hero-video-hero .mega .ital{color:#fff}
.hero-video-hero .lede{color:rgba(255,255,255,.92);max-width:46ch}
.hero-video-hero .btn-ghost{color:#fff;border-color:rgba(255,255,255,.55)}
.hero-video-hero .btn-ghost:hover{background:#fff;color:var(--ink);border-color:#fff}
.hero-video-hero .scroll-cue{color:rgba(255,255,255,.8)}
.hero-video-hero .scroll-cue::after{background:linear-gradient(rgba(255,255,255,.9),transparent)}
/* Persistent scroll cue, pinned bottom-left inside the hero. */
.hero-scroll-cue{position:absolute;margin-top:0;z-index:2}
.hero-video-hero .hero-scroll-cue{left:max(24px,calc((100% - 1200px)/2 + 24px));bottom:22px}
@media(max-width:900px){.hero-video-hero{min-height:74vh}}

/* ── Hero image slideshow (used when no hero video) ────────────────── */
.hero-slider{position:relative;flex-direction:column;align-items:stretch;justify-content:center}
.hero-slider .hero-scroll-cue{left:0;bottom:14px}
.hero-slider .hero-img{box-shadow:none;opacity:1!important;animation:none!important}
.hero-slider .hero-img,.hero-slider .hero-img img,.hero-slider .hero-video{transform:none!important}
.hero-slider .hero-img::after{content:none!important;display:none!important}
.hero-slides{display:grid;width:100%}
.hero-slide{grid-area:1/1;opacity:0;visibility:hidden;transition:opacity 1.3s cubic-bezier(.4,0,.2,1),visibility 0s linear 1.3s;pointer-events:none}
.hero-slide.is-active{transition:opacity 1.3s cubic-bezier(.4,0,.2,1),visibility 0s}
.hero-slide.is-active{opacity:1;visibility:visible;pointer-events:auto;z-index:1}
.hero-dots{display:flex;gap:11px;justify-content:center;align-items:center;margin-top:42px;position:relative;z-index:2}
.hero-dot{width:9px;height:9px;border-radius:999px;border:1px solid var(--amber);background:transparent;cursor:pointer;padding:0;transition:transform .3s ease,background .3s ease}
.hero-dot:hover{background:rgba(193,138,74,.4)}
.hero-dot.is-active{background:var(--amber);transform:scale(1.35)}
.hero-arrow{position:absolute;top:42%;transform:translateY(-50%);z-index:3;width:46px;height:46px;border-radius:999px;border:1px solid var(--line);background:rgba(248,244,237,.72);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);cursor:pointer;font-size:1.5rem;line-height:1;color:var(--ink);display:flex;align-items:center;justify-content:center;transition:background .3s ease,color .3s ease,border-color .3s ease}
.hero-arrow:hover{background:var(--amber);color:#fff;border-color:var(--amber)}
/* Arrows sit just outside the content box (in the side margin), brought in from the screen edge. */
.hero-prev{left:-58px}
.hero-next{right:-58px}
@media(max-width:1320px){.hero-prev{left:6px}.hero-next{right:6px}}
@media(max-width:900px){.hero-arrow{display:none}.hero-dots{margin-top:30px}}
@media(prefers-reduced-motion:reduce){.hero-slide{transition:none}}

/* ════════════════════════════════════════════════════════════════════
   SHOP PAGE (ver 22.0) — animated, editorial product experience
   ════════════════════════════════════════════════════════════════════ */
/* Scroll-reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .85s cubic-bezier(.16,1,.3,1),transform .85s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ── Hero ── */
.shop-hero{position:relative;overflow:hidden;text-align:center;padding:clamp(56px,7vw,108px) 0 54px}
.shop-hero .wrap{position:relative;z-index:2;max-width:920px}
.shop-hero .mega{font-size:clamp(2.6rem,7vw,5.6rem);margin:0 auto 26px}
.shop-hero .lede{max-width:62ch;margin:0 auto}
.shop-hero-meta{display:flex;gap:clamp(20px,4vw,52px);justify-content:center;flex-wrap:wrap;margin-top:38px;font-family:var(--font-mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--soft)}
.shop-hero-meta strong{font-family:var(--font-hero);font-style:italic;font-weight:500;font-size:1.5rem;color:var(--amber);margin-right:8px;text-transform:none;letter-spacing:0}
.shop-blob{position:absolute;border-radius:50%;filter:blur(48px);opacity:.55;z-index:0;pointer-events:none}
.shop-blob-1{width:420px;height:420px;top:-120px;left:-90px;background:radial-gradient(circle,rgba(232,216,185,.9),transparent 70%);animation:shopFloat 13s ease-in-out infinite}
.shop-blob-2{width:380px;height:380px;top:-60px;right:-80px;background:radial-gradient(circle,rgba(193,138,74,.28),transparent 70%);animation:shopFloat 16s ease-in-out infinite reverse}
.shop-dot{position:absolute;border-radius:50%;background:var(--amber);opacity:.5;z-index:1;pointer-events:none}
.shop-dot.d1{width:9px;height:9px;top:30%;left:12%;animation:shopFloat 7s ease-in-out infinite}
.shop-dot.d2{width:6px;height:6px;top:60%;right:16%;animation:shopFloat 9s ease-in-out infinite reverse}
.shop-dot.d3{width:12px;height:12px;top:18%;right:26%;background:none;border:1.5px solid var(--amber);opacity:.4;animation:shopFloat 11s ease-in-out infinite}
@keyframes shopFloat{0%,100%{transform:translate(0,0)}50%{transform:translate(0,-26px)}}

/* ── Featured spotlight ── */
.shop-feature{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(28px,4vw,60px);align-items:center;background:var(--bg2);border-radius:calc(var(--radius) + 6px);padding:clamp(22px,3vw,40px);margin:56px 0 12px;box-shadow:var(--glow)}
.shop-feature-media{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3.4;background:var(--bg)}
.shop-feature-media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.1s cubic-bezier(.2,.7,.3,1)}
.shop-feature:hover .shop-feature-media img{transform:scale(1.05)}
.shop-feature-tag{position:absolute;top:16px;left:16px;font-family:var(--font-mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;background:var(--ink);color:#FFF8EE;padding:8px 14px;border-radius:999px}
.shop-feature-body h2{font-size:clamp(1.8rem,3.4vw,2.8rem);margin:8px 0 14px}
.shop-feature-list{list-style:none;margin:18px 0 0;padding:0}
.shop-feature-list li{position:relative;padding:10px 0 10px 26px;border-bottom:1px solid var(--line-soft);color:var(--soft);font-size:.95rem}
.shop-feature-list li:last-child{border-bottom:none}
.shop-feature-list li::before{content:"✦";position:absolute;left:0;top:11px;color:var(--amber);font-size:.78rem}
.shop-feature-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:26px}
/* Match the product-page price styling for consistency. */
.shop-feature-actions .price{font-family:var(--font-mono);font-weight:700;font-size:1.3rem;color:var(--amber);margin-right:4px}
.shop-feature-actions .price small{font-size:.78rem;color:var(--soft);font-weight:400}

/* ── Catalogue category rows (Apple-style header + scrollable rail) ── */
.shop-cat{margin-bottom:clamp(54px,6vw,88px)}
.shop-cat-head{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(20px,4vw,56px);align-items:end;margin:0 0 22px;padding-bottom:22px;border-bottom:1px solid var(--line-soft)}
.shop-cat-head-left{display:flex;flex-direction:column;gap:7px}
.shop-cat-num{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.2em;color:var(--amber)}
.shop-cat-head h3{font-family:var(--font-hero);font-weight:500;font-size:clamp(1.7rem,3vw,2.5rem);letter-spacing:-.015em;line-height:1;color:var(--ink)}
.shop-cat-count{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--soft)}
.shop-cat-head-right p{color:var(--soft);font-size:1rem;line-height:1.75;margin:0 0 16px}
.shop-cat-tags{display:flex;flex-wrap:wrap;gap:8px}
.shop-cat .rail-hint{margin-bottom:2px}
/* Category landing pages */
.cat-hero .chip-row{justify-content:center;margin-top:30px}
.cat-page .rail-hint{margin-top:8px}
/* Clickable mega-menu column headers */
a.drop-head{cursor:pointer;transition:color .2s ease}
a.drop-head:hover{color:var(--amber)}

/* ════════════════════════════════════════════════════════════════════
   INGREDIENTS — the case for tallow
   ════════════════════════════════════════════════════════════════════ */
.tallow-hero{padding:clamp(64px,8vw,116px) 0}
.tallow-hero .mega{font-size:clamp(2.3rem,5.5vw,4.6rem);margin:14px auto 24px}
.tallow-stats{display:flex;gap:clamp(26px,5vw,68px);justify-content:center;flex-wrap:wrap;margin-top:42px}
.tallow-stats div{display:flex;flex-direction:column;gap:3px}
.tallow-stats strong{font-family:var(--font-hero);font-style:italic;font-weight:500;font-size:1.75rem;color:var(--amber);line-height:1}
.tallow-stats span{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--soft)}
.tallow-split{padding:clamp(44px,6vw,84px) 0}
.tallow-split .split .img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--glow);aspect-ratio:1/1;background:var(--bg2)}
.tallow-split .split .img img{width:100%;height:100%;object-fit:cover}
.tallow-split .split .checklist{margin-top:24px}
/* Fatty-acid match chart */
.fa-chart{display:flex;flex-direction:column;gap:20px;margin-top:44px}
.fa-row{display:grid;grid-template-columns:138px 1fr 168px;align-items:center;gap:20px}
.fa-name{font-family:var(--font-display);font-weight:600;font-size:.96rem;color:var(--ink)}
.fa-bar{height:13px;border-radius:999px;background:var(--line-soft);overflow:hidden}
.fa-bar>span{display:block;height:100%;width:0;border-radius:999px;background:var(--grad);transition:width 1.2s cubic-bezier(.16,1,.3,1)}
.fa-chart.in .fa-bar>span{width:var(--w)}
.fa-note{font-family:var(--font-mono);font-size:.64rem;letter-spacing:.08em;text-transform:uppercase;color:var(--soft);text-align:right}
.fa-disclaimer{font-size:.82rem;color:var(--soft);text-align:center;margin:30px auto 0;max-width:62ch;line-height:1.7}
.ingredients-page sup{color:var(--amber);font-size:.62em;font-weight:600;margin-left:1px}
/* ════════════════════════════════════════════════════════════════════
   ROUTINE — product finder quiz (Typeform-like)
   ════════════════════════════════════════════════════════════════════ */
.quiz-section .sec-head{margin-bottom:36px}
.quiz{position:relative;background:var(--bg);border:1px solid var(--line-soft);border-radius:calc(var(--radius) + 6px);padding:clamp(30px,4vw,54px);min-height:340px;box-shadow:var(--glow);overflow:hidden}
.quiz-progress{position:absolute;top:0;left:0;right:0;height:4px;background:var(--line-soft)}
.quiz-progress>span{display:block;height:100%;width:0;background:var(--grad);transition:width .5s cubic-bezier(.16,1,.3,1)}
.quiz-step,.quiz-result{display:none}
.quiz-step.is-active,.quiz-result.is-active{display:block;animation:quizIn .5s cubic-bezier(.16,1,.3,1)}
@keyframes quizIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.quiz-qnum{display:block;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--amber);margin-bottom:14px}
.quiz-q{font-family:var(--font-hero);font-weight:500;font-size:clamp(1.5rem,3.2vw,2.3rem);line-height:1.16;letter-spacing:-.01em;color:var(--ink);margin-bottom:28px}
.quiz-options{display:flex;flex-direction:column;gap:12px}
.quiz-opt{text-align:left;font-family:var(--font-body);font-size:1rem;color:var(--ink);background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:18px 22px;cursor:pointer;transition:border-color .25s ease,background .25s ease,transform .25s ease}
.quiz-opt:hover{border-color:var(--amber);background:#fff;transform:translateX(5px)}
.quiz-back{margin-top:24px;background:none;border:none;color:var(--soft);font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:color .2s ease}
.quiz-back:hover{color:var(--amber)}
.quiz-rcard{display:grid;grid-template-columns:200px 1fr;gap:30px;align-items:center}
.quiz-rimg{border-radius:var(--radius);overflow:hidden;background:var(--bg2);aspect-ratio:1/1}
.quiz-rimg img{width:100%;height:100%;object-fit:cover;display:block}
.quiz-rbody h3{font-size:clamp(1.4rem,2.6vw,2rem);margin:6px 0 8px}
.quiz-rbody .price{font-family:var(--font-mono);font-weight:700;color:var(--amber);font-size:1.15rem;margin-bottom:12px}
.quiz-rbody p{color:var(--soft);margin-bottom:22px}
.quiz-rbody .btn-row{gap:12px;flex-wrap:wrap}
.quiz-runner{margin-top:26px;padding-top:18px;border-top:1px solid var(--line-soft);font-size:.9rem;color:var(--soft)}
.quiz-runner a{color:var(--amber)}
@media(max-width:620px){
  .quiz-rcard{grid-template-columns:1fr;gap:20px}
  .quiz-rimg{max-width:220px}
}

/* ── Upcoming Events ── */
.event-month{font-family:var(--font-hero);font-style:italic;font-weight:500;font-size:clamp(1.4rem,2.6vw,2rem);color:var(--amber);margin:40px 0 18px;padding-bottom:12px;border-bottom:1px solid var(--line-soft)}
.event-month:first-child{margin-top:0}
.event-card{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;background:rgba(255,255,255,.55);border:1px solid var(--line-soft);border-radius:var(--radius);padding:26px 30px;margin-bottom:16px;transition:transform .4s cubic-bezier(.2,.7,.3,1),box-shadow .4s ease,background .3s ease}
.event-card:hover{background:#fff}
.event-card:hover{transform:translateY(-3px);box-shadow:var(--glow)}
.event-main{flex:1;min-width:240px}
.event-main h3{font-size:1.25rem;margin-bottom:14px}
.event-meta{display:flex;flex-wrap:wrap;gap:8px 32px}
.event-meta span{font-size:.92rem;color:var(--soft);display:flex;flex-direction:column;gap:2px}
.event-meta span .event-k{font-family:var(--font-mono);font-size:.72rem;font-weight:500;letter-spacing:.28em;text-transform:uppercase;color:var(--amber);text-decoration:underline;text-underline-offset:4px;text-decoration-thickness:1px;margin-bottom:3px}
.event-map{flex:0 0 auto;white-space:nowrap}
.event-empty{color:var(--soft);font-size:1rem}
.event-empty a{color:var(--amber)}
@media(max-width:560px){.event-card{flex-direction:column;align-items:flex-start}.event-map{width:100%;text-align:center}}

/* Ingredients science figure (full-width diagram) */
.ingredient-figure{margin:0 auto 46px;max-width:760px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--glow);background:var(--bg)}
.ingredient-figure img{width:100%;display:block}
.ingredient-figure.wide{max-width:920px}
.ingredient-figure figcaption{padding:13px 22px;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.05em;text-transform:uppercase;color:var(--soft);text-align:center;border-top:1px solid var(--line-soft);background:var(--bg2)}
.sci-figure{margin:34px auto 8px}

/* Legal-page bullet lists ("term: detail" items, stacked) */
.legal-list{list-style:none;margin:0 0 52px;padding:0}
.legal-list li{position:relative;padding:13px 0 13px 28px;border-bottom:1px solid var(--line-soft);color:var(--soft);line-height:1.7;font-size:.98rem}
.legal-list li:last-child{border-bottom:none}
.legal-list li::before{content:"✦";position:absolute;left:0;top:15px;color:var(--amber);font-size:.72rem}
.legal-list li strong{color:var(--ink)}

/* Small-print science footnotes (inline within the science section) */
.sci-notes{margin-top:36px;padding-top:20px;border-top:1px solid var(--line-soft)}
.sci-foot{font-size:.72rem;line-height:1.75;color:var(--soft);max-width:78ch;margin:0 auto 8px}
.sci-foot em{font-style:italic}
.sci-foot sup{color:var(--amber);font-weight:600}
@media(max-width:680px){
  .fa-row{grid-template-columns:1fr auto;gap:6px 14px}
  .fa-bar{grid-column:1/-1;order:3}
  .fa-note{text-align:left}
}
.shop-cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:28px}

/* ── Catalogue + filter ── */
.shop-catalogue{margin-top:84px}
.shop-filter{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin:0 0 44px}
.shop-filter-btn{font-family:var(--font-mono);font-size:.72rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--soft);background:transparent;border:1px solid var(--line);border-radius:999px;padding:11px 22px;cursor:pointer;transition:all .3s cubic-bezier(.2,.7,.3,1)}
.shop-filter-btn small{opacity:.6;margin-left:5px}
.shop-filter-btn:hover{border-color:var(--amber);color:var(--ink)}
.shop-filter-btn.is-active{background:var(--ink);border-color:var(--ink);color:#FFF8EE}
.shop-filter-btn.is-active small{opacity:.7}
.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:28px}
.shop-grid .product-card{transition:opacity .5s cubic-bezier(.16,1,.3,1),transform .5s cubic-bezier(.16,1,.3,1),box-shadow .4s ease}
.shop-grid .product-card.is-hidden{opacity:0;transform:scale(.93)}
.shop-grid-empty{text-align:center;color:var(--soft);font-family:var(--font-mono);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;padding:40px 0}

/* ── Build your ritual ── */
.shop-ritual{margin-top:96px}
.ritual-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;counter-reset:step}
.ritual-step{position:relative;background:var(--bg);border:1px solid var(--line-soft);border-radius:var(--radius);padding:38px 30px 32px;transition:transform .5s cubic-bezier(.2,.7,.3,1),box-shadow .5s ease}
.ritual-step:hover{transform:translateY(-6px);box-shadow:var(--glow)}
.ritual-n{font-family:var(--font-hero);font-style:italic;font-size:2.6rem;color:var(--amber);opacity:.5;line-height:1;margin-bottom:14px}
.ritual-step h3{margin:6px 0 10px}
.ritual-step p{color:var(--soft);margin-bottom:16px}

/* ── Standards strip ── */
.shop-standards{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center;margin:90px 0 20px;padding:44px 0;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.shop-standards div{display:flex;flex-direction:column;align-items:center;gap:4px}
.shop-standards strong{font-family:var(--font-display);font-size:1.02rem;color:var(--ink)}
.shop-standards span{font-size:.84rem;color:var(--soft)}
.std-mark{font-size:1.5rem;color:var(--amber);margin-bottom:8px;transition:transform .5s cubic-bezier(.2,.7,.3,1)}
.shop-standards div:hover .std-mark{transform:rotate(90deg) scale(1.15)}

/* ── Shop responsive ── */
@media(max-width:880px){
  .shop-feature{grid-template-columns:1fr}
  .ritual-steps{grid-template-columns:1fr;gap:18px}
  .shop-standards{grid-template-columns:1fr 1fr;gap:30px 16px}
  .shop-cat-head{grid-template-columns:1fr;gap:14px;align-items:start}
}


/* ── Robust Forms: contact form matched to the original .contact-form ───────── */
.rf-form.mt-contact{max-width:none;padding:28px 36px 36px}
.rf-form.mt-contact .rf-fields{gap:20px 16px}
.rf-form.mt-contact .rf-field{gap:7px}
.rf-form.mt-contact .rf-label{font-family:var(--font-mono);font-weight:400;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--soft)}
.rf-form.mt-contact .rf-field input,
.rf-form.mt-contact .rf-field select,
.rf-form.mt-contact .rf-field textarea{width:100%;padding:13px 16px;border:1.5px solid var(--line);border-radius:12px;font-family:var(--font-body);font-size:.94rem;background:var(--bg);color:var(--ink);box-sizing:border-box;-webkit-appearance:none;appearance:none;transition:border-color .2s,box-shadow .2s}
.rf-form.mt-contact .rf-field input:focus,
.rf-form.mt-contact .rf-field select:focus,
.rf-form.mt-contact .rf-field textarea:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(107,114,130,.08)}
.rf-form.mt-contact .rf-field [aria-invalid="true"]{border-color:#c0392b;box-shadow:0 0 0 3px rgba(192,57,43,.1)}
.rf-form.mt-contact .rf-field textarea{min-height:140px;resize:vertical;line-height:1.65}
.rf-form.mt-contact .rf-field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236B7282'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;cursor:pointer}
.rf-form.mt-contact .rf-html{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.04em;color:var(--soft);line-height:1.5;max-width:36ch}
.rf-form.mt-contact .rf-html a{color:var(--amber);text-decoration:underline;text-underline-offset:2px}
.rf-form.mt-contact .rf-actions{margin-top:0;padding-top:4px;gap:20px}
.rf-form.mt-contact .rf-submit{flex:none;background:var(--ink);color:#fff;border-radius:999px;padding:14px 30px;font-weight:600;letter-spacing:.01em;box-shadow:var(--glow);transition:transform .25s,filter .25s}
.rf-form.mt-contact .rf-submit:hover{filter:brightness(1.1)}
.rf-form.mt-contact .rf-submit:active{transform:scale(.97)}
/* Success / error: plain on-brand text, no background box */
.rf-form.mt-contact .rf-message.rf-success{background:none;border:0;padding:0;margin-top:14px;color:#33683f;font-weight:600}
.rf-form.mt-contact .rf-summary{background:none;border:0;padding:0;margin-bottom:12px;color:#b3392d;font-weight:600}
.rf-form.mt-contact .rf-field-error{font-family:var(--font-mono);font-size:.63rem;letter-spacing:.06em;color:#c0392b}
.rf-form.mt-contact .rf-req{color:var(--amber)}
@media(max-width:680px){
  .rf-form.mt-contact{padding:20px 22px 28px}
  .rf-form.mt-contact .rf-fields{gap:16px}
}

/* ── Review form: photos + video share a row; Turnstile left-aligned ── */
.rv-form-section.rv-media-row{display:flex;gap:24px;align-items:flex-start}
.rv-media-row .rv-media-col{flex:1 1 0;min-width:0}
#rvInlineForm .rv-ts .mt-ts-wrap{justify-content:flex-start}
@media(max-width:640px){
  .rv-form-section.rv-media-row{flex-direction:column;gap:18px}
}
.rv-posting-as-val{font-size:1rem;color:var(--ink,#504E4E);font-weight:600;margin-top:2px}
.rv-posting-as-val .rv-posting-loc{font-weight:400;color:#8a8378}

/* ── Branded login + register (logged-out My Account) ──────────────── */
.woocommerce-account:not(.logged-in) .woocommerce{
  flex-direction:column;align-items:center;justify-content:center;
  max-width:960px;gap:0;padding-top:8px
}
/* Two-column login + register */
.woocommerce-account:not(.logged-in) #customer_login.u-columns{
  display:grid;grid-template-columns:1fr 1fr;gap:26px;width:100%;margin:0 auto;align-items:start
}
.woocommerce-account:not(.logged-in) #customer_login .u-column1,
.woocommerce-account:not(.logged-in) #customer_login .u-column2{
  width:auto!important;float:none!important;margin:0!important;padding:0!important
}
.woocommerce-account:not(.logged-in) .woocommerce h2,
.woocommerce-account:not(.logged-in) .woocommerce .u-column1 > h2,
.woocommerce-account:not(.logged-in) .woocommerce .u-column2 > h2{
  font-family:var(--font-display);font-size:1.4rem;color:var(--ink);
  text-align:center;margin:0 0 18px
}
@media(max-width:760px){
  .woocommerce-account:not(.logged-in) #customer_login.u-columns{grid-template-columns:1fr;gap:20px}
}
.woocommerce form.woocommerce-form-login{
  width:100%;max-width:440px;margin:0 auto;
  background:#fff;border:1px solid var(--line);border-radius:16px;
  padding:34px 34px 30px;box-shadow:0 8px 34px rgba(80,78,78,.07)
}
.woocommerce form.login > p:first-of-type:not(.form-row){
  color:var(--soft);font-size:.9rem;margin:0 0 20px;text-align:center
}
.woocommerce form.login .form-row{margin:0 0 18px;padding:0}
.woocommerce form.login label{
  display:block;font-family:var(--font-mono);font-size:.62rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--soft);margin-bottom:8px
}
.woocommerce form.login .woocommerce-Input.input-text,
.woocommerce form.login input[type=text],
.woocommerce form.login input[type=email],
.woocommerce form.login input[type=password]{
  width:100%;padding:13px 16px;border:1.5px solid var(--line);border-radius:12px;
  background:var(--bg);color:var(--ink);font-size:.98rem;box-sizing:border-box;
  transition:border-color .15s,box-shadow .15s
}
.woocommerce form.login input:focus{
  outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(107,114,130,.14);background:#fff
}
.woocommerce form.login .password-input{display:block;position:relative}
.woocommerce form.login .show-password-input{
  position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--soft);cursor:pointer
}
.woocommerce form.login .woocommerce-form-login__submit{
  background:var(--amber)!important;color:#fff!important;border:0!important;
  border-radius:12px!important;padding:13px 26px!important;
  font-family:var(--font-body);font-weight:600;font-size:.95rem;
  cursor:pointer;transition:filter .15s;float:none!important;margin:0!important
}
.woocommerce form.login .woocommerce-form-login__submit:hover{filter:brightness(1.06)}
.woocommerce form.login .mt-login-actions{display:flex;flex-direction:column;align-items:flex-start;gap:14px;margin-bottom:8px}
.woocommerce form.login .mt-auth-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;order:1}
.woocommerce form.login label.woocommerce-form-login__rememberme{
  text-transform:none;letter-spacing:normal;font-family:var(--font-body);
  font-size:.85rem;color:var(--ink);display:inline-flex;align-items:center;gap:8px;margin:0;order:-1
}
.mt-signup-link{
  display:inline-block;background:transparent!important;color:var(--amber)!important;
  border:1.5px solid var(--amber)!important;border-radius:12px!important;
  padding:11px 22px!important;font-family:var(--font-body);font-weight:600;font-size:.95rem;
  text-decoration:none!important;transition:background .15s,color .15s;line-height:1.2
}
.mt-signup-link:hover{background:var(--amber)!important;color:#fff!important}
.woocommerce form.login label.woocommerce-form-login__rememberme input{
  width:16px;height:16px;accent-color:var(--amber);margin:0
}
.woocommerce form.login .lost_password{margin:14px 0 0;text-align:left}
.woocommerce form.login .lost_password a{color:var(--amber);font-size:.85rem;text-decoration:none}
.woocommerce form.login .lost_password a:hover{text-decoration:underline}
.woocommerce form.login .required{color:#b3392d;border:0}
@media(max-width:520px){
  .woocommerce form.woocommerce-form-login{padding:26px 22px 24px}
}

/* ── Branded lost / reset password form ────────────────────────────── */
.woocommerce form.woocommerce-ResetPassword.lost_reset_password{
  width:100%;max-width:440px;margin:0 auto;
  background:#fff;border:1px solid var(--line);border-radius:16px;
  padding:34px 34px 30px;box-shadow:0 8px 34px rgba(80,78,78,.07)
}
.woocommerce form.lost_reset_password > p:first-of-type{
  color:var(--soft);font-size:.9rem;line-height:1.5;margin:0 0 22px;text-align:left
}
.woocommerce form.lost_reset_password .form-row{margin:0 0 18px;padding:0;width:100%;float:none}
.woocommerce form.lost_reset_password label{
  display:block;font-family:var(--font-mono);font-size:.62rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--soft);margin-bottom:8px
}
.woocommerce form.lost_reset_password .input-text{
  width:100%;padding:13px 16px;border:1.5px solid var(--line);border-radius:12px;
  background:var(--bg);color:var(--ink);font-size:.98rem;box-sizing:border-box;
  transition:border-color .15s,box-shadow .15s
}
.woocommerce form.lost_reset_password .input-text:focus{
  outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(107,114,130,.14);background:#fff
}
.woocommerce form.lost_reset_password .required{color:#b3392d;border:0}
.woocommerce form.lost_reset_password button{
  background:var(--amber)!important;color:#fff!important;border:0!important;
  border-radius:12px!important;padding:13px 26px!important;
  font-family:var(--font-body);font-weight:600;font-size:.95rem;
  cursor:pointer;transition:filter .15s;float:none!important;margin:0!important
}
.woocommerce form.lost_reset_password button:hover{filter:brightness(1.06)}
.woocommerce form.lost_reset_password .form-row:last-of-type{margin-bottom:0}
@media(max-width:520px){
  .woocommerce form.woocommerce-ResetPassword.lost_reset_password{padding:26px 22px 24px}
}

/* ── Branded register form ─────────────────────────────────────────── */
#customer_login.u-columns form.woocommerce-form-login,
#customer_login.u-columns form.woocommerce-form-register{max-width:none;width:100%}
.woocommerce form.woocommerce-form-register{
  width:100%;margin:0 auto;
  background:#fff;border:1px solid var(--line);border-radius:16px;
  padding:34px 34px 30px;box-shadow:0 8px 34px rgba(80,78,78,.07)
}
.woocommerce form.register .form-row{margin:0 0 18px;padding:0;width:100%;float:none}
.woocommerce form.register label{
  display:block;font-family:var(--font-mono);font-size:.62rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--soft);margin-bottom:8px
}
.woocommerce form.register .woocommerce-Input.input-text,
.woocommerce form.register input[type=text],
.woocommerce form.register input[type=email],
.woocommerce form.register input[type=password]{
  width:100%;padding:13px 16px;border:1.5px solid var(--line);border-radius:12px;
  background:var(--bg);color:var(--ink);font-size:.98rem;box-sizing:border-box;
  transition:border-color .15s,box-shadow .15s
}
.woocommerce form.register input:focus{
  outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(107,114,130,.14);background:#fff
}
.woocommerce form.register .password-input{display:block;position:relative}
.woocommerce form.register .show-password-input{
  position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--soft);cursor:pointer
}
.woocommerce form.register .woocommerce-privacy-policy-text{
  color:var(--soft);font-size:.82rem;line-height:1.55;margin:4px 0 18px
}
.woocommerce form.register .woocommerce-privacy-policy-text a{color:var(--amber)}
.woocommerce form.register .woocommerce-form-register__submit{
  background:var(--amber)!important;color:#fff!important;border:0!important;
  border-radius:12px!important;padding:13px 26px!important;
  font-family:var(--font-body);font-weight:600;font-size:.95rem;
  cursor:pointer;transition:filter .15s;float:none!important;margin:0!important;width:auto
}
.woocommerce form.register .woocommerce-form-register__submit:hover{filter:brightness(1.06)}
.woocommerce form.register .required{color:#b3392d;border:0}
.woocommerce form.register .mt-ts-wrap{margin:6px 0 18px;justify-content:flex-start}
.woocommerce form.login .mt-ts-wrap{margin:6px 0 16px;justify-content:flex-start}
.woocommerce form.lost_reset_password .mt-ts-wrap{margin:2px 0 18px;justify-content:flex-start}
@media(max-width:520px){
  .woocommerce form.woocommerce-form-register{padding:26px 22px 24px}
}

/* ── Dedicated signup page ─────────────────────────────────────────── */
.mt-signup-form,.mt-signup-card{
  max-width:520px;margin:0 auto;
  background:#fff;border:1px solid var(--line);border-radius:16px;
  padding:34px 34px 30px;box-shadow:0 8px 34px rgba(80,78,78,.07)
}
.mt-signup-form .mt-su-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.mt-signup-form .mt-su-field{margin:0 0 18px}
.mt-signup-form label{
  display:block;font-family:var(--font-mono);font-size:.62rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--soft);margin-bottom:8px
}
.mt-signup-form input[type=text],
.mt-signup-form input[type=email],
.mt-signup-form input[type=password]{
  width:100%;padding:13px 16px;border:1.5px solid var(--line);border-radius:12px;
  background:var(--bg);color:var(--ink);font-size:.98rem;box-sizing:border-box;
  transition:border-color .15s,box-shadow .15s
}
.mt-signup-form input:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(107,114,130,.14);background:#fff}
.mt-signup-form .req{color:#b3392d}
.mt-signup-form .mt-su-news{
  display:flex;gap:10px;align-items:flex-start;margin:6px 0 4px;padding:14px 16px;
  background:var(--bg);border:1px solid var(--line-soft);border-radius:12px;
  font-family:var(--font-body);text-transform:none;letter-spacing:normal;
  font-size:.85rem;line-height:1.5;color:var(--ink);cursor:pointer
}
.mt-signup-form .mt-su-news input{width:17px;height:17px;accent-color:var(--amber);flex:0 0 auto;margin-top:2px}
.mt-signup-form .mt-su-news strong{color:var(--ink)}
.mt-signup-form .mt-ts-wrap{margin:16px 0 4px;justify-content:flex-start}
.mt-signup-form .mt-su-submit{
  width:100%;margin-top:16px;background:var(--amber);color:#fff;border:0;
  border-radius:12px;padding:14px 24px;font-family:var(--font-body);font-weight:600;
  font-size:.98rem;cursor:pointer;transition:filter .15s
}
.mt-signup-form .mt-su-submit:hover{filter:brightness(1.06)}
.mt-signup-form .mt-su-alt{text-align:center;font-size:.86rem;color:var(--soft);margin:16px 0 0}
.mt-signup-form .mt-su-alt a{color:var(--amber);text-decoration:none;font-weight:600}
.mt-signup-form .mt-signup-errors{
  background:rgba(179,57,45,.07);border:1px solid rgba(179,57,45,.25);border-radius:12px;
  padding:12px 16px;margin-bottom:20px;color:#8f2f26;font-size:.88rem
}
.mt-signup-form .mt-signup-errors p{margin:0 0 4px}
.mt-signup-form .mt-signup-errors p:last-child{margin:0}
@media(max-width:520px){
  .mt-signup-form,.mt-signup-card{padding:26px 22px 24px}
  .mt-signup-form .mt-su-row{grid-template-columns:1fr;gap:0}
}


/* Mega menu: View-all link — centered column, no stray divider (2026-07-02) */
.drop-menu.wide .drop-all{align-self:center;border:1px solid var(--line);border-radius:999px;padding:9px 18px;margin:0 24px;white-space:nowrap;transition:border-color .2s ease,color .2s ease}
.drop-menu.wide .drop-all:hover{border-color:var(--amber);text-decoration:none}

/* ══ Checkout UX sprint (2026-07-02) ══════════════════════════════════════ */

/* Returning-customer + coupon toggles: calmer bars with chip-style actions */
.woocommerce-checkout .woocommerce-form-login-toggle .woocommerce-info,
.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.woocommerce-checkout .woocommerce-form-login-toggle .woocommerce-info a,
.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info a{display:inline-block;font-family:var(--font-mono);font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:8px 18px;border:1px solid var(--line);border-radius:999px;color:var(--ink)!important;background:var(--bg);transition:border-color .2s,color .2s,background .2s;margin-left:auto}
.woocommerce-checkout .woocommerce-form-login-toggle .woocommerce-info a:hover,
.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info a:hover{border-color:var(--amber);color:var(--amber)!important;text-decoration:none}

/* Checkout login drawer: stacked, on-brand */
.woocommerce-checkout form.login{border:1px solid var(--line-soft)!important;border-radius:var(--radius);background:#fdfbf7}
.woocommerce-checkout form.login .form-row{display:block;float:none;width:100%}
.woocommerce-checkout form.login .woocommerce-form-login__rememberme{display:block;margin:4px 0 14px}
.woocommerce-checkout form.login .button,
.woocommerce-checkout form.login button[type=submit]{display:block;width:100%;margin:0;padding:14px 28px;border-radius:999px;font-family:var(--font-display);font-weight:600}
.woocommerce-checkout form.login .lost_password{margin-top:12px;text-align:center}

/* "New here? Create an account" block inside the login drawer */
.mt-checkout-register{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:18px;padding-top:16px;border-top:1px solid var(--line-soft)}
.mt-checkout-register-divider{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--soft)}
.mt-checkout-register-btn{display:inline-block;padding:10px 22px;border:1px solid var(--line);border-radius:999px;font-family:var(--font-mono);font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink)!important;transition:border-color .2s,color .2s}
.mt-checkout-register-btn:hover{border-color:var(--amber);color:var(--amber)!important;text-decoration:none}
.mt-checkout-register-note{font-size:.78rem;color:var(--soft)}

/* Express-pay slot: below Place order, matching its width, tidy stack */
#mt-express-slot{display:flex;flex-direction:column;gap:10px;margin-top:14px;width:100%}
#mt-express-slot:not(:empty)::before{content:"— or pay express —";display:block;text-align:center;font-family:var(--font-mono);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--soft);margin:4px 0 2px}
#mt-express-slot>*{width:100%!important;max-width:none!important;margin:0!important;float:none!important}
#mt-express-slot .gpay-button,
#mt-express-slot iframe,
#mt-express-slot .paypal-buttons{width:100%!important;min-width:0!important}
#mt-express-slot #ppcp-messages{margin-top:4px!important}
/* Old top-of-checkout express area + its OR separator: gone */
.woocommerce-checkout .mt-checkout-main > #wc-stripe-express-checkout-element:empty{display:none}
#wc-stripe-express-checkout-button-separator,
.wc-stripe-payment-request-button-separator,
p#wc-stripe-payment-request-button-separator{display:none!important}

@media (max-width:720px){
	.woocommerce-checkout .woocommerce-form-login-toggle .woocommerce-info a,
	.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info a{margin-left:0;width:100%;text-align:center}
	.mt-checkout-register{flex-direction:column;align-items:stretch;text-align:center}
	#mt-express-slot{gap:8px}
}
