/*
 * ARI HAIR — main stylesheet.
 * Ported verbatim from the v3 visual reference (arihair-light-v3.html).
 * Custom properties are declared here so components render identically whether
 * or not theme.json variables are present.
 */

:root{
  --bg:#FDFBF8;          /* bright warm white */
  --white:#FFFFFF;
  --pink:#FBE7EC;
  --peach:#FCEADF;
  --butter:#FBF1DA;
  --mint:#E7F2EC;
  --lilac:#F0EAF8;
  --sky:#E7EFF7;
  --rose-soft:#F6D2DC;
  --rose:#C0506A;         /* accent / primary (accessible on white & w/ white text) */
  --rose-dk:#A8425A;
  --text:#41302A;         /* warm dark brown — body text */
  --ink:#33251F;          /* headings */
  --muted:#8E7E72;
  --r-lg:34px; --r-md:24px; --r-sm:16px; --r-pill:999px;
  --sh:0 14px 40px rgba(74,52,38,.07), 0 4px 12px rgba(74,52,38,.04);
  --sh-h:0 26px 64px rgba(74,52,38,.14);
  --sh-sm:0 6px 18px rgba(74,52,38,.07);
  --maxw:1240px;
  --pad:clamp(18px,5vw,64px);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);
  font-family:'Plus Jakarta Sans',sans-serif;font-size:16.5px;line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;letter-spacing:-.025em;line-height:1.05;margin:0;color:var(--ink)}
.fr{font-family:'Fraunces',serif;font-weight:300;font-style:italic;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--rose);font-weight:600}
.eyebrow::before{content:"";width:18px;height:1.5px;background:var(--rose-soft);border-radius:2px}
.skip{position:absolute;left:-999px;top:0;background:var(--rose);color:#fff;padding:10px 16px;z-index:300}
.skip:focus{left:0}
:focus-visible{outline:2.5px solid var(--rose);outline-offset:3px}

.btn{display:inline-flex;align-items:center;gap:.55em;border:none;border-radius:var(--r-pill);
  padding:.95em 1.85em;font-size:.86rem;font-weight:600;transition:transform .25s,box-shadow .25s,background .25s,color .25s}
.btn-primary{background:var(--rose);color:#fff}
.btn-primary:hover{background:var(--rose-dk);transform:translateY(-3px);box-shadow:0 12px 26px rgba(192,80,106,.32)}
.btn-white{background:var(--white);color:var(--ink);box-shadow:var(--sh-sm)}
.btn-white:hover{transform:translateY(-3px);box-shadow:var(--sh)}
.btn-ghost{background:transparent;color:var(--rose);border:1.5px solid var(--rose-soft)}
.btn-ghost:hover{border-color:var(--rose);background:var(--pink);transform:translateY(-3px)}

.ann{background:var(--pink);color:var(--ink);text-align:center;font-size:.78rem;letter-spacing:.04em;padding:9px 16px;font-weight:500}
.ann b{font-weight:700;color:var(--rose)}

header.site{position:sticky;top:0;z-index:100;background:rgba(253,251,248,.78);backdrop-filter:blur(12px);transition:box-shadow .3s,background .3s,padding .3s}
header.site.scrolled{box-shadow:0 6px 24px rgba(74,52,38,.06);background:rgba(253,251,248,.94)}
.navbar{display:flex;align-items:center;gap:clamp(14px,2vw,28px);padding:12px 0;transition:padding .3s}
header.site.scrolled .navbar{padding:8px 0}
.brand{font-weight:700;font-size:1.35rem;letter-spacing:.16em;white-space:nowrap;color:var(--ink);flex:none}
.brand .dot{color:var(--rose)}
.icons{display:flex;gap:6px;align-items:center;flex:none;margin-left:auto}
.iconbtn{background:none;border:none;width:42px;height:42px;border-radius:var(--r-pill);display:inline-flex;align-items:center;justify-content:center;position:relative;transition:background .2s}
.iconbtn:hover{background:var(--pink)}
.iconbtn svg{width:21px;height:21px;stroke:var(--ink);stroke-width:1.5;fill:none}
.cartcount{position:absolute;top:4px;right:4px;background:var(--rose);color:#fff;font-size:.6rem;min-width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;padding:0 3px}
.burger{display:none;background:none;border:none;flex-direction:column;gap:5px;width:42px;height:42px;align-items:center;justify-content:center;border-radius:var(--r-pill)}
.burger span{width:22px;height:2px;background:var(--ink);border-radius:2px}

/* IMAGE CATEGORY QUICK-NAV — primary nav, inline in the header beside the logo */
.qn-scroll{overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none}
.qn-scroll::-webkit-scrollbar{display:none}
.hdr-nav{flex:1 1 auto;min-width:0}
.qn-row{display:flex;gap:clamp(10px,1.4vw,18px);justify-content:flex-end;padding:4px 2px;min-width:min-content}
.qn{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:6px;width:auto}
.qn-img{width:clamp(42px,3.4vw,54px);height:clamp(42px,3.4vw,54px);border-radius:50%;background:var(--t);
  display:flex;align-items:center;justify-content:center;box-shadow:var(--sh-sm);position:relative;overflow:hidden;
  transition:transform .3s ease,box-shadow .3s ease}
.qn-img span{font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:1.3rem;color:rgba(65,48,42,.4)}
.qn:hover .qn-img,.qn:focus-visible .qn-img{transform:translateY(-3px);box-shadow:var(--sh);outline:2.5px solid var(--rose-soft);outline-offset:2px}
.qn-l{font-size:.66rem;font-weight:600;color:var(--ink);text-align:center;line-height:1.1;white-space:nowrap}

/* hero */
.hero{position:relative;overflow:hidden;
  background:
    radial-gradient(40% 55% at 8% 12%, rgba(251,231,236,.85), transparent 70%),
    radial-gradient(42% 50% at 92% 8%, rgba(240,234,248,.85), transparent 70%),
    radial-gradient(50% 62% at 78% 96%, rgba(231,242,236,.85), transparent 70%),
    radial-gradient(46% 56% at 22% 94%, rgba(252,234,223,.8), transparent 70%),
    var(--bg);
  padding-top:clamp(34px,5vw,72px);padding-bottom:clamp(30px,5vw,56px)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,56px);align-items:center}
.hero h1{font-size:clamp(2.9rem,7vw,5.7rem)}
.hero h1 .fr{display:block;font-size:1.04em;color:var(--rose);margin-top:.04em}
.hero p.lead{font-size:1.1rem;color:#6c5d50;max-width:36ch;margin:1.4rem 0 0;line-height:1.62}
.hero-cta{display:flex;gap:13px;flex-wrap:wrap;margin-top:2rem}
.hero-trust{display:flex;gap:22px;margin-top:2.1rem;flex-wrap:wrap;align-items:center}
.hero-trust .ht{display:flex;align-items:center;gap:8px;font-size:.84rem;color:#6c5d50;font-weight:500}
.hero-trust .star{color:var(--rose)}
.hero-trust .sep{width:1px;height:20px;background:rgba(58,42,33,.14)}

.hero-fig{position:relative;aspect-ratio:1/1.04;border-radius:var(--r-lg)}
.hero-photo{position:absolute;inset:0;border-radius:var(--r-lg);overflow:hidden;
  background:radial-gradient(120% 100% at 70% 12%, #fdeaf0, #fbd9e3 52%, #f6cdd8);box-shadow:var(--sh)}
.hero-photo .mono{position:absolute;right:6%;bottom:-4%;font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:15rem;color:rgba(255,255,255,.45);line-height:.8}
.hero-photo .tag{position:absolute;top:18px;left:18px;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(120,70,80,.55);font-weight:600}
.chip-float{position:absolute;background:var(--white);border-radius:var(--r-pill);box-shadow:var(--sh);padding:10px 16px;font-size:.8rem;font-weight:600;display:flex;align-items:center;gap:9px}
.chip-float.c1{top:13%;right:-4%}
.chip-float.c2{bottom:19%;left:-6%;flex-direction:column;align-items:flex-start;gap:6px;padding:13px 17px}
.chip-float .rev-stars{color:var(--rose)}
.chip-float .mini-dots{display:flex;gap:5px}
.chip-float .mini-dots i{width:15px;height:15px;border-radius:50%;display:inline-block;border:1.5px solid #fff;box-shadow:0 0 0 1px rgba(0,0,0,.05)}
.chip-float .mlabel{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:600}

/* shade bar */
.sigbar{margin-top:clamp(34px,4vw,56px)}
.sig-top{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:14px;flex-wrap:wrap}
.sig-top .lab{font-size:.82rem;color:#6c5d50;font-weight:600}
.sig-top .lab b{font-family:'Fraunces',serif;font-style:italic;font-weight:400;color:var(--rose)}
.shadebar{position:relative;height:60px;border-radius:var(--r-pill);box-shadow:inset 0 1px 3px rgba(0,0,0,.1), var(--sh-sm)}
.sb-track{position:absolute;inset:0;border-radius:var(--r-pill)}
.sb-hits{position:absolute;inset:0;display:flex}
.sb-hit{flex:1;background:transparent;border:none;height:100%;border-radius:var(--r-pill)}
.sb-thumb{position:absolute;top:50%;width:30px;height:30px;border-radius:50%;background:#fff;box-shadow:0 4px 12px rgba(0,0,0,.25);transform:translate(-50%,-50%);left:50%;transition:left .25s cubic-bezier(.2,.7,.2,1);pointer-events:none;border:2px solid #fff}
.sb-bubble{position:absolute;bottom:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(6px);background:var(--white);box-shadow:var(--sh);border-radius:14px;padding:8px 14px;font-size:.8rem;font-weight:600;white-space:nowrap;opacity:0;transition:.25s;pointer-events:none}
.sb-bubble.show{opacity:1;transform:translateX(-50%) translateY(0)}
.sb-bubble .code{color:var(--muted);font-weight:500;margin-left:6px}
.sb-bubble::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:7px solid transparent;border-top-color:var(--white)}

.pills{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;padding-top:clamp(40px,5vw,64px)}
.pill{background:var(--white);box-shadow:var(--sh-sm);border-radius:var(--r-pill);padding:13px 22px;font-size:.9rem;font-weight:600;display:flex;align-items:center;gap:10px;color:var(--ink)}
.pill .ic{width:8px;height:8px;border-radius:50%;background:var(--rose)}

section{padding-top:clamp(64px,9vw,116px);padding-bottom:clamp(8px,2vw,24px)}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:22px;margin-bottom:42px;flex-wrap:wrap}
.sec-head h2{font-size:clamp(2rem,4.6vw,3.5rem);max-width:16ch}
.sec-head h2 .fr{color:var(--rose)}
.sec-head .more{font-size:.86rem;font-weight:600;background:var(--white);box-shadow:var(--sh-sm);border-radius:var(--r-pill);padding:11px 20px;white-space:nowrap;transition:transform .2s,box-shadow .2s;color:var(--ink)}
.sec-head .more:hover{transform:translateY(-2px);box-shadow:var(--sh)}

.cats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cat{position:relative;border-radius:var(--r-md);padding:24px;overflow:hidden;display:flex;flex-direction:column;min-height:300px;transition:transform .35s,box-shadow .35s;box-shadow:var(--sh-sm)}
.cat:hover{transform:translateY(-6px);box-shadow:var(--sh-h)}
.cat .cimg{position:absolute;inset:0;z-index:0;transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.cat:hover .cimg{transform:scale(1.06)}
.cat .cmono{position:absolute;right:8%;bottom:2%;font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:7rem;color:rgba(65,48,42,.08);z-index:0;line-height:.8}
.cat>*{position:relative;z-index:1}
.cat .ctag{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);opacity:.65;font-weight:700}
.cat h3{font-size:1.7rem;margin-top:auto}
.cat .cs{font-size:.9rem;color:#5c4d40;margin-top:5px;max-width:26ch}
.cat .arrow{position:absolute;right:22px;bottom:22px;width:44px;height:44px;border-radius:50%;background:var(--rose);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:transform .3s,background .3s;z-index:2}
.cat:hover .arrow{transform:translateX(4px);background:var(--rose-dk)}
.cat .premium{position:absolute;top:24px;right:24px;font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;background:rgba(255,255,255,.78);color:var(--rose);padding:5px 10px;border-radius:var(--r-pill);font-weight:700;z-index:2}

.prods{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.card{background:var(--white);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--sh-sm);display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s}
.card:hover{transform:translateY(-6px);box-shadow:var(--sh-h)}
.card .pimg{aspect-ratio:1/1.06;position:relative;overflow:hidden}
.card .pimg .pmono{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:3.4rem;color:rgba(65,48,42,.13)}
.badge{position:absolute;top:14px;left:14px;background:var(--white);color:var(--rose);font-size:.64rem;letter-spacing:.08em;text-transform:uppercase;padding:6px 12px;border-radius:var(--r-pill);font-weight:700;box-shadow:var(--sh-sm)}
.wish{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.85);border:none;display:flex;align-items:center;justify-content:center;box-shadow:var(--sh-sm)}
.wish svg{width:16px;height:16px;stroke:var(--rose);fill:none;stroke-width:1.6}
.card .pinfo{padding:18px;display:flex;flex-direction:column;gap:9px;flex:1}
.card .pname{font-weight:700;font-size:1.05rem;letter-spacing:-.01em;color:var(--ink)}
.card .pmeta{font-size:.8rem;color:var(--muted)}
.dots{display:flex;gap:6px;align-items:center;margin-top:2px}
.dot{width:15px;height:15px;border-radius:50%;border:1.5px solid #fff;box-shadow:0 0 0 1px rgba(0,0,0,.06);cursor:pointer;transition:transform .2s}
.dot:hover{transform:scale(1.2)}
.dot.more{width:auto;padding:0 7px;font-size:.62rem;color:var(--muted);background:var(--bg);border:none;box-shadow:none;display:flex;align-items:center;height:15px}
.prow{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:8px}
.price{font-weight:700;font-size:1.12rem;color:var(--ink)}
.price small{font-weight:500;font-size:.7rem;color:var(--muted)}
.add{background:var(--rose);color:#fff;border:none;border-radius:var(--r-pill);padding:.66em 1.15em;font-size:.76rem;font-weight:600;transition:transform .2s,background .25s}
.add:hover{transform:translateY(-2px);background:var(--rose-dk)}
.add.added{background:#5a9e7a}
.note{font-size:.76rem;color:var(--muted);margin-top:22px}

.finder .fin-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,60px);align-items:center}
.fin-card{background:var(--white);border-radius:var(--r-lg);box-shadow:var(--sh);padding:clamp(28px,4vw,46px);text-align:center}
.fin-card .big{width:120px;height:120px;border-radius:50%;margin:0 auto 22px;box-shadow:0 10px 30px rgba(0,0,0,.14);transition:background .3s}
.fin-card h3{font-size:2rem}
.fin-card .fcode{color:var(--rose);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;margin:6px 0 16px}
.fin-card p{color:#6c5d50;font-size:.92rem;max-width:34ch;margin:0 auto}
.chips{display:flex;flex-wrap:wrap;gap:14px;margin-top:24px}
.chip{display:flex;flex-direction:column;align-items:center;gap:7px;background:none;border:none;padding:2px}
.chip .sw{width:48px;height:48px;border-radius:50%;border:2.5px solid transparent;box-shadow:var(--sh-sm);transition:transform .2s,border-color .2s}
.chip:hover .sw{transform:scale(1.1)}
.chip.sel .sw{border-color:var(--rose);transform:scale(1.1)}
.chip .cd{font-size:.64rem;color:var(--muted);font-weight:600}

.story-panel{background:linear-gradient(135deg,var(--lilac),var(--pink));border-radius:var(--r-lg);padding:clamp(30px,5vw,72px);display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,4vw,60px);align-items:center}
.story-panel h2{font-size:clamp(2rem,4.4vw,3.3rem)}
.story-panel h2 .fr{color:var(--rose)}
.story-panel p{color:#5c4d40;max-width:44ch;margin:1.2rem 0 0}
.stat-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}
.stat{background:rgba(255,255,255,.72);border-radius:var(--r-md);padding:16px 20px}
.stat .n{font-weight:700;font-size:1.4rem;letter-spacing:-.02em;color:var(--ink)}
.stat .l{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:600}
.story-fig{aspect-ratio:1/1.05;border-radius:var(--r-md);overflow:hidden;position:relative;background:radial-gradient(120% 100% at 30% 10%, #fdeef2, #f6cdd9);box-shadow:var(--sh)}
.story-fig .mono{position:absolute;right:6%;bottom:-2%;font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:8rem;color:rgba(255,255,255,.5);line-height:.8}

.methods-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.method{border-radius:var(--r-md);padding:clamp(26px,3vw,42px);box-shadow:var(--sh-sm)}
.method.diy{background:var(--butter)}
.method.salon{background:var(--mint)}
.method .mk{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);opacity:.6;font-weight:700;margin-bottom:12px}
.method h3{font-size:1.55rem}
.method .mtime{font-size:.84rem;color:#5c4d40;margin:6px 0 16px;font-weight:500}
.method ul{list-style:none;margin:0;padding:0}
.method li{padding:10px 0;font-size:.92rem;display:flex;gap:11px;align-items:flex-start;color:#4a3c30}
.method li+li{border-top:1px solid rgba(58,42,33,.1)}
.method li .ck{flex:none;width:20px;height:20px;border-radius:50%;background:rgba(255,255,255,.85);display:flex;align-items:center;justify-content:center;font-size:.7rem;color:var(--rose);margin-top:1px;font-weight:800}

.reviews{background:var(--pink);border-radius:var(--r-lg);padding:clamp(36px,5vw,72px) 0;margin-top:clamp(40px,5vw,64px)}
.reviews .wrap2{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
.reviews .sec-head{margin-bottom:36px}
.quote-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.quote{background:var(--white);border-radius:var(--r-md);padding:28px;box-shadow:var(--sh-sm)}
.quote .stars{color:var(--rose);letter-spacing:2px;font-size:.85rem;margin-bottom:14px}
.quote p{font-size:1.05rem;line-height:1.5;color:var(--ink);font-weight:500}
.quote .by{display:flex;align-items:center;gap:10px;margin-top:18px}
.quote .av{width:34px;height:34px;border-radius:50%;display:inline-block}
.quote .by .nm{font-size:.82rem;font-weight:700;color:var(--ink)}
.quote .by .lc{font-size:.72rem;color:var(--muted)}

.news-panel{background:radial-gradient(120% 140% at 0% 0%, var(--rose-soft), var(--peach) 50%, var(--lilac));border-radius:var(--r-lg);padding:clamp(40px,6vw,80px) var(--pad);text-align:center;box-shadow:var(--sh-sm)}
.news-panel h2{font-size:clamp(2rem,4.6vw,3.5rem)}
.news-panel h2 .fr{color:var(--rose)}
.news-panel p{color:#5c4d40;max-width:42ch;margin:1rem auto 26px}
.news-panel form{display:flex;gap:10px;max-width:480px;margin:0 auto;flex-wrap:wrap;justify-content:center}
.news-panel input{flex:1;min-width:220px;border:none;background:var(--white);border-radius:var(--r-pill);padding:1em 1.4em;font-family:inherit;font-size:.95rem;color:var(--ink);box-shadow:var(--sh-sm)}
.news-panel input:focus{outline:none;box-shadow:0 0 0 2.5px var(--rose)}
.news-panel .msg{min-height:1.4em;margin-top:16px;font-size:.85rem;color:var(--rose-dk);font-weight:600}
.vh{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}

footer.site{margin-top:clamp(64px,8vw,110px);background:var(--white);padding-top:64px}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px;padding-bottom:44px}
footer .brand{font-size:1.4rem;display:inline-block;margin-bottom:14px}
.foot-intro p{font-size:.92rem;color:#6c5d50;max-width:32ch}
.pay{display:flex;gap:8px;flex-wrap:wrap;margin-top:20px}
.pay span{background:var(--bg);border-radius:var(--r-pill);padding:7px 13px;font-size:.66rem;letter-spacing:.04em;font-weight:600;color:var(--ink)}
.fcol h4{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);margin:0 0 14px;font-weight:700}
.fcol a{display:block;font-size:.9rem;padding:6px 0;color:#6c5d50;font-weight:500}
.fcol a:hover{color:var(--rose)}
.foot-bot{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:24px 0;margin-top:8px;border-top:1px solid rgba(58,42,33,.1);flex-wrap:wrap;font-size:.78rem;color:var(--muted);font-weight:500}
.foot-bot .region{display:flex;align-items:center;gap:8px}

.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

@media(max-width:980px){
  .hdr-nav,.icons .search-d{display:none}
  .burger{display:flex}
  .navbar{justify-content:space-between}
  .qn-row{justify-content:flex-start}
  .hero-grid{grid-template-columns:1fr;gap:38px}
  .hero-fig{max-width:440px;margin:0 auto;width:100%}
  .fin-grid,.story-panel,.methods-grid{grid-template-columns:1fr}
  .story-fig{order:-1;max-width:420px;margin:0 auto;width:100%}
  .cats{grid-template-columns:repeat(2,1fr)}
  .prods{grid-template-columns:repeat(2,1fr)}
  .quote-grid{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr 1fr}
  .foot-intro{grid-column:1/-1}
}
@media(max-width:560px){
  .cats{grid-template-columns:1fr}
  .prods{grid-template-columns:1fr 1fr}
  .chip-float.c1,.chip-float.c2{display:none}
  .foot-top{grid-template-columns:1fr 1fr}
}
.mobnav{position:fixed;inset:0;background:var(--bg);z-index:200;transform:translateX(100%);transition:transform .4s cubic-bezier(.2,.7,.2,1);display:flex;flex-direction:column;padding:20px var(--pad)}
.mobnav.open{transform:none}
.mobnav .mtop{display:flex;justify-content:space-between;align-items:center}
.mobnav .x{background:var(--white);border:none;width:42px;height:42px;border-radius:50%;font-size:1.5rem;box-shadow:var(--sh-sm)}
.mobnav a{font-size:1.9rem;font-weight:700;padding:14px 0;border-bottom:1px solid rgba(58,42,33,.08);color:var(--ink);letter-spacing:-.02em}
.mobnav a:first-of-type{margin-top:20px}

@media (prefers-reduced-motion: reduce){*{transition-duration:.01ms!important;animation:none!important;scroll-behavior:auto}.reveal{opacity:1;transform:none}}

/* =====================================================================
   WOOCOMMERCE — Phase D
   PLP (archive / taxonomy), filters, PDP, cross-sell, sticky add-to-cart.
   Reuses the same tokens, radii and shadows as the homepage.
   ===================================================================== */

/* --- Shop header --- */
.shop-wrap{padding-top:clamp(28px,5vw,52px);padding-bottom:clamp(40px,6vw,80px)}
.shop-head{align-items:flex-end;margin-bottom:18px}
.shop-head-l{display:flex;flex-direction:column;gap:6px}
.shop-title{font-size:clamp(2rem,4.6vw,3.2rem);margin:0}
.shop-head .woocommerce-result-count,.shop-head .wc-block-product-results-count{color:var(--muted);font-size:.84rem;margin:0}
.shop-head .wp-block-woocommerce-catalog-sorting,.shop-head .woocommerce-ordering{margin:0}
.shop-head select.orderby,
.shop-head .wp-block-woocommerce-catalog-sorting select,
.shop-head .orderby,.shop-head select{
  -webkit-appearance:none;-moz-appearance:none;appearance:none;
  font-family:inherit;font-size:.84rem;font-weight:600;color:var(--ink);cursor:pointer;
  background-color:var(--white);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23C0506A' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;
  border:none;box-shadow:var(--sh-sm);border-radius:var(--r-pill);padding:11px 42px 11px 18px}
.shop-head select.orderby:focus,.shop-head .orderby:focus{outline:none;box-shadow:0 0 0 2.5px var(--rose-soft),var(--sh-sm)}
.shop-desc{color:#6c5d50;max-width:62ch;margin:0 0 30px;font-size:.95rem}
.shop-layout{gap:clamp(20px,3vw,40px)!important;align-items:flex-start}
.shop-sidebar{position:sticky;top:96px}

/* --- Filters sidebar --- */
.ari-filters{background:var(--white);border-radius:var(--r-md);box-shadow:var(--sh-sm);padding:24px}
.ari-filters .fgroup+.fgroup{margin-top:22px;padding-top:20px;border-top:1px solid rgba(58,42,33,.1)}
.ari-filters h4{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);margin:0 0 14px;font-weight:700}
.fswatches{display:flex;flex-wrap:wrap;gap:10px}
.fswatch{cursor:pointer;line-height:0}
.fswatch input{position:absolute;width:1px;height:1px;opacity:0;overflow:hidden}
.fswatch .sw{display:block;width:34px;height:34px;border-radius:50%;background:var(--sw,var(--rose-soft));border:2.5px solid transparent;box-shadow:var(--sh-sm);transition:transform .2s,border-color .2s}
.fswatch:hover .sw{transform:scale(1.1)}
.fswatch input:checked+.sw{border-color:var(--rose);transform:scale(1.1)}
.fswatch input:focus-visible+.sw{outline:2.5px solid var(--rose);outline-offset:3px}
.fchips{display:flex;flex-wrap:wrap;gap:8px}
.fchip{cursor:pointer}
.fchip input{position:absolute;width:1px;height:1px;opacity:0;overflow:hidden}
.fchip span{display:block;padding:7px 13px;border-radius:var(--r-pill);background:var(--bg);font-size:.78rem;font-weight:600;color:var(--ink);border:1.5px solid transparent;transition:.2s}
.fchip:hover span{border-color:var(--rose-soft)}
.fchip input:checked+span{border-color:var(--rose);background:var(--pink);color:var(--rose-dk)}
.fchip input:focus-visible+span{outline:2.5px solid var(--rose);outline-offset:2px}
.fprice{display:flex;gap:8px;align-items:center}
.fprice input{width:100%;min-width:0;border:1.5px solid rgba(58,42,33,.16);border-radius:var(--r-sm);padding:9px 11px;font-family:inherit;font-size:.85rem;color:var(--ink);background:var(--bg)}
.fprice input:focus{outline:none;border-color:var(--rose)}
.fprice-sep{color:var(--muted)}
.ari-filters .btn{width:100%;justify-content:center;margin-top:20px}
.fclear{display:inline-block;margin-top:12px;font-size:.8rem;font-weight:600;color:var(--rose)}
.fclear:hover{color:var(--rose-dk)}

/* --- Product grid (Product Collection styled as homepage cards) --- */
.ari-plp .wp-block-post-template{list-style:none;margin:0;padding:0;gap:20px!important}
.ari-plp .wp-block-post-template>li,.ari-plp .wc-block-product{
  background:var(--white);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--sh-sm);
  display:flex;flex-direction:column;padding:0;margin:0;transition:transform .3s,box-shadow .3s}
.ari-plp .wp-block-post-template>li:hover{transform:translateY(-6px);box-shadow:var(--sh-h)}
.ari-plp .wp-block-post-template>li>*{padding-left:16px;padding-right:16px}
.ari-plp .wp-block-post-template>li>.wp-block-woocommerce-product-image,
.ari-plp .wp-block-post-template>li>figure{padding:0;margin:0}
.ari-plp .wp-block-woocommerce-product-image img{width:100%;aspect-ratio:1/1.06;object-fit:cover;display:block;border-radius:0}
.ari-plp .wp-block-woocommerce-product-image .wc-block-components-product-sale-badge{
  background:var(--white);color:var(--rose);border:none;box-shadow:var(--sh-sm);border-radius:var(--r-pill);
  font-size:.64rem;letter-spacing:.08em;text-transform:uppercase;font-weight:700;padding:6px 12px}
.ari-plp .wp-block-post-title{font-size:1.05rem;font-weight:700;letter-spacing:-.01em;margin:14px 0 0;line-height:1.25}
.ari-plp .wp-block-post-title a{color:var(--ink)}
.ari-plp .wp-block-post-title a:hover{color:var(--rose)}
.ari-plp .wp-block-woocommerce-product-price,.ari-plp .wc-block-components-product-price{
  font-weight:700;font-size:1.05rem;color:var(--ink);margin-top:6px}
.ari-plp .wc-block-components-product-price__regular{color:var(--muted);font-weight:500}
.ari-plp .wc-block-components-product-rating{margin-top:4px}
.ari-plp .wc-block-components-product-rating .wc-block-components-product-rating__stars,
.ari-plp .star-rating span:before{color:var(--rose)}
.ari-plp .wp-block-woocommerce-product-button{margin-top:auto;padding-top:10px;padding-bottom:18px}
.ari-plp .wp-block-woocommerce-product-button a,
.ari-plp .wp-block-button__link,.ari-plp a.add_to_cart_button,.ari-plp a.added_to_cart{
  background:var(--rose);color:#fff;border:none;border-radius:var(--r-pill);
  padding:.7em 1.3em;font-size:.78rem;font-weight:600;width:100%;text-align:center;
  transition:transform .2s,background .25s;display:inline-block}
.ari-plp .wp-block-woocommerce-product-button a:hover,
.ari-plp a.add_to_cart_button:hover{background:var(--rose-dk);transform:translateY(-2px)}

/* --- Pagination as pills --- */
.ari-pagination{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:40px}
.ari-pagination .wp-block-query-pagination-numbers{display:flex;gap:8px;flex-wrap:wrap}
.ari-pagination a,.ari-pagination .page-numbers,
.ari-pagination .wp-block-query-pagination-previous,
.ari-pagination .wp-block-query-pagination-next{
  background:var(--white);box-shadow:var(--sh-sm);border-radius:var(--r-pill);
  padding:9px 16px;font-weight:600;font-size:.85rem;color:var(--ink);text-decoration:none;
  min-width:40px;text-align:center;transition:transform .2s,box-shadow .2s}
.ari-pagination a:hover{transform:translateY(-2px);box-shadow:var(--sh)}
.ari-pagination .page-numbers.current{background:var(--rose);color:#fff}

/* --- PDP --- */
.ari-breadcrumbs{margin-top:22px;font-size:.78rem;color:var(--muted)}
.ari-breadcrumbs a{color:var(--muted)}
.ari-breadcrumbs a:hover{color:var(--rose)}
.pdp-wrap{padding-top:clamp(16px,2vw,26px);padding-bottom:clamp(40px,6vw,80px)}
.pdp-cols{gap:clamp(28px,4vw,56px)!important;align-items:flex-start}
/* Gallery sticks while the (taller) config column scrolls past, on desktop */
@media(min-width:981px){.pdp-gallery{position:sticky;top:96px}}
.pdp-gallery img{border-radius:var(--r-lg);box-shadow:var(--sh)}
.pdp-gallery .flex-control-thumbs img,.pdp-gallery .wc-block-components-product-image-gallery img{box-shadow:none}
.pdp-summary{display:flex;flex-direction:column;gap:12px}
/* Tighter H1 so price + configurator + add-to-cart sit above the fold */
.pdp-title{font-size:clamp(1.5rem,2.6vw,2.1rem);margin:0;line-height:1.1}
.pdp-headline{display:flex;align-items:center;gap:14px 18px;flex-wrap:wrap;margin:0}
.pdp-headline .wp-block-woocommerce-product-rating,.pdp-headline .wc-block-components-product-rating{margin:0}
.pdp-price,.pdp-summary .wp-block-woocommerce-product-price{font-size:1.5rem;font-weight:700;color:var(--ink);margin:0}
.pdp-headline .wc-block-components-product-rating .wc-block-components-product-rating__stars{color:var(--rose)}
.pdp-summary-text{color:#6c5d50;font-size:.96rem;line-height:1.6}
.pdp-intro{max-width:70ch;margin:clamp(24px,3vw,36px) 0 0}
.pdp-atc-form{background:var(--white);border-radius:var(--r-md);box-shadow:var(--sh-sm);padding:clamp(18px,2.4vw,24px);margin-top:2px}
.pdp-atc-form .stock{font-size:.82rem;font-weight:600;margin:0 0 12px}
.pdp-atc-form .stock.in-stock{color:#5a9e7a}
.pdp-atc-form .stock.out-of-stock{color:var(--rose-dk)}
.pdp-atc-form .variations{width:100%;margin-bottom:4px}
.pdp-atc-form .variations tbody,.pdp-atc-form .variations tr{display:block}
.pdp-atc-form .variations th{display:block;text-align:left;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700;padding:8px 0 4px}
.pdp-atc-form .variations td{display:block;padding:0 0 8px}
/* The native <select> is driven by the swatches (plugin hides it); keep a sane
   fallback style if JS is off. */
.pdp-atc-form .variations select,.pdp-atc-form select{
  width:100%;font-family:inherit;font-size:.9rem;color:var(--ink);background:var(--bg);
  border:1.5px solid rgba(58,42,33,.16);border-radius:var(--r-pill);padding:11px 18px}
.pdp-atc-form .variations select:focus,.pdp-atc-form select:focus{outline:none;border-color:var(--rose)}
.pdp-atc-form .reset_variations{font-size:.78rem;color:var(--rose);font-weight:600}
.pdp-atc-form .quantity input.qty{
  width:84px;font-family:inherit;font-size:.95rem;text-align:center;color:var(--ink);
  background:var(--bg);border:1.5px solid rgba(58,42,33,.16);border-radius:var(--r-pill);padding:12px 8px;margin-right:10px}
.pdp-atc-form .single_add_to_cart_button,.pdp-atc-form .wp-block-button__link{
  width:100%;display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  background:var(--rose);color:#fff;border:none;border-radius:var(--r-pill);
  padding:1.05em 2.2em;font-size:.98rem;font-weight:700;letter-spacing:.01em;cursor:pointer;
  box-shadow:0 10px 24px rgba(192,80,106,.22);
  transition:transform .25s,background .25s,box-shadow .25s}
.pdp-atc-form .single_add_to_cart_button::after{content:"→";font-weight:600;transition:transform .25s}
.pdp-atc-form .single_add_to_cart_button:hover{background:var(--rose-dk);transform:translateY(-3px);box-shadow:0 16px 32px rgba(192,80,106,.32)}
.pdp-atc-form .single_add_to_cart_button:hover::after{transform:translateX(4px)}
.pdp-atc-form .single_add_to_cart_button:disabled,.pdp-atc-form .single_add_to_cart_button.disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}
.pdp-atc-form .woocommerce-variation-add-to-cart{display:flex;align-items:center;flex-wrap:wrap;gap:12px;margin-top:10px}
.pdp-atc-form .woocommerce-variation-price{font-size:1.3rem;font-weight:700;color:var(--ink);margin:6px 0}
.pdp-summary .product_meta{font-size:.8rem;color:var(--muted);margin-top:4px}
.pdp-summary .product_meta a{color:var(--rose)}

/* Care panel */
.care-panel{background:var(--butter);border-radius:var(--r-md);box-shadow:var(--sh-sm);padding:clamp(26px,3vw,40px);margin-top:clamp(40px,5vw,64px)}
.care-panel .mk{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);opacity:.6;font-weight:700;margin-bottom:10px}
.care-panel h3{font-size:1.5rem;margin:0 0 6px}
.care-panel ul{list-style:none;margin:14px 0 0;padding:0}
.care-panel li{padding:10px 0;font-size:.95rem;display:flex;gap:11px;align-items:flex-start;color:#4a3c30}
.care-panel li+li{border-top:1px solid rgba(58,42,33,.1)}
.care-panel li .ck{flex:none;width:20px;height:20px;border-radius:50%;background:rgba(255,255,255,.85);display:flex;align-items:center;justify-content:center;font-size:.7rem;color:var(--rose);margin-top:1px;font-weight:800}

/* Product details / tabs */
.pdp-tabs{margin-top:clamp(40px,5vw,64px)}
.pdp-tabs .wc-tabs,.pdp-tabs ul.tabs{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 24px;padding:0;list-style:none;border:none}
.pdp-tabs .wc-tabs li,.pdp-tabs ul.tabs li{margin:0;padding:0;background:none;border:none}
.pdp-tabs .wc-tabs li a,.pdp-tabs ul.tabs li a{
  display:inline-block;background:var(--white);box-shadow:var(--sh-sm);border-radius:var(--r-pill);
  padding:11px 22px;font-size:.85rem;font-weight:600;color:var(--ink)}
.pdp-tabs .wc-tabs li.active a,.pdp-tabs ul.tabs li.active a{background:var(--rose);color:#fff}
.pdp-tabs h2{font-size:1.6rem;margin:0 0 14px}
.pdp-tabs .woocommerce-Reviews .comment-form input,
.pdp-tabs .woocommerce-Reviews .comment-form textarea{
  font-family:inherit;border:1.5px solid rgba(58,42,33,.16);border-radius:var(--r-sm);padding:12px 14px;background:var(--bg);width:100%}

/* Cross-sell row */
.ari-crosssell{margin-top:8px}
.crosssell-head{margin-top:clamp(48px,6vw,80px);margin-bottom:28px}
.crosssell-head h2{font-size:clamp(1.8rem,3.6vw,2.6rem)}
.crosssell-head h2 .fr{color:var(--rose)}

/* --- Sticky mobile add-to-cart --- */
.sticky-atc{position:fixed;left:0;right:0;bottom:0;z-index:90;display:none;align-items:center;gap:12px;
  background:rgba(253,251,248,.96);backdrop-filter:blur(12px);box-shadow:0 -6px 24px rgba(74,52,38,.1);
  padding:11px var(--pad);transform:translateY(120%);transition:transform .35s cubic-bezier(.2,.7,.2,1)}
.sticky-atc.show{transform:none}
.sticky-atc-info{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}
.sticky-atc-title{font-size:.92rem;font-weight:700;margin:0;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sticky-atc .wp-block-woocommerce-product-price{font-size:.86rem;font-weight:700;color:var(--ink)}
.sticky-atc-btn{flex:none;white-space:nowrap}
@media(max-width:768px){
  .sticky-atc{display:flex}
  .shop-sidebar{position:static}
}

/* Generic WooCommerce notices / messages, on-brand */
.woocommerce-message,.woocommerce-info,.woocommerce-error,.wc-block-components-notice-banner{
  border-radius:var(--r-sm);font-family:inherit}
.woocommerce-message{background:var(--mint);border:none;color:var(--ink)}
.woocommerce-message a.button,.woocommerce a.button.wc-forward{
  background:var(--rose);color:#fff;border-radius:var(--r-pill)}
