/* ============================================================
   Natty Women — luxury skincare design system
   Serif display (Cormorant Garamond) + refined sans (Jost)
   Warm ivory canvas, champagne-gold accent, deep ink text.
   ============================================================ */
:root{
  /* bright white canvas + deep indigo accent (LovelySkin-style scheme) */
  --bg:#ffffff;          /* white canvas */
  --paper:#ffffff;       /* card / surface */
  --paper-2:#f4f3fb;     /* light lavender tint */
  --ink:#272442;         /* deep indigo-charcoal text */
  --ink-soft:#56527a;
  --muted:#8c89a6;       /* muted lavender-grey */
  --line:#e7e6f1;        /* hairline */
  --line-2:#efeef7;
  --gold:#333078;        /* PRIMARY indigo (accent variable, repointed) */
  --gold-deep:#28265f;   /* darker indigo (hover) */
  --sale:#d23a6a;        /* magenta-pink sale accent */
  --shadow:0 18px 50px -28px rgba(40,38,90,.32);
  --r:14px;
  /* one basic system font everywhere — no display/serif faces */
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --serif:var(--sans);
}
*{box-sizing:border-box}
*{ min-width:0 }                              /* stop flex/grid children forcing overflow */
html,body{ max-width:100%; overflow-x:hidden } /* never wider than the viewport */
html{ -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility }
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--sans); font-size:15px; line-height:1.65; font-weight:400;
  letter-spacing:.01em;
}
img,svg,video,table{ max-width:100% }
/* any data table becomes horizontally scrollable inside its own box on small screens */
.table-scroll{ width:100%; overflow-x:auto; -webkit-overflow-scrolling:touch }
/* checkout: 2-col on desktop, single column on mobile (was an inline style that ignored media queries) */
.checkout-grid{ display:grid; grid-template-columns:1fr 360px; gap:24px }
@media(max-width:880px){ .checkout-grid{ grid-template-columns:1fr } }
a{ color:inherit; text-decoration:none; transition:color .25s ease,opacity .25s ease }
a:hover{ color:var(--gold-deep) }
img{ max-width:100%; display:block }
.container{ max-width:1200px; margin:0 auto; padding:40px 28px }
.muted{ color:var(--muted) }

h1,h2,h3{ font-family:var(--sans); font-weight:600; letter-spacing:0; color:var(--ink) }

/* ---------- announcement + header ---------- */
.announce{
  background:var(--gold); color:#ffffff; text-align:center;
  font-family:var(--sans); font-size:11px; letter-spacing:.28em; text-transform:uppercase;
  padding:9px 12px; font-weight:300;
}
.site-header{ background:rgba(255,255,255,.9); backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line); position:sticky; top:0; z-index:20; transition:box-shadow .3s ease }
body.scrolled .site-header{ box-shadow:0 12px 34px -26px rgba(40,30,15,.5) }
.site-header .bar{ max-width:1200px; margin:0 auto; padding:20px 28px; display:flex; align-items:center; gap:26px }
.logo{ display:inline-flex; align-items:center; line-height:1;
  font-size:22px; font-weight:500; letter-spacing:.34em; text-transform:uppercase }
.logo:hover{ color:var(--ink) }
.logo-img{ display:block; height:28px; width:auto }
.drawer-top .logo-img{ height:30px }
.foot-logo{ height:46px; filter:brightness(0) invert(1) }
.logo-word{ font-size:26px; font-weight:500; letter-spacing:.34em; text-transform:uppercase; color:var(--ink);
  padding-left:.05em }
.logo-word::after{ content:"."; color:var(--gold); margin-left:.04em }   /* sleek gold accent */

.search{ flex:1; display:flex }
.search-box{ position:relative; width:100%; max-width:480px }
.search-ico{ position:absolute; left:15px; top:50%; transform:translateY(-50%); width:17px; height:17px; color:#b7ad9c; pointer-events:none }
.search-box input{ width:100%; padding:12px 16px 12px 40px; border:1px solid var(--line); border-radius:999px;
  background:var(--paper); font-family:var(--sans); font-size:13px; letter-spacing:.03em; color:var(--ink);
  transition:border-color .25s,box-shadow .25s }
.search-box input::placeholder{ color:#b7ad9c; letter-spacing:.05em }
.search-box input:focus{ outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(176,141,87,.12) }
.search-suggest{ position:absolute; top:calc(100% + 8px); left:0; right:0; background:var(--paper);
  border:1px solid var(--line); border-radius:14px; box-shadow:var(--shadow); padding:8px; z-index:75; max-height:72vh; overflow:auto }
.ss-title{ font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); padding:9px 10px 4px }
.ss-item{ display:flex; align-items:center; gap:11px; padding:9px 10px; border-radius:10px; color:var(--ink-soft) }
.ss-item:hover{ background:var(--paper-2); color:var(--ink) }
.ss-item img{ width:42px; height:42px; object-fit:contain; background:var(--paper-2); border-radius:8px; padding:4px; flex:0 0 auto }
.ss-t{ flex:1; font-size:14px; line-height:1.3 }
.ss-p{ font-size:12px; color:var(--muted); white-space:nowrap }
.ss-brand{ font-size:13.5px; letter-spacing:.02em }
.nav{ display:flex; align-items:center; gap:22px; font-size:12px; text-transform:uppercase; letter-spacing:.18em }
.nav a{ color:var(--ink-soft) }
.nav select{
  appearance:none; -webkit-appearance:none; padding:8px 28px 8px 12px; border:1px solid var(--line);
  border-radius:999px; background:var(--paper)
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6'><path d='M0 0l5 6 5-6z' fill='%23938b7d'/></svg>") no-repeat right 12px center;
  font-family:var(--sans); font-size:11px; letter-spacing:.14em; color:var(--ink-soft); cursor:pointer;
}
.cart-link{ font-weight:400; color:var(--ink) }
.cart-link:hover{ color:var(--gold-deep) }

/* ---------- footer ---------- */
.site-footer{ border-top:1px solid var(--line); margin-top:80px; background:var(--paper) }
.site-footer .bar{ max-width:1200px; margin:0 auto; padding:34px 28px; display:flex; justify-content:space-between;
  align-items:center; gap:16px; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted) }

/* ---------- hero ---------- */
/* ---------- editorial hero ---------- */
.hero{
  position:relative; overflow:hidden; border-radius:22px; margin-bottom:30px;
  display:grid; grid-template-columns:1.06fr .94fr; gap:50px; align-items:center; padding:66px;
  background:
    radial-gradient(130% 120% at 92% 6%, #e9e7fb 0%, rgba(233,231,251,0) 52%),
    radial-gradient(120% 130% at 0% 100%, #eef0fb 0%, rgba(238,240,251,0) 50%),
    linear-gradient(155deg,#ffffff 0%,#f4f3fb 100%);
  border:1px solid var(--line);
}
.hero::before{ content:""; position:absolute; left:-1px; top:-1px; bottom:-1px; width:5px;
  background:linear-gradient(180deg,var(--gold),rgba(176,141,87,0)); opacity:.6 }
.hero-text{ position:relative; z-index:2 }
.hero .eyebrow{ display:inline-flex; align-items:center; gap:10px; font-size:11px; letter-spacing:.32em;
  text-transform:uppercase; color:var(--gold-deep); margin:0 0 20px }
.hero .eyebrow::before{ content:""; width:26px; height:1px; background:var(--gold) }
.hero h1{ font-size:clamp(38px,5vw,64px); line-height:1.04; margin:0 0 20px; font-weight:500;
  letter-spacing:-.015em; max-width:13ch; color:var(--ink) }
.hero h1 em{ font-style:italic; color:var(--gold-deep) }
.hero-sub{ color:var(--ink-soft); max-width:44ch; font-size:16.5px; line-height:1.7; margin:0 0 30px }
.hero-cta{ display:flex; gap:12px; flex-wrap:wrap; align-items:center }
.hero-cta .btn{ margin-top:0 }
.hero-trust{ list-style:none; display:flex; gap:26px; padding:0; margin:34px 0 0; flex-wrap:wrap }
.hero-trust li{ font-size:11px; letter-spacing:.13em; text-transform:uppercase; color:var(--muted);
  display:flex; align-items:center; gap:8px }
.hero-trust li::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--gold); flex:0 0 auto }

.hero-visual{ position:relative; z-index:1 }
.hero-stage{ position:relative; background:linear-gradient(165deg,#fff,#f4f3fb); border:1px solid var(--line);
  border-radius:20px; aspect-ratio:4/5; display:flex; align-items:center; justify-content:center; padding:40px;
  box-shadow:0 40px 80px -50px rgba(60,45,20,.55) }
.hero-stage img{ max-height:100%; max-width:100%; object-fit:contain; filter:drop-shadow(0 24px 30px rgba(60,45,20,.18)) }
.hero-badge{ position:absolute; top:18px; right:18px; background:rgba(39,36,66,.92); color:#ffffff;
  font-size:11px; letter-spacing:.12em; text-transform:uppercase; padding:8px 14px; border-radius:999px }
.hero-pcard{ position:absolute; left:-22px; bottom:26px; background:var(--paper); border:1px solid var(--line);
  border-radius:14px; padding:14px 16px; box-shadow:var(--shadow); max-width:230px; display:flex; flex-direction:column; gap:4px }
.hero-pcard .pc-brand{ font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-deep) }
.hero-pcard .pc-name{ font-size:14px; font-weight:500; line-height:1.3; color:var(--ink) }
.hero-pcard .pc-row{ display:flex; align-items:center; justify-content:space-between; margin-top:4px }
.hero-pcard .pc-price{ font-weight:600 } .hero-pcard .pc-go{ font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--gold-deep) }

@media(max-width:880px){
  .hero{ grid-template-columns:1fr; gap:34px; padding:40px 26px; text-align:center }
  .hero .eyebrow,.hero-trust{ justify-content:center }
  .hero h1{ max-width:none } .hero-sub{ margin-left:auto; margin-right:auto }
  .hero-cta{ justify-content:center }
  .hero-visual{ max-width:360px; margin:0 auto; width:100% }
  .hero-pcard{ left:8px }
}

/* ---------- buttons ---------- */
.btn{
  display:inline-block; margin-top:26px; padding:15px 34px; border:0; cursor:pointer;
  background:var(--ink); color:#ffffff; border-radius:999px;
  font-family:var(--sans); font-size:11px; letter-spacing:.2em; text-transform:uppercase; font-weight:400;
  transition:transform .25s ease, background .25s ease, color .25s ease;
}
.btn:hover{ background:var(--gold-deep); color:#fff; transform:translateY(-1px) }
.btn.gold{ background:var(--gold); color:#ffffff }
.btn.gold:hover{ background:var(--gold-deep); color:#fff }
.btn:disabled{ opacity:.4; cursor:not-allowed; transform:none }
.btn-ghost{ background:transparent; border:1px solid var(--ink); color:var(--ink) }
.btn-ghost:hover{ background:var(--ink); color:#ffffff }

/* ---------- section titles ---------- */
.section-title{ display:flex; align-items:flex-end; justify-content:space-between; margin:54px 0 26px; gap:20px }
.section-title h2{ font-size:32px; margin:0; position:relative; padding-bottom:14px }
.section-title h2::after{ content:""; position:absolute; left:0; bottom:0; width:46px; height:1.5px; background:var(--gold) }
.section-title a{ font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted) }

/* ---------- product grid + card ---------- */
.grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:22px }

/* ---------- product card (luxury) ---------- */
.card-prod{
  background:var(--paper); border:1px solid var(--line-2); border-radius:16px; overflow:hidden;
  display:flex; flex-direction:column; text-align:left;
  transition:transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s ease, border-color .4s ease;
}
.card-prod:hover{ transform:translateY(-6px); box-shadow:0 30px 60px -40px rgba(60,45,20,.5); border-color:var(--line) }
.card-prod .thumb{ position:relative; aspect-ratio:1/1; background:linear-gradient(170deg,#fff,#f4f3fb);
  display:flex; align-items:center; justify-content:center; overflow:hidden }
.card-prod .thumb-link{ width:100%; height:100%; display:flex; align-items:center; justify-content:center; padding:24px }
.card-prod .thumb img{ max-height:100%; max-width:100%; object-fit:contain; transition:transform .6s cubic-bezier(.2,.7,.2,1) }
.card-prod:hover .thumb img{ transform:scale(1.05) }
.card-tag{ position:absolute; top:12px; left:12px; z-index:2; background:var(--ink); color:#ffffff;
  font-size:10px; font-weight:600; letter-spacing:.08em; padding:5px 9px; border-radius:999px }

.card-prod .body{ padding:16px 16px 18px; display:flex; flex-direction:column; gap:6px; flex:1 }
.card-prod .brand{ font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-deep) }
.card-prod .name{ font-size:14.5px; line-height:1.35; font-weight:500; color:var(--ink);
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; min-height:2.7em }
.card-prod .name:hover{ color:var(--gold-deep) }
.card-prod .rating{ min-height:16px; display:flex; align-items:center; gap:6px }
.rating .stars{ font-size:12px; letter-spacing:.12em; color:var(--gold) }
.rating .rc{ font-size:11px; color:var(--muted) }
.card-prod .price{ margin-top:2px; font-size:15px; font-weight:600; letter-spacing:.01em; color:var(--ink) }
.card-prod .was{ color:var(--sale); text-decoration:line-through; font-size:12.5px; font-weight:400; margin-left:7px; opacity:.85 }
.card-add{ margin-top:12px; width:100%; padding:11px; border:1px solid var(--ink); background:transparent; color:var(--ink);
  border-radius:999px; cursor:pointer; font-family:var(--sans); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase;
  font-weight:500; text-align:center; transition:background .25s, color .25s, border-color .25s }
.card-add:hover{ background:var(--ink); color:#ffffff }

/* ---------- horizontal product rail (home rows) ---------- */
.row-scroll{ display:flex; gap:20px; overflow-x:auto; overflow-y:hidden; scroll-snap-type:x mandatory;
  padding:4px 2px 16px; margin:0 -2px; -webkit-overflow-scrolling:touch; scrollbar-width:thin; scrollbar-color:var(--gold) transparent }
.row-scroll::-webkit-scrollbar{ height:6px }
.row-scroll::-webkit-scrollbar-thumb{ background:#e0d4bf; border-radius:999px }
.row-scroll::-webkit-scrollbar-thumb:hover{ background:var(--gold) }
.row-scroll > .card-prod{ flex:0 0 clamp(220px,23%,272px); scroll-snap-align:start }
@media(max-width:640px){ .row-scroll > .card-prod{ flex:0 0 76% } .row-scroll{ gap:14px } }
.row-brands > .card-prod{ flex-basis:clamp(148px,16%,184px) }
@media(max-width:640px){ .row-brands > .card-prod{ flex:0 0 44% } }
.brand-card .thumb{ aspect-ratio:4/3 } .brand-card .thumb-link{ padding:18px }
.brand-card .name{ text-align:center; font-size:13px; letter-spacing:.04em }
.brand-img{ max-width:100%; max-height:100%; object-fit:contain }
.brand-fallback{ display:flex; align-items:center; justify-content:center; width:100%; height:100%;
  min-height:46px; font:600 16px/1.25 var(--sans); letter-spacing:.02em; color:var(--ink-soft);
  text-align:center; padding:6px }

/* ============================================================
   Home page sections (value props, categories, promo, concerns)
   ============================================================ */
.valueprops{ display:flex; flex-wrap:wrap; justify-content:center; gap:12px 44px; padding:20px 24px;
  background:var(--paper-2); border:1px solid var(--line); border-radius:14px; margin:0 0 42px }
.vp{ display:flex; align-items:center; gap:11px; font-size:13px; letter-spacing:.02em; color:var(--ink-soft) }
.vp svg{ width:22px; height:22px; color:var(--gold); flex:0 0 auto }
.vp strong{ color:var(--ink); font-weight:600 }
@media(max-width:680px){ .valueprops{ gap:14px 22px; padding:16px } .vp{ font-size:11.5px } .vp svg{ width:19px; height:19px } }

.cat-grid{ display:grid; grid-template-columns:repeat(8,1fr); gap:18px }
@media(max-width:900px){ .cat-grid{ grid-template-columns:repeat(4,1fr) } }
@media(max-width:560px){ .cat-grid{ grid-template-columns:repeat(3,1fr); gap:14px } }
.cat-tile{ display:flex; flex-direction:column; align-items:center; gap:11px; text-align:center }
.ct-img{ width:100%; aspect-ratio:1/1; background:radial-gradient(120% 120% at 50% 25%, #fff, #f0f0fa);
  border:1px solid var(--line-2); border-radius:50%; display:flex; align-items:center; justify-content:center; padding:20%;
  transition:transform .3s, box-shadow .3s, border-color .3s }
.cat-tile:hover .ct-img{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:var(--gold) }
.ct-img img{ max-width:100%; max-height:100%; object-fit:contain }
.ct-img.is-sale{ background:radial-gradient(120% 120% at 50% 25%, #fbe6ee, #f6dbe6) }
.ct-label{ font-size:12.5px; font-weight:500; color:var(--ink); letter-spacing:.02em }

.promo-2up{ display:grid; grid-template-columns:1fr 1fr; gap:22px; margin:8px 0 4px }
@media(max-width:760px){ .promo-2up{ grid-template-columns:1fr } }
.promo-card{ position:relative; overflow:hidden; border-radius:18px; min-height:260px; display:flex; align-items:flex-end;
  border:1px solid var(--line); background:linear-gradient(135deg,#333078,#5b57a8); transition:box-shadow .3s, transform .3s }
.promo-card:hover{ transform:translateY(-3px); box-shadow:0 30px 60px -40px rgba(40,38,90,.5) }
.promo-card .pc-bg{ position:absolute; right:-6%; bottom:-6%; width:62%; height:118%; background-size:contain;
  background-repeat:no-repeat; background-position:right bottom; opacity:.9; filter:drop-shadow(0 20px 30px rgba(0,0,0,.25)) }
.promo-card .pc-content{ position:relative; z-index:2; padding:30px; color:#fff; max-width:62% }
.promo-card .pc-eyebrow{ font-size:11px; letter-spacing:.22em; text-transform:uppercase; opacity:.9; margin:0 0 10px }
.promo-card h3{ font-size:26px; line-height:1.18; margin:0 0 18px; font-weight:600 }
.promo-card .btn{ margin-top:0 }
.promo-card.light{ background:linear-gradient(135deg,#eef0fb,#f4f3fb) }
.promo-card.light .pc-content{ color:var(--ink) } .promo-card.light .pc-eyebrow{ color:var(--gold-deep); opacity:1 }
.promo-card .pc-blob{ position:absolute; right:-60px; top:-60px; width:240px; height:240px; border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(210,58,106,.22), rgba(210,58,106,0) 70%) }
@media(max-width:760px){ .promo-card{ min-height:200px } .promo-card .pc-content{ max-width:78% } }

.concern-grid{ display:grid; grid-template-columns:repeat(6,1fr); gap:14px }
@media(max-width:900px){ .concern-grid{ grid-template-columns:repeat(3,1fr) } }
@media(max-width:520px){ .concern-grid{ grid-template-columns:repeat(2,1fr) } }
.concern-tile{ aspect-ratio:3/2; border-radius:14px; display:flex; align-items:flex-end; padding:14px;
  color:#fff; font-size:13.5px; font-weight:500; letter-spacing:.02em; position:relative; overflow:hidden;
  background:linear-gradient(150deg,#3b388f,#28265f); transition:transform .3s, box-shadow .3s }
.concern-tile:nth-child(even){ background:linear-gradient(150deg,#5b57a8,#333078) }
.concern-tile:nth-child(3n){ background:linear-gradient(150deg,#46307d,#2c265e) }
.concern-tile:hover{ transform:translateY(-3px); box-shadow:var(--shadow) }
.concern-tile::after{ content:""; position:absolute; right:-30px; top:-30px; width:120px; height:120px; border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.16), rgba(255,255,255,0) 70%) }

/* ---------- shop layout ---------- */
/* ---------- shop / brand results ---------- */
.crumbs{ display:flex; gap:8px; align-items:center; font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-bottom:16px }
.crumbs a:hover{ color:var(--gold-deep) } .crumbs span{ color:#cdc9e0 }
.crumbs span.cur{ color:var(--ink) }
.crumbs a.cur{ color:var(--gold-deep); font-weight:600; text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:1px }
.crumbs a.cur:hover{ color:var(--ink) }
.shop-head h1{ font-size:clamp(28px,3.6vw,42px); margin:0; font-weight:600; letter-spacing:-.01em }
.brand-hero{ display:flex; gap:26px; align-items:center; margin-bottom:8px;
  background:radial-gradient(120% 140% at 100% 0%, #e9e7fb, rgba(233,231,251,0) 60%), linear-gradient(160deg,#ffffff,#f4f3fb);
  border:1px solid var(--line); border-radius:18px; padding:26px 30px }
.bh-logo{ flex:0 0 auto; width:128px; height:96px; background:#fff; border:1px solid var(--line); border-radius:13px;
  display:flex; align-items:center; justify-content:center; padding:16px }
.bh-logo img{ max-width:100%; max-height:100%; object-fit:contain }
.bh-info h1{ font-size:clamp(26px,3.4vw,38px); margin:0 0 8px; font-weight:600 }
.bh-info p{ color:var(--ink-soft); max-width:72ch; margin:0 0 10px; font-size:14.5px; line-height:1.7 }
.bh-count{ font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-deep) }

.shop-toolbar{ display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap;
  padding:16px 0 18px; border-bottom:1px solid var(--line-2); margin-bottom:24px }
.sortform{ display:flex; align-items:center; gap:10px }
.sort-label{ margin:0; font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted) }
.sortform select{ appearance:none; -webkit-appearance:none; padding:10px 34px 10px 15px; border:1px solid var(--line);
  border-radius:999px; background:var(--paper) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6'><path d='M0 0l5 6 5-6z' fill='%23938b7d'/></svg>") no-repeat right 14px center;
  font-family:var(--sans); font-size:12.5px; letter-spacing:.03em; color:var(--ink); cursor:pointer }
.sortform select:focus{ outline:none; border-color:var(--gold) }
.empty-state{ text-align:center; padding:60px 10px; color:var(--muted) } .empty-state .btn{ margin-top:14px }

.shop{ display:grid; grid-template-columns:230px 1fr; gap:44px }
.filters{ background:transparent; border:0; padding:0; position:sticky; top:120px; max-height:calc(100vh - 150px); overflow:auto }
.filters h3{ margin:0 0 12px; font-family:var(--sans); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted) }
.filters a{ display:block; padding:7px 0; font-size:14px; color:var(--ink-soft); border-bottom:1px solid transparent }
.filters a:hover{ color:var(--gold-deep) }
.filters a.active{ color:var(--ink); font-weight:500 }
.filters a.active::before{ content:"— "; color:var(--gold) }
@media(max-width:880px){ .shop{ grid-template-columns:1fr } .filters{ display:none } .brand-hero{ flex-direction:column; align-items:flex-start; text-align:left; padding:22px } }
.pager{ display:flex; gap:8px; margin-top:46px; flex-wrap:wrap; justify-content:center }
.pager a,.pager span{ min-width:42px; text-align:center; padding:10px 14px; border:1px solid var(--line);
  border-radius:999px; background:var(--paper); font-size:12px; letter-spacing:.1em; color:var(--ink-soft) }
.pager a:hover{ border-color:var(--gold) }
.pager .on{ background:var(--ink); color:#ffffff; border-color:var(--ink) }

/* ---------- product detail ---------- */
.pdp{ display:grid; gap:34px 56px; align-items:start;
  grid-template-columns:1.05fr 1fr; grid-template-areas:"gallery head" "gallery buy" }
.pdp-head{ grid-area:head } .gallery{ grid-area:gallery; position:sticky; top:118px; align-self:start } .pdp-buy{ grid-area:buy }
.pdp-brand{ font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--gold-deep); display:inline-block; margin-bottom:10px }
.pdp h1{ font-size:clamp(22px,2.6vw,32px); line-height:1.12; margin:0 0 8px; font-weight:600; letter-spacing:-.01em }
.pdp-size{ color:var(--muted); font-size:15px; margin-bottom:12px }
.pdp-rate{ display:flex; align-items:center; gap:16px; flex-wrap:wrap; padding-top:4px; border-top:1px solid var(--line-2) }
.pdp-rate .stars{ color:var(--gold); letter-spacing:.1em; font-size:16px }
.pdp-rate .rate-count{ font-size:13px; color:var(--ink-soft) } .pdp-rate .rate-count:hover{ color:var(--gold-deep) }
.share-btn{ margin-left:auto; display:inline-flex; align-items:center; gap:6px; background:none; border:0; cursor:pointer;
  font-family:var(--sans); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft) }
.share-btn:hover{ color:var(--gold-deep) }

.gallery .main{ background:var(--paper-2); border:1px solid var(--line-2); border-radius:var(--r); padding:44px;
  aspect-ratio:1/1; display:flex; align-items:center; justify-content:center }
.gallery .main img{ max-width:100%; max-height:100%; object-fit:contain }
.gallery .thumbs{ display:flex; gap:10px; margin-top:14px; flex-wrap:wrap }
.gallery .thumbs img{ width:66px; height:66px; object-fit:contain; border:1px solid var(--line);
  border-radius:10px; background:var(--paper); cursor:pointer; padding:7px; transition:border-color .25s }
.gallery .thumbs img:hover{ border-color:var(--gold) }
.gallery .thumbs img.active{ border-color:var(--gold); box-shadow:0 0 0 1px var(--gold) }

.pdp-buy .price-lg{ font-size:28px; font-weight:700; letter-spacing:.01em; margin:0 0 8px; display:flex; align-items:center; gap:10px; flex-wrap:wrap }
.price-lg{ font-size:28px; font-weight:700 }
.price-lg .was{ color:var(--muted); text-decoration:line-through; font-size:18px; font-weight:400 }
.price-lg .save{ background:var(--sale); color:#fff; font-size:11px; font-weight:600; letter-spacing:.04em; padding:4px 9px; border-radius:999px }
.pdp-ap{ margin:10px 0 2px } .pdp-ap #pdpApplePay{ min-height:46px }
.pdp-ov{ color:var(--ink-soft); font-size:15.5px; line-height:1.7; margin:0 0 6px }
/* short description shown in the head (desktop only); full one stays in buy on mobile */
.pdp-blurb{ display:none }
@media(min-width:881px){
  .pdp-blurb{ display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
    color:var(--ink-soft); font-size:15px; line-height:1.65; margin:16px 0 0 }
  .pdp-buy .pdp-ov{ display:none }
}
.qty{ display:flex; align-items:center; gap:12px; margin:20px 0 6px }
.qty input{ width:74px; padding:13px; border:1px solid var(--line); border-radius:10px; background:var(--paper);
  font-family:var(--sans); text-align:center; font-size:15px }
.qty .btn{ margin-top:0; flex:1 }
.pdp-assure{ display:flex; align-items:center; gap:8px; font-size:12.5px; color:var(--ink-soft); margin:4px 0 0 }
.pdp-assure svg{ color:var(--gold) }
.trust-points{ list-style:none; margin:16px 0 4px; padding:16px 18px; border:1px solid var(--line); border-radius:13px;
  background:linear-gradient(170deg,#fff,var(--paper-2)); display:flex; flex-direction:column; gap:11px }
.trust-points li{ position:relative; padding-left:28px; font-size:13.5px; color:var(--ink-soft); line-height:1.5; letter-spacing:.01em }
.trust-points li::before{ content:"✓"; position:absolute; left:0; top:1px; width:18px; height:18px; border-radius:50%;
  background:var(--gold); color:#fff; font-size:11px; display:flex; align-items:center; justify-content:center; font-weight:700 }
.trust-points li strong{ color:var(--ink); font-weight:600 }

/* "Why we're cheaper" tag + modal */
.why-cheaper{ display:inline-flex; align-items:center; gap:7px; margin:2px 0 12px; padding:7px 14px; cursor:pointer;
  border:1px solid var(--gold); border-radius:999px; background:rgba(51,48,120,.06); color:var(--gold-deep);
  font-family:var(--sans); font-size:11.5px; letter-spacing:.05em; font-weight:600; transition:background .2s, color .2s }
.why-cheaper:hover{ background:var(--gold); color:#fff }
.why-cheaper svg{ flex:0 0 auto }
.why-modal{ position:fixed; inset:0; background:rgba(28,26,48,.55); backdrop-filter:blur(3px); z-index:130;
  display:flex; align-items:center; justify-content:center; padding:20px; opacity:0; visibility:hidden; transition:.25s }
.why-modal.show{ opacity:1; visibility:visible }
.why-card{ position:relative; background:#fff; border-radius:18px; max-width:470px; width:100%; padding:34px 32px;
  box-shadow:var(--shadow); transform:translateY(12px) scale(.98); transition:.25s; max-height:88vh; overflow:auto }
.why-modal.show .why-card{ transform:none }
.why-close{ position:absolute; top:14px; right:16px; background:none; border:0; font-size:17px; color:var(--muted); cursor:pointer }
.why-tag{ display:inline-block; font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep);
  background:var(--paper-2); border:1px solid var(--line); padding:4px 11px; border-radius:999px; margin-bottom:14px }
.why-card h3{ font-size:21px; margin:0 0 12px; font-weight:600; line-height:1.28 }
.why-lead{ color:var(--ink); font-weight:500; margin:0 0 16px }
.why-list{ list-style:none; padding:0; margin:0 0 18px; display:flex; flex-direction:column; gap:12px }
.why-list li{ position:relative; padding-left:30px; color:var(--ink-soft); font-size:14px; line-height:1.55 }
.why-list li::before{ content:"✓"; position:absolute; left:0; top:1px; width:19px; height:19px; border-radius:50%;
  background:var(--gold); color:#fff; font-size:11px; display:flex; align-items:center; justify-content:center }
.why-foot{ color:var(--ink); font-style:italic; margin:0 }

/* shipping + payment-methods band (between details and reviews) */
.pdp-assurance{ display:grid; grid-template-columns:1.1fr 1fr; gap:18px; align-items:stretch; margin:36px 0 8px }
.pa-ship,.pa-pay{ border:1px solid var(--line); border-radius:14px; padding:18px 22px;
  background:linear-gradient(170deg,#fff,var(--paper-2)) }
.pa-ship{ display:flex; flex-direction:column; justify-content:center }
.ship-points{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:9px }
.ship-points li{ display:flex; gap:9px; align-items:flex-start; font-size:13.5px; color:var(--ink-soft); line-height:1.45 }
.ship-points .se{ flex:0 0 auto; font-size:15px; line-height:1.3 }
.ship-points strong{ color:var(--ink); font-weight:600 }
.ship-points em{ font-style:normal; color:var(--gold-deep); font-weight:600 }
.pa-learn{ align-self:flex-start; margin-top:14px; font-size:12px; font-weight:600; color:var(--gold-deep);
  text-decoration:underline; text-underline-offset:3px }
.pa-learn:hover{ color:var(--ink) }
.pa-pay{ display:flex; flex-direction:column; justify-content:center; gap:12px }
.pa-label{ font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted) }
.pa-pay .payments{ display:flex; gap:8px; flex-wrap:wrap }
@media(max-width:760px){ .pdp-assurance{ grid-template-columns:1fr } }

/* policy pages (shipping, etc.) */
.policy{ max-width:760px; margin:0 auto }
.policy .eyebrow{ display:inline-block; font-size:11px; letter-spacing:.3em; text-transform:uppercase; color:var(--gold-deep); margin:0 0 8px }
.policy h1{ font-size:clamp(28px,4vw,40px); margin:0 0 12px; font-weight:600 }
.policy-lead{ font-size:17px; color:var(--ink-soft); margin:0 0 24px; line-height:1.6 }
.policy h2{ font-size:20px; margin:28px 0 8px }
.policy p{ color:var(--ink-soft); line-height:1.7; margin:0 0 10px }
.policy a{ color:var(--gold-deep); text-decoration:underline; text-underline-offset:2px }
.policy-list{ color:var(--ink-soft); line-height:1.8; padding-left:20px; margin:0 0 12px }
.policy-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin:22px 0 10px }
.pcard{ border:1px solid var(--line); border-radius:12px; padding:16px 18px; background:linear-gradient(170deg,#fff,var(--paper-2)) }
.pcard strong{ display:block; font-size:14px; color:var(--ink); margin-bottom:6px }
.pcard span{ font-size:13px; color:var(--ink-soft); line-height:1.55 }
@media(max-width:680px){ .policy-cards{ grid-template-columns:1fr } }
.glossary{ display:grid; grid-template-columns:1fr 1fr; gap:16px; margin:22px 0 12px }
.gloss-item{ border:1px solid var(--line-2); border-radius:12px; padding:16px 18px; background:var(--paper) }
.gloss-item h3{ font-size:15px; font-weight:600; color:var(--ink); margin:0 0 6px }
.gloss-item p{ font-size:13px; color:var(--ink-soft); line-height:1.6; margin:0 }
@media(max-width:680px){ .glossary{ grid-template-columns:1fr } }
@media(max-width:880px){
  .pdp{ grid-template-columns:1fr; grid-template-areas:"head" "gallery" "buy"; gap:18px }
  .gallery{ position:static }
  .gallery .main{ padding:32px } .gallery .thumbs{ overflow-x:auto; flex-wrap:nowrap; padding-bottom:4px }
  .pdp-brand{ display:none }   /* brand already shown in breadcrumb on mobile */
}
.acc{ border-top:1px solid var(--line); margin-top:34px }
.acc details{ border-bottom:1px solid var(--line) }
.acc summary{ padding:18px 0; cursor:pointer; font-family:var(--sans); font-size:12px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--ink); list-style:none; display:flex; justify-content:space-between; align-items:center }
.acc summary::-webkit-details-marker{ display:none }
.acc summary::after{ content:"+"; color:var(--gold-deep); font-size:18px; font-weight:300 }
.acc details[open] summary::after{ content:"–" }
.acc .acc-body{ padding:0 0 22px; white-space:pre-line; color:var(--ink-soft); font-size:14.5px; line-height:1.8 }

/* ---------- reviews ---------- */
.reviews{ margin-top:72px }
.review{ border:1px solid var(--line-2); background:var(--paper); border-radius:var(--r); padding:22px 24px; margin-bottom:16px }
.review .head{ display:flex; justify-content:space-between; gap:14px; font-size:13px; align-items:baseline }
.review .head strong{ font-family:var(--serif); font-size:18px; font-weight:500; letter-spacing:.01em }
.review .head .muted{ font-size:11px; letter-spacing:.1em; text-transform:uppercase }
.verified{ color:var(--gold-deep); font-size:11px; letter-spacing:.12em; text-transform:uppercase }
.review p{ color:var(--ink-soft); margin:6px 0 0 }
.rev-stars{ color:var(--gold); font-size:14px; letter-spacing:1px; white-space:nowrap }
.rev-meta{ display:flex; flex-wrap:wrap; align-items:center; gap:8px; margin-top:6px;
  font-size:12px; color:var(--muted) }
.rev-meta .rev-name{ font-weight:600; color:var(--ink-soft) }
.rev-page-hide{ display:none }
.rev-body{ margin-top:6px }
.rev-text{ color:var(--ink-soft); margin:0;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden }
.rev-body.rev-open .rev-text{ -webkit-line-clamp:unset; overflow:visible }
.rev-readmore{ margin-top:6px; padding:0; background:none; border:0; cursor:pointer;
  color:var(--gold-deep); font:600 12px/1 var(--sans); letter-spacing:.02em }
.rev-readmore:hover{ text-decoration:underline }
.rev-more{ display:block; margin:18px auto 0; padding:12px 30px; background:transparent;
  border:1px solid var(--ink); color:var(--ink); border-radius:999px; cursor:pointer;
  font:500 11px/1 var(--sans); letter-spacing:.16em; text-transform:uppercase; transition:background .25s,color .25s }
.rev-more:hover{ background:var(--ink); color:#fff }

/* ---------- cart page ---------- */
.bag{ max-width:1000px; margin:16px auto 56px }
.bag-head{ display:flex; align-items:baseline; gap:12px; margin-bottom:22px }
.bag-head h1{ margin:0; font-size:clamp(24px,3.5vw,32px); font-weight:600; color:var(--ink) }
.bag-count{ font-size:13px; color:var(--muted) }
.bag-empty{ text-align:center; padding:60px 20px; color:var(--ink-soft) }
.bag-empty svg{ color:var(--muted); margin-bottom:12px }
.bag-empty p{ margin:0 0 16px; font-size:15px }
.bag-grid{ display:grid; grid-template-columns:1.5fr 1fr; gap:26px; align-items:start }
.bag-free{ background:var(--paper-2); border:1px solid var(--line-2); border-radius:12px; padding:12px 16px; margin-bottom:16px; font-size:13px; color:var(--ink-soft) }
.bag-free strong{ color:var(--ink) }
.bag-free-bar{ height:5px; border-radius:999px; background:#e2e0f2; overflow:hidden; margin-top:9px }
.bag-free-bar i{ display:block; height:100%; background:var(--gold); transition:width .4s ease }
.bag-free-ok{ display:flex; align-items:center; gap:7px; color:var(--gold-deep); font-weight:600 }
.bag-li{ display:grid; grid-template-columns:auto 1fr auto; gap:16px; padding:18px 0; border-bottom:1px solid var(--line-2) }
.bag-li:first-of-type{ border-top:1px solid var(--line-2) }
.bag-li-img{ width:84px; height:84px; border:1px solid var(--line); border-radius:12px; background:#fff; flex:0 0 auto; overflow:hidden; display:block }
.bag-li-img img{ width:100%; height:100%; object-fit:contain; padding:7px; box-sizing:border-box }
.bag-li-mid{ min-width:0 }
.bag-li-brand{ font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:3px }
.bag-li-name{ display:block; font-size:14.5px; font-weight:500; color:var(--ink); line-height:1.35 }
.bag-li-price{ font-size:13.5px; color:var(--ink-soft); margin-top:5px }
.bag-was{ text-decoration:line-through; color:var(--muted); margin-left:5px }
.bag-qty{ display:inline-flex; align-items:center; gap:14px; margin-top:12px; border:1px solid var(--line); border-radius:999px; padding:4px 6px }
.bag-qty button{ width:26px; height:26px; border:0; background:none; cursor:pointer; font-size:17px; color:var(--ink); line-height:1; border-radius:50% }
.bag-qty button:hover{ background:var(--paper-2) }
.bag-qty span{ min-width:18px; text-align:center; font-size:14px; font-weight:600 }
.bag-li-end{ text-align:right; display:flex; flex-direction:column; align-items:flex-end; justify-content:space-between }
.bag-li-line{ font-size:15px; font-weight:600; color:var(--ink); white-space:nowrap }
.bag-rm{ background:none; border:0; cursor:pointer; font-size:12px; color:var(--muted); letter-spacing:.04em; padding:0 }
.bag-rm:hover{ color:var(--sale) }
.bag-continue{ display:inline-block; margin-top:20px; font-size:13px; color:var(--gold-deep) }
.bag-continue:hover{ text-decoration:underline }
/* summary */
.bag-sum{ background:var(--paper-2); border:1px solid var(--line-2); border-radius:16px; padding:24px 26px; position:sticky; top:96px }
.bag-sum h3{ font-size:13px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); margin:0 0 16px; font-weight:600 }
.bag-row{ display:flex; justify-content:space-between; align-items:baseline; font-size:14px; color:var(--ink-soft); padding:7px 0 }
.bag-ship-note{ font-style:normal; font-size:10.5px; color:var(--muted); display:block; margin-top:2px }
.bag-save{ color:var(--sale); font-weight:600 }
.bag-total{ border-top:1px solid var(--line); margin-top:8px; padding-top:14px; color:var(--ink); font-weight:700; font-size:16px }
.bag-total span:last-child{ font-size:22px }
.bag-sum .co-pay{ margin-top:16px }
.bag-trust{ margin-top:22px; padding-top:20px; border-top:1px solid var(--line-2); text-align:center }
.bag-trust .trust-head{ font-size:10.5px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--ink); margin:0 0 14px }
.bag-trust .co-sec-seals{ justify-content:center; gap:12px }
.bag-trust .deptseal{ width:58px; height:58px }
.bag-trust .deptseal text{ font-size:9px }
.bag-pays{ display:flex; justify-content:center; gap:7px; margin-top:16px }
.bag-pays .pay{ height:24px; min-width:36px; padding:0 7px; box-shadow:0 1px 3px rgba(39,36,66,.10) }
.bag-foot{ font-size:10.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); margin:14px 0 0 }
@media(max-width:820px){
  .bag-grid{ grid-template-columns:1fr; gap:20px }
  .bag-sum{ position:static }
}
@media(max-width:480px){
  .bag-li-img{ width:68px; height:68px }
  .bag-trust .deptseal{ width:52px; height:52px }
}

/* ---------- payment processing overlay ---------- */
.pay-overlay{ position:fixed; inset:0; z-index:3000; background:rgba(20,18,40,.55);
  display:flex; align-items:center; justify-content:center; padding:24px }
.pay-overlay[hidden]{ display:none }
.pay-overlay-card{ background:#fff; border-radius:16px; padding:30px 34px; text-align:center; max-width:300px; box-shadow:0 24px 64px rgba(0,0,0,.32) }
.pay-spin{ width:38px; height:38px; border:3px solid var(--line); border-top-color:var(--gold); border-radius:50%; margin:0 auto 16px; animation:payspin .8s linear infinite }
@keyframes payspin{ to{ transform:rotate(360deg) } }
.pay-overlay-card h4{ font-size:16px; font-weight:600; margin:0 0 6px; color:var(--ink) }
.pay-overlay-card p{ font-size:13px; color:var(--ink-soft); margin:0; line-height:1.5 }

/* ---------- Checkout chrome (Shopify pattern) ---------- */
.co-alert{ display:flex; align-items:center; gap:9px; margin:0 0 22px; padding:13px 16px;
  background:#fdecef; border:1px solid #f3c4cf; border-radius:10px; color:#8c2f44; font-size:13.5px; line-height:1.45 }
.co-alert svg{ flex:0 0 auto; color:#d23a6a }
.co-alert[hidden]{ display:none }
.co-header{ position:relative; display:flex; justify-content:center; align-items:center; padding:20px 24px; border-bottom:1px solid var(--line-2); background:#fff }
.co-logo-img{ height:42px; width:auto; display:block }
.co-cart-back{ position:absolute; right:20px; top:50%; transform:translateY(-50%); display:inline-flex; align-items:center; gap:6px;
  font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft) }
.co-cart-back:hover{ color:var(--gold-deep) }
.co-cart-back svg{ flex:0 0 auto }
@media(max-width:520px){ .co-cart-back{ right:14px } .co-cart-back span{ display:none } }
.co-footer{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:10px; max-width:1100px; margin:0 auto;
  padding:26px 28px; font-size:12px; color:var(--muted); border-top:1px solid var(--line-2) }
.co-footer-links a{ color:var(--ink-soft) }
.co-footer-links a:hover{ color:var(--ink) }
.co-page{ padding-top:6px }

/* ---------- Modern boxed checkout ---------- */
.co{ display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:start; margin:14px 0 56px; background:transparent }
.co-main{ min-width:0 }
.co-block{ margin-bottom:32px }
.co-block:last-of-type{ margin-bottom:0 }
.co-block h2{ font-size:21px; font-weight:700; color:var(--ink); margin:0 0 16px; letter-spacing:-.01em }
.co-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:16px }
.co-head h2{ margin:0 }
.co-login{ font-size:14px; color:var(--gold-deep); text-decoration:underline; text-underline-offset:3px }
/* boxed floating-label inputs */
.co-field{ position:relative; margin-bottom:13px }
.co-input{ width:100%; height:52px; padding:19px 14px 5px; border:1px solid var(--line); border-radius:10px;
  font:400 14.5px/1.2 var(--sans); color:var(--ink); background:#fff; transition:border-color .15s ease, box-shadow .15s ease }
.co-input::placeholder{ color:transparent }
.co-input:hover{ border-color:#c6c3da }
.co-input:focus{ outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(51,48,120,.10) }
.co-field > label, .co-phone-field > label{ position:absolute; left:14px; top:50%; transform:translateY(-50%);
  margin:0; display:block; text-transform:none; letter-spacing:0; color:#9c99b5; font-size:14.5px; font-weight:400;
  pointer-events:none; transform-origin:left center; transition:transform .14s ease, color .14s ease; white-space:nowrap }
.co-input:focus + label,
.co-input:not(:placeholder-shown) + label{ transform:translateY(-19px) scale(.8); color:var(--ink-soft) }
.co-opt{ color:var(--muted) }
.co-hint{ font-size:12.5px; color:var(--muted); margin:6px 2px 0 }
.co-secure{ font-size:13px; color:var(--muted); margin:0 0 14px }
.co-applepay{ min-height:0 }
.co-applepay-wrap{ position:relative; min-height:46px }
.co-ap-loading{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; gap:9px;
  background:#fff; border:1px solid var(--line); border-radius:12px; font-size:12.5px; color:var(--muted); letter-spacing:.02em }
.co-ap-loading[hidden]{ display:none }
.ap-spin{ width:16px; height:16px; border:2px solid var(--line); border-top-color:var(--gold); border-radius:50%; animation:payspin .8s linear infinite }
.co-row{ display:grid; grid-template-columns:1fr 1fr; gap:13px; margin-bottom:13px }
.co-row .co-field{ margin-bottom:0 }
/* country (locked to top-bar region) — styled like a select */
.co-country{ display:flex; align-items:center; gap:11px; height:56px; padding:0 14px; border:1px solid var(--line);
  border-radius:10px; background:#fff; cursor:default }
.co-country-flag{ font-size:20px; line-height:1 }
.co-country-text{ display:flex; flex-direction:column; min-width:0; line-height:1.2 }
.co-country-lab{ font-size:10.5px; color:var(--ink-soft) }
.co-country-val{ font-size:14.5px; color:var(--ink) }
.co-country-chev{ margin-left:auto; color:var(--muted); flex:0 0 auto }
/* phone — separate prefix segment + input with its own floating label */
.co-phone{ display:flex; flex-wrap:wrap; align-items:stretch; gap:10px }
.co-dial{ display:flex; align-items:center; justify-content:center; height:52px; min-width:62px; padding:0 14px;
  border:1px solid var(--line); border-radius:10px; background:var(--paper-2);
  color:var(--ink); font-size:14.5px; font-weight:600; white-space:nowrap; flex:0 0 auto }
.co-phone-field{ position:relative; flex:1 1 auto; min-width:0 }
.co-phone-field .co-input{ width:100% }
.co-phone .co-err{ flex:0 0 100%; width:100% }
/* payment method card */
.co-method{ display:flex; align-items:center; gap:13px; padding:18px 18px; border:1.5px solid var(--line); border-radius:12px; background:#fff }
.co-method-on{ border-color:var(--gold); background:#f7f6fc }
.co-method-radio{ width:18px; height:18px; border-radius:50%; border:2px solid var(--gold); position:relative; flex:0 0 auto }
.co-method-on .co-method-radio::after{ content:""; position:absolute; inset:3px; border-radius:50%; background:var(--gold) }
.co-method-name{ font-size:15px; font-weight:600; color:var(--ink) }
.co-method-brands{ margin-left:auto; display:flex; align-items:center; gap:7px }
.co-method-more{ font-size:12px; color:var(--muted); font-weight:600 }
/* secure-checkout card */
.co-cardbox{ border:1px solid var(--line); border-radius:12px; padding:4px; background:#fff }
/* clearly-labelled card details box */
.co-cardwrap{ border:1px solid var(--line); border-radius:14px; background:#fff; overflow:hidden; margin-bottom:16px }
.co-cardwrap-head{ display:flex; align-items:center; justify-content:space-between; gap:10px; padding:12px 16px; background:var(--paper-2); border-bottom:1px solid var(--line-2) }
.co-cardwrap-title{ display:inline-flex; align-items:center; gap:7px; font-size:13px; font-weight:600; color:var(--ink) }
.co-cardwrap-title svg{ color:var(--ink-soft); flex:0 0 auto }
.co-cardwrap-cards{ display:flex; gap:6px }
.co-cardwrap-cards .pay{ height:22px; min-width:34px; padding:0 6px; box-shadow:0 1px 2px rgba(39,36,66,.08) }
.co-cardwrap .co-cardbox{ border:0; border-radius:0; padding:12px 14px; background:#fff }
.co-cardwrap .co-cardbox.co-input-bad{ border:0; box-shadow:inset 0 0 0 2px var(--sale) }
.co-cardwrap-foot{ display:flex; align-items:center; gap:7px; padding:11px 16px; border-top:1px solid var(--line-2); background:var(--paper-2); font-size:11.5px; color:var(--muted) }
.co-cardwrap-foot svg{ color:var(--gold); flex:0 0 auto }
.co-cardbox.co-input-bad{ border-color:var(--sale) }
.co-accept{ display:flex; align-items:center; gap:8px; margin:12px 0 18px }
.co-accept-lab{ font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-right:2px }
.co-check{ display:flex; align-items:center; gap:11px; font-size:14px; color:var(--ink); cursor:pointer; user-select:none; margin:4px 0 0; text-transform:none; letter-spacing:0 }
.co-check input{ width:18px; height:18px; accent-color:var(--gold) }
.co-bill{ margin-top:18px }
.co-bill[hidden]{ display:none }
.co-err{ display:block; color:var(--sale); font-size:11.5px; margin-top:5px }
.co-err:empty{ display:none }
.co-input-bad{ border-color:var(--sale)!important; box-shadow:none!important }
/* express */
.co-express{ margin-bottom:24px }
.co-express-label{ text-align:center; font-size:10.5px; letter-spacing:.22em; text-transform:uppercase; color:var(--muted); margin-bottom:14px }
.co-or{ display:flex; align-items:center; gap:16px; color:var(--muted); font-size:11px; margin:20px 0 0;
  text-transform:uppercase; letter-spacing:.18em }
.co-or::before,.co-or::after{ content:""; flex:1; height:1px; background:var(--line) }
/* place order */
.co-pay{ width:100%; margin-top:22px; display:flex; align-items:center; justify-content:center; gap:9px;
  background:var(--ink); color:#fff; border:0; border-radius:12px; padding:17px; font-size:14px; letter-spacing:.1em }
.co-pay:hover{ background:#000 }
.co-placefoot{ text-align:center; font-size:11px; letter-spacing:.05em; color:var(--muted); margin:14px 0 0 }
.co-fxnote{ font-size:12px; line-height:1.5; color:var(--ink-soft); background:var(--paper-2); border:1px solid var(--line-2); border-radius:10px; padding:10px 13px; margin:14px 0 0 }
.co-fxnote strong{ color:var(--ink) }
/* accreditation-style seals aligned with the Secure Checkout heading */
.co-sec-head{ display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap; margin-bottom:22px }
.co-sec-head h2{ margin:0 }
.co-sec-seals{ display:flex; gap:16px; align-items:center }
.deptseal{ width:82px; height:82px; color:var(--gold); flex:0 0 auto }
.deptseal text{ fill:#fff; font-family:var(--sans); font-weight:700; font-size:9px; letter-spacing:.5px }
@media(max-width:560px){ .co-sec-head{ gap:14px } .co-sec-seals{ gap:10px } .deptseal{ width:64px; height:64px } .deptseal text{ font-size:10px } }

/* trust seals block */
.trust{ margin-top:18px; padding-top:16px; border-top:1px solid var(--line-2); text-align:center }
.trust-head{ font-size:10.5px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--ink); margin:0 0 12px }
.trust-seals{ display:flex; justify-content:center; gap:18px; margin-bottom:14px }
.seal{ display:flex; flex-direction:column; align-items:center; gap:6px; width:78px }
.seal svg{ width:40px; height:40px; color:var(--gold); flex:0 0 auto }
.seal span{ font-size:9px; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-soft); line-height:1.3; font-weight:600 }
.trust-pays{ display:flex; justify-content:center; align-items:center; flex-wrap:wrap; gap:7px; padding-top:14px; border-top:1px solid var(--line-2) }
.trust-pays .pay{ height:24px; min-width:36px; padding:0 7px; box-shadow:0 1px 3px rgba(39,36,66,.10) }
.trust-verified{ display:inline-flex; align-items:center; gap:4px; font-size:10.5px; font-weight:600; color:#1d9e75; letter-spacing:.02em }
@media(max-width:520px){ .trust-seals{ gap:12px } .seal{ width:72px } .seal svg{ width:36px; height:36px } }
.co-log{ margin-top:16px; font:12px/1.5 Menlo,monospace; color:var(--ink-soft); background:var(--paper-2);
  border:1px solid var(--line-2); border-radius:8px; padding:10px 12px; white-space:pre-wrap;
  max-height:160px; overflow:auto; display:none }
.co-log:not(:empty){ display:block }
/* order summary — right column */
.co-summary{ background:var(--paper-2); border:1px solid var(--line-2); border-radius:16px; padding:24px 26px; align-self:start }
.co-summary-in{ position:sticky; top:96px }
.co-li{ display:grid; grid-template-columns:auto 1fr auto; gap:16px; align-items:center; padding:0 0 18px; margin:0 }
.co-li-img{ position:relative; width:62px; height:62px; flex:0 0 auto; overflow:visible }
.co-li-thumb{ display:block; width:100%; height:100%; border:1px solid var(--line); border-radius:10px;
  background:#fff; overflow:hidden }
.co-li-thumb img{ width:100%; height:100%; object-fit:contain; padding:6px; box-sizing:border-box }
.co-li-q{ position:absolute; top:-9px; left:-9px; z-index:2; min-width:23px; height:23px; padding:0 6px; border-radius:999px;
  background:var(--ink); color:#fff; font-size:12px; font-weight:600; line-height:1; display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 0 2px var(--paper-2) }
.co-li-info{ min-width:0 }
.co-li-t{ font-size:14px; line-height:1.35; color:var(--ink); font-weight:500; overflow-wrap:anywhere }
.co-li-brand{ font-size:12.5px; color:var(--muted); margin-top:3px }
.co-li-p{ font-size:14px; font-weight:600; color:var(--ink); white-space:nowrap; align-self:start; text-align:right }
.co-sum-row{ display:flex; justify-content:space-between; font-size:14px; color:var(--ink-soft); padding:6px 0 }
.co-sum-first{ border-top:1px solid var(--line-2); margin-top:4px; padding-top:14px }
.co-li-was{ display:block; margin:2px 0 0; color:var(--muted); text-decoration:line-through; font-weight:400; font-size:12px }
.co-sum-save{ color:var(--sale); font-weight:600 }
.co-sum-total{ display:flex; justify-content:space-between; align-items:baseline; color:var(--ink);
  font-size:16px; font-weight:700; border-top:1px solid var(--line); margin-top:8px; padding-top:14px }
.co-sum-total span:last-child{ font-size:24px }
@media(max-width:860px){
  .co{ grid-template-columns:1fr; gap:22px; margin:8px 0 40px }
  .co-summary{ grid-row:1 }
  .co-summary-in{ position:static }
}
@media(max-width:600px){
  .co-summary{ padding:18px 16px; border-radius:14px }
  .co-block{ margin-bottom:26px }
  .co-block h2{ font-size:19px; margin-bottom:13px }
  .co-input{ height:54px; padding:20px 14px 6px; font-size:16px }
  .co-field > label{ left:14px; font-size:15px }
  .co-country{ height:56px; padding:0 14px }
  .co-logo-img{ height:36px }
  .co-row{ grid-template-columns:1fr; gap:13px }
  .co-method{ padding:15px 14px }
  .co-method-name{ font-size:14px }
  .co-pay{ padding:16px; font-size:15px }
  .co-li-t{ font-size:13.5px }
  .co-li-p,.co-sum-row,.co-sum-total span:first-child{ font-size:13.5px }
}

/* ---------- Order receipt ---------- */
.receipt{ max-width:860px; margin:18px auto 56px }
.rcpt-top{ text-align:center; margin-bottom:34px }
.rcpt-check{ display:inline-flex; align-items:center; justify-content:center; width:54px; height:54px; border-radius:50%;
  background:#e8f6ee; color:#1d9e75; margin-bottom:16px }
.rcpt-eyebrow{ font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep); margin:0 0 8px }
.rcpt-eyebrow-warn{ color:var(--sale) }
.rcpt-top h1{ font-size:clamp(26px,4vw,34px); margin:0 0 10px; color:var(--ink); font-weight:600 }
.rcpt-sub{ color:var(--ink-soft); font-size:15px; line-height:1.6; max-width:48ch; margin:0 auto }
.rcpt-sub strong{ color:var(--ink) }
.rcpt-meta{ display:flex; flex-wrap:wrap; justify-content:center; align-items:center; gap:8px; margin-top:18px; font-size:13px; color:var(--muted) }
.rcpt-meta strong{ color:var(--ink) }
.rcpt-dot{ opacity:.5 }
.rcpt-grid{ display:grid; grid-template-columns:1.4fr 1fr; gap:18px; align-items:start }
.rcpt-card{ border:1px solid var(--line-2); border-radius:16px; padding:24px 26px; background:#fff }
.rcpt-card h3{ font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); margin:0 0 16px; font-weight:600 }
.rcpt-li{ display:grid; grid-template-columns:auto 1fr auto; gap:14px; align-items:center; padding:0 0 16px }
.rcpt-li-img{ position:relative; width:54px; height:54px; border:1px solid var(--line); border-radius:9px; background:#fff; flex:0 0 auto }
.rcpt-li-img img{ width:100%; height:100%; object-fit:contain; padding:5px; box-sizing:border-box }
.rcpt-li-q{ position:absolute; top:-8px; left:-8px; min-width:21px; height:21px; padding:0 5px; border-radius:999px;
  background:var(--ink); color:#fff; font-size:11px; font-weight:600; display:flex; align-items:center; justify-content:center; box-shadow:0 0 0 2px #fff }
.rcpt-li-t{ font-size:13.5px; line-height:1.4; color:var(--ink) }
.rcpt-li-p{ font-size:13.5px; font-weight:600; color:var(--ink); white-space:nowrap }
.rcpt-row{ display:flex; justify-content:space-between; font-size:14px; color:var(--ink-soft); padding:7px 0 }
.rcpt-row:first-of-type{ border-top:1px solid var(--line-2); margin-top:6px; padding-top:15px }
.rcpt-total{ color:var(--ink); font-weight:700; font-size:16px; border-top:1px solid var(--line); margin-top:6px; padding-top:14px }
.rcpt-total span:last-child{ font-size:22px }
.rcpt-side{ display:flex; flex-direction:column; gap:18px }
.rcpt-addr{ font-size:13.5px; line-height:1.7; color:var(--ink-soft); margin:0 }
.rcpt-track p{ font-size:13px; line-height:1.6; color:var(--ink-soft); margin:0 }
.rcpt-actions{ text-align:center; margin-top:28px }
.rcpt-continue{ font-size:13px; letter-spacing:.04em; color:var(--gold-deep) }
.rcpt-continue:hover{ text-decoration:underline }
@media(max-width:760px){ .rcpt-grid{ grid-template-columns:1fr } .rcpt-card{ padding:20px } }

/* ---------- Top Picks rail ---------- */
.toppicks{ margin:56px 0 8px }
.tp-head{ text-align:center; margin-bottom:22px }
.tp-head h2{ font-family:var(--serif); font-size:30px; font-weight:500; color:var(--gold-deep); margin:0 }
.tp-wrap{ position:relative }
.tp-track{ scroll-snap-type:x mandatory }
.tp-arrow{ position:absolute; top:42%; transform:translateY(-50%); z-index:3;
  width:42px; height:42px; border-radius:50%; border:1px solid var(--line); background:#fff;
  color:var(--gold-deep); font-size:24px; line-height:1; cursor:pointer; display:flex;
  align-items:center; justify-content:center; box-shadow:0 6px 18px rgba(39,36,66,.12); transition:background .2s }
.tp-arrow:hover{ background:var(--paper-2) }
.tp-prev{ left:-8px } .tp-next{ right:-8px }
.tp-dots{ display:flex; justify-content:center; gap:8px; margin-top:14px }
.tp-dots b{ width:9px; height:9px; border-radius:50%; background:var(--line); cursor:pointer; transition:background .2s }
.tp-dots b.on{ background:var(--gold) }
@media(max-width:640px){
  .tp-arrow{ display:none }
  .tp-head h2{ font-size:24px }
  .toppicks{ margin:40px 0 4px }
}
.rv-sec{ background:var(--paper-2); border:1px solid var(--line-2); border-radius:18px; padding:26px 20px 22px }
.rv-sec[hidden]{ display:none }
@media(max-width:640px){ .rv-sec{ padding:20px 12px 18px } }

/* ---------- cart / checkout ---------- */
.tbl{ width:100%; border-collapse:collapse; background:var(--paper); border:1px solid var(--line); border-radius:var(--r); overflow:hidden }
.tbl th{ font-family:var(--sans); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); font-weight:400 }
.tbl th,.tbl td{ padding:18px; border-bottom:1px solid var(--line-2); text-align:left; font-size:14px; vertical-align:middle }
.tbl tr:last-child td{ border-bottom:0 }
.tbl img{ width:64px; border-radius:8px; background:var(--paper-2) }
.tbl input[type=number]{ font-family:var(--sans) }
.totals{ margin-top:26px; max-width:380px; margin-left:auto; background:var(--paper); border:1px solid var(--line);
  border-radius:var(--r); padding:26px 28px }
.totals h3{ font-size:22px; margin:0 0 12px }
.totals .row{ display:flex; justify-content:space-between; padding:8px 0; font-size:14px; color:var(--ink-soft) }
.totals .row.grand{ border-top:1px solid var(--line); margin-top:10px; padding-top:16px; font-weight:400;
  font-size:18px; color:var(--ink) }
.totals .row.grand span:last-child{ font-family:var(--serif); font-size:24px }

/* labels + inputs (checkout) */
label{ display:block; font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin:14px 0 6px }
.txt,input.txt{ width:100%; padding:13px 15px; border:1px solid var(--line); border-radius:10px;
  background:var(--paper); font-family:var(--sans); font-size:15px; color:var(--ink) }
.txt:focus{ outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(176,141,87,.12) }
.badge{ display:inline-block; font-size:10px; letter-spacing:.14em; text-transform:uppercase; padding:4px 12px;
  border-radius:999px; background:var(--paper-2); border:1px solid var(--gold); color:var(--gold-deep);
  vertical-align:middle; margin-left:10px; font-family:var(--sans) }
.err{ background:#fbf0ec; border:1px solid var(--sale); color:#7a2b20; border-radius:10px; padding:14px; font-size:13px }
.or{ display:flex; align-items:center; gap:14px; color:var(--muted); font-size:11px; letter-spacing:.2em;
  text-transform:uppercase; margin:18px 0 6px }
.or::before,.or::after{ content:""; height:1px; background:var(--line); flex:1 }

#log{ margin-top:16px; background:#211f3a; color:#d8d6ea; padding:14px; border-radius:10px;
  font:12px/1.5 ui-monospace,Menlo,Monaco,monospace; white-space:pre-wrap; min-height:80px; max-height:260px; overflow:auto }
.ok{color:#7fb89a}.warn{color:#d9b24c}.bad{color:#d98b7a}

/* ---------- utilities row (region + bag) ---------- */
.utils{ display:flex; align-items:center; gap:18px }
.region{ position:relative }
.region-btn{ display:flex; align-items:center; gap:7px; background:transparent; border:1px solid var(--line);
  border-radius:999px; padding:8px 13px; cursor:pointer; font-family:var(--sans); font-size:11px;
  letter-spacing:.12em; color:var(--ink-soft) }
.region-btn .flag{ font-size:15px; line-height:1 }
.region-btn .chev{ color:var(--muted); font-size:12px }
.region-menu{ position:absolute; right:0; top:calc(100% + 10px); width:268px; background:var(--paper);
  border:1px solid var(--line); border-radius:14px; box-shadow:var(--shadow); padding:10px;
  opacity:0; visibility:hidden; transform:translateY(6px); transition:all .22s ease; z-index:60; max-height:60vh; overflow:auto }
.region:hover .region-menu,.region:focus-within .region-menu{ opacity:1; visibility:visible; transform:translateY(0) }
.region-head{ font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin:6px 10px 8px }
.region-menu a{ display:flex; align-items:center; gap:9px; padding:9px 10px; border-radius:9px; font-size:13.5px; color:var(--ink-soft) }
.region-menu a .flag{ font-size:16px }
.region-menu a .muted{ margin-left:auto; font-size:11px; letter-spacing:.08em }
.region-menu a:hover{ background:var(--paper-2) }
.region-menu a.active{ background:var(--paper-2); color:var(--ink) }

/* ---------- hamburger ---------- */
.hamburger{ display:none; background:none; border:0; cursor:pointer; width:26px; height:20px; position:relative; padding:0 }
.hamburger span{ position:absolute; left:0; width:100%; height:1.6px; background:var(--ink); transition:.3s }
.hamburger span:nth-child(1){ top:0 } .hamburger span:nth-child(2){ top:9px } .hamburger span:nth-child(3){ top:18px }

/* ---------- mega menu ---------- */
.megabar{ border-top:1px solid var(--line-2); background:transparent }
.mega{ list-style:none; margin:0 auto; padding:0 28px; max-width:1200px; display:flex; gap:38px; justify-content:center }
.mega > li{ position:relative }
.mega > li > .top{ display:block; padding:15px 0; font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink-soft); position:relative }
.mega > li > .top::after{ content:""; position:absolute; left:0; right:0; bottom:8px; height:1px; background:var(--gold);
  transform:scaleX(0); transform-origin:left; transition:transform .3s ease }
.mega > li:hover > .top{ color:var(--ink) }
.mega > li:hover > .top::after{ transform:scaleX(1) }
.panel{ position:absolute; left:50%; top:100%; transform:translateX(-50%) translateY(8px); min-width:240px;
  background:var(--paper); border:1px solid var(--line); border-radius:14px; box-shadow:var(--shadow); padding:8px;
  opacity:0; visibility:hidden; transition:all .24s ease; z-index:50 }
.mega > li:hover .panel{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0) }
.panel-head{ font-family:var(--serif); font-size:18px; padding:10px 14px 6px; color:var(--ink) }
.panel ul{ list-style:none; margin:0; padding:0 }
.panel a{ display:block; padding:9px 14px; border-radius:9px; font-size:13.5px; color:var(--ink-soft); letter-spacing:.01em }
.panel a:hover{ background:var(--paper-2); color:var(--gold-deep) }
.panel a.strong{ color:var(--ink); font-weight:400; border-top:1px solid var(--line-2); margin-top:4px }

/* ---------- mobile drawer ---------- */
.drawer-scrim{ position:fixed; inset:0; background:rgba(28,22,12,.45); opacity:0; visibility:hidden; transition:.3s; z-index:80 }
.drawer{ position:fixed; top:0; left:0; height:100%; width:min(86vw,360px); background:var(--paper); z-index:90;
  transform:translateX(-100%); transition:transform .34s cubic-bezier(.3,.7,.2,1); overflow:auto;
  border-right:1px solid var(--line); display:flex; flex-direction:column }
body.nav-open .drawer{ transform:translateX(0) }
body.nav-open .drawer-scrim{ opacity:1; visibility:visible }
body.nav-open{ overflow:hidden }
.drawer-top{ display:flex; align-items:center; justify-content:space-between; padding:20px 22px; border-bottom:1px solid var(--line-2) }
.drawer-top .logo{ font-size:22px } .drawer-top button{ background:none; border:0; font-size:18px; cursor:pointer; color:var(--ink) }
.drawer-nav{ padding:8px 12px }
.drawer-nav details{ border-bottom:1px solid var(--line-2) }
.drawer-nav summary{ list-style:none; padding:15px 10px; font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  cursor:pointer; display:flex; justify-content:space-between; align-items:center }
.drawer-nav summary::-webkit-details-marker{ display:none }
.drawer-nav summary::after{ content:"+"; color:var(--gold-deep); font-size:17px }
.drawer-nav details[open] summary::after{ content:"–" }
.drawer-sub{ padding:0 10px 12px } .drawer-sub a{ display:block; padding:8px 12px; font-size:14px; color:var(--ink-soft) }
.drawer-region{ margin-top:auto; padding:16px 18px; border-top:1px solid var(--line-2) }
.drawer-region a{ display:block; padding:8px 6px; font-size:13.5px; color:var(--ink-soft) }
.drawer-region a.active{ color:var(--ink) }

/* ---------- geo modal ---------- */
.geo-modal{ position:fixed; inset:0; background:rgba(28,22,12,.5); backdrop-filter:blur(3px);
  display:flex; align-items:center; justify-content:center; padding:20px; z-index:120;
  opacity:0; visibility:hidden; transition:.3s }
.geo-modal.show{ opacity:1; visibility:visible }
.geo-card{ position:relative; background:var(--paper); border:1px solid var(--line); border-radius:18px;
  box-shadow:var(--shadow); max-width:420px; width:100%; padding:40px 36px; text-align:center;
  transform:translateY(12px) scale(.98); transition:.3s }
.geo-modal.show .geo-card{ transform:none }
.geo-flag{ font-size:42px; line-height:1; margin-bottom:14px }
.geo-card h3{ font-size:26px; margin:0 0 10px }
.geo-card p{ color:var(--ink-soft); font-size:14.5px; margin:0 auto 22px; max-width:34ch }
.geo-actions{ display:flex; flex-direction:column; gap:10px }
.geo-actions .btn{ margin-top:0; width:100% }
.geo-close{ position:absolute; top:14px; right:16px; background:none; border:0; font-size:16px; color:var(--muted); cursor:pointer }

/* ---------- luxury footer ---------- */
.lux-footer{ margin-top:90px; background:#26244d; color:#cbc9e4; font-size:14px }
.lux-footer .logo{ color:#ffffff; font-size:30px; font-weight:600; letter-spacing:.30em; opacity:1 }
.news{ border-bottom:1px solid rgba(255,255,255,.10); text-align:center; padding:60px 24px }
.news-inner{ max-width:540px; margin:0 auto }
.news .eyebrow{ color:#a7a3e6; letter-spacing:.34em; text-transform:uppercase; font-size:11.5px; font-weight:600; margin:0 0 14px }
.news h2{ color:#ffffff; font-size:34px; margin:0 0 12px }
.news-sub{ color:#c4c1e2; margin:0 auto 28px; max-width:42ch }
.news-form{ display:flex; gap:12px; max-width:480px; margin:0 auto; flex-wrap:nowrap }
.news-form input{ flex:1 1 auto; min-width:0; padding:15px 20px; border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.06); border-radius:999px; color:#ffffff; font-family:var(--sans); font-size:14px }
.news-form input::placeholder{ color:#b0adda }
.news-form input:focus{ outline:none; border-color:#8884d8; background:rgba(255,255,255,.10) }
.news-form .btn{ margin-top:0; flex:0 0 auto; background:#5b57b8; color:#ffffff; border:0 }
.news-form .btn:hover{ background:#6d69c9 }
.news-msg{ color:#a7a3e6; font-size:13px; margin:14px 0 0; min-height:18px; letter-spacing:.04em }
@media(max-width:560px){
  .news{ padding:48px 22px }
  .news-form{ flex-direction:column; gap:12px }
  .news-form .btn{ width:100% }
}

.foot-grid{ max-width:1200px; margin:0 auto; padding:56px 28px; display:grid;
  grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px }
.foot-brand p{ color:#a7a4c8; max-width:38ch; margin:14px 0 18px; font-size:13.5px; line-height:1.7 }
.social{ display:flex; gap:12px }
.social a{ width:38px; height:38px; border:1px solid rgba(255,255,255,.16); border-radius:50%;
  display:flex; align-items:center; justify-content:center; color:#cbc9e4; transition:.25s }
.social a:hover{ background:var(--gold); color:#ffffff; border-color:var(--gold) }
.foot-col h4{ font-family:var(--sans); font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  color:#ffffff; margin:0 0 16px; font-weight:500 }
.foot-col a{ display:block; padding:6px 0; color:#a7a4c8; font-size:13.5px; transition:color .18s ease }
.foot-col a:hover{ color:#ffffff }

.foot-trust{ max-width:1200px; margin:0 auto; padding:24px 28px; border-top:1px solid rgba(255,255,255,.08);
  display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap }
.security{ display:flex; gap:18px; flex-wrap:wrap }
.trust-chip{ display:inline-flex; align-items:center; gap:7px; font-size:11px; letter-spacing:.1em;
  text-transform:uppercase; color:#b6b3d4 }
.trust-chip svg{ color:var(--gold) }
.payments{ display:flex; gap:8px; align-items:center; flex-wrap:wrap }
.pay{ height:30px; min-width:48px; padding:0 10px; border-radius:6px; background:#fff; color:#1a1a1a;
  display:inline-flex; align-items:center; justify-content:center; font:700 11px/1 var(--sans); letter-spacing:.04em }
.pay.visa{ color:#1a1f71; font-style:italic } .pay.amex{ color:#2e77bb }
.pay.mada{ color:#1a1a1a } .pay.applepay{ color:#000; font-weight:500 } .pay.tap{ color:#11a16b }
.pay.mc{ gap:0 } .pay.mc i{ width:15px; height:15px; border-radius:50% } .pay.mc i:first-child{ background:#eb001b }
.pay.mc i:last-child{ background:#f79e1b; margin-left:-6px; mix-blend-mode:multiply }

/* promo / urgency banner (full-bleed) */
.promo-bar{ display:flex; align-items:center; gap:14px;
  padding:16px 24px; background:#a8dadc; color:var(--gold-deep);
  text-decoration:none; border-bottom:1px solid rgba(40,38,95,.10); }
.promo-bar:hover{ background:#9fd4d6 }
.promo-copy{ flex:1 1 auto; min-width:0; display:flex; flex-direction:column; gap:3px; }
.promo-copy strong{ font:700 17px/1.25 var(--sans); letter-spacing:-.01em }
.promo-copy span{ font:500 14px/1.35 var(--sans); color:var(--ink) }
.promo-arrow{ flex:0 0 auto; color:var(--gold-deep) }
@media (max-width:600px){
  .promo-bar{ padding:13px 16px; gap:10px }
  .promo-copy strong{ font-size:15px }
  .promo-copy span{ font-size:12.5px }
  .promo-arrow{ width:18px; height:18px }
}

/* social-proof popup */
.sp-toast{ position:fixed; left:18px; bottom:18px; z-index:1400; max-width:330px;
  display:flex; align-items:center; gap:11px; padding:12px 15px;
  background:#fff; border:1px solid var(--line); border-radius:12px;
  box-shadow:0 12px 34px rgba(39,36,66,.16); color:var(--ink);
  font:400 13px/1.4 var(--sans);
  opacity:0; transform:translateY(14px); pointer-events:none;
  transition:opacity .45s ease, transform .45s ease; }
.sp-toast.show{ opacity:1; transform:translateY(0); }
.sp-ico{ flex:0 0 auto; width:34px; height:34px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:var(--paper-2); color:var(--gold); }
.sp-text{ min-width:0 }
.sp-text strong{ font-weight:600; color:var(--ink) }
.sp-prod{ color:var(--gold); font-weight:600 }
.sp-ago{ color:var(--muted); font-size:12px }
@media (max-width:520px){
  .sp-toast{ left:10px; right:10px; bottom:10px; max-width:none; }
}
@media (prefers-reduced-motion:reduce){
  .sp-toast{ transition:opacity .3s ease }
}
.foot-bottom{ border-top:1px solid rgba(255,255,255,.08); padding:20px 28px; max-width:1200px; margin:0 auto;
  display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; font-size:11px; letter-spacing:.08em; color:#8e8bb4 }
.foot-bottom .muted{ color:#8e8bb4 }

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:960px){
  .megabar{ display:none }
  .hamburger{ display:block }
  .site-header .bar{ gap:14px }
  .region-btn .cur{ display:none }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:30px }
  .foot-brand{ grid-column:1 / -1 }
}
@media(max-width:880px){
  .shop{ grid-template-columns:1fr } .filters{ position:static }
  .pdp{ grid-template-columns:1fr } .hero{ padding:56px 26px }
  .container{ padding:26px 18px }
  .section-title{ margin:38px 0 20px } .section-title h2{ font-size:26px }
  .grid{ grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:16px }
  .card-prod .name{ font-size:16px }
  .foot-trust{ justify-content:center; text-align:center }
}
@media(max-width:560px){
  .site-header .bar{ flex-wrap:wrap; padding:14px 16px }
  .logo-word{ font-size:20px; letter-spacing:.26em }
  .search{ order:3; flex-basis:100%; margin-top:4px }
  .search-box{ max-width:none }
  .news h2{ font-size:26px } .hero h1{ font-size:34px }
  .foot-grid{ grid-template-columns:1fr 1fr }
}

/* ============================================================
   Drawer system v2 (icon utils + slide-in panels)
   ============================================================ */
.utils{ display:flex; align-items:center; gap:6px }
.icon-btn{ position:relative; background:none; border:0; cursor:pointer; color:var(--ink);
  width:42px; height:42px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  transition:background .2s,color .2s }
.icon-btn:hover{ background:var(--paper-2); color:var(--gold-deep) }
.icon-btn .flag{ font-size:20px; line-height:1 }
.bag-count{ position:absolute; top:4px; right:3px; min-width:17px; height:17px; padding:0 4px; border-radius:999px;
  background:var(--gold); color:#ffffff; font:600 10px/17px var(--sans); text-align:center; letter-spacing:0 }

/* shared scrim */
.scrim{ position:fixed; inset:0; background:rgba(28,22,12,.5); backdrop-filter:blur(2px);
  opacity:0; visibility:hidden; transition:opacity .3s,visibility .3s; z-index:100 }
body.drawer-open .scrim{ opacity:1; visibility:visible }
body.drawer-open{ overflow:hidden }

/* base panels */
.drawer,.drawer-r{ position:fixed; top:0; height:100%; width:min(92vw,420px); background:var(--paper); z-index:110;
  display:flex; flex-direction:column; overflow:hidden; box-shadow:var(--shadow);
  transition:transform .36s cubic-bezier(.32,.72,.2,1) }
.drawer{ left:0; transform:translateX(-100%); border-right:1px solid var(--line); width:min(88vw,360px) }
.drawer-r{ right:0; transform:translateX(100%); border-left:1px solid var(--line) }
body.d-nav .drawer-nav-panel{ transform:translateX(0) }
body.d-region .drawer-region-panel{ transform:translateX(0) }
body.d-account .drawer-account-panel{ transform:translateX(0) }
body.d-cart .drawer-cart-panel{ transform:translateX(0) }

.drawer-top{ display:flex; align-items:center; justify-content:space-between; padding:22px 24px; border-bottom:1px solid var(--line-2); flex:0 0 auto }
.drawer-top h3{ font-size:24px; margin:0 } .drawer-top .logo{ font-size:22px }
.drawer-top .x,.drawer .x{ background:none; border:0; font-size:17px; cursor:pointer; color:var(--ink); padding:6px }
.drawer-note{ padding:16px 24px 4px; color:var(--muted); font-size:13px }

/* left nav drawer */
.drawer-acct-row,.drawer-region-row{ display:flex; align-items:center; gap:12px; width:100%; text-align:left;
  background:var(--paper-2); border:0; border-bottom:1px solid var(--line-2); padding:16px 24px; cursor:pointer;
  font-family:var(--sans); font-size:13px; letter-spacing:.04em; color:var(--ink) }
.drawer-acct-row .arr,.drawer-region-row .arr{ margin-left:auto; color:var(--muted); font-size:18px }
.drawer-region-row{ margin-top:auto; border-top:1px solid var(--line-2); border-bottom:0 } .drawer-region-row .flag{ font-size:18px }
.drawer-nav{ padding:6px 12px; overflow:auto; flex:1 }
.drawer-nav details{ border-bottom:1px solid var(--line-2) }
.drawer-nav summary{ list-style:none; padding:16px 12px; font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  cursor:pointer; display:flex; justify-content:space-between; align-items:center }
.drawer-nav summary::-webkit-details-marker{ display:none }
.drawer-nav summary::after{ content:"+"; color:var(--gold-deep); font-size:17px }
.drawer-nav details[open] summary::after{ content:"–" }
.drawer-sub{ padding:0 12px 14px } .drawer-sub a{ display:block; padding:8px 12px; font-size:14px; color:var(--ink-soft) }
.drawer-sub a:hover{ color:var(--gold-deep) }

/* region list */
.region-list{ padding:8px 12px 20px; overflow:auto; flex:1 }
.region-list a{ position:relative; display:flex; align-items:center; gap:12px; padding:14px 14px; border-radius:11px; color:var(--ink-soft) }
.region-list a:hover{ background:var(--paper-2) }
.region-list a.active{ background:var(--paper-2); color:var(--ink) }
.region-list .flag{ font-size:21px } .region-list .rl-name{ font-size:14.5px }
.region-list .rl-cur{ margin-left:auto; font-size:11px; letter-spacing:.1em; color:var(--muted) }
.region-list .rl-check{ color:var(--gold-deep); margin-left:10px }

/* account drawer */
.acct-hero{ text-align:center; padding:34px 28px 28px; border-bottom:1px solid var(--line-2); color:var(--ink) }
.acct-hero svg{ color:var(--gold-deep) }
.acct-hero p{ font-family:var(--serif); font-size:24px; margin:10px 0 6px }
.acct-hero .muted{ display:block; font-size:13px; max-width:30ch; margin:0 auto 18px }
.acct-cta{ display:flex; gap:10px; justify-content:center } .acct-cta .btn{ margin-top:0 }
.acct-links{ padding:10px 12px; overflow:auto }
.acct-links a{ display:flex; align-items:center; justify-content:space-between; padding:16px 14px;
  border-bottom:1px solid var(--line-2); font-size:14px; color:var(--ink-soft) }
.acct-links a:hover{ color:var(--gold-deep) } .acct-links .arr{ color:var(--muted); font-size:18px }

/* cart drawer */
.cart-free{ display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center;
  padding:11px 16px; min-height:42px; font-size:12.5px; letter-spacing:.02em; color:var(--ink-soft);
  background:var(--paper-2); border-bottom:1px solid var(--line-2) }
.cart-free .bar{ height:4px; border-radius:999px; background:#e2e0f2; margin-top:8px; overflow:hidden; align-self:stretch }
.cart-free .bar i{ display:block; height:100%; background:var(--gold); transition:width .4s ease }
.cart-free .free-ok{ color:var(--gold-deep); letter-spacing:.06em }
.cart-body{ flex:1; overflow:auto; padding:0 24px }
.cart-loading{ padding:40px 0; text-align:center; color:var(--muted) }
.cart-empty{ padding:60px 10px; text-align:center; color:var(--muted) } .cart-empty .btn{ margin-top:14px }
.ci{ display:grid; grid-template-columns:64px 1fr auto; gap:14px; padding:18px 0; border-bottom:1px solid var(--line-2) }
.ci-img img{ width:64px; height:64px; object-fit:contain; background:var(--paper-2); border-radius:9px; padding:6px }
.ci-name{ font-family:var(--serif); font-size:16px; line-height:1.25; color:var(--ink); display:block }
.ci-price{ font-size:12px; color:var(--muted); margin-top:3px }
.ci-was{ text-decoration:line-through; color:var(--muted); opacity:.8; margin-left:5px }
.ci-qty{ display:inline-flex; align-items:center; gap:0; margin-top:10px; border:1px solid var(--line); border-radius:999px; overflow:hidden }
.ci-qty button{ width:30px; height:30px; background:none; border:0; cursor:pointer; font-size:15px; color:var(--ink) }
.ci-qty button:hover{ background:var(--paper-2) } .ci-qty span{ min-width:26px; text-align:center; font-size:13px }
.ci-end{ text-align:right; display:flex; flex-direction:column; justify-content:space-between; align-items:flex-end }
.ci-line{ font-size:14px } .ci-rm{ background:none; border:0; cursor:pointer; font-size:11px; letter-spacing:.08em;
  text-transform:uppercase; color:var(--muted); text-decoration:underline; text-underline-offset:3px; padding:0 }
.ci-rm:hover{ color:var(--sale) }
.cart-foot{ flex:0 0 auto; padding:20px 24px 24px; border-top:1px solid var(--line); background:var(--paper) }
.cart-row{ display:flex; justify-content:space-between; padding:5px 0; font-size:14px; color:var(--ink-soft) }
.cart-row.cart-save{ color:var(--sale); font-weight:600 }
.cart-row.cart-save[hidden]{ display:none }
.cart-row.grand{ border-top:1px solid var(--line-2); margin-top:8px; padding-top:12px; color:var(--ink); font-size:16px }
.cart-row.grand span:last-child{ font-family:var(--serif); font-size:22px }
.cart-ap-wrap{ margin-top:14px }
.cart-ap-wrap[hidden]{ display:none }
.cart-ap{ min-height:44px }
.cart-ap-or{ display:flex; align-items:center; gap:12px; color:var(--muted); font-size:11px; text-transform:uppercase; letter-spacing:.14em; margin:10px 0 0 }
.cart-ap-or::before,.cart-ap-or::after{ content:""; flex:1; height:1px; background:var(--line-2) }
.cart-checkout{ display:flex; align-items:center; justify-content:center; gap:8px; text-align:center; width:100%; margin-top:12px }
.ship-note{ font-style:normal; font-size:10.5px; color:var(--muted); letter-spacing:0; white-space:nowrap }
/* yellow authenticity strip (carries the close button) + free-shipping strip — matched height */
.cart-trust{ position:relative; background:#fbe79a; color:#5b4a08; display:flex; align-items:center; justify-content:center;
  text-align:center; font-size:11.5px; font-weight:600; letter-spacing:.01em; padding:11px 40px; min-height:42px }
.cart-x{ position:absolute; right:10px; top:50%; transform:translateY(-50%); background:none; border:0; cursor:pointer;
  font-size:18px; line-height:1; color:#5b4a08; padding:4px 8px }
.cart-x:hover{ color:#000 }
/* secure-checkout trust block (single button kept above) */
.cart-secure{ margin-top:14px; text-align:center }
.cs-sub{ font-size:11.5px; color:var(--muted); letter-spacing:.04em; margin:0 0 10px }
.cs-pays{ display:flex; justify-content:center; gap:7px }
.cs-pays .pay{ height:26px; min-width:40px; padding:0 8px; box-shadow:0 1px 3px rgba(39,36,66,.12) }
.cs-pays .pay.mc i{ width:13px; height:13px }

/* profile row pinned to the bottom of the menu drawer (where region used to be) */
.drawer-acct-row{ margin-top:auto; border-top:1px solid var(--line-2); border-bottom:0 }

/* mobile: only the PROFILE moves into the menu drawer; region + bag stay top-right */
@media(max-width:960px){
  .acct-icon{ display:none }
  .utils{ gap:2px; margin-left:auto }
}

/* ============================================================
   Brands — professional A–Z index mega panel
   ============================================================ */
.panel-brands{ width:min(860px,92vw); min-width:0; padding:0; max-height:72vh; overflow:auto; text-align:left }
.brands-head{ display:flex; align-items:baseline; justify-content:space-between; padding:20px 26px 12px;
  position:sticky; top:0; background:var(--paper); z-index:2; border-bottom:1px solid var(--line-2) }
.brands-head .bh-title{ font-family:var(--serif); font-size:22px; color:var(--ink) }
.brands-head .bh-all{ font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep) }
.brands-index{ display:flex; flex-wrap:wrap; gap:4px; padding:14px 24px; position:sticky; top:53px;
  background:var(--paper); z-index:2; border-bottom:1px solid var(--line-2) }
.brands-index .bi{ width:26px; height:26px; display:flex; align-items:center; justify-content:center;
  font-size:11px; letter-spacing:.04em; border-radius:7px; color:#ccbfa8 }
.brands-index a.bi.on{ color:var(--ink); border:1px solid var(--line) }
.brands-index a.bi.on:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink) }
.brands-cols{ column-count:4; column-gap:30px; padding:18px 26px 24px }
.bgroup{ break-inside:avoid; margin-bottom:18px; scroll-margin-top:96px }
.bgroup h5{ font-family:var(--serif); font-size:20px; color:var(--gold-deep); margin:0 0 6px;
  border-bottom:1px solid var(--line-2); padding-bottom:4px }
.bgroup a{ display:block; padding:4px 0; font-size:13.5px; color:var(--ink-soft) }
.bgroup a:hover{ color:var(--gold-deep) }
@media(max-width:1100px){ .brands-cols{ column-count:3 } }

/* ============================================================
   All Brands directory page (/{loc}/brands)
   ============================================================ */
.brands-page{ max-width:1140px; margin:0 auto }
.bp-head{ text-align:center; padding:10px 0 4px }
.bp-head .eyebrow{ display:inline-block; font-size:11px; letter-spacing:.32em; text-transform:uppercase; color:var(--gold-deep); margin:0 0 8px }
.bp-head h1{ font-size:clamp(32px,5vw,52px); margin:0 0 8px; font-weight:600; letter-spacing:-.01em }
.bp-index{ display:flex; flex-wrap:wrap; gap:5px; justify-content:center; max-width:640px; margin:22px auto 8px;
  padding:14px; background:var(--paper); border:1px solid var(--line); border-radius:14px; box-shadow:0 18px 40px -34px rgba(60,45,20,.4) }
.bp-index a,.bp-index span{ width:30px; height:30px; display:flex; align-items:center; justify-content:center; font-size:12.5px; border-radius:8px }
.bp-index span{ color:#cdbfa6 }
.bp-index a{ color:var(--ink); border:1px solid var(--line); transition:.2s }
.bp-index a:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink) }
.bp-section{ scroll-margin-top:128px; margin:34px 0 }
.bp-letter{ font-size:30px; font-weight:600; color:var(--gold-deep); letter-spacing:.04em;
  border-bottom:1px solid var(--line); padding-bottom:10px; margin:0 0 20px }
.bp-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(168px,1fr)); gap:16px }
.brand-tile{ background:var(--paper); border:1px solid var(--line-2); border-radius:14px; padding:22px 18px;
  display:flex; flex-direction:column; align-items:center; gap:12px; text-align:center;
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s, border-color .35s }
.brand-tile:hover{ transform:translateY(-5px); box-shadow:0 26px 54px -38px rgba(60,45,20,.5); border-color:var(--line) }
.bt-logo{ height:66px; width:100%; display:flex; align-items:center; justify-content:center }
.bt-logo img{ max-height:66px; max-width:82%; object-fit:contain }
.bt-name{ font-size:13px; color:var(--ink-soft); letter-spacing:.02em; line-height:1.35 }
@media(max-width:600px){ .bp-grid{ grid-template-columns:repeat(auto-fill,minmax(118px,1fr)); gap:12px } .brand-tile{ padding:16px 12px } .bt-logo{ height:52px } .bt-logo img{ max-height:52px } }

/* ============================================================
   Auth / account / contact
   ============================================================ */
.auth-wrap{ max-width:460px; margin:48px auto; padding:0 16px }
.auth-card{ background:var(--paper); border:1px solid var(--line); border-radius:14px; padding:34px 30px }
.auth-card h1{ font-size:26px; margin:0 0 18px }
.auth-links{ display:flex; justify-content:space-between; gap:12px; margin-top:16px; font-size:13px }
.auth-links a{ color:var(--gold-deep) }
.flash{ padding:12px 14px; border-radius:10px; font-size:13.5px; margin-bottom:14px }
.flash.ok{ background:#eaf5ee; border:1px solid #0f8a5f; color:#0f6a49 }
.flash.err{ background:#fbeeea; border:1px solid var(--sale); color:#7a2b20 }
.grid2{ display:grid; grid-template-columns:1fr 1fr; gap:12px }
label.check{ display:flex; gap:8px; align-items:flex-start; text-transform:none; letter-spacing:0; font-size:13px; color:var(--ink-soft); margin:14px 0 }
label.check input{ margin-top:2px }
textarea.txt{ resize:vertical; font-family:var(--sans) }
.btn.btn-ghost{ background:transparent; border:1px solid var(--ink); color:var(--ink) }

.account{ max-width:1040px; margin:0 auto }
.acct-head h1{ font-size:30px; margin:0 0 4px }
.acct-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-top:18px }
.acct-box{ background:var(--paper); border:1px solid var(--line); border-radius:14px; padding:22px }
.acct-box h2{ font-size:20px; margin:0 0 14px }
.acct-box .btn{ margin-top:14px }
.acct-box:first-child{ grid-column:1 / -1 }   /* orders span full width */
.addr{ display:flex; justify-content:space-between; gap:12px; padding:12px 0; border-bottom:1px solid var(--line-2); font-size:13.5px }
.addr-add summary{ cursor:pointer; padding:12px 0; color:var(--gold-deep); font-size:13px; list-style:none }
.linkbtn{ background:none; border:0; color:var(--muted); cursor:pointer; text-decoration:underline; font-size:12px }
.stat{ padding:3px 10px; border-radius:999px; font-size:11px; letter-spacing:.06em; text-transform:uppercase }
.stat-paid{background:#e7f4ec;color:#0f8a5f}.stat-pending{background:#fdf3e4;color:#9a6b1f}
.stat-cancelled{background:#fbece9;color:#9a3b2e}.stat-fulfilled,.stat-processing{background:#eef0f6;color:#3b4a78}.stat-refunded{background:#f0eef6;color:#5b4a78}

.contact{ display:grid; grid-template-columns:1fr 1.5fr; gap:36px }
.contact-info{ list-style:none; padding:0; margin:18px 0 0 } .contact-info li{ margin-bottom:14px; font-size:14px; color:var(--ink-soft) }
@media(max-width:760px){ .acct-grid,.contact,.grid2{ grid-template-columns:1fr } .acct-box:first-child{ grid-column:auto } }
@media(max-width:680px){
  .tbl th,.tbl td{ padding:11px 10px; font-size:13px }
  .tbl img{ width:46px }
  .acct-head h1{ font-size:24px }
  .totals,.acct-box{ padding:18px }
}

/* mobile brands accordion — index-based directory */
.drawer-brands{ padding-bottom:14px }
.m-bindex{ display:flex; flex-wrap:wrap; gap:3px; padding:6px 2px 12px }
.m-bindex a,.m-bindex span{ width:24px; height:24px; display:flex; align-items:center; justify-content:center;
  font-size:11px; border-radius:6px }
.m-bindex span{ color:#ccbfa8 }
.m-bindex a{ color:var(--ink); border:1px solid var(--line) }
.m-ball{ display:block; padding:8px 12px; font-size:12px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--gold-deep); border-bottom:1px solid var(--line-2); margin-bottom:6px }
.m-bgroup{ scroll-margin-top:8px; padding:2px 0 6px }
.m-bgroup h6{ margin:8px 0 2px; font-size:13px; font-weight:600; color:var(--gold-deep); letter-spacing:.06em }
.m-bgroup a{ display:block; padding:7px 12px; font-size:14px; color:var(--ink-soft) }
