/* =========================================================
   Valentina Diamonds — main stylesheet
   Homepage implemented from Figma "Website Design"
   (desktop node 686-19041 + mobile node 686-20107).
   Brand: maroon #7f0f0f on white, Poppins, 2px buttons, 10px cards.
   Mobile-first; breakpoints at 768px and 1024px.
   ========================================================= */
@font-face{
  font-family:"Perpetua";
  src:url("perpetua.TTF") format("truetype");
  font-weight:normal;
  font-style:normal;
  font-display:swap;
}
:root{
  --maroon:#7f0f0f; --maroon-dark:#5e0a0a; --maroon-soft:#fbf3f3;
  --ink:#212529; --text:#343a40; --text-2:#495057; --muted:#6c757d;
  --white:#fff; --bg-soft:#f8f9fa; --bg-rose:#f5e9e9; --line:#e9ecef;
  --footer:#1a1010; --footer-2:#2a1817;
  --max:1600px; --gutter:clamp(20px,5vw,40px);
  --r-btn:2px; --r-card:10px;
  --sans:"Poppins",-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  --serif:"Perpetua",Georgia,"Times New Roman",serif;
  --shadow:0 12px 34px rgba(0,0,0,.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);font-weight:300;color:var(--text);background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.2;color:var(--ink);margin:0 0 .4em}
.section-head__title,.hero__title,.motion__title,.contact__title{font-family:var(--serif)}
.screen-reader-text{position:absolute!important;clip:rect(1px,1px,1px,1px);height:1px;width:1px;overflow:hidden}
.skip-link{position:absolute;left:-999px}
.skip-link:focus{left:1rem;top:1rem;background:#fff;padding:.5rem 1rem;z-index:1000}
.container{width:100%;max-width:var(--max);margin:0 auto;padding-inline:var(--gutter)}

/* Section rhythm */
.section{padding-block:clamp(48px,7vw,88px)}
.section--soft{background:var(--bg-soft)}
.section--tight{padding-block:clamp(36px,5vw,56px)}

/* Section heads */
.section-head{text-align:center;max-width:760px;margin:0 auto clamp(28px,4vw,44px)}
.section-head__title{font-size:clamp(24px,3.4vw,32px);letter-spacing:.005em;margin:0 0 14px}
.section-head__desc{font-weight:300;font-size:15px;line-height:1.75;color:var(--text-2);margin:0}
.section-head--left{text-align:left;margin-inline:0}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-weight:500;font-size:16px;line-height:1;height:52px;padding:0 24px;border:1px solid transparent;border-radius:var(--r-btn);cursor:pointer;transition:.2s;text-align:center;white-space:nowrap}
.btn svg{width:18px;height:18px;flex:0 0 auto}
.btn--primary{background:var(--maroon);color:#fff}
.btn--primary:hover{background:var(--maroon-dark)}
.btn--outline{background:transparent;color:var(--maroon);border-color:var(--maroon)}
.btn--outline:hover{background:var(--maroon);color:#fff}
.btn--light{background:#fff;color:var(--maroon)}
.btn--light:hover{background:#f1e6e6}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}
.btn--ghost:hover{background:#fff;color:var(--maroon)}
.btn--sm{height:46px;font-size:14px;padding:0 20px}
.btn--block{width:100%}

/* ---------- Header (two-row: logo+actions / diamond toggle + nav) ---------- */
.site-header{position:sticky;top:0;z-index:60;background:#fff;border-bottom:1px solid var(--line)}
.header-top__inner{position:relative;display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:84px}
.site-branding{display:flex;align-items:center}
.site-logo{display:block;height:auto;width:clamp(155px,18vw,200px)}
.header-actions{display:flex;gap:18px;align-items:center}
.header-action{position:relative;color:var(--ink);display:inline-flex;line-height:0;transition:.2s}
.header-action:hover{color:var(--maroon)}
.header-action svg{width:24px;height:24px}
.header-action__badge{position:absolute;top:-8px;right:-9px;background:var(--maroon);color:#fff;font-size:10px;font-weight:500;min-width:16px;height:16px;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 3px;line-height:1}
.header-cta{height:44px;padding:0 18px;font-size:14px}
.header-cta svg{width:16px;height:16px}
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;background:var(--maroon);border:0;border-radius:4px;cursor:pointer;flex:0 0 auto}
.nav-toggle span{width:26px;height:2px;background:#fff;margin-inline:auto;transition:.3s}

/* Row 2: diamond toggle + shop nav + more nav */
.header-bar{border-top:1px solid var(--line)}
.header-bar__inner{display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:56px}
.diamond-toggle{display:inline-flex;align-items:center;gap:4px;flex:0 0 auto}
.diamond-toggle__opt{background:none;border:0;cursor:pointer;font-family:inherit;font-size:14px;color:var(--muted);padding:6px 8px;position:relative;transition:.2s}
.diamond-toggle__opt:hover{color:var(--ink)}
.diamond-toggle__opt.is-active{color:var(--ink);font-weight:500}
.diamond-toggle__opt.is-active::after{content:"";position:absolute;left:8px;right:8px;bottom:-1px;height:2px;background:var(--maroon)}
.nav-shop,.nav-more{min-width:0}
.nav-shop__list{display:flex;gap:26px;list-style:none;margin:0;padding:0}
.nav-shop__list a{font-size:14px;font-weight:400;color:var(--ink);padding:14px 0;position:relative;white-space:nowrap;display:block}
.nav-shop__list a::after{content:"";position:absolute;left:0;right:100%;bottom:8px;height:1.5px;background:var(--maroon);transition:right .3s}
.nav-shop__list a:hover::after{right:0}
.nav-shop__item{position:relative}
/* Desktop subnav dropdown */
.subnav{position:absolute;top:100%;left:-14px;min-width:218px;background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:0 18px 40px rgba(0,0,0,.12);padding:8px;opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .2s,transform .2s;z-index:70}
.nav-shop__item.has-sub:hover>.subnav,.nav-shop__item.has-sub:focus-within>.subnav{opacity:1;visibility:visible;transform:none}
.subnav ul{list-style:none;margin:0;padding:0}
.subnav a{display:block;padding:9px 12px;border-radius:6px;font-size:14px;font-weight:300;color:var(--text-2)}
.subnav a::after{display:none}
.subnav a:hover{background:var(--maroon-soft);color:var(--maroon)}
.subnav__all{color:var(--maroon);font-weight:500;border-top:1px solid var(--line);border-radius:0;margin-top:6px;padding-top:11px}
/* Mobile drawer (hidden on desktop) */
.mobile-menu{display:none}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:520px;display:flex;align-items:flex-end;color:#fff;overflow:hidden;background:#2b2b2b}
.hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 30%}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,0) 35%,rgba(0,0,0,.82) 100%)}
.hero__inner{position:relative;z-index:2;width:100%;padding-block:clamp(40px,7vw,80px)}
.hero__title{max-width:780px;font-weight:300;font-size:clamp(30px,5vw,54px);line-height:1.12;letter-spacing:-.01em;margin:0 0 26px;
  background:linear-gradient(96.87deg,#adb5bd 0%,#fff 48.5%,#adb5bd 64.4%,#fff 76.9%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}

/* ---------- Category cards (image + title + CTA) ---------- */
.cat-tiles{display:grid;grid-template-columns:1fr;gap:clamp(30px,4vw,36px)}
.cat-tile{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;min-width:0}
.cat-tile__media{position:relative;display:block;width:100%;aspect-ratio:1;border-radius:var(--r-card);overflow:hidden;background:var(--bg-soft)}
.cat-tile__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .4s}
.cat-tile__media:hover .cat-tile__img{transform:scale(1.05)}
.cat-tile__title{font-family:var(--serif);font-weight:400;font-size:clamp(20px,2.2vw,26px);letter-spacing:.06em;text-transform:uppercase;color:var(--ink);margin:0}
.cat-tile .btn{align-self:center;max-width:100%;height:auto;min-height:46px;white-space:normal;padding-block:10px;line-height:1.35}

/* ---------- Diamond shapes (mobile carousel → desktop grid + feature) ---------- */
.shapes2{display:grid;grid-template-columns:1fr;gap:clamp(26px,4vw,40px);align-items:center}
.shapes2__intro{display:flex;flex-direction:column;align-items:center;text-align:center;gap:22px}
.shapes2__intro .section-head__title{margin:0}
.shapes2__feature{width:100%;max-width:340px;border-radius:var(--r-card);margin-inline:auto}
/* mobile: horizontal swipe carousel */
.shapes2__grid{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;padding-bottom:2px}
.shapes2__grid::-webkit-scrollbar{display:none}
.shape-tile{flex:0 0 30%;scroll-snap-align:start;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;transition:transform .2s}
.shape-tile:hover{transform:translateY(-4px)}
.shape-tile__img{width:100%;max-width:118px;aspect-ratio:1;object-fit:contain;mix-blend-mode:multiply}
.shape-tile__label{font-size:15px;color:var(--ink)}
.shapes2__progress{height:3px;background:var(--line);border-radius:3px;position:relative;overflow:hidden;margin-top:4px}
.shapes2__progress span{position:absolute;left:0;top:0;height:100%;width:30%;background:var(--maroon);border-radius:3px;transition:left .15s}
@media(min-width:768px){
  .shapes2__intro{align-items:flex-start;text-align:left}
  .shapes2__feature{margin-inline:0}
  .shapes2__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px 12px;overflow:visible}
  .shape-tile{flex:none}
  .shapes2__progress{display:none}
}
@media(min-width:1024px){
  .shapes2{grid-template-columns:0.8fr 2.4fr;align-items:start}
  .shapes2__grid{grid-template-columns:repeat(5,1fr);border-left:1px solid var(--line);padding-left:clamp(24px,3vw,48px)}
}

/* ---------- Card grids (styles / products) ---------- */
.card-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.style-strip{display:grid;grid-template-columns:repeat(2,1fr);gap:24px 14px;max-width:var(--max);margin-inline:auto;padding-inline:var(--gutter)}
@media(min-width:600px){ .style-strip{grid-template-columns:repeat(3,1fr)} }
@media(min-width:900px){ .style-strip{grid-template-columns:repeat(6,1fr)} }
.style-card{display:flex;flex-direction:column;gap:12px}
.style-card__box{position:relative;aspect-ratio:1;border-radius:var(--r-card);overflow:hidden;background:linear-gradient(135deg,#f3e6e6,#e6d2d2);display:flex;align-items:center;justify-content:center;transition:.25s}
.style-card:hover .style-card__box{box-shadow:var(--shadow);transform:translateY(-4px)}
.style-card__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.style-card__ph{display:flex;color:#c9a9a9}
.style-card__ph svg{width:44px;height:44px}
.style-card__label{text-align:center;color:var(--ink);font-size:15px;font-weight:400}
.product-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-card);overflow:hidden;transition:.25s}
.product-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.product-card__media{aspect-ratio:1;background:linear-gradient(135deg,#f3e6e6,#e6d2d2);position:relative;display:flex;align-items:center;justify-content:center;color:#c9a9a9}
.product-card__media svg{width:46px;height:46px}
.product-card__body{padding:16px 18px}
.product-card__title{font-size:16px;margin:0 0 6px}
.product-card__price{color:var(--maroon);font-weight:500;margin:0}

/* ---------- Trending columns (mobile carousel → desktop 3-up) ---------- */
.trending-cols{position:relative;display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;scroll-padding-inline:var(--gutter)}
.trending-cols::-webkit-scrollbar{display:none}
.trend-col{flex:0 0 100%;scroll-snap-align:center;display:flex;flex-direction:column;align-items:center;gap:24px;text-align:center}
.trend-col__head{display:flex;flex-direction:column;align-items:center;gap:14px;width:100%}
.trend-col__rule{width:160px;max-width:55%;height:1px;background:rgba(0,0,0,.3)}
.trend-col__title{font-family:var(--serif);text-transform:uppercase;font-size:clamp(24px,2.9vw,38px);line-height:1.1;letter-spacing:.02em;color:rgba(0,0,0,.42);margin:0;white-space:nowrap}
.trend-col__img{width:100%;aspect-ratio:543/731;object-fit:cover;border-radius:var(--r-card)}
.trend-col__desc{font-weight:300;font-size:14px;line-height:1.7;color:var(--ink);max-width:340px;margin:0;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
@media(min-width:768px){ .trending-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;overflow:visible} .trend-col{flex:none} }

/* ---------- Valentina difference (mobile carousel → desktop grid) ---------- */
.diff-grid{position:relative;display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;scroll-padding-inline:var(--gutter)}
.diff-grid::-webkit-scrollbar{display:none}
.diff-card{flex:0 0 100%;scroll-snap-align:center;display:flex;flex-direction:column;border:1px solid var(--maroon);border-radius:10px;overflow:hidden;background:#fff}
.diff-card__img{width:100%;aspect-ratio:338/229;object-fit:cover;display:block}
.diff-card__stat{background:rgba(127,15,15,.94);color:#fff;text-align:center;font-family:var(--serif);font-weight:400;font-size:clamp(30px,3vw,44px);line-height:1.1;padding:14px 10px}
.diff-card__body{display:flex;flex-direction:column;gap:12px;padding:22px 22px 26px;text-align:center}
.diff-card__title{font-size:clamp(20px,1.8vw,24px);margin:0}
.diff-card__desc{font-weight:300;font-size:15px;line-height:1.7;color:var(--ink);margin:0}
@media(min-width:768px){ .diff-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;overflow:visible} .diff-card{flex:none} }
@media(min-width:1000px){ .diff-grid{grid-template-columns:repeat(4,1fr);gap:16px} }

/* ---------- Carousel dots (mobile pagination) ---------- */
.carousel-dots{display:none;justify-content:center;gap:8px;margin-top:22px}
.carousel-dots .carousel-dot{width:8px;height:8px;padding:0;border:0;border-radius:50%;background:#d9c6c6;cursor:pointer;transition:width .25s,background .25s}
.carousel-dots .carousel-dot.is-active{background:var(--maroon);width:22px;border-radius:5px}
@media(max-width:767px){ .carousel-dots{display:flex} }

/* ---------- Reviews carousel (Figma 720-180670) ---------- */
.reviews{display:grid;grid-template-columns:1fr;gap:clamp(28px,4vw,48px);align-items:start}
.reviews__intro{max-width:460px}
.reviews__intro .section-head__title{text-align:left;margin:0 0 16px}
.reviews__lede{font-weight:300;font-size:16px;line-height:1.75;color:var(--ink);margin:0 0 24px}
.google-badge{display:inline-flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:8px 14px;box-shadow:var(--shadow)}
.google-badge__g{font-weight:600;font-size:18px;font-family:var(--sans);letter-spacing:-.02em}
.google-badge__rating{font-size:12px;color:var(--muted);line-height:1.2}
.google-badge__stars{color:#e8b923;letter-spacing:1px}
.reviews__col{min-width:0}
.reviews__track{display:flex;gap:30px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding-bottom:6px;scrollbar-width:none}
.reviews__track::-webkit-scrollbar{display:none}
.review-card{flex:0 0 86%;max-width:440px;margin:0;scroll-snap-align:start;background:#f4f4f4;border-radius:10px;padding:28px;display:flex;flex-direction:column;gap:16px}
.review-card__stars{color:#e8b923;letter-spacing:2px;font-size:15px}
.review-card blockquote{margin:0;font-weight:300;font-size:15px;line-height:1.7;color:var(--ink)}
.review-card figcaption{margin-top:auto;font-size:15px;color:var(--ink)}
.reviews__nav{display:flex;align-items:center;gap:16px;margin-top:24px}
.reviews__arrows{display:flex;gap:10px}
.reviews__arrow{width:42px;height:42px;border-radius:50%;border:1px solid var(--line);background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink);font-size:20px;line-height:1;transition:.2s}
.reviews__arrow:hover{border-color:var(--maroon);color:var(--maroon)}
.reviews__progress{flex:1;height:3px;background:var(--line);border-radius:3px;position:relative;overflow:hidden}
.reviews__progress span{position:absolute;left:0;top:0;height:100%;width:32%;background:var(--maroon);border-radius:3px;transition:left .2s}
@media(min-width:900px){
  .reviews{grid-template-columns:380px 1fr}
  .review-card{flex-basis:47%}
}

/* ---------- Experience in motion ---------- */
.motion__inner{display:grid;grid-template-columns:1fr;gap:clamp(28px,5vw,56px);align-items:center}
.motion__title{font-size:clamp(24px,3.4vw,32px);margin:0 0 18px}
.motion__desc{font-weight:300;color:var(--text-2);line-height:1.8;margin:0 0 28px}
.motion__cta{display:flex;flex-wrap:wrap;gap:14px}
.motion__video{position:relative;border-radius:var(--r-card);overflow:hidden;aspect-ratio:16/11;background:#222}
.motion__video img{width:100%;height:100%;object-fit:cover}
.motion__play{position:absolute;inset:0;margin:auto;width:72px;height:72px;border-radius:50%;background:#fff;color:var(--maroon);border:0;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 8px 24px rgba(0,0,0,.35);transition:.2s}
.motion__play:hover{transform:scale(1.06);background:#f3e7e7}
.motion__play svg{width:26px;height:26px;margin-left:3px}

/* ---------- Valentina difference (features + stat) ---------- */
.features{display:grid;grid-template-columns:1fr;gap:20px}
.feature{text-align:center;padding:28px 22px;border:1px solid var(--line);border-radius:var(--r-card);background:#fff;transition:.25s}
.feature:hover{box-shadow:var(--shadow);border-color:transparent}
.feature__icon{width:60px;height:60px;margin:0 auto 18px;border-radius:50%;background:var(--maroon-soft);color:var(--maroon);display:flex;align-items:center;justify-content:center}
.feature__icon svg{width:30px;height:30px}
.feature__title{font-size:18px;margin:0 0 10px}
.feature__desc{font-weight:300;font-size:14px;line-height:1.7;color:var(--text-2);margin:0}
.feature__stat{font-size:30px;font-weight:500;color:var(--maroon);line-height:1;margin:0 0 8px}

/* ---------- Instagram ---------- */
.insta-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.insta-cell{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;background:linear-gradient(135deg,#f3e6e6,#e3cccc);display:flex;align-items:center;justify-content:center;color:#bd9a9a;transition:.25s}
.insta-cell img{width:100%;height:100%;object-fit:cover}
.insta-cell svg{width:34px;height:34px}
.insta-cell:hover{filter:brightness(.94)}

/* ---------- Testimonials ---------- */
.testimonials__grid{display:grid;grid-template-columns:1fr;gap:20px}
.testimonial{background:#fff;border:1px solid var(--line);border-radius:var(--r-card);padding:28px;display:flex;flex-direction:column;gap:16px}
.testimonial__brand{display:flex;align-items:center;gap:8px;color:#1877f2}
.testimonial__brand svg{width:22px;height:22px}
.testimonial__stars{color:#e8b923;letter-spacing:2px;font-size:15px}
.testimonial blockquote{margin:0;font-weight:300;font-size:15px;line-height:1.75;color:var(--text-2)}
.testimonial figcaption{margin-top:auto;font-weight:500;font-size:14px;color:var(--ink)}

/* ---------- Get in touch ---------- */
.contact{background:transparent;position:relative;z-index:2;padding-bottom:0;padding-inline:clamp(20px,5vw,40px)}
.contact__card{position:relative;z-index:2;max-width:1400px;margin:0 auto -150px;background:var(--maroon);color:#fff;text-align:center;border-radius:12px;padding:clamp(40px,5vw,62px) clamp(40px,5.5vw,84px)}
.contact__card::before{content:"";position:absolute;inset:16px;border:2px dashed rgba(255,255,255,.45);border-radius:8px;pointer-events:none}
.contact__title{color:#fff;font-size:clamp(24px,3.4vw,32px);margin:0 0 16px;text-align:left}
.contact__form{display:grid;grid-template-columns:repeat(3,1fr);gap:14px 22px;text-align:left;max-width:820px;margin-left:auto;margin-right:0;width:100%}
.field--full{grid-column:1/-1}
@media(max-width:640px){ .contact__form{grid-template-columns:1fr} }
.field label{display:block;font-size:14px;color:rgba(255,255,255,.85);margin-bottom:8px}
.field input,.field textarea{width:100%;background:transparent;border:0;border-bottom:1px solid rgba(255,255,255,.5);color:#fff;font-family:inherit;font-size:16px;font-weight:300;padding:8px 0;transition:.2s}
.field textarea{resize:vertical;min-height:44px}
.field input::placeholder,.field textarea::placeholder{color:rgba(255,255,255,.6)}
.field input:focus,.field textarea:focus{outline:0;border-bottom-color:#fff}
.contact__submit{grid-column:1/-1;justify-self:start;margin-top:6px}
/* Get in Touch — Contact Form 7 outputs its own <form class="wpcf7-form">, not
   .contact__form, so mirror the grid onto it: Name/Email/Phone row, Message full,
   left-aligned labels (overrides the card's centered text). Applies on every page
   that uses the contact card (Home, FAQ, About, Education). */
.contact__card .wpcf7-form{display:grid;grid-template-columns:repeat(3,1fr);gap:14px 22px;text-align:left;max-width:820px;margin:0 0 0 auto;width:100%}
.contact__card .wpcf7-form .field--full{grid-column:1/-1}
.contact__card .wpcf7-form input[type=submit],.contact__card .wpcf7-form .contact__submit{grid-column:1/-1;justify-self:start;margin-top:6px}
.contact__card .wpcf7-form .wpcf7-response-output{grid-column:1/-1;margin:6px 0 0}
@media(max-width:640px){ .contact__card .wpcf7-form{grid-template-columns:1fr} }

/* ---------- Footer ---------- */
.site-footer{background:var(--footer);color:#cdbdbb}
.footer-top{display:grid;grid-template-columns:1fr;gap:clamp(32px,5vw,56px);padding-top:clamp(180px,18vw,210px);padding-bottom:clamp(40px,6vw,64px);border-bottom:1px solid rgba(255,255,255,.1)}
.footer-connect{text-align:center;max-width:560px;margin:0 auto}
.footer-logo{height:45px;width:auto;max-width:100%;margin:0 auto 22px;filter:brightness(0) invert(1)}
@media(max-width:640px){ .footer-logo{height:auto;width:min(72vw,320px)} }
.footer-connect__title{color:#fff;font-size:15px;font-weight:500;letter-spacing:.04em;margin:0 0 22px}
.footer-contact{display:flex;flex-direction:column;gap:14px;margin-bottom:24px}
.footer-contact__row{display:flex;align-items:center;justify-content:center;gap:10px;font-size:14px;font-weight:300}
.footer-contact__row svg{width:20px;height:20px;color:var(--maroon-soft);flex:0 0 auto}
.footer-contact__row a:hover{color:#fff}
.footer-nav{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.footer-col__title{color:#fff;font-size:14px;font-weight:500;letter-spacing:.05em;margin:0 0 16px}
.footer-menu{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.footer-menu a{font-size:14px;font-weight:300}
.footer-menu a:hover{color:#fff}
.footer-bottom{display:flex;flex-direction:column;gap:18px;align-items:center;padding-block:24px;text-align:center}
.pay-methods{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:center}
.pay-methods .pay{height:28px;min-width:46px;padding:0 9px;border-radius:4px;background:#fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 1px 3px rgba(0,0,0,.16)}
.pay-methods .pay svg{height:16px;width:auto;display:block}
.pay-methods .pay img{height:17px;width:auto;display:block}
.footer-copy{font-size:12.5px;font-weight:300;color:#a99}
.footer-copy a:hover{color:#fff}

/* ---------- Trending title letter animation ---------- */
.trend-col__title .ltr{display:inline-block;opacity:0;transform:translateY(.5em);transition:opacity .5s ease,transform .5s ease}
.trend-col__title.is-in .ltr{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.trend-col__title .ltr{opacity:1!important;transform:none!important;transition:none}}

/* ---------- Chat widget ---------- */
.chat-fab{position:fixed;right:22px;bottom:22px;z-index:80;width:60px;height:60px;border-radius:50%;background:var(--maroon);color:#fff;border:0;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 8px 24px rgba(0,0,0,.28);transition:transform .2s,background .2s}
.chat-fab:hover{transform:scale(1.06);background:var(--maroon-dark)}
.chat-fab svg{width:28px;height:28px}
.chat-panel{position:fixed;right:22px;bottom:94px;z-index:80;width:300px;max-width:calc(100vw - 44px);background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 18px 50px rgba(0,0,0,.22);overflow:hidden;transform:translateY(12px) scale(.96);transform-origin:bottom right;opacity:0;visibility:hidden;transition:.22s}
.chat-panel.is-open{opacity:1;visibility:visible;transform:none}
.chat-panel__head{background:var(--maroon);color:#fff;padding:18px 20px}
.chat-panel__head strong{display:block;font-size:18px}
.chat-panel__head span{font-size:13px;font-weight:300;opacity:.85}
.chat-panel__body{padding:18px 20px;font-size:14px;font-weight:300;line-height:1.6;color:var(--text-2)}
.chat-panel__body .btn{margin-top:14px;width:100%}

/* ============ Tablet ============ */
@media(min-width:768px){
  .cat-tiles{grid-template-columns:repeat(3,1fr)}
  .cat-tile__media{aspect-ratio:3/4}
  .card-grid{grid-template-columns:repeat(3,1fr)}
  .features{grid-template-columns:repeat(2,1fr)}
  .insta-grid{grid-template-columns:repeat(3,1fr)}
  .testimonials__grid{grid-template-columns:repeat(2,1fr)}
  .footer-nav{grid-template-columns:repeat(3,1fr)}
  .footer-bottom{flex-direction:row;justify-content:space-between}
}

/* ============ Desktop ============ */
@media(min-width:1024px){
  .hero{min-height:660px}
  .shapes__grid{grid-template-columns:repeat(10,1fr)}
  .motion__inner{grid-template-columns:1fr 1fr}
  .card-grid--4{grid-template-columns:repeat(4,1fr)}
  .features{grid-template-columns:repeat(4,1fr)}
  .insta-grid{grid-template-columns:repeat(6,1fr)}
  .testimonials__grid{grid-template-columns:repeat(3,1fr)}
  .footer-top{grid-template-columns:1.1fr 1.6fr;align-items:start}
  .footer-connect{text-align:left;max-width:none;margin:0}
  .footer-connect .footer-logo{margin-inline:0}
  .footer-contact__row{justify-content:flex-start}
}

/* ============ Mobile header behaviour ============ */
@media(max-width:1179px){
  .nav-toggle{display:inline-flex}
  .header-bar{display:none}            /* row 2 collapses into the drawer */
  .header-cta{display:none}            /* Appointment button moves into the drawer */
  .site-branding{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}
  .site-logo{width:auto;height:68px}
  body.nav-open{overflow:hidden}
  .mobile-menu{display:block;position:fixed;inset:84px 0 0 0;background:#fff;transform:translateX(-100%);transition:transform .3s ease;overflow-y:auto;-webkit-overflow-scrolling:touch;z-index:55}
  .mobile-menu.is-open{transform:none}
  .mobile-menu__inner{padding:18px var(--gutter) 44px;display:flex;flex-direction:column}
  .diamond-toggle--mobile{align-self:flex-start;border:1px solid var(--line);border-radius:7px;padding:3px;margin-bottom:14px}
  .diamond-toggle--mobile .diamond-toggle__opt{padding:8px 16px;border-radius:5px}
  .diamond-toggle--mobile .diamond-toggle__opt.is-active{background:var(--maroon);color:#fff;font-weight:500}
  .diamond-toggle--mobile .diamond-toggle__opt.is-active::after{display:none}
  .mobile-menu__list{list-style:none;margin:0;padding:0}
  .m-item{border-bottom:1px solid var(--line)}
  .m-divider{border:0;height:10px}
  .m-link{display:flex;align-items:center;justify-content:space-between;width:100%;gap:12px;background:none;border:0;padding:15px 2px;font-family:inherit;font-size:16px;font-weight:400;color:var(--ink);text-align:left;cursor:pointer}
  .m-chev{width:18px;height:18px;color:var(--muted);flex:0 0 auto;transition:transform .25s}
  .m-item.has-msub.is-open .m-chev{transform:rotate(180deg)}
  .m-sub{list-style:none;margin:0;padding:0;max-height:0;overflow:hidden;transition:max-height .32s ease}
  .m-item.has-msub.is-open .m-sub{max-height:560px}
  .m-sub a{display:block;padding:11px 14px;font-size:15px;font-weight:300;color:var(--text-2)}
  .m-sub a::after{display:none}
  .m-sub__all{color:var(--maroon);font-weight:500}
  .m-sub li:last-child a{padding-bottom:16px}
  .mobile-menu__cta{margin-top:22px}
}
@media(max-width:520px){
  .shapes__grid{grid-template-columns:repeat(3,1fr)}
  .insta-grid{grid-template-columns:repeat(2,1fr)}
}

/* ============================================================
   Inner pages: product listing + product detail
   ============================================================ */
/* ----- Inner-page hero banner ----- */
.page-hero{position:relative;min-height:468px;display:flex;align-items:center;color:#fff;overflow:hidden;background:#2b2b2b}
.page-hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 25%}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.9) 0%,rgba(0,0,0,.78) 30%,rgba(0,0,0,.3) 46%,rgba(0,0,0,0) 60%)}
.page-hero__inner{position:relative;z-index:2;width:100%}
.page-hero__eyebrow,.page-hero__title,.page-hero__text{max-width:560px}
.page-hero__title{color:#fff;font-size:clamp(30px,4vw,52px);line-height:1.12;margin:0 0 16px}
.page-hero__text{font-weight:300;color:#eee;line-height:1.7;margin:0 0 24px}
.page-hero__eyebrow{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:clamp(15px,1.8vw,19px);color:#fff;margin:0 0 16px}
.page-hero__eyebrow svg{width:24px;height:24px;flex:0 0 auto}
.page-hero__cta{display:flex;gap:14px;flex-wrap:wrap}
.page-hero__cta .btn svg{width:18px;height:18px;margin-right:8px}
.page-hero__note{font-size:13px;color:rgba(255,255,255,.82);font-weight:300;margin:14px 0 0;max-width:430px}
@media(max-width:767px){ .page-hero,.page-hero.page-hero--tall{min-height:600px} }

.breadcrumb{font-size:13px;color:var(--muted);padding-block:18px}
.breadcrumb a:hover{color:var(--maroon)}

/* ----- Shop layout ----- */
.shop{display:grid;grid-template-columns:1fr;gap:34px}
@media(min-width:900px){
  .shop{grid-template-columns:288px 1fr;gap:42px}
  /* Desktop filter sidebar = bordered rounded card (Figma 684-1031) */
  .filters{border:1px solid rgba(127,15,15,.5);border-radius:14px;padding:24px 22px;gap:0;align-self:start;position:sticky;top:96px}
  .filters .filter{padding-top:18px}
  .filters .filter:first-child{padding-top:0}
}
.shop-bar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.shop-bar__count{font-size:14px;color:var(--muted)}
.shop-bar select{font-family:inherit;font-size:14px;padding:9px 14px;border:1px solid var(--line);border-radius:4px;background:#fff;color:var(--ink)}
.filters{display:flex;flex-direction:column;gap:18px}
.filter{border-bottom:1px solid var(--line);padding-bottom:18px}
.filter__title{font-family:var(--serif);font-size:17px;margin:0 0 14px}
.filter__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.filter__list label{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:300;color:var(--text);cursor:pointer}
.filter__list input{accent-color:var(--maroon);width:15px;height:15px}
.filter-shapes{display:flex;flex-wrap:wrap;gap:10px}
.filter-shapes a{width:46px;height:46px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ink)}
.filter-shapes a:hover{border-color:var(--maroon);color:var(--maroon)}
.filter-shapes svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:1.4}

/* ----- Filter sidebar v2 (Figma 684-1031) ----- */
.fil{border-bottom:1px solid var(--line);padding:18px 0}
.fil:first-child{padding-top:0}
.fil--last,.fil:last-child{border-bottom:0;padding-bottom:0}
.fil__title{font-family:var(--serif);font-size:18px;color:var(--ink);margin:0}
.fil--inline{display:flex;align-items:center;justify-content:space-between}
.fil__head{display:flex;align-items:center;justify-content:space-between;width:100%;gap:12px;background:none;border:0;padding:0;cursor:pointer;font-family:inherit;text-align:left}
.fil-chev{width:18px;height:18px;flex:0 0 auto;color:var(--muted);transition:transform .25s}
.fil--collapsible.is-collapsed .fil-chev{transform:rotate(180deg)}
.fil__body{margin-top:15px}
.fil--collapsible.is-collapsed .fil__body{display:none}
/* toggle switch */
.fil-switch{position:relative;display:inline-block;width:46px;height:26px;flex:0 0 auto;cursor:pointer}
.fil-switch input{position:absolute;opacity:0;width:0;height:0}
.fil-switch__track{position:absolute;inset:0;background:#dcc9c9;border-radius:999px;transition:.2s}
.fil-switch__track::before{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:.2s;box-shadow:0 1px 2px rgba(0,0,0,.2)}
.fil-switch input:checked+.fil-switch__track{background:var(--maroon)}
.fil-switch input:checked+.fil-switch__track::before{transform:translateX(20px)}
/* origin pills */
.fil-pills{display:flex;flex-wrap:wrap;gap:10px}
.fil-pill{font-family:inherit;font-size:13px;padding:9px 16px;border-radius:999px;border:1px solid var(--maroon);background:#fff;color:var(--maroon);cursor:pointer;transition:.18s}
.fil-pill:hover{background:var(--maroon-soft)}
.fil-pill.is-active{background:var(--maroon);color:#fff}
/* range slider */
.fil-range__input{-webkit-appearance:none;appearance:none;width:100%;height:4px;border-radius:3px;background:var(--line);outline:none;cursor:pointer}
.fil-range__input::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--maroon);border:2px solid #fff;box-shadow:0 0 0 1px var(--maroon);cursor:pointer}
.fil-range__input::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--maroon);border:2px solid #fff;cursor:pointer}
.fil-range__labels{display:flex;justify-content:space-between;margin-top:11px;font-size:12px;color:var(--muted)}
.fil-range__labels .js-range-val{color:var(--maroon);font-weight:600}
/* shape / category option rows */
.fil-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.fil-opt{display:flex;align-items:center;gap:12px;width:100%;background:none;border:0;padding:8px 4px;font-family:inherit;font-size:15px;color:var(--ink);cursor:pointer;text-align:left;transition:color .15s}
.fil-opt:hover{color:var(--maroon)}
.fil-opt.is-active{color:var(--maroon);font-weight:500}
.fil-opt__ico{width:26px;height:26px;flex:0 0 auto;background-color:currentColor;-webkit-mask-position:center;mask-position:center;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}
/* material radios */
.fil-radios{display:flex;flex-direction:column;gap:13px}
.fil-radio{display:flex;align-items:center;gap:12px;font-size:15px;color:var(--ink);cursor:pointer}
.fil-radio input{accent-color:var(--maroon);width:16px;height:16px;flex:0 0 auto}

/* ----- Mobile filter toolbar (Show Filter + sort + currency) ----- */
.shop-toolbar{display:none}
.filter-toggle{display:inline-flex;align-items:center;gap:9px;background:var(--maroon);color:#fff;border:0;border-radius:8px;padding:11px 16px;font-family:inherit;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s;white-space:nowrap}
.filter-toggle:hover{background:var(--maroon-dark)}
.filter-toggle svg{width:18px;height:18px;flex:0 0 auto}
.shop-tool-select{padding:11px 14px;border:1px solid var(--line);border-radius:8px;background:#fff;font-family:inherit;font-size:14px;color:var(--ink);cursor:pointer}
.shop-cur{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);border-radius:8px;padding-left:10px;background:#fff;flex:0 0 auto}
.shop-cur__flag{width:22px;height:15px;border-radius:2px;flex:0 0 auto;display:block}
.shop-cur select{border:0;background:none;font-family:inherit;font-size:14px;color:var(--ink);padding:11px 8px 11px 2px;cursor:pointer}
@media(max-width:899px){
  .shop-toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:18px}
  .shop-toolbar .shop-tool-select{flex:1;min-width:120px}
  .filters{display:none;margin:0}
  .filters.is-open{display:flex;margin-bottom:10px}
  .shop-bar{display:none}
}

/* ----- Product card (listing + related) ----- */
.products{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
@media(min-width:700px){ .products{grid-template-columns:repeat(3,1fr)} }
@media(min-width:900px){ .products--related{grid-template-columns:repeat(4,1fr)} }
.product{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--r-card);overflow:hidden;background:#fff;transition:.25s}
.product:hover{box-shadow:var(--shadow)}
.product__media{position:relative;aspect-ratio:1;background:var(--bg-soft)}
.product__media img{width:100%;height:100%;object-fit:cover}
.product__compare{position:absolute;top:10px;right:12px;font-size:12px;color:var(--muted);background:rgba(255,255,255,.85);border-radius:4px;padding:3px 8px;cursor:pointer;user-select:none;transition:.18s;z-index:2}
.product__compare:hover{color:var(--maroon)}
.product.is-comparing .product__compare{background:var(--maroon);color:#fff}
.product.is-comparing{box-shadow:0 0 0 2px var(--maroon)}
.product__body{padding:16px 16px 0;display:flex;flex-direction:column;gap:7px;flex:1;text-align:center}
.product__name{font-size:14px;font-weight:300;line-height:1.45;color:var(--ink)}
.product__price{color:var(--maroon);font-weight:500;font-size:14px}
.product__price small{color:var(--muted);font-weight:300;font-size:12px}
.product .btn{border-radius:0;width:100%;margin-top:14px}
.pagination{display:flex;justify-content:center;gap:8px;margin-top:34px}
.pagination a{min-width:38px;height:38px;padding:0 6px;border:1px solid var(--line);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--ink)}
.pagination a:hover{border-color:var(--maroon);color:var(--maroon)}
.pagination a.is-active{background:var(--maroon);color:#fff;border-color:var(--maroon)}

/* ----- Promo banner ----- */
.promo{display:grid;grid-template-columns:1fr;border-radius:var(--r-card);overflow:hidden;background:var(--maroon);color:#fff}
@media(min-width:768px){ .promo{grid-template-columns:1fr 1fr} }
.promo__img{position:relative;min-height:260px}
.promo__img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.promo__body{display:flex;flex-direction:column;gap:16px;justify-content:center;padding:clamp(28px,4vw,56px)}
.promo__title{color:#fff;font-size:clamp(24px,3vw,36px);margin:0}
.promo__body p{font-weight:300;line-height:1.7;margin:0;color:#f0e3e3}

/* ----- Signature 3-tile (reuse trending columns visual, simpler) ----- */
.sig-tiles{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:768px){ .sig-tiles{grid-template-columns:repeat(3,1fr)} }
.sig-tile{position:relative;border-radius:var(--r-card);overflow:hidden;aspect-ratio:4/3}
.sig-tile img{width:100%;height:100%;object-fit:cover}
.sig-tile span{position:absolute;left:0;right:0;bottom:0;padding:18px;color:#fff;font-family:var(--serif);font-size:20px;background:linear-gradient(to top,rgba(0,0,0,.65),transparent)}

/* ----- USP icon row (product page) ----- */
.usp-row{display:grid;grid-template-columns:1fr;gap:30px}
.usp{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}
.usp__icon{width:52px;height:52px;border-radius:50%;background:var(--maroon-soft);color:var(--maroon);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.usp__icon svg{width:26px;height:26px}
.usp__title{font-size:18px;margin:0}
.usp__desc{font-weight:300;font-size:14px;line-height:1.7;color:var(--text-2);max-width:280px;margin:0}
@media(min-width:768px){
  .usp-row{grid-template-columns:repeat(4,1fr)}
  .usp{padding-inline:22px;position:relative}
  .usp + .usp::before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:1px;background:var(--line)}
}
/* USP as a swipe carousel on mobile (product page) */
@media(max-width:767px){
  .usp-row--carousel{display:flex;grid-template-columns:none;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;scroll-padding-inline:var(--gutter)}
  .usp-row--carousel::-webkit-scrollbar{display:none}
  .usp-row--carousel .usp{flex:0 0 100%;scroll-snap-align:center}
}

/* ----- Product detail (PDP) ----- */
.pdp{display:grid;grid-template-columns:1fr;gap:clamp(28px,4vw,48px)}
@media(min-width:900px){ .pdp{grid-template-columns:1fr 1fr;align-items:start} }
.gallery{display:grid;grid-template-columns:72px 1fr;gap:14px}
.gallery__thumbs{display:flex;flex-direction:column;gap:10px}
.gallery__thumb{width:72px;height:72px;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--bg-soft);cursor:pointer;padding:0}
.gallery__thumb.is-active{border-color:var(--maroon)}
.gallery__thumb img{width:100%;height:100%;object-fit:cover}
.gallery__main{border:1px solid var(--line);border-radius:10px;overflow:hidden;aspect-ratio:1;background:var(--bg-soft)}
.gallery__main img{width:100%;height:100%;object-fit:cover}
@media(max-width:767px){
  .gallery{display:flex;flex-direction:column;gap:10px}
  .gallery__main{order:1}
  .gallery__thumbs{order:2;flex-direction:row;gap:8px}
  .gallery__thumb{flex:1;width:auto;height:auto;aspect-ratio:1}
}
.pdp-info__title{font-size:clamp(24px,3vw,32px);margin:0 0 12px}
.pdp-info__desc{font-weight:300;color:var(--text-2);line-height:1.7;margin:0 0 22px}
.pdp-selects{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:22px}
.pdp-select{flex:1;min-width:160px;padding:13px 14px;border:1px solid var(--maroon);border-radius:6px;font-family:inherit;font-size:14px;color:var(--ink);background:#fff}
.pdp-shapes{margin-bottom:22px}
.pdp-shapes__label{font-size:14px;color:var(--ink);margin:0 0 12px}
.pdp-shapes__scroll{position:relative}
.pdp-shapes__row{display:flex;gap:20px;align-items:flex-start;flex-wrap:nowrap;overflow-x:auto;scroll-behavior:smooth;scrollbar-width:none;padding-right:26px}
.pdp-shapes__row::-webkit-scrollbar{display:none}
.pdp-shape{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:7px;font-size:12px;color:#9a9a9a;white-space:nowrap;background:none;border:0;padding:0;font-family:inherit;cursor:default;transition:color .15s}
.pdp-shape.is-active{color:var(--maroon)}
.pdp-shape__ico{width:34px;height:34px;display:block;background-color:currentColor;-webkit-mask-position:center;mask-position:center;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}
.pdp-shapes__arrow{position:absolute;right:-4px;top:4px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border:0;border-radius:50%;background:#fff;color:var(--maroon);cursor:pointer;box-shadow:-10px 0 12px 6px #fff}
.pdp-shapes__arrow svg{width:18px;height:18px}
.pdp-price{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:22px}
.pdp-price__now{color:var(--maroon);font-size:22px;font-weight:600}
.pdp-price__was{color:var(--muted);text-decoration:line-through;font-size:15px}
.pdp-price__rating{font-size:13px;color:var(--muted)}
.pdp-price__rating .stars{color:#e8b923;letter-spacing:1px}
.pdp-actions{display:flex;flex-direction:column;gap:12px;margin-bottom:18px}
.pdp-actions .btn{width:100%}
.pdp-pay{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:8px}
.pdp-pay img{height:24px;width:auto;max-width:100%}
.pdp-pay .pay{height:26px;width:40px;border-radius:4px;background:var(--bg-soft);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;color:var(--ink)}
.accordion__item{border-top:1px solid var(--line)}
.accordion__head{display:flex;justify-content:space-between;align-items:center;gap:12px;width:100%;padding:16px 0;background:none;border:0;font-family:var(--serif);font-size:16px;color:var(--ink);cursor:pointer;text-align:left}
.accordion__head svg{width:20px;height:20px;flex:0 0 auto;transition:transform .2s}
.accordion__item.is-open .accordion__head svg{transform:rotate(45deg)}
.accordion__body{padding:0 0 16px;font-size:14px;font-weight:300;line-height:1.7;color:var(--text-2);display:none}
.accordion__item.is-open .accordion__body{display:block}
.related-head{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:22px}
.related-head h2{margin:0}

/* ----- Generic split (image + text) — about / education ----- */
.split{display:grid;grid-template-columns:1fr;gap:clamp(28px,4vw,56px);align-items:center}
.split__img{width:100%;border-radius:var(--r-card);object-fit:cover;display:block}
.split__body h2{font-size:clamp(24px,3vw,36px);margin:0 0 16px}
.split__body p{font-weight:300;line-height:1.8;color:var(--text-2);margin:0 0 14px}
@media(min-width:900px){
  .split{grid-template-columns:1fr 1fr}
  .split--reverse .split__media{order:2}
}
.eyebrow{display:block;font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--maroon);margin-bottom:10px}

/* shape strip (about) */
.shape-strip{display:flex;flex-wrap:wrap;gap:clamp(16px,3vw,40px);justify-content:center;align-items:center;margin-top:6px}
.shape-strip svg{width:42px;height:42px;fill:none;stroke:var(--maroon);stroke-width:1.1}

/* image trio */
.img-trio{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:768px){ .img-trio{grid-template-columns:repeat(3,1fr)} }
.img-trio img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:var(--r-card)}

/* ----- Signature pieces gallery (Figma 787-57): full-bleed slideshow on mobile, 3 columns on desktop ----- */
.sig-gallery{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none}
.sig-gallery::-webkit-scrollbar{display:none}
.sig-img{flex:0 0 100%;scroll-snap-align:center;width:100%;aspect-ratio:3/2;object-fit:cover;border-radius:16px;display:block}
.sig-card{position:relative;flex:0 0 100%;scroll-snap-align:center;aspect-ratio:5/6;overflow:hidden;border-radius:20px 20px 0 0}
.sig-card>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.sig-card::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.04) 32%,rgba(0,0,0,.72))}
.sig-card__body{position:absolute;left:0;right:0;bottom:0;z-index:2;display:flex;flex-direction:column;gap:12px;padding:clamp(24px,5vw,34px);color:#fff}
.sig-card__icon{line-height:0;color:#fff}
.sig-card__icon svg{width:26px;height:26px}
.sig-card__title{font-family:var(--serif);font-size:24px;color:#fff;margin:0}
.sig-card__desc{font-weight:300;font-size:14px;line-height:1.7;color:#fff;margin:0}
@media(min-width:768px){
  .sig-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;overflow:visible;max-width:var(--max);margin-inline:auto;padding-inline:var(--gutter)}
  .sig-card{flex:none;aspect-ratio:688/466;scroll-snap-align:none}
  .sig-img{flex:none;scroll-snap-align:none;aspect-ratio:688/466}
}

/* Award marquee */
.marquee{overflow:hidden;width:100%;padding:clamp(22px,4vw,40px) 0;border-block:1px solid var(--line);background:#fff}
.marquee__track{display:flex;align-items:center;width:max-content;animation:marquee-scroll 45s linear infinite}
.marquee__item{height:clamp(48px,7vw,68px);width:auto;flex:0 0 auto;display:block;margin-right:clamp(40px,6vw,72px)}
.marquee:hover .marquee__track{animation-play-state:paused}
@keyframes marquee-scroll{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.marquee__track{animation:none}}

/* horizontal filter bar (ready to ship) */
.filter-bar{display:grid;grid-template-columns:1fr;gap:26px 48px;padding:28px 0;border-block:1px solid var(--line);margin-bottom:8px}
@media(min-width:768px){ .filter-bar{grid-template-columns:minmax(0,1.5fr) minmax(0,1fr)} }
.filter-group__title{font-family:var(--serif);font-size:18px;color:var(--ink);margin:0 0 14px}
.filter-radios{display:flex;flex-wrap:wrap;gap:12px 20px}
.filter-radio{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--ink);cursor:pointer;white-space:nowrap}
.filter-radio input{accent-color:var(--maroon);width:15px;height:15px;flex:0 0 auto}
.filter-shapes__scroll{position:relative}
.rts-shapes{display:flex;flex-wrap:nowrap;gap:20px;align-items:center;overflow-x:auto;scroll-behavior:smooth;scrollbar-width:none;padding-right:30px}
.rts-shapes::-webkit-scrollbar{display:none}
.filter-shape{flex:0 0 auto;display:flex;align-items:center;gap:8px;font-size:14px;color:var(--ink);background:none;border:0;padding:0;font-family:inherit;cursor:pointer;white-space:nowrap;transition:color .15s}
.filter-shape:hover{color:var(--maroon)}
.filter-shape.is-active{color:var(--maroon)}
.filter-shape__ico{width:24px;height:24px;flex:0 0 auto;display:block;background-color:currentColor;-webkit-mask-position:center;mask-position:center;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}
.filter-shapes__arrow{position:absolute;right:-6px;top:50%;transform:translateY(-50%);width:30px;height:30px;display:flex;align-items:center;justify-content:center;border:0;border-radius:50%;background:#fff;color:var(--ink);cursor:pointer;box-shadow:-10px 0 12px 6px #fff}
.filter-shapes__arrow svg{width:18px;height:18px}
.rts-filter-active{font-size:14px;color:var(--text-2);margin:16px 0 0}
.rts-filter-clear{color:var(--maroon);margin-left:10px;text-decoration:underline}
.rts-empty{color:var(--muted);font-size:15px;padding:22px 0}
.product-pager{display:flex;justify-content:center;align-items:center;gap:10px;margin-top:26px}
.product-pager__num,.product-pager__btn{min-width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border:0;background:none;font-family:inherit;font-size:14px;color:var(--ink);cursor:pointer;border-radius:6px}
.product-pager__num.is-active{background:var(--maroon);color:#fff}
.product-pager__btn{color:var(--muted);font-size:20px}
/* Mobile filter dropdowns (expanded bar swaps to 2x2 selects) */
.filter-dropdowns{display:none}
.filter-dd{display:flex;flex-direction:column;gap:8px;min-width:0}
.filter-dd__label{font-family:var(--serif);font-size:16px;color:var(--ink)}
.filter-dd__select{appearance:none;-webkit-appearance:none;width:100%;border:1px solid var(--maroon);border-radius:8px;padding:11px 34px 11px 14px;font-family:inherit;font-size:14px;color:var(--ink);background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5 6 6.5 11 1.5' stroke='%237f0f0f' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 12px center;cursor:pointer}
@media(max-width:767px){
  .filter-bar{display:none}
  .filter-dropdowns{display:grid;grid-template-columns:1fr 1fr;gap:18px 14px;padding:24px 0;border-block:1px solid var(--line);margin-bottom:8px}
}
.product-row{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
@media(min-width:760px){ .product-row{grid-template-columns:repeat(4,1fr)} }

/* maroon content block + lists (education) */
.block--maroon{background:var(--maroon);color:#fff}
.block--maroon .split__body h2{color:#fff}
.block--maroon .split__body p{color:#f0e3e3}
.feature-media{text-align:center;max-width:900px;margin:0 auto}
.feature-media__img{width:clamp(200px,36vw,380px);aspect-ratio:1;object-fit:contain;margin:6px auto 0;display:block;mix-blend-mode:multiply}
.edu-list{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-direction:column;gap:10px}
.edu-list li{position:relative;padding-left:24px;font-weight:300;line-height:1.7}
.edu-list li::before{content:"";position:absolute;left:0;top:9px;width:8px;height:8px;border-radius:50%;background:var(--maroon)}
.block--maroon .edu-list li::before{background:#fff}
/* Education: 4 Cs tags + Beyond cards */
.cs-tags{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}
.cs-tag{border:1px solid var(--line);background:none;border-radius:20px;padding:7px 18px;font-family:inherit;font-size:14px;color:var(--ink);cursor:pointer;transition:.2s}
.cs-tag:hover{border-color:var(--maroon);color:var(--maroon)}
.cs-tag.is-active{background:var(--maroon);color:#fff;border-color:var(--maroon)}
.cs-title{font-family:var(--serif);font-size:clamp(22px,2.4vw,28px);margin:0 0 12px}
.cs-panel{display:none}
.cs-panel.is-active{display:block}
.beyond-grid{display:grid;grid-template-columns:1fr;gap:clamp(16px,2vw,24px)}
@media(min-width:768px){ .beyond-grid{grid-template-columns:repeat(3,1fr)} }
.beyond-card{position:relative;margin:0;border-radius:var(--r-card);overflow:hidden;aspect-ratio:3/4}
.beyond-card img{width:100%;height:100%;object-fit:cover;display:block}
.beyond-card__cap{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:24px;color:#fff;background:linear-gradient(to top,rgba(0,0,0,.72),rgba(0,0,0,0) 52%);transition:background .35s}
.beyond-card__title{font-family:var(--serif);font-size:22px;margin:0;color:#fff}
.beyond-card__desc{font-weight:300;font-size:14px;line-height:1.65;margin:0;max-height:0;opacity:0;overflow:hidden;transition:max-height .45s ease,opacity .35s ease,margin .45s ease}
.beyond-card:hover .beyond-card__cap,.beyond-card:focus-within .beyond-card__cap{background:linear-gradient(to top,rgba(0,0,0,.86),rgba(0,0,0,.28))}
.beyond-card:hover .beyond-card__desc,.beyond-card:focus-within .beyond-card__desc{max-height:280px;opacity:1;margin-top:12px}
@media(hover:none){.beyond-card__desc{max-height:280px;opacity:1;margin-top:12px}.beyond-card__cap{background:linear-gradient(to top,rgba(0,0,0,.82),rgba(0,0,0,.2))}}
/* Education image treatments */
.edu-curve-tr{border-top-right-radius:250px}
.section--media-bleed{padding:0}
.section--media-bleed > .container{max-width:none;padding:0}
.section--media-bleed .split{gap:0;align-items:stretch;grid-template-columns:1fr}
.section--media-bleed .split__img{width:100%;height:100%;object-fit:cover;border-radius:0;min-height:300px}
.section--media-bleed .split__img.bleed-img--curve-tr{border-radius:0 250px 0 0}
.section--media-bleed .split__body{padding:clamp(40px,6vw,72px) clamp(20px,5vw,40px)}
@media(min-width:900px){
  .section--media-bleed .split{grid-template-columns:1fr 1fr}
  .section--media-bleed .split__body{display:flex;flex-direction:column;justify-content:center}
  .section--media-bleed .split--reverse .split__body{padding-left:max(var(--gutter),calc((100vw - var(--max))/2 + var(--gutter)));padding-right:clamp(30px,4vw,60px)}
  .section--media-bleed .split:not(.split--reverse) .split__body{padding-right:max(var(--gutter),calc((100vw - var(--max))/2 + var(--gutter)));padding-left:clamp(30px,4vw,60px)}
}

/* ----- Support service cards ----- */
.svc-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:700px){ .svc-grid{grid-template-columns:repeat(2,1fr)} }
.svc-card{display:flex;flex-direction:column;align-items:flex-start;gap:12px;border:1px solid var(--line);border-radius:var(--r-card);padding:28px;background:#fff}
.svc-card__icon{width:48px;height:48px;border-radius:50%;background:var(--maroon-soft);color:var(--maroon);display:flex;align-items:center;justify-content:center}
.svc-card__icon svg{width:24px;height:24px}
.svc-card h3{font-size:18px;margin:0}
.svc-card p{font-weight:300;font-size:14px;line-height:1.7;color:var(--text-2);margin:0}
.svc-card .btn{margin-top:4px}
/* Shipping & Delivery page */
.ship-cards{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:768px){ .ship-cards{grid-template-columns:repeat(3,1fr)} }
.ship-card{border-radius:10px;overflow:hidden;background:#f4f4f4;display:flex;flex-direction:column}
.ship-card__head{background:var(--maroon);color:#fff;font-family:var(--serif);font-size:clamp(20px,2vw,24px);text-align:center;padding:34px 20px}
.ship-card__body{padding:36px 28px 40px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px;flex:1}
.ship-card__time{font-family:var(--serif);font-size:clamp(26px,2.6vw,32px);color:var(--ink);margin:0}
.ship-card__sub{font-family:var(--serif);font-size:clamp(19px,2vw,24px);color:var(--ink);margin:0 0 16px}
.ship-card__desc{font-weight:300;font-size:14px;line-height:1.7;color:var(--text-2);margin:0;max-width:360px}
.ship-doc{max-width:1400px;margin:0 auto;display:flex;flex-direction:column;gap:32px}
.ship-doc__item{display:flex;flex-direction:column;gap:18px;padding-bottom:32px;border-bottom:1px solid var(--line)}
.ship-doc__item:last-child{border-bottom:0;padding-bottom:0}
.ship-doc__title{font-family:var(--serif);font-size:clamp(20px,2vw,24px);color:var(--ink);margin:0}
.ship-doc__item p{font-weight:300;font-size:14px;line-height:1.85;color:var(--ink);margin:0}
.ship-doc__item a{color:var(--maroon)}
.ship-doc__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.ship-doc__list li{position:relative;padding-left:22px;font-weight:300;font-size:14px;line-height:1.7;color:var(--ink)}
.ship-doc__list li::before{content:"";position:absolute;left:4px;top:9px;width:6px;height:6px;border-radius:50%;background:var(--maroon)}

/* ----- Order status bar (track order) ----- */
.order-bar{background:var(--maroon);color:#fff;border-radius:var(--r-card);padding:clamp(24px,3vw,38px)}
.order-bar h2{color:#fff;font-size:clamp(20px,2.4vw,26px);margin:0 0 18px}
.order-bar__row{display:flex;gap:16px;flex-wrap:wrap;align-items:flex-end}
.order-bar__field{flex:1;min-width:180px;display:flex;flex-direction:column;gap:6px;font-size:13px;color:rgba(255,255,255,.85)}
.order-bar__field input{background:transparent;border:0;border-bottom:1px solid rgba(255,255,255,.5);color:#fff;padding:9px 0;font-family:inherit;font-size:15px}
.order-bar__field input::placeholder{color:rgba(255,255,255,.55)}

/* ----- Order timeline / steps ----- */
.order-no{font-family:var(--serif);font-size:18px;margin:32px 0 0}
.steps{display:flex;list-style:none;margin:24px 0 0;padding:0;overflow-x:auto}
.step{flex:1;min-width:84px;position:relative;text-align:center;font-size:12.5px;color:var(--muted);padding-top:34px}
.step::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid var(--line);z-index:1}
.step::after{content:"";position:absolute;top:8px;right:50%;width:100%;height:2px;background:var(--line)}
.step:first-child::after{display:none}
.step.is-done{color:var(--ink)}
.step.is-done::before{background:var(--maroon);border-color:var(--maroon)}
.step.is-done::after{background:var(--maroon)}

/* ----- Shipping feature row (3-up) ----- */
@media(min-width:768px){ .usp-row--3{grid-template-columns:repeat(3,1fr)} }
.usp-row--3 .usp + .usp::before{display:none}

/* ============================================================
   Support pages: FAQ / Book Appointment / Live Chat
   (Figma 684-4321, 684-4632, 684-3405)
   ============================================================ */
/* Tall hero with silver-gradient headline (reuses .page-hero) */
.page-hero--tall{min-height:clamp(598px,75vw,806px)}
.page-hero--tall .page-hero__eyebrow,.page-hero--tall .page-hero__title,.page-hero--tall .page-hero__text{max-width:660px}
.page-hero--tall .page-hero__title{font-size:clamp(34px,5vw,60px);font-weight:300}
.page-hero__title--silver{
  background:linear-gradient(96.87deg,#adb5bd 0%,#fff 48.5%,#adb5bd 64.4%,#fff 76.9%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.page-hero__cta .btn--primary{border-color:rgba(255,255,255,.75)}
@media(min-width:768px){ .page-hero__img{object-position:38% 25%} }
/* Mobile hero + split tweaks */
@media(max-width:767px){
  .page-hero::after{background:linear-gradient(90deg,rgba(0,0,0,.72),rgba(0,0,0,.42))}
  .page-hero__title,.page-hero--tall .page-hero__title{font-family:var(--sans);font-size:32px;font-weight:300;line-height:1.2}
  .page-hero__cta{flex-wrap:nowrap;gap:10px}
  .page-hero__cta .btn{height:46px;padding:0 16px;font-size:14px;white-space:nowrap}
  .split__media{width:calc(100% + var(--gutter)*2);margin-inline:calc(var(--gutter)*-1)}
  .split__media .split__img{border-radius:0}
}

/* FAQ search + card */
.faq-search{display:flex;align-items:center;gap:12px;width:min(370px,100%);background:#fff;border:1px solid var(--maroon);border-radius:10px;padding:9px 16px;margin-bottom:24px}
.faq-search input{flex:1;min-width:0;border:0;background:none;font-family:inherit;font-size:14px;font-weight:300;color:var(--ink)}
.faq-search input::placeholder{color:var(--muted)}
.faq-search input:focus{outline:0}
.faq-search svg{width:16px;height:16px;color:var(--muted);flex:0 0 auto}
.faq-card{background:#fff;border-radius:var(--r-card);box-shadow:var(--shadow);padding:clamp(22px,4vw,52px)}
.accordion--lg .accordion__item:first-child{border-top:0}
.accordion--lg .accordion__head{font-size:clamp(16px,2vw,22px);padding:18px 0;gap:20px;align-items:flex-start}
.accordion--lg .accordion__head svg{width:24px;height:24px;margin-top:4px}
.accordion--lg .accordion__body{font-size:14.5px;padding-bottom:18px;max-width:940px}

/* Testimonial person row (extends .testimonial) */
.testimonial__person{display:flex;align-items:center;gap:12px;margin-top:auto}
.testimonial__avatar{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--maroon-soft);color:var(--maroon);font-weight:600;font-size:14px;flex:0 0 auto}
.testimonial__who{font-size:13px;line-height:1.35;color:var(--ink);flex:1;min-width:0}
.testimonial__who b{display:block;font-weight:500}
.testimonial__who span{color:var(--muted);font-weight:300}
.testimonial__fb{color:#1877f2;flex:0 0 auto;line-height:0}
.testimonial__fb svg{width:22px;height:22px}

/* Team */
.team{display:flex;flex-direction:column;gap:24px;max-width:1100px;margin:0 auto}
.team-card{display:grid;grid-template-columns:1fr;background:#f4f4f4;border-radius:var(--r-card);overflow:hidden}
.team-card__media{position:relative;min-height:300px;background:#171010}
.team-card__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center}
.team-card__body{padding:clamp(24px,3.4vw,40px);display:flex;flex-direction:column;gap:10px;justify-content:center}
.team-card__role{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--maroon);font-weight:500}
.team-card__name{font-family:var(--serif);font-size:clamp(22px,2.4vw,26px);color:var(--ink);margin:0}
.team-card__bio{font-weight:300;font-size:14px;line-height:1.8;color:var(--text-2);margin:0}
@media(min-width:720px){ .team-card{grid-template-columns:300px 1fr} }

/* Calendly embed placeholder */
.calendly-embed{position:relative;background:var(--maroon);color:#fff;border-radius:var(--r-card);min-height:clamp(340px,40vw,480px);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px}
.calendly-embed::before{content:"";position:absolute;inset:14px;border:2px dashed rgba(255,255,255,.45);border-radius:8px;pointer-events:none}
.calendly-embed__label{position:relative;font-family:var(--serif);font-size:clamp(22px,3vw,34px)}
.calendly-embed__note{position:relative;font-weight:300;font-size:14px;color:rgba(255,255,255,.82);margin-top:12px;max-width:420px}

/* Connect form (live chat) */
.connect{position:relative;background:var(--maroon);color:#fff;border-radius:var(--r-card);padding:clamp(30px,4vw,52px);max-width:1100px;margin:0 auto}
.connect::before{content:"";position:absolute;inset:14px;border:2px dashed rgba(255,255,255,.4);border-radius:8px;pointer-events:none}
.connect__inner{position:relative}
.connect__head{display:flex;align-items:center;gap:14px;margin-bottom:8px}
.connect__head svg{width:34px;height:34px;flex:0 0 auto;color:#fff}
.connect__title{color:#fff;margin:0;font-size:clamp(22px,3vw,32px)}
.connect__text{font-weight:300;font-size:14px;color:rgba(255,255,255,.9);margin:0 0 24px;max-width:560px}
.connect__form{display:grid;grid-template-columns:repeat(2,1fr);gap:18px 22px}
.connect__form .field--full{grid-column:1/-1}
.connect__submit{margin-top:8px}
@media(max-width:640px){ .connect__form{grid-template-columns:1fr} }
/* Live-chat connect: intro left / form right split on desktop (Figma 684-3405) */
.connect--split .connect__inner{display:grid;grid-template-columns:1fr;gap:clamp(24px,3vw,44px);align-items:center}
.connect--split .connect__intro{min-width:0}
.connect--split .connect__text{margin-bottom:0}
@media(min-width:860px){ .connect--split .connect__inner{grid-template-columns:minmax(0,340px) minmax(0,1fr)} }

/* Footer without overlapping contact card */
.site-footer--flush .footer-top{padding-top:clamp(48px,7vw,80px)}

/* ============================================================
   Consultation booking + Contact Us pages
   (Figma 684-3672, 684-3988)
   ============================================================ */
/* How-to-book step cards */
.steps-grid{display:grid;grid-template-columns:1fr;gap:22px}
@media(min-width:560px){ .steps-grid{grid-template-columns:repeat(2,1fr)} }
@media(min-width:1000px){ .steps-grid{grid-template-columns:repeat(4,1fr)} }
.step-card{background:#fff;border-radius:var(--r-card);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}
.step-card__head{background:var(--maroon);color:#fff;text-align:center;font-family:var(--serif);font-size:22px;padding:30px 16px}
.step-card__body{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;padding:26px 24px 32px}
.step-card__icon{color:var(--maroon);line-height:0}
.step-card__icon svg{width:32px;height:32px}
.step-card__desc{font-weight:300;font-size:14px;line-height:1.7;color:var(--text-2);margin:0}

/* Assist / contact two-up (grey info card + maroon panel) */
.assist-grid{display:grid;grid-template-columns:1fr;gap:24px;align-items:stretch}
@media(min-width:900px){ .assist-grid{grid-template-columns:1fr 1fr} }
.info-card{background:#f4f4f4;border-radius:var(--r-card);padding:clamp(28px,3.5vw,48px);display:flex;flex-direction:column;gap:18px}
.info-card__title{font-size:clamp(22px,2.6vw,32px);margin:0}
.info-card__lead{font-weight:300;font-size:14px;line-height:1.7;color:var(--text-2);margin:0}
.info-card .btn{align-self:flex-start;margin-top:4px}
.contact-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px}
.contact-list li{display:flex;align-items:center;gap:14px;font-size:14px;font-weight:300;color:var(--maroon)}
.contact-list li svg{width:22px;height:22px;color:var(--maroon);flex:0 0 auto}
.contact-list a{color:var(--maroon);text-decoration:underline}
.contact-list a:hover{color:var(--maroon-dark)}
.contact-list small{color:var(--muted)}
.contact-social{display:flex;gap:14px;margin-top:2px}
.contact-social a{width:42px;height:42px;border-radius:50%;background:var(--maroon-soft);color:var(--maroon);display:flex;align-items:center;justify-content:center;transition:.2s}
.contact-social a:hover{background:var(--maroon);color:#fff}
.contact-social svg{width:20px;height:20px}

/* Maroon "Send Us a Message" panel reuses .connect; title-only head */
.connect__head--plain{margin-bottom:18px}

/* Embedded map with overlay card */
.map-full{position:relative;background:#e9ecef}
.map-full iframe{display:block;width:100%;height:clamp(360px,42vw,560px);border:0}
.map-card{position:absolute;left:clamp(16px,6vw,120px);top:50%;transform:translateY(-50%);background:#fff;border-radius:var(--r-card);box-shadow:0 14px 40px rgba(0,0,0,.18);padding:22px 26px;max-width:300px}
.map-card h3{font-family:var(--sans);font-size:14px;font-weight:600;margin:0 0 8px;color:var(--ink)}
.map-card p{font-size:13px;font-weight:300;line-height:1.7;color:var(--text-2);margin:0}
@media(max-width:560px){ .map-card{position:static;transform:none;max-width:none;margin:16px var(--gutter);box-shadow:var(--shadow)} .map-full{display:flex;flex-direction:column} }

/* Reviews band: left intro + card row */
.reviews-band{display:grid;grid-template-columns:1fr;gap:clamp(24px,4vw,44px);align-items:start}
.reviews-band__intro .section-head__title{text-align:left;margin:0 0 14px}
.reviews-band__intro .section-head__desc{text-align:left}
.reviews-band__cards{display:grid;grid-template-columns:1fr;gap:20px;min-width:0}
.reviews-band__cards .testimonial{min-width:0}
@media(min-width:640px){ .reviews-band__cards{grid-template-columns:repeat(2,minmax(0,1fr))} }
@media(min-width:1200px){
  .reviews-band{grid-template-columns:320px minmax(0,1fr)}
  .reviews-band__cards{grid-template-columns:repeat(3,minmax(0,1fr))}
}

/* Full-bleed image / text split (alternating) */
.split-full{display:grid;grid-template-columns:1fr}
.split-full__media{position:relative;min-height:300px;background:#171010}
.split-full__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.split-full__body{display:flex;flex-direction:column;justify-content:center;gap:16px;padding:clamp(36px,6vw,76px) clamp(24px,6vw,92px)}
.split-full__body h2{font-size:clamp(24px,3vw,32px);margin:0}
.split-full__body p{font-weight:300;line-height:1.85;color:var(--text-2);margin:0}
.split-full--soft .split-full__body{background:#f4f4f4}
.split-full__list{list-style:none;margin:4px 0 0;padding:0;display:flex;flex-direction:column;gap:12px}
.split-full__list li{font-weight:300;line-height:1.7;color:var(--text-2);padding-left:22px;position:relative}
.split-full__list li::before{content:"";position:absolute;left:0;top:9px;width:7px;height:7px;border-radius:50%;background:var(--maroon)}
.split-full__list b{color:var(--ink);font-weight:600}
@media(min-width:900px){
  .split-full{grid-template-columns:1fr 1fr}
  .split-full--reverse .split-full__media{order:2}
}

/* ===== Modals: welcome + compare popups ===== */
.modal{position:fixed;inset:0;z-index:1200;display:none;align-items:center;justify-content:center;padding:20px}
.modal.is-open{display:flex}
.modal__backdrop{position:absolute;inset:0;background:rgba(26,10,10,.58)}
.modal__dialog{position:relative;z-index:1;width:100%;background:#fff;border-radius:14px;box-shadow:0 30px 80px rgba(0,0,0,.35);max-height:calc(100vh - 40px);overflow:auto;animation:modalpop .28s ease}
@keyframes modalpop{from{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}
.modal__close{position:absolute;top:12px;right:12px;z-index:3;width:34px;height:34px;border-radius:50%;border:0;background:rgba(255,255,255,.92);color:var(--ink);font-size:22px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,.14);transition:.2s}
.modal__close:hover{background:var(--maroon);color:#fff}
body.modal-open{overflow:hidden}

/* Welcome popup */
.welcome{max-width:720px;display:grid;grid-template-columns:1fr;overflow:hidden}
.welcome__media{background:#2a0a0a}
.welcome__media img{display:block;width:100%;height:200px;object-fit:cover}
.welcome__body{padding:30px clamp(24px,4vw,44px) 36px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}
.welcome__eyebrow{font-family:var(--serif);font-size:clamp(19px,2.4vw,24px);color:var(--ink);margin:0}
.welcome__lead{font-weight:300;font-size:15px;line-height:1.7;color:var(--text-2);margin:0;max-width:380px}
.welcome__lead b{color:var(--maroon);font-weight:600}
.welcome__code{position:relative;background:var(--maroon);color:#fff;border-radius:3px;padding:14px 20px;font-size:15px;letter-spacing:.04em;width:100%;max-width:320px}
.welcome__code::before{content:"";position:absolute;inset:4px;border:1px dashed rgba(255,255,255,.5);border-radius:2px;pointer-events:none}
.welcome__code strong{font-weight:600}
.welcome__valid{font-size:13px;color:var(--muted);margin:0}
.welcome__cta{margin-top:4px}
@media(min-width:720px){
  .welcome{grid-template-columns:300px 1fr;max-width:760px}
  .welcome__media img{height:100%;min-height:430px}
}

/* Compare popup */
.compare{max-width:860px;padding:clamp(24px,3.5vw,40px)}
.compare__title{font-family:var(--serif);font-size:clamp(24px,3.4vw,38px);color:var(--ink);margin:0 0 clamp(16px,2.2vw,26px)}
.compare__grid{display:grid;grid-template-columns:1fr 1fr;column-gap:clamp(16px,3vw,40px)}
.compare__cell{padding:16px 0;display:flex;flex-direction:column;align-items:center;text-align:center;gap:9px;min-width:0;border-top:1px solid var(--line)}
.compare__cell.is-first{border-top:0}
.compare__cell--label{display:none}
.compare__media img{width:100%;max-width:180px;height:120px;object-fit:cover;background:var(--bg-soft);border-radius:8px}
.compare__name{font-size:14px;font-weight:300;line-height:1.5;color:var(--ink)}
.compare__more{display:inline-flex;align-items:center;gap:6px;color:var(--maroon);font-size:13px;font-weight:500}
.compare__more svg{width:12px;height:12px}
.compare__price{color:var(--maroon);font-weight:600;font-size:16px}
.compare__price small{color:var(--muted);font-weight:300;font-size:12px}
.compare__cart .btn{border-radius:0}
@media(min-width:720px){
  .compare__grid{grid-template-columns:90px minmax(0,1fr) minmax(0,1fr)}
  .compare__cell--label{display:flex;align-items:center;justify-content:flex-start;text-align:left;color:var(--muted);font-size:13px;letter-spacing:.04em}
}

/* Image-upload popup (Figma 684-4950 / 684-17143) */
.upload{max-width:720px;display:grid;grid-template-columns:1fr;overflow:hidden}
.upload__media{background:#e7dadb}
.upload__media img{display:block;width:100%;height:190px;object-fit:cover}
.upload__body{padding:clamp(24px,3.4vw,40px);display:flex;flex-direction:column;gap:16px;justify-content:center}
.upload__drop{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;border:1.5px dashed var(--maroon);border-radius:8px;padding:clamp(28px,4vw,40px) 20px;cursor:pointer;background:#fff;transition:.18s}
.upload__drop:hover,.upload__drop.is-drag{background:var(--maroon-soft)}
.upload__icon{color:var(--ink);line-height:0}
.upload__icon svg{width:38px;height:38px}
.upload__heading{font-size:15px;color:var(--ink);line-height:1.5}
.upload__heading-mobile{display:none}
.upload__formats{font-size:12px;color:var(--muted)}
.upload__preview{max-width:130px;max-height:96px;border-radius:6px;margin-top:8px;display:block}
.upload__cta{width:100%}
@media(min-width:720px){
  .upload{grid-template-columns:320px minmax(0,1fr);max-width:820px}
  .upload__media img{height:100%;min-height:440px}
}
@media(max-width:719px){
  .upload__heading-desktop{display:none}
  .upload__heading-mobile{display:inline}
}

/* ============================================================
   WooCommerce integration — make WC default markup on-brand.
   (Custom templates live in /woocommerce; these rules style the
   core elements WC still outputs: notices, prices, buttons,
   ordering, pagination, related products, variations, quantity.)
   ============================================================ */
.woocommerce ul.products{margin:0;padding:0;list-style:none}
.woocommerce ul.products li.product{width:auto;margin:0;float:none}
.woocommerce ul.products li.product::before{display:none}
.product__badge{position:absolute;top:10px;left:12px;background:var(--maroon);color:#fff;font-size:11px;font-weight:500;border-radius:4px;padding:3px 8px;z-index:2}
.product .added_to_cart{display:none}                 /* hide WC "View cart" text link; badge updates instead */
.woocommerce-result-count,.shop-bar__count{font-size:14px;color:var(--muted);margin:0 0 18px}
.woocommerce-ordering select,.shop-tool-select{padding:11px 14px;border:1px solid var(--line);border-radius:8px;background:#fff;font-family:inherit;font-size:14px;color:var(--ink);cursor:pointer}
.woocommerce-ordering{margin:0}
/* Prices */
.woocommerce-Price-amount{color:inherit}
.product__price del,.pdp-price del{color:var(--muted);font-weight:300;font-size:.85em;margin-left:6px}
.product__price ins,.pdp-price ins{text-decoration:none}
/* Single add-to-cart form styled into the brand action row */
.pdp-actions form.cart{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:0}
.pdp-actions .quantity{display:inline-flex}
.pdp-actions .quantity .qty{width:64px;height:52px;border:1px solid var(--line);border-radius:var(--r-btn);padding:0 10px;font-family:inherit;font-size:15px;text-align:center}
.woocommerce .single_add_to_cart_button,.woocommerce-page .single_add_to_cart_button{display:inline-flex;align-items:center;justify-content:center;height:52px;padding:0 28px;background:var(--maroon);color:#fff;border:1px solid var(--maroon);border-radius:var(--r-btn);font-weight:500;font-size:16px;cursor:pointer;transition:.2s}
.woocommerce .single_add_to_cart_button:hover{background:var(--maroon-dark)}
.woocommerce .variations{margin:0 0 16px;border-collapse:collapse;width:100%}
.woocommerce .variations td,.woocommerce .variations th{padding:6px 0;text-align:left;vertical-align:middle}
.woocommerce .variations select{width:100%;appearance:none;-webkit-appearance:none;border:1px solid var(--maroon);border-radius:8px;padding:11px 34px 11px 14px;font-family:inherit;font-size:14px;color:var(--ink);background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5 6 6.5 11 1.5' stroke='%237f0f0f' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 12px center;cursor:pointer}
/* Variable-product PDP: WooCommerce variations form styled to the preview —
   Metal + Carat selects side by side (label above each), the selected-variation
   price as the maroon headline, full-width add-to-cart, quantity fixed at 1. */
.pdp-variform{margin:0 0 18px}
.pdp-variform form.variations_form.cart{display:block;margin:0}
.pdp-variform .variations{margin:0 0 14px;width:100%;border:0}
.pdp-variform .variations tbody{display:flex;gap:14px;flex-wrap:wrap}
.pdp-variform .variations tr{display:flex;flex-direction:column;flex:1;min-width:160px}
.pdp-variform .variations th.label{padding:0 0 6px}
.pdp-variform .variations th.label label{font-size:14px;font-weight:500;color:var(--ink);margin:0}
.pdp-variform .variations td.value{padding:0}
.pdp-variform .reset_variations{display:inline-block;margin:6px 0 0;font-size:13px;color:var(--muted)}
.pdp-variform .single_variation{margin:0 0 14px}
.pdp-variform .single_variation .price{color:var(--maroon);font-size:22px;font-weight:600}
.pdp-variform .single_variation .price del{color:var(--muted);font-weight:300;font-size:.7em;margin-right:6px}
.pdp-variform .single_variation .price ins{text-decoration:none}
.pdp-variform .woocommerce-variation-availability{font-size:13px;color:var(--muted);margin-top:4px}
.pdp-variform .woocommerce-variation-add-to-cart{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.pdp-variform .woocommerce-variation-add-to-cart .quantity{display:none!important}
.pdp-variform .single_add_to_cart_button{flex:1;width:100%}
.pdp-actions--single{margin-top:12px}
.pdp-actions--single .btn{width:100%}
/* Notices */
.woocommerce-message,.woocommerce-info,.woocommerce-error,.woocommerce-noreviews,.wc-block-components-notice-banner{border:0;border-left:3px solid var(--maroon);background:var(--maroon-soft);color:var(--ink);border-radius:6px;padding:14px 18px;font-size:14px;list-style:none}
.woocommerce-message .button,.woocommerce-error .button,.woocommerce-info .button{background:var(--maroon);color:#fff;border-radius:var(--r-btn);padding:8px 16px}
/* Related products heading */
.related.products>h2,.up-sells>h2,.cross-sells>h2{font-family:var(--serif);font-size:clamp(24px,3vw,32px);color:var(--ink);text-align:center;margin:0 0 clamp(24px,3vw,36px)}
/* WooCommerce pagination → match the theme .pagination pills */
.woocommerce-pagination ul.page-numbers{display:flex;justify-content:center;flex-wrap:wrap;gap:8px;margin:34px 0 0;padding:0;list-style:none;border:0}
.woocommerce-pagination ul.page-numbers li{border:0;margin:0}
.woocommerce-pagination .page-numbers{min-width:38px;height:38px;padding:0 8px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:4px;font-size:14px;color:var(--ink);background:#fff}
.woocommerce-pagination .page-numbers:hover{border-color:var(--maroon);color:var(--maroon)}
.woocommerce-pagination .page-numbers.current{background:var(--maroon);color:#fff;border-color:var(--maroon)}
/* Cart / checkout buttons inherit the brand */
.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,.woocommerce #respond input#submit{background:var(--maroon);color:#fff;border-radius:var(--r-btn);font-family:inherit;font-weight:500}
.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce input.button:hover{background:var(--maroon-dark)}
.woocommerce a.button.alt,.woocommerce button.button.alt{background:var(--maroon)}

/* ── Shop product grid fix ───────────────────────────────────────────────
   Neutralise WooCommerce's default ul.products clearfix pseudo-elements
   (which otherwise become phantom CSS-grid cells and offset the first
   product), and enforce the brand product grid on shop/category pages. */
.shop-main ul.products,
.woocommerce .shop-main ul.products{
	display:grid;
	grid-template-columns:repeat(2,1fr);
	gap:18px;
	margin:0;
	padding:0;
	list-style:none;
}
@media(min-width:768px){
	.shop-main ul.products,
	.woocommerce .shop-main ul.products{ grid-template-columns:repeat(3,1fr); }
}
.shop-main ul.products::before,
.shop-main ul.products::after{ content:none !important; display:none !important; }
.shop-main ul.products li.product,
.woocommerce .shop-main ul.products li.product{
	width:auto !important;
	margin:0 !important;
	float:none !important;
	clear:none !important;
}

/* Force product-card images to fill the square media box (beats WooCommerce
   default ul.products li.product img { height:auto; margin:0 0 1em }). */
.product__media img,
.shop-main ul.products li.product .product__media img,
.woocommerce ul.products li.product .product__media img{
	width:100% !important;
	height:100% !important;
	object-fit:cover !important;
	margin:0 !important;
	display:block;
}

/* Related products grid on the PDP (matches .products--related in the design). */
section.related.products{ margin-top:clamp(30px,5vw,56px); }
section.related.products > h2{
	font-family:var(--serif);
	font-weight:300;
	font-size:clamp(24px,3vw,34px);
	text-align:center;
	margin:0 0 clamp(24px,3vw,36px);
}
ul.products::before,ul.products::after{ content:none !important; display:none !important; }
ul.products{
	display:grid;
	grid-template-columns:repeat(2,1fr);
	gap:18px;
	margin:0;
	padding:0;
	list-style:none;
}
@media(min-width:992px){
	.related ul.products,
	ul.products.columns-4{ grid-template-columns:repeat(4,1fr); }
}
ul.products li.product{ width:auto !important; margin:0 !important; float:none !important; clear:none !important; }

/* The related-products wrapper itself carries the `products` class; stop the
   base .products grid from turning the whole section into a 2-col grid (which
   pushed the heading into column 1 and squashed the list). Only the inner
   <ul class="products"> is the grid. */
section.related.products{ display:block !important; }
section.related.products > .related-head{ text-align:center; }

/* Shop filter form (functional). */
.shop-filter-form{ display:flex; flex-direction:column; gap:clamp(20px,3vw,28px); }
.fil-pill input,.fil-opt input{ position:absolute; opacity:0; width:0; height:0; pointer-events:none; }
.fil-pill{ display:inline-flex; align-items:center; }
.fil-pill:has(input:checked){ background:var(--maroon); color:#fff; }
.fil-opt:has(input:checked){ color:var(--maroon); font-weight:500; }
.fil-actions{ display:flex; gap:10px; align-items:center; }
.fil-actions .btn{ flex:1; text-align:center; }

/* When JS live-filtering is active, the Apply button is redundant. */
.shop-filter-form.is-live .fil-actions [type="submit"]{ display:none; }
.shop-filter-form.is-live .fil-actions .btn--ghost{ flex:1; }
