/* ═══════════════════════════════════════════════════════════
   BHI Landing v3 — Refined
   Fonts : Poppins (all weights — UI, body, and headlines)
   Colors: var(--blue-dark) (primary dark) · var(--blue-mid) (primary mid)
   ═══════════════════════════════════════════════════════════ */

/* ─────────────────── DESIGN TOKENS ─────────────────── */
:root {
  /* ── Brand blues ── */
  --blue-dark: #014785; /* primary dark navy */
  --blue-deeper: #013f78; /* deeper navy (gradients) */
  --blue-rich: #015fa8; /* mid-dark blue (gradients) */
  --blue-mid: #007fc6; /* primary accent blue */
  --blue-light: #e0f0fb; /* tinted bg / tulips bg */
  --blue-page: #eef5fd; /* page mesh bg start */

  /* ── Glass / alpha layers (used on dark hero) ── */
  --glass-2: rgba(255, 255, 255, 0.02);
  --glass-4: rgba(255, 255, 255, 0.04);
  --glass-5: rgba(255, 255, 255, 0.05);
  --glass-6: rgba(255, 255, 255, 0.06);
  --glass-8: rgba(255, 255, 255, 0.08);
  --glass-9: rgba(255, 255, 255, 0.09);
  --glass-10: rgba(255, 255, 255, 0.1);
  --glass-11: rgba(255, 255, 255, 0.11);
  --glass-12: rgba(255, 255, 255, 0.12);
  --glass-14: rgba(255, 255, 255, 0.14);
  --glass-16: rgba(255, 255, 255, 0.16);
  --glass-20: rgba(255, 255, 255, 0.2);
  --glass-24: rgba(255, 255, 255, 0.24);
  --glass-72: rgba(255, 255, 255, 0.72);
  --glass-82: rgba(255, 255, 255, 0.82);
  --glass-94: rgba(255, 255, 255, 0.94);
  --glass-95: rgba(255, 255, 255, 0.95);

  /* ── Glass borders ── */
  --glass-border-5: rgba(255, 255, 255, 0.05);
  --glass-border-8: rgba(255, 255, 255, 0.08);
  --glass-border-12: rgba(255, 255, 255, 0.12);
  --glass-border-14: rgba(255, 255, 255, 0.14);
  --glass-border-16: rgba(255, 255, 255, 0.16);
  --glass-border-18: rgba(255, 255, 255, 0.18);
  --glass-border-22: rgba(255, 255, 255, 0.22);
  --glass-border-28: rgba(255, 255, 255, 0.28);
  --glass-border-35: rgba(255, 255, 255, 0.35);
  --glass-border-50: rgba(255, 255, 255, 0.5);
  --glass-border-52: rgba(255, 255, 255, 0.52);
  --glass-border-60: rgba(255, 255, 255, 0.6);
  --glass-border-85: rgba(255, 255, 255, 0.85);
  --glass-border-90: rgba(255, 255, 255, 0.9);

  /* ── White text alpha (on dark sections) ── */
  --white-45: rgba(255, 255, 255, 0.45);
  --white-55: rgba(255, 255, 255, 0.55);
  --white-58: rgba(255, 255, 255, 0.58);
  --white-60: rgba(255, 255, 255, 0.6);
  --white-65: rgba(255, 255, 255, 0.65);
  --white-68: rgba(255, 255, 255, 0.68);
  --white-70: rgba(255, 255, 255, 0.7);
  --white-78: rgba(255, 255, 255, 0.78);

  /* ── Blue alpha (accent glows) ── */
  --blue-glass: rgba(0, 127, 198, 0.1);
  --blue-glow: rgba(0, 127, 198, 0.28);
  --blue-glow-2: rgba(0, 127, 198, 0.2);
  --blue-glow-22: rgba(0, 127, 198, 0.22);
  --blue-glow-45: rgba(0, 127, 198, 0.45);

  /* ── Navy alpha (shadows on light bg) ── */
  --navy-07: rgba(1, 71, 133, 0.07);
  --navy-09: rgba(1, 71, 133, 0.09);
  --navy-14: rgba(1, 71, 133, 0.14);
  --navy-18: rgba(1, 71, 133, 0.18);
  --navy-92: rgba(1, 71, 133, 0.92);
  --navy-50: rgba(0, 127, 198, 0.5); /* overlay mid at 50% */

  /* ── Black alpha ── */
  --black-14: rgba(0, 0, 0, 0.14);
  --black-18: rgba(0, 0, 0, 0.18);
  --black-20: rgba(0, 0, 0, 0.2);
  --black-25: rgba(0, 0, 0, 0.25);
  --black-30: rgba(0, 0, 0, 0.3);

  /* ── Neutral surfaces ── */
  --white: #ffffff;
  --off-white: #f4f7fb;
  --light-gray: #eaeff6;
  --border: #dce4ef;

  /* ── Text ── */
  --text-dark: #021d3a;
  --text-body: #415572;
  --text-muted: #8098b8;

  /* ── Brand accent colours ── */
  --wm: #c94f77; /* White Moon dark pink */
  --wm-light: #e8789e; /* White Moon light pink (hero cards) */
  --wm-bg: #fdf0f4;
  --bm: #d4920f; /* Baby Moon dark amber */
  --bm-light: #f0ab3c; /* Baby Moon light amber (hero cards) */
  --bm-bg: #fdf6e3;
  --tulips: #007fc6;
  --tulips-light: #7ec8f0; /* Tulips light blue (hero cards) */
  --tulips-bg: #e0f0fb;

  /* ── Radii ── */
  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 24px;
  --radius-xl: 36px;

  /* ── Shadows ── */
  --shadow-xs: 0 1px 4px var(--navy-07);
  --shadow-sm: 0 2px 12px var(--navy-09);
  --shadow-md: 0 8px 32px var(--navy-14);
  --shadow-lg: 0 20px 64px var(--navy-18);
  --shadow-glow: 0 6px 28px var(--blue-glow-45);

  /* ── Typography ── */
  --font-ui: "Poppins", system-ui, sans-serif;
  --font-serif: "Poppins", system-ui, sans-serif;

  /* ── Extra glass/alpha tokens ── */
  --glass-7: rgba(255, 255, 255, 0.07);
  --glass-15: rgba(255, 255, 255, 0.15);
  --glass-22: rgba(255, 255, 255, 0.22);
  --white-26: rgba(255, 255, 255, 0.26);
  --white-42: rgba(255, 255, 255, 0.42);
  --white-60: rgba(255, 255, 255, 0.6);
  --black-30: rgba(0, 0, 0, 0.3);
  --footer-bg: #030d1e;
  --blue-page-2: #f7faff;
  --blue-page-3: #edf4fb;

  /* ── Text shades (used throughout body copy) ── */
  --text-mid: #607a96; /* medium body text — between body and muted */
  --text-light: #8098b8; /* light muted text */
  --surface-2: #f7f9fc; /* light page surface (testimonials, cards) */

  /* ── Motion ── */
  --transition: 0.25s ease;
}

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
html {
  scroll-behavior: smooth;
  font-size: 16px;
}
img {
  display: block;
  max-width: 100%;
}
a {
  text-decoration: none;
  color: inherit;
}
ul {
  list-style: none;
}

body {
  font-family: var(--font-ui);
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.65;
  color: var(--text-dark);
  background: var(--white);
  -webkit-font-smoothing: antialiased;
}
h1,
h2,
h3 {
  font-family: var(--font-serif);
  font-weight: 800;
  line-height: 1.12;
  letter-spacing: -0.02em;
  color: var(--text-dark);
}
h4,
h5,
h6,
p,
span,
a,
li,
label,
button {
  font-family: var(--font-ui);
}
p {
  color: var(--text-body);
}

/* Subtle blue mesh only applies below the hero */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(
      ellipse 80% 55% at 75% 15%,
      var(--blue-glass) 0%,
      transparent 60%
    ),
    radial-gradient(
      ellipse 55% 45% at 10% 85%,
      var(--navy-07) 0%,
      transparent 55%
    ),
    linear-gradient(
      175deg,
      var(--blue-page) 0%,
      var(--blue-page-2) 45%,
      var(--blue-page-3) 100%
    );
  /* Hidden behind hero which has its own solid dark background */
}

/* ═══ NAVBAR — white glossy glass ═══ */
.navbar,
.navbar.navbar--gloss-white {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 200;
  isolation: isolate;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.99) 0%,
    rgba(255, 255, 255, 0.97) 42%,
    rgba(244, 249, 255, 0.95) 100%
  );
  backdrop-filter: blur(26px) saturate(220%);
  -webkit-backdrop-filter: blur(26px) saturate(220%);
  border-bottom: 1px solid rgba(255, 255, 255, 0.95);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.95) inset,
    0 2px 0 rgba(255, 255, 255, 0.45) inset,
    0 14px 48px -14px rgba(1, 71, 133, 0.14);
  transition:
    background var(--transition),
    border-color var(--transition),
    box-shadow var(--transition);
}
.navbar::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 42%;
  pointer-events: none;
  z-index: 0;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.55) 0%,
    rgba(255, 255, 255, 0) 100%
  );
  border-radius: 0 0 50% 50% / 0 0 28% 28%;
  opacity: 0.85;
}
.navbar::after {
  content: "";
  position: absolute;
  left: 8%;
  right: 8%;
  top: 0;
  height: 1px;
  pointer-events: none;
  z-index: 0;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255, 255, 255, 0.95) 35%,
    rgba(255, 255, 255, 0.55) 50%,
    rgba(255, 255, 255, 0.95) 65%,
    transparent 100%
  );
  opacity: 0.9;
}
.navbar.scrolled {
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 1) 0%,
    rgba(252, 254, 255, 0.99) 50%,
    rgba(238, 246, 255, 0.97) 100%
  );
  border-bottom: 1px solid rgba(1, 71, 133, 0.08);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 1) inset,
    0 2px 0 rgba(255, 255, 255, 0.5) inset,
    0 18px 50px -12px rgba(1, 71, 133, 0.18);
}
.nav-inner {
  position: relative;
  z-index: 1;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 36px;
  height: 72px;
  display: flex;
  align-items: center;
  gap: 36px;
}
.nav-logo img {
  height: 32px !important;
  width: auto;
  max-height: 32px;
}
.nav-links {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px 24px;
  margin-left: auto;
  justify-content: flex-end;
}
.nav-links-cluster {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px 24px;
}
.nav-links-cluster--split {
  padding-left: 20px;
  margin-left: 4px;
  border-left: 1px solid rgba(1, 71, 133, 0.12);
}
.nav-links a {
  font-family: var(--font-ui);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-body);
  letter-spacing: 0.01em;
  position: relative;
  transition: color var(--transition);
}
.nav-links a::after {
  content: "";
  position: absolute;
  bottom: -4px;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--blue-dark), var(--blue-mid));
  border-radius: 2px;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition);
}
.nav-links a:hover {
  color: var(--blue-dark);
}
.nav-links a:hover::after {
  transform: scaleX(1);
}
/* Active page link — persistent underline */
.nav-links a.active {
  color: var(--blue-dark);
  font-weight: 600;
}
.nav-links a.active::after {
  transform: scaleX(1);
}
.nav-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}
.nav-cart {
  font-family: var(--font-ui);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-dark);
  display: flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
  transition: color var(--transition);
}
.nav-cart:hover {
  color: var(--blue-mid);
}
.cart-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--blue-mid);
  color: var(--white);
  font-size: 0.7rem;
  font-weight: 700;
  min-width: 18px;
  height: 18px;
  border-radius: 50px;
  padding: 0 5px;
}
.btn-nav-cta {
  font-family: var(--font-ui);
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--white) !important;
  background: linear-gradient(
    135deg,
    var(--blue-dark) 0%,
    var(--blue-mid) 100%
  );
  padding: 10px 26px;
  border-radius: 50px;
  box-shadow: var(--shadow-glow);
  white-space: nowrap;
  transition:
    transform var(--transition),
    box-shadow var(--transition);
}
.btn-nav-cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 36px var(--blue-glow-45);
}
/* Auth/account nav buttons (Login, Register, Logout) */
.btn-nav-auth {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid rgba(1, 71, 133, 0.18);
  background: #fff;
  color: var(--blue-dark);
  font-size: 0.84rem;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.2s ease;
}
.btn-nav-auth:hover {
  border-color: var(--blue-mid);
  color: var(--blue-mid);
  background: #f4f9ff;
}
.btn-nav-auth--ghost {
  background: rgba(255, 255, 255, 0.92);
}
.btn-nav-auth--danger {
  border-color: rgba(185, 28, 28, 0.22);
  color: #b91c1c;
}
.btn-nav-auth--danger:hover {
  border-color: rgba(185, 28, 28, 0.35);
  background: #fff5f5;
  color: #991b1b;
}
.nav-links-cluster--mobile-auth {
  display: none;
}
.nav-toggle {
  display: none;
  background: none;
  border: none;
  font-size: 1.5rem;
  color: var(--text-dark);
  cursor: pointer;
}
.nav-hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 42px;
  height: 42px;
  padding: 0;
  border: 1px solid rgba(1, 71, 133, 0.12);
  border-radius: 12px;
  background: linear-gradient(
    165deg,
    rgba(255, 255, 255, 0.95) 0%,
    rgba(248, 252, 255, 0.75) 100%
  );
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.9) inset;
  cursor: pointer;
  transition:
    border-color 0.2s,
    box-shadow 0.2s;
}
.nav-hamburger span {
  display: block;
  width: 18px;
  height: 2px;
  margin: 0 auto;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--blue-dark), var(--blue-mid));
}
.nav-hamburger:hover {
  border-color: rgba(0, 127, 198, 0.28);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.95) inset,
    0 6px 18px rgba(1, 71, 133, 0.1);
}
.nav-links .nav-dropdown-toggle {
  font-family: var(--font-ui);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-body);
  letter-spacing: 0.01em;
  position: relative;
}
.nav-links .nav-dropdown-toggle::after {
  content: "";
  position: absolute;
  bottom: -4px;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--blue-dark), var(--blue-mid));
  border-radius: 2px;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition);
}
.nav-links .nav-dropdown-toggle:hover {
  color: var(--blue-dark);
}
.nav-links .nav-dropdown-toggle:hover::after {
  transform: scaleX(1);
}

/* ═══ HERO ═══ */
.hero {
  position: relative;
  min-height: 92vh;
  display: grid;
  grid-template-columns: 1.08fr 0.92fr;
  align-items: center;
  gap: 12px;
  overflow: hidden;
  background: linear-gradient(
    145deg,
    var(--blue-dark) 0%,
    var(--blue-deeper) 45%,
    var(--blue-rich) 75%,
    var(--blue-mid) 100%
  );
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(
      ellipse 60% 70% at 85% 50%,
      var(--blue-glow-22) 0%,
      transparent 65%
    ),
    radial-gradient(circle at 18% 28%, var(--glass-5) 0%, transparent 50%);
}

/* Decorative rings */
.hero-rings {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}
.h-ring {
  position: absolute;
  border-radius: 50%;
  top: 50%;
  left: 35%;
  transform: translate(-50%, -50%);
}
.h-ring-1 {
  width: 900px;
  height: 900px;
  border: 1px solid var(--glass-5);
}
.h-ring-2 {
  width: 640px;
  height: 640px;
  border: 1px solid var(--glass-8);
}
.h-ring-3 {
  width: 380px;
  height: 380px;
  border: 1px solid var(--glass-12);
}

/* Left column */
.hero-left {
  position: relative;
  z-index: 2;
  padding: 122px 56px 86px 56px;
  text-align: center;
}
.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-ui);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--white-65);
  background: var(--glass-10);
  border: 1px solid var(--glass-border-18);
  padding: 7px 18px;
  border-radius: 50px;
  margin: 0 auto 28px;
}
.hero-headline {
  font-family: var(--font-serif);
  font-size: clamp(2.6rem, 4.5vw, 3.9rem);
  font-weight: 700;
  color: var(--white);
  line-height: 1.07;
  margin: 0 auto 20px;
  max-width: min(640px, 100%);
  letter-spacing: -0.02em;
}
.hero-headline em {
  font-style: normal;
  color: var(--white);
}
.hero-sub {
  font-family: var(--font-ui);
  font-size: 1rem;
  font-weight: 400;
  color: var(--white-68);
  max-width: 500px;
  margin: 0 auto 36px;
  line-height: 1.78;
}
.hero-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin: 0 auto 40px;
  justify-content: center;
}

/* Buttons */
.btn-primary {
  font-family: var(--font-ui);
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--blue-dark);
  background: var(--white);
  padding: 14px 32px;
  border-radius: 50px;
  box-shadow: 0 4px 20px var(--black-18);
  display: inline-block;
  transition:
    transform var(--transition),
    box-shadow var(--transition),
    background var(--transition);
}
.btn-primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 32px var(--black-25);
  background: var(--off-white);
}
.btn-glass {
  font-family: var(--font-ui);
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--white);
  background: var(--glass-14);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid var(--glass-border-28);
  padding: 13px 28px;
  border-radius: 50px;
  display: inline-block;
  transition:
    background var(--transition),
    border-color var(--transition);
}
.btn-glass:hover {
  background: var(--glass-24);
  border-color: var(--glass-border-50);
}
.btn-ghost {
  font-family: var(--font-ui);
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--blue-dark);
  border: 2px solid var(--blue-dark);
  padding: 12px 28px;
  border-radius: 50px;
  display: inline-block;
  transition:
    background var(--transition),
    color var(--transition);
}
.btn-ghost:hover {
  background: var(--blue-dark);
  color: var(--white);
}

/* Hero stats */
.hero-stats {
  display: flex;
  gap: 0;
  margin-top: 16px;
  margin-bottom: 0;
  justify-content: center;
}
.hero-stat {
  padding-right: 28px;
  margin-right: 28px;
  text-align: left;
}
.hero-stat + .hero-stat {
  padding-left: 28px;
  border-left: 1px solid var(--glass-15);
}
.hero-stat strong {
  font-family: var(--font-serif);
  font-size: 2rem;
  font-weight: 700;
  color: var(--white);
  display: block;
  line-height: 1;
  margin-bottom: 5px;
}
.hero-stat span {
  font-family: var(--font-ui);
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--white-45);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

/* Brand pills */
.hero-brand-pills {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 14px;
  margin-bottom: 0;
}
.h-brand-pill {
  font-family: var(--font-ui);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--white-55);
  padding: 8px 18px;
  border: 1px solid var(--glass-14);
  border-radius: 50px;
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--glass-6);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  transition:
    background var(--transition),
    border-color var(--transition),
    color var(--transition);
}
.h-brand-pill:hover {
  background: var(--glass-14);
  border-color: var(--glass-border-35);
  color: var(--white);
}
.h-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.h-brand-pill .h-dot {
  background: var(--blue-light);
}
.h-brand-pill--white-moon .h-dot {
  background: var(--wm-light);
}
.h-brand-pill--baby-moon .h-dot {
  background: var(--bm-light);
}
.h-brand-pill--tulips .h-dot {
  background: var(--tulips-light);
}
.h-brand-pill--luna .h-dot {
  background: #6b21a8;
}

/* Right column — product cards */
.hero-right {
  position: relative;
  z-index: 2;
  padding: 110px 72px 86px 48px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 18px;
}
.hero-prod-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  width: min(100%, 380px);
}
.hero-prod-card {
  --brand-accent: var(--white-60);
  position: relative;
  overflow: hidden;
  border: 2px solid var(--brand-accent);
  border-radius: 18px;
  aspect-ratio: 1 / 1;
  transition:
    border-color var(--transition),
    transform var(--transition),
    box-shadow var(--transition);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.35);
}
.hero-prod-card img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 0.4s ease;
}
.hero-prod-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.45);
}
.hero-prod-card:hover img {
  transform: scale(1.06);
}
.hero-prod-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    transparent 40%,
    color-mix(in srgb, var(--brand-accent) 55%, transparent) 100%
  );
  pointer-events: none;
  border-radius: inherit;
}
.hero-prod-card--logo {
  background: var(--glass-94);
}
.hero-prod-card--logo img {
  object-fit: contain;
  padding: 18%;
}
.hero-prod-card--logo::after {
  content: none;
}
.hero-prod-wm {
  --brand-accent: var(--wm-light);
}
.hero-prod-bm {
  --brand-accent: var(--bm-light);
}
.hero-prod-tl {
  --brand-accent: var(--tulips-light);
}
.hero-prod-generic {
  --brand-accent: var(--blue-mid);
}
.hero-cert-badge {
  background: var(--glass-8);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid var(--glass-16);
  border-radius: 14px;
  padding: 16px 20px;
  display: flex;
  align-items: center;
  gap: 14px;
  width: min(100%, 360px);
}
.hero-cert-badge .cert-icon {
  font-size: 1.8rem;
  flex-shrink: 0;
}
.hero-cert-badge strong {
  font-family: var(--font-ui);
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--white);
  display: block;
  margin-bottom: 3px;
}
.hero-cert-badge span {
  font-family: var(--font-ui);
  font-size: 0.7rem;
  font-weight: 400;
  color: var(--white-45);
}

/* Scroll cue */
.hero-scroll-cue {
  position: absolute;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  font-family: var(--font-ui);
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--glass-border-28);
  animation: scrollBob 2.2s ease-in-out infinite;
  z-index: 2;
}
.hero-scroll-cue svg {
  opacity: 0.32;
}
@keyframes scrollBob {
  0%,
  100% {
    transform: translateX(-50%) translateY(0);
  }
  50% {
    transform: translateX(-50%) translateY(7px);
  }
}

/* ═══ STATS STRIP ═══ */
.stats-strip {
  background: linear-gradient(
    135deg,
    var(--blue-dark) 0%,
    var(--blue-rich) 55%,
    var(--blue-mid) 100%
  );
  padding: 36px 0;
  position: relative;
  overflow: hidden;
}
.stats-strip::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(
    circle at 50% 50%,
    var(--glass-4) 1px,
    transparent 1px
  );
  background-size: 32px 32px;
}
.stats-inner {
  position: relative;
  max-width: 960px;
  margin: 0 auto;
  padding: 0 36px;
  display: flex;
  align-items: center;
  justify-content: space-around;
  gap: 20px;
}
.stat {
  text-align: center;
  color: white;
}
.stat strong {
  display: block;
  font-family: var(--font-serif);
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 5px;
  letter-spacing: -0.02em;
}
.stat span {
  font-family: var(--font-ui);
  font-size: 0.72rem;
  font-weight: 500;
  opacity: 0.65;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.stat-divider {
  width: 1px;
  height: 44px;
  background: var(--glass-20);
  flex-shrink: 0;
}

/* ═══ SECTION HELPERS ═══ */
.section-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 36px;
}
.section-label {
  font-family: var(--font-ui);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--blue-mid);
  margin-bottom: 12px;
}
.section-label.light {
  color: var(--white-60);
}
.section-title {
  font-family: var(--font-serif);
  font-size: clamp(1.9rem, 3.5vw, 2.6rem);
  font-weight: 700;
  color: var(--text-dark);
  margin-bottom: 16px;
  letter-spacing: -0.01em;
}
.section-title.light {
  color: white;
}
.section-title em {
  font-style: italic;
  color: var(--blue-mid);
}
.section-sub {
  font-family: var(--font-ui);
  font-size: 0.97rem;
  font-weight: 400;
  color: var(--text-body);
  max-width: 540px;
  margin-bottom: 48px;
  line-height: 1.78;
}

/* ═══ GLOBAL UTILITY HELPERS ═══ */
/* Spacing — mirrors Bootstrap scale so existing markup keeps working */
.mt-1 {
  margin-top: 0.25rem;
}
.mt-2 {
  margin-top: 0.5rem;
}
.mt-3 {
  margin-top: 1rem;
}
.mt-4 {
  margin-top: 1.5rem;
}
.mb-0 {
  margin-bottom: 0 !important;
}
.mb-1 {
  margin-bottom: 0.25rem;
}
.mb-2 {
  margin-bottom: 0.5rem;
}
.mb-3 {
  margin-bottom: 1rem;
}
.mb-4 {
  margin-bottom: 1.5rem;
}
.ms-2 {
  margin-left: 0.5rem;
}
/* Text helpers */
.text-muted {
  color: var(--text-muted);
}
.text-center {
  text-align: center;
}
.text-dark {
  color: var(--text-dark);
}
.small {
  font-size: 0.875rem;
  line-height: 1.5;
}
/* Display helpers */
.d-block {
  display: block !important;
}
/* Heading scale utilities */
.h4 {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--text-dark);
  line-height: 1.3;
}
.h5 {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text-dark);
  line-height: 1.35;
}
/* Section label / body typography */
.section-heading {
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--text-dark);
  line-height: 1.3;
  margin-bottom: 8px;
}
.section-body {
  font-size: 0.95rem;
  color: var(--text-body);
  line-height: 1.65;
}
.section-eyebrow {
  display: block;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--blue-mid);
  margin-bottom: 10px;
}
/* simple-card width modifiers */
.simple-card--sm {
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}
.simple-card--md {
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}
.simple-card--lg {
  max-width: 980px;
  margin-left: auto;
  margin-right: auto;
}

/* ═══ INTRO / ABOUT SECTION ═══ */
.intro-section {
  padding: 80px 0;
  background: var(--white);
}
.intro-section .section-sub {
  max-width: 780px;
  margin-bottom: 12px;
}
.intro-cards-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 40px;
  align-items: start;
}
.intro-expertise-card,
.intro-tulips-card {
  background: var(--off-white);
  border: 1px solid var(--glass-10);
  border-radius: 16px;
  padding: 28px 30px;
}
.intro-card-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: var(--blue-dark);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
}
.intro-card-icon i {
  font-size: 1.1rem;
  color: var(--white);
}
.intro-expertise-card h4,
.intro-tulips-card h4 {
  font-family: var(--font-serif);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--blue-dark);
  margin-bottom: 10px;
}
.intro-expertise-card p,
.intro-tulips-card p {
  color: var(--text-mid);
  font-size: 0.92rem;
  line-height: 1.7;
  margin-bottom: 14px;
}
.intro-expertise-card h5 {
  font-family: var(--font-ui);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 10px;
  margin-top: 4px;
}
.intro-industries-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.intro-industries-list li {
  font-size: 0.9rem;
  color: var(--text-mid);
  display: flex;
  align-items: center;
  gap: 8px;
}
.intro-industries-list li i {
  font-size: 0.7rem;
  color: var(--blue-mid);
  flex-shrink: 0;
}
/* Tulips card */
.intro-tulips-card {
  border-left: 3px solid var(--tulips-light, #3b82f6);
}
.intro-tulips-card-top {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 14px;
}
.intro-tulips-img {
  width: 64px;
  height: 64px;
  object-fit: contain;
  border-radius: 10px;
  background: rgba(59, 130, 246, 0.06);
  padding: 6px;
  flex-shrink: 0;
}
.intro-tulips-card-text {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.intro-tulips-badge {
  display: inline-block;
  font-family: var(--font-ui);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--tulips-light, #3b82f6);
  background: rgba(59, 130, 246, 0.08);
  border: 1px solid rgba(59, 130, 246, 0.18);
  border-radius: 50px;
  padding: 4px 12px;
  width: fit-content;
}
.intro-tulips-stat {
  display: flex;
  align-items: baseline;
  gap: 10px;
  background: rgba(59, 130, 246, 0.06);
  border-radius: 10px;
  padding: 12px 16px;
  margin-top: 4px;
}
.intro-tulips-stat-value {
  font-family: var(--font-serif);
  font-size: 1.8rem;
  font-weight: 800;
  color: var(--tulips-light, #3b82f6);
  line-height: 1;
}
.intro-tulips-stat-label {
  font-family: var(--font-ui);
  font-size: 0.78rem;
  color: var(--text-mid);
  line-height: 1.4;
}
@media (max-width: 768px) {
  .intro-cards-row {
    grid-template-columns: 1fr;
  }
  .intro-section {
    padding: 56px 0;
  }
}

/* ═══ BRANDS SECTION ═══ */
.brands-section {
  padding: 100px 0;
  background: var(--off-white);
  position: relative;
}
.brands-section::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(
    90deg,
    var(--blue-dark),
    var(--blue-mid),
    var(--blue-dark)
  );
}
.brands-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 48px;
}
.brand-card {
  background: var(--glass-82);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-radius: var(--radius-lg);
  padding: 32px 28px;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--glass-border-90);
  position: relative;
  overflow: hidden;
  transition:
    transform var(--transition),
    box-shadow var(--transition);
}
.brand-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.brand-wm::before {
  background: var(--wm);
}
.brand-tulips::before {
  background: linear-gradient(90deg, var(--blue-dark), var(--blue-mid));
}
.brand-bm::before {
  background: var(--bm);
}
.brand-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-md);
}
.brand-logo-wrap {
  width: calc(100% + 56px);
  margin: -32px -28px 24px;
  height: 120px;
  overflow: hidden;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.brand-logo-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: left center;
  display: block;
}
.brand-logo-img--tulips {
  object-position: left center;
}
.brand-logo-img--bm {
  object-position: right center;
}
.brand-card-top {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 20px;
}
.brand-icon {
  width: 52px;
  height: 52px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  flex-shrink: 0;
}
.wm-icon {
  background: var(--wm-bg);
  color: var(--wm);
}
.tulips-icon {
  background: var(--tulips-bg);
  color: var(--tulips);
}
.bm-icon {
  background: var(--bm-bg);
  color: var(--bm);
}
.brand-name {
  font-family: var(--font-ui);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--text-dark);
  margin-bottom: 2px;
}
.brand-tagline {
  font-family: var(--font-ui);
  font-size: 0.76rem;
  font-weight: 500;
  color: var(--text-muted);
}
.brand-desc {
  font-family: var(--font-ui);
  font-size: 0.87rem;
  font-weight: 400;
  color: var(--text-body);
  line-height: 1.7;
  margin-bottom: 20px;
}
.brand-products {
  margin-bottom: 24px;
}
.brand-products li {
  font-family: var(--font-ui);
  font-size: 0.82rem;
  font-weight: 400;
  color: var(--text-body);
  padding: 6px 0;
  border-bottom: 1px solid var(--light-gray);
  display: flex;
  align-items: center;
  gap: 8px;
}
.brand-products li::before {
  content: "\2192";
  font-size: 0.7rem;
  flex-shrink: 0;
}
.brand-wm .brand-products li::before {
  color: var(--wm);
}
.brand-tulips .brand-products li::before {
  color: var(--blue-mid);
}
.brand-bm .brand-products li::before {
  color: var(--bm);
}
.brand-link {
  font-family: var(--font-ui);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  display: inline-block;
  transition: letter-spacing var(--transition);
}
.brand-link:hover {
  letter-spacing: 0.06em;
}
.wm-link {
  color: var(--wm);
}
.tulips-link {
  color: var(--blue-mid);
}
.bm-link {
  color: var(--bm);
}

/* ═══ HOME FEATURED PRODUCTS ═══ */
.products-section {
  padding: 100px 0;
  background: linear-gradient(
    180deg,
    var(--white) 0%,
    #f2f7fc 42%,
    var(--white) 100%
  );
}
.home-products-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 24px;
  align-items: stretch;
}
.home-product-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 440px;
  text-decoration: none;
  color: inherit;
  background: var(--white);
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: 0 6px 22px var(--navy-07);
  transition:
    transform 0.28s ease,
    box-shadow 0.28s ease;
  position: relative;
}
.home-product-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--blue-mid);
  z-index: 1;
}
.home-product-card[data-brand="white-moon"]::before {
  background: var(--wm);
}
.home-product-card[data-brand="baby-moon"]::before {
  background: var(--bm);
}
.home-product-card[data-brand="tulips"]::before {
  background: var(--blue-mid);
}
.home-product-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 40px var(--navy-14);
}
.home-product-card:focus-visible {
  outline: 3px solid var(--blue-mid);
  outline-offset: 3px;
}
.home-product-card__media {
  flex-shrink: 0;
  height: 200px;
  min-height: 200px;
  max-height: 200px;
  box-sizing: border-box;
  background: linear-gradient(165deg, #e8f1fa 0%, #fafcfe 55%, #fff 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}
.home-product-card__media img {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  object-position: center;
  transition: transform 0.38s ease;
}
.home-product-card:hover .home-product-card__media img {
  transform: scale(1.06);
}
.home-product-card__body {
  padding: 18px 18px 20px;
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: 0;
  gap: 8px;
}
.home-product-card__brand {
  font-family: var(--font-ui);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: var(--blue-mid);
  align-self: flex-start;
  padding: 5px 11px;
  border-radius: 999px;
  background: var(--blue-light);
  min-height: 26px;
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.home-product-card__brand-logo {
  width: 18px;
  height: 18px;
  object-fit: contain;
  flex-shrink: 0;
}
.home-product-card__brand-text {
  line-height: 1.2;
}
.home-product-card[data-brand="white-moon"] .home-product-card__brand {
  background: var(--wm-bg);
  color: var(--wm);
}
.home-product-card[data-brand="baby-moon"] .home-product-card__brand {
  background: var(--bm-bg);
  color: var(--bm);
}
.home-product-card__brand--placeholder {
  visibility: hidden;
  pointer-events: none;
  background: transparent !important;
  color: transparent !important;
}
.home-product-card__title {
  font-family: var(--font-ui);
  font-size: 1.06rem;
  font-weight: 700;
  color: var(--blue-dark);
  line-height: 1.28;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: calc(1.06rem * 1.28 * 2);
}
.home-product-card__desc {
  font-family: var(--font-ui);
  font-size: 0.82rem;
  color: #55687a;
  line-height: 1.52;
  margin: 0;
  flex: 1 1 auto;
  min-height: calc(0.82rem * 1.52 * 2);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.home-product-card__meta {
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid rgba(1, 71, 133, 0.09);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.home-product-card__price {
  font-family: var(--font-ui);
  font-weight: 700;
  font-size: 0.96rem;
  color: var(--blue-dark);
}
.home-product-card__cta {
  font-family: var(--font-ui);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--blue-mid);
  flex-shrink: 0;
}
.home-product-card:hover .home-product-card__cta {
  color: var(--blue-dark);
}

/* ═══ WHY BHI ═══ */
.why-section {
  background: linear-gradient(
    140deg,
    var(--blue-dark) 0%,
    var(--blue-deeper) 50%,
    var(--blue-rich) 100%
  );
  padding: 100px 0;
  position: relative;
  overflow: hidden;
}
.why-section::after {
  content: "";
  position: absolute;
  bottom: -80px;
  right: -80px;
  width: 420px;
  height: 420px;
  background: radial-gradient(circle, var(--blue-glow-2) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}
.why-inner {
  position: relative;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 36px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}
.why-desc {
  font-family: var(--font-ui);
  font-size: 0.97rem;
  font-weight: 400;
  color: var(--white-70);
  line-height: 1.8;
  margin-bottom: 40px;
  max-width: 480px;
}
.why-features {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.why-feat {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  background: var(--glass-6);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid var(--glass-12);
  border-radius: var(--radius-md);
  padding: 18px 20px;
  transition:
    background var(--transition),
    border-color var(--transition);
}
.why-feat:hover {
  background: var(--glass-11);
  border-color: var(--glass-22);
}
.why-feat-icon {
  font-size: 1.4rem;
  flex-shrink: 0;
  margin-top: 2px;
}
.why-feat h4 {
  font-family: var(--font-ui);
  font-size: 0.93rem;
  font-weight: 600;
  color: white;
  margin-bottom: 4px;
  letter-spacing: 0.01em;
}
.why-feat p {
  font-family: var(--font-ui);
  font-size: 0.82rem;
  font-weight: 400;
  color: var(--white-58);
  line-height: 1.55;
}
.why-visual {
  position: relative;
}
.why-img-wrap {
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--glass-12);
}
.why-img-wrap img {
  width: 100%;
  height: 420px;
  object-fit: cover;
}
.why-cert-card {
  position: absolute;
  bottom: -20px;
  left: -24px;
  background: var(--glass-95);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-radius: var(--radius-md);
  padding: 16px 20px;
  display: flex;
  align-items: center;
  gap: 14px;
  box-shadow: var(--shadow-md);
  border: 1px solid var(--glass-border-85);
}
.cert-icon {
  font-size: 1.6rem;
}
.why-cert-card strong {
  font-family: var(--font-ui);
  display: block;
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--text-dark);
  margin-bottom: 2px;
}
.why-cert-card span {
  font-family: var(--font-ui);
  font-size: 0.7rem;
  font-weight: 400;
  color: var(--text-muted);
  line-height: 1.4;
  max-width: 180px;
  display: block;
}

/* ═══ HOME STORY — sticky-scroll brand storytelling ═══ */
.home-story {
  --story-count: 4;
  position: relative;
  width: 100%;
  background: linear-gradient(180deg, #f5f9fd 0%, #ffffff 100%);
}
.home-story__scroll {
  position: relative;
  /* Tall enough to give each panel its own viewport-worth of scroll */
  height: calc(100vh * var(--story-count));
}
.home-story__sticky {
  position: sticky;
  top: 0;
  height: 100vh;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.home-story__stage {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 5vw, 96px);
  align-items: center;
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0 clamp(32px, 6vw, 96px);
  box-sizing: border-box;
}

/* Media column (left) — visuals crossfade */
.home-story__media {
  position: relative;
  aspect-ratio: 4 / 5;
  max-height: 78vh;
  border-radius: 28px;
  overflow: hidden;
  box-shadow: 0 32px 80px rgba(1, 71, 133, 0.2);
  background: #f0f6fc;
}
.home-story__visual {
  position: absolute;
  inset: 0;
  opacity: 0;
  visibility: hidden;
  transform: scale(1.04);
  transition:
    opacity 600ms ease,
    transform 800ms ease,
    visibility 0s linear 600ms;
}
.home-story__visual.is-active {
  opacity: 1;
  visibility: visible;
  transform: scale(1);
  transition:
    opacity 600ms ease,
    transform 800ms ease,
    visibility 0s linear 0s;
}
.home-story__visual--navy {
  background: linear-gradient(
    145deg,
    var(--blue-dark) 0%,
    var(--blue-rich) 100%
  );
}
.home-story__visual--light {
  background: linear-gradient(145deg, #ffffff 0%, #eaf3fb 100%);
}
.home-story__visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Content column (right) — panels crossfade in place */
.home-story__content {
  position: relative;
  min-height: 480px;
  display: flex;
  align-items: center;
}
.home-story__panel {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 22px;
  max-width: 560px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(20px);
  transition:
    opacity 500ms ease,
    transform 600ms ease,
    visibility 0s linear 500ms;
  pointer-events: none;
}
.home-story__panel.is-active {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  transition:
    opacity 500ms ease,
    transform 600ms ease,
    visibility 0s linear 0s;
  pointer-events: auto;
}
.home-story__label {
  display: inline-block;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--blue-mid);
}
.home-story__panel--navy .home-story__label {
  color: var(--blue-rich);
}
.home-story__title {
  margin: 0;
  font-size: clamp(2rem, 3.4vw, 3.4rem);
  line-height: 1.05;
  font-weight: 800;
  letter-spacing: -0.01em;
  color: var(--blue-dark);
}
.home-story__desc {
  margin: 0;
  max-width: 540px;
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--text-muted, #46556a);
}
.home-story__cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: fit-content;
  margin-top: 4px;
}
.home-story__cta span {
  transition: transform 220ms ease;
}
.home-story__cta:hover span {
  transform: translateX(4px);
}

/* Per-panel inline image — hidden on desktop, shown on mobile */
.home-story__panel-img {
  display: none;
}

/* Invisible scroll triggers stack within the tall scroll area */
.home-story__trigger {
  height: 100vh;
  width: 1px;
  pointer-events: none;
}

/* Dot navigation — anchored to sticky inner, bottom center */
.home-story__dots {
  position: absolute;
  bottom: clamp(20px, 4vh, 48px);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 12px;
  z-index: 5;
}
.home-story__dot {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  padding: 0;
  border-radius: 999px;
  background: rgba(1, 71, 133, 0.22);
  border: 2px solid transparent;
  cursor: pointer;
  transition:
    width 260ms ease,
    height 260ms ease,
    background 260ms ease,
    border-color 260ms ease;
}
.home-story__dot:hover {
  background: rgba(1, 71, 133, 0.5);
}
.home-story__dot.is-active {
  width: 38px;
  height: 38px;
  background: var(--blue-dark);
  border-color: rgba(255, 255, 255, 0.95);
  box-shadow: 0 6px 18px rgba(1, 71, 133, 0.3);
}
.home-story__dot-index {
  position: absolute;
  font-size: 0.72rem;
  font-weight: 700;
  color: #fff;
  opacity: 0;
  transition: opacity 200ms ease;
}
.home-story__dot.is-active .home-story__dot-index {
  opacity: 1;
}

/* ─── Mobile ─── */
@media (max-width: 980px) {
  .home-story__scroll {
    height: auto;
  }
  .home-story__sticky {
    position: relative;
    top: auto;
    height: auto;
    display: block;
    padding: 48px 0 24px;
    overflow: visible;
  }
  .home-story__stage {
    grid-template-columns: 1fr;
    gap: 0;
    padding: 0 18px;
  }
  .home-story__media {
    display: none;
  }
  .home-story__content {
    min-height: auto;
    display: flex;
    flex-direction: column;
    gap: 36px;
  }
  .home-story__panel {
    position: relative;
    inset: auto;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
    max-width: none;
    width: 100%;
    opacity: 1;
    visibility: visible;
    transform: none;
    pointer-events: auto;
    padding: 18px;
    background: #ffffff;
    border-radius: 22px;
    box-shadow: 0 18px 40px rgba(1, 71, 133, 0.1);
  }
  .home-story__panel--navy {
    background: linear-gradient(
      160deg,
      var(--blue-dark) 0%,
      var(--blue-rich) 100%
    );
    box-shadow: 0 20px 48px rgba(1, 71, 133, 0.28);
  }
  .home-story__panel--navy .home-story__title,
  .home-story__panel--navy .home-story__desc,
  .home-story__panel--navy .home-story__label {
    color: #ffffff;
  }
  .home-story__panel--navy .home-story__label {
    color: rgba(255, 255, 255, 0.78);
  }
  .home-story__panel-img {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    border-radius: 16px;
    margin-bottom: 4px;
    background: #f0f6fc;
  }
  .home-story__title {
    font-size: clamp(1.6rem, 6vw, 2.1rem);
  }
  .home-story__desc {
    font-size: 0.98rem;
    line-height: 1.65;
  }
  .home-story__trigger {
    display: none;
  }
  .home-story__dots {
    display: none;
  }
}

/* ═══ HOME BRAND SPLITS (two column, like Why BHI) ═══ */
.home-split-section {
  padding: 100px 0;
  position: relative;
  overflow: hidden;
}
.home-split-section--navy {
  background: linear-gradient(
    140deg,
    var(--blue-dark) 0%,
    var(--blue-deeper) 50%,
    var(--blue-rich) 100%
  );
}
.home-split-section--navy::after {
  content: "";
  position: absolute;
  bottom: -80px;
  right: -80px;
  width: 420px;
  height: 420px;
  background: radial-gradient(circle, var(--blue-glow-2) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}
.home-split-section--light {
  background: linear-gradient(180deg, #f5f9fd 0%, #ffffff 55%, #f8fbff 100%);
  border-top: 1px solid rgba(1, 71, 133, 0.07);
  border-bottom: 1px solid rgba(1, 71, 133, 0.07);
}
.home-split-inner {
  position: relative;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 36px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
  z-index: 1;
}
.home-split-text {
  min-width: 0;
}
@media (min-width: 981px) {
  .home-split-section--reverse .home-split-text {
    order: 2;
  }
  .home-split-section--reverse .home-split-visual {
    order: 1;
  }
}
.home-split-desc {
  font-family: var(--font-ui);
  font-size: 0.97rem;
  font-weight: 400;
  color: var(--white-70);
  line-height: 1.8;
  margin-bottom: 8px;
  max-width: 520px;
}
.home-split-desc--muted {
  color: var(--text-muted);
}
.home-split-cta {
  margin-top: 28px;
}
.home-split-visual {
  position: relative;
}
.home-split-img-wrap {
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--glass-12);
}
.home-split-section--light .home-split-img-wrap {
  border: 1px solid rgba(1, 71, 133, 0.1);
  box-shadow:
    0 22px 48px -24px rgba(1, 71, 133, 0.22),
    0 6px 16px -8px rgba(1, 71, 133, 0.12);
}
.home-split-img-wrap img {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  display: block;
}
@media (max-width: 980px) {
  .home-split-img-wrap img {
    aspect-ratio: 4 / 5;
    max-height: 78vh;
  }
}
.home-split-cert.why-cert-card {
  left: auto;
  right: -12px;
}
.home-split-section--reverse .home-split-cert.why-cert-card {
  right: auto;
  left: -24px;
}

/* ═══ HOME PILLARS ═══ */
.home-pillars-section {
  padding: 88px 0 96px;
  background: white;
}
.home-pillars-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin-top: 40px;
}
.home-pillar-card {
  background: linear-gradient(
    160deg,
    rgba(248, 252, 255, 0.95) 0%,
    rgba(255, 255, 255, 0.98) 100%
  );
  border: 1px solid rgba(1, 71, 133, 0.08);
  border-radius: var(--radius-md);
  padding: 28px 26px 30px;
  box-shadow: 0 14px 36px -22px rgba(1, 71, 133, 0.2);
  transition:
    box-shadow var(--transition),
    border-color var(--transition);
}
.home-pillar-card:hover {
  border-color: rgba(1, 71, 133, 0.14);
  box-shadow: 0 20px 44px -22px rgba(1, 71, 133, 0.22);
}
.home-pillar-icon {
  font-size: 2rem;
  line-height: 1;
  margin-bottom: 14px;
}
.home-pillar-title {
  font-family: var(--font-ui);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text-dark);
  margin-bottom: 10px;
  letter-spacing: 0.01em;
}
.home-pillar-desc {
  font-family: var(--font-ui);
  font-size: 0.9rem;
  font-weight: 400;
  color: var(--text-muted);
  line-height: 1.65;
  margin: 0;
}

/* ═══ CTA BANNER ═══ */
.cta-banner {
  background: linear-gradient(
    135deg,
    var(--blue-mid) 0%,
    var(--blue-dark) 100%
  );
  padding: 88px 0;
  position: relative;
  overflow: hidden;
}
.cta-banner::before {
  content: "";
  position: absolute;
  top: -60px;
  right: -60px;
  width: 320px;
  height: 320px;
  background: radial-gradient(circle, var(--glass-9) 0%, transparent 70%);
  border-radius: 50%;
}
.cta-inner {
  position: relative;
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 36px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 48px;
  flex-wrap: wrap;
}
.cta-text h2 {
  font-family: var(--font-serif);
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  font-weight: 700;
  color: white;
  margin-bottom: 12px;
}
.cta-text p {
  font-family: var(--font-ui);
  font-size: 0.95rem;
  font-weight: 400;
  color: var(--white-78);
  max-width: 460px;
  line-height: 1.72;
}
.cta-actions {
  display: flex;
  gap: 16px;
  flex-shrink: 0;
  flex-wrap: wrap;
}
.btn-white {
  font-family: var(--font-ui);
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  background: white;
  color: var(--blue-dark);
  padding: 16px 38px;
  border-radius: 50px;
  display: inline-block;
  box-shadow: 0 4px 20px var(--black-14);
  transition:
    transform var(--transition),
    box-shadow var(--transition),
    background var(--transition);
}
.btn-white:hover {
  background: var(--off-white);
  transform: translateY(-2px);
  box-shadow: 0 8px 28px var(--black-20);
}
.btn-outline-light {
  font-family: var(--font-ui);
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: white;
  border: 2px solid var(--glass-border-52);
  padding: 14px 34px;
  border-radius: 50px;
  display: inline-block;
  transition:
    border-color var(--transition),
    background var(--transition);
}
.btn-outline-light:hover {
  border-color: white;
  background: var(--glass-12);
}

/* ═══ FOOTER ═══ */
/* ═══ TESTIMONIALS ═══ */
.testimonials-section {
  padding: 96px 0;
  background: var(--surface-2, #f7f9fc);
}
.testimonials-section .section-title {
  color: var(--blue-dark);
  margin-bottom: 48px;
}
.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 36px;
}
.testimonial-card {
  background: #fff;
  border: 1px solid rgba(1, 71, 133, 0.08);
  border-radius: 20px;
  padding: 36px 32px 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  box-shadow: 0 4px 24px rgba(1, 71, 133, 0.06);
  transition:
    transform 0.25s,
    box-shadow 0.25s;
}
.testimonial-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(1, 71, 133, 0.13);
}
.tcard-quote {
  font-size: 3.5rem;
  line-height: 1;
  color: var(--blue-mid);
  font-family: Georgia, serif;
  opacity: 0.35;
  margin-bottom: -12px;
}
.tcard-text {
  font-size: 0.97rem;
  line-height: 1.7;
  color: #444;
  flex: 1;
}
.tcard-author {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-top: 16px;
  border-top: 1px solid rgba(1, 71, 133, 0.08);
}
.tcard-author img {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  object-fit: cover;
  background: var(--blue-light);
}
.tcard-author strong {
  display: block;
  font-size: 0.92rem;
  color: var(--blue-dark);
}
.tcard-author span {
  font-size: 0.8rem;
  color: #888;
}

/* ─── Testimonials Swiper ─── */
.testimonials-swiper {
  position: relative;
  max-width: 1200px;
  margin: 0 auto;
  padding: 8px 56px 56px;
  overflow: hidden;
}
.testimonials-swiper .swiper-wrapper {
  align-items: stretch;
}
.testimonials-swiper .swiper-slide {
  height: auto;
  display: flex;
}
.testimonials-swiper .swiper-slide .testimonial-card {
  width: 100%;
  height: 100%;
}
.testimonials-swiper__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 4;
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid rgba(1, 71, 133, 0.18);
  background: #fff;
  color: var(--blue-dark);
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(1, 71, 133, 0.12);
  transition:
    background 200ms ease,
    color 200ms ease,
    transform 200ms ease;
}
.testimonials-swiper__nav:hover {
  background: var(--blue-dark);
  color: #fff;
  transform: translateY(-50%) scale(1.06);
}
.testimonials-swiper__nav--prev {
  left: 8px;
}
.testimonials-swiper__nav--next {
  right: 8px;
}
.testimonials-swiper__nav.swiper-button-disabled {
  opacity: 0.35;
  cursor: default;
}
.testimonials-swiper__pagination {
  position: absolute;
  bottom: 16px;
  left: 0;
  right: 0;
  text-align: center;
  z-index: 3;
}
.testimonials-swiper__pagination .swiper-pagination-bullet {
  width: 10px;
  height: 10px;
  background: rgba(1, 71, 133, 0.25);
  opacity: 1;
  transition:
    width 240ms ease,
    background 240ms ease;
}
.testimonials-swiper__pagination .swiper-pagination-bullet-active {
  width: 32px;
  border-radius: 999px;
  background: var(--blue-dark);
}

@media (max-width: 720px) {
  .testimonials-swiper {
    padding: 4px 12px 48px;
  }
  .testimonials-swiper__nav {
    display: none;
  }
}

/* ═══ PRODUCT FILTER TABS ═══ */
.products-section .product-filter-tabs {
  padding: 8px 10px 10px;
  margin-bottom: 28px;
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(1, 71, 133, 0.1);
  border-radius: 999px;
  box-shadow: 0 6px 20px var(--navy-07);
}
.product-filter-tabs {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
}
.pf-tab {
  padding: 9px 22px;
  border-radius: 99px;
  border: 1.5px solid rgba(1, 71, 133, 0.18);
  background: transparent;
  color: var(--blue-dark);
  font-family: var(--font-ui);
  font-size: 0.88rem;
  font-weight: 500;
  cursor: pointer;
  transition:
    background 0.2s,
    border-color 0.2s,
    color 0.2s;
}
.pf-tab:hover,
.pf-tab.active {
  background: var(--blue-dark);
  border-color: var(--blue-dark);
  color: #fff;
}

/* ═══ PRODUCTS CTA LINK ═══ */
.products-cta {
  text-align: center;
  margin-top: 48px;
}
.btn-outline-blue {
  display: inline-block;
  padding: 14px 36px;
  border: 2px solid var(--blue-dark);
  color: var(--blue-dark);
  border-radius: 99px;
  font-weight: 600;
  font-size: 0.95rem;
  text-decoration: none;
  transition:
    background 0.2s,
    color 0.2s;
}
.btn-outline-blue:hover {
  background: var(--blue-dark);
  color: #fff;
}

/* ═══ CTA CONTACT ROW ═══ */
.cta-contact-row {
  display: flex;
  gap: 28px;
  flex-wrap: wrap;
  margin-top: 18px;
}
.cta-contact-item {
  color: rgba(255, 255, 255, 0.8);
  font-size: 0.92rem;
  text-decoration: none;
  transition: color 0.2s;
}
.cta-contact-item:hover {
  color: #fff;
}

/* ═══ FOOTER CONTACT MINI ═══ */
.footer-contact-mini {
  margin-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.footer-contact-mini a {
  color: rgba(255, 255, 255, 0.5);
  font-size: 0.83rem;
  text-decoration: none;
  transition: color 0.2s;
}
.footer-contact-mini a:hover {
  color: rgba(255, 255, 255, 0.85);
}

/* ═══ FOOTER ═══ */
.site-footer {
  background: var(--footer-bg);
  padding: 72px 0 0;
}
.footer-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 36px 52px;
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 60px;
  border-bottom: 1px solid var(--glass-7);
}
.footer-brand-logo {
  height: 32px !important;
  width: auto;
  max-height: 32px;
  margin-bottom: 0;
  filter: invert(1);
  opacity: 0.92;
}
.footer-brand-contact {
  margin-top: 18px;
  margin-bottom: 18px;
}
.footer-brand-contact h6 {
  font-family: var(--font-ui);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.88);
  margin: 0 0 12px;
}
.footer-brand-contact ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.footer-brand-contact li {
  margin-bottom: 8px;
}
.footer-brand-contact li:last-child {
  margin-bottom: 0;
}
.footer-brand-contact a {
  font-family: var(--font-ui);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.86rem;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.88);
  text-decoration: none;
  transition: color var(--transition);
}
.footer-brand-contact a:hover {
  color: #fff;
}
.footer-brand-contact .footer-contact-line {
  display: inline-flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 0.86rem;
  color: rgba(255, 255, 255, 0.82);
  line-height: 1.5;
}
.footer-brand-blurb {
  font-family: var(--font-ui);
  font-size: 0.83rem;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.78);
  line-height: 1.7;
  max-width: 320px;
  margin: 0 0 16px;
}
.footer-social {
  display: flex;
  gap: 10px;
  margin-top: 14px;
}
.footer-social a {
  width: 38px;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.16);
  color: rgba(255, 255, 255, 0.9);
  text-decoration: none;
  transition:
    background 0.2s,
    color 0.2s;
}
.footer-social a:hover {
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
}
.footer-links {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.footer-col h5,
.footer-col h6 {
  font-family: var(--font-ui);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.88);
  margin-bottom: 16px;
}
.footer-col ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.footer-col li {
  margin-bottom: 8px;
}
.footer-col a {
  font-family: var(--font-ui);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.86rem;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.82);
  margin-bottom: 0;
  transition: color var(--transition);
  text-decoration: none;
}
.footer-col a:hover {
  color: #fff;
}
.footer-contact-line {
  display: inline-flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 0.86rem;
  color: rgba(255, 255, 255, 0.82);
  line-height: 1.5;
}
.footer-bottom {
  max-width: 1200px;
  margin: 0 auto;
  padding: 22px 36px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.footer-bottom span,
.footer-bottom p {
  font-family: var(--font-ui);
  font-size: 0.82rem;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.72);
  margin: 0;
}
.footer-bottom-links {
  display: flex;
  gap: 16px;
}
.footer-bottom-links a {
  font-size: 0.82rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.82);
  text-decoration: none;
}
.footer-bottom-links a:hover {
  color: #fff;
  text-decoration: underline;
}
.back-top {
  font-family: var(--font-ui);
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--white-42);
  letter-spacing: 0.02em;
  transition: color var(--transition);
}
.back-top:hover {
  color: white;
}

/* Fixed back-to-top (all pages; toggled by js/scripts.js) */
#myBtn.back-to-top-btn {
  display: none;
  position: fixed;
  bottom: 26px;
  right: 22px;
  z-index: 950;
  width: 46px;
  height: 46px;
  padding: 0;
  margin: 0;
  border: none;
  border-radius: 50%;
  align-items: center;
  justify-content: center;
  background: var(--blue-mid);
  color: #fff;
  cursor: pointer;
  box-shadow: 0 6px 20px var(--navy-18);
  transition:
    background 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
  font-size: 1rem;
}
#myBtn.back-to-top-btn:hover {
  background: var(--blue-dark);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px var(--navy-18);
}
#myBtn.back-to-top-btn:focus-visible {
  outline: 2px solid var(--blue-light);
  outline-offset: 3px;
}
@media (max-width: 640px) {
  #myBtn.back-to-top-btn {
    bottom: 18px;
    right: 14px;
    width: 42px;
    height: 42px;
    font-size: 0.95rem;
  }
}

/* ═══ RESPONSIVE ═══ */
@media (max-width: 1024px) {
  .hero {
    grid-template-columns: 1fr;
  }
  .hero-left {
    padding: 108px 36px 30px;
    text-align: center;
  }
  .hero-eyebrow {
    margin-left: auto;
    margin-right: auto;
  }
  .hero-sub {
    margin-left: auto;
    margin-right: auto;
  }
  .hero-actions {
    justify-content: center;
  }
  .hero-right {
    padding: 0 36px 56px;
    align-items: center;
  }
  .brands-grid {
    grid-template-columns: 1fr 1fr;
  }
  .brand-card:last-child {
    grid-column: span 2;
  }
  .why-inner {
    grid-template-columns: 1fr;
    gap: 48px;
  }
  .why-visual {
    display: none;
  }
  .home-split-inner {
    grid-template-columns: 1fr;
    gap: 48px;
  }
  .home-split-section--reverse .home-split-text,
  .home-split-section--reverse .home-split-visual {
    order: unset;
  }
  .home-split-cert.why-cert-card {
    left: 12px;
    right: 12px;
    bottom: -12px;
  }
  .home-pillars-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .home-products-grid {
    gap: 18px;
  }
  .hero-prod-cards {
    width: min(100%, 390px);
    grid-template-columns: repeat(3, minmax(100px, 1fr));
  }
  .testimonials-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 768px) {
  .products-section .product-filter-tabs {
    justify-content: flex-start;
    border-radius: 18px;
  }

  /* Mobile nav: show only logo + Shop Now + cart + hamburger */
  .nav-actions .btn-nav-auth {
    display: none !important;
  }
  .btn-nav-auth {
    min-height: 34px;
    padding: 0 12px;
    font-size: 0.78rem;
  }
  .nav-links-cluster--mobile-auth {
    display: flex;
  }
  .nav-actions {
    gap: 10px;
  }

  .navbar,
  .navbar.navbar--gloss-white {
    position: sticky;
    top: 0;
    left: 0;
    right: 0;
    transform: translateZ(0);
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
  }

  .nav-links {
    display: none;
    position: absolute;
    top: 72px;
    left: 0;
    right: 0;
    flex-direction: column;
    gap: 0;
    margin: 0;
    padding: 12px 20px 20px;
    background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98) 0%,
      rgba(248, 252, 255, 0.96) 100%
    );
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border-bottom: 1px solid rgba(1, 71, 133, 0.08);
    box-shadow: 0 16px 40px -12px rgba(1, 71, 133, 0.14);
  }
  .nav-links.open {
    display: flex;
    flex-direction: column;
    align-items: stretch;
  }
  .nav-links.open .nav-links-cluster {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
    gap: 0;
  }
  .nav-links.open .nav-links-cluster--split {
    border-left: none;
    padding-left: 0;
    margin-left: 0;
  }
  .nav-links a {
    padding: 12px 8px;
    border-bottom: 1px solid rgba(1, 71, 133, 0.06);
  }
  .nav-links.open .nav-links-cluster--split > a:last-child {
    border-bottom: none;
  }
  .nav-links .nav-dropdown {
    border-bottom: 1px solid rgba(1, 71, 133, 0.06);
  }
  .nav-links .nav-dropdown-toggle {
    width: 100%;
    text-align: left;
    padding: 12px 8px;
  }
  .nav-hamburger {
    display: flex;
  }
  .nav-toggle {
    display: none;
  }
  .hero {
    grid-template-columns: 1fr;
    min-height: auto;
  }
  .hero-left {
    padding: 96px 20px 24px;
  }
  .hero-right {
    padding: 0 20px 46px;
    align-items: center;
  }
  .hero-stats {
    flex-wrap: wrap;
    gap: 14px;
    margin-bottom: 24px;
  }
  .hero-stat,
  .hero-stat + .hero-stat {
    border-left: none;
    margin-right: 0;
    padding-right: 0;
    padding-left: 0;
  }
  .hero-prod-cards {
    grid-template-columns: repeat(3, 1fr);
    width: min(100%, 320px);
    gap: 8px;
  }
  .hero-scroll-cue {
    display: none;
  }
  .brands-grid {
    grid-template-columns: 1fr;
  }
  .brand-card:last-child {
    grid-column: span 1;
  }
  .home-products-grid {
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 16px;
  }
  .footer-inner {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .footer-links {
    grid-template-columns: repeat(2, 1fr);
  }
  .cta-inner {
    flex-direction: column;
    text-align: center;
  }
  .cta-actions {
    justify-content: center;
  }
  .stats-inner {
    flex-wrap: wrap;
    gap: 28px;
  }
  .stat-divider {
    display: none;
  }
  .testimonials-grid {
    grid-template-columns: 1fr;
    padding: 0 20px;
  }
  .cta-contact-row {
    flex-direction: column;
    gap: 10px;
    align-items: center;
  }
}
@media (max-width: 480px) {
  .hero-prod-cards {
    grid-template-columns: repeat(3, 1fr);
    width: min(100%, 280px);
    gap: 6px;
  }
  .home-products-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .footer-links {
    grid-template-columns: 1fr;
  }
  .footer-bottom {
    flex-direction: column;
    text-align: center;
  }
}

/* ═══════════════════════════════════════════════════════════
   INNER PAGES — shared layout components
   ═══════════════════════════════════════════════════════════ */

/* ── Page Hero Banner ── */
.page-hero {
  background: linear-gradient(
    135deg,
    var(--blue-deeper) 0%,
    var(--blue-rich) 60%,
    var(--blue-mid) 100%
  );
  padding: 140px 0 72px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(
    ellipse 80% 60% at 50% 0%,
    var(--blue-glow) 0%,
    transparent 70%
  );
  pointer-events: none;
}
.page-hero-sm {
  padding: 120px 0 52px;
}
.page-hero-inner {
  position: relative;
  z-index: 1;
  max-width: 720px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  box-sizing: border-box;
}
.page-hero-inner h1,
.page-hero-inner .page-hero-sub,
.page-hero-inner > p {
  width: 100%;
  max-width: 52ch;
  margin-left: auto;
  margin-right: auto;
}
.page-hero-inner h1 {
  color: var(--white);
  font-size: clamp(2rem, 4vw, 3rem);
  margin-bottom: 12px;
}
.page-hero-sub {
  color: var(--white-70);
  font-size: 1.05rem;
  margin-top: 10px;
}
/* Eyebrow line on inner page heroes (matches home hero chip style, centered) */
.page-hero .section-eyebrow {
  display: inline-block;
  font-family: var(--font-ui);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--white-65);
  background: var(--glass-10);
  border: 1px solid var(--glass-border-18);
  padding: 7px 18px;
  border-radius: 50px;
  margin: 0 auto 16px;
}
.brand-hero .section-eyebrow {
  background: rgba(255, 255, 255, 0.35);
  border-color: rgba(255, 255, 255, 0.35);
  color: rgba(30, 30, 40, 0.75);
}
.breadcrumb-back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--white-70);
  font-size: 0.85rem;
  margin-bottom: 14px;
  transition: color var(--transition);
}
.breadcrumb-back:hover {
  color: var(--white);
}

/* ── Inner Section Wrapper ── */
.inner-section {
  padding: 72px 0 96px;
  background: var(--blue-page);
}
.inner-container {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 32px;
}

/* ── Notice Boxes ── */
.notice {
  padding: 14px 20px;
  border-radius: var(--radius-md);
  font-size: 0.95rem;
  margin-bottom: 28px;
}
/* List inside a notice (errors/notices from forms) */
.notice-list {
  margin: 0;
  padding-left: 1.2rem;
}
.notice-list li + li {
  margin-top: 4px;
}
.notice-warning {
  background: #fff8e1;
  border: 1px solid #ffe082;
  color: #5d4037;
}
.notice-info {
  background: var(--blue-light);
  border: 1px solid var(--border);
  color: var(--text-body);
}

/* ── Page Error ── */
.page-error {
  min-height: 40vh;
  display: flex;
  align-items: center;
}
.page-error .inner-container {
  text-align: center;
}
.page-error h2 {
  margin-bottom: 12px;
}
.page-error p {
  margin-bottom: 24px;
  color: var(--text-body);
}

/* ── Shop Grid ── */
.shop-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 28px;
}

/* Sidebar mobile overlay backdrop */
.sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  z-index: 998;
}
.sidebar-overlay.open {
  display: block;
}

/* Sidebar mobile header (close button row) */
.sidebar-mobile-header {
  display: none;
  justify-content: space-between;
  align-items: center;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
  background: var(--white);
}
.sidebar-mobile-title {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--text-dark);
  display: flex;
  align-items: center;
  gap: 7px;
}
.sidebar-close-btn {
  background: none;
  border: none;
  padding: 4px 8px;
  font-size: 1rem;
  color: var(--text-muted);
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition:
    background var(--transition),
    color var(--transition);
}
.sidebar-close-btn:hover {
  background: var(--glass-8);
  color: var(--text-dark);
}

/* ═══════════════════════════════════════════════════════════════
   SHOP LAYOUT  — sidebar + main grid
═══════════════════════════════════════════════════════════════ */
.shop-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 32px;
  align-items: start;
}

/* ── Sidebar ── */
.shop-sidebar {
  position: sticky;
  top: 90px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 0;
  overflow: hidden;
}
.sidebar-section {
  padding: 16px 18px;
  border-bottom: 1px solid var(--border);
}
.sidebar-section:last-child {
  border-bottom: none;
}
.sidebar-heading {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin: 0 0 10px;
}
/* Search row */
.shop-search-bar {
  margin-bottom: 24px;
}
.sidebar-search {
  display: flex;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  overflow: hidden;
}
.sidebar-price-grid {
  display: block;
}
.sidebar-price-info {
  margin-bottom: 14px;
  font-size: 0.9rem;
  color: var(--text-dark);
}
.sidebar-price-info strong {
  font-weight: 700;
}
.sidebar-range-wrap {
  width: 100%;
  margin-bottom: 12px;
}
.sidebar-range-input {
  width: 100%;
  -webkit-appearance: none;
  appearance: none;
  background: transparent;
  margin: 0;
}
.sidebar-range-input:focus {
  outline: none;
}
.sidebar-range-input::-webkit-slider-runnable-track {
  width: 100%;
  height: 10px;
  border-radius: 999px;
  background: var(--light-gray);
}
.sidebar-range-input::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--blue-dark);
  border: 2px solid #fff;
  margin-top: -4px;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.08);
  cursor: pointer;
}
.sidebar-range-input::-moz-range-track {
  width: 100%;
  height: 10px;
  border-radius: 999px;
  background: var(--light-gray);
}
.sidebar-range-input::-moz-range-thumb {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--blue-dark);
  border: 2px solid #fff;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.08);
  cursor: pointer;
}

.sidebar-price-info strong {
  font-weight: 700;
}
.sidebar-range-wrap {
  width: 100%;
}
.sidebar-range-input {
  width: 100%;
  -webkit-appearance: none;
  appearance: none;
  background: transparent;
  margin: 0;
}
.sidebar-range-input:focus {
  outline: none;
}
.sidebar-range-input::-webkit-slider-runnable-track {
  width: 100%;
  height: 10px;
  border-radius: 999px;
  background: var(--light-gray);
}
.sidebar-range-input::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--blue-dark);
  border: 2px solid #fff;
  margin-top: -4px;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.08);
  cursor: pointer;
}
.sidebar-range-input::-moz-range-track {
  width: 100%;
  height: 10px;
  border-radius: 999px;
  background: var(--light-gray);
}
.sidebar-range-input::-moz-range-thumb {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--blue-dark);
  border: 2px solid #fff;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.08);
  cursor: pointer;
}
.sidebar-search input {
  flex: 1;
  padding: 9px 12px;
  border: none;
  outline: none;
  font-size: 0.88rem;
  color: var(--text-dark);
  background: var(--white);
}
.sidebar-search-btn {
  padding: 0 14px;
  background: var(--blue-dark);
  border: none;
  color: var(--white);
  cursor: pointer;
  font-size: 0.8rem;
  transition: background var(--transition);
}
.sidebar-search-btn:hover {
  background: var(--blue-mid);
}
.sidebar-apply-btn {
  margin-top: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 12px 0;
  border: none;
  border-radius: var(--radius-sm);
  background: var(--blue-dark);
  color: #ffffff;
  font-size: 0.9rem;
  font-weight: 700;
  cursor: pointer;
  transition: background var(--transition);
}
.sidebar-apply-btn:hover {
  background: var(--blue-mid);
}
/* Radio list */
.sidebar-checklist {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
  max-height: 220px;
  overflow-y: auto;
}
.sidebar-check-label {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  border-radius: var(--radius-sm);
  font-size: 0.88rem;
  color: var(--text-body);
  cursor: pointer;
  transition: background var(--transition);
}
.sidebar-check-label:hover {
  background: var(--glass-8);
}
.sidebar-check-label.is-active {
  background: #e8f0fe;
  color: var(--blue-dark);
  font-weight: 600;
}
.sidebar-check-label input[type="radio"] {
  accent-color: var(--blue-mid);
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}
/* Size pills */
.sidebar-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.sidebar-pill {
  padding: 4px 12px;
  border: 1px solid var(--border);
  border-radius: 99px;
  background: var(--white);
  font-size: 0.8rem;
  color: var(--text-body);
  cursor: pointer;
  transition:
    background var(--transition),
    border-color var(--transition),
    color var(--transition);
}
.sidebar-pill:hover {
  border-color: var(--blue-mid);
  color: var(--blue-mid);
}
.sidebar-pill.is-active {
  background: var(--blue-dark);
  border-color: var(--blue-dark);
  color: var(--white);
  font-weight: 600;
}
/* Reset link */
.sidebar-reset {
  display: flex;
  align-items: center;
  gap: 7px;
  margin: 14px 18px;
  font-size: 0.82rem;
  color: #c62828;
  font-weight: 600;
  text-decoration: none;
}
.sidebar-reset:hover {
  text-decoration: underline;
}

/* ── Shop main area ── */
.shop-main {
  min-width: 0;
}
.shop-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
  gap: 12px;
}
.sku-count {
  font-size: 0.88rem;
  color: var(--text-body);
  margin: 0;
}
.sku-count strong {
  color: var(--text-dark);
}
.btn-filter-toggle {
  display: none;
  align-items: center;
  gap: 7px;
  padding: 8px 16px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-dark);
  cursor: pointer;
  position: relative;
}
.filter-badge {
  color: var(--blue-mid);
  font-size: 1.1rem;
  line-height: 1;
}

/* ── Shop grid ── */
.shop-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

/* ── Responsive ── */
@media (max-width: 1100px) {
  .shop-layout {
    grid-template-columns: 210px 1fr;
    gap: 22px;
  }
  .shop-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 820px) {
  .shop-layout {
    grid-template-columns: 1fr;
  }
  .shop-sidebar {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    height: 100dvh;
    width: 290px;
    overflow-y: auto;
    z-index: 999;
    border-radius: 0;
    box-shadow: 4px 0 24px rgba(0, 0, 0, 0.18);
  }
  .shop-sidebar.open {
    display: block;
  }
  .sidebar-mobile-header {
    display: flex;
  }
  .btn-filter-toggle {
    display: flex;
  }
}
@media (max-width: 540px) {
  .shop-grid {
    grid-template-columns: 1fr 1fr;
    gap: 14px;
  }
}
@media (max-width: 360px) {
  .shop-grid {
    grid-template-columns: 1fr;
  }
}

.shop-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}
.shop-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}
.shop-card-img-wrap {
  display: block;
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--off-white);
}
.shop-card-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}
.shop-card:hover .shop-card-img-wrap img {
  transform: scale(1.04);
}
.shop-card-body {
  padding: 18px 20px 20px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.shop-card-name {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-dark);
  line-height: 1.3;
}
.shop-card-desc {
  font-size: 0.85rem;
  color: var(--text-body);
  flex: 1;
}
.shop-card-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 4px;
}
.shop-card-price {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--blue-dark);
}
.shop-card-price-wrap {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.shop-card-price--discount {
  color: #16a34a;
}
.shop-card-price--strike {
  font-size: 0.85rem;
  font-weight: 500;
  color: #94a3b8;
  text-decoration: line-through;
}
.btn-shop-view {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--blue-mid);
  border: 1px solid var(--blue-mid);
  border-radius: 20px;
  padding: 4px 14px;
  transition:
    background var(--transition),
    color var(--transition);
}
.btn-shop-view:hover {
  background: var(--blue-mid);
  color: var(--white);
}

/* ── Shared Buttons ── */
/* Icon spacing inside buttons */
.btn-primary-pill i,
.btn-outline-blue i,
.btn-solid-reg i {
  margin-right: 0.35rem;
}
.btn-primary-pill {
  display: inline-block;
  padding: 13px 32px;
  background: linear-gradient(135deg, var(--blue-rich), var(--blue-mid));
  color: var(--white);
  font-size: 0.9rem;
  font-weight: 600;
  border-radius: 50px;
  border: none;
  cursor: pointer;
  transition:
    opacity var(--transition),
    transform var(--transition);
}
.btn-primary-pill:hover {
  opacity: 0.88;
  transform: translateY(-1px);
}
.btn-add-cart {
  display: block;
  width: 100%;
  padding: 10px;
  margin-top: 4px;
  background: var(--blue-dark);
  color: var(--white);
  font-size: 0.85rem;
  font-weight: 600;
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background var(--transition);
}
.btn-add-cart:hover {
  background: var(--blue-rich);
}
.btn-danger-sm {
  padding: 6px 14px;
  font-size: 0.78rem;
  font-weight: 600;
  background: #fee2e2;
  color: #b91c1c;
  border: 1px solid #fca5a5;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background var(--transition);
}
.btn-danger-sm:hover {
  background: #fca5a5;
}

/* Consistent action controls across inner pages */
.btn-primary-pill,
.btn-outline-blue,
.btn-add-cart,
.btn-shop-view,
.btn-add-cart-sm,
.btn-danger-sm,
.sidebar-search-btn,
.btn-filter-toggle,
.btn-solid-reg,
.form-control-submit-button {
  min-height: 42px;
  font-family: var(--font-ui);
  font-weight: 600;
  line-height: 1.1;
}

/* Legacy aliases used by old pages */
.btn-solid-reg,
.form-control-submit-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 24px;
  border-radius: 999px;
  border: none;
  color: var(--white);
  background: linear-gradient(135deg, var(--blue-rich), var(--blue-mid));
  text-decoration: none;
  cursor: pointer;
  transition:
    opacity var(--transition),
    transform var(--transition);
}
.btn-solid-reg:hover,
.form-control-submit-button:hover {
  opacity: 0.9;
  transform: translateY(-1px);
}

/* ── Product Detail ── */
.product-detail {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: start;
}
.product-detail-img {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--off-white);
  box-shadow: var(--shadow-md);
}
.product-detail-img img {
  width: 100%;
  aspect-ratio: 1/1;
  object-fit: cover;
}
.product-detail-gallery {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 16px 0 0;
}
.product-detail-thumb {
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  width: 72px;
  height: 72px;
  padding: 0;
  background: transparent;
  cursor: pointer;
}
.product-detail-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.product-detail-thumb.is-active {
  border-color: var(--blue-dark);
  box-shadow: 0 0 0 2px rgba(1, 71, 133, 0.12);
}
.product-detail-slide-btn {
  position: absolute;
  top: 42%;
  transform: translateY(-50%);
  width: 38px;
  height: 38px;
  border: 0;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(2, 29, 58, 0.72);
  color: #fff;
  cursor: pointer;
  z-index: 2;
  transition:
    background var(--transition),
    transform var(--transition);
}
.product-detail-slide-btn:hover {
  background: rgba(2, 29, 58, 0.88);
}
.product-detail-slide-btn:active {
  transform: translateY(-50%) scale(0.96);
}
.product-detail-slide-btn--prev {
  left: 12px;
}
.product-detail-slide-btn--next {
  right: 12px;
}
.product-detail-info h2 {
  font-size: clamp(1.6rem, 2.5vw, 2.2rem);
  margin-bottom: 14px;
}
.product-detail-desc {
  color: var(--text-body);
  line-height: 1.75;
  margin-bottom: 20px;
}
.product-detail-price {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--blue-dark);
  margin-bottom: 24px;
}
.product-detail-price-wrap {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 24px;
}
.price-discount {
  font-size: 1.5rem;
  font-weight: 800;
  color: #16a34a;
}
.price-mrp-strike {
  font-size: 1rem;
  font-weight: 500;
  color: #94a3b8;
  text-decoration: line-through !important;
}
.price-mrp-strike--sm {
  font-size: 0.85rem;
}
.price-discount-badge {
  display: inline-block;
  background: #dcfce7;
  color: #15803d;
  font-size: 0.78rem;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 20px;
}
.sku-picker-price-wrap {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  margin: 4px 0 0;
}
.product-detail-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.qty-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-width: 160px;
}
.qty-field label {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-dark);
}
.qty-field input {
  padding: 9px 14px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 0.95rem;
  width: 100%;
  outline: none;
}
.qty-field input:focus {
  border-color: var(--blue-mid);
}
.product-detail-form .qty-field {
  max-width: 220px;
}
.product-detail-form .shop-qty-wrap {
  width: 100%;
  justify-content: flex-start;
}
.product-detail-form .shop-qty-btn {
  width: 36px;
  height: 36px;
  font-size: 1.05rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.product-detail-form .shop-qty-input {
  height: 36px;
  flex: 1;
  min-width: 0;
  max-width: 88px;
}
.product-detail-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

/* ── Cart ── */
.cart-empty {
  text-align: center;
  padding: 72px 0;
  color: var(--text-muted);
}
.cart-empty i {
  font-size: 3rem;
  margin-bottom: 16px;
  color: var(--border);
}
.cart-empty p {
  margin-bottom: 24px;
  font-size: 1.05rem;
}
.cart-table-wrap {
  overflow-x: auto;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  margin-bottom: 32px;
}
.cart-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--white);
}
.cart-table th {
  background: var(--blue-dark);
  color: var(--white);
  font-size: 0.85rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 14px 18px;
  text-align: left;
}
.cart-table td {
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
  color: var(--text-body);
  font-size: 0.9rem;
  vertical-align: middle;
}
.cart-table tbody tr:last-child td {
  border-bottom: none;
}
.cart-qty-form {
  display: flex;
  gap: 8px;
  align-items: center;
}
.cart-qty-form input[type="number"] {
  width: 72px;
  padding: 7px 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 0.9rem;
  outline: none;
}
.cart-qty-form input:focus {
  border-color: var(--blue-mid);
}
.cart-summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  padding: 24px 0;
  border-top: 2px solid var(--border);
}
.cart-subtotal {
  font-size: 1.1rem;
  color: var(--text-dark);
}
.cart-subtotal strong {
  color: var(--blue-dark);
  font-size: 1.3rem;
}
.cart-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
}

/* Generic horizontal scroll for wide tables (track order, etc.) */
.table-responsive {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.cms-content img {
  max-width: 100%;
  height: auto;
}

.contact-notice {
  margin-bottom: 20px;
}
.contact-form-hint {
  font-size: 0.88rem;
  color: var(--text-muted);
  margin-bottom: 18px;
  line-height: 1.55;
}
.contact-hp {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

/* ── CMS Content ── */
.cms-content {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: 48px 52px;
  box-shadow: var(--shadow-sm);
}
.cms-content h2,
.cms-content h3 {
  margin: 28px 0 12px;
}
.cms-content p {
  color: var(--text-body);
  line-height: 1.8;
  margin-bottom: 14px;
}
.cms-content ul,
.cms-content ol {
  padding-left: 24px;
  color: var(--text-body);
  line-height: 1.8;
  margin-bottom: 14px;
}

/* ── Inner Page Responsive ── */
@media (max-width: 900px) {
  .product-detail {
    grid-template-columns: 1fr;
    gap: 32px;
  }
}
@media (max-width: 640px) {
  .inner-container {
    padding: 0 20px;
  }
  .inner-section {
    padding: 52px 0 72px;
  }
  .page-hero {
    padding: 110px 0 56px;
  }
  .cart-summary {
    flex-direction: column;
    align-items: flex-start;
  }
  .cms-content {
    padding: 28px 22px;
  }
  .shop-grid {
    grid-template-columns: 1fr 1fr;
  }
  .product-detail-actions,
  .cart-actions {
    width: 100%;
  }
  .product-detail-actions > *,
  .cart-actions > * {
    width: 100%;
    text-align: center;
  }
  .cart-qty-form {
    flex-wrap: wrap;
  }
  .cart-qty-form input[type="number"] {
    width: 100%;
    max-width: 110px;
  }
  .cart-qty-form .btn-outline-blue {
    width: 100%;
    padding: 10px 14px;
  }
}
@media (max-width: 400px) {
  .shop-grid {
    grid-template-columns: 1fr;
  }
}

/* ═══════════════════════════════════════════════════════════════
   PRODUCT FEATURES LIST  (product.php)
═══════════════════════════════════════════════════════════════ */
.product-brand-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px 14px;
  border-radius: 99px;
  background: var(--glass-8);
  border: 1px solid var(--glass-12);
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--blue-mid);
  text-decoration: none;
  letter-spacing: 0.04em;
  margin-bottom: 12px;
}
.product-brand-badge-logo {
  width: 22px;
  height: 22px;
  object-fit: contain;
  flex-shrink: 0;
}
.product-brand-badge:hover {
  background: var(--glass-12);
}

.product-features-list {
  list-style: none;
  padding: 0;
  margin: 16px 0 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.product-features-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 0.92rem;
  color: var(--text-mid);
  line-height: 1.5;
}
.product-features-list li i {
  color: var(--blue-mid);
  font-size: 0.85rem;
  margin-top: 3px;
  flex-shrink: 0;
}

/* ── Products listing — variant hint & short desc ── */
.shop-card-short {
  font-size: 0.83rem;
  color: var(--text-muted);
  margin: 4px 0 8px;
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.sku-variant-hint {
  font-size: 0.78rem;
  color: var(--blue-mid);
  font-weight: 600;
  background: #e8f0fe;
  padding: 2px 8px;
  border-radius: 99px;
  white-space: nowrap;
}
.shop-card-footer {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.shop-variant-list {
  list-style: none;
  margin: 0 0 10px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.shop-variant-link {
  display: block;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 8px 10px;
  background: #f8fbff;
  text-decoration: none;
  transition:
    border-color var(--transition),
    background var(--transition);
}
.shop-variant-link:hover {
  border-color: var(--blue-mid);
  background: #eef5ff;
}
.shop-variant-name {
  display: block;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text-dark);
  line-height: 1.35;
}
.shop-variant-meta {
  display: block;
  margin-top: 2px;
  font-size: 0.74rem;
  color: var(--text-muted);
}
.shop-variant-more {
  margin: -2px 0 10px;
  font-size: 0.75rem;
  color: var(--blue-mid);
  font-weight: 600;
}

.shop-add-form {
  margin-top: auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.shop-qty-wrap {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.shop-qty-btn {
  width: 30px;
  height: 30px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: var(--white);
  color: var(--text-dark);
  font-weight: 700;
  cursor: pointer;
  transition:
    background var(--transition),
    border-color var(--transition);
}

.shop-qty-btn:hover {
  border-color: var(--blue-mid);
  background: #eef5ff;
}

.shop-qty-input {
  width: 64px;
  height: 30px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  text-align: center;
  font-size: 0.85rem;
  color: var(--text-dark);
  outline: none;
}

.shop-qty-input:focus {
  border-color: var(--blue-mid);
}

/* ── Product detail — scroll hint ── */
.sku-scroll-hint {
  font-size: 0.85rem;
  color: var(--blue-mid);
  font-weight: 600;
  margin: 10px 0 0;
}
.sku-scroll-hint i {
  margin-right: 5px;
}

/* ═══════════════════════════════════════════════════════════════
   SKU VARIANT PICKER  (product.php)
═══════════════════════════════════════════════════════════════ */
.sku-picker-section {
  margin-top: 52px;
  padding-top: 40px;
  border-top: 2px solid var(--border);
}
.inline-success {
  margin-bottom: 18px;
  padding: 10px 12px;
  border: 1px solid #c5e8cf;
  background: #eaf8ef;
  color: #1f6a37;
  border-radius: var(--radius-sm);
  font-size: 0.92rem;
  font-weight: 600;
}
.selected-variant {
  margin-top: 32px;
  padding: 18px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: #f8fbff;
}
.selected-variant-heading {
  margin: 0 0 14px;
  font-size: 1.1rem;
  color: var(--text-dark);
}
.selected-variant-grid {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 16px;
}
.selected-variant-img-wrap {
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: var(--off-white);
  aspect-ratio: 4/3;
}
.selected-variant-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.selected-variant-body {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.selected-variant-name {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-dark);
}
.selected-variant-series {
  margin: -2px 0 0;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--blue-dark);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.selected-variant-price {
  margin: 2px 0;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--blue-dark);
}
.selected-variant-desc {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.9rem;
  line-height: 1.55;
}
.selected-variant-meta {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
}
.selected-variant-meta-item {
  font-size: 0.86rem;
  color: var(--text-body);
  line-height: 1.45;
}
.selected-variant-meta-item strong {
  color: var(--text-dark);
}
.selected-variant-features {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.selected-variant-pill {
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 0.78rem;
  border: 1px solid #d8e3f8;
  background: #edf3ff;
  color: #1f3f7a;
  font-weight: 600;
}
.variant-form {
  margin-top: 6px;
}
.sku-picker-heading {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--text-dark);
  margin: 0 0 28px;
}
.sku-picker-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 20px;
}
.sku-picker-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  cursor: pointer;
  transition:
    box-shadow 0.2s ease,
    transform 0.2s ease;
}
.sku-picker-card:focus-visible {
  outline: 2px solid var(--blue-dark);
  outline-offset: 2px;
}
.sku-picker-card.is-selected {
  border-color: var(--blue-dark);
  box-shadow: 0 0 0 1px rgba(23, 69, 174, 0.2);
}
.sku-picker-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
}
.sku-picker-img {
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--off-white);
}
.sku-picker-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}
.sku-picker-card:hover .sku-picker-img img {
  transform: scale(1.04);
}
.sku-picker-body {
  padding: 14px 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}
.sku-picker-name {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text-dark);
  margin: 0;
  line-height: 1.4;
}
.sku-picker-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.sku-picker-price {
  font-size: 1rem;
  font-weight: 700;
  color: var(--blue-dark);
  margin: 4px 0 0;
}
.btn-add-cart-sm {
  padding: 8px 14px;
  font-size: 0.82rem;
  margin-top: auto;
  text-align: center;
}

@media (max-width: 640px) {
  .selected-variant-grid {
    grid-template-columns: 1fr;
  }
  .sku-picker-grid {
    grid-template-columns: 1fr 1fr;
    gap: 14px;
  }
}
@media (max-width: 400px) {
  .sku-picker-grid {
    grid-template-columns: 1fr;
  }
}

/* ═══════════════════════════════════════════════════════════════
   BRAND PAGE  (brand.php)
═══════════════════════════════════════════════════════════════ */
.brand-hero {
  position: relative;
}
.brand-hero--white-moon {
  background: linear-gradient(135deg, #f5e6fa 0%, #ede9fe 100%);
}
.brand-hero--white-moon h1,
.brand-hero--white-moon .page-hero-sub {
  color: #3b1e6e;
}
.brand-hero--baby-moon {
  background: linear-gradient(135deg, #fef9c3 0%, #fde68a 100%);
}
.brand-hero--baby-moon h1,
.brand-hero--baby-moon .page-hero-sub {
  color: #78350f;
}
.brand-hero--tulips {
  background: linear-gradient(135deg, #dbeafe 0%, #bfdbfe 100%);
}
.brand-hero--tulips h1,
.brand-hero--tulips .page-hero-sub {
  color: #1e3a5f;
}

.brand-hero-icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 16px;
  font-size: 1.6rem;
  backdrop-filter: blur(8px);
}
.brand-hero-logo-img {
  width: 44px;
  height: 44px;
  object-fit: contain;
}
.brand-hero--white-moon .brand-hero-icon {
  color: #7c3aed;
}
.brand-hero--baby-moon .brand-hero-icon {
  color: #d97706;
}
.brand-hero--tulips .brand-hero-icon {
  color: var(--blue-dark);
}

.brand-about-section {
  padding: 40px 0 0;
}
.brand-about-text {
  font-size: 1.05rem;
  color: var(--text-mid);
  line-height: 1.85;
  max-width: 820px;
  margin: 0 auto;
  text-align: center;
}

.brand-visual-story {
  padding: 24px 0 8px;
}
.brand-visual-story-heading {
  font-size: 1.45rem;
  font-weight: 700;
  color: var(--blue-dark);
  text-align: center;
  margin: 0 0 10px;
}
.brand-visual-story-lead {
  text-align: center;
  color: var(--text-body);
  font-size: 0.98rem;
  max-width: 560px;
  margin: 0 auto 36px;
  line-height: 1.55;
}
.brand-story-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 28px;
}
@media (max-width: 720px) {
  .brand-story-grid {
    grid-template-columns: 1fr;
  }
}
.brand-story-card {
  margin: 0;
  background: var(--white);
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-sm);
}
.brand-story-card-img {
  aspect-ratio: 4 / 3;
  background: var(--off-white);
  overflow: hidden;
}
.brand-story-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.brand-story-caption {
  padding: 16px 18px 20px;
  font-size: 0.95rem;
  line-height: 1.55;
  color: var(--text-dark);
  font-weight: 500;
}
.brand-visual-story--white-moon .brand-visual-story-heading {
  color: var(--wm);
}
.brand-visual-story--baby-moon .brand-visual-story-heading {
  color: var(--bm);
}

.brand-products-section {
  padding-top: 48px;
}
.brand-products-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--blue-dark);
  margin-bottom: 32px;
}

.brand-cta-band {
  background: var(--blue-dark);
  padding: 40px 24px;
  text-align: center;
}
.brand-cta-band-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  flex-wrap: wrap;
}
.brand-cta-band-inner p {
  color: rgba(255, 255, 255, 0.85);
  font-size: 1rem;
  margin: 0;
}

.brand-not-found-links {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 20px;
}

/* ═══════════════════════════════════════════════════════════════
   CONTACT PAGE  (contact.php)
═══════════════════════════════════════════════════════════════ */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 48px;
  align-items: start;
}

.contact-info h3 {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--blue-dark);
  margin-bottom: 12px;
}
.contact-intro {
  color: var(--text-mid);
  line-height: 1.75;
  font-size: 0.95rem;
  margin-bottom: 28px;
}

.contact-details-list {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.contact-details-list li {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}
.contact-icon {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--glass-8);
  border: 1px solid var(--glass-12);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--blue-mid);
  font-size: 0.9rem;
}
.contact-details-list strong {
  display: block;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--blue-dark);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 2px;
}
.contact-details-list p {
  margin: 0;
  color: var(--text-mid);
  font-size: 0.93rem;
}
.contact-details-list a {
  color: var(--blue-mid);
  text-decoration: none;
}
.contact-details-list a:hover {
  text-decoration: underline;
}

.contact-social {
  display: flex;
  gap: 10px;
}
.contact-social a {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--glass-8);
  border: 1px solid var(--glass-12);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--blue-mid);
  text-decoration: none;
  transition:
    background 0.2s,
    color 0.2s;
}
.contact-social a:hover {
  background: var(--blue-mid);
  color: var(--white);
}

/* Form */
.contact-form-wrap {
  background: var(--off-white);
  border: 1px solid var(--glass-10);
  border-radius: 20px;
  padding: 36px 36px 40px;
}
.contact-form-wrap h3 {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--blue-dark);
  margin-bottom: 24px;
}
.form-row-two {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 16px;
}
.form-group label {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--blue-dark);
  letter-spacing: 0.03em;
}
.form-group input,
.form-group textarea {
  padding: 10px 14px;
  border: 1px solid var(--glass-12);
  border-radius: 10px;
  background: var(--white);
  font-family: var(--font-ui);
  font-size: 0.93rem;
  color: var(--blue-dark);
  outline: none;
  transition: border-color 0.2s;
}
.form-group input:focus,
.form-group textarea:focus {
  border-color: var(--blue-mid);
}
.form-group textarea {
  resize: vertical;
}
.contact-form .btn-primary-pill {
  margin-top: 4px;
}
.contact-form .btn-primary-pill i {
  margin-left: 6px;
}

/* ═══════════════════════════════════════════════════════════════
   NAV DROPDOWN  (brands in header)
═══════════════════════════════════════════════════════════════ */
.nav-dropdown {
  position: relative;
}
.nav-dropdown-toggle {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  font-family: var(--font-ui);
  font-size: inherit;
}
.nav-caret {
  font-size: 0.65rem;
  margin-left: 4px;
  transition: transform 0.2s;
}
.nav-dropdown.open .nav-caret {
  transform: rotate(180deg);
}

.nav-dropdown-menu {
  display: none;
  position: absolute;
  top: calc(100% + 10px);
  left: 50%;
  transform: translateX(-50%);
  min-width: 180px;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.98) 0%,
    rgba(248, 252, 255, 0.95) 100%
  );
  backdrop-filter: blur(16px) saturate(180%);
  -webkit-backdrop-filter: blur(16px) saturate(180%);
  border: 1px solid rgba(255, 255, 255, 0.9);
  border-radius: 14px;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.85) inset,
    0 12px 40px -8px rgba(1, 71, 133, 0.15);
  padding: 8px 0;
  list-style: none;
  z-index: 200;
}
.nav-dropdown.open .nav-dropdown-menu {
  display: block;
}
.nav-dropdown-menu li a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 18px;
  font-size: 0.9rem;
  color: var(--blue-dark);
  text-decoration: none;
  transition: background 0.15s;
}
.nav-dropdown-menu li a:hover {
  background: var(--glass-8);
}
.nav-dropdown-menu li a i {
  width: 16px;
  color: var(--blue-mid);
  font-size: 0.85rem;
}

/* ── Responsive: Contact & Brand ── */
@media (max-width: 900px) {
  .contact-grid {
    grid-template-columns: 1fr;
  }
  .contact-form-wrap {
    padding: 28px 24px 32px;
  }
}
@media (max-width: 640px) {
  .form-row-two {
    grid-template-columns: 1fr;
  }
  .brand-about-text {
    font-size: 0.97rem;
  }
  .nav-dropdown-menu {
    left: 0;
    transform: none;
  }
}

/* ── Track & Payment Pages ── */
.simple-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 28px 24px;
}
.simple-card h2,
.simple-card h3 {
  color: var(--blue-dark);
  margin-bottom: 12px;
}
.simple-card p {
  margin-bottom: 12px;
}
.track-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.track-details-list {
  display: grid;
  gap: 10px;
}
.track-details-list li {
  border-bottom: 1px solid var(--border);
  padding-bottom: 8px;
  font-size: 0.92rem;
  color: var(--text-body);
}
.track-details-list li:last-child {
  border-bottom: none;
}
.track-status-track {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 4px;
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--border);
}
.track-status-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
  min-width: 52px;
  text-align: center;
  opacity: 0.4;
}
.track-status-step.is-done {
  opacity: 1;
}
.track-status-step.is-current .track-status-label {
  font-weight: 800;
  color: var(--blue-dark);
}
.track-status-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--border);
  margin-bottom: 6px;
}
.track-status-step.is-done .track-status-dot {
  background: var(--blue-mid);
  box-shadow: 0 0 0 3px rgba(0, 127, 198, 0.22);
}
.track-status-step.is-current .track-status-dot {
  background: var(--blue-dark);
}
.track-status-label {
  font-size: 0.66rem;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.payment-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}
@media (max-width: 860px) {
  .track-layout {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 640px) {
  .simple-card {
    padding: 22px 18px;
  }
  .payment-actions {
    flex-direction: column;
  }
  .payment-actions > * {
    width: 100%;
  }
}

/* ── Notices: success / danger ── */
.notice-success {
  background: #e8f5e9;
  border: 1px solid #a5d6a7;
  color: #2e7d32;
}
.notice-danger {
  background: #ffebee;
  border: 1px solid #ef9a9a;
  color: #c62828;
}

/* ── Checkout Page ── */
.checkout-grid {
  display: grid;
  grid-template-columns: 1fr 400px;
  gap: 48px;
  align-items: start;
}
.checkout-form-heading {
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--blue-dark);
  margin-bottom: 22px;
}
.checkout-total-line {
  font-size: 1rem;
  color: var(--text-body);
  margin-bottom: 20px;
}
.checkout-submit {
  width: 100%;
  margin-top: 8px;
  justify-content: center;
}
.order-summary-box {
  background: var(--off-white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 28px 24px;
  position: sticky;
  top: 90px;
}
.order-summary-box h3 {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--blue-dark);
  margin-bottom: 18px;
}
.order-summary-list {
  list-style: none;
  padding: 0;
  margin: 0 0 18px;
}
.order-summary-list li {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
  gap: 12px;
}
.os-name {
  font-size: 0.88rem;
  color: var(--text-body);
  flex: 1;
}
.os-price {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--blue-dark);
  white-space: nowrap;
}
.order-summary-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 14px;
  font-size: 1rem;
  color: var(--blue-dark);
}
.order-summary-total strong {
  font-size: 1.15rem;
}
@media (max-width: 860px) {
  .checkout-grid {
    grid-template-columns: 1fr;
  }
  .order-summary-box {
    position: static;
  }
}

/* ── Checkout success: email status ── */
.checkout-success-banner {
  margin-bottom: 14px;
}
.checkout-email-status {
  border-radius: var(--radius-md);
  padding: 12px 16px;
  margin-bottom: 20px;
  font-size: 0.92rem;
  line-height: 1.55;
}
.checkout-email-status strong {
  display: block;
  margin-bottom: 4px;
}
.checkout-email-status--ok {
  background: #e8f4fc;
  border: 1px solid #90caf9;
  color: #0d47a1;
}
.checkout-email-status--warn {
  background: #fff8e1;
  border: 1px solid #ffcc80;
  color: #6d4c41;
}
.checkout-email-detail {
  display: block;
  font-size: 0.86rem;
  margin-top: 4px;
  opacity: 0.95;
}

.checkout-invoice-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  margin-bottom: 20px;
}
.checkout-invoice-actions .btn-outline-blue {
  text-decoration: none;
}

/* ── Checkout invoice (print-friendly) ── */
.checkout-invoice {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 32px 36px 28px;
  width: 880px;
  max-width: 880px;
  margin: 0 auto 40px;
  color: var(--text-dark);
}
.checkout-invoice__masthead {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 24px;
  padding-bottom: 22px;
  margin-bottom: 22px;
  border-bottom: 2px solid var(--blue-dark);
}
.checkout-invoice__company-name {
  font-family: var(--font-serif);
  font-size: 1.45rem;
  font-weight: 800;
  color: var(--blue-dark);
  letter-spacing: -0.02em;
}
.checkout-invoice__company-tag {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--blue-mid);
  margin-top: 6px;
}
.checkout-invoice__company-meta {
  font-size: 0.82rem;
  color: var(--text-muted);
  margin-top: 6px;
}
.checkout-invoice__meta-box {
  min-width: 220px;
  background: var(--off-white);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 14px 16px;
}
.checkout-invoice__meta-row {
  display: grid;
  grid-template-columns: 135px minmax(0, 1fr);
  gap: 16px;
  font-size: 0.84rem;
  padding: 4px 0;
}
.checkout-invoice__meta-row + .checkout-invoice__meta-row {
  border-top: 1px solid var(--border);
}
.checkout-invoice__meta-label {
  color: var(--text-muted);
  font-weight: 600;
}
.checkout-invoice__meta-value {
  font-weight: 700;
  color: var(--blue-dark);
  text-align: right;
  overflow-wrap: anywhere;
}
.checkout-invoice__parties {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-bottom: 26px;
}
.checkout-invoice__party-title {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--blue-mid);
  margin: 0 0 10px;
}
.checkout-invoice__party-line {
  margin: 0 0 6px;
  font-size: 0.9rem;
  color: var(--text-body);
  line-height: 1.5;
}
.checkout-invoice__table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
  margin-bottom: 20px;
}
.checkout-invoice__th,
.checkout-invoice__td {
  border: 1px solid #d3e2f0;
  padding: 10px 12px;
  vertical-align: top;
}
.checkout-invoice__th {
  background: #f0f5fb;
  font-weight: 700;
  color: var(--blue-dark);
  text-align: left;
}
.checkout-invoice__th--num {
  width: 36px;
  text-align: center;
}
.checkout-invoice__th--right,
.checkout-invoice__td--right {
  text-align: right;
}
.checkout-invoice__th--center,
.checkout-invoice__td--center {
  text-align: center;
  width: 56px;
}
.checkout-invoice__td--num {
  text-align: center;
  color: var(--text-muted);
}
.checkout-invoice__total-row .checkout-invoice__td {
  background: #fafcfe;
  font-size: 0.95rem;
}
.checkout-invoice__grand {
  font-size: 1.1rem !important;
  color: var(--blue-dark) !important;
}
.checkout-invoice__footer {
  border-top: 1px solid var(--border);
  padding-top: 16px;
  font-size: 0.82rem;
  color: var(--text-muted);
  line-height: 1.6;
}
.checkout-invoice__footer p {
  margin: 0 0 8px;
}
.checkout-invoice__footer-note {
  font-size: 0.78rem !important;
  font-style: italic;
}

@media (max-width: 640px) {
  .inner-container {
    overflow-x: auto;
  }
}

/* ── Responsive safety net (headings/text overflow + containers) ── */
.page-hero-inner,
.inner-container,
.cms-content {
  min-width: 0;
}

.page-hero-inner h1,
.page-hero-inner .page-hero-sub,
.cms-content h1,
.cms-content h2,
.cms-content h3,
.cms-content h4,
.cms-content h5,
.cms-content h6 {
  overflow-wrap: anywhere;
  word-break: normal;
}

/* Ensure logo images inside tight header/footer areas never overflow */
.nav-logo img,
.footer-brand-logo,
.brand-hero-logo-img {
  max-width: 100%;
  height: auto;
}

/* ── Auth Experience (website-wide unified form rhythm) ── */
.auth-shell {
  padding-top: 44px;
}

.auth-shell__container {
  display: grid;
  grid-template-columns: minmax(260px, 0.95fr) minmax(360px, 1.05fr);
  gap: 22px;
  align-items: stretch;
}

.auth-visual {
  border-radius: 24px;
  padding: 30px 26px;
  background:
    radial-gradient(
      circle at 18% 20%,
      rgba(0, 127, 198, 0.35) 0%,
      rgba(0, 127, 198, 0) 50%
    ),
    radial-gradient(
      circle at 82% 78%,
      rgba(255, 255, 255, 0.14) 0%,
      rgba(255, 255, 255, 0) 48%
    ),
    linear-gradient(145deg, #013e74 0%, #025899 54%, #007fc6 100%);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.28);
  box-shadow: 0 24px 46px rgba(1, 71, 133, 0.2);
  position: relative;
  overflow: hidden;
  animation: authPanelIn 0.46s ease both;
}

.auth-visual::after {
  content: "";
  position: absolute;
  width: 230px;
  height: 230px;
  right: -75px;
  top: -85px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.12);
}

.auth-visual__eyebrow {
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.86);
  margin-bottom: 10px;
}

.auth-visual h3 {
  color: #fff;
  margin-bottom: 10px;
  font-size: 1.52rem;
}

.auth-visual p {
  color: rgba(255, 255, 255, 0.9);
  margin-bottom: 16px;
  line-height: 1.62;
}

.auth-benefits {
  display: grid;
  gap: 10px;
}

.auth-benefits li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 0.93rem;
  color: rgba(255, 255, 255, 0.96);
}

.auth-benefits i {
  margin-top: 2px;
  color: #d9f1ff;
}

.auth-card {
  max-width: none !important;
  margin: 0 !important;
  border-radius: 24px;
  border: 1px solid #dae7f6;
  box-shadow: 0 18px 36px rgba(1, 71, 133, 0.12);
  padding: 26px 24px;
  animation: authCardIn 0.42s ease both;
}

.auth-card .section-heading,
.auth-card h1 {
  margin-bottom: 14px;
}

.auth-card .form-group {
  margin-bottom: 12px;
}

.auth-card .notice {
  margin-bottom: 12px;
}

.auth-card .text-muted {
  font-size: 0.82rem;
}

@keyframes authPanelIn {
  from {
    opacity: 0;
    transform: translateY(14px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes authCardIn {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 980px) {
  .auth-shell__container {
    grid-template-columns: 1fr;
  }
  .auth-visual {
    padding: 24px 20px;
  }
}

@media (max-width: 620px) {
  .auth-shell {
    padding-top: 26px;
  }
  .auth-card {
    padding: 20px 16px;
    border-radius: 18px;
  }
  .auth-visual {
    border-radius: 18px;
  }
}

@media print {
  @page {
    size: A4 portrait;
    margin: 10mm;
  }
  html,
  body {
    background: #fff !important;
    margin: 0 !important;
    padding: 0 !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  .navbar,
  .site-footer,
  .page-hero,
  .no-print {
    display: none !important;
  }
  .inner-section {
    padding: 0 !important;
  }
  .inner-container {
    max-width: 100% !important;
    padding: 0 !important;
  }
  .checkout-invoice {
    border: none !important;
    box-shadow: none !important;
    margin: 0 !important;
    padding: 0 !important;
    max-width: 190mm !important;
    width: 190mm !important;
    min-width: 0 !important;
    font-size: 12px !important;
  }
  .checkout-invoice__meta-row {
    grid-template-columns: 130px minmax(0, 1fr);
  }
  .checkout-invoice,
  .checkout-invoice * {
    box-sizing: border-box;
    min-width: 0;
  }
  .checkout-invoice__meta-box,
  .checkout-invoice__meta-row,
  .checkout-invoice__meta-value,
  .checkout-invoice__party-line {
    overflow-wrap: anywhere;
    word-break: break-word;
    white-space: normal !important;
  }
  .checkout-invoice__masthead,
  .checkout-invoice__parties,
  .checkout-invoice__footer {
    page-break-inside: avoid;
  }
  .checkout-invoice__parties {
    gap: 12px !important;
    margin-bottom: 14px !important;
  }
  .checkout-invoice__table {
    width: 100% !important;
    table-layout: fixed;
    font-size: 11px !important;
    page-break-inside: auto;
  }
  .checkout-invoice__table th:nth-child(1),
  .checkout-invoice__table td:nth-child(1) {
    width: 5% !important;
  }
  .checkout-invoice__table th:nth-child(2),
  .checkout-invoice__table td:nth-child(2) {
    width: 45% !important;
  }
  .checkout-invoice__table th:nth-child(3),
  .checkout-invoice__table td:nth-child(3) {
    width: 16% !important;
  }
  .checkout-invoice__table th:nth-child(4),
  .checkout-invoice__table td:nth-child(4) {
    width: 10% !important;
  }
  .checkout-invoice__table th:nth-child(5),
  .checkout-invoice__table td:nth-child(5) {
    width: 24% !important;
  }
  .checkout-invoice__th,
  .checkout-invoice__td {
    padding: 6px 7px !important;
    word-break: break-word;
    overflow-wrap: anywhere;
  }
  .checkout-invoice__th--num,
  .checkout-invoice__td--num {
    width: 6% !important;
  }
  .checkout-invoice__th--center,
  .checkout-invoice__td--center {
    width: 10% !important;
  }
  .checkout-invoice__th--right,
  .checkout-invoice__td--right {
    white-space: normal !important;
  }
  .checkout-invoice__table {
    page-break-inside: avoid;
  }
}

/* ── Luna Brand Hero ── */
.brand-hero--luna {
  background: linear-gradient(135deg, #1a1035 0%, #0d1b3e 100%);
}

/* ── Luna Institutional Brand Page ── */
.brand-inst-note {
  font-size: 1rem;
  color: var(--text-body);
  background: #fffbeb;
  border-left: 4px solid #f5c842;
  padding: 14px 20px;
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  margin-bottom: 32px;
  line-height: 1.7;
}
.luna-specs-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-bottom: 32px;
}
.luna-spec-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 22px 20px 18px;
  box-shadow: var(--shadow-sm);
}
.luna-spec-size {
  font-size: 1.5rem;
  font-weight: 700;
  color: #1a1035;
  margin-bottom: 4px;
}
.luna-spec-label {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--blue-dark);
  margin-bottom: 2px;
}
.luna-spec-desc {
  font-size: 0.77rem;
  color: var(--text-muted);
  margin-bottom: 14px;
}
.luna-variants {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.luna-variant {
  background: var(--off-white);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 8px 12px;
}
.luna-variant--note {
  opacity: 0.65;
}
.luna-variant-name {
  display: block;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--blue-dark);
}
.luna-variant-tech {
  display: block;
  font-size: 0.77rem;
  color: var(--text-muted);
  margin-top: 2px;
}
.luna-tender-quote {
  background: #1a1035;
  border-radius: var(--radius-lg);
  padding: 28px 32px;
  margin-bottom: 24px;
}
.luna-tender-quote p {
  font-size: 1rem;
  color: rgba(255, 255, 255, 0.82);
  font-style: italic;
  line-height: 1.75;
  margin-bottom: 10px;
}
.luna-tender-quote cite {
  font-size: 0.82rem;
  color: #f5c842;
  font-style: normal;
}
.luna-badges-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 16px;
}
.luna-inst-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--off-white);
  border: 1px solid var(--border);
  border-radius: 100px;
  padding: 6px 14px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--blue-dark);
}
.luna-inst-badge i {
  color: #1a1035;
  font-size: 0.8rem;
}
@media (max-width: 860px) {
  .luna-specs-grid {
    grid-template-columns: 1fr;
  }
}

/* ── Manufacturing Stats Row (our-story page) ── */
.mfg-stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin: 20px 0;
  background: var(--off-white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px;
}
.mfg-stat {
  text-align: center;
}
.mfg-stat strong {
  display: block;
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--blue-dark);
}
.mfg-stat span {
  font-size: 0.78rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
@media (max-width: 640px) {
  .mfg-stats-row {
    grid-template-columns: 1fr 1fr;
  }
}

/* ── OEM Page ── */
.oem-intro-band {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 40px;
  align-items: start;
  margin-bottom: 48px;
}
.oem-intro-text h2 {
  font-size: 1.55rem;
  font-weight: 700;
  color: var(--blue-dark);
  margin-bottom: 14px;
}
.oem-intro-text p {
  font-size: 1rem;
  color: var(--text-body);
  line-height: 1.75;
}
.oem-machine-card {
  background: #0d1b3e;
  border-radius: var(--radius-lg);
  padding: 24px 22px;
  color: white;
}
.oem-machine-name {
  font-size: 1.2rem;
  font-weight: 700;
  color: #f5c842;
  margin-bottom: 4px;
}
.oem-machine-sub {
  font-size: 0.82rem;
  color: rgba(255, 255, 255, 0.5);
  margin-bottom: 16px;
}
.oem-machine-stats {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
  margin-bottom: 14px;
}
.oem-mstat {
  text-align: center;
  background: rgba(255, 255, 255, 0.07);
  border-radius: var(--radius-sm);
  padding: 8px 6px;
}
.oem-mstat strong {
  display: block;
  font-size: 0.95rem;
  font-weight: 700;
  color: white;
}
.oem-mstat span {
  font-size: 0.67rem;
  color: rgba(255, 255, 255, 0.45);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.oem-machine-mfg {
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.38);
  text-align: center;
}
.oem-services-title {
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--blue-dark);
  margin-bottom: 22px;
}
.oem-services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-bottom: 40px;
}
.oem-service-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px 20px;
  box-shadow: var(--shadow-sm);
}
.oem-service-icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-md);
  background: var(--blue-light);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
  color: var(--blue-dark);
  font-size: 1.1rem;
}
.oem-icon-nepal {
  background: #fff3cd;
  color: #92400e;
}
.oem-service-card h3 {
  font-size: 0.97rem;
  font-weight: 700;
  color: var(--blue-dark);
  margin-bottom: 8px;
}
.oem-service-card p {
  font-size: 0.87rem;
  color: var(--text-body);
  line-height: 1.7;
}
.oem-raw-materials {
  background: var(--off-white);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 18px 22px;
  margin-bottom: 24px;
}
.oem-raw-materials h3 {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--blue-dark);
  margin-bottom: 8px;
}
.oem-raw-materials p {
  font-size: 0.88rem;
  color: var(--text-body);
  line-height: 1.7;
}
.oem-product-types {
  margin-bottom: 40px;
}
.oem-product-types h3 {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--blue-dark);
  margin-bottom: 12px;
}
.oem-formats-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.oem-format-pill {
  background: var(--off-white);
  border: 1px solid var(--border);
  border-radius: 100px;
  padding: 5px 14px;
  font-size: 0.82rem;
  color: var(--text-body);
}
.oem-cta-section {
  background: linear-gradient(135deg, #0d1b3e 0%, #1a3a7a 100%);
  border-radius: var(--radius-lg);
  padding: 40px 36px;
  text-align: center;
}
.oem-cta-section h2 {
  font-size: 1.4rem;
  font-weight: 700;
  color: white;
  margin-bottom: 12px;
}
.oem-cta-section p {
  font-size: 0.97rem;
  color: rgba(255, 255, 255, 0.7);
  max-width: 560px;
  margin: 0 auto 28px;
  line-height: 1.75;
}
.oem-contact-row {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 16px;
}
.oem-contact-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 100px;
  padding: 10px 20px;
  font-size: 0.9rem;
  color: white;
  text-decoration: none;
  transition: background 0.2s ease;
}
.oem-contact-item:hover {
  background: rgba(255, 255, 255, 0.2);
}
.oem-contact-item i {
  font-size: 0.85rem;
  color: #f5c842;
}
@media (max-width: 900px) {
  .oem-intro-band {
    grid-template-columns: 1fr;
  }
  .oem-services-grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 640px) {
  .oem-services-grid {
    grid-template-columns: 1fr;
  }
  .oem-contact-row {
    flex-direction: column;
    align-items: center;
  }
}

/* ═══════════════════════════════════════════════════════════════
   SKU CATALOGUE CARDS  (products.php)
═══════════════════════════════════════════════════════════════ */
.sku-count {
  font-size: 0.85rem;
  color: var(--text-light);
  margin: 0 0 20px;
}
.sku-brand-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 2px 10px;
  border-radius: 99px;
  background: var(--glass-8);
  border: 1px solid var(--glass-12);
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--blue-mid);
  text-decoration: none;
  letter-spacing: 0.04em;
  margin-bottom: 6px;
}
.sku-brand-badge-logo {
  width: 18px;
  height: 18px;
  object-fit: contain;
  flex-shrink: 0;
}
.sku-brand-badge:hover {
  background: var(--glass-12);
}
.sku-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 6px 0 10px;
}
.sku-tag {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 10px;
  border-radius: 99px;
  background: var(--glass-8);
  border: 1px solid var(--glass-12);
  font-size: 0.75rem;
  color: var(--text-body);
}
.sku-tag i {
  font-size: 0.68rem;
  color: var(--blue-mid);
}
.sku-tag-type {
  background: #e8f0fe;
  border-color: #c5d5fc;
  color: #2a52be;
  font-weight: 600;
}

/* ═══════════════════════════════════════════════════════════════
   ENHANCED CMS PAGE STYLES  (page.php)
   ════════════════════════════════════════════════════════════════ */

/* ── Brand Showcase Section ── */
.brand-showcase-section {
  padding: 80px 0;
  background: linear-gradient(180deg, var(--white) 0%, var(--off-white) 100%);
}

.brand-showcase-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 24px;
  margin-top: 48px;
}

.brand-showcase-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: 32px 28px;
  text-decoration: none;
  color: inherit;
  box-shadow: var(--shadow-sm);
  border: 2px solid transparent;
  transition: all 0.3s ease;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.brand-showcase-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-md);
}

.brand-showcase-card--wm {
  border-color: var(--wm);
}
.brand-showcase-card--wm:hover {
  box-shadow: 0 12px 40px rgba(201, 79, 119, 0.15);
}

.brand-showcase-card--bm {
  border-color: var(--bm);
}
.brand-showcase-card--bm:hover {
  box-shadow: 0 12px 40px rgba(212, 146, 15, 0.15);
}

.brand-showcase-card--tulips {
  border-color: var(--tulips);
}
.brand-showcase-card--tulips:hover {
  box-shadow: 0 12px 40px rgba(0, 127, 198, 0.15);
}

.brand-showcase-card--luna {
  border-color: #6b21a8;
}
.brand-showcase-card--luna:hover {
  box-shadow: 0 12px 40px rgba(107, 33, 168, 0.15);
}

.brand-showcase-logo-wrap {
  width: 100%;
  height: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  background: var(--off-white);
  border-radius: var(--radius-md);
  padding: 16px;
}

.brand-showcase-logo {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

.brand-showcase-logo-placeholder {
  font-size: 3rem;
  color: var(--blue-mid);
}

.brand-showcase-name {
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--text-dark);
  margin-bottom: 12px;
}

.brand-showcase-desc {
  font-size: 0.9rem;
  color: var(--text-body);
  line-height: 1.7;
  margin-bottom: 20px;
  flex: 1;
}

.brand-showcase-link {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--blue-mid);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: color 0.2s ease;
}

.brand-showcase-card:hover .brand-showcase-link {
  color: var(--blue-dark);
}

.brand-showcase-link i {
  font-size: 0.8rem;
  transition: transform 0.2s ease;
}

.brand-showcase-card:hover .brand-showcase-link i {
  transform: translateX(4px);
}

/* ── Page Stats Section ── */
.page-stats-section {
  padding: 60px 0;
  background: linear-gradient(
    135deg,
    var(--blue-dark) 0%,
    var(--blue-rich) 50%,
    var(--blue-mid) 100%
  );
  position: relative;
  overflow: hidden;
}

.page-stats-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 30% 50%, var(--glass-8) 0%, transparent 50%),
    radial-gradient(circle at 70% 50%, var(--glass-5) 0%, transparent 50%);
}

.page-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  position: relative;
  z-index: 1;
}

.page-stat-card {
  background: var(--glass-8);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--glass-border-28);
  border-radius: var(--radius-lg);
  padding: 28px 24px;
  display: flex;
  align-items: center;
  gap: 16px;
  transition: all 0.3s ease;
}

.page-stat-card:hover {
  background: var(--glass-12);
  transform: translateY(-4px);
}

.page-stat-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--glass-20);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  color: var(--white);
  flex-shrink: 0;
}

.page-stat-content {
  display: flex;
  flex-direction: column;
}

.page-stat-number {
  font-size: 2rem;
  font-weight: 800;
  color: var(--white);
  line-height: 1.2;
}

.page-stat-label {
  font-size: 0.85rem;
  color: var(--white-65);
  font-weight: 500;
}

/* ── Timeline Section ── */
.timeline-section {
  padding: 100px 0;
  background: var(--white);
}

.timeline {
  position: relative;
  max-width: 800px;
  margin: 48px auto 0;
  padding-left: 40px;
}

.timeline::before {
  content: "";
  position: absolute;
  left: 12px;
  top: 0;
  bottom: 0;
  width: 4px;
  background: linear-gradient(
    180deg,
    var(--blue-dark) 0%,
    var(--blue-mid) 100%
  );
  border-radius: 2px;
}

.timeline-item {
  position: relative;
  padding-bottom: 40px;
}

.timeline-item:last-child {
  padding-bottom: 0;
}

.timeline-year {
  position: absolute;
  left: -40px;
  width: 60px;
  height: 60px;
  background: linear-gradient(
    135deg,
    var(--blue-dark) 0%,
    var(--blue-mid) 100%
  );
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--white);
  box-shadow: 0 4px 20px var(--blue-glow-22);
}

.timeline-content {
  background: var(--off-white);
  border-radius: var(--radius-md);
  padding: 24px 28px;
  margin-left: 40px;
  border-left: 4px solid var(--blue-mid);
  transition: all 0.3s ease;
}

.timeline-item:hover .timeline-content {
  background: var(--white);
  box-shadow: var(--shadow-sm);
  transform: translateX(8px);
}

.timeline-content h4 {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--blue-dark);
  margin-bottom: 8px;
}

.timeline-content p {
  font-size: 0.95rem;
  color: var(--text-body);
  line-height: 1.7;
  margin: 0;
}

/* ── Values Section ── */
.values-section {
  padding: 100px 0;
  background: linear-gradient(180deg, var(--off-white) 0%, var(--white) 100%);
}

.values-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-top: 48px;
}

.value-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: 32px 28px;
  text-align: center;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border);
  transition: all 0.3s ease;
}

.value-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-md);
}

.value-icon {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.8rem;
  margin: 0 auto 20px;
  color: var(--white);
}

.value-icon--quality {
  background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
}

.value-icon--innovation {
  background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
}

.value-icon--care {
  background: linear-gradient(135deg, #ec4899 0%, #db2777 100%);
}

.value-icon--community {
  background: linear-gradient(135deg, #8b5cf6 0%, #7c3aed 100%);
}

.value-card h4 {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--blue-dark);
  margin-bottom: 12px;
}

.value-card p {
  font-size: 0.9rem;
  color: var(--text-body);
  line-height: 1.7;
  margin: 0;
}

/* ── Page CTA Section ── */
.page-cta-section {
  padding: 80px 0 100px;
  background: var(--white);
}

.page-cta-card {
  background: linear-gradient(
    135deg,
    var(--blue-deeper) 0%,
    var(--blue-rich) 50%,
    var(--blue-mid) 100%
  );
  border-radius: var(--radius-xl);
  padding: 48px 56px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  position: relative;
  overflow: hidden;
}

.page-cta-card::before {
  content: "";
  position: absolute;
  top: -50%;
  right: -20%;
  width: 400px;
  height: 400px;
  background: radial-gradient(circle, var(--glass-10) 0%, transparent 70%);
  border-radius: 50%;
}

.page-cta-content {
  position: relative;
  z-index: 1;
}

.page-cta-content h2 {
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 700;
  color: var(--white);
  margin-bottom: 12px;
}

.page-cta-content p {
  font-size: 1rem;
  color: var(--white-70);
  max-width: 480px;
  margin: 0;
  line-height: 1.7;
}

.page-cta-actions {
  display: flex;
  gap: 16px;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}

.page-cta-actions .btn-primary-pill {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 32px;
  font-size: 1rem;
}

.page-cta-actions .btn-outline-blue {
  border-color: var(--white-55);
  color: var(--white);
  background: var(--glass-8);
  padding: 12px 28px;
}

.page-cta-actions .btn-outline-blue:hover {
  background: var(--white);
  color: var(--blue-dark);
  border-color: var(--white);
}

/* ── Responsive for Page Sections ── */
@media (max-width: 1024px) {
  .page-stats-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .values-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .brand-showcase-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .page-stats-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .values-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .brand-showcase-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .page-cta-card {
    flex-direction: column;
    text-align: center;
    padding: 36px 28px;
  }
  .page-cta-content p {
    max-width: 100%;
  }
  .page-cta-actions {
    flex-direction: column;
    width: 100%;
  }
  .page-cta-actions a {
    width: 100%;
    text-align: center;
  }
  .timeline {
    padding-left: 20px;
  }
  .timeline-year {
    left: -30px;
    width: 48px;
    height: 48px;
    font-size: 0.75rem;
  }
  .timeline-content {
    margin-left: 30px;
    padding: 20px 22px;
  }
}

@media (max-width: 480px) {
  .brand-showcase-card {
    padding: 24px 20px;
  }
  .page-stat-card {
    flex-direction: column;
    text-align: center;
  }
  .value-card {
    padding: 24px 20px;
  }
}

/* ═══════════════════════════════════════════════════════════════
   PRODUCTS DETAIL SECTION
   ════════════════════════════════════════════════════════════════ */
.products-detail-section {
  padding: 100px 0;
  background: var(--white);
}

.products-categories {
  display: flex;
  flex-direction: column;
  gap: 32px;
  margin-top: 48px;
}

.product-category-card {
  background: var(--off-white);
  border-radius: var(--radius-lg);
  padding: 32px 36px;
  border: 1px solid var(--border);
  transition: all 0.3s ease;
  border-left: 4px solid var(--blue-mid);
}

.product-category-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateX(8px);
}

.product-cat--wm {
  border-left-color: var(--wm);
}

.product-cat--baby {
  border-left-color: var(--bm);
}

.product-cat-header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 16px;
}

.product-cat-icon {
  width: 56px;
  height: 56px;
  border-radius: var(--radius-md);
  background: linear-gradient(
    135deg,
    var(--blue-dark) 0%,
    var(--blue-mid) 100%
  );
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  color: var(--white);
}

.product-cat--wm .product-cat-icon {
  background: linear-gradient(135deg, var(--wm) 0%, var(--wm-light) 100%);
}

.product-cat--baby .product-cat-icon {
  background: linear-gradient(135deg, var(--bm) 0%, var(--bm-light) 100%);
}

.product-cat-header h3 {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--blue-dark);
}

.product-cat-desc {
  font-size: 1rem;
  color: var(--text-body);
  line-height: 1.7;
  margin-bottom: 20px;
}

.product-list {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
}

.product-list li {
  padding: 12px 0;
  border-bottom: 1px solid var(--border);
  font-size: 0.95rem;
  color: var(--text-body);
  line-height: 1.7;
}

.product-list li:last-child {
  border-bottom: none;
}

.product-list li strong {
  color: var(--blue-dark);
  font-weight: 600;
}

.product-cat-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(
    135deg,
    var(--blue-dark) 0%,
    var(--blue-mid) 100%
  );
  color: var(--white);
  padding: 10px 18px;
  border-radius: 999px;
  font-size: 0.85rem;
  font-weight: 600;
}

.product-cat-brand {
  display: inline-block;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text-muted);
  padding: 8px 16px;
  background: var(--white);
  border-radius: 999px;
  border: 1px solid var(--border);
}

.oem-banner {
  margin-top: 48px;
  background: linear-gradient(
    135deg,
    var(--blue-deeper) 0%,
    var(--blue-rich) 100%
  );
  border-radius: var(--radius-xl);
  padding: 40px 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
}

.oem-content {
  display: flex;
  align-items: flex-start;
  gap: 24px;
}

.oem-icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--glass-16);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.8rem;
  color: var(--white);
  border: 2px solid var(--glass-border-28);
  flex-shrink: 0;
}

.oem-text h4 {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--white);
  margin-bottom: 10px;
}

.oem-text p {
  font-size: 0.95rem;
  color: var(--white-70);
  line-height: 1.7;
  max-width: 700px;
}

.oem-banner .btn-primary-pill {
  flex-shrink: 0;
  background: var(--white);
  color: var(--blue-dark);
}

.oem-banner .btn-primary-pill:hover {
  background: var(--off-white);
}

@media (max-width: 768px) {
  .oem-banner {
    flex-direction: column;
    text-align: center;
    padding: 32px 24px;
  }
  .oem-content {
    flex-direction: column;
    align-items: center;
  }
  .oem-icon {
    margin: 0 auto;
  }
  .product-category-card {
    padding: 24px;
  }
}

/* ═══════════════════════════════════════════════════════════════
   ENHANCED VISUAL SECTIONS FOR OUR-STORY PAGE
   ════════════════════════════════════════════════════════════════ */

/* ── About Visual Section ── */
.about-visual-section {
  padding: 100px 0;
  background: linear-gradient(180deg, var(--white) 0%, var(--off-white) 100%);
}

.about-visual-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 60px;
  align-items: center;
}

.about-image-wrap {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}

.about-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  background: linear-gradient(
    135deg,
    var(--blue-dark) 0%,
    var(--blue-mid) 100%
  );
  padding: 40px;
}

.about-image-badge {
  position: absolute;
  bottom: 20px;
  left: 20px;
  background: var(--white);
  border-radius: var(--radius-md);
  padding: 14px 18px;
  display: flex;
  align-items: center;
  gap: 12px;
  box-shadow: var(--shadow-md);
}

.about-image-badge i {
  font-size: 1.4rem;
  color: var(--blue-mid);
}

.about-image-badge span {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text-dark);
  line-height: 1.3;
}

.about-visual-content .section-title {
  margin-bottom: 20px;
}

.about-lead {
  font-size: 1.15rem;
  color: var(--blue-dark);
  font-weight: 500;
  line-height: 1.7;
  margin-bottom: 16px;
}

.about-visual-content p {
  color: var(--text-body);
  line-height: 1.8;
  margin-bottom: 24px;
}

.about-highlights {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.about-highlight-item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 1rem;
  color: var(--text-dark);
  font-weight: 500;
}

.about-highlight-item i {
  color: #22c55e;
  font-size: 1.2rem;
}

/* ── Mission Section ── */
.mission-section {
  padding: 80px 0;
  background: linear-gradient(
    135deg,
    var(--blue-deeper) 0%,
    var(--blue-rich) 50%,
    var(--blue-mid) 100%
  );
  position: relative;
  overflow: hidden;
}

.mission-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 50%, var(--glass-8) 0%, transparent 40%),
    radial-gradient(circle at 80% 50%, var(--glass-5) 0%, transparent 40%);
}

.mission-card {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  max-width: 800px;
  margin: 0 auto;
}

.mission-icon-ring {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background: var(--glass-12);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 32px;
  border: 2px solid var(--glass-border-28);
}

.mission-icon {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--white) 0%, var(--off-white) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  color: var(--blue-dark);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
}

.mission-content h2 {
  font-size: clamp(1.8rem, 4vw, 2.5rem);
  font-weight: 700;
  color: var(--white);
  margin-bottom: 24px;
}

.mission-motto {
  margin-bottom: 32px;
  padding: 24px 32px;
  background: var(--glass-12);
  border-radius: var(--radius-lg);
  border: 1px solid var(--glass-border-28);
}

.motto-text {
  display: block;
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--white);
  margin-bottom: 8px;
  font-family: "Noto Sans Devanagari", "Poppins", sans-serif;
}

.motto-translation {
  display: block;
  font-size: 1.1rem;
  color: var(--white-70);
  font-style: italic;
}

.mission-details {
  display: flex;
  flex-direction: column;
  gap: 20px;
  max-width: 800px;
  margin: 0 auto;
}

.mission-item {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  text-align: left;
  padding: 16px 20px;
  background: var(--glass-8);
  border-radius: var(--radius-md);
  border: 1px solid var(--glass-border-22);
}

.mission-item i {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--glass-16);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  color: var(--white);
  border: 1px solid var(--glass-border-28);
  flex-shrink: 0;
}

.mission-item div {
  font-size: 1rem;
  color: var(--white-78);
  line-height: 1.7;
}

.mission-item strong {
  color: var(--white);
  font-weight: 600;
}

/* ── Manufacturing Section ── */
.manufacturing-section {
  padding: 100px 0;
  background: var(--white);
}

.mfg-features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin-top: 48px;
}

.mfg-feature-card {
  background: var(--off-white);
  border-radius: var(--radius-lg);
  padding: 36px 28px;
  border: 1px solid var(--border);
  transition: all 0.3s ease;
}

.mfg-feature-card:hover {
  background: var(--white);
  box-shadow: var(--shadow-md);
  transform: translateY(-6px);
}

.mfg-feature-visual {
  position: relative;
  width: 80px;
  height: 80px;
  border-radius: var(--radius-lg);
  background: linear-gradient(
    135deg,
    var(--blue-dark) 0%,
    var(--blue-mid) 100%
  );
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  color: var(--white);
  margin-bottom: 24px;
  overflow: hidden;
}

.mfg-visual--clean {
  background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
}

.mfg-visual--lab {
  background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
}

.mfg-glow {
  position: absolute;
  inset: 0;
  background: radial-gradient(
    circle,
    rgba(255, 255, 255, 0.3) 0%,
    transparent 70%
  );
}

.mfg-feature-card h4 {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--blue-dark);
  margin-bottom: 12px;
}

.mfg-feature-card > p {
  font-size: 0.95rem;
  color: var(--text-body);
  line-height: 1.7;
  margin-bottom: 20px;
}

.mfg-feature-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.mfg-feature-list li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.9rem;
  color: var(--text-body);
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
}

.mfg-feature-list li:last-child {
  border-bottom: none;
}

.mfg-feature-list li i {
  color: #22c55e;
  font-size: 0.85rem;
}

/* ── Capabilities Section ── */
.capabilities-section {
  padding: 100px 0;
  background: linear-gradient(180deg, var(--off-white) 0%, var(--white) 100%);
}

.capabilities-header {
  text-align: center;
  margin-bottom: 48px;
}

.capabilities-visual {
  background: var(--white);
  border-radius: var(--radius-xl);
  padding: 40px;
  margin-bottom: 48px;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border);
}

.capability-flow {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.capability-step {
  flex: 1;
  text-align: center;
}

.capability-icon-wrap {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--blue-light) 0%, var(--white) 100%);
  border: 2px solid var(--blue-mid);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  color: var(--blue-dark);
  margin: 0 auto 16px;
}

.capability-step h5 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--blue-dark);
  margin-bottom: 6px;
}

.capability-step p {
  font-size: 0.85rem;
  color: var(--text-muted);
  margin: 0;
}

.capability-arrow {
  font-size: 1.2rem;
  color: var(--blue-mid);
  flex-shrink: 0;
}

.capabilities-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

.capability-card {
  background: linear-gradient(
    135deg,
    var(--blue-dark) 0%,
    var(--blue-rich) 100%
  );
  border-radius: var(--radius-lg);
  padding: 28px 24px;
  text-align: center;
  color: var(--white);
  transition: all 0.3s ease;
}

.capability-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px var(--blue-glow-22);
}

.capability-stat {
  font-size: 2.2rem;
  font-weight: 800;
  display: block;
  margin-bottom: 8px;
}

.capability-card span {
  font-size: 0.9rem;
  opacity: 0.85;
}

/* ── Commitment Section ── */
.commitment-section {
  padding: 100px 0;
  background: var(--white);
}

.commitment-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin-top: 48px;
}

.commitment-card {
  background: var(--off-white);
  border-radius: var(--radius-lg);
  padding: 0 0 28px;
  overflow: hidden;
  transition: all 0.3s ease;
  border: 1px solid var(--border);
}

.commitment-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-6px);
}

.commitment-visual {
  position: relative;
  height: 160px;
  background: linear-gradient(
    135deg,
    var(--blue-light) 0%,
    var(--off-white) 100%
  );
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 24px;
  overflow: hidden;
}

.commitment-icon {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  color: var(--white);
  position: relative;
  z-index: 2;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
}

.commitment-icon--quality {
  background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
}

.commitment-icon--sustain {
  background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
}

.commitment-icon--afford {
  background: linear-gradient(135deg, #ec4899 0%, #db2777 100%);
}

.commitment-pattern {
  position: absolute;
  inset: 0;
  opacity: 0.1;
  background-image: radial-gradient(
    circle,
    var(--blue-dark) 2px,
    transparent 2px
  );
  background-size: 20px 20px;
}

.commitment-card h4 {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--blue-dark);
  margin: 0 24px 12px;
}

.commitment-card > p {
  font-size: 0.95rem;
  color: var(--text-body);
  line-height: 1.7;
  margin: 0 24px 20px;
}

.commitment-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 24px;
}

.commit-badge {
  font-size: 0.75rem;
  font-weight: 600;
  padding: 6px 14px;
  border-radius: 999px;
  background: var(--white);
  color: var(--blue-dark);
  border: 1px solid var(--border);
}

/* ── Community Section ── */
.community-section {
  padding: 100px 0;
  background: linear-gradient(180deg, var(--off-white) 0%, var(--white) 100%);
}

.community-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 60px;
  align-items: center;
}

.community-content .section-title {
  margin-bottom: 16px;
}

.community-lead {
  font-size: 1.1rem;
  color: var(--text-body);
  line-height: 1.7;
  margin-bottom: 32px;
}

.community-initiatives {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.initiative-card {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: 24px;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border);
  transition: all 0.3s ease;
}

.initiative-card:hover {
  transform: translateX(8px);
  box-shadow: var(--shadow-md);
}

.initiative-icon {
  width: 56px;
  height: 56px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  color: var(--white);
  flex-shrink: 0;
}

.initiative-icon--health {
  background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
}

.initiative-icon--women {
  background: linear-gradient(135deg, #8b5cf6 0%, #7c3aed 100%);
}

.initiative-icon--disaster {
  background: linear-gradient(135deg, #06b6d4 0%, #0891b2 100%);
}

.initiative-info h4 {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--blue-dark);
  margin-bottom: 6px;
}

.initiative-info p {
  font-size: 0.9rem;
  color: var(--text-body);
  line-height: 1.6;
  margin: 0;
}

.community-visual {
  display: flex;
  justify-content: center;
  align-items: center;
}

.community-image-stack {
  position: relative;
}

.community-img {
  width: 280px;
  height: 280px;
  border-radius: var(--radius-xl);
  background: linear-gradient(
    135deg,
    var(--blue-dark) 0%,
    var(--blue-mid) 100%
  );
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 6rem;
  color: var(--white);
  box-shadow: var(--shadow-lg);
}

.community-stats-float {
  position: absolute;
  bottom: -20px;
  left: -30px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.comm-stat {
  background: var(--white);
  border-radius: var(--radius-md);
  padding: 16px 20px;
  box-shadow: var(--shadow-md);
  text-align: center;
  border: 1px solid var(--border);
}

.comm-stat strong {
  display: block;
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--blue-dark);
  margin-bottom: 4px;
}

.comm-stat span {
  font-size: 0.75rem;
  color: var(--text-muted);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* ── Brand Showcase Compact ── */
.brand-showcase-compact {
  display: flex;
  justify-content: center;
  gap: 40px;
  flex-wrap: wrap;
  margin-top: 48px;
}

.brand-compact-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  text-decoration: none;
  color: inherit;
  padding: 24px 32px;
  background: var(--white);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  transition: all 0.3s ease;
  min-width: 140px;
}

.brand-compact-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-md);
  border-color: var(--blue-mid);
}

.brand-compact-logo {
  width: 80px;
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.brand-compact-logo img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

.brand-compact-logo i {
  font-size: 2.5rem;
  color: var(--blue-mid);
}

.brand-compact-name {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-dark);
}

/* ── Responsive for Visual Sections ── */
@media (max-width: 1024px) {
  .about-visual-grid,
  .community-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .mfg-features-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .commitment-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .capabilities-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .capability-flow {
    flex-direction: column;
    gap: 24px;
  }
  .capability-arrow {
    transform: rotate(90deg);
  }
}

@media (max-width: 768px) {
  .mfg-features-grid,
  .commitment-grid,
  .capabilities-grid {
    grid-template-columns: 1fr;
  }
  .community-stats-float {
    position: static;
    flex-direction: row;
    justify-content: center;
    margin-top: 24px;
  }
  .community-img {
    width: 200px;
    height: 200px;
    font-size: 4rem;
  }
  .brand-showcase-compact {
    gap: 16px;
  }
  .brand-compact-card {
    min-width: 120px;
    padding: 20px 24px;
  }
  .mission-pillars {
    gap: 24px;
  }
}

@media (max-width: 480px) {
  .about-image-badge {
    display: none;
  }
  .initiative-card {
    flex-direction: column;
    text-align: center;
  }
  .initiative-icon {
    margin: 0 auto;
  }
  .capabilities-visual {
    padding: 24px;
  }
  .mission-icon-ring {
    width: 100px;
    height: 100px;
  }
  .mission-icon {
    width: 64px;
    height: 64px;
    font-size: 1.6rem;
  }
  .mission-quote {
    font-size: 1.05rem;
  }
}

/* ═══ HOME VIDEO BAND (full-width carousel + BHI navy blues) ═══ */
.pv-video-band {
  width: 100%;
  padding: 72px 0 88px;
  background:
    radial-gradient(
      120% 80% at 50% -10%,
      rgba(0, 127, 198, 0.35),
      transparent 55%
    ),
    linear-gradient(
      165deg,
      var(--blue-deeper, #013f78) 0%,
      var(--blue-dark, #014785) 42%,
      var(--blue-rich, #015fa8) 88%,
      var(--blue-mid, #007fc6) 100%
    );
  position: relative;
  overflow: hidden;
}
/* Headline + tabs: same width as rest of site (.section-container), not full-bleed */
.pv-video-band__intro {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 clamp(20px, 4vw, 36px);
  box-sizing: border-box;
  position: relative;
  z-index: 1;
}
/* Only the swiper row spans the full viewport width */
.pv-video-band__carousel {
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  position: relative;
  z-index: 1;
}
.pv-video-band__eyebrow {
  margin: 0 0 12px;
  text-align: center;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.58);
}
.pv-video-band__title {
  margin: 0 auto 16px;
  max-width: 920px;
  text-align: center;
  font-size: clamp(1.65rem, 4vw, 2.75rem);
  font-weight: 800;
  line-height: 1.12;
  letter-spacing: -0.02em;
  color: #fff;
}
.pv-video-band__lead {
  margin: 0 auto 40px;
  max-width: 640px;
  text-align: center;
  font-size: 1rem;
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.72);
}

/* Tabs under headline */
.pv-tabs-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: 0 0 32px;
  padding: 0 0 4px;
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.35) transparent;
}
.pv-tabs-scroll::-webkit-scrollbar {
  height: 4px;
}
.pv-tabs-scroll::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.35);
  border-radius: 999px;
}
.pv-tabs {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  gap: 18px;
  min-width: max-content;
  margin: 0 auto 2px;
  padding: 0 2px;
}
.pv-tab {
  position: relative;
  background: none;
  border: none;
  padding: 0 6px 12px;
  cursor: pointer;
  font-family: inherit;
  text-align: center;
  color: rgba(255, 255, 255, 0.48);
  transition: color 0.25s ease;
}
.pv-tab:hover,
.pv-tab:focus-visible {
  color: rgba(255, 255, 255, 0.82);
  outline: none;
}
.pv-tab.is-active {
  color: #fff;
}
.pv-tab__name {
  display: block;
  font-size: clamp(0.92rem, 1.2vw, 1.06rem);
  font-weight: 700;
  white-space: nowrap;
}
.pv-tab__sub {
  display: block;
  margin-top: 4px;
  font-size: 0.78rem;
  font-weight: 500;
  opacity: 0.85;
  white-space: nowrap;
}
.pv-tab__line {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 3px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.22);
  transition:
    background 0.25s ease,
    height 0.25s ease,
    opacity 0.25s ease;
}
.pv-tab.is-active .pv-tab__line {
  height: 4px;
  background: #fff;
  opacity: 1;
}

/* Swiper shell — spans nearly full viewport width */
.pv-swiper-shell {
  position: relative;
  width: 100%;
  max-width: 1480px;
  margin: 0 auto;
}
.pv-swiper {
  overflow: visible;
  padding: 10px 8px 54px;
  width: 100%;
}
.pv-swiper .swiper-wrapper {
  align-items: stretch;
}
.pv-swiper .swiper-slide {
  box-sizing: border-box;
}
/* No scale — scaling left empty gutters inside each slide. Fade + overlay only. */
.pv-slide {
  height: auto;
  opacity: 0.36;
  transform: none;
  transition: opacity 0.4s ease;
  cursor: pointer;
}
.pv-slide.swiper-slide-active {
  opacity: 1;
  cursor: default;
  z-index: 3;
}
.pv-slide.swiper-slide-prev,
.pv-slide.swiper-slide-next {
  opacity: 0.52;
  z-index: 2;
}

/* Fill each slide edge-to-edge so neighboring videos touch (no gutter inside slide) */
.pv-card {
  width: 100%;
  max-width: 920px;
  margin: 0 auto;
  padding: 0 8px;
  box-sizing: border-box;
}
.pv-card__frame {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  margin: 0;
  border-radius: clamp(12px, 1.25vw, 16px);
  overflow: hidden;
  background: #022949;
  box-shadow: 0 24px 48px rgba(1, 36, 68, 0.38);
}
.pv-slide:not(.swiper-slide-active) .pv-card__frame::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 8;
  border-radius: inherit;
  background: rgba(1, 71, 133, 0.72);
  pointer-events: none;
}
.pv-slide:not(.swiper-slide-active) .pv-card__quote {
  display: none;
}
.pv-slide.swiper-slide-active .pv-card__frame::after {
  display: none;
}

.pv-card__player {
  position: absolute;
  inset: 0;
  z-index: 2;
  background: #000;
}
.pv-card__iframe,
.pv-card__video-el {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

.pv-card__poster {
  position: absolute;
  inset: 0;
  z-index: 3;
  transition:
    opacity 0.35s ease,
    visibility 0.35s ease;
}
.pv-card__poster.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.pv-card__poster img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.pv-card__poster-fallback {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  font-size: 3rem;
  color: rgba(255, 255, 255, 0.35);
  background: linear-gradient(
    145deg,
    var(--blue-deeper, #013f78),
    var(--blue-mid, #007fc6)
  );
}

.pv-card__play-btn {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: clamp(72px, 10vw, 92px);
  height: clamp(72px, 10vw, 92px);
  border-radius: 50%;
  border: none;
  background: rgba(255, 255, 255, 0.95);
  color: var(--blue-dark, #014785);
  font-size: 1.25rem;
  cursor: pointer;
  box-shadow: 0 14px 40px rgba(0, 0, 0, 0.45);
  transition:
    transform 0.2s ease,
    background 0.2s ease;
  z-index: 5;
}
.pv-card__play-btn:hover {
  transform: translate(-50%, -50%) scale(1.06);
  background: #fff;
}
.pv-slide:not(.swiper-slide-active) .pv-card__play-btn {
  display: none;
}

/* Quote overlay on video (left side, gold heart) */
.pv-card__quote {
  position: absolute;
  left: clamp(16px, 3.5vw, 36px);
  top: 50%;
  transform: translateY(-50%);
  max-width: min(46%, 380px);
  z-index: 7;
  display: flex;
  gap: 10px;
  align-items: flex-start;
  pointer-events: none;
  text-align: left;
}
.pv-card__quote-icon {
  flex-shrink: 0;
  margin-top: 2px;
  font-size: 1.15rem;
  line-height: 1;
  color: #ffd54f;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.5);
}
.pv-card__quote-text {
  margin: 0;
  font-size: clamp(0.92rem, 1.55vw, 1.25rem);
  font-weight: 600;
  line-height: 1.35;
  color: #fff;
  text-shadow: 0 2px 16px rgba(0, 0, 0, 0.55);
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.pv-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.35);
  background: rgba(255, 255, 255, 0.14);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 12;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition:
    background 0.2s ease,
    transform 0.2s ease,
    border-color 0.2s ease;
}
.pv-nav:hover {
  background: rgba(255, 255, 255, 0.28);
  border-color: rgba(255, 255, 255, 0.55);
  transform: translateY(-50%) scale(1.05);
}
.pv-nav.swiper-button-disabled {
  opacity: 0.28;
  pointer-events: none;
}
.pv-nav--prev {
  left: clamp(8px, 2vw, 24px);
}
.pv-nav--next {
  right: clamp(8px, 2vw, 24px);
}

.pv-pagination {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 18px;
  display: flex;
  justify-content: center;
  gap: 7px;
}
.pv-pagination .swiper-pagination-bullet {
  width: 7px;
  height: 7px;
  background: rgba(255, 255, 255, 0.35);
  opacity: 1;
  transition:
    width 0.25s ease,
    background 0.25s ease;
  border-radius: 999px;
}
.pv-pagination .swiper-pagination-bullet-active {
  width: 22px;
  background: #fff;
}

@media (max-width: 992px) {
  .pv-video-band {
    padding: 56px 0 72px;
  }
  .pv-video-band__intro {
    padding: 0 clamp(14px, 4vw, 36px);
  }
  .pv-tabs-scroll {
    margin-bottom: 26px;
  }
  .pv-tabs {
    justify-content: flex-start;
    gap: 12px;
    min-width: max-content;
  }
  .pv-nav {
    width: 42px;
    height: 42px;
  }
}

@media (max-width: 640px) {
  .pv-video-band__lead {
    margin-bottom: 28px;
  }
  .pv-card__frame {
    border-radius: 12px;
  }
  .pv-card {
    max-width: none;
    padding: 0 2px;
  }
  .pv-card__quote {
    max-width: 92%;
    top: auto;
    bottom: 14px;
    transform: none;
    flex-direction: column;
    gap: 6px;
  }
  .pv-card__quote-icon {
    font-size: 1rem;
  }
  .pv-card__quote-text {
    font-size: 0.88rem;
    line-height: 1.4;
  }
  .pv-nav {
    display: none;
  }
  .pv-swiper {
    padding-bottom: 44px;
  }
}

/* Modal player */
.home-video-modal {
  position: fixed;
  inset: 0;
  z-index: 9000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.home-video-modal[hidden] {
  display: none;
}
.home-video-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(2, 18, 36, 0.8);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.home-video-modal__dialog {
  position: relative;
  width: min(960px, 100%);
  background: #0a1726;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.55);
}
.home-video-modal__player {
  position: relative;
  aspect-ratio: 16 / 9;
  background: #000;
}
.home-video-modal__player iframe,
.home-video-modal__player video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}
.home-video-modal__title {
  margin: 0;
  padding: 16px 20px;
  font-size: 1rem;
  font-weight: 600;
  color: #fff;
}
.home-video-modal__title:empty {
  display: none;
}
.home-video-modal__close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 0;
  background: rgba(255, 255, 255, 0.92);
  color: var(--blue-dark);
  font-size: 0.95rem;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  transition:
    background 0.2s ease,
    transform 0.2s ease;
}
.home-video-modal__close:hover {
  background: #fff;
  transform: scale(1.05);
}
body.home-video-modal-open {
  overflow: hidden;
}

/* ═══════════════════════════════════════════════════════════
   PHASE 1 — Global shell upgrades
   ═══════════════════════════════════════════════════════════ */

/* ─────────────── FOOTER TRUST STRIP ─────────────── */
.footer-trust-strip {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0 36px;
  padding: 18px 36px;
  border-top: 1px solid rgba(1, 71, 133, 0.1);
  border-bottom: 1px solid rgba(1, 71, 133, 0.1);
  background: rgba(0, 127, 198, 0.03);
}
.footer-trust-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.8rem;
  font-weight: 600;
  color: #014785;
  letter-spacing: 0.02em;
  white-space: nowrap;
  padding: 6px 0;
}
.footer-trust-item i {
  font-size: 1rem;
  color: #007fc6;
}

/* ─────────────── MOBILE STICKY UTILITY BAR ─────────────── */
.mobile-util-bar {
  display: none;
}
@media (max-width: 768px) {
  .mobile-util-bar {
    display: flex;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 300;
    background: rgba(255, 255, 255, 0.97);
    backdrop-filter: blur(20px) saturate(200%);
    -webkit-backdrop-filter: blur(20px) saturate(200%);
    border-top: 1px solid rgba(1, 71, 133, 0.1);
    box-shadow: 0 -4px 24px rgba(1, 71, 133, 0.1);
    padding: 0;
    padding-bottom: env(safe-area-inset-bottom, 0);
    transition:
      transform 0.24s ease,
      opacity 0.24s ease;
  }
  .mobile-util-bar.is-hidden {
    transform: translateY(100%);
    opacity: 0;
    pointer-events: none;
  }
  .mobile-util-bar__item {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 3px;
    padding: 10px 4px;
    color: #4a6080;
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.03em;
    text-decoration: none;
    position: relative;
    transition: color 0.2s ease;
    -webkit-tap-highlight-color: transparent;
  }
  .mobile-util-bar__item:active {
    background: rgba(0, 127, 198, 0.06);
  }
  .mobile-util-bar__item.is-primary {
    color: #007fc6;
  }
  .mobile-util-bar__item i {
    font-size: 1.05rem;
    line-height: 1;
  }
  .mobile-util-bar__badge {
    position: absolute;
    top: 6px;
    right: calc(50% - 16px);
    background: #007fc6;
    color: #fff;
    font-size: 0.6rem;
    font-weight: 700;
    min-width: 16px;
    height: 16px;
    border-radius: 50px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 4px;
  }
  /* Push page content above the util bar */
  body {
    padding-bottom: calc(60px + env(safe-area-inset-bottom, 0px));
  }
  /* Keep back-to-top above mobile bar */
  .back-to-top-btn {
    bottom: calc(64px + env(safe-area-inset-bottom, 0px)) !important;
  }
  /* Period tracker sticky button: move above bar */
  #period-tracker-sticky {
    bottom: calc(68px + env(safe-area-inset-bottom, 0px)) !important;
  }
}

/* Period tracker sticky floating button */
#period-tracker-sticky {
  position: fixed;
  bottom: 5.5rem;
  right: 1.5rem;
  z-index: 999;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  background: #d4346b;
  color: #fff;
  border-radius: 999px;
  padding: 0.65rem 1.1rem;
  font-size: 0.85rem;
  font-weight: 600;
  text-decoration: none;
  box-shadow: 0 4px 16px rgba(212, 52, 107, 0.35);
  opacity: 0;
  transform: translateY(10px);
  transition:
    opacity 0.3s ease,
    transform 0.3s ease;
}

/* ═══════════════════════════════════════════════════════════
   PHASE 2 — Homepage upgrades
   ═══════════════════════════════════════════════════════════ */

/* ─────────────── SHOP BY NEED / CATEGORY ─────────────── */
.shop-by-need {
  padding: 64px 0 56px;
  background: #fff;
}
.shop-by-need__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(148px, 1fr));
  gap: 16px;
  margin-top: 36px;
}
.need-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 22px 12px 18px;
  border-radius: 20px;
  border: 1px solid rgba(1, 71, 133, 0.1);
  background: linear-gradient(145deg, #f8fbff 0%, #fff 100%);
  text-align: center;
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    border-color 0.2s ease;
  text-decoration: none;
  color: inherit;
}
.need-card:hover {
  transform: translateY(-3px);
  border-color: rgba(0, 127, 198, 0.28);
  box-shadow: 0 10px 32px rgba(1, 71, 133, 0.1);
}
.need-card__icon {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background: linear-gradient(135deg, #e0f0fb 0%, #f0f7ff 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  color: #007fc6;
  flex-shrink: 0;
}
.need-card__label {
  font-size: 0.82rem;
  font-weight: 600;
  color: #0f2944;
  line-height: 1.3;
}
.need-card__count {
  font-size: 0.72rem;
  color: #607a96;
  font-weight: 500;
}

/* ─────────────── PERIOD TRACKER SECTION ─────────────── */
.period-tracker-section {
  padding: 56px 0;
  background: linear-gradient(145deg, #fff5f9 0%, #fdf7ff 50%, #f5f9ff 100%);
}
.period-tracker-section__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
  max-width: 900px;
  margin: 0 auto;
  padding: 0 24px;
}
.period-tracker-section__heading {
  margin-bottom: 0.8rem;
  color: #214b76;
}
.period-tracker-section__lead {
  color: #555;
  font-size: 0.95rem;
  line-height: 1.6;
  margin-bottom: 1.2rem;
}
.period-tracker-section__features {
  list-style: none;
  padding: 0;
  margin: 0 0 1.5rem 0;
  font-size: 0.9rem;
}
.period-tracker-section__features li {
  padding: 0.4rem 0;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.period-tracker-section__features .fa-check-circle {
  color: #d4346b;
}
.period-tracker-section__visual {
  text-align: center;
}
.period-tracker-section__icon {
  font-size: 4rem;
  color: #d4346b;
  margin-bottom: 1.2rem;
  opacity: 0.9;
}
.period-tracker-section__card {
  background: #f8fbff;
  border-radius: 12px;
  padding: 1.2rem;
  border: 1px solid #dce7f3;
  font-size: 0.85rem;
  color: #555;
}
.period-tracker-section__card strong {
  color: #214b76;
  display: block;
  margin-bottom: 0.5rem;
}

/* ─────────────── BTN PRIMARY PILL ─────────────── */
.btn-primary-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: linear-gradient(135deg, #d4346b 0%, #e8556a 100%);
  color: #fff;
  border-radius: 999px;
  padding: 0.65rem 1.4rem;
  font-size: 0.88rem;
  font-weight: 600;
  text-decoration: none;
  box-shadow: 0 4px 16px rgba(212, 52, 107, 0.3);
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}
.btn-primary-pill:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(212, 52, 107, 0.4);
  color: #fff;
}

/* ═══════════════════════════════════════════════════════════
   PHASE 3 — Catalog upgrades
   ═══════════════════════════════════════════════════════════ */

/* ─────────────── ACTIVE FILTER CHIPS ─────────────── */
.filter-chips-bar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  padding: 10px 0 4px;
}
.filter-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px 5px 10px;
  border-radius: 999px;
  background: rgba(0, 127, 198, 0.1);
  border: 1px solid rgba(0, 127, 198, 0.22);
  color: #014785;
  font-size: 0.78rem;
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
  transition: background 0.15s ease;
}
.filter-chip:hover {
  background: rgba(0, 127, 198, 0.18);
}
.filter-chip__remove {
  font-size: 0.75rem;
  color: #607a96;
  line-height: 1;
  margin-left: 2px;
}
.filter-chips-bar__clear {
  font-size: 0.78rem;
  font-weight: 600;
  color: #b91c1c;
  text-decoration: none;
  padding: 5px 8px;
  border-radius: 8px;
  transition: background 0.15s ease;
}
.filter-chips-bar__clear:hover {
  background: #fff5f5;
}

/* ═══════════════════════════════════════════════════════════
   PHASE 4 — Product detail upgrades
   ═══════════════════════════════════════════════════════════ */

/* ─────────────── PDP TRUST STRIP ─────────────── */
.pdp-trust-strip {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px 18px;
  margin-top: 18px;
  padding: 14px 18px;
  border-radius: 14px;
  background: linear-gradient(135deg, #f4f9ff 0%, #edf5ff 100%);
  border: 1px solid rgba(0, 127, 198, 0.12);
}
.pdp-trust-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.75rem;
  font-weight: 600;
  color: #014785;
  white-space: nowrap;
}
.pdp-trust-item i {
  color: #007fc6;
  font-size: 0.9rem;
}

/* ─────────────── PDP STICKY BUY BOX (desktop) ─────────────── */
@media (min-width: 900px) {
  .product-detail-info {
    position: sticky;
    top: calc(72px + 20px); /* navbar height + offset */
    align-self: start;
  }
}

/* ═══════════════════════════════════════════════════════════
   PHASE 1 — Mobile responsive footer cleanup
   ═══════════════════════════════════════════════════════════ */
@media (max-width: 600px) {
  .footer-trust-strip {
    gap: 0 20px;
    padding: 14px 20px;
  }
  .footer-trust-item {
    font-size: 0.72rem;
    gap: 6px;
  }
  .shop-by-need__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
  }
  .need-card {
    padding: 16px 8px 12px;
  }
  .need-card__icon {
    width: 42px;
    height: 42px;
    font-size: 1.15rem;
    border-radius: 11px;
  }
  .period-tracker-section__inner {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .period-tracker-section__visual {
    order: -1;
  }
}

/* ═══════════════════════════════════════════════════════════
   AUTH MODAL  (cart.php inline checkout gate)
══════════════════════════════════════════════════════════════ */
.auth-modal-wrap {
  position: fixed;
  inset: 0;
  display: none;
  z-index: 3000;
}
.auth-modal-wrap.open {
  display: block;
}
.auth-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(5, 22, 43, 0.58);
}
.auth-modal {
  position: relative;
  width: min(760px, calc(100vw - 2rem));
  max-height: calc(100vh - 2rem);
  overflow: auto;
  margin: 1rem auto;
  background: #fff;
  border-radius: 14px;
  padding: 1.2rem;
  box-shadow: 0 20px 52px rgba(8, 30, 56, 0.3);
}
.auth-modal h3 {
  color: #0b2f52;
}
.auth-modal .form-group {
  margin-bottom: 0.9rem;
}
.auth-modal .form-group label {
  display: block;
  margin-bottom: 0.35rem;
  font-weight: 600;
  color: #153a61;
  font-size: 0.95rem;
}
.auth-modal .form-group input,
.auth-modal .form-group select,
.auth-modal .form-group textarea {
  width: 100%;
  border: 1px solid #cdddf0;
  border-radius: 10px;
  padding: 0.65rem 0.75rem;
  background: #fff;
  color: #0c2d4d;
  font-size: 0.95rem;
  line-height: 1.35;
}
.auth-modal .form-group select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, #2a5f93 50%),
    linear-gradient(135deg, #2a5f93 50%, transparent 50%);
  background-position:
    calc(100% - 18px) calc(50% - 2px),
    calc(100% - 12px) calc(50% - 2px);
  background-size:
    6px 6px,
    6px 6px;
  background-repeat: no-repeat;
  padding-right: 2rem;
}
.auth-modal .form-group textarea {
  min-height: 86px;
  resize: vertical;
}
.auth-modal .form-group input:focus,
.auth-modal .form-group select:focus,
.auth-modal .form-group textarea:focus {
  outline: none;
  border-color: #4596dd;
  box-shadow: 0 0 0 3px rgba(69, 150, 221, 0.2);
}
.auth-pane {
  display: none;
}
.auth-pane.active {
  display: block;
}
.auth-head {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 0.5rem;
}
.auth-required-note {
  background: #eef7ff;
  border: 1px solid #c9e2ff;
  color: #0b3e6d;
  padding: 0.6rem 0.8rem;
  border-radius: 8px;
  margin-bottom: 0.85rem;
}
.auth-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.8rem;
}
.auth-grid .form-group.full {
  grid-column: 1 / -1;
}
.auth-action-row {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
}
@media (max-width: 700px) {
  .auth-grid {
    grid-template-columns: 1fr;
  }
  .auth-modal {
    padding: 1rem;
  }
  .auth-action-row .btn-primary-pill,
  .auth-action-row .btn-outline-blue {
    width: 100%;
    text-align: center;
    justify-content: center;
  }
}

/* ═══════════════════════════════════════════════════════════
   CART — order summary & action row
══════════════════════════════════════════════════════════════ */
.cart-summary {
  display: block;
  border-top: 0;
  padding-top: 0;
}
.cart-order-summary {
  background: #fff;
  border: 1px solid #d8e4f0;
  border-radius: 14px;
  padding: 1rem;
  box-shadow: 0 6px 18px rgba(1, 71, 133, 0.08);
}
.cart-order-summary h4 {
  margin: 0 0 0.75rem;
  color: #083660;
  font-size: 1rem;
  font-weight: 700;
}
.cart-order-summary-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.55rem 0;
  border-bottom: 1px dashed #d8e4f0;
  color: #264b72;
  font-size: 0.92rem;
}
.cart-order-summary-row:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}
.cart-order-summary-total {
  color: #0a2f52;
  font-size: 1.02rem;
  font-weight: 700;
}
.cart-actions {
  margin-top: 0.95rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}
/* Price display in cart */
.cart-price-discount {
  font-weight: 700;
  color: #16a34a;
}
.cart-price-strike {
  text-decoration: line-through;
  color: #94a3b8;
  font-size: 0.85rem;
  margin-left: 4px;
}

/* ═══════════════════════════════════════════════════════════
   ACCOUNT PAGE
══════════════════════════════════════════════════════════════ */
.account-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 1rem;
  margin-bottom: 1rem;
}
.account-card {
  background: #fff;
  border: 1px solid #dce7f3;
  border-radius: 14px;
  padding: 1rem;
  box-shadow: 0 4px 14px rgba(1, 71, 133, 0.08);
}
.account-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.35rem;
}
.account-points {
  font-size: 0.86rem;
  color: #214b76;
  background: #ecf5ff;
  border: 1px solid #d3e7fb;
  border-radius: 999px;
  padding: 0.28rem 0.65rem;
}
.account-card .form-group {
  margin-bottom: 0.85rem;
}
.account-card .form-group label {
  display: block;
  margin-bottom: 0.3rem;
  font-size: 0.82rem;
  font-weight: 600;
  color: #1c4a76;
  letter-spacing: 0.01em;
}
.account-card .form-group input,
.account-card .form-group select,
.account-card .form-group textarea {
  width: 100%;
  border: 1px solid #cfdeef;
  border-radius: 10px;
  padding: 0.58rem 0.7rem;
  background: #fff;
  color: #153b62;
  font-size: 0.92rem;
  line-height: 1.35;
}
.account-card .form-group select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, #2a5f93 50%),
    linear-gradient(135deg, #2a5f93 50%, transparent 50%);
  background-position:
    calc(100% - 18px) calc(50% - 2px),
    calc(100% - 12px) calc(50% - 2px);
  background-size:
    6px 6px,
    6px 6px;
  background-repeat: no-repeat;
  padding-right: 2rem;
}
.account-card .form-group textarea {
  min-height: 90px;
  resize: vertical;
}
.account-card .form-group input:focus,
.account-card .form-group select:focus,
.account-card .form-group textarea:focus {
  outline: none;
  border-color: #4f8fcb;
  box-shadow: 0 0 0 3px rgba(79, 143, 203, 0.16);
}
.account-card .form-group input[disabled] {
  background: #f6f9fc;
  color: #5f7893;
  cursor: not-allowed;
}
.account-orders-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
  background: #fff;
}
.account-orders-table th,
.account-orders-table td {
  padding: 0.65rem 0.55rem;
  border-bottom: 1px solid #e4edf7;
  text-align: left;
}
.account-orders-table th {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #44688d;
}
.account-orders-table tr:last-child td {
  border-bottom: 0;
}
.order-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 0.2rem 0.55rem;
  font-size: 0.75rem;
  font-weight: 700;
}
.order-badge.status-pending {
  background: #fff8e1;
  color: #8a5800;
}
.order-badge.status-processing {
  background: #e8f1ff;
  color: #11478a;
}
.order-badge.status-shipped {
  background: #e8f8ee;
  color: #1f6a37;
}
.order-badge.status-delivered {
  background: #e7f8ef;
  color: #17653a;
}
.order-badge.status-cancelled {
  background: #ffebee;
  color: #9f1f2f;
}
.order-badge.status-paid {
  background: #e7f8ef;
  color: #17653a;
}
.order-badge.status-failed,
.order-badge.status-pendingpay {
  background: #ffebee;
  color: #9f1f2f;
}
.account-actions {
  margin-top: 1rem;
  display: flex;
  gap: 0.65rem;
  flex-wrap: wrap;
}
.account-order-money {
  line-height: 1.35;
}
.account-order-money small {
  display: block;
  color: #5b7796;
}
.promo-chip {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 0.18rem 0.5rem;
  font-size: 0.72rem;
  font-weight: 700;
  background: #eef7ff;
  color: #0d4f85;
  border: 1px solid #cde5fb;
}
/* "Track" button inside orders table */
.btn-track-sm {
  padding: 0.38rem 0.75rem;
  min-height: auto;
  font-size: 0.82rem;
}
/* Period tracker card icon accent */
.icon-period {
  color: #d4346b;
  margin-right: 0.4rem;
}
@media (max-width: 900px) {
  .account-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 640px) {
  .account-head {
    flex-direction: column;
    align-items: flex-start;
  }
  .account-actions {
    width: 100%;
  }
  .account-actions .btn-primary-pill,
  .account-actions .btn-outline-blue {
    width: 100%;
    text-align: center;
  }
}

/* ═══════════════════════════════════════════════════════════
   CHECKOUT — payment option cards
══════════════════════════════════════════════════════════════ */
.payment-method-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0.75rem;
  margin-top: 0.35rem;
}
.payment-option {
  position: relative;
}
.payment-option input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.payment-option-label {
  display: block;
  border: 1px solid #d3e2f2;
  border-radius: 12px;
  padding: 0.75rem 0.85rem;
  background: #fff;
  color: #1d3f66;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}
.payment-option-label:hover {
  border-color: #8cb8e2;
  background: #f7fbff;
}
.payment-option input[type="radio"]:checked + .payment-option-label {
  border-color: var(--blue-mid);
  background: #eaf5ff;
  box-shadow: 0 0 0 2px rgba(0, 127, 198, 0.15);
}

/* ═══════════════════════════════════════════════════════════
   PAYMENT PAGE — Fonepay method chooser
══════════════════════════════════════════════════════════════ */
.fonepay-method-choice {
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
  margin-top: 8px;
}
.fonepay-method-choice .btn-solid-reg,
.fonepay-method-choice .btn-outline-blue {
  display: block;
  text-align: center;
}
/* QR code display panel */
.fonepay-qr-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem;
  border: 1px solid #d3e2f2;
  border-radius: 12px;
  background: #fff;
  margin-bottom: 1rem;
}
.fonepay-qr-wrap img {
  max-width: 100%;
  height: auto;
  width: 280px;
  image-rendering: pixelated;
}
/* Poll status message */
#fonepayQrPollMsg {
  min-height: 1.25rem;
}

/* ═══════════════════════════════════════════════════════════
   TRACK ORDER — page-level helpers
══════════════════════════════════════════════════════════════ */
.track-info-link {
  margin-top: 14px;
  font-size: 0.9rem;
}
.track-cancelled-notice {
  margin-top: 12px;
}
.track-btn-row {
  margin-top: 16px;
}
.track-items-heading {
  margin-top: 24px;
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-dark);
}
.track-items-table {
  margin-top: 8px;
}
/* Default spacing between consecutive notice + content */
.notice + * {
  margin-top: 14px;
}

/* ═══════════════════════════════════════════════════════════
   STORES LOCATOR PAGE
══════════════════════════════════════════════════════════════ */
.stores-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  align-items: start;
  margin-top: 32px;
}
.stores-map-pane {
  position: sticky;
  top: 86px;
}
#storeMapInteractive,
.leaflet-container {
  touch-action: pan-y pinch-zoom;
}
#storeMapInteractive {
  width: 100%;
  height: 540px;
  border-radius: 14px;
  border: 1px solid rgba(1, 71, 133, 0.12);
}
.leaflet-popup-content-wrapper,
.leaflet-popup-content-wrapper.store-map-popup {
  max-width: 150px !important;
  padding: 4px 6px !important;
}
.leaflet-popup-content,
.store-map-popup .leaflet-popup-content {
  font-size: 0.74rem !important;
  line-height: 1.15 !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
}
.leaflet-popup-content strong,
.store-map-popup .leaflet-popup-content strong {
  display: block;
  margin-bottom: 1px;
  font-size: 0.84rem;
}
.store-popup {
  display: grid;
  gap: 1px;
  margin: 0;
}
.store-popup-detail {
  color: #415572;
  font-size: 0.72rem;
  line-height: 1.15;
  margin: 0;
}
.store-popup-detail.store-popup-location,
.store-popup-detail.store-popup-address,
.store-popup-detail.store-popup-brands {
  color: #5b6b8a;
}
.leaflet-popup-tip {
  margin: 0 auto !important;
}
@media (max-width: 900px) {
  .leaflet-popup-content-wrapper,
  .leaflet-popup-content-wrapper.store-map-popup {
    max-width: 180px !important;
  }
  .leaflet-popup-content,
  .store-map-popup .leaflet-popup-content {
    font-size: 0.76rem !important;
  }
}
#mapStatus {
  font-size: 0.8rem;
  color: var(--text-muted);
  margin-top: 8px;
  text-align: center;
}
.store-search-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.store-search-row input {
  flex: 1 1 200px;
  min-width: 0;
  padding: 10px 18px;
  border: 1px solid rgba(1, 71, 133, 0.18);
  border-radius: 999px;
  font-family: var(--font-ui);
  font-size: 0.9rem;
  color: var(--text-dark);
  background: #fff;
  outline: none;
  transition: border-color 0.2s;
}
.store-search-row input:focus {
  border-color: rgba(0, 127, 198, 0.5);
  box-shadow: 0 0 0 3px rgba(0, 127, 198, 0.1);
}
.stores-count {
  font-size: 0.8rem;
  color: var(--text-muted);
  white-space: nowrap;
  flex-shrink: 0;
}
.store-list-scroll {
  max-height: 64vh;
  overflow-y: auto;
  padding-right: 2px;
}
.store-item {
  background: #fff;
  border: 1px solid rgba(1, 71, 133, 0.09);
  border-radius: 14px;
  padding: 16px 18px;
  margin-bottom: 10px;
  box-shadow: 0 2px 12px rgba(1, 71, 133, 0.06);
  transition:
    border-color 0.2s,
    box-shadow 0.2s;
  cursor: pointer;
}
.store-item:hover {
  border-color: rgba(0, 127, 198, 0.2);
}
.store-item.is-active {
  border-color: rgba(0, 127, 198, 0.45);
  box-shadow: 0 6px 24px rgba(1, 71, 133, 0.12);
}
.store-item__name {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text-dark);
  margin-bottom: 4px;
}
.store-item__meta {
  font-size: 0.82rem;
  color: var(--text-body);
  margin-bottom: 3px;
  display: flex;
  align-items: flex-start;
  gap: 5px;
}
.store-item__meta i {
  flex-shrink: 0;
  margin-top: 3px;
  color: var(--text-muted);
}
.store-item__distance {
  font-size: 0.76rem;
  color: var(--text-muted);
  margin: 5px 0 10px;
}
.store-item__brands {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 12px;
}
.store-brand-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--off-white);
  border: 1px solid rgba(1, 71, 133, 0.12);
  border-radius: 999px;
  padding: 3px 10px 3px 6px;
  font-size: 0.74rem;
  font-weight: 600;
  color: var(--blue-dark);
}
.store-brand-chip img {
  width: 16px;
  height: 16px;
  object-fit: contain;
  flex-shrink: 0;
  border-radius: 2px;
}
.store-item__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.store-btn-map {
  display: inline-block;
  padding: 8px 20px;
  border: 2px solid var(--blue-dark);
  color: var(--blue-dark);
  border-radius: 99px;
  font-family: var(--font-ui);
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  background: transparent;
  transition:
    background 0.2s,
    color 0.2s;
}
.store-btn-map:hover {
  background: var(--blue-dark);
  color: #fff;
}
.store-btn-directions {
  display: inline-block;
  padding: 8px 20px;
  background: var(--blue-dark);
  color: #fff;
  border-radius: 99px;
  font-family: var(--font-ui);
  font-size: 0.82rem;
  font-weight: 600;
  text-decoration: none;
  transition: opacity 0.2s;
}
.store-btn-directions:hover {
  opacity: 0.88;
}
/* "You are here" pulsing marker */
.me-marker-pin {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: #0369a1;
  border: 2px solid #fff;
  border-radius: 999px;
  padding: 4px 10px 4px 6px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.28);
  white-space: nowrap;
  animation: me-pulse 1.8s ease-in-out infinite;
}
@keyframes me-pulse {
  0%,
  100% {
    box-shadow:
      0 2px 8px rgba(0, 0, 0, 0.28),
      0 0 0 0 rgba(3, 105, 161, 0.6);
  }
  50% {
    box-shadow:
      0 2px 8px rgba(0, 0, 0, 0.28),
      0 0 0 10px rgba(3, 105, 161, 0);
  }
}
.me-marker-label {
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  font-family: var(--font-ui, sans-serif);
  letter-spacing: 0.03em;
}
.stores-viewmore-wrap {
  text-align: center;
  margin-top: 18px;
}
@media (max-width: 900px) {
  .stores-split {
    grid-template-columns: 1fr;
  }
  .stores-map-pane {
    position: static;
    order: -1;
  }
  #storeMapInteractive {
    height: 300px;
  }
  .store-list-scroll {
    max-height: none;
  }
  .leaflet-popup-content-wrapper {
    max-width: 200px;
  }
  .leaflet-popup-content {
    font-size: 0.82rem;
  }
}
@media (max-width: 480px) {
  .store-search-row {
    flex-direction: column;
    align-items: stretch;
  }
  .store-search-row input {
    flex: 1 1 auto;
  }
  .stores-count {
    text-align: right;
  }
}

/* ═══════════════════════════════════════════════════════════════════════
   PERIOD TRACKER APP
   account/period-tracker.php component styles
═══════════════════════════════════════════════════════════════════════ */

/* Stat summary cards row */
.account-grid--mb {
  margin-bottom: 1.5rem;
}

/* Stat card label */
.tracker-stat-label {
  font-size: 0.85rem;
  color: #666;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  margin-bottom: 0.5rem;
}

/* Stat card big value */
.tracker-stat-value {
  font-size: 2rem;
  font-weight: 800;
  color: #d4346b;
  margin: 0;
  line-height: 1;
}

.tracker-stat-value--blue {
  color: #2a5f93;
}

/* Stat card sub-text */
.tracker-stat-sub {
  font-size: 0.9rem;
  color: #555;
  margin-top: 0.3rem;
  margin-bottom: 0;
}

/* Calendar add-to-cal button wrapper */
.tracker-cal-btn-row {
  margin-top: 0.8rem;
}

/* Required field asterisk */
.tracker-required {
  color: #c41e3a;
}

/* Hint text below inputs */
.form-hint {
  font-size: 0.8rem;
  color: #999;
  display: block;
  margin-top: 0.3rem;
}

/* Checkbox inline row */
.form-group--checkbox {
  display: flex;
  align-items: center;
  gap: 0.55rem;
}
.form-group--checkbox input[type="checkbox"] {
  width: auto;
  flex-shrink: 0;
}
.form-group--checkbox label {
  margin-bottom: 0;
}

/* Tab navigation */
.tracker-tabs {
  margin-bottom: 1.2rem;
  border-bottom: 2px solid #ecf5ff;
  display: flex;
  flex-wrap: wrap;
  gap: 0.15rem;
}
.tracker-tabs .tab-btn {
  background: none;
  border: none;
  padding: 0.8rem 1rem;
  font-size: 0.92rem;
  font-weight: 600;
  color: #999;
  cursor: pointer;
  border-bottom: 3px solid transparent;
  transition:
    color 0.15s,
    border-color 0.15s;
}
.tracker-tabs .tab-btn.is-active {
  color: #2a5f93;
  border-bottom-color: #2a5f93;
}

/* Tab panels */
.tab-content {
  display: none;
}
.tab-content.is-active {
  display: block;
}

/* Account card two-column form row */
.account-card .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.8rem;
}

/* Empty state */
.tracker-empty {
  text-align: center;
  padding: 2rem 0;
  color: var(--text-muted);
}
.tracker-empty i {
  font-size: 2rem;
  margin-bottom: 1rem;
  display: block;
  opacity: 0.5;
}

/* Inline delete form */
.form-inline {
  display: inline;
}

@media (max-width: 900px) {
  .account-card .form-row {
    grid-template-columns: 1fr;
  }
}
