/* =========================================================
   Haven Collective Theme
   static/opshop/theme.css
   Modern editorial retail style:
   - straight lines
   - generous spacing
   - greys, deep red, gold
   - promoted content as visual hero
   - large overlapping AI search
   ========================================================= */

/* -----------------------------
   Design Tokens
----------------------------- */

:root {
  --haven-ink: #171717;
  --haven-charcoal: #2b2b2b;
  --haven-soft-charcoal: #3f3f46;

  --haven-grey: #707070;
  --haven-mid-grey: #a1a1aa;
  --haven-light-grey: #f5f5f5;
  --haven-panel-grey: #f8f8f8;

  --haven-paper: #fbfaf7;
  --haven-white: #ffffff;

  --haven-red: #8f1728;
  --haven-red-dark: #5f0f1b;
  --haven-red-soft: rgba(143, 23, 40, .1);

  --haven-gold: #b98a2f;
  --haven-gold-light: #d7b35c;
  --haven-gold-soft: #f3e2b8;

  --haven-border: rgba(23, 23, 23, .16);
  --haven-border-light: rgba(23, 23, 23, .08);

  --haven-shadow: 0 28px 90px rgba(23, 23, 23, .18);
  --haven-shadow-soft: 0 14px 48px rgba(23, 23, 23, .08);

  --haven-max-width: 1380px;
  --haven-wide-width: 1680px;
}

/* -----------------------------
   Base
----------------------------- */

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 90px;
}

body {
  margin: 0;
  background: var(--haven-paper);
  color: var(--haven-ink);
  font-family: "Montserrat Alternates", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.5;
}

img,
video {
  max-width: 100%;
}

a {
  color: inherit;
}

main.container,
footer.container,
.navbar .container {
  max-width: var(--haven-max-width);
}

/* Remove old rounded / paper effects from earlier theme */
.card,
.paper-grain,
.footer-card,
.product-card,
.haven-feature-card,
.haven-mini-card,
.haven-contact-box,
.haven-partner-card,
.launch-note,
.alert,
.form-control,
.form-select,
.btn {
  border-radius: 0 !important;
}

.paper-grain {
  box-shadow: none;
}

.paper-grain::before,
.paper-grain::after {
  display: none !important;
}

/* -----------------------------
   Typography
----------------------------- */

.brand {
  margin: 0;
  color: var(--haven-ink);
  font-family: inherit;
  font-size: 1.05rem;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.navbar small {
  color: var(--haven-grey);
  letter-spacing: .14em;
  text-transform: uppercase;
  font-size: .63rem;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  color: var(--haven-ink);
}

.section-kicker {
  display: inline-flex;
  margin-bottom: .9rem;
  color: var(--haven-red);
  font-size: .7rem;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.section-kicker-light {
  color: var(--haven-gold-light);
}

.text-secondary,
.small-muted {
  color: var(--haven-grey) !important;
}

/* -----------------------------
   Navigation
----------------------------- */

.navbar {
  background: rgba(251, 250, 247, .96);
  border-bottom: 1px solid var(--haven-border);
  box-shadow: none;
  backdrop-filter: blur(8px);
}

.navbar-brand {
  min-width: max-content;
}

.nav-link {
  position: relative;
  color: var(--haven-ink);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding-inline: .7rem !important;
}

.nav-link::after {
  content: "";
  position: absolute;
  left: .7rem;
  right: .7rem;
  bottom: .25rem;
  height: 1px;
  background: var(--haven-red);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .24s ease;
}

.nav-link:hover,
.nav-link:focus {
  color: var(--haven-red);
}

.nav-link:hover::after,
.nav-link:focus::after {
  transform: scaleX(1);
}

.navbar-toggler {
  border-radius: 0;
  border-color: var(--haven-border);
}

/* -----------------------------
   Buttons
----------------------------- */

.btn {
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: .8rem 1.05rem;
  box-shadow: none !important;
}

.btn-sm {
  padding: .52rem .82rem;
  font-size: .68rem;
}

.btn-lg {
  padding: .95rem 1.35rem;
}

.btn-primary {
  --bs-btn-bg: var(--haven-red);
  --bs-btn-border-color: var(--haven-red);
  --bs-btn-hover-bg: var(--haven-red-dark);
  --bs-btn-hover-border-color: var(--haven-red-dark);
  --bs-btn-active-bg: var(--haven-red-dark);
  --bs-btn-active-border-color: var(--haven-red-dark);
  --bs-btn-color: #fff;
}

.btn-outline-primary {
  --bs-btn-color: var(--haven-ink);
  --bs-btn-border-color: var(--haven-ink);
  --bs-btn-hover-bg: var(--haven-ink);
  --bs-btn-hover-border-color: var(--haven-ink);
  --bs-btn-hover-color: #fff;
}

.btn-gold {
  background: var(--haven-gold);
  border-color: var(--haven-gold);
  color: var(--haven-ink);
  font-weight: 900;
}

.btn-gold:hover,
.btn-gold:focus {
  background: var(--haven-gold-light);
  border-color: var(--haven-gold-light);
  color: var(--haven-ink);
}

/* -----------------------------
   Forms
----------------------------- */

.form-label {
  color: var(--haven-charcoal);
  font-size: .7rem;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.form-control,
.form-select {
  border-color: rgba(23, 23, 23, .22);
  padding: .82rem .9rem;
  background-color: #fff;
  color: var(--haven-ink);
}

.form-control:focus,
.form-select:focus {
  border-color: var(--haven-red);
  box-shadow: 0 0 0 .15rem rgba(143, 23, 40, .12);
}

/* -----------------------------
   Hide old hero if still present
----------------------------- */

.haven-logo-hero,
.hero {
  display: none !important;
}

/* -----------------------------
   Promoted Feature Banner
----------------------------- */

.promoted-stage {
  perspective: 1400px;
}

.promoted-stage-wide,
.promoted-stage {
  width: min(100vw - 2rem, var(--haven-wide-width));
  margin-left: 50%;
  transform: translateX(-50%);
  margin-bottom: 0 !important;
}

.promoted-frame {
  position: relative;
  background: #fff;
  padding: clamp(.7rem, 1.4vw, 1.15rem);
  box-shadow:
    0 0 0 1px rgba(23, 23, 23, .08),
    0 30px 90px rgba(23, 23, 23, .2);
}

.promoted-frame::before {
  content: "";
  position: absolute;
  inset: clamp(.7rem, 1.4vw, 1.15rem);
  border: 1px solid rgba(255, 255, 255, .38);
  pointer-events: none;
  z-index: 5;
}

.promoted-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  min-height: clamp(620px, 78vh, 820px);
  overflow: hidden;
  background: #111;
  border: 0;
  box-shadow: none;
}

.promo-panel {
  position: relative;
  isolation: isolate;
  min-height: clamp(620px, 78vh, 820px);
  overflow: hidden;
  color: #fff;
  text-decoration: none;
  border-right: 1px solid rgba(255, 255, 255, .22);
  transform-style: preserve-3d;
  transition:
    transform .7s cubic-bezier(.2,.8,.2,1),
    filter .45s ease;
}

.promo-panel:last-child {
  border-right: 0;
}

.promo-panel:hover,
.promo-panel.is-active {
  color: #fff;
  z-index: 3;
}

.promo-media,
.promo-media img,
.promo-media video,
.promo-placeholder {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.promo-media img,
.promo-media video {
  object-fit: cover;
  transform: scale(1.02);
  transition: transform 1.1s cubic-bezier(.2,.8,.2,1), filter .8s ease;
}

.promo-panel::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.78)),
    linear-gradient(90deg, rgba(0,0,0,.22), transparent 55%);
}

.promo-placeholder {
  background:
    radial-gradient(circle at 30% 20%, rgba(185, 138, 47, .35), transparent 26rem),
    linear-gradient(135deg, var(--haven-red-dark), var(--haven-charcoal));
}

.promo-copy {
  position: absolute;
  left: clamp(1rem, 2vw, 2rem);
  right: clamp(1rem, 2vw, 2rem);
  bottom: clamp(1.25rem, 2.5vw, 2.5rem);
  z-index: 4;
  transform: translateY(18px);
  transition: transform .5s ease;
}

.promo-badge {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  width: fit-content;
  padding: .45rem .7rem;
  color: #fff;
  font-size: .66rem;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
  background: rgba(0, 0, 0, .38);
  border: 1px solid rgba(255, 255, 255, .42);
  backdrop-filter: blur(6px);
}

.promo-ai {
  border-left: 1px solid rgba(255, 255, 255, .4);
  padding-left: .5rem;
}

.promo-copy h2 {
  margin: 1rem 0 .7rem;
  color: #fff;
  font-size: clamp(1.65rem, 3vw, 3.5rem);
  line-height: .95;
  letter-spacing: -.06em;
  font-weight: 900;
  text-shadow: 0 4px 24px rgba(0,0,0,.35);
}

.promo-subtitle,
.promo-body {
  max-width: 28rem;
  color: rgba(255,255,255,.82);
  margin: 0;
}

.promo-body {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height .45s ease, opacity .45s ease, margin-top .45s ease;
}

.promo-link {
  display: inline-block;
  margin-top: 1rem;
  color: #fff;
  font-size: .7rem;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
  border-bottom: 1px solid currentColor;
}

.promo-panel:hover .promo-media img,
.promo-panel:hover .promo-media video,
.promo-panel.is-active .promo-media img,
.promo-panel.is-active .promo-media video {
  transform: scale(1.12);
  filter: saturate(1.05) contrast(1.04);
}

.promo-panel:hover .promo-copy,
.promo-panel.is-active .promo-copy {
  transform: translateY(0);
}

.promo-panel:hover .promo-body,
.promo-panel.is-active .promo-body {
  max-height: 8rem;
  opacity: 1;
  margin-top: .55rem;
}

/* Subtle panel effects */
.promo-effect-flip:hover,
.promo-effect-flip.is-active {
  transform: translateY(-8px);
}

.promo-effect-swipe:hover,
.promo-effect-swipe.is-active {
  transform: translateX(-4px);
}

.promo-effect-twist:hover,
.promo-effect-twist.is-active {
  transform: translateY(-8px) skewY(-.8deg);
}

.promo-effect-zoom:hover,
.promo-effect-zoom.is-active {
  transform: scale(1.025);
}

/* -----------------------------
   Overlapping AI Search
----------------------------- */

.haven-search-overlap {
  position: relative;
  z-index: 10;
  margin-top: clamp(-5.8rem, -7vw, -4rem);
  margin-bottom: clamp(3rem, 6vw, 5rem);
}

.haven-search-panel {
  width: min(1180px, calc(100vw - 2rem));
  margin-inline: auto;
  background: rgba(255, 255, 255, .97);
  border: 1px solid rgba(23, 23, 23, .14);
  box-shadow:
    0 22px 70px rgba(23, 23, 23, .18),
    inset 0 1px 0 rgba(255,255,255,.9);
  padding: clamp(1.25rem, 3vw, 2.5rem);
}

.haven-search-heading {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
  gap: clamp(1rem, 3vw, 3rem);
  align-items: end;
  margin-bottom: 1.5rem;
}

.haven-search-heading .section-kicker {
  grid-column: 1 / -1;
  margin-bottom: 0;
}

.haven-search-heading h1 {
  margin: 0;
  max-width: 760px;
  font-size: clamp(2rem, 4.8vw, 4.6rem);
  line-height: .92;
  letter-spacing: -.07em;
  font-weight: 900;
}

.haven-search-heading p {
  margin: 0;
  color: var(--haven-grey);
  font-size: 1rem;
  line-height: 1.6;
}

.haven-ai-search-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  border: 1px solid rgba(23, 23, 23, .22);
  background: #fff;
}

.haven-main-search {
  min-height: 64px;
  border: 0 !important;
  box-shadow: none !important;
  font-size: clamp(1rem, 1.7vw, 1.25rem);
  padding-inline: 1.2rem;
}

.haven-search-btn {
  min-width: 150px;
  border-top: 0 !important;
  border-bottom: 0 !important;
  border-right: 0 !important;
}

.haven-filter-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr)) auto;
  gap: .75rem;
  align-items: end;
}

.haven-filter-actions {
  display: flex;
  gap: .5rem;
}

.haven-search-prompts {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
}

.haven-prompt-chip {
  border: 1px solid rgba(23, 23, 23, .18);
  background: #fff;
  color: var(--haven-ink);
  padding: .55rem .75rem;
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
  transition: background .18s ease, color .18s ease, border-color .18s ease;
}

.haven-prompt-chip:hover {
  background: var(--haven-ink);
  color: #fff;
  border-color: var(--haven-ink);
}

/* Legacy filter-chip support */
.filter-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
}

.filter-chip {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  border: 1px solid rgba(23, 23, 23, .2);
  padding: .55rem .75rem;
  color: var(--haven-ink);
  background: #fff;
  text-decoration: none;
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.filter-chip:hover,
.filter-chip.active {
  color: #fff;
  background: var(--haven-red);
  border-color: var(--haven-red);
}

.filter-chip span {
  display: inline-flex;
  min-width: 1.3rem;
  height: 1.3rem;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,.08);
  font-size: .66rem;
}

/* -----------------------------
   Platform Promotion Section
----------------------------- */

.haven-platform-section {
  padding-top: clamp(1rem, 3vw, 2rem);
}

.haven-platform-intro {
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: clamp(1rem, 4vw, 4rem);
  align-items: start;
  margin-bottom: 2rem;
  border-top: 1px solid rgba(23, 23, 23, .18);
  padding-top: 2rem;
}

.haven-platform-intro h2 {
  max-width: 980px;
  margin: 0;
  font-size: clamp(2rem, 4vw, 4.4rem);
  line-height: .95;
  letter-spacing: -.07em;
  font-weight: 900;
}

.haven-platform-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  border-top: 1px solid rgba(23, 23, 23, .18);
  border-left: 1px solid rgba(23, 23, 23, .18);
}

.haven-platform-card {
  min-height: 270px;
  padding: clamp(1.25rem, 2.4vw, 2rem);
  border-right: 1px solid rgba(23, 23, 23, .18);
  border-bottom: 1px solid rgba(23, 23, 23, .18);
  background: #fff;
  transition: background .2s ease, color .2s ease;
}

.haven-platform-card:hover {
  background: var(--haven-ink);
  color: #fff;
}

.haven-platform-card span {
  display: block;
  margin-bottom: 2rem;
  color: var(--haven-red);
  font-size: .8rem;
  font-weight: 900;
  letter-spacing: .12em;
}

.haven-platform-card:hover span,
.haven-platform-card:hover p {
  color: rgba(255,255,255,.72);
}

.haven-platform-card h3 {
  max-width: 15rem;
  color: inherit;
  font-size: clamp(1.25rem, 2vw, 1.8rem);
  font-weight: 900;
  letter-spacing: -.04em;
}

.haven-platform-card p {
  margin-top: 1rem;
  color: var(--haven-grey);
  line-height: 1.55;
}

/* -----------------------------
   Dress Me Section
----------------------------- */

.haven-dressme-section {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(360px, .75fr);
  gap: clamp(1rem, 4vw, 4rem);
  align-items: stretch;
  padding: clamp(2rem, 5vw, 4rem);
  background:
    radial-gradient(circle at top right, rgba(185, 138, 47, .18), transparent 22rem),
    linear-gradient(135deg, var(--haven-red-dark), var(--haven-ink));
  color: #fff;
  box-shadow: 0 28px 80px rgba(23, 23, 23, .18);
}

.haven-dressme-copy h2 {
  color: #fff;
  font-size: clamp(2.6rem, 6vw, 6rem);
  line-height: .86;
  letter-spacing: -.08em;
  font-weight: 900;
  margin-bottom: 1.25rem;
}

.haven-dressme-copy p {
  max-width: 760px;
  color: rgba(255,255,255,.76);
  font-size: 1.05rem;
  line-height: 1.7;
}

.haven-dressme-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  margin-top: 2rem;
}

.haven-dressme-section .btn-outline-primary {
  --bs-btn-color: #fff;
  --bs-btn-border-color: rgba(255,255,255,.72);
  --bs-btn-hover-bg: #fff;
  --bs-btn-hover-border-color: #fff;
  --bs-btn-hover-color: var(--haven-ink);
}

.haven-dressme-panel {
  display: grid;
  gap: 1rem;
  align-content: center;
}

.dressme-card {
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.22);
  padding: 1.5rem;
}

.dressme-card-main p {
  margin: 0;
  color: #fff;
  font-size: clamp(1.2rem, 2vw, 1.8rem);
  line-height: 1.25;
  letter-spacing: -.04em;
  font-weight: 800;
}

.dressme-label {
  margin-bottom: 1rem;
  color: var(--haven-gold-light);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.dressme-flow {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  border-top: 1px solid rgba(255,255,255,.18);
  border-left: 1px solid rgba(255,255,255,.18);
}

.dressme-flow div {
  padding: 1rem;
  border-right: 1px solid rgba(255,255,255,.18);
  border-bottom: 1px solid rgba(255,255,255,.18);
  color: rgba(255,255,255,.8);
  font-size: .76rem;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
}

/* -----------------------------
   Products
----------------------------- */

#products {
  padding-top: 1rem;
}

#products h2,
.haven-section h2 {
  font-weight: 900;
  letter-spacing: -.04em;
}

.product-card {
  border: 0;
  background: transparent;
  box-shadow: none;
}

.product-card:hover {
  transform: none;
  box-shadow: none;
}

.product-image-link {
  position: relative;
  display: block;
  overflow: hidden;
  background: #f1f1f1;
  border: 1px solid rgba(23, 23, 23, .08);
  color: inherit;
}

.product-image,
.product-card .card-img-top,
.placeholder-image {
  aspect-ratio: 3 / 4;
  width: 100%;
  object-fit: cover;
  transition: transform .55s ease, filter .55s ease;
}

.placeholder-image {
  background:
    linear-gradient(135deg, rgba(185, 138, 47, .1), rgba(143, 23, 40, .08)),
    #f2f2f2;
}

.product-hover-layer {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  background: rgba(23, 23, 23, .28);
  color: #fff;
  opacity: 0;
  transition: opacity .24s ease;
}

.product-hover-layer span {
  padding: .75rem 1rem;
  background: #fff;
  color: var(--haven-ink);
  font-size: .7rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.product-image-link:hover .product-image {
  transform: scale(1.07);
  filter: saturate(1.02);
}

.product-image-link:hover .product-hover-layer {
  opacity: 1;
}

.product-card .card-body {
  padding: 1rem 0 0 !important;
  background: transparent;
}

.product-card h3 {
  color: var(--haven-ink);
  font-size: .96rem;
  font-weight: 900;
  letter-spacing: -.01em;
}

.product-summary {
  color: var(--haven-grey);
  font-size: .9rem;
  min-height: 3.6em;
}

.price {
  color: var(--haven-ink);
  font-size: .96rem;
}

/* -----------------------------
   General Content Sections
----------------------------- */

.haven-section {
  padding-block: clamp(1rem, 3vw, 2.5rem);
}

.haven-feature-card,
.haven-mini-card,
.haven-contact-box,
.haven-partner-card {
  border: 1px solid var(--haven-border);
  background: #fff;
  box-shadow: var(--haven-shadow-soft);
}

.haven-feature-card,
.haven-contact-box {
  padding: clamp(1.5rem, 3vw, 3rem);
}

.haven-feature-card p,
.haven-mini-card p {
  color: var(--haven-grey);
}

.haven-mini-card {
  padding: 1.4rem;
  transition: background .2s ease, color .2s ease;
}

.haven-mini-card:hover {
  background: var(--haven-ink);
  color: #fff;
}

.haven-mini-card:hover p {
  color: rgba(255,255,255,.72);
}

.haven-mini-card h3 {
  color: inherit;
  font-size: 1.05rem;
  font-weight: 900;
}

.haven-red-card {
  background: var(--haven-red);
  color: #fff;
}

.haven-red-card h2,
.haven-red-card .section-kicker,
.haven-red-card p {
  color: #fff;
}

.haven-red-card p {
  opacity: .82;
}

.haven-gold-card {
  background: var(--haven-gold);
  color: var(--haven-ink);
}

.haven-gold-card h2,
.haven-gold-card .section-kicker {
  color: var(--haven-ink);
}

.haven-gold-card p {
  color: rgba(23, 23, 23, .72);
}

.haven-dark-card {
  border: 0;
  color: #fff;
  background:
    radial-gradient(circle at top right, rgba(185,138,47,.18), transparent 22rem),
    var(--haven-ink);
  box-shadow: var(--haven-shadow);
}

.haven-dark-card h2,
.haven-dark-card .section-kicker {
  color: #fff;
}

.haven-dark-card p {
  color: rgba(255,255,255,.76);
}

/* Partner checklist */
.haven-check-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
  background: var(--haven-border);
  border: 1px solid var(--haven-border);
}

.haven-check-grid div {
  background: #fff;
  padding: 1rem;
  font-size: .85rem;
  font-weight: 900;
}

/* Driver tiles */
.haven-driver-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
  background: var(--haven-border);
  border: 1px solid var(--haven-border);
}

.haven-driver-tile {
  min-height: 180px;
  display: flex;
  flex-direction: column;
  justify-content: end;
  padding: 1.5rem;
  background: #fff;
  color: var(--haven-ink);
  transition: background .2s ease, color .2s ease;
}

.haven-driver-tile:hover {
  background: var(--haven-ink);
  color: #fff;
}

.haven-driver-tile strong {
  font-size: 1.2rem;
  font-weight: 900;
}

.haven-driver-tile span {
  color: inherit;
  opacity: .72;
}

/* Impact / launch notes */
.launch-note {
  background: #fff;
  border: 1px solid var(--haven-border);
  box-shadow: var(--haven-shadow-soft);
}

.badge-soft,
.status-pill {
  display: inline-flex;
  align-items: center;
  padding: .45rem .65rem;
  background: var(--haven-red-soft);
  border: 1px solid rgba(143, 23, 40, .22);
  color: var(--haven-red-dark);
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

/* -----------------------------
   Product Detail
----------------------------- */

.gallery-image,
.gallery-thumb {
  aspect-ratio: 4 / 3;
  object-fit: cover;
  background: #f2f2f2;
}

.product-description {
  white-space: pre-line;
}

.product-promo-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
}

.product-promo-card {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 1rem;
  align-items: center;
  min-height: 120px;
  padding: .75rem;
  color: var(--haven-ink);
  text-decoration: none;
  background: #fff;
  border: 1px solid var(--haven-border);
  box-shadow: var(--haven-shadow-soft);
  transition: background .2s ease, color .2s ease;
}

.product-promo-card:hover {
  background: var(--haven-ink);
  color: #fff;
}

.product-promo-card img {
  width: 120px;
  height: 100px;
  object-fit: cover;
}

/* -----------------------------
   Footer
----------------------------- */

.footer-card {
  background: #fff;
  border: 1px solid var(--haven-border);
  box-shadow: var(--haven-shadow-soft);
}

/* -----------------------------
   Utility Overrides
----------------------------- */

.shadow-sm {
  box-shadow: var(--haven-shadow-soft) !important;
}

.border-0 {
  border: 0 !important;
}

/* -----------------------------
   Responsive
----------------------------- */

@media (max-width: 1199px) {
  .nav-link {
    font-size: .68rem;
    padding-inline: .55rem !important;
  }
}

@media (max-width: 991px) {
  html {
    scroll-padding-top: 76px;
  }

  .navbar-nav {
    align-items: stretch !important;
  }

  .nav-link {
    padding-block: .75rem;
  }

  .nav-link::after {
    display: none;
  }

  .promoted-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    min-height: auto;
  }

  .promo-panel {
    min-height: 480px;
  }

  .haven-search-heading {
    grid-template-columns: 1fr;
  }

  .haven-filter-grid {
    grid-template-columns: 1fr;
  }

  .haven-filter-actions {
    flex-wrap: wrap;
  }

  .haven-platform-intro {
    grid-template-columns: 1fr;
  }

  .haven-platform-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .haven-dressme-section {
    grid-template-columns: 1fr;
  }

  .haven-check-grid,
  .haven-driver-grid {
    grid-template-columns: 1fr;
  }

  .product-promo-strip {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 575px) {
  main.container {
    padding-inline: .85rem;
  }

  .promoted-stage-wide,
  .promoted-stage {
    width: calc(100vw - 1rem);
  }

  .promoted-frame {
    margin-inline: 0;
    padding: .55rem;
  }

  .promoted-grid {
    grid-template-columns: 1fr;
  }

  .promo-panel {
    min-height: 430px;
  }

  .promo-copy h2 {
    font-size: 2rem;
  }

  .haven-search-overlap {
    margin-top: -3rem;
  }

  .haven-search-panel {
    width: calc(100vw - 1rem);
    padding: 1rem;
  }

  .haven-search-heading h1 {
    font-size: 2.3rem;
  }

  .haven-ai-search-row {
    grid-template-columns: 1fr;
  }

  .haven-search-btn {
    width: 100%;
    border-left: 0 !important;
    border-top: 1px solid rgba(23, 23, 23, .18) !important;
  }

  .haven-platform-grid {
    grid-template-columns: 1fr;
  }

  .haven-platform-card {
    min-height: 220px;
  }

  .haven-dressme-section {
    padding: 1.5rem;
  }

  .haven-dressme-copy h2 {
    font-size: 3rem;
  }

  .dressme-flow {
    grid-template-columns: 1fr;
  }

  .product-promo-card {
    grid-template-columns: 90px 1fr;
  }

  .product-promo-card img {
    width: 90px;
    height: 82px;
  }
}

/* -----------------------------
   Reduced Motion
----------------------------- */

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation: none !important;
    transition-duration: .001ms !important;
    scroll-behavior: auto !important;
  }

  .promo-panel:hover,
  .promo-panel.is-active {
    transform: none;
  }
}