/* ============================================================================
   BabyRompers.in — Redesign layer (header, footer, homepage)
   Loaded after style.css. New components are namespaced `bx-` to avoid
   clashing with the existing 2.8k-line stylesheet.
   ========================================================================== */
:root{
  --bx-ink:#3E2723;
  --bx-ink-soft:#6E5A50;
  --bx-cream:#FDF8F0;
  --bx-cream-2:#F6EEE3;
  --bx-line:#ECE0D2;
  --bx-accent:#C17767;        /* terracotta — primary CTA */
  --bx-accent-dark:#A85C52;
  --bx-beige:#D4A574;
  --bx-sage:#9CAF88;
  --bx-amber:#D4A031;
  --bx-shadow-sm:0 2px 8px rgba(62,39,35,.06);
  --bx-shadow:0 10px 30px rgba(62,39,35,.10);
  --bx-shadow-lg:0 24px 60px rgba(62,39,35,.16);
  --bx-r:18px;
}
.bx-scope, .bx-home{ -webkit-font-smoothing:antialiased; }
.bx-home img{ display:block; }
.bx-container{ max-width:1240px; margin:0 auto; padding:0 24px; }
@media (max-width:600px){ .bx-container{ padding:0 16px; } }

/* ---- buttons ---- */
.bx-btn{ display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--font-body); font-weight:700; font-size:15px; line-height:1;
  padding:15px 28px; border-radius:100px; border:2px solid transparent; cursor:pointer;
  text-decoration:none; transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease; }
.bx-btn svg{ width:18px; height:18px; }
.bx-btn-primary{ background:var(--bx-accent); color:#fff; box-shadow:0 8px 20px rgba(193,119,103,.32); }
.bx-btn-primary:hover{ background:var(--bx-accent-dark); transform:translateY(-2px); box-shadow:0 12px 26px rgba(193,119,103,.42); }
.bx-btn-outline{ background:transparent; color:var(--bx-ink); border-color:var(--bx-line); }
.bx-btn-outline:hover{ border-color:var(--bx-beige); background:#fff; transform:translateY(-2px); }
.bx-btn-light{ background:#fff; color:var(--bx-ink); box-shadow:var(--bx-shadow-sm); }
.bx-btn-light:hover{ transform:translateY(-2px); box-shadow:var(--bx-shadow); }
.bx-btn-sm{ padding:11px 20px; font-size:13.5px; }

/* ============================================================================
   HEADER
   ========================================================================== */
.bx-header{ position:sticky; top:0; z-index:200; background:rgba(255,255,255,.92);
  backdrop-filter:saturate(140%) blur(10px); border-bottom:1px solid var(--bx-line); }
.bx-header-inner{ display:flex; align-items:center; gap:22px; height:74px; }
.bx-logo{ flex:0 0 auto; display:inline-flex; align-items:center; }
.bx-logo .logo-compact{ display:none; }
.bx-search{ flex:1 1 auto; max-width:520px; position:relative; }
.bx-search input{ width:100%; height:46px; border:1.5px solid var(--bx-line); background:var(--bx-cream);
  border-radius:100px; padding:0 50px 0 20px; font-family:var(--font-body); font-size:14.5px; color:var(--bx-ink);
  transition:border .15s, background .15s, box-shadow .15s; }
.bx-search input::placeholder{ color:#A89080; }
.bx-search input:focus{ outline:none; border-color:var(--bx-beige); background:#fff; box-shadow:0 0 0 4px rgba(212,165,116,.16); }
.bx-search button{ position:absolute; right:5px; top:5px; width:36px; height:36px; border:none; border-radius:50%;
  background:var(--bx-accent); color:#fff; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:background .15s; }
.bx-search button:hover{ background:var(--bx-accent-dark); }
.bx-header-actions{ flex:0 0 auto; display:flex; align-items:center; gap:6px; }
.bx-iconbtn{ width:44px; height:44px; border:none; background:transparent; border-radius:12px; color:var(--bx-ink);
  display:inline-flex; align-items:center; justify-content:center; cursor:pointer; text-decoration:none; position:relative; transition:background .15s, color .15s; }
.bx-iconbtn:hover{ background:var(--bx-cream-2); color:var(--bx-accent); }
.bx-iconbtn .bx-dot{ position:absolute; top:8px; right:9px; min-width:16px; height:16px; padding:0 4px; border-radius:10px;
  background:var(--bx-accent); color:#fff; font-size:10px; font-weight:800; display:flex; align-items:center; justify-content:center; }
.bx-header-mobile{ display:none; align-items:center; gap:2px; }

/* nav row */
.bx-navrow{ border-top:1px solid var(--bx-line); background:#fff; }
.bx-nav{ display:flex; align-items:center; justify-content:center; gap:30px; height:50px; }
.bx-nav a{ font-family:var(--font-body); font-size:14.5px; font-weight:600; color:var(--bx-ink-soft);
  text-decoration:none; letter-spacing:.1px; position:relative; display:inline-flex; align-items:center; gap:6px; height:100%; }
.bx-nav a:hover{ color:var(--bx-accent); }
.bx-nav a.is-hot{ color:var(--bx-accent); }
.bx-nav a::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:2px; background:var(--bx-accent);
  transform:scaleX(0); transition:transform .2s ease; border-radius:2px; }
.bx-nav a:hover::after{ transform:scaleX(1); }
.bx-nav .bx-megawrap{ position:relative; height:100%; display:flex; align-items:center; }
.bx-mega{ position:absolute; top:100%; left:50%; transform:translateX(-50%); width:680px;
  background:#fff; border:1px solid var(--bx-line); border-radius:16px; box-shadow:var(--bx-shadow-lg);
  padding:22px; display:grid; grid-template-columns:repeat(4,1fr); gap:18px; z-index:50; }
.bx-mega strong{ display:block; font-family:var(--font-body); font-size:11px; text-transform:uppercase; letter-spacing:1.2px; color:var(--bx-beige); margin-bottom:10px; }
.bx-mega a{ display:block; height:auto; font-size:13.5px; color:var(--bx-ink-soft); font-weight:500; padding:5px 0; }
.bx-mega a::after{ display:none; }
.bx-mega a:hover{ color:var(--bx-accent); padding-left:4px; transition:padding .15s; }

/* mobile drawer */
.bx-mobile-panel{ background:#fff; border-top:1px solid var(--bx-line); box-shadow:var(--bx-shadow); }
.bx-mobile-panel form{ display:flex; gap:8px; padding:14px 16px; }
.bx-mobile-panel form input{ flex:1; height:44px; border:1.5px solid var(--bx-line); border-radius:100px; padding:0 18px; font-size:14px; background:var(--bx-cream); }
.bx-mobile-nav{ padding:6px 8px 16px; }
.bx-mobile-nav a{ display:block; padding:13px 14px; border-radius:12px; text-decoration:none; color:var(--bx-ink); font-weight:600; font-size:15px; }
.bx-mobile-nav a:hover{ background:var(--bx-cream-2); color:var(--bx-accent); }
.bx-mobile-nav a.sub{ padding-left:28px; font-weight:500; color:var(--bx-ink-soft); font-size:14px; }

/* ============================================================================
   HERO
   ========================================================================== */
.bx-hero{ background:
   radial-gradient(1100px 520px at 88% -8%, #FCEFE0 0%, rgba(252,239,224,0) 60%),
   radial-gradient(900px 480px at 6% 110%, #EFF3E8 0%, rgba(239,243,232,0) 55%),
   var(--bx-cream); overflow:hidden; }
.bx-hero-inner{ display:grid; grid-template-columns:1.04fr .96fr; gap:54px; align-items:center;
  padding:70px 24px 76px; max-width:1240px; margin:0 auto; }
.bx-pill{ display:inline-flex; align-items:center; gap:8px; background:#fff; border:1px solid var(--bx-line);
  border-radius:100px; padding:8px 16px; font-size:13px; font-weight:700; color:var(--bx-accent); box-shadow:var(--bx-shadow-sm); }
.bx-pill .star{ color:var(--bx-amber); }
.bx-hero h1{ font-family:var(--font-display); font-weight:700; color:var(--bx-ink); letter-spacing:-1px;
  font-size:clamp(34px,4.6vw,58px); line-height:1.04; margin:20px 0 0; }
.bx-hero h1 em{ font-style:italic; color:var(--bx-accent); }
.bx-hero p.sub{ font-family:var(--font-body); font-size:clamp(15px,1.4vw,18px); line-height:1.65; color:var(--bx-ink-soft); margin:18px 0 0; max-width:520px; }
.bx-hero-ctas{ display:flex; flex-wrap:wrap; gap:14px; margin-top:30px; }
.bx-hero-trust{ display:flex; flex-wrap:wrap; gap:10px 22px; margin-top:30px; }
.bx-hero-trust span{ display:inline-flex; align-items:center; gap:8px; font-size:13.5px; font-weight:600; color:var(--bx-ink-soft); }
.bx-hero-trust svg{ color:var(--bx-sage); width:18px; height:18px; flex:0 0 auto; }

/* hero collage */
.bx-hero-art{ position:relative; min-height:480px; }
.bx-hero-main{ position:relative; width:84%; margin-left:auto; border-radius:28px; overflow:hidden;
  box-shadow:var(--bx-shadow-lg); aspect-ratio:11/13; background:#EAD6C2; }
.bx-hero-main img{ width:100%; height:100%; object-fit:cover; }
.bx-hero-blob{ position:absolute; inset:auto -6% 6% -8%; width:64%; aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle at 30% 30%, #F6D9BD, #E8B98A); filter:blur(2px); opacity:.5; z-index:0; }
.bx-float{ position:absolute; background:#fff; border-radius:18px; box-shadow:var(--bx-shadow-lg); overflow:hidden; z-index:3; }
.bx-float img{ width:100%; height:100%; object-fit:cover; }
.bx-float-1{ width:150px; aspect-ratio:1; left:-2%; top:14%; transform:rotate(-5deg); border:4px solid #fff; }
.bx-float-2{ width:128px; aspect-ratio:1; left:2%; bottom:6%; transform:rotate(4deg); border:4px solid #fff; }
.bx-chip{ position:absolute; z-index:4; background:#fff; border-radius:14px; box-shadow:var(--bx-shadow); padding:11px 14px; display:flex; align-items:center; gap:10px; }
.bx-chip-rating{ right:2%; top:6%; }
.bx-chip-rating .n{ font-family:var(--font-display); font-weight:800; font-size:20px; color:var(--bx-ink); line-height:1; }
.bx-chip-rating .s{ color:var(--bx-amber); font-size:12px; letter-spacing:1px; }
.bx-chip-rating .t{ font-size:11px; color:var(--bx-ink-soft); }
.bx-chip-price{ right:6%; bottom:13%; flex-direction:column; align-items:flex-start; gap:2px; }
.bx-chip-price .l{ font-size:10px; text-transform:uppercase; letter-spacing:1px; color:var(--bx-ink-soft); font-weight:700; }
.bx-chip-price .p{ font-family:var(--font-display); font-weight:800; font-size:18px; color:var(--bx-accent); }
.bx-hero-avatars{ display:flex; align-items:center; gap:12px; margin-top:30px; }
.bx-hero-avatars .stack{ display:flex; }
.bx-hero-avatars .stack span{ width:38px; height:38px; border-radius:50%; border:2.5px solid var(--bx-cream); margin-left:-12px;
  background-size:cover; background-position:center; box-shadow:var(--bx-shadow-sm); color:#fff; font-weight:700; font-size:13px; display:flex; align-items:center; justify-content:center; }
.bx-hero-avatars .stack span:first-child{ margin-left:0; }
.bx-hero-avatars small{ font-size:13px; color:var(--bx-ink-soft); }
.bx-hero-avatars small b{ color:var(--bx-ink); }

/* marquee strip under hero */
.bx-marquee{ background:var(--bx-ink); color:var(--bx-cream); overflow:hidden; }
.bx-marquee-track{ display:flex; gap:48px; padding:13px 0; white-space:nowrap; animation:bx-scroll 26s linear infinite; }
.bx-marquee span{ font-size:13.5px; font-weight:600; letter-spacing:.3px; display:inline-flex; align-items:center; gap:10px; opacity:.92; }
.bx-marquee .dot{ color:var(--bx-beige); }
@keyframes bx-scroll{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }

/* ============================================================================
   SECTIONS / HEADINGS
   ========================================================================== */
.bx-section{ padding:78px 0; }
.bx-section.alt{ background:var(--bx-cream-2); }
.bx-eyebrow{ font-family:var(--font-body); font-size:12px; font-weight:800; letter-spacing:2.4px; text-transform:uppercase; color:var(--bx-accent); }
.bx-section-head{ text-align:center; max-width:660px; margin:0 auto 46px; }
.bx-section-head h2{ font-family:var(--font-display); font-weight:700; color:var(--bx-ink); font-size:clamp(28px,3.2vw,42px); line-height:1.08; letter-spacing:-.6px; margin:12px 0 0; }
.bx-section-head p{ font-size:16px; line-height:1.6; color:var(--bx-ink-soft); margin:14px 0 0; }
.bx-head-row{ display:flex; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom:34px; }
.bx-head-row .l h2{ font-family:var(--font-display); font-weight:700; color:var(--bx-ink); font-size:clamp(26px,3vw,38px); margin:10px 0 0; letter-spacing:-.5px; }
.bx-head-row .l p{ color:var(--bx-ink-soft); margin:8px 0 0; font-size:15px; }
.bx-head-row .seeall{ color:var(--bx-accent); font-weight:700; text-decoration:none; font-size:14.5px; white-space:nowrap; display:inline-flex; align-items:center; gap:6px; }
.bx-head-row .seeall:hover{ gap:10px; transition:gap .15s; }

/* ---- trust strip ---- */
.bx-trust{ background:#fff; border-top:1px solid var(--bx-line); border-bottom:1px solid var(--bx-line); }
.bx-trust-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:8px; }
.bx-trust-item{ display:flex; align-items:center; gap:14px; padding:26px 18px; }
.bx-trust-item + .bx-trust-item{ border-left:1px solid var(--bx-line); }
.bx-trust-ic{ flex:0 0 auto; width:48px; height:48px; border-radius:14px; background:var(--bx-cream-2);
  display:flex; align-items:center; justify-content:center; color:var(--bx-accent); }
.bx-trust-ic svg{ width:24px; height:24px; }
.bx-trust-item h4{ font-family:var(--font-body); font-size:14.5px; font-weight:700; color:var(--bx-ink); margin:0 0 3px; }
.bx-trust-item p{ font-size:12.5px; color:var(--bx-ink-soft); margin:0; line-height:1.4; }

/* ---- age tiles ---- */
.bx-age-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.bx-age-card{ position:relative; display:block; border-radius:var(--bx-r); overflow:hidden; aspect-ratio:4/5;
  text-decoration:none; box-shadow:var(--bx-shadow-sm); transition:transform .25s ease, box-shadow .25s ease; }
.bx-age-card img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.bx-age-card::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(62,39,35,.72) 0%, rgba(62,39,35,.12) 48%, rgba(62,39,35,0) 72%); }
.bx-age-card:hover{ transform:translateY(-6px); box-shadow:var(--bx-shadow-lg); }
.bx-age-card:hover img{ transform:scale(1.06); }
.bx-age-meta{ position:absolute; left:18px; right:18px; bottom:16px; z-index:2; color:#fff; }
.bx-age-meta .t{ font-family:var(--font-display); font-weight:700; font-size:21px; line-height:1.1; }
.bx-age-meta .s{ font-size:12.5px; opacity:.9; margin-top:2px; display:inline-flex; align-items:center; gap:6px; }
.bx-age-meta .s svg{ width:13px; height:13px; }

/* ---- collection tiles (2 wide + small) ---- */
.bx-collection{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:22px; }
.bx-col-card{ position:relative; overflow:hidden; border-radius:var(--bx-r); display:block; text-decoration:none; box-shadow:var(--bx-shadow-sm); transition:transform .25s, box-shadow .25s; }
.bx-col-card img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.bx-col-card::after{ content:""; position:absolute; inset:0; background:linear-gradient(120deg, rgba(62,39,35,.55), rgba(62,39,35,0) 65%); }
.bx-col-card:hover{ transform:translateY(-5px); box-shadow:var(--bx-shadow-lg); }
.bx-col-card:hover img{ transform:scale(1.05); }
.bx-col-card .meta{ position:absolute; left:22px; top:22px; z-index:2; color:#fff; }
.bx-col-card .meta .t{ font-family:var(--font-display); font-weight:700; font-size:23px; }
.bx-col-card .meta .s{ font-size:13px; opacity:.92; margin-top:3px; }
.bx-col-card .shopnow{ position:absolute; left:22px; bottom:20px; z-index:2; color:#fff; font-weight:700; font-size:13.5px; display:inline-flex; align-items:center; gap:7px; }
.bx-col-tall{ grid-row:span 2; }
.bx-col-wide{ grid-column:span 2; }

/* ---- product grid (wraps render_product_card output) ---- */
.bx-products{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.bx-products .product-card{ box-shadow:var(--bx-shadow-sm)!important; border:1px solid var(--bx-line)!important; transition:transform .22s ease, box-shadow .22s ease; }
.bx-products .product-card:hover{ transform:translateY(-6px); box-shadow:var(--bx-shadow-lg)!important; }

/* ---- promise / fabric band ---- */
.bx-promise-inner{ display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center; }
.bx-promise-imgs{ position:relative; }
.bx-promise-imgs .big{ border-radius:22px; overflow:hidden; box-shadow:var(--bx-shadow-lg); aspect-ratio:7/5; }
.bx-promise-imgs .big img{ width:100%; height:100%; object-fit:cover; }
.bx-promise-imgs .small{ position:absolute; right:-14px; bottom:-26px; width:46%; border-radius:18px; overflow:hidden; border:5px solid #fff; box-shadow:var(--bx-shadow-lg); aspect-ratio:1; }
.bx-promise-imgs .small img{ width:100%; height:100%; object-fit:cover; }
.bx-promise h2{ font-family:var(--font-display); font-weight:700; font-size:clamp(26px,3vw,38px); color:var(--bx-ink); letter-spacing:-.5px; margin:12px 0 0; line-height:1.1; }
.bx-promise > .l > p{ color:var(--bx-ink-soft); font-size:16px; line-height:1.65; margin:16px 0 0; }
.bx-promise-list{ list-style:none; margin:24px 0 0; padding:0; display:grid; gap:14px; }
.bx-promise-list li{ display:flex; gap:13px; align-items:flex-start; }
.bx-promise-list .ic{ flex:0 0 auto; width:30px; height:30px; border-radius:9px; background:#EFF3E8; color:var(--bx-sage); display:flex; align-items:center; justify-content:center; }
.bx-promise-list .ic svg{ width:17px; height:17px; }
.bx-promise-list b{ color:var(--bx-ink); font-size:15px; }
.bx-promise-list span{ display:block; color:var(--bx-ink-soft); font-size:13.5px; margin-top:2px; }

/* ---- gifting band ---- */
.bx-gift{ position:relative; border-radius:26px; overflow:hidden; background:var(--bx-ink); color:var(--bx-cream); }
.bx-gift-inner{ display:grid; grid-template-columns:1.1fr .9fr; align-items:center; }
.bx-gift .copy{ padding:54px 50px; }
.bx-gift .copy h2{ font-family:var(--font-display); font-weight:700; font-size:clamp(28px,3vw,40px); line-height:1.08; margin:14px 0 0; color:#fff; }
.bx-gift .copy p{ color:rgba(253,248,240,.78); font-size:16px; line-height:1.6; margin:16px 0 26px; max-width:440px; }
.bx-gift .eyebrow-l{ color:var(--bx-beige); }
.bx-gift .photo{ position:relative; align-self:stretch; min-height:340px; }
.bx-gift .photo img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.bx-gift .priceline{ display:flex; align-items:baseline; gap:14px; margin-bottom:24px; }
.bx-gift .priceline .now{ font-family:var(--font-display); font-weight:800; font-size:34px; color:#fff; }
.bx-gift .priceline .was{ color:rgba(253,248,240,.5); text-decoration:line-through; }
.bx-gift .priceline .save{ background:var(--bx-accent); color:#fff; padding:4px 12px; border-radius:100px; font-size:12.5px; font-weight:800; }

/* ---- reviews ---- */
.bx-reviews-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.bx-review{ background:#fff; border:1px solid var(--bx-line); border-radius:var(--bx-r); padding:28px; box-shadow:var(--bx-shadow-sm); display:flex; flex-direction:column; }
.bx-review .stars{ color:var(--bx-amber); font-size:16px; letter-spacing:2px; }
.bx-review .vp{ font-size:11.5px; font-weight:700; color:var(--bx-sage); margin-left:auto; }
.bx-review .top{ display:flex; align-items:center; }
.bx-review p{ color:var(--bx-ink); font-size:15px; line-height:1.6; margin:16px 0 0; }
.bx-review .who{ display:flex; align-items:center; gap:12px; margin-top:22px; }
.bx-review .av{ width:44px; height:44px; border-radius:50%; color:#fff; font-weight:700; font-size:14px; display:flex; align-items:center; justify-content:center; flex:0 0 auto; }
.bx-review .who .n{ font-weight:700; color:var(--bx-ink); font-size:14px; }
.bx-review .who .loc{ font-size:12px; color:var(--bx-ink-soft); }
.bx-rating-summary{ display:flex; align-items:center; justify-content:center; gap:30px; flex-wrap:wrap; margin-top:40px;
  background:#fff; border:1px solid var(--bx-line); border-radius:var(--bx-r); padding:26px 34px; box-shadow:var(--bx-shadow-sm); }
.bx-rating-summary .big{ font-family:var(--font-display); font-weight:800; font-size:52px; color:var(--bx-ink); line-height:1; }
.bx-rating-summary .s{ color:var(--bx-amber); font-size:20px; letter-spacing:2px; }
.bx-rating-summary .muted{ color:var(--bx-ink-soft); font-size:14px; }
.bx-rating-summary .div{ width:1px; height:46px; background:var(--bx-line); }

/* ---- newsletter band ---- */
.bx-newsletter{ position:relative; overflow:hidden; border-radius:26px; min-height:340px; display:flex; align-items:center; }
.bx-newsletter img.bg{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.bx-newsletter::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(62,39,35,.86) 0%, rgba(62,39,35,.6) 50%, rgba(62,39,35,.28) 100%); }
.bx-newsletter .inner{ position:relative; z-index:2; padding:54px 50px; max-width:560px; color:#fff; }
.bx-newsletter h2{ font-family:var(--font-display); font-weight:700; font-size:clamp(26px,3vw,38px); line-height:1.1; margin:10px 0 0; color:#fff; }
.bx-newsletter p{ color:rgba(253,248,240,.85); margin:14px 0 24px; font-size:15.5px; line-height:1.6; }
.bx-news-form{ display:flex; gap:10px; flex-wrap:wrap; }
.bx-news-form input{ flex:1; min-width:220px; height:52px; border-radius:100px; border:none; padding:0 22px; font-size:15px; font-family:var(--font-body); }
.bx-news-form input:focus{ outline:none; box-shadow:0 0 0 4px rgba(212,165,116,.4); }
.bx-news-form .note{ width:100%; font-size:12px; color:rgba(253,248,240,.7); margin-top:4px; }

/* ============================================================================
   FOOTER
   ========================================================================== */
.bx-footer{ background:var(--bx-ink); color:var(--bx-cream); }
.bx-footer-top{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:40px; padding:64px 0 48px; }
.bx-footer .brand .tag{ color:rgba(253,248,240,.7); font-size:14px; line-height:1.6; margin:18px 0 22px; max-width:300px; }
.bx-footer .brand .socials{ display:flex; gap:10px; }
.bx-footer .brand .socials a{ width:40px; height:40px; border-radius:11px; background:rgba(255,255,255,.08); color:#fff;
  display:flex; align-items:center; justify-content:center; transition:background .15s, transform .15s; }
.bx-footer .brand .socials a:hover{ background:var(--bx-accent); transform:translateY(-2px); }
.bx-footer h3{ font-family:var(--font-body); font-size:12px; text-transform:uppercase; letter-spacing:1.5px; color:var(--bx-beige); margin:0 0 18px; }
.bx-footer ul{ list-style:none; margin:0; padding:0; display:grid; gap:11px; }
.bx-footer ul a{ color:rgba(253,248,240,.82); text-decoration:none; font-size:14px; transition:color .15s, padding .15s; }
.bx-footer ul a:hover{ color:#fff; padding-left:4px; }
.bx-footer-badges{ display:flex; flex-wrap:wrap; gap:10px; padding:6px 0 34px; }
.bx-footer-badges span{ display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08); border-radius:100px; padding:9px 16px; font-size:12.5px; font-weight:600; color:rgba(253,248,240,.86); }
.bx-footer-badges svg{ width:16px; height:16px; color:var(--bx-sage); }
.bx-footer-bottom{ border-top:1px solid rgba(255,255,255,.1); padding:22px 0; display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap; }
.bx-footer-bottom p{ margin:0; font-size:13px; color:rgba(253,248,240,.62); }
.bx-footer-pay{ display:flex; gap:10px; align-items:center; }

/* ============================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width:1024px){
  .bx-hero-inner{ grid-template-columns:1fr; gap:40px; padding:48px 24px 56px; }
  .bx-hero-art{ min-height:420px; max-width:520px; margin:0 auto; width:100%; }
  .bx-promise-inner{ grid-template-columns:1fr; gap:60px; }
  .bx-gift-inner{ grid-template-columns:1fr; }
  .bx-gift .photo{ min-height:240px; order:-1; }
  .bx-collection{ grid-auto-rows:180px; }
}
@media (max-width:860px){
  .bx-nav, .bx-search, .bx-header-actions .bx-hide-sm{ display:none; }
  .bx-header-mobile{ display:flex; }
  .bx-age-grid{ grid-template-columns:repeat(2,1fr); }
  .bx-products{ grid-template-columns:repeat(2,1fr); }
  .bx-trust-grid{ grid-template-columns:repeat(2,1fr); }
  .bx-trust-item:nth-child(3){ border-left:none; }
  .bx-trust-item{ border-top:1px solid var(--bx-line); }
  .bx-trust-item:nth-child(-n+2){ border-top:none; }
  .bx-reviews-grid{ grid-template-columns:1fr; }
  .bx-collection{ grid-template-columns:repeat(2,1fr); grid-auto-rows:170px; }
  .bx-col-wide{ grid-column:span 2; }
  .bx-footer-top{ grid-template-columns:1fr 1fr; gap:30px; }
}
@media (max-width:560px){
  .bx-section{ padding:54px 0; }
  .bx-hero h1{ font-size:clamp(30px,8vw,40px); }
  .bx-age-grid{ grid-template-columns:1fr 1fr; gap:14px; }
  .bx-products{ grid-template-columns:1fr 1fr; gap:14px; }
  .bx-collection{ grid-template-columns:1fr; grid-auto-rows:200px; }
  .bx-col-wide{ grid-column:span 1; }
  .bx-col-tall{ grid-row:span 1; }
  .bx-gift .copy{ padding:36px 26px; }
  .bx-newsletter .inner{ padding:36px 26px; }
  .bx-footer-top{ grid-template-columns:1fr; }
  .bx-head-row{ flex-direction:column; align-items:flex-start; gap:10px; }
}
