/* =========================================================
   SILKY STRANDS — Design System
   Heritage-modern. Black · Vermilion · Gold · Ivory
   ========================================================= */

@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,400;1,500&family=Manrope:wght@400;500;600;700&family=Marcellus&family=Inter:wght@300;400;500;600&display=swap");

:root{
  /* Palette — restrained: 90% foundation, <10% accents */
  --ink:#1A1612;            /* Soft Ink — text, lines, duotone (NOT pure black) */
  --ink-2:#1A1612;
  --vermilion:#C4282E;      /* Kumkum Red — CTAs / key prices ONLY, never decorative */
  --vermilion-deep:#A11F25;
  --vermilion-soft:#C4282E;
  --gold:#8C6E54;           /* Walnut — secondary text, icons, photo overlays */
  --gold-light:#8C6E54;
  --gold-soft:#D9C7B0;      /* Sandstone — dividers, hovers, soft fills */
  --ivory:#FFFFFF;          /* Primary background — pure white */
  --ivory-2:#FFFFFF;        /* Bright Cream — cards, modals */
  --bone:#D9C7B0;           /* Sandstone */
  --line:rgba(26,22,18,0.12);
  --line-strong:rgba(26,22,18,0.24);
  --muted:#8C6E54;          /* Walnut as secondary text color */

  /* Type */
  --serif:"Cormorant Garamond", Georgia, serif;
  --display:"Marcellus", Georgia, serif;
  --sans:"Manrope", "Inter", system-ui, -apple-system, sans-serif;
  --product-font:"Manrope", "Inter", system-ui, -apple-system, sans-serif;
  --nav-accent:#751410;     /* Navbar hover / active / underline */

  /* Type scale — single source of truth */
  --fs-h1: clamp(38px, 5vw, 64px);    /* Hero / page-hero */
  --fs-h2: clamp(28px, 3.4vw, 44px);  /* Section heading */
  --fs-h3: 22px;                      /* Tertiary heading */
  --fs-sub: 18px;                     /* Lead / subheading */
  --fs-body: 16px;                    /* Body */
  --fs-small: 13px;                   /* Captions / fine print */
  --fs-eyebrow: 11px;                 /* Small uppercase label */

  /* Layout */
  --maxw:1320px;
  --gut:32px;
  --r-sm:6px;
  --r:10px;
  --r-lg:18px;

  /* Motion */
  --ease:cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{box-sizing:border-box;}
html,body{margin:0;padding:0;overflow-x:clip;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--ivory);
  font-size:var(--fs-body);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  width:100%;
}

/* Global heading font — all headings use the display face */
h1,h2,h3,h4,h5,h6{
  font-family:var(--display);
  font-weight:400;
}
h1{font-size:var(--fs-h1);line-height:1.05;letter-spacing:-0.01em;margin:0;}
h2{font-size:var(--fs-h2);line-height:1.1;letter-spacing:-0.01em;margin:0;}
h3{font-size:var(--fs-h3);line-height:1.25;margin:0;}
h4{font-size:var(--fs-sub);line-height:1.3;margin:0;}

/* Global paragraph + lead text — serif face */
p{ font-family:var(--serif); font-size:var(--fs-body); line-height:1.65; }

/* UI elements — sans-serif (nav, buttons, inputs, labels, selects) */
nav, button, input, select, textarea, label,
.nav, .eyebrow, .chip, .btn, .icon-btn,
.header, .footer, .drawer, .mobile-menu{
  font-family:var(--sans);
}

/* Welcome popup — mobile */
@media (max-width: 720px) {
  .wp-card { grid-template-columns: 1fr !important; max-width: 420px !important; }
  .wp-visual { min-height: 200px !important; padding: 32px 28px !important; }
  .wp-visual + div { padding: 36px 28px !important; min-height: auto !important; }
}

img{max-width:100%;display:block;}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;}
a{color:inherit;text-decoration:none;}
input,select,textarea{font:inherit;color:inherit;}

/* Type scale */
.h-display{font-family:var(--display);font-weight:400;letter-spacing:-0.01em;line-height:0.98;}
.h-serif{font-family:var(--serif);font-weight:400;letter-spacing:-0.005em;}
.eyebrow{
  font-family:var(--sans);
  font-size:var(--fs-eyebrow);
  letter-spacing:0.22em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--muted);
}
.eyebrow.gold{color:var(--gold);}    /* walnut */
.eyebrow.red{color:var(--vermilion);}  /* kumkum — for CTA-style emphasis only */
.devnagari{font-family:"Cormorant Garamond",serif;}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;
  border-radius:999px;
  font-size:13px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  font-weight:500;
  transition:all .35s var(--ease);
  white-space:nowrap;
  cursor:pointer;
  border:1px solid transparent;
}
.btn-primary{background:var(--ink);color:var(--ivory);}
.btn-primary:hover{background:var(--ink-2);opacity:0.92;}
.btn-vermilion{background:var(--vermilion);color:var(--ivory-2);}
.btn-vermilion:hover{background:var(--vermilion-deep);}
.btn-ghost{border:1px solid var(--line-strong);color:var(--ink);}
.btn-ghost:hover{border-color:var(--ink);background:var(--ink);color:var(--ivory);}
.btn-ghost-light{border:1px solid rgba(245,239,230,0.4);color:var(--ivory);}
.btn-ghost-light:hover{background:var(--ivory);color:var(--ink);}
.btn-link{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;letter-spacing:0.18em;text-transform:uppercase;
  border-bottom:1px solid currentColor;padding-bottom:3px;
}

/* Container & rule */
.container{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);}
.rule{height:1px;background:var(--line);}
.rule-gold{height:1px;background:linear-gradient(90deg,transparent,var(--gold-soft),transparent);}

/* Section */
section{position:relative;}
.section-pad{padding:80px 0;}
.section-pad-sm{padding:60px 0;}

/* Image placeholder — duotone of ink + sandstone (no decorative red/gold) */
.img-ph{
  position:relative;
  background:
    radial-gradient(120% 80% at 30% 20%, rgba(217,199,176,0.18), transparent 55%),
    linear-gradient(140deg,#1A1612 0%, #2a221c 60%, #1A1612 100%);
  overflow:hidden;
}
.img-ph.warm{
  background:
    radial-gradient(120% 80% at 70% 20%, rgba(217,199,176,0.32), transparent 55%),
    linear-gradient(140deg,#3a2d24 0%, #5a4636 50%, #2a221c 100%);
}
.img-ph.cream{
  background:
    radial-gradient(120% 80% at 30% 20%, rgba(255,255,255,0.55), transparent 55%),
    linear-gradient(140deg,#FFFFFF 0%, #D9C7B0 100%);
}
.img-ph.dark{
  background:
    radial-gradient(110% 70% at 30% 20%, rgba(140,110,84,0.22), transparent 55%),
    linear-gradient(160deg,#1A1612 0%, #2a221c 100%);
}

/* Hair texture overlay (CSS-only) */
.hair-texture::after{
  content:"";position:absolute;inset:0;
  background:
    repeating-linear-gradient(
      102deg,
      rgba(0,0,0,0.22) 0 1px,
      transparent 1px 3px,
      rgba(217,199,176,0.05) 3px 4px,
      transparent 4px 7px
    );
  mix-blend-mode:overlay;
  opacity:0.7;
  pointer-events:none;
}

/* Decorative ornaments — walnut, never red */
.ornament{display:inline-flex;align-items:center;gap:14px;color:var(--gold);}
.ornament::before,.ornament::after{
  content:"";width:48px;height:1px;background:currentColor;opacity:0.45;
}
.diamond{
  width:5px;height:5px;background:currentColor;
  transform:rotate(45deg);display:inline-block;
  opacity:0.7;
}

/* Tags / chips */
.chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:999px;
  font-size:11px;letter-spacing:0.14em;text-transform:uppercase;
  border:1px solid var(--line-strong);
  background:transparent;
  cursor:pointer;
  transition:all .25s var(--ease);
  color:var(--ink);
}
.chip:hover{background:var(--bone);border-color:var(--ink);color:var(--ink);}
.chip.active{background:var(--ink);color:var(--ivory);border-color:var(--ink);}
.cat-chip.active{background:var(--ink);color:rgb(243,234,189);border-color:var(--ink);box-shadow:none;}
.chip-gold{border-color:var(--gold);color:var(--gold);}
.chip-red{border-color:var(--vermilion);color:var(--vermilion);}

/* Form controls */
.field{display:flex;flex-direction:column;gap:6px;}
.field label{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);}
.field input,.field select,.field textarea{
  background:transparent;
  border:0;border-bottom:1px solid var(--line-strong);
  padding:10px 0;font-size:14px;outline:none;
  transition:border-color .3s var(--ease);
  font-family:var(--sans);
  border-radius:0;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--ink);}

/* Card */
.card{
  background:var(--ivory-2);
  border:1px solid var(--line);
  transition:all .35s var(--ease);
}
.card:hover{border-color:var(--ink);}

/* Marquee */
@keyframes marquee {
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}
.marquee{display:flex;width:max-content;animation:marquee 40s linear infinite;}

/* Reveal on view */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease), transform .9s var(--ease);}
.reveal.in{opacity:1;transform:none;}

/* Top announcement bar */
.announce{
  background:var(--ink);color:var(--ivory);
  font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  padding:10px 0;text-align:center;
  overflow:hidden;
}
.announce .marquee{animation-duration:55s;}
.announce span{padding:0 28px;display:inline-flex;align-items:center;gap:14px;}
.announce .dot{width:3px;height:3px;background:var(--bone);border-radius:50%;opacity:0.6;}

/* Header */
.header{
  position:sticky;top:0;z-index:60;
  background:var(--ivory);
  border-bottom:1px solid var(--line);
  transition:all .3s var(--ease);
}
.header-inner{
  display:flex;align-items:center;gap:28px;
  padding:8px 0;
}
.header.dark{background:rgba(14,11,10,0.92);color:var(--ivory);border-color:rgba(245,239,230,0.1);backdrop-filter:blur(12px);}
.nav{display:flex;gap:24px;align-items:center;}
.nav a{
  font-size:12px;letter-spacing:0.18em;text-transform:uppercase;font-weight:500;
  position:relative;padding:6px 0;
  transition:color .22s var(--ease);
}
.nav a::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;
  background:var(--nav-accent);transform:scaleX(0);transform-origin:left;
  transition:transform .28s var(--ease), background-color .22s var(--ease);
}
.nav a:hover,.nav a.active{color:var(--nav-accent);}
.nav a:hover::after,.nav a.active::after{transform:scaleX(1);}

/* Nav trigger buttons (dropdown openers) */
.nav-trigger{
  background:none;border:0;cursor:pointer;color:inherit;
  font-family:inherit;font-size:12px;letter-spacing:0.18em;text-transform:uppercase;font-weight:500;
  padding:6px 0;display:inline-flex;align-items:center;gap:6px;
  position:relative;white-space:nowrap;
  transition:color .22s var(--ease);
}
.nav a{white-space:nowrap;}
.nav-trigger::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;
  background:var(--nav-accent);transform:scaleX(0);transform-origin:left;
  transition:transform .28s var(--ease), background-color .22s var(--ease);
}
.header.dark .nav-trigger::after{background:var(--ivory);}
.nav-trigger:hover,.nav-trigger.open{color:var(--nav-accent);}
.nav-trigger:hover::after,.nav-trigger.open::after{transform:scaleX(1);}
.header-left{display:flex;align-items:center;justify-content:flex-start;}
.nav-trigger svg{transition:transform .25s var(--ease), color .22s var(--ease), opacity .22s var(--ease);opacity:0.6;}
.nav-trigger:hover svg,.nav-trigger.open svg{color:var(--nav-accent);opacity:1;}
.nav-trigger.open svg{transform:rotate(180deg);}

/* Mega dropdown */
.mega-wrap{
  position:absolute;left:0;right:0;top:100%;
  background:var(--ivory);border-top:1px solid var(--rule);
  box-shadow:0 24px 40px -24px rgba(58,42,28,0.18);
  opacity:0;pointer-events:none;transform:translateY(-6px);
  transition:opacity .25s var(--ease), transform .25s var(--ease);
  z-index:50;
}
.header.dark .mega-wrap{background:var(--ink);color:var(--ivory);border-color:rgba(245,239,230,0.1);}
.mega-wrap.open{opacity:1;pointer-events:auto;transform:translateY(0);}
.mega-panel{padding:34px 0 42px;}
.mega-panel--compact{padding:18px 0 22px;}
.mega-head{margin-bottom:20px;text-align:center;}
.mega-grid{display:grid;gap:28px 48px;justify-content:center;margin:0 auto;}
.mega-grid-2{grid-template-columns:repeat(2,minmax(280px,360px));}
.mega-grid-shop{grid-template-columns:repeat(3,minmax(220px,280px));}
.mega-grid-shop-compact{grid-template-columns:repeat(4,minmax(140px,170px));gap:4px 12px;}
.mega-item{
  display:block;padding:14px 16px 14px 0;border-radius:2px;
  transition:background .22s var(--ease), transform .22s var(--ease), color .22s var(--ease);
  text-decoration:none;color:inherit;
}
.mega-item.compact{padding:8px 14px 8px 14px;text-align:center;}
.mega-item:hover{background:rgba(117,20,16,0.05);transform:translateX(4px);}
.mega-item.compact:hover{transform:none;}
.mega-item:hover .mega-item-title{color:var(--nav-accent);}
.mega-item-title{font-size:22px;line-height:1.2;margin-bottom:6px;transition:color .22s var(--ease);}
.mega-item.compact .mega-item-title{font-size:17px;margin-bottom:0;}
.mega-item-title.h-display{font-family:var(--display);font-weight:400;letter-spacing:-0.01em;}
.mega-item-title.h-serif{font-family:var(--serif);font-weight:500;}
.mega-item-desc{font-size:13px;color:var(--ink-soft);line-height:1.5;letter-spacing:0.01em;}
.header.dark .mega-item-desc{color:rgba(245,239,230,0.6);}
@media (max-width: 900px){
  .mega-wrap{display:none;}
}

.logo{
  font-family:var(--display);
  font-size:22px;letter-spacing:0.04em;
  display:flex;flex-direction:column;align-items:center;line-height:1;
  cursor:pointer;
}
.logo .mark{font-family:var(--display);font-size:22px;}
.logo .sub{font-size:9px;letter-spacing:0.4em;color:var(--gold);margin-top:4px;text-transform:uppercase;} /* walnut */

/* === PDP recommended + reviews mobile === */
@media (max-width:1024px){
  .pdp-recommend-grid{grid-template-columns:repeat(2,1fr) !important;}
  .pdp-reviews-grid{grid-template-columns:1fr !important;}
}
@media (max-width:768px){
  .pdp-recommend-grid{grid-template-columns:1fr 1fr !important; gap:14px !important;}
  .pdp-reviews-grid{grid-template-columns:1fr !important; gap:14px !important;}
  .pdp-reviews-head h2,
  .pdp-faq .h-display{font-size:22px !important;}

  /* PDP grid collapse — image gallery first, info below */
  [style*="grid-template-columns: 1.4fr 1fr"],
  [style*="grid-template-columns:1.4fr 1fr"]{
    grid-template-columns:1fr !important;
    gap:30px !important;
  }
  /* PDP trust strip — 2 col already, tighten */
  .trust-strip,
  [style*="grid-template-columns:repeat(2, 1fr)"][style*="border-top"]{
    gap:12px !important;
  }
  /* Quiz length grid — 2-col instead of 4 on phone */
  .quiz-length-grid{grid-template-columns:repeat(2, 1fr) !important;}
  /* Shade swatches — keep 4-col but smaller */
  .quiz-shade-grid{grid-template-columns:repeat(2, 1fr) !important;}
  /* Bridal hero on phone tighter */
  .bridal-hero-h1{padding:0 8px;}
  /* Edit hero copy tighter */
  .edit-hero{padding:46px 0 !important; min-height:30vh !important;}
  /* Categories grid — 2x2 already enforced */
  /* Hide secondary nav row on phone since it's in mobile sheet */
  /* Welcome popup — tighter padding */
  .wp-card{margin:12px;}
  .wp-pad{padding:0 24px 22px !important;}
  .wp-hero-pad,.wp-left{padding:24px 22px 8px !important;}
  .wp-mega{font-size:88px !important;}
  /* Footer — ensure footer logo image scales */
  .footer img{max-height:36px;}
  /* Long inline section padding 140px → 60 */
  [style*="padding: 140px 0"],[style*="padding:140px 0"]{padding:60px 0 !important;}
}
@media (max-width:420px){
  .wp-mega{font-size:72px !important;}
  .pdp-recommend-grid .product-card h4{font-size:14px !important;}
  .pdp-recommend-grid{gap:10px !important;}
  .edit-hero-h1{padding:0 12px;}
}
.logo-img{
  align-items:center;
  height: clamp(42px, 4.6vw, 64px);
  aspect-ratio: 2.7 / 1;
  background-image: url('assets/silkystrands-logo.png');
  background-repeat: no-repeat;
  background-size: 270% auto;
  background-position: 50% 52%;
  flex: 0 0 auto;
}
.logo-img--invert{ filter: invert(1); }
@media (max-width:360px){
  .logo-img{ height: 48px; }
}

.icons{display:flex;justify-content:flex-end;gap:18px;align-items:center;margin-left:auto;}
.icon-btn{
  width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:50%;position:relative;
  transition:background .22s var(--ease), color .22s var(--ease);
}
.icon-btn:hover,.icon-btn:active,.icon-btn:focus-visible{
  background:rgba(117,20,16,0.06);color:var(--nav-accent);
}
.header.dark .icon-btn:hover,.header.dark .icon-btn:active{
  background:rgba(245,239,230,0.1);color:var(--nav-accent);
}
.cart-count{
  position:absolute;top:2px;right:2px;
  background:var(--vermilion);color:var(--ivory);
  font-size:9px;font-weight:600;
  width:16px;height:16px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}
.wishlist-count{
  position:absolute;top:2px;right:2px;
  background:var(--nav-accent);color:var(--ivory);
  font-size:9px;font-weight:600;
  width:16px;height:16px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}

/* Footer */
.footer{
  background:var(--ink);color:var(--ivory);
  padding:54px 0 22px;
}
.footer .footer-grid{
  display:grid;
  grid-template-columns:1.6fr 1fr 0.8fr 1fr 1fr;
  gap:28px;
}
.footer h5{
  font-family:var(--sans);font-size:10px;letter-spacing:0.22em;
  text-transform:uppercase;font-weight:500;color:var(--bone);
  margin:0 0 14px;
}
.footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:7px;}
.footer a{font-size:12.5px;color:rgba(245,239,230,0.7);transition:color .25s var(--ease);}
.footer a:hover{color:var(--ivory);}
.footer-bottom{
  margin-top:36px;padding-top:18px;
  border-top:1px solid rgba(245,239,230,0.1);
  display:flex;justify-content:space-between;align-items:center;
  font-size:10px;letter-spacing:0.16em;text-transform:uppercase;
  color:rgba(245,239,230,0.5);
}

/* Shop (category) grid — 2-up on phone */
@media (max-width:768px){
  .shop-grid,
  .shop-grid[style*="grid-template-columns"]{
    grid-template-columns:repeat(2, 1fr) !important;
    gap:16px 12px !important;
  }
  .shop-grid .product-card .pc-info{padding:12px 0 4px;}
  .shop-grid .product-card .pc-info h4{font-size:14px;}
  .shop-grid .product-card .pc-price{font-size:13px;}
  /* Quick-add button — keep tappable but compact in the tighter 2-up tile */
  .shop-grid .product-card .pc-quick{font-size:10.5px; padding:9px 12px;}
}
@media (max-width:420px){
  .shop-grid,
  .shop-grid[style*="grid-template-columns"]{gap:14px 10px !important;}
  .shop-grid .product-card .pc-info h4{font-size:13px;}
}

/* Breadcrumbs — elegant minimal */
.breadcrumb{
  display:flex;flex-wrap:wrap;gap:10px;align-items:center;
  font-size:10.5px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--muted);
}
.breadcrumb a{
  color:var(--muted);
  border-bottom:1px solid transparent;
  transition:color .22s var(--ease), border-color .22s var(--ease);
}
.breadcrumb a:hover{color:var(--vermilion); border-bottom-color:var(--vermilion);}
.breadcrumb span[aria-current="page"]{color:var(--ink); font-weight:500;}
.breadcrumb svg{color:var(--bone); opacity:0.7; flex-shrink:0;}
@media (max-width:768px){
  .breadcrumb-wrap{padding:14px 18px 0 !important;}
  .breadcrumb{font-size:9.5px; letter-spacing:0.14em; gap:7px;}
  .breadcrumb svg{width:8px; height:8px;}
}

/* PDP shipping note — keep subtle but visible on phone */
@media (max-width:768px){
  .pdp-ship-note{font-size:12px !important; padding:10px 12px !important; gap:8px !important;}
}

/* Quiz progress row collapse on phone */
@media (max-width:768px){
  .quiz-progress{flex-wrap:wrap !important; gap:10px;}
  .quiz-progress > div[style*="height:1px"]{width:100% !important; flex:0 0 100% !important; order:3; margin:0 !important;}
  .quiz-question{font-size:clamp(26px, 7vw, 38px) !important;}
}

/* Footer — compact inline new-customer signup (brand column) */
.footer-signup-form{
  display:flex;flex-wrap:wrap;gap:6px;align-items:stretch;max-width:320px;
}
.footer-signup-form input[type="email"]{
  flex:1 1 160px;
  min-width:0;
  background:transparent;
  border:1px solid rgba(245,239,230,0.24);
  color:var(--ivory);
  padding:9px 12px;
  font-family:var(--sans);font-size:12.5px;letter-spacing:0.02em;
  outline:none;
  transition:border-color .2s var(--ease), background .2s var(--ease);
}
.footer-signup-form input[type="email"]::placeholder{color:rgba(245,239,230,0.4);}
.footer-signup-form input[type="email"]:focus{
  border-color:var(--gold-light);
  background:rgba(245,239,230,0.04);
}
.footer-signup-form .btn{padding:9px 16px;font-size:10.5px;letter-spacing:0.14em;min-height:0;}
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* Hero motion */
@keyframes hairFlow {
  0%{transform:translateY(0) scaleY(1);}
  50%{transform:translateY(-1.5%) scaleY(1.01);}
  100%{transform:translateY(0) scaleY(1);}
}
@keyframes shimmer {
  0%{background-position:-200% 0;}
  100%{background-position:200% 0;}
}
@keyframes fadeUp {
  from{opacity:0;transform:translateY(40px);}
  to{opacity:1;transform:none;}
}
.fade-up{animation:fadeUp 1.1s var(--ease) both;}
.fade-up-d1{animation-delay:.15s;}
.fade-up-d2{animation-delay:.3s;}
.fade-up-d3{animation-delay:.45s;}
.fade-up-d4{animation-delay:.6s;}

/* Page transitions */
.page-enter{animation:fadeUp .7s var(--ease);}

/* Drawer */
.drawer-overlay{
  position:fixed;inset:0;background:rgba(14,11,10,0.45);
  z-index:80;opacity:0;pointer-events:none;
  transition:opacity .35s var(--ease);
}
.drawer-overlay.open{opacity:1;pointer-events:auto;}
.drawer{
  position:fixed;top:0;right:0;bottom:0;width:min(440px,90vw);
  background:var(--ivory);z-index:90;
  transform:translateX(100%);transition:transform .45s var(--ease);
  display:flex;flex-direction:column;
}
.drawer.open{transform:none;}
.drawer-header{
  padding:24px 28px;display:flex;justify-content:space-between;align-items:center;
  border-bottom:1px solid var(--line);
}
.drawer-body{flex:1;overflow-y:auto;padding:24px 28px;}
.drawer-foot{padding:24px 28px;border-top:1px solid var(--line);}

/* Utility */
.flex{display:flex;}
.between{justify-content:space-between;}
.center{align-items:center;}
.col{flex-direction:column;}
.gap-8{gap:8px;}
.gap-12{gap:12px;}
.gap-16{gap:16px;}
.gap-24{gap:24px;}
.gap-32{gap:32px;}
.text-center{text-align:center;}
.muted{color:var(--muted);}
.gold{color:var(--gold);}
.red{color:var(--vermilion);}
.ivory-bg{background:var(--ivory);}
.bone-bg{background:var(--ivory);}
.dark-bg{background:var(--ink);color:var(--ivory);}
.red-bg{background:var(--vermilion);color:var(--ivory);}

/* Page heading hero */
.page-hero{
  padding:60px 0 44px;
  text-align:center;
  border-bottom:1px solid var(--line);
}
.page-hero h1{
  font-family:var(--display);font-size:clamp(48px,7vw,96px);
  margin:14px 0 10px;font-weight:400;letter-spacing:-0.01em;
}
.page-hero p{max-width:560px;margin:0 auto;color:var(--muted);font-size:15px;}

/* Product card */
.product-card{cursor:pointer;}
.product-card .pc-img{aspect-ratio:4/5;position:relative;overflow:hidden;}
.product-card .pc-img > div{transition:transform .8s var(--ease);}
.product-card:hover .pc-img > div{transform:scale(1.04);}
.product-card .pc-info{padding:18px 0 4px;}
.product-card h4{
  font-family:var(--product-font);font-weight:500;font-size:15px;
  margin:0 0 4px;letter-spacing:-0.005em;line-height:1.35;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.product-card .pc-price{font-family:var(--product-font);font-size:13px;font-weight:500;letter-spacing:0.01em;}
.product-card .pc-price .strike{color:var(--muted);text-decoration:line-through;margin-right:8px;font-weight:400;}
.product-card .pc-quick{
  position:absolute;left:16px;right:16px;bottom:16px;
  background:var(--ivory);color:var(--ink);
  text-align:center;padding:12px;
  font-size:11px;letter-spacing:0.18em;text-transform:uppercase;
  opacity:0;transform:translateY(10px);
  transition:all .35s var(--ease);
}
.product-card:hover .pc-quick{opacity:1;transform:none;}
/* Corner tags — use ink/ivory by default to keep red CTA-only.
   Add .tag-corner.red on a New/Bestseller etc only when truly highlighting a buying decision. */
.tag-corner{
  position:absolute;top:10px;left:10px;
  background:var(--ink);color:var(--ivory);
  font-size:9px;letter-spacing:0.14em;text-transform:uppercase;
  padding:4px 8px;
}
.tag-corner.red{background:var(--vermilion);}

/* Product card subtitle — spec line beneath name on listing tiles */
.pc-subtitle{
  font-family:var(--serif);
  font-size:12px;
  color:var(--muted);
  letter-spacing:0.03em;
  margin:2px 0 6px;
  line-height:1.4;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

/* PDP subtitle — spec line beneath the product h1 on the detail page */
.pdp-subtitle{
  font-family:var(--serif);
  font-size:17px;
  color:var(--muted);
  letter-spacing:0.01em;
  margin:0 0 4px;
  line-height:1.5;
}
@media (max-width:768px){
  .pdp-subtitle{ font-size:14px !important; margin-bottom:4px !important; }
  .pc-subtitle{ font-size:11px; }
}

/* Tweaks panel container override */
.tweaks-panel{font-family:var(--sans);}

/* Scrollbar */
::-webkit-scrollbar{width:8px;height:8px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:rgba(26,22,18,0.18);border-radius:4px;}
::-webkit-scrollbar-thumb:hover{background:rgba(26,22,18,0.32);}

/* Collapse padding between consecutive same-bg ivory sections */
.ivory-bg + .ivory-bg{padding-top:0;}
.section-pad.ivory-bg + .section-pad.ivory-bg{padding-top:0;}
.usp-section + .section-pad.ivory-bg{padding-top:40px;}

/* ===== Bestseller carousel ===== */
.bestseller-carousel{
  overflow:hidden;
  width:100%;
}
.bestseller-track{
  display:flex;
  transition:transform .8s var(--ease);
  width:100%;
}
.bestseller-page{
  flex:0 0 100%;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:24px;
}
/* Bestseller section — tighter padding than generic section-pad */
.section-pad.ivory-bg:has(.bestseller-carousel) { padding:60px 0; }

/* ===== USP 2x2 grid ===== */
.usp-section{padding:60px 0;background:var(--ivory);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.usp-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  border:1px solid var(--line);
  background:var(--ivory-2);
}
.usp-card{
  padding:28px 26px;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  position:relative;
  transition:background .35s var(--ease);
}
.usp-card:nth-child(2n){border-right:0;}
.usp-card:nth-child(n+3){border-bottom:0;}
.usp-card:hover{background:var(--ivory);}
.usp-card-head{display:flex;align-items:center;justify-content:space-between;}
.usp-num{
  font-family:var(--display);font-size:26px;color:var(--gold);
  letter-spacing:0.02em;
}
.usp-icon{
  width:38px;height:38px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--line);color:var(--ink);
}
.usp-title{
  font-size:30px;line-height:1.18;font-weight:500;margin:10px 0 6px;letter-spacing:-0.01em;
}
.usp-body{
  color:var(--muted);font-size:14px;line-height:1.65;margin:0;
  font-family:var(--serif);
}

/* ===== Hero carousel ===== */
.hero-carousel{
  position:relative;
  height:calc(100vh - 140px);
  min-height:600px;
  overflow:hidden;
  color:var(--ivory);
  background:var(--ink);
}
.hero-slides{position:absolute;inset:0;}
.hero-slide{
  position:absolute;inset:0;
  opacity:0;
  transition:opacity 1.2s var(--ease);
  pointer-events:none;
}
.hero-slide.active{opacity:1;pointer-events:auto;}
.hero-slide .hero-bg{
  position:absolute;inset:0;width:100%;height:100%;
  transform:scale(1.05);
  animation:heroKen 9s var(--ease) both;
}
.hero-slide.active .hero-bg{transform:scale(1);}
@keyframes heroKen{
  from{transform:scale(1.12);}
  to{transform:scale(1.0);}
}
.hero-scrim{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(26,22,18,0.55) 0%, rgba(26,22,18,0.35) 40%, rgba(26,22,18,0.85) 100%);
}
.hero-canvas-wrap{position:absolute;inset:0;mix-blend-mode:screen;opacity:0.45;}
.hero-content{
  position:relative;height:100%;
  display:flex;flex-direction:column;justify-content:center;
  z-index:2;
}
.hero-copy{animation:heroFade .9s var(--ease);}
@keyframes heroFade{
  from{opacity:0;transform:translateY(20px);}
  to{opacity:1;transform:none;}
}
.hero-dots{
  position:absolute;bottom:30px;left:0;right:0;
  display:flex;justify-content:center;gap:14px;
  z-index:3;
}
.hero-dot{
  width:36px;height:24px;display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;background:none;border:0;padding:0;
}
.hero-dot span{
  display:block;height:1px;width:100%;
  background:rgba(245,239,230,0.35);
  transition:all .4s var(--ease);
}
.hero-dot.active span{background:var(--ivory);height:2px;}


.mobile-only{display:none;}
.desktop-only{display:flex;}
.mobile-menu{
  position:fixed;inset:0;z-index:75;
  background:rgba(26,22,18,0.4);
  opacity:0;pointer-events:none;
  transition:opacity .3s var(--ease);
}
.mobile-menu.open{opacity:1;pointer-events:auto;}
.mobile-menu-inner{
  position:absolute;top:0;left:0;right:0;
  background:var(--ivory);
  padding:90px 24px 30px;
  display:flex;flex-direction:column;gap:6px;
  transform:translateY(-100%);
  transition:transform .4s var(--ease);
  box-shadow:0 12px 40px rgba(26,22,18,0.18);
}
.mobile-menu.open .mobile-menu-inner{transform:none;}
.mobile-menu-inner a{
  font-family:var(--serif);font-size:22px;
  padding:12px 4px;border-bottom:1px solid var(--line);
  letter-spacing:-0.01em;
}
.mobile-menu-inner a:last-of-type{border-bottom:0;}

/* Mobile menu — accordion + close header */
.mm-head{display:flex;align-items:center;justify-content:space-between;padding:4px 4px 14px;border-bottom:1px solid var(--line);margin-bottom:10px;}
.mm-acc{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;padding:14px 4px;
  font-family:var(--serif);font-size:22px;letter-spacing:-0.01em;
  border-bottom:1px solid var(--line);
  background:none;border-top:0;border-left:0;border-right:0;cursor:pointer;color:inherit;
  transition:color .22s var(--ease), border-color .22s var(--ease);
}
.mm-acc svg{transition:transform .25s var(--ease), color .22s var(--ease), opacity .22s var(--ease);opacity:0.55;}
.mm-acc:hover,.mm-acc:active,.mm-acc.open{color:var(--nav-accent);border-bottom-color:var(--nav-accent);}
.mm-acc:hover svg,.mm-acc:active svg,.mm-acc.open svg{color:var(--nav-accent);opacity:1;}
.mm-acc.open svg{transform:rotate(180deg);}
.mm-panel{padding:6px 4px 12px 18px;border-bottom:1px solid var(--line);background:rgba(184,140,77,0.04);}
.mm-panel a{font-family:var(--serif);font-size:18px;padding:10px 4px;display:block;border-bottom:1px solid rgba(0,0,0,0.05);transition:color .22s var(--ease);}
.mm-panel a:hover,.mm-panel a:active,.mm-panel a.active{color:var(--nav-accent);}
.mm-panel a:last-child{border-bottom:0;}
.mm-flat{display:block;font-family:var(--serif);font-size:20px;padding:14px 4px;border-bottom:1px solid var(--line);transition:color .22s var(--ease), border-color .22s var(--ease);}
.mm-flat:hover,.mm-flat:active,.mm-flat.active{color:var(--nav-accent);border-bottom-color:var(--nav-accent);}

/* ===== Our Story ===== */
@media (max-width:900px){
  .our-story-grid{grid-template-columns:1fr !important;gap:40px !important;}
}

/* ===== Edit Carousel (Bridal / Crown) ===== */
.edit-carousel-section{
  position:relative;overflow:hidden;
  background:var(--ink);
}
.edit-carousel-track{
  display:flex;
  transition:transform .8s var(--ease);
  touch-action:pan-y;
}
.edit-slide{
  flex:0 0 100%;
  position:relative;
  min-height:600px;
  display:flex;align-items:center;justify-content:center;
  padding:90px 0;
}
.edit-slide-bg{position:absolute;inset:0;width:100%;height:100%;}
.edit-slide-overlay{position:absolute;inset:0;background:linear-gradient(180deg, rgba(14,11,10,0.55), rgba(14,11,10,0.78));}
.edit-slide-content{position:relative;text-align:center;z-index:2;}
.edit-carousel-dots{
  position:absolute;left:0;right:0;bottom:30px;
  display:flex;justify-content:center;gap:10px;z-index:3;
}
.edit-dot{
  width:36px;height:2px;background:rgba(245,239,230,0.3);border:0;cursor:pointer;
  transition:background .3s, width .3s;
}
.edit-dot.active{background:var(--gold);width:56px;}

@media (max-width:768px){
  .edit-slide{min-height:480px;padding:60px 0 80px;}
}

/* ===== Reviews — Before/After ===== */
.review-card{
  display:grid;grid-template-columns:1.05fr 1fr;
  gap:50px;align-items:center;
  max-width:1100px;margin:0 auto;
  background:var(--ivory);
  border:1px solid var(--line);
  padding:36px;border-radius:2px;
}
.review-ba{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.review-ba-cell{position:relative;}
.review-ba-label{
  position:absolute;left:12px;bottom:12px;
  background:rgba(14,11,10,0.78);color:var(--ivory);
  padding:5px 10px;font-size:10px;letter-spacing:0.18em;text-transform:uppercase;
}
.review-body{padding:8px 12px;}
@media (max-width:900px){
  .review-card{grid-template-columns:1fr !important;gap:30px;padding:24px;}
}
@media (max-width:768px){
  .review-card{padding:18px;}
  .review-ba{gap:10px;}
}

/* ============ Responsive ============ */

/* Tablet */
@media (max-width:1024px){
  :root{--gut:24px;}
  .section-pad{padding:90px 0;}
  /* Bestsellers — 2x2 on tablet */
  .bestseller-page{grid-template-columns:1fr 1fr !important;gap:20px;}
  /* Categories — keep 2x2 on tablet, narrower max-width */
  .categories-grid{max-width:720px !important;}

  /* Collapse 4-up product/category grids to 2 */
  [style*="grid-template-columns: repeat(4, 1fr)"],
  [style*="grid-template-columns:repeat(4, 1fr)"],
  [style*="grid-template-columns:repeat(4,1fr)"]{
    grid-template-columns:repeat(2, 1fr) !important;
  }
  /* Collapse 3-up to 2 */
  [style*="grid-template-columns: repeat(3, 1fr)"],
  [style*="grid-template-columns:repeat(3, 1fr)"],
  [style*="grid-template-columns:repeat(3,1fr)"]{
    grid-template-columns:repeat(2, 1fr) !important;
  }
  /* Two-column editorial splits — keep on tablet but tighten gap */
  .container[style*="grid-template-columns"]{ gap:48px !important; }

  .footer .footer-grid{grid-template-columns:1.3fr 1fr 0.8fr 1fr 1fr !important; gap:18px 22px;}
}

/* Phone */
@media (max-width:768px){
  :root{
    --gut:18px;
    --maxw:100%;
  }

  /* Header */
  .nav{display:none;}
  .desktop-only{display:none !important;}
  .mobile-only{display:inline-flex;}
  .header-inner{
    display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
    gap:0;padding:6px 0;
  }
  .header-left{justify-self:start;}
  .header-inner > .logo-img{justify-self:center;margin:0;}
  .icons{justify-self:end;margin-left:0;}

  /* Section padding tighter */
  .section-pad{padding:48px 0 !important;}
  .usp-section{padding:40px 0 !important;}

  /* Bestsellers — keep 2x2 on phone */
  .bestseller-page,
  .bestseller-page[style*="grid-template-columns"]{grid-template-columns:1fr 1fr !important;gap:14px !important;}
  .bestseller-carousel{max-width:100%;}
  /* Categories — also keep 2x2 on phone (matches Bestsellers rhythm) */
  .categories-grid,
  .categories-grid[style*="grid-template-columns"]{grid-template-columns:1fr 1fr !important;gap:14px !important;max-width:100% !important;}

  /* USP — keep 2x2 on phone, tighter padding */
  .usp-section{padding:60px 0;}
  .usp-grid{grid-template-columns:1fr 1fr !important;gap:0 !important;}
  .usp-card{padding:18px 14px;}
  .usp-num{font-size:18px;}
  .usp-icon{width:30px;height:30px;}
  .usp-title{font-size:20px;margin:8px 0 4px;line-height:1.2;}
  .usp-body{font-size:12.5px;line-height:1.55;}

  /* Hero — full-bleed edge-to-edge image, shrink height */
  .hero-floater{display:none !important;}
  .hero-carousel{
    height:auto !important;
    min-height:0 !important;
    margin-left:calc(-1 * var(--gut));
    margin-right:calc(-1 * var(--gut));
    width:auto;
  }
  .hero-carousel .hero-content{
    padding:0 var(--gut);
    min-height:78vh;
    justify-content:flex-end;
    padding-bottom:90px;
    padding-top:40px;
  }
  .hero-h1{font-size:clamp(36px,11vw,60px) !important; line-height:1.02 !important;}
  .hero-copy p{font-size:15px !important;line-height:1.55 !important;}
  .hero-copy .ornament span:nth-child(2){font-size:9px !important;letter-spacing:0.24em !important;}
  .hero-dots{bottom:22px;}
  .hero-dot{width:28px;}
  .hero-section{height:auto !important; min-height:480px !important; padding:60px 0 80px;}
  .header{padding:10px 0;}
  /* Keep the header pinned on phones too */
  .header{position:sticky !important; top:0 !important; z-index:60;}
  .icons{gap:6px;}
  .icon-btn{width:32px;height:32px;}
  .icons .icon-btn svg{width:18px;height:18px;}
  .logo .mark{font-size:18px;}
  .logo .sub{font-size:8px;letter-spacing:0.32em;}

  /* Announce bar — slow + smaller */
  .announce{font-size:9px;letter-spacing:0.18em;padding:8px 0;}

  /* Sections */
  .section-pad{padding:64px 0;}
  .page-hero{padding:38px 0 28px;}
  .page-hero h1{font-size:clamp(34px,8.5vw,52px);margin:10px 0 8px;}
  .page-hero p{font-size:14px;max-width:90%;}

  /* Universal grid collapse — every inline gridTemplateColumns becomes single column.
     Selector matches anything that has grid-template-columns set inline. */
  [style*="grid-template-columns"]{
    grid-template-columns:1fr !important;
    gap:24px !important;
  }
  /* …except a handful that MUST stay multi-column on phone (cart line items, order tracking dots, etc.) — restore to readable defaults */
  /* Cart drawer line items: image + content — keep 2-col but smaller image */
  .drawer [style*="grid-template-columns: 96px"],
  .drawer [style*="grid-template-columns:96px"]{
    grid-template-columns:72px 1fr !important;
    gap:12px !important;
  }
  /* Search results */
  [style*="grid-template-columns: 80px 1fr auto"],
  [style*="grid-template-columns:80px 1fr auto"]{
    grid-template-columns:60px 1fr !important;
    gap:12px !important;
  }
  /* Order tracking step dot lane */
  [style*="grid-template-columns: 40px 1fr auto"],
  [style*="grid-template-columns:40px 1fr auto"]{
    grid-template-columns:32px 1fr auto !important;
    gap:12px !important;
  }
  /* Product gallery thumbs (4-up under main image) — keep 4 across, just smaller */
  [style*="grid-template-columns:repeat(4,1fr)"][style*="gap:14px"],
  [style*="grid-template-columns: repeat(4, 1fr)"][style*="gap: 14px"]{
    grid-template-columns:repeat(4, 1fr) !important;
    gap:8px !important;
  }
  /* Quiz options — keep 2-up for shade swatches */
  /* (already covered by universal collapse; quiz uses 2-col which is fine 1-col on phone) */

  /* Container grids: shrink gap */
  .container[style*="grid-template-columns"]{ gap:40px !important; }

  /* Display type — keep dramatic but cap so it doesn't spill */
  .h-display{font-size:clamp(28px,9vw,48px) !important;}

  /* Typography clamps via inline clamp() already work; just scale hero h1 */
  h1{font-size:clamp(34px,9vw,56px);}
  h2{font-size:clamp(28px,7vw,44px);}

  /* Product card — mobile font sizes */
  .product-card h4                    { font-size:16px !important; }
  .product-card .pc-subtitle          { font-size:12px !important; }
  .product-card .pc-price,
  .product-card .pc-price span        { font-size:15px !important; }


  /* Reduce inline padding on heritage/section-tile cells */
  [style*="padding:60px 40px 60px 0"],
  [style*="padding: 60px 40px 60px 0"]{
    padding:30px 0 !important;
    border-right:0 !important;
    border-bottom:1px solid var(--line);
  }

  /* Footer — stack */
  .footer{padding:64px 0 24px;}
  .footer .footer-grid{grid-template-columns:1fr 1fr !important; gap:32px 24px;}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center;}

  /* Drawer / cart / search overlays full-width */
  .drawer{width:100vw;}
  .drawer-header,.drawer-body,.drawer-foot{padding-left:18px;padding-right:18px;}

  /* Buttons full-width when used standalone */
  .btn{padding:14px 26px;font-size:11px;justify-content:center;text-align:center;}
  /* CTAs sitting inside a flex/edit-cta row stay tappable and centred */
  .edit-cta .btn{width:100%; max-width:360px;}

  /* Disable sticky positioning on heritage chronology side */
  [style*="position:sticky"],
  [style*="position: sticky"]{position:static !important;}

  /* Form fields take full width */
  .field input,.field textarea,.field select{width:100%;}

  /* Generous block paddings (140px etc) tame */
  [style*="padding:140px 0"],
  [style*="padding: 140px 0"]{padding:72px 0 !important;}
  [style*="padding:120px 0"],
  [style*="padding: 120px 0"]{padding:64px 0 !important;}
  [style*="padding:100px 0"],
  [style*="padding: 100px 0"]{padding:60px 0 !important;}
  [style*="padding:90px 0"],
  [style*="padding: 90px 0"]{padding:54px 0 !important;}
  [style*="padding:80px 0"],
  [style*="padding: 80px 0"]{padding:48px 0 !important;}

  /* Big inline display fontSize:48–72 — shrink */
  [style*="fontSize:72"],[style*="font-size:72"]{font-size:42px !important;}
  [style*="fontSize:64"],[style*="font-size:64"]{font-size:38px !important;}
  [style*="fontSize:56"],[style*="font-size:56"]{font-size:34px !important;}
  [style*="fontSize:48"],[style*="font-size:48"]{font-size:30px !important;}
  [style*="fontSize:36"],[style*="font-size:36"]{font-size:26px !important;}

  /* Order tracking step lines — smaller dot */
  /* maxWidth content boxes */
  [style*="maxWidth:1100"],[style*="max-width:1100"],
  [style*="maxWidth:780"],[style*="max-width:780"],
  [style*="maxWidth:620"],[style*="max-width:620"],
  [style*="maxWidth:480"],[style*="max-width:480"]{
    max-width:100% !important;
  }

  /* No horizontal overflow on phone.
     IMPORTANT: use `clip` not `hidden` — overflow:hidden creates a scroll
     container which silently breaks position:sticky on iOS Safari. */
  html,body{ overflow-x:clip; max-width:100vw; }
  body{width:100%;}
  img,video,svg{max-width:100%; height:auto;}

  /* Contact — form stacks first, address below */
  .contact-grid{gap:40px !important;}

  /* Tighter, consistent section padding */
  .container{padding-left:var(--gut); padding-right:var(--gut);}
}

/* Small phone */
@media (max-width:420px){
  :root{--gut:14px;}
  .icons{gap:6px;}
  .icon-btn{width:32px;height:32px;}
  .logo .sub{display:none;}
  /* Footer single column */
  .footer .footer-grid{grid-template-columns:1fr !important;}
  /* Cart drawer item subtotal/qty rows can stack */
  [style*="grid-template-columns: 3fr 1fr 1fr 1fr"],
  [style*="grid-template-columns:3fr 1fr 1fr 1fr"]{
    grid-template-columns:1fr !important;
    gap:10px !important;
  }
}

/* =========================================================
   BRIDAL CONCIERGE PAGE
   ========================================================= */

/* ====================================================
   Edit pages (Bridal Edit, Crown Edit) — curated PLP
   ==================================================== */
.edit-hero{
  position:relative;
  min-height:46vh;
  display:flex;align-items:center;justify-content:center;
  background:var(--ink);
  color:var(--ivory);
  overflow:hidden;
  padding:80px 0;
}
.edit-hero--crown{background:#1f1a14;}
.edit-hero-bg{
  position:absolute;inset:0;
  opacity:0.45;
  -webkit-mask-image:radial-gradient(120% 100% at 50% 50%, rgba(0,0,0,0.9) 0%, transparent 78%);
          mask-image:radial-gradient(120% 100% at 50% 50%, rgba(0,0,0,0.9) 0%, transparent 78%);
}
.edit-hero-vignette{
  position:absolute;inset:0;
  background:radial-gradient(60% 60% at 50% 50%, transparent 0%, rgba(0,0,0,0.55) 100%);
}
.edit-hero-inner{position:relative;z-index:2;text-align:center;}
.edit-hero-h1{
  font-size:clamp(44px, 7vw, 92px);
  line-height:1.02;
  letter-spacing:-0.01em;
  margin:18px 0 0;
  color:var(--ivory);
  font-weight:400;
}

/* Toolbar (count + filter chips) */
.edit-toolbar{
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;flex-wrap:wrap;
  padding-bottom:24px;
  margin-bottom:32px;
  border-bottom:1px solid var(--rule);
}
.edit-eyebrow{color:var(--ink-3); letter-spacing:0.22em;}
.edit-filters{
  display:flex;flex-wrap:wrap;gap:8px;
}
.edit-chip{
  font-family:var(--sans);
  font-size:11px;letter-spacing:0.18em;text-transform:uppercase;
  padding:9px 16px;
  border:1px solid var(--rule-strong, var(--ink-3));
  background:transparent;color:var(--ink-2);
  border-radius:999px;
  cursor:pointer;
  transition:all .25s var(--ease);
}
.edit-chip:hover{border-color:var(--ink); color:var(--ink);}
.edit-chip.active{background:var(--ink); color:var(--ivory); border-color:var(--ink);}

/* Product grid (4-up desktop, mirrors bestsellers shape) */
.edit-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:24px 20px;
}

.edit-cta{
  display:flex;justify-content:center;gap:14px;flex-wrap:wrap;
  margin-top:48px;
}

@media (max-width:1024px){
  .edit-grid{grid-template-columns:repeat(3, 1fr); gap:22px 18px;}
  .edit-hero{min-height:38vh; padding:60px 0;}
  .edit-hero-h1{font-size:clamp(40px, 6.5vw, 72px);}
}
@media (max-width:768px){
  .edit-grid{grid-template-columns:repeat(2, 1fr) !important; gap:18px 12px !important;}
  .edit-toolbar{padding-bottom:18px; margin-bottom:22px; gap:16px;}
  .edit-eyebrow{font-size:10px;}
  .edit-chip{font-size:10px; letter-spacing:0.16em; padding:7px 12px;}
  /* Image-led hero — occupy ~70% of the viewport, with title overlay near the bottom */
  .edit-hero{min-height:70vh !important; padding:0 !important;}
  .edit-hero .edit-hero-bg{opacity:0.7;}
  .edit-hero-inner{
    display:flex; flex-direction:column; justify-content:flex-end;
    align-items:center; gap:14px;
    padding:0 22px 36px; width:100%;
  }
  .edit-hero-h1{font-size:clamp(34px, 9vw, 56px) !important; margin-top:10px;}
  .edit-cta{margin-top:32px;}
  .edit-cta .btn{flex:1 1 auto; min-width:160px;}
}
@media (max-width:420px){
  .edit-hero-h1{font-size:clamp(30px, 10vw, 46px) !important;}
  .edit-grid{gap:14px 10px !important;}
}

/* (legacy bridal-* styles below are unused now but kept harmless) */
.bridal-hero-legacy-marker{display:none;}

/* Hero */
.bridal-hero{
  position:relative;
  min-height:96vh;
  display:flex;align-items:center;justify-content:center;
  text-align:center;
  color:var(--ivory);
  overflow:hidden;
  background:#0d0a08;
  padding:90px 0 80px;
}
.bridal-hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(120% 80% at 50% 30%, rgba(140,110,84,0.32), transparent 60%),
    linear-gradient(160deg,#1a1108 0%, #28160e 40%, #0d0806 100%);
}
.bridal-vignette{
  position:absolute;inset:0;
  background:radial-gradient(120% 100% at 50% 50%, transparent 30%, rgba(0,0,0,0.55) 90%);
}
/* Jaali pattern — geometric overlay reminiscent of Mughal lattice */
.bridal-jaali{
  position:absolute;inset:0;
  opacity:0.18;
  background-image:
    repeating-linear-gradient(45deg, rgba(217,199,176,0.4) 0 1px, transparent 1px 32px),
    repeating-linear-gradient(-45deg, rgba(217,199,176,0.4) 0 1px, transparent 1px 32px),
    repeating-linear-gradient(0deg, rgba(217,199,176,0.18) 0 1px, transparent 1px 64px),
    repeating-linear-gradient(90deg, rgba(217,199,176,0.18) 0 1px, transparent 1px 64px);
  mask-image:radial-gradient(120% 100% at 50% 50%, rgba(0,0,0,0.7) 0%, transparent 75%);
  -webkit-mask-image:radial-gradient(120% 100% at 50% 50%, rgba(0,0,0,0.7) 0%, transparent 75%);
}
.bridal-hero-inner{position:relative; z-index:2;}
.bridal-mantra{
  font-size:clamp(28px, 4vw, 44px);
  color:var(--gold-soft);
  font-style:italic;
  margin:30px 0 14px;
  letter-spacing:0.04em;
  opacity:0.85;
}
.bridal-hero-h1{
  font-size:clamp(56px, 9vw, 132px);
  line-height:0.94;
  margin:6px 0 28px;
  letter-spacing:-0.015em;
  color:var(--ivory);
  font-weight:400;
}
.bridal-hero-sub{
  font-family:var(--serif);
  font-size:clamp(16px, 1.6vw, 19px);
  line-height:1.65;
  max-width:620px;
  margin:0 auto;
  color:rgba(245,239,230,0.78);
}
.bridal-hero-marks{
  display:grid;grid-template-columns:1fr auto 1fr auto 1fr;
  gap:24px;align-items:center;
  max-width:780px;margin:80px auto 0;
  padding-top:44px;
  border-top:1px solid rgba(217,199,176,0.22);
}
.bhm-num{font-size:42px; color:var(--gold-soft); margin-bottom:6px; line-height:1;}
.bhm-l{
  font-family:var(--sans); font-size:11px;
  letter-spacing:0.18em; text-transform:uppercase;
  color:rgba(245,239,230,0.55); line-height:1.5;
}
.bhm-rule{width:1px;height:48px;background:rgba(217,199,176,0.22);}

/* Section heads */
.bridal-section-head{
  text-align:center;
  max-width:820px;
  margin:0 auto 70px;
}
.bridal-section-head .ornament{justify-content:center;}

/* THE KIT */
.bridal-kit{padding-top:80px;}
.bridal-kit-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:32px;
  margin-bottom:60px;
}
.bridal-kit-card{
  background:var(--ivory-2);
  border:1px solid var(--line);
  display:flex;flex-direction:column;
  transition:all .4s var(--ease);
}
.bridal-kit-card.featured{
  border-color:var(--vermilion);
  transform:translateY(-12px);
  box-shadow:0 30px 60px rgba(196,40,46,0.08);
}
.bridal-kit-card:hover{border-color:var(--ink);}
.bridal-kit-img{
  position:relative;
  aspect-ratio:4/5;
}
.bridal-kit-num{
  position:absolute;left:24px;top:22px;z-index:2;
  font-size:36px; color:var(--gold-soft);
  letter-spacing:-0.02em;
}
.bridal-kit-dev{
  position:absolute;right:24px;bottom:20px;z-index:2;
  font-size:42px; color:var(--gold-soft);
  font-style:italic;
  opacity:0.78;
}
.bridal-kit-tag{
  position:absolute;left:24px;bottom:24px;z-index:2;
  background:var(--vermilion);
  color:var(--ivory);
  padding:7px 14px;
  font-size:10px;
  letter-spacing:0.16em;
}
.bridal-kit-body{padding:32px 30px 36px;flex:1;}
.bridal-kit-pieces{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:10px;
}
.bridal-kit-pieces li{
  display:flex;align-items:center;gap:12px;
  font-size:13px; font-family:var(--serif);
  color:var(--ink);
  padding-bottom:10px;
  border-bottom:1px dotted var(--line);
}
.bridal-kit-pieces li:last-child{border-bottom:0;}

/* Bundle row */
.bridal-kit-bundle{
  display:flex;align-items:center;justify-content:space-between;
  gap:40px;
  background:var(--ink); color:var(--ivory);
  padding:40px 50px;
  margin-top:30px;
  border:1px solid var(--gold);
}
.bridal-kit-bundle .h-display{color:var(--ivory);}
.bridal-kit-bundle .h-serif{color:rgba(245,239,230,0.7);}

/* PROCESS */
.bridal-process{
  max-width:880px;margin:0 auto;
  display:flex;flex-direction:column;
}
.bridal-process-row{
  display:grid;grid-template-columns:80px 60px 1fr;
  gap:30px;align-items:flex-start;
  padding:36px 0;
  border-bottom:1px solid rgba(217,199,176,0.18);
}
.bridal-process-row:last-child{border-bottom:0;}
.bp-roman{
  font-size:46px;color:var(--gold-soft);
  line-height:1;letter-spacing:-0.01em;
  font-style:italic;
}
.bp-line{
  position:relative;
  width:60px;height:100%;
  display:flex;flex-direction:column;align-items:center;
}
.bp-dot{
  width:9px;height:9px;border-radius:50%;
  background:var(--vermilion);
  margin-top:18px;flex-shrink:0;
  box-shadow:0 0 0 6px rgba(196,40,46,0.15);
}
.bp-trail{
  position:absolute;top:30px;bottom:-36px;left:50%;
  width:1px;background:rgba(217,199,176,0.25);
}
.bp-content{padding-top:6px;}

/* LOOKBOOK */
.bridal-lookbook{
  display:grid;grid-template-columns:repeat(3, 1fr);
  grid-auto-rows:280px;
  gap:24px;
}
.bl-tile{
  position:relative;margin:0;overflow:hidden;
  cursor:pointer;
  transition:transform .5s var(--ease);
}
.bl-tile.tall{grid-row:span 2;}
.bl-tile:hover{transform:translateY(-4px);}
.bl-tile .img-ph{transition:transform .8s var(--ease);}
.bl-tile:hover .img-ph{transform:scale(1.04);}
.bl-overlay{
  position:absolute;inset:0;
  display:flex;align-items:flex-start;justify-content:flex-end;
  padding:18px;
}
.bl-tile figcaption{
  font-family:var(--serif);font-size:15px;
  padding:14px 4px 0;letter-spacing:-0.005em;
}

/* TEAM */
.bridal-team{
  display:grid;grid-template-columns:repeat(3, 1fr);
  gap:36px;
  max-width:1180px;margin:0 auto;
}
.bt-card{}
.bt-portrait{
  aspect-ratio:3/4;width:100%;
  border-bottom:1px solid var(--ink);
}

/* TROUSSEAU */
.bridal-trousseau{
  display:grid;grid-template-columns:1fr;
  border-top:1px solid var(--line-strong);
  max-width:880px;margin:0 auto;
}
.bt-row{
  display:grid;grid-template-columns:60px 1.4fr 1fr;
  gap:30px;align-items:baseline;
  padding:22px 4px;
  border-bottom:1px solid var(--line);
  transition:padding .3s var(--ease), background .3s var(--ease);
}
.bt-row:hover{background:rgba(217,199,176,0.18); padding-left:14px;}
.bt-num{font-size:18px; color:var(--gold);}
.bt-label{font-family:var(--display); font-size:22px; letter-spacing:-0.005em;}
.bt-detail{font-size:13px; color:var(--muted); font-family:var(--serif); font-style:italic;}

/* QUOTE */
.bridal-quote{
  text-align:center;max-width:820px;margin:0 auto;
  position:relative;
  padding:0 20px;
}
.bq-mark{
  font-size:140px;color:var(--gold-soft);opacity:0.4;
  line-height:0.6;margin-bottom:-20px;
  font-family:var(--display);
}
.bq-body{
  font-size:clamp(20px, 2.3vw, 28px);
  line-height:1.55;font-style:italic;
  color:rgba(245,239,230,0.92);
  margin:0 0 36px;
  font-weight:400;
  letter-spacing:-0.005em;
  text-wrap:pretty;
}
.bq-meta{display:flex;flex-direction:column;align-items:center;gap:0;}
.bq-dots{
  display:flex;justify-content:center;gap:14px;
  margin-top:46px;
}
.bq-dot{
  width:34px;height:1px;background:rgba(245,239,230,0.25);
  cursor:pointer;transition:all .3s var(--ease);border:0;padding:0;
}
.bq-dot.active{background:var(--gold-soft);height:2px;}

/* ATELIERS */
.bridal-ateliers{
  display:grid;grid-template-columns:repeat(3, 1fr);
  gap:28px;
}
.ba-card{
  padding:36px 32px;
  border:1px solid var(--line-strong);
  background:var(--ivory-2);
  transition:all .35s var(--ease);
}
.ba-card:hover{
  border-color:var(--ink);
  transform:translateY(-4px);
  box-shadow:0 24px 40px rgba(26,22,18,0.06);
}

/* FAQ */
.bridal-faq{border-top:1px solid var(--line-strong);}
.bf-row{border-bottom:1px solid var(--line);}
.bf-q{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;padding:24px 0;
  text-align:left;cursor:pointer;
  transition:padding .25s var(--ease);
}
.bf-row:hover .bf-q{padding-left:8px;}
.bf-icon{
  width:30px;height:30px;border-radius:50%;
  border:1px solid var(--line-strong);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;color:var(--gold);
}
.bf-a{
  max-height:0;overflow:hidden;
  transition:max-height .5s var(--ease);
}
.bf-row.open .bf-a{max-height:300px;}

/* ENQUIRY */
.bridal-enquiry-grid{
  display:grid;grid-template-columns:1fr 1.1fr;
  gap:90px;align-items:start;
}
.be-meta{margin-top:50px;display:flex;flex-direction:column;gap:18px;}
.be-meta-row{
  display:flex;align-items:baseline;gap:18px;
  padding:14px 0;border-bottom:1px solid var(--line);
}
.be-meta-row .eyebrow{min-width:90px;}
.be-form{
  background:var(--ivory-2);
  border:1px solid var(--line-strong);
  padding:48px 42px;
}
.be-form-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:28px 30px;
}
.be-pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;}
.be-pill{
  padding:8px 14px;
  font-size:11px;letter-spacing:0.16em;text-transform:uppercase;
  border:1px solid var(--line-strong);
  background:transparent;cursor:pointer;
  transition:all .25s var(--ease);
  color:var(--ink);font-family:var(--sans);font-weight:500;
}
.be-pill:hover{border-color:var(--ink);}
.be-pill.on{background:var(--ink);color:var(--ivory);border-color:var(--ink);}

/* ============ Bridal — Tablet ============ */
@media (max-width:1024px){
  .bridal-hero{min-height:80vh;padding:60px 0;}
  .bridal-hero-h1{font-size:clamp(48px, 8vw, 88px);}
  .bridal-kit-grid{grid-template-columns:1fr; gap:24px; max-width:560px; margin:0 auto 50px;}
  .bridal-kit-card.featured{transform:none;}
  .bridal-team{grid-template-columns:repeat(3, 1fr); gap:28px;}
  .bridal-ateliers{grid-template-columns:repeat(3, 1fr);}
  .bridal-lookbook{grid-template-columns:repeat(2, 1fr); grid-auto-rows:260px;}
  .bridal-enquiry-grid{grid-template-columns:1fr; gap:50px;}
  .bridal-process-row{grid-template-columns:60px 50px 1fr; gap:22px;}
  .bp-roman{font-size:36px;}
  .bridal-kit-bundle{flex-direction:column; align-items:flex-start; padding:32px;}
}

/* ============ Bridal — Phone ============ */
@media (max-width:768px){
  /* Hero */
  .bridal-hero{
    min-height:auto !important;
    padding:60px 0 70px !important;
  }
  .bridal-hero-h1{font-size:clamp(40px,11vw,64px) !important; line-height:0.98 !important; margin:4px 0 22px;}
  .bridal-hero-sub{font-size:14px !important; line-height:1.6;}
  .bridal-mantra{font-size:24px; margin:20px 0 8px;}
  .bridal-hero-marks{
    grid-template-columns:1fr !important;
    gap:18px !important;
    margin-top:50px;
    padding-top:30px;
    text-align:center;
  }
  .bhm-rule{display:none;}
  .bhm-num{font-size:32px;}

  /* Section heads */
  .bridal-section-head{margin:0 auto 40px; padding:0 4px;}

  /* Kit */
  .bridal-kit{padding-top:0;}
  .bridal-kit-grid{
    grid-template-columns:1fr !important;
    gap:18px !important;
    max-width:100%;
    margin-bottom:30px;
  }
  .bridal-kit-card.featured{transform:none; box-shadow:none;}
  .bridal-kit-img{aspect-ratio:5/4;}
  .bridal-kit-num{font-size:28px; left:18px; top:16px;}
  .bridal-kit-dev{font-size:32px; right:18px; bottom:14px;}
  .bridal-kit-tag{left:18px; bottom:18px; font-size:9px; padding:6px 10px;}
  .bridal-kit-body{padding:24px 22px 28px;}
  .bridal-kit-bundle{
    flex-direction:column !important;
    align-items:flex-start !important;
    padding:28px 22px !important;
    gap:22px;
  }
  .bridal-kit-bundle .h-display{font-size:24px !important;}

  /* Process */
  .bridal-process-row{
    grid-template-columns:46px 30px 1fr !important;
    gap:14px !important;
    padding:24px 0;
  }
  .bp-roman{font-size:28px;}
  .bp-dot{width:7px;height:7px;margin-top:14px;box-shadow:0 0 0 4px rgba(196,40,46,0.15);}
  .bp-content h3{font-size:21px !important;}
  .bp-content p{font-size:13px !important;}

  /* Lookbook */
  .bridal-lookbook{
    grid-template-columns:1fr 1fr !important;
    grid-auto-rows:200px !important;
    gap:12px !important;
  }
  .bl-tile.tall{grid-row:span 2;}
  .bl-tile figcaption{font-size:12px;padding:10px 2px 0;}

  /* Team */
  .bridal-team{
    grid-template-columns:1fr !important;
    gap:30px !important;
    max-width:420px;
  }

  /* Trousseau */
  .bt-row{
    grid-template-columns:36px 1fr !important;
    grid-template-rows:auto auto !important;
    gap:6px 14px !important;
    padding:18px 4px !important;
  }
  .bt-row:hover{padding-left:4px !important;}
  .bt-num{font-size:14px;grid-row:1;}
  .bt-label{font-size:17px !important; grid-column:2; grid-row:1;}
  .bt-detail{grid-column:2; grid-row:2; font-size:12px;}

  /* Quote */
  .bq-mark{font-size:90px; margin-bottom:-10px;}
  .bq-body{font-size:18px !important; line-height:1.55;}
  .bq-meta .h-serif{font-size:17px !important;}

  /* Ateliers */
  .bridal-ateliers{grid-template-columns:1fr !important; gap:14px !important;}
  .ba-card{padding:26px 22px;}
  .ba-card .h-display{font-size:28px !important;}

  /* FAQ */
  .bf-q{padding:18px 0;}
  .bf-row:hover .bf-q{padding-left:0;}
  .bf-q .h-display{font-size:16px !important; line-height:1.35; padding-right:14px;}
  .bf-icon{width:26px;height:26px;}

  /* Enquiry */
  .bridal-enquiry-grid{grid-template-columns:1fr !important; gap:36px !important;}
  .be-form{padding:30px 22px;}
  .be-form-grid{grid-template-columns:1fr !important; gap:22px !important;}
  .be-pill{padding:7px 12px;font-size:10px;}
  .be-meta{margin-top:30px;}
  .be-meta-row{flex-direction:column;align-items:flex-start;gap:4px;}
}

/* ============ Bridal — Small phone ============ */
@media (max-width:420px){
  .bridal-hero-h1{font-size:clamp(36px, 13vw, 56px) !important;}
  .bridal-mantra{font-size:20px;}
  .bridal-lookbook{grid-template-columns:1fr !important; grid-auto-rows:240px !important;}
  .bridal-lookbook .bl-tile.tall{grid-row:auto;}
  .bhm-num{font-size:28px;}
  .be-form{padding:24px 16px;}
}

/* =====================================================
   MOBILE REFINEMENTS — Page-specific overrides
   (applied AFTER the generic universal-collapse rules)
   ===================================================== */

/* Mobile-only labels — hidden on desktop, used inside line items on phones */
.cart-line-mlbl{ display:none; }

/* === QUIZ — option grids === */
@media (max-width:768px){
  /* Keep shade & length grids 2-column, override the universal 1fr collapse */
  .quiz-grid--shade,
  .quiz-grid--length{
    grid-template-columns:repeat(2, 1fr) !important;
    gap:10px !important;
  }
  .quiz-grid--goal,
  .quiz-grid--natural,
  .quiz-grid--life{
    grid-template-columns:repeat(2, 1fr) !important;
    gap:10px !important;
  }
  /* Compact option padding */
  .quiz-grid > [role="button"]{
    padding:14px 14px 18px !important;
  }
  .quiz-grid--length > [role="button"]{
    padding:18px 12px !important;
  }
  .quiz-grid--shade > [role="button"]{
    padding:18px 14px !important;
  }
  /* Image zones on phone — use aspect-ratio so nothing is cut */
  .quiz-grid--goal > [role="button"] > div:first-child,
  .quiz-grid--natural > [role="button"] > div:first-child,
  .quiz-grid--life > [role="button"] > div:first-child{
    height:auto !important;
    aspect-ratio:3/4 !important;
  }
  /* Non-image quiz cards keep fixed height */
  .quiz-grid > [role="button"] > div:first-child{
    height:118px !important;
  }
  .quiz-grid--goal > [role="button"] > div:first-child img,
  .quiz-grid--natural > [role="button"] > div:first-child img,
  .quiz-grid--life > [role="button"] > div:first-child img {
    object-fit: contain !important;
    object-position: center !important;
  }
  /* Title type — scale down */
  .quiz-grid--goal > [role="button"] span[style*="fontSize"],
  .quiz-grid--natural > [role="button"] span[style*="fontSize"],
  .quiz-grid--life > [role="button"] span[style*="fontSize"]{
    font-size:16px !important;
    letter-spacing:0.04em !important;
  }
  .quiz-grid--length > [role="button"] span[style*="fontSize"]{
    font-size:24px !important;
  }
  .quiz-grid--shade > [role="button"] span[style*="fontSize"]{
    font-size:14px !important;
    letter-spacing:0.02em !important;
  }
  .quiz-grid > [role="button"] ul li{ font-size:11.5px !important; }

  /* Quiz analyzing — shrink ring + percent */
  .page-enter [style*="width:260px"][style*="height:260px"]{
    width:210px !important; height:210px !important;
  }

  /* Quiz result row — already 1-col via universal; ensure image not too tall */
  .page-enter .img-ph[style*="aspectRatio:\"4/5\""]{ aspect-ratio:5/6 !important; }
}

/* === CART PAGE line items === */
@media (max-width:768px){
  .cart-line-head{ display:none !important; }
  .cart-line{
    grid-template-columns:96px 1fr !important;
    grid-template-rows:auto auto auto !important;
    gap:8px 16px !important;
    padding:22px 0 !important;
    align-items:start !important;
  }
  .cart-line .cart-line-item{
    grid-column:1 / -1 !important;
    grid-template-columns:96px 1fr !important;
    gap:16px !important;
  }
  .cart-line .cart-line-qty{
    grid-column:1 / -1 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    padding-top:6px !important;
    border-top:1px dashed var(--line) !important;
  }
  .cart-line .cart-line-price,
  .cart-line .cart-line-sub{
    grid-column:1 / -1 !important;
    text-align:left !important;
    font-size:14px !important;
  }
  .cart-line .cart-line-sub{
    font-size:18px !important;
    border-top:1px dashed var(--line) !important;
    padding-top:8px !important;
    display:flex !important;
    justify-content:space-between !important;
    align-items:center !important;
  }
  .cart-line-mlbl{
    display:inline !important;
    font-family:var(--sans) !important;
    font-size:10px !important;
    letter-spacing:0.18em !important;
    text-transform:uppercase !important;
    color:var(--muted) !important;
    margin-right:8px !important;
    font-style:normal !important;
  }
  /* Cart aside summary — make full width */
  aside[style*="position:sticky"][style*="background"][style*="bone"]{
    position:static !important;
    padding:28px 22px !important;
  }
}

/* === CHECKOUT — progress strip === */
@media (max-width:768px){
  .checkout-progress{
    gap:6px !important;
    margin-bottom:36px !important;
    flex-wrap:nowrap !important;
    padding:0 4px;
  }
  .checkout-progress > div{ gap:6px !important; }
  .checkout-progress .eyebrow{
    font-size:9px !important;
    letter-spacing:0.10em !important;
    white-space:nowrap;
  }
  .checkout-progress > div > div[style*="width:40px"]{
    width:14px !important;
  }
  .checkout-progress > div > div[style*="width:24px"][style*="height:24px"]{
    width:20px !important; height:20px !important; font-size:10px !important;
  }
}
@media (max-width:420px){
  .checkout-progress .eyebrow{ font-size:0 !important; } /* hide labels, keep dots */
  .checkout-progress .eyebrow::first-letter{ font-size:9px !important; }
  /* Better: keep first-letter approach off, just show dots — labels would be 0 anyway */
}

/* === ACCOUNT — order rows === */
@media (max-width:768px){
  .account-order{
    grid-template-columns:64px 1fr !important;
    grid-template-rows:auto auto !important;
    padding:18px !important;
    gap:14px !important;
  }
  .account-order > div:nth-child(3){
    grid-column:1 / -1 !important;
    text-align:left !important;
    display:flex !important;
    justify-content:space-between !important;
    align-items:center !important;
    padding-top:10px !important;
    border-top:1px dashed var(--line) !important;
  }
  .account-order > div:nth-child(3) .h-display{
    font-size:20px !important;
  }
  /* Account: collapse sidebar to top scroll-row of pills */
  .page-enter .container[style*="grid-template-columns:240px"],
  .page-enter .container[style*="grid-template-columns: 240px"]{
    display:flex !important;
    flex-direction:column !important;
    gap:30px !important;
  }
  .page-enter aside button[style*="border-bottom:1px solid var(--line)"]{
    /* Sidebar buttons → keep as a list of full-width links on mobile */
    padding:12px 0 !important;
    font-size:15px !important;
  }
  /* Wishlist 3-col grid → 2-col on phone */
  [style*="grid-template-columns: repeat(3, 1fr)"][style*="gap:24"]{
    grid-template-columns:repeat(2, 1fr) !important;
    gap:14px !important;
  }
}

/* === ABOUT — 2x2 stats grid (instead of 1-col stack) === */
@media (max-width:768px){
  .about-numbers{
    grid-template-columns:1fr 1fr !important;
    gap:36px 18px !important;
  }
  .about-numbers .h-display{
    font-size:54px !important;
  }
  .about-numbers .eyebrow{
    font-size:10px !important;
    letter-spacing:0.16em !important;
    margin-top:8px !important;
  }
  /* About values — 1-col with clean borders */
  .about-values{
    grid-template-columns:1fr !important;
  }
  .about-values > div{
    padding:26px 0 !important;
    padding-left:0 !important;
    border-right:0 !important;
    border-bottom:1px solid var(--line) !important;
  }
  .about-values > div:last-child{
    border-bottom:0 !important;
  }
  .about-values > div p{
    padding-left:46px !important;
  }
}

/* === HERITAGE — process rows, image first === */
@media (max-width:768px){
  .heritage-step{
    display:flex !important;
    flex-direction:column !important;
    gap:24px !important;
    padding:36px 0 !important;
  }
  .heritage-step .img-ph{
    order:-1;
    aspect-ratio:4/3 !important;
    width:100% !important;
  }
  .heritage-step h3{
    font-size:24px !important;
  }
  .heritage-step .h-display[style*="fontSize:60"]{
    font-size:36px !important;
  }
}

/* ================================================================
   PDP — Comprehensive mobile fixes (product detail pages)
   ================================================================ */
@media (max-width:768px){

  /* ── Main PDP section padding ──────────────────────────────── */
  .page-enter section[style*="padding:30px 0 80px"],
  .page-enter section[style*="padding: 30px 0 80px"]{
    padding:16px 0 40px !important;
  }

  /* ── Gallery: main image caption text ─────────────────────── */
  /* Label positioned top-left of hero image — needs safe padding */
  .page-enter [style*="top:24px"][style*="left:24px"]{
    top:14px !important;
    left:14px !important;
  }

  /* ── Thumbnail strip — keep all 4 visible, compressed ──────── */
  /* Class-based: reliable override of the universal 1fr collapse  */
  .pdp-thumbs{
    grid-template-columns:repeat(4, 1fr) !important;
    gap:6px !important;
  }
  /* Each thumb: square crop on phone so all 4 fit */
  .pdp-thumb-img{
    aspect-ratio:1/1 !important;
  }

  /* ── PDP main image: let flex control the size ─────────────── */
  .pdp-main-img-wrap{
    min-height: 44vw;
  }

  /* ── Vertical thumb strip on mobile: slim column ────────────── */
  .pdp-thumbs{
    width: 48px !important;
    gap: 6px !important;
  }

  /* ── Hide quick-add overlay on mobile (tap goes to PDP) ─────── */
  .product-card .pc-quick{ display:none !important; }

  /* ── Shade swatch buttons — tighter on phone ──────────────── */
  .page-enter button[title][style*="border-radius:50%"],
  .page-enter button[title][style*="borderRadius:"]{
    width:36px !important;
    height:36px !important;
  }

  /* ── Add-to-cart row — qty + CTA button ───────────────────── */
  /* Ensure the row wraps if needed and CTA text shrinks */
  .page-enter [style*="gap:12px"][style*="alignItems:stretch"],
  .page-enter [style*="gap:12"][style*="alignItems:stretch"]{
    flex-wrap:nowrap !important;
    gap:8px !important;
  }
  .page-enter [style*="gap:12px"][style*="alignItems:stretch"] .btn-vermilion,
  .page-enter [style*="gap:12"][style*="alignItems:stretch"] .btn-vermilion{
    min-width:0 !important;
    font-size:11px !important;
    padding:12px 14px !important;
    letter-spacing:0.08em !important;
    white-space:normal !important;
    text-align:center !important;
    line-height:1.3 !important;
  }
  /* Qty stepper — keep square and tappable */
  .page-enter [style*="width:48px"][style*="padding:0 12px"]{
    width:40px !important;
    padding:0 8px !important;
  }
  .page-enter [style*="width:44px"][style*="alignItems:center"]{
    width:36px !important;
  }

  /* ── Buy Now full-width button ─────────────────────────────── */
  .page-enter .btn-ghost[style*="width:100%"]{
    font-size:11px !important;
    padding:12px 14px !important;
    letter-spacing:0.08em !important;
  }

  /* ── Tab strip — horizontal scroll, no wrap ───────────────── */
  .page-enter [style*="display:flex"][style*="borderBottom"][style*="gap:30"]{
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch !important;
    flex-wrap:nowrap !important;
    gap:18px !important;
    padding-bottom:1px;
    /* Hide scrollbar but keep functionality */
    scrollbar-width:none;
    -ms-overflow-style:none;
  }
  .page-enter [style*="display:flex"][style*="borderBottom"][style*="gap:30"]::-webkit-scrollbar{
    display:none;
  }
  .page-enter [style*="display:flex"][style*="borderBottom"][style*="gap:30"] button{
    flex-shrink:0;
    padding:12px 0 !important;
    font-size:10px !important;
    letter-spacing:0.14em !important;
  }

  /* ── Trust strip — 2-col, tighter padding ─────────────────── */
  .page-enter [style*="grid-template-columns:repeat(2, 1fr)"][style*="border-top"],
  .page-enter [style*="grid-template-columns: repeat(2, 1fr)"][style*="border-top"]{
    grid-template-columns:repeat(2, 1fr) !important;
    gap:12px !important;
    padding:16px 0 !important;
  }

  /* ── Product info heading ─────────────────────────────────── */
  .page-enter [style*="font-size:clamp(28px, 3.2vw, 40px)"],
  .page-enter [style*="font-size:clamp(28px,3.2vw,40px)"]{
    font-size:clamp(22px, 6vw, 32px) !important;
  }

  /* ── Price display ────────────────────────────────────────── */
  .page-enter [style*="font-size:28px"][style*="font-weight:600"]{
    font-size:24px !important;
  }

  /* ── Shipping note ────────────────────────────────────────── */
  .pdp-ship-note{
    font-size:11.5px !important;
    padding:10px 12px !important;
    gap:8px !important;
  }

  /* ── Tab content ──────────────────────────────────────────── */
  .page-enter [style*="padding:24px 0"][style*="font-size:14px"]{
    font-size:13px !important;
    padding:18px 0 !important;
  }

  /* ── Details 2-col grid in tab — keep 2-col ──────────────── */
  .pdp-details{
    grid-template-columns:1fr 1fr !important;
    gap:12px !important;
  }

  /* ── Recommended section heading ─────────────────────────── */
  .page-enter [style*="padding-top:80px"][style*="padding-bottom:80px"]{
    padding-top:40px !important;
    padding-bottom:40px !important;
  }

  /* ── Reviews head — stack vertically ─────────────────────── */
  .pdp-reviews-head{
    flex-direction:column !important;
    align-items:flex-start !important;
    gap:14px !important;
  }
  .pdp-reviews-head button{
    align-self:flex-start !important;
  }

  /* ── "You may also love" heading row ─────────────────────── */
  .page-enter [style*="margin-bottom:36px"][style*="flex-wrap:wrap"]{
    margin-bottom:20px !important;
  }
}

/* Small phone extra tightening */
@media (max-width:420px){
  /* Thumbnail strip — already square from 768 rule, still 4-col */
  .pdp-thumbs{
    gap:4px !important;
  }
  .pdp-thumb-img{
    aspect-ratio:1/1 !important;
  }
  /* Add-to-cart CTA — allow wrapping on very small screens */
  .page-enter [style*="gap:12px"][style*="alignItems:stretch"],
  .page-enter [style*="gap:12"][style*="alignItems:stretch"]{
    flex-wrap:wrap !important;
  }
  .page-enter [style*="gap:12px"][style*="alignItems:stretch"] .btn-vermilion,
  .page-enter [style*="gap:12"][style*="alignItems:stretch"] .btn-vermilion{
    flex:1 1 100% !important;
  }
  /* Shade swatch — even smaller */
  .page-enter button[title][style*="border-radius:50%"],
  .page-enter button[title][style*="borderRadius:"]{
    width:32px !important;
    height:32px !important;
  }
}

/* === HOME hero — slight refinements === */
@media (max-width:768px){
  /* The hero h1 italic span — keep on its own visual line, prevent wrap issues */
  .hero-h1 em{ display:inline; }
}

/* === FOOTER newsletter input — make tappable === */
@media (max-width:768px){
  .footer input{ font-size:16px !important; } /* prevent iOS zoom on focus */
  .field input,.field select,.field textarea{ font-size:16px !important; }
}

/* === Welcome popup small-phone tightening === */
@media (max-width:420px){
  .wp-card{ max-width:100% !important; margin:0 !important; }
  .wp-mega{ font-size:88px !important; }
  .wp-otp{ width:48px !important; height:60px !important; font-size:26px !important; }
  .wp-trust-item{ font-size:10px !important; }
}

/* === Tweaks panel — keep readable on phones (matches starter component class .twk-panel) === */
@media (max-width:768px){
  .twk-panel{
    width:240px !important;
    max-width:calc(100vw - 24px) !important;
    right:12px !important;
    bottom:12px !important;
    max-height:50vh !important;
  }
}
@media (max-width:420px){
  .twk-panel{
    width:220px !important;
    max-height:46vh !important;
  }
}

/* === Generic safety: prevent horizontal scroll from clamp() type overflow === */
@media (max-width:768px){
  body, html{ overflow-x:hidden; max-width:100vw; }
  /* Prevent any 100vw element from triggering scroll */
  [style*="width:100vw"]{ width:100% !important; }
}

/* === Improve tap targets across the board === */
@media (max-width:768px){
  .chip{ padding:8px 14px !important; font-size:11px !important; }
  .btn{ min-height:46px; }
  .icon-btn{ min-width:36px; min-height:36px; }
  /* Larger sort select tap area */
  select{ padding:10px 4px !important; min-height:40px; }
}

/* ============================================================
   Interactions, transitions & scroll triggers (added 2026-05)
   ============================================================ */

/* Site-wide smooth scrolling for anchor jumps + js scrollTo. */
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal, .reveal.in { opacity:1; transform:none; transition:none; }
  .cart-bump-on { animation:none !important; }
}

/* Stagger helpers for `.reveal` — assign one of these to a child to
   delay its in-transition without inline styles. */
.reveal-d1 { transition-delay: 80ms; }
.reveal-d2 { transition-delay: 160ms; }
.reveal-d3 { transition-delay: 240ms; }
.reveal-d4 { transition-delay: 320ms; }
.reveal-d5 { transition-delay: 400ms; }
.reveal-d6 { transition-delay: 480ms; }

/* Reveal variants for non-vertical entrances. */
.reveal.from-left  { transform: translateX(-32px); }
.reveal.from-right { transform: translateX( 32px); }
.reveal.zoom       { transform: scale(.96); }
.reveal.in.from-left,
.reveal.in.from-right,
.reveal.in.zoom { transform: none; }

/* Cart bump — triggered on the bag icon when a product is added.
   The class is added briefly then removed (chrome.jsx). */
@keyframes cartBump {
  0%   { transform: scale(1); }
  30%  { transform: scale(1.22) rotate(-6deg); }
  55%  { transform: scale(0.92) rotate(4deg); }
  100% { transform: scale(1) rotate(0); }
}
.cart-bump-on { animation: cartBump .55s var(--ease); }

/* Product-card lift on hover — image-zoom is already wired, this
   adds a soft elevation to the whole card. */
.product-card { transition: transform .45s var(--ease); }
.product-card:hover { transform: translateY(-6px); }

/* Chip press feedback. */
.chip { transition: transform .15s var(--ease), background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease); }
.chip:active { transform: scale(.96); }
.chip.active { box-shadow: inset 0 -2px 0 0 var(--vermilion); }

/* Buttons — subtle press + softer hover sheen on the primary CTA. */
.btn { transition: transform .18s var(--ease), background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease), box-shadow .25s var(--ease); }
.btn:active { transform: translateY(1px); }
.btn-vermilion:hover { box-shadow: 0 6px 22px -10px rgba(196, 40, 46, .55); }

/* Underline-grow under section eyebrows when revealed. */
.reveal .eyebrow.red::after,
.reveal .eyebrow.gold::after {
  content: ""; display: inline-block; vertical-align: middle;
  width: 0; height: 1px; margin-left: 10px;
  background: currentColor;
  transition: width .9s var(--ease) .15s;
}
.reveal.in .eyebrow.red::after,
.reveal.in .eyebrow.gold::after { width: 26px; }

/* Tiny float on icon-only header buttons. */
.icon-btn { transition: transform .25s var(--ease), color .25s var(--ease), background .25s var(--ease); }
.icon-btn:hover { transform: translateY(-1px); }

/* Logo wordmark fade in on first paint. */
.logo-image { transition: opacity .6s var(--ease); }

/* ── Search overlay ── */
.search-overlay{
  position:fixed;inset:0;z-index:100;background:var(--ivory);
  display:flex;flex-direction:column;
  opacity:0;pointer-events:none;
  transition:opacity .28s var(--ease);
}
.search-overlay.open{opacity:1;pointer-events:auto;}
.search-overlay-inner{display:flex;flex-direction:column;height:100%;}

/* ── Wishlist popup ── */
.wp-overlay{
  position:fixed;inset:0;z-index:110;
  background:rgba(14,11,10,0.6);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity .35s var(--ease);
  backdrop-filter:blur(4px);
}
.wp-overlay.open{opacity:1;pointer-events:auto;}
.wp-card{
  display:grid;grid-template-columns:1.1fr 1fr;
  background:var(--ivory);
  max-width:820px;width:90vw;
  position:relative;overflow:hidden;
}
.wp-left{
  background:var(--ink);
  display:flex;align-items:center;justify-content:center;
  padding:48px 44px;
}
.wp-visual-content{position:relative;z-index:2;text-align:left;}
.wp-mega{font-family:var(--display);font-size:152px;line-height:0.82;color:var(--ivory);font-weight:400;display:inline-flex;align-items:flex-start;}
.wp-close{position:absolute;top:16px;right:16px;z-index:3;}
.wp-phone-input{width:100%;border:0;padding:16px 18px;font-family:var(--sans);font-size:15px;outline:none;background:transparent;}
@media(max-width:720px){
  .wp-card{grid-template-columns:1fr !important;max-width:420px !important;}
  .wp-left{min-height:200px;padding:32px 28px !important;}
  .wp-mega{font-size:88px !important;}
}

