/* ═══════════════════════════════════════════════════════════════════
   bridal.css — Bridal page (scoped)
   All rules namespaced under .bridal-page (body class).
   Pure monochrome palette mirroring the home page — alternating
   SNOW / WHITE light sections against NOIR / BLACK dark sections.
   ═══════════════════════════════════════════════════════════════════ */

.bridal-page {
  --br-ink:    #000000;            /* BLACK */
  --br-deep:   #0A0A0A;            /* hero / dark sections — matches home hp-* dark blocks */
  --br-deep-2: #141414;            /* NOIR */
  --br-cream:  #FFFFFF;            /* WHITE — primary light surface (alternates with cream-2) */
  --br-cream-2:#FAFAFA;            /* SNOW — slightly off-white for adjacent light sections */
  --br-rose:   #4A4A4A;            /* GRAPHITE — neutral mid-gray accent */
  --br-rose-l: #8A8A8A;            /* STEEL */
  --br-rose-d: #2A2A2A;
  --br-gold:   #000000;            /* monochrome: italics/eyebrows on light = pure black */
  --br-gold-l: #2A2A2A;            /* gradient highlight (dark gray) */
  --br-gold-d: #000000;            /* deepest tone */
  --br-champagne: #FAFAFA;         /* monochrome accent for dark backgrounds (off-white) */
  --br-line:   rgba(0, 0, 0, 0.10);
  --br-line-l: rgba(255, 255, 255, 0.14);
  --br-shadow:      0 18px 60px -28px rgba(0, 0, 0, 0.35);
  --br-shadow-soft: 0 10px 40px -20px rgba(0, 0, 0, 0.20);
}

.bridal-page { background: var(--br-cream); }


/* ──────────────────────────────────────────
   Shared section heads
─────────────────────────────────────────── */
.bridal-page .br-section-head {
  text-align: center;
  max-width: 760px;
  margin: 0 auto 64px;
  padding: 0 20px;
}
.bridal-page .br-eyebrow {
  display: inline-block;
  font-family: 'Jost', sans-serif;
  font-size: 11px; font-weight: 500;
  letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--br-gold);
  margin-bottom: 20px;
  position: relative;
}
.bridal-page .br-eyebrow::before,
.bridal-page .br-eyebrow::after {
  content: ''; display: inline-block;
  width: 28px; height: 1px;
  background: currentColor;
  vertical-align: middle;
  margin: 0 14px;
  opacity: .55;
}
.bridal-page .br-eyebrow--light { color: rgba(255, 255, 255, 0.62); }

.bridal-page .br-section-title {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: clamp(30px, 5vw, 54px);
  line-height: 1.06;
  color: var(--br-ink);
  letter-spacing: -0.01em;
  margin-bottom: 18px;
}
.bridal-page .br-section-title em { font-style: italic; color: var(--br-gold); }
.bridal-page .br-section-title--light { color: #fff; }
.bridal-page .br-section-title--light em { color: var(--br-champagne); }

.bridal-page .br-section-sub {
  font-family: 'Jost', sans-serif;
  font-size: 15px; line-height: 1.7;
  color: rgba(0, 0, 0, 0.62);
  max-width: 620px; margin: 0 auto;
}
.bridal-page .br-section-sub--light { color: rgba(255, 255, 255, 0.68); }


/* ──────────────────────────────────────────
   Suite collage — semi-bridal section visual
─────────────────────────────────────────── */
.bridal-page .br-suite-collage {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
  max-width: 1180px;
  margin: -28px auto 68px;
  padding: 0 24px;
}
.bridal-page .br-suite-collage__item {
  position: relative;
  margin: 0;
  border-radius: 14px;
  overflow: hidden;
  background: #f4f4f4;
  box-shadow: var(--br-shadow-soft);
  aspect-ratio: 4 / 5;
  transition: transform .6s cubic-bezier(.2,.7,.2,1), box-shadow .6s ease;
}
.bridal-page .br-suite-collage__item img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  filter: grayscale(8%) contrast(1.02);
  transition: transform 1.2s cubic-bezier(.2,.7,.2,1), filter .6s ease;
}
.bridal-page .br-suite-collage__item figcaption {
  position: absolute;
  left: 14px; bottom: 14px;
  padding: 7px 12px;
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  color: var(--br-ink);
  font-family: 'Jost', sans-serif;
  font-size: 11px; font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  border-radius: 999px;
  border: 1px solid rgba(0, 0, 0, 0.06);
}
.bridal-page .br-suite-collage__item--a { transform: translateY(18px) rotate(-1.2deg); }
.bridal-page .br-suite-collage__item--b { transform: translateY(-10px) rotate(0.8deg); }
.bridal-page .br-suite-collage__item--c { transform: translateY(22px) rotate(-0.6deg); }
.bridal-page .br-suite-collage__item--d { transform: translateY(-4px) rotate(1.4deg); }
.bridal-page .br-suite-collage__item--e { transform: translateY(12px) rotate(0.9deg); }
.bridal-page .br-suite-collage__item--f { transform: translateY(-6px) rotate(-1deg); }
.bridal-page .br-suite-collage__item--g { transform: translateY(16px) rotate(1.2deg); }
.bridal-page .br-suite-collage__item--h { transform: translateY(-8px) rotate(-0.7deg); }
.bridal-page .br-suite-collage__item:hover {
  transform: translateY(-4px) rotate(0) scale(1.015);
  box-shadow: var(--br-shadow);
}
.bridal-page .br-suite-collage__item:hover img { transform: scale(1.06); filter: none; }
.bridal-page .br-suite-collage__rule {
  position: absolute;
  left: 50%; bottom: -34px;
  width: 1px; height: 28px;
  background: linear-gradient(to bottom, transparent, rgba(0,0,0,0.35));
  transform: translateX(-50%);
}

/* Small 4-card variant — used by the Semi-Bridal Suite section */
.bridal-page .br-suite-collage--sm {
  max-width: 860px;
  gap: 16px;
}
.bridal-page .br-suite-collage--sm .br-suite-collage__item {
  aspect-ratio: 3 / 4;
  border-radius: 10px;
}
.bridal-page .br-suite-collage--sm .br-suite-collage__item figcaption {
  left: 10px; bottom: 10px;
  padding: 5px 9px;
  font-size: 9.5px;
  letter-spacing: 0.18em;
}

@media (max-width: 900px) {
  .bridal-page .br-suite-collage { grid-template-columns: repeat(2, 1fr); gap: 16px; margin-bottom: 56px; }
  .bridal-page .br-suite-collage__item--a,
  .bridal-page .br-suite-collage__item--b,
  .bridal-page .br-suite-collage__item--c,
  .bridal-page .br-suite-collage__item--d,
  .bridal-page .br-suite-collage__item--e,
  .bridal-page .br-suite-collage__item--f,
  .bridal-page .br-suite-collage__item--g,
  .bridal-page .br-suite-collage__item--h { transform: none; }
}
@media (max-width: 520px) {
  .bridal-page .br-suite-collage { padding: 0 20px; gap: 14px; }
  .bridal-page .br-suite-collage__item figcaption { font-size: 10px; letter-spacing: 0.16em; padding: 6px 10px; }
}


/* ──────────────────────────────────────────
   Buttons
─────────────────────────────────────────── */
.bridal-page .br-btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 16px 30px;
  font-family: 'Jost', sans-serif;
  font-size: 12px; font-weight: 500;
  letter-spacing: 0.18em; text-transform: uppercase;
  text-decoration: none;
  border-radius: 60px;
  cursor: pointer;
  border: 1px solid transparent;
  transition: transform .35s cubic-bezier(.2,.7,.2,1), background .35s, color .35s, box-shadow .35s, border-color .35s;
  white-space: nowrap;
}
.bridal-page .br-btn svg {
  width: 0; height: 16px;
  opacity: 0;
  margin-left: -10px; /* offset .br-btn gap so collapsed arrow takes no visible space */
  transition: width .35s cubic-bezier(.2,.7,.2,1),
              margin-left .35s cubic-bezier(.2,.7,.2,1),
              opacity .25s ease,
              transform .35s cubic-bezier(.2,.7,.2,1);
}
.bridal-page .br-btn:hover svg {
  width: 16px;
  opacity: 1;
  margin-left: 0;
  transform: translateX(5px);
}

/* Solid black CTA — default for light sections. */
.bridal-page .br-btn--primary {
  background: linear-gradient(135deg, #000000, #000000);
  color: #FFFFFF;
  border-color: #000000;
  box-shadow: 0 14px 36px -14px rgba(0, 0, 0, .55);
}
.bridal-page .br-btn--primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 44px -16px rgba(0, 0, 0, .7);
  background: linear-gradient(135deg, #1A1A1A, #000000);
}

/* Inverted on dark backgrounds (hero, full-bridal dark switch) —
   solid black pill disappears on the black gradient, so flip to off-white. */
.bridal-page .br-hero .br-btn--primary,
.bridal-detail--full .bd-switch .br-btn--primary {
  background: #FAFAFA;
  color: #0A0A0A;
  border-color: #FAFAFA;
}
.bridal-page .br-hero .br-btn--primary:hover,
.bridal-detail--full .bd-switch .br-btn--primary:hover {
  background: #FFFFFF;
  border-color: #FFFFFF;
}

.bridal-page .br-btn--ghost {
  background: transparent; color: #fff;
  border-color: rgba(255, 255, 255, .35);
}
.bridal-page .br-btn--ghost:hover {
  background: rgba(255, 255, 255, .1);
  border-color: rgba(255, 255, 255, .65);
}
.bridal-page .br-btn--lg { padding: 20px 38px; font-size: 13px; }


/* ═══════════════════════════════════════════
   1. HERO
═══════════════════════════════════════════ */
.bridal-page .br-hero {
  position: relative; min-height: 100vh;
  padding: calc(var(--nav-h, 100px) + 40px) 24px 56px;
  display: flex; align-items: center; justify-content: center;
  background:
    radial-gradient(circle at 18% 20%, rgba(255, 255, 255, .10), transparent 55%),
    radial-gradient(circle at 80% 80%, rgba(255, 255, 255, .08), transparent 55%),
    linear-gradient(180deg, #0A0A0A 0%, #1A1A1A 55%, #000000 100%);
  color: #fff; overflow: hidden;
}
.bridal-page .br-hero-bg { position: absolute; inset: 0; pointer-events: none; }
.bridal-page .br-orb {
  position: absolute; border-radius: 50%;
  filter: blur(60px); opacity: .55;
  animation: brOrb 14s ease-in-out infinite;
}
.bridal-page .br-orb-1 {
  width: 380px; height: 380px;
  background: radial-gradient(circle, rgba(255, 255, 255, .22), transparent 70%);
  top: -120px; left: -100px;
}
.bridal-page .br-orb-2 {
  width: 460px; height: 460px;
  background: radial-gradient(circle, rgba(255, 255, 255, .14), transparent 70%);
  bottom: -160px; right: -120px;
  animation-delay: -6s;
}
.bridal-page .br-orb-3 {
  width: 280px; height: 280px;
  background: radial-gradient(circle, rgba(255, 255, 255, .14), transparent 70%);
  top: 40%; right: 15%;
  animation-delay: -10s;
}
@keyframes brOrb {
  0%,100% { transform: translate(0,0) scale(1); }
  50%     { transform: translate(20px,-30px) scale(1.06); }
}

.bridal-page .br-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(ellipse at center, #000 0%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at center, #000 0%, transparent 75%);
}

.bridal-page .br-spark {
  position: absolute; width: 6px; height: 6px;
  background: #fff; border-radius: 50%;
  box-shadow: 0 0 20px 4px rgba(255,255,255,.8);
  animation: brSpark 5s ease-in-out infinite;
}
.bridal-page .br-spark-1 { top: 22%; left: 25%; animation-delay: 0s; }
.bridal-page .br-spark-2 { top: 60%; left: 70%; animation-delay: -1.4s; }
.bridal-page .br-spark-3 { top: 30%; left: 80%; animation-delay: -2.8s; }
.bridal-page .br-spark-4 { top: 78%; left: 18%; animation-delay: -4.2s; }
@keyframes brSpark { 0%,100%{opacity:.2;transform:scale(.8)} 50%{opacity:1;transform:scale(1.3)} }

.bridal-page .br-hero-inner {
  position: relative; z-index: 2;
  max-width: 1100px; width: 100%;
  text-align: center;
}
.bridal-page .br-breadcrumb {
  font-family: 'Jost', sans-serif;
  font-size: 11px; letter-spacing: .24em; text-transform: uppercase;
  color: rgba(255,255,255,.6);
  margin-bottom: 26px;
  display: inline-flex; align-items: center; gap: 10px;
  opacity: 0;
}
.bridal-page .br-breadcrumb a { color: rgba(255,255,255,.85); text-decoration: none; transition: color .25s; }
.bridal-page .br-breadcrumb a:hover { color: var(--br-champagne); }

.bridal-page .br-hero-chip {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 18px; border-radius: 60px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(8px);
  color: rgba(255,255,255,.78);
  font-family: 'Jost', sans-serif;
  font-size: 11px; letter-spacing: .22em; text-transform: uppercase;
  margin-bottom: 32px;
  opacity: 0;
}
.bridal-page .br-hero-chip svg { width: 14px; height: 14px; color: var(--br-rose-l); }

.bridal-page .br-hero-title {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: clamp(40px, 7vw, 84px);
  line-height: 1.04;
  letter-spacing: -0.01em;
  color: #fff; margin-bottom: 26px;
}
.bridal-page .br-hero-title em { font-style: italic; color: var(--br-champagne); }
.bridal-page .br-line { display: block; overflow: hidden; padding-bottom: 0.14em; }
.bridal-page .br-line-inner { display: inline-block; will-change: transform; }

.bridal-page .br-hero-desc {
  font-family: 'Jost', sans-serif;
  font-size: 16px; line-height: 1.75;
  color: rgba(255,255,255,.72);
  max-width: 660px; margin: 0 auto 38px;
  opacity: 0;
}
.bridal-page .br-hero-cta-row {
  display: flex; flex-wrap: wrap; justify-content: center; gap: 16px;
  margin-bottom: 48px; opacity: 0;
}
.bridal-page .br-hero-trust {
  display: flex; flex-wrap: wrap; justify-content: center; gap: 28px;
  opacity: 0;
}
.bridal-page .br-trust-i {
  display: inline-flex; align-items: center; gap: 8px;
  color: rgba(255,255,255,.62);
  font-family: 'Jost', sans-serif;
  font-size: 11px; letter-spacing: .2em; text-transform: uppercase;
}
.bridal-page .br-trust-i svg { width: 18px; height: 18px; color: var(--br-champagne); }

.bridal-page .br-hero-fade {
  position: absolute; bottom: 0; left: 0; right: 0; height: 40px;
  background: linear-gradient(to bottom, transparent, var(--br-cream));
}


/* ═══════════════════════════════════════════
   2. CATEGORY OVERVIEW
═══════════════════════════════════════════ */
.bridal-page .br-overview { padding: 56px 24px 110px; background: var(--br-cream); }
.bridal-page .br-overview-grid {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 32px; max-width: 1200px; margin: 0 auto;
}
.bridal-page .br-over-card {
  position: relative; background: #fff;
  border: 1px solid var(--br-line);
  border-radius: 24px; overflow: hidden;
  box-shadow: var(--br-shadow-soft);
  transition: transform .45s cubic-bezier(.2,.7,.2,1), box-shadow .45s, border-color .45s;
  display: flex; flex-direction: column;
}
.bridal-page .br-over-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 30px 80px -28px rgba(0,0,0,.35);
  border-color: rgba(0, 0, 0, .42);
}
.bridal-page .br-over-img {
  position: relative; aspect-ratio: 16/10; overflow: hidden;
}
.bridal-page .br-over-img img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform .8s cubic-bezier(.2,.7,.2,1);
}
.bridal-page .br-over-card:hover .br-over-img img { transform: scale(1.06); }
.bridal-page .br-over-tag {
  position: absolute; top: 18px; left: 18px;
  padding: 8px 16px; border-radius: 60px;
  background: rgba(0,0,0,.65); color: #fff;
  backdrop-filter: blur(6px);
  font-family: 'Jost', sans-serif;
  font-size: 10px; font-weight: 500;
  letter-spacing: .22em; text-transform: uppercase;
}
.bridal-page .br-over-tag--alt { background: rgba(0, 0, 0, .85); }

.bridal-page .br-over-body { padding: 32px 32px 36px; }
.bridal-page .br-over-title {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400; font-size: clamp(24px, 2.5vw, 32px);
  color: var(--br-ink); margin-bottom: 12px; line-height: 1.15;
}
.bridal-page .br-over-desc {
  font-family: 'Jost', sans-serif;
  font-size: 14px; line-height: 1.75;
  color: rgba(0,0,0,.62);
  margin-bottom: 22px;
}
.bridal-page .br-over-cta {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 22px; border-radius: 60px;
  background: linear-gradient(135deg, var(--br-gold-l), var(--br-gold));
  color: #fff;
  font-family: 'Jost', sans-serif;
  font-size: 11px; font-weight: 500;
  letter-spacing: .18em; text-transform: uppercase;
  text-decoration: none;
  transition: transform .3s, box-shadow .3s;
  box-shadow: 0 8px 24px -10px rgba(0,0,0,.35);
}
.bridal-page .br-over-cta:hover { transform: translateY(-2px); box-shadow: 0 14px 32px -10px rgba(0,0,0,.45); }
.bridal-page .br-over-cta svg { width: 14px; height: 14px; transition: transform .3s; }
.bridal-page .br-over-cta:hover svg { transform: translateX(4px); }


/* ═══════════════════════════════════════════
   3 + 4. PIECES BLOCKS
═══════════════════════════════════════════ */
.bridal-page .br-block {
  position: relative;
  padding: 110px 24px;
  background: var(--br-cream);
  scroll-margin-top: calc(var(--nav-h, 100px) + 16px);
}
.bridal-page .br-block--dark {
  background:
    radial-gradient(circle at 15% 15%, rgba(255, 255, 255, .06), transparent 60%),
    radial-gradient(circle at 85% 85%, rgba(255, 255, 255, .06), transparent 60%),
    linear-gradient(180deg, #0A0A0A 0%, #1A1A1A 60%, #000000 100%);
  color: #fff; overflow: hidden;
}
.bridal-page .br-block-bg { position: absolute; inset: 0; pointer-events: none; }
.bridal-page .br-block-orb { position: absolute; border-radius: 50%; filter: blur(60px); opacity: .5; }
.bridal-page .br-block-orb-1 {
  width: 320px; height: 320px;
  background: radial-gradient(circle, rgba(255, 255, 255, .18), transparent 70%);
  top: 18%; left: -80px;
}
.bridal-page .br-block-orb-2 {
  width: 380px; height: 380px;
  background: radial-gradient(circle, rgba(255, 255, 255, .14), transparent 70%);
  bottom: 5%; right: -120px;
}

.bridal-page .br-pieces-grid {
  position: relative; z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
  max-width: 1280px; margin: 0 auto;
}
.bridal-page .br-piece-card {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 20px;
  overflow: hidden;
  backdrop-filter: blur(8px);
  transition: transform .45s, border-color .45s, box-shadow .45s;
  display: flex; flex-direction: column;
}
.bridal-page .br-piece-card:hover {
  transform: translateY(-6px);
  border-color: rgba(255, 255, 255, .32);
  box-shadow: 0 24px 60px -22px rgba(0,0,0,.55);
}
.bridal-page .br-piece-card--light {
  background: #fff;
  border-color: var(--br-line);
  box-shadow: var(--br-shadow-soft);
}
.bridal-page .br-piece-card--light:hover {
  border-color: rgba(0, 0, 0, .42);
  box-shadow: 0 24px 60px -22px rgba(0,0,0,.25);
}

.bridal-page .br-piece-img {
  position: relative; aspect-ratio: 4/3; overflow: hidden;
}
.bridal-page .br-piece-img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .8s cubic-bezier(.2,.7,.2,1);
}
.bridal-page .br-piece-card:hover .br-piece-img img { transform: scale(1.07); }
.bridal-page .br-piece-num {
  position: absolute; top: 14px; right: 14px;
  background: rgba(0,0,0,.65); color: #fff;
  font-family: 'Cormorant Garamond', serif;
  font-size: 14px; font-weight: 500;
  padding: 6px 12px; border-radius: 30px;
  letter-spacing: .1em;
  backdrop-filter: blur(4px);
}

.bridal-page .br-piece-body {
  padding: 22px 22px 26px;
  display: flex; flex-direction: column; gap: 8px;
}
.bridal-page .br-piece-title {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400; font-size: 22px;
  line-height: 1.2;
  color: #fff;
}
.bridal-page .br-piece-card--light .br-piece-title { color: var(--br-ink); }
.bridal-page .br-piece-desc {
  font-family: 'Jost', sans-serif;
  font-size: 13px; line-height: 1.65;
  color: rgba(255,255,255,.7);
}
.bridal-page .br-piece-card--light .br-piece-desc { color: rgba(0,0,0,.62); }

/* ── Shop variant — price + add-to-cart + wishlist heart ───────────── */
.bridal-page .br-piece-card--shop .br-piece-body {
  flex: 1;
  display: flex; flex-direction: column;
}
.bridal-page .br-piece-card--shop .br-piece-desc {
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.bridal-page .br-piece-foot {
  margin-top: 16px;
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding-top: 14px;
  border-top: 1px solid var(--br-line);
}
.bridal-page .br-piece-price {
  font-family: 'Cormorant Garamond', serif;
  font-size: 20px; font-weight: 500;
  color: var(--br-gold-d);
  letter-spacing: .01em;
}
.bridal-page .br-piece-add {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 18px;
  border: none; cursor: pointer; border-radius: 100px;
  background: linear-gradient(135deg, #000000, #000000);
  color: #FFFFFF;
  font-family: 'Jost', sans-serif;
  font-size: 11px; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  white-space: nowrap;
  box-shadow: 0 8px 20px -10px rgba(0, 0, 0, .45);
  transition: transform .25s, box-shadow .25s, background .25s;
}
.bridal-page .br-piece-add svg { width: 14px; height: 14px; fill: none; stroke: currentColor; stroke-width: 1.8; }
.bridal-page .br-piece-add:hover {
  transform: translateY(-2px);
  background: linear-gradient(135deg, #1A1A1A, #000000);
  box-shadow: 0 14px 28px -10px rgba(0, 0, 0, .6);
}
.bridal-page .br-piece-card--shop.cgu-incart .br-piece-add {
  background: linear-gradient(135deg, #4A4A4A, #4A4A4A);
  color: #FFFFFF;
}
.bridal-page .br-piece-wish {
  position: absolute; top: 12px; right: 12px; z-index: 3;
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(255,255,255,.94);
  border: 1px solid var(--br-line);
  display: grid; place-items: center; cursor: pointer;
  color: var(--br-ink);
  transition: background .25s, color .25s, transform .25s;
}
.bridal-page .br-piece-wish svg { width: 16px; height: 16px; fill: none; transition: fill .25s, stroke .25s; }
.bridal-page .br-piece-wish:hover {
  background: var(--br-gold-d); color: #fff; transform: scale(1.08);
}
.bridal-page .br-piece-wish:hover svg { fill: #fff; }
.bridal-page .br-piece-card--shop.cgu-wished .br-piece-wish,
.bridal-page .br-piece-wish.cgu-wished {
  background: var(--br-gold-d); color: #fff;
}
.bridal-page .br-piece-wish.cgu-wished svg { fill: #fff; stroke: #fff; }
@media (max-width: 520px) {
  .bridal-page .br-piece-foot { flex-wrap: wrap; gap: 10px; }
  .bridal-page .br-piece-add  { width: 100%; justify-content: center; }
}

/* ══════════════════════════════════════════════════════════════════
   INSIDE THE SUITE — editorial "moments" variant
   Portrait imagery + caption-on-image + serif numeral watermark.
   Distinct from both the default piece-card grid above and the
   masonry materials grid below — same content section, different
   visual language.
══════════════════════════════════════════════════════════════════ */
.bridal-page .br-pieces-grid--moments {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  padding: 0 24px;
}
.bridal-page .br-pieces-grid--moments .br-piece-card--moment:nth-child(1),
.bridal-page .br-pieces-grid--moments .br-piece-card--moment:nth-child(7) {
  grid-column: span 2;
}

.bridal-page .br-piece-card--moment {
  background: transparent;
  border: none;
  border-radius: 6px;
  overflow: hidden;
  position: relative;
  backdrop-filter: none;
  box-shadow: 0 18px 42px -22px rgba(0, 0, 0, .65);
  transition: transform .55s cubic-bezier(.2,.7,.2,1), box-shadow .55s;
}
.bridal-page .br-piece-card--moment:hover {
  transform: translateY(-4px);
  box-shadow: 0 28px 56px -22px rgba(0, 0, 0, .8);
}

.bridal-page .br-piece-card--moment .br-piece-img {
  aspect-ratio: 3 / 4;
  position: relative;
  overflow: hidden;
  border-radius: 6px;
}
.bridal-page .br-pieces-grid--moments .br-piece-card--moment:nth-child(1) .br-piece-img,
.bridal-page .br-pieces-grid--moments .br-piece-card--moment:nth-child(7) .br-piece-img {
  aspect-ratio: 16 / 9;
}
.bridal-page .br-piece-card--moment .br-piece-img img {
  width: 100%; height: 100%; object-fit: cover;
  filter: saturate(.92) contrast(1.04);
  transition: transform 1.1s cubic-bezier(.2,.7,.2,1), filter .55s;
}
.bridal-page .br-piece-card--moment:hover .br-piece-img img {
  transform: scale(1.06);
  filter: saturate(1) contrast(1.04);
}

/* Big editorial serif numeral — sits top-left as a watermark */
.bridal-page .br-piece-card--moment .br-piece-num {
  position: absolute;
  top: 16px; left: 20px;
  right: auto;
  background: transparent;
  backdrop-filter: none;
  color: rgba(255, 255, 255, .92);
  font-family: 'Cormorant Garamond', serif;
  font-size: 38px;
  font-weight: 300;
  letter-spacing: -0.01em;
  padding: 0;
  text-shadow: 0 2px 12px rgba(0, 0, 0, .55);
  pointer-events: none;
  z-index: 3;
}

/* Caption overlay — gradient base + typography stack */
.bridal-page .br-piece-card--moment .br-piece-overlay {
  position: absolute;
  inset: 0;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 26px 24px 24px;
  color: #fff;
  background: linear-gradient(
    180deg,
    rgba(0,0,0,0)   45%,
    rgba(0,0,0,.55) 70%,
    rgba(0,0,0,.85) 100%
  );
  z-index: 2;
}
.bridal-page .br-piece-card--moment .br-piece-meta {
  font-family: 'Jost', sans-serif;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, .72);
  margin-bottom: 8px;
}
.bridal-page .br-piece-card--moment .br-piece-title {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: 26px;
  line-height: 1.1;
  color: #fff;
  margin: 0;
  letter-spacing: 0.005em;
}
.bridal-page .br-piece-card--moment .br-piece-rule {
  display: block;
  width: 32px; height: 1px;
  background: rgba(255, 255, 255, .55);
  margin: 12px 0 10px;
  transition: width .55s cubic-bezier(.2,.7,.2,1);
}
.bridal-page .br-piece-card--moment:hover .br-piece-rule { width: 64px; }
.bridal-page .br-piece-card--moment .br-piece-desc {
  font-family: 'Jost', sans-serif;
  font-size: 12.5px;
  line-height: 1.6;
  color: rgba(255, 255, 255, .82);
  margin: 0;
  max-width: 36ch;
}

/* Asymmetric layout for the wide first/last cards: caption sits tighter */
.bridal-page .br-pieces-grid--moments .br-piece-card--moment:nth-child(1) .br-piece-overlay,
.bridal-page .br-pieces-grid--moments .br-piece-card--moment:nth-child(7) .br-piece-overlay {
  padding: 36px 36px 32px;
}
.bridal-page .br-pieces-grid--moments .br-piece-card--moment:nth-child(1) .br-piece-title,
.bridal-page .br-pieces-grid--moments .br-piece-card--moment:nth-child(7) .br-piece-title {
  font-size: 34px;
}
.bridal-page .br-pieces-grid--moments .br-piece-card--moment:nth-child(1) .br-piece-num,
.bridal-page .br-pieces-grid--moments .br-piece-card--moment:nth-child(7) .br-piece-num {
  font-size: 52px;
}

@media (max-width: 1024px) {
  .bridal-page .br-pieces-grid--moments { grid-template-columns: repeat(2, 1fr); }
  .bridal-page .br-pieces-grid--moments .br-piece-card--moment:nth-child(1),
  .bridal-page .br-pieces-grid--moments .br-piece-card--moment:nth-child(7) {
    grid-column: span 2;
  }
  .bridal-page .br-pieces-grid--moments .br-piece-card--moment:nth-child(1) .br-piece-img,
  .bridal-page .br-pieces-grid--moments .br-piece-card--moment:nth-child(7) .br-piece-img {
    aspect-ratio: 21 / 9;
  }
}
@media (max-width: 600px) {
  .bridal-page .br-pieces-grid--moments { grid-template-columns: 1fr; gap: 20px; padding: 0 20px; }
  .bridal-page .br-pieces-grid--moments .br-piece-card--moment,
  .bridal-page .br-pieces-grid--moments .br-piece-card--moment:nth-child(1),
  .bridal-page .br-pieces-grid--moments .br-piece-card--moment:nth-child(7) {
    grid-column: span 1;
  }
  .bridal-page .br-pieces-grid--moments .br-piece-card--moment:nth-child(1) .br-piece-img,
  .bridal-page .br-pieces-grid--moments .br-piece-card--moment:nth-child(7) .br-piece-img {
    aspect-ratio: 3 / 4;
  }
  .bridal-page .br-piece-card--moment .br-piece-title { font-size: 22px; }
  .bridal-page .br-pieces-grid--moments .br-piece-card--moment:nth-child(1) .br-piece-title,
  .bridal-page .br-pieces-grid--moments .br-piece-card--moment:nth-child(7) .br-piece-title { font-size: 24px; }
}


/* ═══════════════════════════════════════════
   5. LOOKBOOK / GALLERY
═══════════════════════════════════════════ */
.bridal-page .br-lookbook { padding: 110px 24px; background: var(--br-cream-2); }
.bridal-page .br-look-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 220px;
  gap: 16px;
  max-width: 1280px; margin: 0 auto;
}
.bridal-page .br-look-item {
  position: relative; overflow: hidden;
  border-radius: 18px;
  cursor: pointer;
  border: 1px solid var(--br-line);
  background: #fff;
  margin: 0;
}
.bridal-page .br-look-1 { grid-column: span 2; grid-row: span 2; }
.bridal-page .br-look-3 { grid-column: span 2; }
.bridal-page .br-look-5 { grid-row: span 2; }
.bridal-page .br-look-item img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1s cubic-bezier(.2,.7,.2,1), filter .5s;
}
.bridal-page .br-look-item::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,.7) 100%);
  opacity: 0; transition: opacity .4s;
}
.bridal-page .br-look-item:hover img { transform: scale(1.08); }
.bridal-page .br-look-item:hover::after { opacity: 1; }
.bridal-page .br-look-cap {
  position: absolute; left: 20px; right: 20px; bottom: 18px;
  z-index: 1; color: #fff;
  opacity: 0; transform: translateY(10px);
  transition: opacity .4s ease, transform .4s ease;
  pointer-events: none;
}
.bridal-page .br-look-item:hover .br-look-cap { opacity: 1; transform: translateY(0); }
.bridal-page .br-look-cap strong {
  display: block;
  font-family: 'Cormorant Garamond', serif;
  font-weight: 500; font-size: 18px; letter-spacing: -.005em;
  margin-bottom: 4px;
}
.bridal-page .br-look-cap span {
  display: block;
  font-family: 'Jost', sans-serif;
  font-size: 12px; color: rgba(255,255,255,.85);
  letter-spacing: .04em;
}


/* ═══════════════════════════════════════════
   6. CONSULTATION + 7. ENQUIRY FORM
═══════════════════════════════════════════ */
/* Consult section — SNOW surface so it clearly breaks
   from the dark footer below. Graphite borders + black accents on an off-white surface. */
.bridal-page .br-consult {
  position: relative;
  padding: 130px 24px;
  background:
    radial-gradient(circle at 12% 12%, rgba(74, 74, 74, .10), transparent 55%),
    radial-gradient(circle at 90% 90%, rgba(138, 138, 138, .12), transparent 55%),
    linear-gradient(180deg, #FAFAFA 0%, #F5F5F5 60%, #EAEAEA 100%);
  color: #141414; overflow: hidden;
  scroll-margin-top: calc(var(--nav-h, 100px) + 16px);
}
.bridal-page .br-consult-bg {
  position: absolute; inset: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(74, 74, 74, .05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(74, 74, 74, .05) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(ellipse at center, #000 0%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at center, #000 0%, transparent 75%);
}
.bridal-page .br-consult-shell {
  position: relative; z-index: 1;
  max-width: 1200px; margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: start;
}
.bridal-page .br-consult-aside {
  padding-right: 8px;
}
/* Eyebrow that was light-on-dark needs to be dark-on-cream now */
.bridal-page .br-consult .br-eyebrow--light { color: #000000; }
.bridal-page .br-consult-title {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: clamp(32px, 4vw, 52px);
  line-height: 1.06;
  color: #141414; margin: 12px 0 16px;
}
.bridal-page .br-consult-title em { font-style: italic; color: #000000; }
.bridal-page .br-consult-sub {
  font-family: 'Jost', sans-serif;
  font-size: 15px; line-height: 1.75;
  color: rgba(20, 20, 20, .68);
  margin-bottom: 30px;
}

.bridal-page .br-consult-points {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 14px;
}
.bridal-page .br-consult-points li {
  padding: 16px 18px;
  border: 1px solid rgba(74, 74, 74, .18);
  border-radius: 14px;
  background: rgba(255, 255, 255, .55);
  backdrop-filter: blur(6px);
  transition: border-color .3s, background .3s, transform .3s;
}
.bridal-page .br-consult-points li:hover {
  border-color: rgba(74, 74, 74, .45);
  background: #FFFFFF;
  transform: translateX(4px);
}
.bridal-page .br-consult-points li:hover .br-consult-tick {
  background: #000000;
  color: #FFFFFF;
  border-color: #000000;
}
.bridal-page .br-consult-row {
  display: flex; align-items: center; gap: 14px;
}
.bridal-page .br-consult-tick {
  flex-shrink: 0;
  width: 40px; height: 40px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 12px;
  background: rgba(74, 74, 74, .10);
  color: #000000;
  border: 1px solid rgba(74, 74, 74, .28);
  transition: background .3s, border-color .3s, color .3s;
}
.bridal-page .br-consult-tick svg { width: 21px; height: 21px; display: block; }
.bridal-page .br-consult-points strong {
  display: block;
  font-family: 'Cormorant Garamond', serif;
  font-weight: 500;
  font-size: 19px;
  line-height: 1.2;
  color: #141414;
}
.bridal-page .br-consult-desc {
  display: block;
  margin-top: 9px;
  padding-left: 54px;            /* 40px chip + 14px gap — aligns under the heading */
  font-family: 'Jost', sans-serif;
  font-size: 13px;
  color: rgba(20, 20, 20, .62);
  line-height: 1.6;
}


/* Form — white card on cream surface, brown borders + champagne accents */
.bridal-page .br-form {
  background: #FFFFFF;
  border: 1px solid rgba(74, 74, 74, .18);
  backdrop-filter: blur(10px);
  border-radius: 24px;
  padding: 36px 32px;
  display: flex; flex-direction: column; gap: 18px;
  box-shadow: 0 24px 60px -28px rgba(20, 20, 20, .25);
  /* Sticky on desktop — the aside (5 detailed points) is taller than the form,
     so pinning the form keeps it in view and removes the empty space below it. */
  position: sticky;
  top: calc(var(--nav-h, 100px) + 24px);
  align-self: start;
  /* Anchor-scroll target — keep the form clear of the sticky nav when the
     "Begin Your Bridal Story" CTA jumps to #brForm. */
  scroll-margin-top: calc(var(--nav-h, 100px) + 24px);
  transition: box-shadow .4s ease, border-color .4s ease;
}
/* Brief highlight when the "Book Bridal Consultation" CTA scrolls here */
.bridal-page .br-form.is-flash {
  animation: brFormFlash 1.6s ease-out;
}
@keyframes brFormFlash {
  0%   { box-shadow: 0 24px 60px -28px rgba(20,20,20,.25), 0 0 0 0 rgba(74, 74, 74, 0);  border-color: rgba(74, 74, 74, .18); }
  25%  { box-shadow: 0 24px 60px -28px rgba(20,20,20,.25), 0 0 0 6px rgba(74, 74, 74, .25); border-color: rgba(74, 74, 74, .55); }
  100% { box-shadow: 0 24px 60px -28px rgba(20,20,20,.25), 0 0 0 0 rgba(74, 74, 74, 0);  border-color: rgba(74, 74, 74, .18); }
}
@media (prefers-reduced-motion: reduce) {
  .bridal-page .br-form.is-flash { animation: none; }
}

.bridal-page .br-form-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
}

.bridal-page .br-field {
  position: relative;
}
.bridal-page .br-field input,
.bridal-page .br-field select,
.bridal-page .br-field textarea {
  width: 100%;
  padding: 18px 16px 14px;
  background: #FAFAFA;
  border: 1px solid rgba(74, 74, 74, .22);
  border-radius: 12px;
  font-family: 'Jost', sans-serif;
  font-size: 14px;
  color: #141414;
  transition: border-color .25s, background .25s, box-shadow .25s;
  outline: none;
  appearance: none; -webkit-appearance: none;
}
.bridal-page .br-field input::placeholder,
.bridal-page .br-field textarea::placeholder { color: transparent; }
.bridal-page .br-field input:hover,
.bridal-page .br-field select:hover,
.bridal-page .br-field textarea:hover { border-color: rgba(74, 74, 74, .42); }
.bridal-page .br-field input:focus,
.bridal-page .br-field select:focus,
.bridal-page .br-field textarea:focus {
  border-color: #000000;
  background: #FFFFFF;
  box-shadow: 0 0 0 3px rgba(74, 74, 74, .15);
}
.bridal-page .br-field label {
  position: absolute;
  left: 16px; top: 16px;
  font-family: 'Jost', sans-serif;
  font-size: 13px;
  color: rgba(20, 20, 20, .55);
  pointer-events: none;
  transition: top .2s, font-size .2s, color .2s, transform .2s;
  background: transparent;
}

.bridal-page .br-field input:focus + label,
.bridal-page .br-field input:not(:placeholder-shown) + label,
.bridal-page .br-field input[type="date"] + label,
.bridal-page .br-field textarea:focus + label,
.bridal-page .br-field textarea:not(:placeholder-shown) + label {
  top: -8px; left: 12px;
  font-size: 10.5px; letter-spacing: .12em;
  text-transform: uppercase;
  background: linear-gradient(to bottom, transparent 45%, #FFFFFF 45%);
  padding: 0 6px;
  color: #000000;
}

.bridal-page .br-select { position: relative; }
.bridal-page .br-select select { padding-right: 44px; cursor: pointer; color: rgba(20, 20, 20, .55); color-scheme: light; }
.bridal-page .br-select.has-val select { color: #141414; }
.bridal-page .br-select option {
  background: #FFFFFF; color: #141414;
  padding: 10px 14px;
}
.bridal-page .br-select option:disabled { color: rgba(20, 20, 20, .4); }
.bridal-page .br-select-arr {
  position: absolute; right: 16px; top: 50%;
  width: 15px; height: 15px;
  transform: translateY(-50%);
  color: rgba(20, 20, 20, .5);
  pointer-events: none;
  transition: transform .3s ease, color .25s;
}
.bridal-page .br-select select:hover ~ .br-select-arr { color: rgba(20, 20, 20, .8); }
.bridal-page .br-select select:focus ~ .br-select-arr {
  color: #000000;
  transform: translateY(-50%) rotate(180deg);
}
.bridal-page .br-select select:focus + label,
.bridal-page .br-select.has-val select + label,
.bridal-page .br-select select + label {
  top: -8px; left: 12px;
  font-size: 10.5px; letter-spacing: .12em;
  text-transform: uppercase;
  background: linear-gradient(to bottom, transparent 45%, #FFFFFF 45%);
  padding: 0 6px;
  color: #000000;
}

/* Date — native picker, themed light + champagne */
.bridal-page .br-field input[type="date"] {
  color-scheme: light;
  padding-right: 16px;
  cursor: text;
}
.bridal-page .br-field input[type="date"]::-webkit-datetime-edit {
  padding: 0;
  font-family: 'Jost', sans-serif;
  color: #141414; letter-spacing: .02em;
}
.bridal-page .br-field input[type="date"]:not(.has-val)::-webkit-datetime-edit { color: rgba(20, 20, 20, .45); }
.bridal-page .br-field input[type="date"]::-webkit-datetime-edit-fields-wrapper { padding: 0; }
.bridal-page .br-field input[type="date"]::-webkit-datetime-edit-text { padding: 0 2px; opacity: .6; }
.bridal-page .br-field input[type="date"]::-webkit-inner-spin-button { display: none; }
.bridal-page .br-field input[type="date"]::-webkit-calendar-picker-indicator {
  width: 17px; height: 17px;
  margin-left: 4px;
  cursor: pointer;
  border-radius: 6px;
  filter: none;
  opacity: .55;
  transition: opacity .2s, background .2s;
}
.bridal-page .br-field input[type="date"]::-webkit-calendar-picker-indicator:hover {
  opacity: 1;
  background: rgba(74, 74, 74, .12);
}

.bridal-page .br-textarea textarea {
  resize: vertical;
  min-height: 110px;
}

/* Upload */
.bridal-page .br-upload {
  position: relative;
  border: 1.5px dashed rgba(74, 74, 74, .35);
  border-radius: 14px;
  background: #FAFAFA;
  transition: border-color .3s, background .3s;
}
.bridal-page .br-upload:hover { border-color: #000000; background: #FFFFFF; }
.bridal-page .br-upload input[type="file"] {
  position: absolute; inset: 0;
  opacity: 0; cursor: pointer; z-index: 2;
}
.bridal-page .br-upload-lbl {
  display: flex; align-items: center; gap: 16px;
  padding: 18px 20px;
  cursor: pointer;
}
.bridal-page .br-upload-ico {
  flex-shrink: 0;
  width: 42px; height: 42px;
  display: grid; place-items: center;
  border-radius: 12px;
  background: rgba(74, 74, 74, .10);
  color: #000000;
  border: 1px solid rgba(74, 74, 74, .28);
}
.bridal-page .br-upload-ico svg { width: 20px; height: 20px; }
.bridal-page .br-upload-text { flex: 1; min-width: 0; }
.bridal-page .br-upload-text strong {
  display: block;
  font-family: 'Jost', sans-serif;
  font-size: 13px; font-weight: 600;
  color: #141414;
  margin-bottom: 4px;
  letter-spacing: .03em;
}
.bridal-page .br-upload-text em {
  display: block;
  font-style: normal;
  font-size: 11px;
  color: rgba(20, 20, 20, .55);
}
.bridal-page .br-upload-name {
  margin-left: auto;
  font-family: 'Jost', sans-serif;
  font-size: 12px;
  color: #000000;
  white-space: nowrap;
  max-width: 140px;
  overflow: hidden;
  text-overflow: ellipsis;
}
.bridal-page .br-upload.has-file { border-color: #000000; background: rgba(74, 74, 74, .06); }

/* Submit — champagne gradient on cream */
.bridal-page .br-submit {
  margin-top: 6px;
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  padding: 18px 28px;
  background: linear-gradient(135deg, #4A4A4A 0%, #000000 100%);
  color: #FFFFFF;
  font-family: 'Jost', sans-serif;
  font-size: 12px; font-weight: 600;
  letter-spacing: .2em; text-transform: uppercase;
  border: none; border-radius: 60px;
  cursor: pointer;
  box-shadow: 0 14px 36px -14px rgba(74, 74, 74, .55);
  transition: transform .3s, box-shadow .3s, background .3s;
}
.bridal-page .br-submit:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 44px -16px rgba(74, 74, 74, .7);
  background: linear-gradient(135deg, #000000 0%, #2A2A2A 100%);
}
.bridal-page .br-submit svg { width: 14px; height: 14px; transition: transform .3s; }
.bridal-page .br-submit:hover svg { transform: translateX(4px); }
.bridal-page .br-submit:disabled { opacity: .65; cursor: wait; }

.bridal-page .br-form-success {
  display: none;
  align-items: flex-start; gap: 14px;
  padding: 16px 18px;
  border-radius: 14px;
  background: rgba(74, 74, 74, .10);
  border: 1px solid rgba(74, 74, 74, .30);
  color: #141414;
}
.bridal-page .br-form-success.show { display: flex; }
.bridal-page .br-form-success-ico {
  flex-shrink: 0;
  width: 32px; height: 32px;
  display: grid; place-items: center;
  border-radius: 10px;
  background: #000000;
  color: #FFFFFF;
}
.bridal-page .br-form-success-ico svg { width: 16px; height: 16px; }
.bridal-page .br-form-success strong {
  display: block;
  font-family: 'Cormorant Garamond', serif;
  font-weight: 500; font-size: 17px;
  color: #141414; margin-bottom: 2px;
}
.bridal-page .br-form-success div {
  font-family: 'Jost', sans-serif;
  font-size: 13px;
  color: rgba(20, 20, 20, .68);
  line-height: 1.6;
}

.bridal-page .br-form-note {
  margin-top: 4px;
  font-family: 'Jost', sans-serif;
  font-size: 11px;
  color: rgba(20, 20, 20, .5);
  text-align: center;
  letter-spacing: .04em;
}


/* ═══════════════════════════════════════════
   8. FINAL CTA
═══════════════════════════════════════════ */
.bridal-page .br-final-cta {
  position: relative;
  padding: 130px 24px;
  background:
    radial-gradient(circle at 20% 30%, rgba(74, 74, 74, .14), transparent 55%),
    radial-gradient(circle at 80% 70%, rgba(74, 74, 74, .10), transparent 55%),
    linear-gradient(180deg, var(--br-cream) 0%, var(--br-cream-2) 100%);
  overflow: hidden; text-align: center; color: var(--br-ink);
}
.bridal-page .br-final-bg { position: absolute; inset: 0; pointer-events: none; }
.bridal-page .br-final-orb { position: absolute; border-radius: 50%; filter: blur(70px); opacity: .55; }
.bridal-page .br-final-orb-1 {
  width: 360px; height: 360px;
  background: radial-gradient(circle, rgba(74, 74, 74, .26), transparent 70%);
  top: 10%; left: 10%;
}
.bridal-page .br-final-orb-2 {
  width: 320px; height: 320px;
  background: radial-gradient(circle, rgba(74, 74, 74, .18), transparent 70%);
  bottom: 0; right: 5%;
}
.bridal-page .br-final-inner {
  position: relative; z-index: 1;
  max-width: 720px; margin: 0 auto;
}
.bridal-page .br-final-title {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: clamp(34px, 5vw, 60px);
  line-height: 1.08;
  color: var(--br-ink);
  margin: 16px 0 20px;
}
.bridal-page .br-final-title em { font-style: italic; color: var(--br-gold); }
.bridal-page .br-final-sub {
  font-family: 'Jost', sans-serif;
  font-size: 16px; line-height: 1.7;
  color: rgba(0, 0, 0, 0.66);
  margin-bottom: 36px;
}


/* ═══════════════════════════════════════════
   CUSTOM DROPDOWN + CALENDAR — dark / champagne theme
   (shared .bv-dd / .bv-cal controls, re-skinned for the bridal form)
═══════════════════════════════════════════ */
.bridal-page .br-form .bv-dd,
.bridal-page .br-form .bv-cal { position: relative; }

/* Trigger buttons — look like the bridal text fields (cream theme) */
.bridal-page .br-form .bv-dd-btn,
.bridal-page .br-form .bv-cal-trigger {
  width: 100%;
  min-height: 53px;
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 19px 14px 6px 16px;
  background: #FAFAFA;
  border: 1px solid rgba(74, 74, 74, .22);
  border-radius: 12px;
  font-family: 'Jost', sans-serif; font-size: 14px;
  color: #141414; text-align: left; cursor: pointer; outline: none;
  transition: border-color .25s, background .25s, box-shadow .25s;
  appearance: none; -webkit-appearance: none;
}
.bridal-page .br-form .bv-dd-btn:hover,
.bridal-page .br-form .bv-cal-trigger:hover { border-color: rgba(74, 74, 74, .42); }
.bridal-page .br-form .bv-dd-btn:focus,
.bridal-page .br-form .bv-dd.open .bv-dd-btn,
.bridal-page .br-form .bv-cal-trigger:focus,
.bridal-page .br-form .bv-cal.open .bv-cal-trigger {
  border-color: #000000;
  background: #FFFFFF;
  box-shadow: 0 0 0 3px rgba(74, 74, 74, .15);
}
.bridal-page .br-form .bv-dd-display,
.bridal-page .br-form .bv-cal-display {
  flex: 1; min-height: 1em;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  color: #141414;
}

/* Floating labels */
.bridal-page .br-form .bv-dd-lbl,
.bridal-page .br-form .bv-cal-lbl {
  position: absolute; top: 17px; left: 16px;
  font-family: 'Jost', sans-serif; font-size: 13px;
  color: rgba(20, 20, 20, .55); pointer-events: none;
  transition: top .2s, font-size .2s, letter-spacing .2s, color .2s;
}
.bridal-page .br-form .bv-dd.open .bv-dd-lbl,
.bridal-page .br-form .bv-dd.has-val .bv-dd-lbl,
.bridal-page .br-form .bv-cal.open .bv-cal-lbl,
.bridal-page .br-form .bv-cal.has-val .bv-cal-lbl {
  top: 7px; font-size: 9.5px;
  letter-spacing: .12em; text-transform: uppercase;
  color: #000000;
}

/* Chevron / calendar icon */
.bridal-page .br-form .bv-dd-arrow {
  flex-shrink: 0; width: 16px; height: 16px;
  stroke: rgba(20, 20, 20, .5); fill: none;
  transition: transform .3s cubic-bezier(.22,.61,.36,1), stroke .25s;
}
.bridal-page .br-form .bv-dd.open .bv-dd-arrow { transform: rotate(180deg); stroke: #000000; }
.bridal-page .br-form .bv-cal-ico {
  flex-shrink: 0; width: 32px; height: 32px; border-radius: 9px;
  background: rgba(74, 74, 74, .10); border: 1px solid rgba(74, 74, 74, .28);
  display: grid; place-items: center; transition: background .25s, border-color .25s;
}
.bridal-page .br-form .bv-cal-ico svg { width: 15px; height: 15px; stroke: #000000; fill: none; }
.bridal-page .br-form .bv-cal.open .bv-cal-ico,
.bridal-page .br-form .bv-cal-trigger:focus .bv-cal-ico { background: rgba(74, 74, 74, .18); border-color: rgba(74, 74, 74, .45); }

/* Dropdown list panel */
.bridal-page .br-form .bv-dd-list {
  position: absolute; top: calc(100% + 8px); left: 0; right: 0;
  background: #FFFFFF;
  border: 1px solid rgba(74, 74, 74, .22);
  border-radius: 14px;
  box-shadow: 0 22px 52px rgba(20, 20, 20, .18), 0 6px 16px rgba(20, 20, 20, .12);
  list-style: none; z-index: 200; overflow-y: auto; max-height: 250px;
  opacity: 0; transform: translateY(-6px) scale(.98); pointer-events: none;
  transition: opacity .2s ease, transform .2s ease;
}
.bridal-page .br-form .bv-dd.open .bv-dd-list { opacity: 1; transform: none; pointer-events: auto; }
.bridal-page .br-form .bv-dd-list::-webkit-scrollbar { width: 4px; }
.bridal-page .br-form .bv-dd-list::-webkit-scrollbar-thumb { background: rgba(74, 74, 74, .28); border-radius: 2px; }
.bridal-page .br-form .bv-dd-item {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 12px 16px;
  font-family: 'Jost', sans-serif; font-size: 13.5px;
  color: rgba(20, 20, 20, .78); cursor: pointer;
  border-bottom: 1px solid rgba(74, 74, 74, .12);
  transition: background .15s, color .15s;
}
.bridal-page .br-form .bv-dd-item:last-child { border-bottom: none; }
.bridal-page .br-form .bv-dd-item:hover { background: #FAFAFA; color: #141414; }
.bridal-page .br-form .bv-dd-item.selected { background: rgba(74, 74, 74, .14); color: #000000; font-weight: 600; }
.bridal-page .br-form .bv-dd-item.selected::after {
  content: ''; flex-shrink: 0; width: 15px; height: 15px;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%238B6F47' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size: contain; background-repeat: no-repeat; background-position: center;
}

/* Calendar panel */
.bridal-page .br-form .bv-cal-panel {
  position: absolute; top: calc(100% + 8px); left: 0;
  width: 316px; max-width: calc(100vw - 48px);
  background: #FFFFFF;
  border: 1px solid rgba(74, 74, 74, .22);
  border-radius: 18px;
  box-shadow: 0 26px 64px rgba(20, 20, 20, .22), 0 8px 20px rgba(20, 20, 20, .14);
  z-index: 300; overflow: hidden;
  opacity: 0; transform: translateY(-8px) scale(.97); pointer-events: none;
  transition: opacity .22s ease, transform .22s ease;
}
.bridal-page .br-form .bv-cal-panel.open { opacity: 1; transform: none; pointer-events: auto; }
.bridal-page .br-form .bv-cal-header {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
  padding: 16px 14px 10px; border-bottom: 1px solid rgba(74, 74, 74, .14);
}
.bridal-page .br-form .bv-cal-title {
  flex: 1; text-align: center;
  font-family: 'Cormorant Garamond', serif; font-size: 19px; font-weight: 500; color: #141414;
}
.bridal-page .br-form .bv-cal-nav {
  flex-shrink: 0; width: 30px; height: 30px; border-radius: 8px;
  background: #FAFAFA; border: 1px solid rgba(74, 74, 74, .18);
  cursor: pointer; outline: none; display: grid; place-items: center;
  transition: background .2s, border-color .2s;
}
.bridal-page .br-form .bv-cal-nav:hover { background: rgba(74, 74, 74, .14); border-color: rgba(74, 74, 74, .45); }
.bridal-page .br-form .bv-cal-nav svg { width: 12px; height: 12px; stroke: rgba(20, 20, 20, .7); fill: none; stroke-width: 2.5; transition: stroke .2s; }
.bridal-page .br-form .bv-cal-nav:hover svg { stroke: #000000; }
.bridal-page .br-form .bv-cal-wdays { display: grid; grid-template-columns: repeat(7,1fr); padding: 10px 12px 2px; }
.bridal-page .br-form .bv-cal-wdays span {
  text-align: center; font-family: 'Jost', sans-serif;
  font-size: 9.5px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  color: rgba(20, 20, 20, .4); padding: 4px 0;
}
.bridal-page .br-form .bv-cal-grid { display: grid; grid-template-columns: repeat(7,1fr); padding: 2px 12px 10px; gap: 2px; }
.bridal-page .br-form .bv-cal-day {
  aspect-ratio: 1; min-height: 32px;
  display: grid; place-items: center;
  border-radius: 50%; border: 2px solid transparent; background: none; padding: 0;
  font-family: 'Jost', sans-serif; font-size: 13px; color: rgba(20, 20, 20, .85);
  cursor: pointer; outline: none;
  transition: background .15s, color .15s, border-color .15s, box-shadow .15s;
}
.bridal-page .br-form .bv-cal-day--empty { pointer-events: none; }
.bridal-page .br-form .bv-cal-day:not(:disabled):not(.bv-cal-day--sel):hover { background: rgba(74, 74, 74, .12); color: #000000; }
.bridal-page .br-form .bv-cal-day--today { border-color: rgba(74, 74, 74, .45); color: #000000; font-weight: 600; }
.bridal-page .br-form .bv-cal-day--sel {
  background: #000000 !important; border-color: #000000 !important;
  color: #FFFFFF !important; font-weight: 700;
  box-shadow: 0 4px 14px rgba(74, 74, 74, .35);
}
.bridal-page .br-form .bv-cal-day--past { color: rgba(20, 20, 20, .25); cursor: not-allowed; }
.bridal-page .br-form .bv-cal-day--past:hover { background: none; color: rgba(20, 20, 20, .25); }
.bridal-page .br-form .bv-cal-foot {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 16px 14px; border-top: 1px solid rgba(74, 74, 74, .14);
}
.bridal-page .br-form .bv-cal-today-btn,
.bridal-page .br-form .bv-cal-clear-btn {
  border: none; cursor: pointer; outline: none;
  font-family: 'Jost', sans-serif; font-size: 11px; font-weight: 600;
  letter-spacing: .06em; text-transform: uppercase;
  padding: 7px 14px; border-radius: 8px; transition: background .2s, color .2s;
}
.bridal-page .br-form .bv-cal-today-btn { background: rgba(74, 74, 74, .14); color: #000000; }
.bridal-page .br-form .bv-cal-today-btn:hover { background: #000000; color: #FFFFFF; }
.bridal-page .br-form .bv-cal-clear-btn { background: none; color: rgba(20, 20, 20, .45); }
.bridal-page .br-form .bv-cal-clear-btn:hover { color: #B33A3A; background: rgba(179, 58, 58, .08); }

@media (max-width: 600px) {
  .bridal-page .br-form .bv-cal-panel { width: 100%; }
}


/* ═══════════════════════════════════════════════════════════
   CONSULT SECTION — home-page monochrome palette
   Light SNOW surface + pure black accents (matches home page).
   White bullet tiles + black "Submit Enquiry" pill. Overrides
   earlier dark-bg styling.
   Palette tokens (mirror of home page):
     #FFFFFF  WHITE     primary surface
     #FAFAFA  SNOW      card surface / off-white base
     #E0E0E0  MIST      hairline borders
     #8A8A8A  STEEL     secondary text
     #4A4A4A  GRAPHITE  mid-dark text & accents
     #141414  NOIR      ink (soft black)
     #000000  BLACK     italics / focus / accent solids
═══════════════════════════════════════════════════════════ */
.bridal-page .br-consult {
  background:
    radial-gradient(circle at 12% 12%, rgba(74, 74, 74, .10), transparent 55%),
    radial-gradient(circle at 90% 90%, rgba(138, 138, 138, .12), transparent 55%),
    linear-gradient(180deg, #FAFAFA 0%, #F5F5F5 55%, #EAEAEA 100%) !important;
  color: #141414 !important;
  border-top: 1px solid rgba(74, 74, 74, .14);
  border-bottom: 1px solid rgba(74, 74, 74, .14);

  /* Re-bind the bridal page's champagne token so the form
     dropdown/calendar resolve to the home page champagne. */
  --br-champagne:   #000000;
  --br-champagne-d: #2A2A2A;

  /* Re-bind the site-wide calendar/dropdown tokens (--em*) so
     the date-picker chip, today-ring, selected-day fill, hover
     bg, and dropdown row hover all read in champagne. */
  --em:    #000000;
  --em-l:  #4A4A4A;
  --em-d:  #2A2A2A;
  --em-bg: rgba(74, 74, 74, .12);
  --em-br: rgba(74, 74, 74, .35);
  --em-sh: rgba(74, 74, 74, .45);
}

/* Soft grid overlay — champagne hairlines */
.bridal-page .br-consult-bg {
  background-image:
    linear-gradient(rgba(74, 74, 74, .05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(74, 74, 74, .05) 1px, transparent 1px);
}

/* Eyebrow + title — champagne accents on warm ink */
.bridal-page .br-consult .br-eyebrow,
.bridal-page .br-consult .br-eyebrow--light { color: #000000; }
.bridal-page .br-consult-title              { color: #141414; }
.bridal-page .br-consult-title em           { color: #000000; }
.bridal-page .br-consult-sub                { color: rgba(20, 20, 20, .68); }

/* Bullet tiles — white card, champagne tick that fills on hover */
.bridal-page .br-consult-points li {
  background: #FFFFFF;
  border: 1px solid rgba(74, 74, 74, .18);
}
.bridal-page .br-consult-points li:hover {
  background: #FFFFFF;
  border-color: rgba(74, 74, 74, .45);
  box-shadow: 0 14px 32px -18px rgba(74, 74, 74, .35);
}
.bridal-page .br-consult-tick {
  background: rgba(74, 74, 74, .12);
  color: #000000;
  border: 0;
}
.bridal-page .br-consult-points li:hover .br-consult-tick {
  background: #000000;
  color: #FFFFFF;
  border-color: #000000;
}
.bridal-page .br-consult-points strong { color: #141414; }
.bridal-page .br-consult-desc          { color: rgba(20, 20, 20, .62); }

/* Form — white card with bone hairline */
.bridal-page .br-form {
  background: #FFFFFF;
  border: 1px solid rgba(74, 74, 74, .18);
  box-shadow: 0 24px 60px -28px rgba(20, 20, 20, .22);
}
@keyframes brFormFlash {
  0%   { box-shadow: 0 24px 60px -28px rgba(20,20,20,.22), 0 0 0 0   rgba(74, 74, 74, 0);   border-color: rgba(74, 74, 74, .18); }
  25%  { box-shadow: 0 24px 60px -28px rgba(20,20,20,.22), 0 0 0 6px rgba(74, 74, 74, .22); border-color: rgba(74, 74, 74, .55); }
  100% { box-shadow: 0 24px 60px -28px rgba(20,20,20,.22), 0 0 0 0   rgba(74, 74, 74, 0);   border-color: rgba(74, 74, 74, .18); }
}

/* Form fields — cream-soft backgrounds, champagne focus accent */
.bridal-page .br-field input,
.bridal-page .br-field select,
.bridal-page .br-field textarea {
  background: #FAFAFA;
  border: 1px solid rgba(74, 74, 74, .22);
  color: #141414;
}
.bridal-page .br-field input:hover,
.bridal-page .br-field select:hover,
.bridal-page .br-field textarea:hover { border-color: rgba(74, 74, 74, .42); }
.bridal-page .br-field input:focus,
.bridal-page .br-field select:focus,
.bridal-page .br-field textarea:focus {
  background: #FFFFFF;
  border-color: #000000;
  box-shadow: 0 0 0 4px rgba(74, 74, 74, .15);
}
.bridal-page .br-field label { color: rgba(20, 20, 20, .55); }
.bridal-page .br-field input:focus + label,
.bridal-page .br-field input:not(:placeholder-shown) + label,
.bridal-page .br-field input[type="date"] + label,
.bridal-page .br-field textarea:focus + label,
.bridal-page .br-field textarea:not(:placeholder-shown) + label {
  background: linear-gradient(to bottom, transparent 45%, #FFFFFF 45%);
  color: #000000;
}

/* Custom dropdown + calendar triggers — match fields */
.bridal-page .br-form .bv-dd-btn,
.bridal-page .br-form .bv-cal-trigger {
  background: #FAFAFA;
  border: 1px solid rgba(74, 74, 74, .22);
  color: #141414;
}
.bridal-page .br-form .bv-dd-btn:hover,
.bridal-page .br-form .bv-cal-trigger:hover { border-color: rgba(74, 74, 74, .42); }
.bridal-page .br-form .bv-dd-btn:focus,
.bridal-page .br-form .bv-dd.open .bv-dd-btn,
.bridal-page .br-form .bv-cal-trigger:focus,
.bridal-page .br-form .bv-cal.open .bv-cal-trigger {
  background: #FFFFFF;
  border-color: #000000;
  box-shadow: 0 0 0 4px rgba(74, 74, 74, .15);
}
.bridal-page .br-form .bv-dd-display,
.bridal-page .br-form .bv-cal-display       { color: #141414; }
.bridal-page .br-form .bv-dd-arrow,
.bridal-page .br-form .bv-cal-ico           { stroke: #000000; color: #000000; }
.bridal-page .br-form .bv-cal-ico           { background: rgba(74, 74, 74, .10); border-color: rgba(74, 74, 74, .28); }
.bridal-page .br-form .bv-cal-ico svg       { stroke: #000000; }
.bridal-page .br-form .bv-dd-lbl,
.bridal-page .br-form .bv-cal-lbl           { color: rgba(20, 20, 20, .55); }
.bridal-page .br-form .bv-dd.open .bv-dd-lbl,
.bridal-page .br-form .bv-dd.has-val .bv-dd-lbl,
.bridal-page .br-form .bv-cal.open .bv-cal-lbl,
.bridal-page .br-form .bv-cal.has-val .bv-cal-lbl { color: #000000; }

/* Dropdown + calendar panels — white surfaces with bone borders */
.bridal-page .br-form .bv-dd-list,
.bridal-page .br-form .bv-cal-panel {
  background: #FFFFFF;
  border: 1px solid rgba(74, 74, 74, .22);
  box-shadow: 0 22px 52px rgba(20, 20, 20, .18), 0 6px 16px rgba(20, 20, 20, .14);
}
.bridal-page .br-form .bv-dd-list::-webkit-scrollbar-thumb { background: rgba(74, 74, 74, .28); }
.bridal-page .br-form .bv-dd-item            { color: rgba(20, 20, 20, .78); border-bottom-color: rgba(74, 74, 74, .12); }
.bridal-page .br-form .bv-dd-item:hover      { background: #FAFAFA; color: #141414; }
.bridal-page .br-form .bv-dd-item.selected   { background: rgba(74, 74, 74, .14); color: #000000; font-weight: 600; }
.bridal-page .br-form .bv-dd-item.selected::after {
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%238B6F47' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
}
.bridal-page .br-form .bv-cal-header         { border-bottom-color: rgba(74, 74, 74, .14); }
.bridal-page .br-form .bv-cal-title          { color: #141414; }
.bridal-page .br-form .bv-cal-nav            { background: #FAFAFA; border-color: rgba(74, 74, 74, .18); }
.bridal-page .br-form .bv-cal-nav:hover      { background: rgba(74, 74, 74, .14); border-color: rgba(74, 74, 74, .45); }
.bridal-page .br-form .bv-cal-nav svg        { stroke: rgba(20, 20, 20, .7); }
.bridal-page .br-form .bv-cal-nav:hover svg  { stroke: #000000; }
.bridal-page .br-form .bv-cal-wdays span     { color: rgba(20, 20, 20, .4); }
.bridal-page .br-form .bv-cal-day            { color: rgba(20, 20, 20, .85); }
.bridal-page .br-form .bv-cal-day:not(:disabled):not(.bv-cal-day--sel):hover { background: rgba(74, 74, 74, .12); color: #000000; }
.bridal-page .br-form .bv-cal-day--today     { border-color: rgba(74, 74, 74, .45); color: #000000; }
.bridal-page .br-form .bv-cal-day--sel       { background: #000000 !important; border-color: #000000 !important; color: #FFFFFF !important; box-shadow: 0 4px 14px rgba(74, 74, 74, .35); }
.bridal-page .br-form .bv-cal-day--past      { color: rgba(20, 20, 20, .25); }
.bridal-page .br-form .bv-cal-foot           { border-top-color: rgba(74, 74, 74, .14); }
.bridal-page .br-form .bv-cal-today-btn      { background: rgba(74, 74, 74, .14); color: #000000; }
.bridal-page .br-form .bv-cal-today-btn:hover{ background: #000000; color: #FFFFFF; }
.bridal-page .br-form .bv-cal-clear-btn      { color: rgba(20, 20, 20, .45); }
.bridal-page .br-form .bv-cal-clear-btn:hover{ color: #B33A3A; background: rgba(179, 58, 58, .08); }

/* Date picker — light theme */
.bridal-page .br-field input[type="date"]                                    { color-scheme: light; }
.bridal-page .br-field input[type="date"]::-webkit-datetime-edit             { color: #141414; }
.bridal-page .br-field input[type="date"]:not(.has-val)::-webkit-datetime-edit { color: rgba(20, 20, 20, .45); }
.bridal-page .br-field input[type="date"]::-webkit-calendar-picker-indicator { filter: none; opacity: .55; }
.bridal-page .br-field input[type="date"]::-webkit-calendar-picker-indicator:hover { opacity: 1; background: rgba(74, 74, 74, .12); }

/* Select dropdown native — light scheme */
.bridal-page .br-select select               { color-scheme: light; color: rgba(20, 20, 20, .55); }
.bridal-page .br-select.has-val select       { color: #141414; }
.bridal-page .br-select option               { background: #FFFFFF; color: #141414; }

/* Upload card — cream-soft tile, champagne accents */
.bridal-page .br-upload {
  background: #FAFAFA;
  border: 1.5px dashed rgba(74, 74, 74, .35);
}
.bridal-page .br-upload:hover { background: #FFFFFF; border-color: #000000; }
.bridal-page .br-upload-ico {
  background: rgba(74, 74, 74, .10);
  color: #000000;
  border: 1px solid rgba(74, 74, 74, .28);
}
.bridal-page .br-upload-text strong { color: #141414; }
.bridal-page .br-upload-text em     { color: rgba(20, 20, 20, .55); }
.bridal-page .br-upload-name        { color: #000000; }
.bridal-page .br-upload.has-file    { background: #FFFFFF; border-color: #000000; }

/* Submit pill — champagne gradient (matches home page CTAs) */
.bridal-page .br-submit {
  background: linear-gradient(135deg, #4A4A4A 0%, #000000 100%) !important;
  color: #FFFFFF !important;
  box-shadow: 0 14px 36px -14px rgba(74, 74, 74, .55);
}
.bridal-page .br-submit:hover {
  background: linear-gradient(135deg, #000000 0%, #2A2A2A 100%) !important;
  box-shadow: 0 22px 44px -16px rgba(74, 74, 74, .7);
}

/* Success banner + note */
.bridal-page .br-form-success {
  background: rgba(74, 74, 74, .10);
  border: 1px solid rgba(74, 74, 74, .30);
  color: #141414;
}
.bridal-page .br-form-success-ico { background: #000000; color: #FFFFFF; }
.bridal-page .br-form-success strong { color: #141414; }
.bridal-page .br-form-success div { color: rgba(20, 20, 20, .68); }
.bridal-page .br-form-note { color: rgba(20, 20, 20, .55); }


/* ═══════════════════════════════════════════
   REVEAL fallback
═══════════════════════════════════════════ */
.bridal-page .reveal { opacity: 0; transform: translateY(30px); transition: opacity .8s ease, transform .8s ease; }
.bridal-page .reveal.visible { opacity: 1; transform: translateY(0); }


/* ═══════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════ */
@media (max-width: 1100px) {
  .bridal-page .br-pieces-grid { grid-template-columns: repeat(3, 1fr); }
  .bridal-page .br-look-grid { grid-template-columns: repeat(3, 1fr); grid-auto-rows: 200px; }
  .bridal-page .br-look-1 { grid-column: span 2; grid-row: span 2; }
  .bridal-page .br-look-3 { grid-column: span 1; }
  .bridal-page .br-look-5 { grid-row: span 1; }
}

@media (max-width: 900px) {
  .bridal-page .br-overview-grid     { grid-template-columns: 1fr; }
  .bridal-page .br-pieces-grid       { grid-template-columns: repeat(2, 1fr); }
  .bridal-page .br-consult-shell     { grid-template-columns: 1fr; gap: 40px; }
  .bridal-page .br-form              { position: static; top: auto; }
  .bridal-page .br-overview          { padding: 40px 20px 80px; }
  .bridal-page .br-block,
  .bridal-page .br-lookbook,
  .bridal-page .br-consult           { padding: 80px 20px; }
  .bridal-page .br-final-cta         { padding: 100px 24px; }
  .bridal-page .br-section-head      { margin-bottom: 48px; }
  .bridal-page .br-look-grid         { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 180px; }
  .bridal-page .br-look-1            { grid-column: span 2; grid-row: span 1; }
}

@media (max-width: 600px) {
  .bridal-page .br-pieces-grid       { grid-template-columns: 1fr; }
  .bridal-page .br-form-row          { grid-template-columns: 1fr; gap: 18px; }
  .bridal-page .br-look-grid         { grid-template-columns: 1fr; grid-auto-rows: 220px; }
  .bridal-page .br-look-1,
  .bridal-page .br-look-3,
  .bridal-page .br-look-5            { grid-column: span 1; grid-row: span 1; }
  .bridal-page .br-hero-cta-row      { flex-direction: column; align-items: stretch; }
  .bridal-page .br-hero-cta-row .br-btn { width: 100%; justify-content: center; }
  .bridal-page .br-hero-trust        { gap: 14px; }
  .bridal-page .br-hero              { padding: calc(var(--nav-h, 100px) + 30px) 20px 40px; }
  .bridal-page .br-form              { padding: 28px 20px; gap: 16px; }
  .bridal-page .br-consult-points li { padding: 14px 14px; }
  .bridal-page .br-consult-row       { gap: 12px; }
  .bridal-page .br-consult-tick      { width: 36px; height: 36px; }
  .bridal-page .br-consult-tick svg  { width: 19px; height: 19px; }
  .bridal-page .br-consult-points strong { font-size: 18px; }
  .bridal-page .br-consult-desc      { padding-left: 0; margin-top: 10px; }
}

@media (max-width: 420px) {
  .bridal-page .br-form              { padding: 24px 16px; }
  .bridal-page .br-upload-lbl        { gap: 12px; padding: 16px 14px; }
  .bridal-page .br-upload-text strong { font-size: 12px; }
  .bridal-page .br-upload-text em    { font-size: 10.5px; }
  .bridal-page .br-upload-name       { display: none; }
  .bridal-page .br-field input,
  .bridal-page .br-field select,
  .bridal-page .br-field textarea    { font-size: 13.5px; }
  .bridal-page .br-field input[type="date"]::-webkit-datetime-edit { font-size: 13.5px; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .bridal-page .br-orb,
  .bridal-page .br-spark,
  .bridal-page .br-block-orb,
  .bridal-page .br-final-orb { animation: none; }
}


/* ═══════════════════════════════════════════════════════════════════
   BRIDAL SUB-PAGES  (.bridal-detail) — Full Bridal & Semi Bridal
   Builds on every .bridal-page rule above; adds a few new sections.
   ═══════════════════════════════════════════════════════════════════ */

/* Small index badge that sits next to a section eyebrow on these pages */
.bridal-detail .br-hero-title em { display: inline; }

/* ── A. INTRO SPLIT (image + copy + stat chips) ─────────────────── */
.bridal-detail .bd-intro {
  display: grid;
  grid-template-columns: 1.02fr 0.98fr;
  gap: 60px;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
  padding: 110px 24px;
  background: var(--br-cream);
}
.bridal-detail .bd-intro-media {
  position: relative;
  border-radius: 26px;
  overflow: hidden;
  box-shadow: var(--br-shadow);
  aspect-ratio: 4 / 5;
}
.bridal-detail .bd-intro-media img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform 1.1s cubic-bezier(.2,.7,.2,1);
}
.bridal-detail .bd-intro-media:hover img { transform: scale(1.05); }
.bridal-detail .bd-intro-media::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(200deg, transparent 55%, rgba(0,0,0,.45));
  pointer-events: none;
}
.bridal-detail .bd-intro-badge {
  position: absolute; left: 20px; bottom: 20px; z-index: 1;
  display: inline-flex; align-items: center; gap: 9px;
  padding: 10px 18px; border-radius: 60px;
  background: rgba(0,0,0,.55);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.18);
  color: #fff;
  font-family: 'Jost', sans-serif;
  font-size: 10.5px; font-weight: 500;
  letter-spacing: .22em; text-transform: uppercase;
}
.bridal-detail .bd-intro-badge svg { width: 14px; height: 14px; color: var(--br-champagne); }

/* Full-bridal "suite" mosaic: 2x2 of actual bridal pieces under the
   "Not a set you pick from a tray — a suite drawn around you" heading. */
.bridal-detail .bd-intro-media--suite {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 10px;
  padding: 10px;
  background: var(--br-cream);
}
.bridal-detail .bd-intro-media--suite::after { display: none; }
.bridal-detail .bd-intro-media--suite img {
  position: static; height: 100%;
}
.bridal-detail .bd-intro-tile {
  position: relative; margin: 0;
  border-radius: 16px; overflow: hidden;
  box-shadow: 0 6px 18px rgba(0,0,0,.08);
}
.bridal-detail .bd-intro-tile img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform 1.1s cubic-bezier(.2,.7,.2,1);
}
.bridal-detail .bd-intro-media--suite:hover .bd-intro-tile img { transform: scale(1.05); }
.bridal-detail .bd-intro-tile-cap {
  position: absolute; left: 10px; bottom: 10px; z-index: 1;
  display: inline-flex; align-items: center;
  padding: 5px 11px; border-radius: 999px;
  background: rgba(0,0,0,.55);
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,.16);
  color: #fff;
  font-family: 'Jost', sans-serif;
  font-size: 10px; font-weight: 500;
  letter-spacing: .22em; text-transform: uppercase;
}
.bridal-detail .bd-intro-media--suite .bd-intro-badge {
  left: auto; bottom: auto;
  top: 18px; right: 18px;
  z-index: 2;
}

.bridal-detail .bd-intro-body .br-eyebrow { margin-bottom: 18px; }
.bridal-detail .bd-intro-title {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: clamp(30px, 4.2vw, 50px);
  line-height: 1.08;
  letter-spacing: -.01em;
  color: var(--br-ink);
  margin-bottom: 20px;
}
.bridal-detail .bd-intro-title em { font-style: italic; color: var(--br-gold); }
.bridal-detail .bd-intro-body p {
  font-family: 'Jost', sans-serif;
  font-size: 15px; line-height: 1.8;
  color: rgba(0,0,0,.66);
  margin-bottom: 16px;
}
.bridal-detail .bd-intro-body p:last-of-type { margin-bottom: 28px; }

.bridal-detail .bd-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.bridal-detail .bd-stat {
  padding: 18px 16px;
  border: 1px solid var(--br-line);
  border-radius: 16px;
  background: #fff;
  box-shadow: var(--br-shadow-soft);
  text-align: center;
}
.bridal-detail .bd-stat b {
  display: block;
  font-family: 'Cormorant Garamond', serif;
  font-weight: 500;
  font-size: 28px;
  line-height: 1;
  color: var(--br-gold);
  margin-bottom: 7px;
}
.bridal-detail .bd-stat span {
  font-family: 'Jost', sans-serif;
  font-size: 10.5px; font-weight: 500;
  letter-spacing: .14em; text-transform: uppercase;
  color: rgba(0,0,0,.55);
}

/* ── B. PROCESS STEPS ───────────────────────────────────────────── */
.bridal-detail .bd-steps-wrap { padding: 110px 24px; background: var(--br-cream-2); }
.bridal-detail .bd-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
  max-width: 1200px; margin: 0 auto;
}
.bridal-detail .bd-step {
  position: relative;
  padding: 30px 24px 28px;
  border: 1px solid var(--br-line);
  border-radius: 20px;
  background: #fff;
  box-shadow: var(--br-shadow-soft);
  transition: transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s, border-color .4s;
  overflow: hidden;
}
.bridal-detail .bd-step::before {
  content: ''; position: absolute; left: 0; top: 0; width: 100%; height: 3px;
  background: linear-gradient(90deg, var(--br-gold-l), var(--br-champagne));
  transform: scaleX(0); transform-origin: left;
  transition: transform .5s cubic-bezier(.2,.7,.2,1);
}
.bridal-detail .bd-step:hover {
  transform: translateY(-6px);
  box-shadow: 0 26px 60px -26px rgba(0,0,0,.30);
  border-color: rgba(0,0,0,.42);
}
.bridal-detail .bd-step:hover::before { transform: scaleX(1); }
.bridal-detail .bd-step-num {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 500; font-size: 30px;
  color: rgba(74,74,74,.55);
  line-height: 1;
  margin-bottom: 16px;
}
.bridal-detail .bd-step h3 {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 500; font-size: 21px;
  color: var(--br-ink);
  margin-bottom: 9px; line-height: 1.2;
}
.bridal-detail .bd-step p {
  font-family: 'Jost', sans-serif;
  font-size: 13px; line-height: 1.7;
  color: rgba(0,0,0,.6);
}

/* ── C. CROSS-PROMO SWITCH BAND ─────────────────────────────────── */
.bridal-detail .bd-switch {
  position: relative;
  padding: 90px 24px;
  background:
    radial-gradient(circle at 15% 25%, rgba(74,74,74,.12), transparent 55%),
    radial-gradient(circle at 85% 75%, rgba(74,74,74,.08), transparent 55%),
    linear-gradient(180deg, var(--br-cream-2) 0%, var(--br-cream) 100%);
  overflow: hidden; color: var(--br-ink);
}
.bridal-detail .bd-switch-inner {
  position: relative; z-index: 1;
  max-width: 1100px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  gap: 36px; flex-wrap: wrap;
}
.bridal-detail .bd-switch-text { max-width: 640px; }
.bridal-detail .bd-switch-text .br-eyebrow { margin-bottom: 14px; }
.bridal-detail .bd-switch-text h2 {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400; font-size: clamp(28px, 3.6vw, 44px);
  line-height: 1.1; color: var(--br-ink); margin-bottom: 12px;
}
.bridal-detail .bd-switch-text h2 em { font-style: italic; color: var(--br-gold); }
.bridal-detail .bd-switch-text p {
  font-family: 'Jost', sans-serif;
  font-size: 14.5px; line-height: 1.75;
  color: rgba(0, 0, 0, 0.66);
}

/* ── Dark monochrome variant — applied ONLY on /full-bridal ─────────── */
.bridal-detail--full .bd-switch {
  background:
    radial-gradient(circle at 15% 25%, rgba(255, 255, 255, .14), transparent 55%),
    radial-gradient(circle at 85% 75%, rgba(255, 255, 255, .08), transparent 55%),
    linear-gradient(180deg, #0A0A0A 0%, #1A1A1A 50%, #000000 100%);
  color: #FAFAFA;
}
.bridal-detail--full .bd-switch .br-eyebrow {
  color: var(--br-champagne, #FAFAFA);
}
.bridal-detail--full .bd-switch .br-eyebrow::before,
.bridal-detail--full .bd-switch .br-eyebrow::after {
  background: rgba(255, 255, 255, .32);
}
.bridal-detail--full .bd-switch-text h2 {
  color: #FAFAFA;
}
.bridal-detail--full .bd-switch-text h2 em {
  color: var(--br-champagne, #FAFAFA);
}
.bridal-detail--full .bd-switch-text p {
  color: rgba(250, 250, 250, .78);
}

/* ── /semi-bridal only — measured gap between
   "What Semi Bridal Means" (.bd-intro) and "The Semi Bridal Suite" (.br-block).
   Was 150+150 = 300px (too airy); tightened to a single ~80px breath. ── */
.bridal-detail--semi .bd-intro {
  padding-bottom: 70px;
}
.bridal-detail--semi .bd-intro + .br-block {
  padding-top: 70px;
}
@media (max-width: 900px) {
  .bridal-detail--semi .bd-intro {
    padding-bottom: 50px;
  }
  .bridal-detail--semi .bd-intro + .br-block {
    padding-top: 50px;
  }
}

/* ── /full-bridal only — tighten gap between
   "What Full Bridal Means" (.bd-intro) and "Bridal Trousseau" (.br-materials) ── */
.bridal-detail--full .bd-intro {
  padding-bottom: 50px;
}
.bridal-detail--full .bd-intro + .br-materials {
  padding-top: 50px;
}
@media (max-width: 900px) {
  .bridal-detail--full .bd-intro {
    padding-bottom: 40px;
  }
  .bridal-detail--full .bd-intro + .br-materials {
    padding-top: 40px;
  }
}

/* ── Final CTA override on bridal-detail pages ──────────────────────
   Slightly brighter off-white wash so the Full Bridal / Semi Bridal
   detail pages feel distinct from the main bridal page, staying inside
   the home page's pure monochrome palette. */
.bridal-detail .br-final-cta {
  background:
    radial-gradient(circle at 30% 30%, rgba(74, 74, 74, .14), transparent 60%),
    radial-gradient(circle at 75% 70%, rgba(74, 74, 74, .10), transparent 60%),
    linear-gradient(135deg, #FFFFFF 0%, #FAFAFA 100%);
}
.bridal-detail .br-final-orb-1 {
  background: radial-gradient(circle, rgba(74, 74, 74, .22), transparent 70%);
}
.bridal-detail .br-final-orb-2 {
  background: radial-gradient(circle, rgba(74, 74, 74, .16), transparent 70%);
}
.bridal-detail .br-final-title em { color: var(--br-gold); }

/* ── Responsive (sub-pages) ─────────────────────────────────────── */
@media (max-width: 1100px) {
  .bridal-detail .bd-steps { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 900px) {
  .bridal-detail .bd-intro {
    grid-template-columns: 1fr;
    gap: 36px;
    padding: 80px 20px;
  }
  .bridal-detail .bd-intro-media { aspect-ratio: 16 / 11; order: -1; }
  .bridal-detail .bd-steps-wrap,
  .bridal-detail .bd-switch { padding: 80px 20px; }
  .bridal-detail .bd-switch-inner { flex-direction: column; align-items: flex-start; gap: 24px; }
}
@media (max-width: 540px) {
  .bridal-detail .bd-stats { grid-template-columns: 1fr; }
  .bridal-detail .bd-steps { grid-template-columns: 1fr; }
  .bridal-detail .bd-switch-inner .br-btn { width: 100%; justify-content: center; }
}

/* ══════════════════════════════════════════════════════════════════
   FEATURED PIECES — card grid (mirrors precious.css .pr-feat-*)
══════════════════════════════════════════════════════════════════ */
.bridal-page .br-featured {
  padding: 110px 0;
  background: var(--br-cream-2);
}
.bridal-page .br-featured .br-wrap,
.bridal-page .br-feat-wrap {
  max-width: 1240px; margin: 0 auto; padding: 0 24px;
}
.bridal-page .br-feat-head {
  text-align: center; max-width: 720px; margin: 0 auto 56px; padding: 0 4px;
}
.bridal-page .br-feat-eyebrow {
  display: inline-block;
  font-family: 'Jost', sans-serif;
  font-size: 11px; font-weight: 600;
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--br-gold); margin-bottom: 14px;
}
.bridal-page .br-feat-title {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400; font-size: clamp(34px, 4vw, 50px);
  line-height: 1.12; color: var(--br-ink);
}
.bridal-page .br-feat-title em { font-style: italic; color: var(--br-gold); }
.bridal-page .br-feat-sub {
  margin-top: 14px;
  font-family: 'Jost', sans-serif;
  font-size: 14px; line-height: 1.6;
  color: rgba(0,0,0,.62);
}
/* Filter pills — All / Gold-Silver OR Full-Semi Bridal */
.bridal-page .br-filter {
  display: flex; flex-wrap: nowrap; justify-content: center; gap: 6px;
  margin: 0 auto 48px;
  padding: 6px;
  width: fit-content;
  max-width: 100%;
  background: #fff;
  border: 1px solid var(--br-line);
  border-radius: 60px;
  box-shadow: var(--br-shadow-soft);
}
.bridal-page .br-filter-btn {
  flex: 0 1 auto;
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 11px 22px;
  background: transparent;
  border: none;
  border-radius: 50px;
  font-family: 'Jost', sans-serif;
  font-size: 12px; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase;
  color: rgba(0,0,0,.55);
  cursor: pointer;
  transition: background .25s, color .25s;
  white-space: nowrap;
}
@media (max-width: 520px) {
  .bridal-page .br-filter {
    flex-wrap: wrap;
    border-radius: 24px;
    padding: 8px;
    gap: 4px;
  }
  .bridal-page .br-filter-btn {
    flex: 1 1 auto;
    padding: 10px 14px;
    font-size: 11px;
    letter-spacing: .08em;
  }
}
.bridal-page .br-filter-btn:hover { color: var(--br-ink); }
.bridal-page .br-filter-btn.is-active {
  background: linear-gradient(135deg, var(--br-gold-l), var(--br-gold));
  color: #fff;
  box-shadow: 0 6px 20px -8px rgba(0, 0, 0, .45);
}
.bridal-page .br-filter-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  display: inline-block;
}
.bridal-page .br-filter-dot--all    { background: linear-gradient(135deg, #000000, #B7C2C9); }
.bridal-page .br-filter-dot--gold   { background: #000000; }
.bridal-page .br-filter-dot--silver { background: #B7C2C9; }
.bridal-page .br-filter-dot--full   { background: #000000; }
.bridal-page .br-filter-dot--semi   { background: #4A4A4A; }
.bridal-page .br-filter-btn.is-active .br-filter-dot { box-shadow: 0 0 0 2px rgba(255,255,255,.6); }

.bridal-page .br-feat-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
}
/* Filter hide state — JS toggles 'is-hidden' */
.bridal-page .br-feat-card.is-hidden {
  opacity: 0; transform: scale(.92);
  pointer-events: none;
  position: absolute; visibility: hidden;
}
/* Badge variants on the card image — metal AND bridal-type */
.bridal-page .br-feat-tag--gold   { background: rgba(0, 0, 0, .85); color: #FFFFFF; }
.bridal-page .br-feat-tag--silver { background: rgba(183, 194, 201, .92); color: #000000; }
.bridal-page .br-feat-tag--full   { background: rgba(0, 0, 0, .85); color: #FFFFFF; }
.bridal-page .br-feat-tag--semi   { background: rgba(255, 255, 255, .94); color: #000000; }
.bridal-page .br-feat-card {
  background: #fff;
  border: 1px solid var(--br-line);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: var(--br-shadow-soft);
  transition: transform .45s cubic-bezier(.2,.7,.2,1), box-shadow .45s, border-color .45s;
  display: flex; flex-direction: column;
  position: relative;
}
.bridal-page .br-feat-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 60px -22px rgba(0,0,0,.30);
  border-color: rgba(0, 0, 0, .42);
}
.bridal-page .br-feat-img {
  position: relative; aspect-ratio: 1/1; overflow: hidden;
}
.bridal-page .br-feat-img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .8s cubic-bezier(.2,.7,.2,1);
}
.bridal-page .br-feat-card:hover .br-feat-img img { transform: scale(1.07); }
.bridal-page .br-feat-num {
  position: absolute; bottom: 12px; right: 12px;
  background: rgba(0,0,0,.65); color: #fff;
  font-family: 'Cormorant Garamond', serif;
  font-size: 13px; font-weight: 500;
  padding: 4px 10px; border-radius: 30px;
  letter-spacing: .1em;
  backdrop-filter: blur(4px);
  z-index: 2;
}
.bridal-page .br-feat-tag {
  position: absolute; top: 12px; left: 12px;
  padding: 5px 12px; border-radius: 30px;
  font-family: 'Jost', sans-serif;
  font-size: 9.5px; font-weight: 600;
  letter-spacing: .2em; text-transform: uppercase;
  backdrop-filter: blur(4px);
  background: rgba(0, 0, 0, .85);
  color: #FFFFFF;
}
.bridal-page .br-feat-body {
  padding: 18px 18px 22px;
  display: flex; flex-direction: column; gap: 8px;
  flex: 1;
}
.bridal-page .br-feat-meta {
  font-family: 'Jost', sans-serif;
  font-size: 10px; font-weight: 500;
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--br-gold);
}
.bridal-page .br-feat-name {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400; font-size: 19px;
  line-height: 1.2; color: var(--br-ink);
}
.bridal-page .br-feat-desc {
  font-family: 'Jost', sans-serif;
  font-size: 12.5px; line-height: 1.6;
  color: rgba(0,0,0,.62);
  flex: 1;
}
@media (max-width: 1100px) {
  .bridal-page .br-feat-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 820px) {
  .bridal-page .br-feat-grid { grid-template-columns: repeat(2, 1fr); }
  .bridal-page .br-featured  { padding: 80px 0; }
}
@media (max-width: 520px) {
  .bridal-page .br-feat-grid { grid-template-columns: 1fr; }
}

/* ── Product variant: card is a link, has wishlist + cart buttons, price row ── */
.bridal-page a.br-feat-card--product {
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
}
.bridal-page .br-feat-wish {
  position: absolute;
  top: 12px; right: 12px;
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid var(--br-line);
  border-radius: 999px;
  cursor: pointer;
  color: var(--br-ink);
  padding: 0;
  backdrop-filter: blur(4px);
  transition: background .25s ease, transform .25s ease, color .25s ease, border-color .25s ease;
  z-index: 3;
}
.bridal-page .br-feat-wish svg { width: 17px; height: 17px; }
.bridal-page .br-feat-wish:hover {
  background: var(--br-ink);
  color: #fff;
  transform: scale(1.05);
}
.bridal-page .br-feat-wish:hover svg { fill: currentColor; }
.bridal-page .br-feat-wish.is-on {
  background: var(--br-ink);
  color: #fff;
  border-color: var(--br-ink);
}
.bridal-page .br-feat-foot {
  margin-top: auto;
  padding-top: 14px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  border-top: 1px solid var(--br-line);
}
.bridal-page .br-feat-price {
  font-family: 'Cormorant Garamond', serif;
  font-size: 20px;
  font-weight: 500;
  color: var(--br-ink);
  letter-spacing: 0.01em;
}
.bridal-page .br-feat-cart {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--br-ink);
  color: #fff;
  border: 1px solid var(--br-ink);
  border-radius: 999px;
  padding: 9px 16px;
  font-family: 'Jost', sans-serif;
  font-size: 11.5px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .25s ease, color .25s ease, transform .25s ease;
}
.bridal-page .br-feat-cart svg { width: 14px; height: 14px; }
.bridal-page .br-feat-cart:hover {
  background: #fff;
  color: var(--br-ink);
}
.bridal-page .br-feat-cart.is-flash {
  transform: scale(0.96);
}
@media (max-width: 520px) {
  .bridal-page .br-feat-cart span { display: none; }
  .bridal-page .br-feat-cart { padding: 9px 11px; }
}

/* Empty state when no bridal products published yet */
.bridal-page .br-feat-empty {
  max-width: 560px;
  margin: 0 auto;
  text-align: center;
  padding: 48px 24px;
  border: 1px dashed var(--br-line);
  border-radius: 18px;
  background: var(--br-cream-2);
}
.bridal-page .br-feat-empty p {
  font-family: 'Jost', sans-serif;
  font-size: 14px;
  color: rgba(0, 0, 0, 0.7);
  margin: 0 0 20px;
}

/* Toast — minimal monochrome flash */
.bridal-page .br-toast,
.br-toast {
  position: fixed;
  bottom: 28px; left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: #000;
  color: #fff;
  font-family: 'Jost', sans-serif;
  font-size: 13px;
  letter-spacing: 0.04em;
  padding: 12px 22px;
  border-radius: 999px;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s ease, transform .25s ease;
  z-index: 9000;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.25);
}
.br-toast.is-on {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* ══════════════════════════════════════════════════════════════════
   BRIDAL MATERIALS — lifestyle lehenga/saree imagery (full-bridal only)
══════════════════════════════════════════════════════════════════ */
.bridal-page .br-materials {
  padding: 110px 0;
  background: linear-gradient(180deg, var(--br-cream) 0%, #fff 100%);
}
.bridal-page .br-mat-head {
  text-align: center; max-width: 720px; margin: 0 auto 56px; padding: 0 24px;
}
.bridal-page .br-mat-grid {
  max-width: 1240px; margin: 0 auto; padding: 0 24px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 280px;
  gap: 18px;
}
.bridal-page .br-mat-card {
  position: relative;
  overflow: hidden;
  border-radius: 16px;
  background: #FAFAFA;
  cursor: pointer;
  transition: transform .45s cubic-bezier(.2,.7,.2,1), box-shadow .45s;
  box-shadow: var(--br-shadow-soft);
}
.bridal-page .br-mat-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 60px -22px rgba(0,0,0,.35);
}
.bridal-page .br-mat-card--wide { grid-column: span 2; }
.bridal-page .br-mat-card--tall { grid-row: span 2; }
.bridal-page .br-mat-card img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform 1s cubic-bezier(.2,.7,.2,1);
}
.bridal-page .br-mat-card:hover img { transform: scale(1.08); }
.bridal-page .br-mat-caption {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: 24px 20px 18px;
  background: linear-gradient(to top, rgba(0,0,0,.85) 0%, transparent 100%);
  color: #fff;
  font-family: 'Jost', sans-serif;
  font-size: 12px; font-weight: 500;
  letter-spacing: .12em; text-transform: uppercase;
  transform: translateY(8px);
  opacity: .92;
  transition: transform .35s, opacity .35s;
}
.bridal-page .br-mat-card:hover .br-mat-caption { transform: translateY(0); opacity: 1; }
@media (max-width: 1100px) {
  .bridal-page .br-mat-grid { grid-template-columns: repeat(3, 1fr); grid-auto-rows: 240px; }
}
@media (max-width: 820px) {
  .bridal-page .br-mat-grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 220px; gap: 14px; }
  .bridal-page .br-mat-card--wide { grid-column: span 1; }
  .bridal-page .br-mat-card--tall { grid-row: span 1; }
  .bridal-page .br-materials  { padding: 80px 0; }
}
