/* ==========================================================================
   Blueprint Biologics, Homepage Mock-Up Styles
   Phase 2. Consumes design-system/tokens.css and utilities.css.
   ========================================================================== */

/* --------------------------------------------------------------------------
   Page chrome
   -------------------------------------------------------------------------- */

html, body {
  background: var(--bg-base);
  color: var(--text-body);
}

/* Subtle blueprint grid behind the whole page, very low opacity */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image:
    linear-gradient(var(--bg-grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--bg-grid) 1px, transparent 1px);
  background-size: 64px 64px;
  opacity: 0.35;
  mask-image: radial-gradient(ellipse at top, rgba(0,0,0,0.6), transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse at top, rgba(0,0,0,0.6), transparent 70%);
}

main {
  position: relative;
  z-index: 1;
}

/* --------------------------------------------------------------------------
   Compliance strip
   -------------------------------------------------------------------------- */

.compliance-strip {
  position: relative;
  z-index: 60;
  background: var(--surface-dark);
  color: var(--text-on-dark);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.compliance-strip__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-5);
  flex-wrap: wrap;
  padding-block: 8px;
  text-align: center;
}

.compliance-strip__dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 8px var(--accent);
  display: inline-block;
}

.compliance-strip__item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: rgba(244, 248, 255, 0.78);
  font-weight: 500;
}

/* (Earlier compliance-strip mobile override was relocated to the very
   bottom of this file so cascade order is unambiguous.) */

/* --------------------------------------------------------------------------
   Header and navigation
   -------------------------------------------------------------------------- */

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(10, 26, 47, 0.92);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  color: var(--text-on-dark);
}

@supports ((backdrop-filter: blur(12px)) or (-webkit-backdrop-filter: blur(12px))) {
  .site-header {
    background: rgba(10, 26, 47, 0.72);
    -webkit-backdrop-filter: saturate(140%) blur(12px);
    backdrop-filter: saturate(140%) blur(12px);
  }
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-5);
  padding-block: var(--space-3);
}

.site-header__brand {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}

.site-header__brand img {
  height: 32px;
  width: auto;
}

@media (min-width: 768px) {
  .site-header__brand img { height: 36px; }
}

@media (min-width: 1024px) {
  .site-header__brand img { height: 40px; }
}

.site-nav {
  display: none;
  align-items: center;
  gap: var(--space-6);
}

@media (min-width: 1024px) {
  .site-nav { display: flex; }
}

.site-nav__link {
  color: rgba(244, 248, 255, 0.78);
  font-size: 0.95rem;
  font-weight: 500;
  text-decoration: none;
  padding: 6px 2px;
  position: relative;
  transition: color var(--dur-fast) var(--ease);
}

.site-nav__link::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform var(--dur-fast) var(--ease);
}

.site-nav__link:hover,
.site-nav__link:focus-visible {
  color: var(--text-on-dark);
  text-decoration: none;
}

.site-nav__link:hover::after,
.site-nav__link:focus-visible::after {
  transform: scaleX(1);
}

.site-header__cta {
  display: none;
}

@media (min-width: 1024px) {
  .site-header__cta { display: inline-flex; }
}

/* Mobile menu trigger */
.site-header__toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: transparent;
  color: var(--text-on-dark);
  border: 1px solid rgba(255,255,255,0.16);
  border-radius: var(--radius-sm);
  cursor: pointer;
}

@media (min-width: 1024px) {
  .site-header__toggle { display: none; }
}

.site-header__toggle .bar {
  display: block;
  width: 18px;
  height: 2px;
  background: currentColor;
  position: relative;
}
.site-header__toggle .bar::before,
.site-header__toggle .bar::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  height: 2px;
  background: currentColor;
}
.site-header__toggle .bar::before { top: -6px; }
.site-header__toggle .bar::after  { top: 6px; }

/* Mobile menu drawer */
.mobile-menu {
  display: none;
  border-top: 1px solid rgba(255,255,255,0.08);
  padding-block: var(--space-4);
}

.mobile-menu[data-open="true"] {
  display: block;
}

.mobile-menu__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-2);
}

.mobile-menu__link {
  display: block;
  padding: 12px 4px;
  color: rgba(244, 248, 255, 0.9);
  font-weight: 500;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  text-decoration: none;
}

.mobile-menu__cta {
  margin-top: var(--space-4);
  width: 100%;
}

/* --------------------------------------------------------------------------
   Hero
   -------------------------------------------------------------------------- */

.hero {
  position: relative;
  overflow: hidden;
  background: var(--surface-dark);
  color: var(--text-on-dark);
  isolation: isolate;
}

.hero__bg {
  position: absolute;
  inset: 0;
  /* Mobile default: portrait hero composition for narrow viewports. */
  background-image: url("../assets/images/hero-background-mobile.jpeg?v=final-legal-pages-v1");
  background-size: cover;
  background-position: center center;
  z-index: 0;
}

@media (min-width: 768px) {
  /* Tablet and desktop: wide landscape composition. */
  .hero__bg {
    background-image: url("../assets/images/hero-background-desktop.jpeg?v=final-legal-pages-v1");
    background-position: center right;
  }
}

.hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  /* Desktop/tablet: deeper dark-navy across the text area, easing only
     near the far right so the vials + DNA still read as premium art. */
  background:
    linear-gradient(
      90deg,
      rgba(5, 18, 35, 0.96) 0%,
      rgba(5, 18, 35, 0.88) 28%,
      rgba(5, 18, 35, 0.70) 52%,
      rgba(5, 18, 35, 0.38) 78%,
      rgba(5, 18, 35, 0.18) 100%
    );
}

/* Mobile: text sits over more of the image, so use a vertical fade that
   stays darker behind the hero copy and lightens toward the bottom CTA
   area where the image becomes visible. */
@media (max-width: 767px) {
  .hero__overlay {
    background:
      linear-gradient(
        180deg,
        rgba(5, 18, 35, 0.86) 0%,
        rgba(5, 18, 35, 0.78) 45%,
        rgba(5, 18, 35, 0.56) 100%
      );
  }
}

.hero__grid {
  position: absolute;
  inset: 0;
  z-index: 2;
  background-image:
    linear-gradient(rgba(255,255,255,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.06) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse at left, rgba(0,0,0,0.5), transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse at left, rgba(0,0,0,0.5), transparent 70%);
  pointer-events: none;
}

/* ----- Client preview lock ---------------------------------------------- */
html.site-lock-pending body > *:not(.site-lock),
html.site-lock-active body > *:not(.site-lock) {
  visibility: hidden;
}

html.site-lock-pending,
html.site-lock-active {
  background: var(--navy);
}

html.site-lock-pending body,
html.site-lock-active body {
  min-height: 100vh;
  overflow: hidden;
}

.site-lock {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  padding: var(--space-5);
  background:
    radial-gradient(ellipse at 20% 10%, rgba(31,111,235,0.22), transparent 42%),
    radial-gradient(ellipse at 78% 74%, rgba(34,184,207,0.15), transparent 44%),
    linear-gradient(145deg, #F8FBFF 0%, #EEF4FB 46%, #DCE8F4 100%);
  overflow: auto;
}

.site-lock::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(31,111,235,0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(31,111,235,0.08) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: radial-gradient(ellipse at center, rgba(0,0,0,0.62), transparent 72%);
  -webkit-mask-image: radial-gradient(ellipse at center, rgba(0,0,0,0.62), transparent 72%);
}

.site-lock__shell {
  position: relative;
  z-index: 1;
  width: min(100%, 460px);
  display: grid;
  gap: var(--space-5);
}

.site-lock__brand {
  display: flex;
  justify-content: center;
}

.site-lock__brand img {
  width: min(190px, 58vw);
  height: auto;
  filter: drop-shadow(0 10px 28px rgba(10,26,47,0.12));
}

.site-lock__card {
  display: grid;
  gap: var(--space-4);
  padding: clamp(var(--space-5), 5vw, var(--space-7));
  border: 1px solid rgba(31,111,235,0.18);
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,0.78);
  box-shadow: var(--shadow-lg);
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
}

.site-lock__eyebrow {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
}

.site-lock__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(2rem, 8vw, 3rem);
  line-height: 1.04;
  color: var(--text-strong);
}

.site-lock__body {
  margin: 0;
  color: var(--text-muted);
  line-height: 1.6;
}

.site-lock__label {
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-strong);
}

.site-lock__input {
  width: 100%;
  min-height: 52px;
  padding: 0 14px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,0.88);
  color: var(--text-strong);
  font: inherit;
  outline: none;
  transition: border-color var(--dur-fast) var(--ease),
              box-shadow var(--dur-fast) var(--ease);
}

.site-lock__input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 4px rgba(31,111,235,0.14);
}

.site-lock__input[aria-invalid="true"] {
  border-color: #B42318;
}

.site-lock__error {
  margin: 0;
  color: #B42318;
  font-size: 0.9rem;
  line-height: 1.45;
}

.site-lock__button {
  width: 100%;
  justify-content: center;
}

.hero__inner {
  position: relative;
  z-index: 3;
  padding-block: clamp(64px, 10vw, 128px);
  display: grid;
  gap: var(--space-6);
  max-width: 680px;
}

.hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: clamp(0.66rem, 0.6rem + 0.4vw, 0.78rem);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: rgba(244, 248, 255, 0.85);
  padding: 6px 12px;
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: var(--radius-pill);
  background: rgba(255,255,255,0.04);
  align-self: start;
  max-width: 100%;
  flex-wrap: wrap;
  text-wrap: balance;
}

.hero__eyebrow::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 10px var(--accent);
}

.hero__title {
  font-family: var(--font-display);
  font-size: clamp(1.65rem, 1.1rem + 3.6vw, 3.5rem);
  line-height: 1.08;
  letter-spacing: -0.015em;
  color: #fff;
  font-weight: 700;
  overflow-wrap: anywhere;
  word-break: normal;
  text-shadow: 0 2px 18px rgba(0, 0, 0, 0.32);
}

.hero__title .accent {
  background: linear-gradient(90deg, #6FB0FF 0%, #1F6FEB 60%, #22B8CF 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.hero__lede {
  font-size: 1.0625rem;
  line-height: 1.65;
  color: rgba(244, 248, 255, 0.9);
  max-width: 56ch;
  text-shadow: 0 2px 18px rgba(0, 0, 0, 0.32);
}

.hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.hero__cta-secondary {
  background: transparent;
  border-color: rgba(255,255,255,0.22);
  color: var(--text-on-dark);
}

.hero__cta-secondary:hover {
  background: rgba(255,255,255,0.06);
}

.hero__badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-2);
}

.hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  font-weight: 500;
  color: rgba(244, 248, 255, 0.78);
  padding: 6px 12px;
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: var(--radius-pill);
  background: rgba(255,255,255,0.04);
}

.hero__badge svg {
  width: 14px;
  height: 14px;
  color: var(--cyan);
}

.hero__microcopy {
  font-size: 0.8rem;
  color: rgba(244, 248, 255, 0.6);
  letter-spacing: 0.02em;
}

/* Hero scrim card on the right, decorative spec frame */
.hero__panel {
  display: none;
}

@media (min-width: 1024px) {
  .hero__panel {
    display: block;
    position: absolute;
    z-index: 3;
    right: clamp(24px, 4vw, 80px);
    bottom: clamp(48px, 8vw, 96px);
    width: 280px;
    padding: 18px 20px;
    border-radius: var(--radius-md);
    border: 1px solid rgba(255,255,255,0.14);
    background: rgba(10, 26, 47, 0.58);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    color: rgba(244, 248, 255, 0.92);
    font-family: var(--font-mono);
    font-size: 0.78rem;
    line-height: 1.7;
  }
  .hero__panel-title {
    font-size: 0.7rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--cyan);
    margin-bottom: 8px;
  }
  .hero__panel-row {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    border-bottom: 1px dashed rgba(255,255,255,0.1);
    padding: 4px 0;
  }
  .hero__panel-row:last-child { border-bottom: 0; }
  .hero__panel-row span:last-child { color: rgba(255,255,255,0.65); }
}

/* --------------------------------------------------------------------------
   Trust / Compliance bar
   -------------------------------------------------------------------------- */

.trust-bar {
  background: var(--bg-base);
  border-bottom: 1px solid var(--border);
}

.trust-bar__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3);
  padding-block: var(--space-5);
}

@media (min-width: 640px) {
  .trust-bar__inner {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .trust-bar__inner {
    grid-template-columns: repeat(5, 1fr);
    gap: var(--space-5);
  }
}

.trust-item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 0.92rem;
  color: var(--text-body);
}

.trust-item__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-sm);
  background: var(--accent-soft);
  color: var(--accent);
  flex-shrink: 0;
}

.trust-item__icon svg {
  width: 18px;
  height: 18px;
}

.trust-item__label {
  font-weight: 600;
  color: var(--text-strong);
  line-height: 1.25;
}

/* --------------------------------------------------------------------------
   Section heading shared
   -------------------------------------------------------------------------- */

.section-head {
  display: grid;
  gap: var(--space-3);
  margin-bottom: var(--space-7);
  max-width: 760px;
}

.section-head--center {
  margin-inline: auto;
  text-align: center;
}

.section-head__eyebrow {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.section-head--center .section-head__eyebrow {
  justify-content: center;
}

.section-head__eyebrow::before {
  content: "";
  display: inline-block;
  width: 24px;
  height: 1px;
  background: var(--accent);
}

.section-head__title {
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: var(--text-strong);
}

.section-head__lede {
  font-size: 1.0625rem;
  line-height: 1.65;
  color: var(--text-muted);
  max-width: 60ch;
}

.section-head--center .section-head__lede { margin-inline: auto; }

/* --------------------------------------------------------------------------
   About / Positioning
   -------------------------------------------------------------------------- */

.about {
  background: var(--bg-base);
}

.feature-card {
  position: relative;
  background: var(--bg-base);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: border-color var(--dur-mid) var(--ease),
              box-shadow var(--dur-mid) var(--ease),
              transform var(--dur-mid) var(--ease);
}

.feature-card:hover {
  border-color: var(--border-strong);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.feature-card__icon {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-sm);
  background: var(--accent-soft);
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-1);
}

.feature-card__icon svg {
  width: 22px;
  height: 22px;
}

.feature-card__title {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--text-strong);
}

.feature-card__body {
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--text-muted);
}

.feature-card__tag {
  margin-top: auto;
  font-family: var(--font-mono);
  font-size: 0.72rem;
  color: var(--text-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding-top: var(--space-3);
  border-top: 1px dashed var(--border);
}

/* --------------------------------------------------------------------------
   Catalog preview
   -------------------------------------------------------------------------- */

.catalog {
  background: var(--bg-soft);
  border-block: 1px solid var(--border);
}

.catalog-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}

@media (min-width: 640px) {
  .catalog-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 1024px) {
  .catalog-grid { grid-template-columns: repeat(3, 1fr); }
}

.catalog-card {
  position: relative;
  background: var(--bg-base);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: border-color var(--dur-mid) var(--ease),
              box-shadow var(--dur-mid) var(--ease),
              transform var(--dur-mid) var(--ease);
  display: flex;
  flex-direction: column;
}

.catalog-card:hover {
  border-color: var(--accent);
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
}

.catalog-card__visual {
  aspect-ratio: 16 / 10;
  background: linear-gradient(135deg, #EEF4FF 0%, #DDE7F5 100%);
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid var(--border);
}

.catalog-card__visual::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(31,111,235,0.10) 1px, transparent 1px),
    linear-gradient(90deg, rgba(31,111,235,0.10) 1px, transparent 1px);
  background-size: 28px 28px;
}

.catalog-card__visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 70% 50%, rgba(31,111,235,0.15), transparent 60%);
}

.catalog-card__visual-img,
.featured-cat__visual-img,
.product-card__visual-img,
.placeholder-visual__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.catalog-card__visual-img,
.featured-cat__visual-img,
.product-card__visual-img {
  z-index: 1;
}

.catalog-card__visual-img,
.featured-cat__visual-img {
  filter: saturate(0.95) contrast(1.03);
}

.catalog-card__visual:has(.catalog-card__visual-img:not([hidden]))::after,
.featured-cat__visual:has(.featured-cat__visual-img:not([hidden]))::before {
  z-index: 2;
  background:
    linear-gradient(180deg, rgba(10,26,47,0.02), rgba(10,26,47,0.24)),
    radial-gradient(circle at 70% 50%, rgba(31,111,235,0.10), transparent 60%);
}

.catalog-card__visual:has(.catalog-card__visual-img:not([hidden])) .catalog-card__glyph,
.featured-cat__visual:has(.featured-cat__visual-img:not([hidden])) .featured-cat__glyph,
.product-card__visual:has(.product-card__visual-img:not([hidden])) .product-card__molecule {
  display: none;
}

.catalog-card__glyph {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  opacity: 0.55;
  z-index: 3;
  mix-blend-mode: multiply;
}

.catalog-card__glyph svg {
  width: 64px;
  height: 64px;
}

.catalog-card__placeholder-label {
  position: absolute;
  left: 12px;
  bottom: 12px;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  background: rgba(255,255,255,0.85);
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid var(--border);
}

.catalog-card__body {
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  flex: 1;
}

.catalog-card__sku {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
}

.catalog-card__title {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--text-strong);
  line-height: 1.25;
}

.catalog-card__desc {
  font-size: 0.9rem;
  color: var(--text-muted);
  line-height: 1.55;
}

.catalog-card__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--border);
}

.catalog-card__count {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  text-transform: uppercase;
}

.catalog-card__link {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  text-decoration: none;
}

.catalog-card__link svg {
  width: 14px;
  height: 14px;
  transition: transform var(--dur-fast) var(--ease);
}

.catalog-card:hover .catalog-card__link svg { transform: translateX(3px); }

.catalog-disclaimer {
  margin-top: var(--space-6);
  padding: var(--space-4);
  border: 1px dashed var(--border-strong);
  border-radius: var(--radius-md);
  font-size: 0.82rem;
  color: var(--text-muted);
  background: var(--bg-base);
  text-align: center;
}

/* --------------------------------------------------------------------------
   Quality / Documentation
   -------------------------------------------------------------------------- */

.quality {
  background: var(--bg-base);
}

.quality-grid {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: 1fr;
}

@media (min-width: 1024px) {
  .quality-grid {
    grid-template-columns: 5fr 7fr;
    align-items: center;
  }
}

.quality-cards {
  display: grid;
  gap: var(--space-3);
  grid-template-columns: 1fr;
}

@media (min-width: 640px) {
  .quality-cards { grid-template-columns: repeat(2, 1fr); }
}

.quality-card {
  background: var(--bg-base);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  min-height: 100%;
}

.quality-card__num {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  color: var(--accent);
}

.quality-card__title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-strong);
}

.quality-card__body {
  font-size: 0.88rem;
  color: var(--text-muted);
  line-height: 1.55;
}

/* Placeholder visual block, premium look */
.placeholder-visual {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--border);
  background:
    radial-gradient(ellipse at 30% 20%, rgba(31,111,235,0.18), transparent 60%),
    radial-gradient(ellipse at 70% 80%, rgba(34,184,207,0.14), transparent 60%),
    linear-gradient(160deg, #F2F6FC 0%, #E6EDF8 100%);
  box-shadow: var(--shadow-md);
}

.placeholder-visual::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(31,111,235,0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(31,111,235,0.08) 1px, transparent 1px);
  background-size: 32px 32px;
}

.placeholder-visual__core {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: var(--space-3);
  color: var(--accent);
  text-align: center;
  padding: var(--space-5);
}

.placeholder-visual.has-image .placeholder-visual__img {
  z-index: 1;
}

.placeholder-visual.has-image::before,
.placeholder-visual.has-image .placeholder-visual__core,
.placeholder-visual.has-image .placeholder-visual__tag {
  opacity: 0;
  pointer-events: none;
}

.placeholder-visual.has-image.is-fallback::before,
.placeholder-visual.has-image.is-fallback .placeholder-visual__core,
.placeholder-visual.has-image.is-fallback .placeholder-visual__tag {
  opacity: 1;
}

.placeholder-visual__icon {
  width: 88px;
  height: 88px;
  border-radius: var(--radius-md);
  background: rgba(255,255,255,0.7);
  border: 1px solid rgba(31,111,235,0.18);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 10px 30px rgba(31,111,235,0.18);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}

.placeholder-visual__icon svg {
  width: 40px;
  height: 40px;
}

.placeholder-visual__label {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
  background: rgba(255,255,255,0.7);
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--border);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}

.placeholder-visual__hint {
  font-size: 0.78rem;
  color: var(--text-muted);
  max-width: 32ch;
  line-height: 1.45;
}

.placeholder-visual__tag {
  position: absolute;
  top: 14px;
  left: 14px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
  background: rgba(255,255,255,0.8);
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid var(--border);
}

.placeholder-visual__tag::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
}

/* --------------------------------------------------------------------------
   Wholesale CTA
   -------------------------------------------------------------------------- */

.wholesale {
  position: relative;
  background: var(--surface-dark);
  color: var(--text-on-dark);
  overflow: hidden;
  isolation: isolate;
}

.wholesale::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse at center, rgba(0,0,0,0.7), transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse at center, rgba(0,0,0,0.7), transparent 70%);
  z-index: 0;
}

.wholesale::after {
  content: "";
  position: absolute;
  z-index: 0;
  width: 600px;
  height: 600px;
  right: -160px;
  top: -160px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(31,111,235,0.35), transparent 60%);
  pointer-events: none;
  filter: blur(20px);
}

.wholesale__inner {
  position: relative;
  z-index: 1;
  display: grid;
  gap: var(--space-6);
  grid-template-columns: 1fr;
  align-items: center;
}

@media (min-width: 1024px) {
  .wholesale__inner {
    grid-template-columns: 7fr 5fr;
  }
}

.wholesale__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 1.4rem + 1.6vw, 2.6rem);
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: #fff;
}

.wholesale__title .accent {
  background: linear-gradient(90deg, #6FB0FF 0%, #22B8CF 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.wholesale__body {
  color: rgba(244, 248, 255, 0.78);
  font-size: 1.0625rem;
  line-height: 1.65;
  max-width: 56ch;
}

.wholesale__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-3);
}

.wholesale__card {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}

.wholesale__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-3);
}

.wholesale__list li {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 12px;
  align-items: start;
  font-size: 0.94rem;
  color: rgba(244, 248, 255, 0.88);
}

.wholesale__list svg {
  width: 20px;
  height: 20px;
  color: var(--cyan);
  margin-top: 2px;
}

.wholesale__card-foot {
  margin-top: var(--space-5);
  padding-top: var(--space-4);
  border-top: 1px dashed rgba(255,255,255,0.14);
  font-family: var(--font-mono);
  font-size: 0.74rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(244, 248, 255, 0.6);
}

/* --------------------------------------------------------------------------
   Contact / Inquiry
   -------------------------------------------------------------------------- */

.contact {
  background: var(--bg-base);
}

.contact-grid {
  display: grid;
  gap: var(--space-7);
  grid-template-columns: 1fr;
}

@media (min-width: 1024px) {
  .contact-grid {
    grid-template-columns: 4fr 7fr;
    align-items: start;
  }
}

.contact-info {
  display: grid;
  gap: var(--space-5);
  align-content: start;
}

.contact-method {
  display: grid;
  gap: 4px;
  padding: var(--space-4);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--bg-soft);
}

.contact-method__label {
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
}

.contact-method__value {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-strong);
  word-break: break-word;
}

.contact-method__hint {
  font-size: 0.85rem;
  color: var(--text-muted);
}

/* Form */
.inquiry-form {
  background: var(--bg-base);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
}

.inquiry-form__row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}

@media (min-width: 640px) {
  .inquiry-form__row--2 { grid-template-columns: repeat(2, 1fr); }
}

.inquiry-form .u-field { margin-bottom: var(--space-4); }

.checkbox-field {
  display: grid;
  grid-template-columns: 20px 1fr;
  gap: 12px;
  align-items: start;
  padding: var(--space-4);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--bg-soft);
}

.checkbox-field input[type="checkbox"] {
  width: 18px;
  height: 18px;
  margin-top: 2px;
  accent-color: var(--accent);
}

.checkbox-field label {
  font-size: 0.85rem;
  line-height: 1.5;
  color: var(--text-body);
}

.inquiry-form__submit {
  margin-top: var(--space-5);
  width: 100%;
}

@media (min-width: 640px) {
  .inquiry-form__submit { width: auto; }
}

.inquiry-form__note {
  margin-top: var(--space-3);
  font-size: 0.78rem;
  color: var(--text-muted);
}

/* --------------------------------------------------------------------------
   Footer
   -------------------------------------------------------------------------- */

.site-footer {
  background: var(--surface-dark);
  color: rgba(244, 248, 255, 0.7);
  padding-block: var(--space-8) var(--space-5);
}

.site-footer__grid {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: 1fr;
  padding-bottom: var(--space-6);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

@media (min-width: 768px) {
  .site-footer__grid {
    grid-template-columns: 2fr 1fr 1fr 1fr;
  }
}

.site-footer__brand img {
  height: 40px;
  width: auto;
  margin-bottom: var(--space-4);
}

.site-footer__about {
  font-size: 0.9rem;
  line-height: 1.6;
  max-width: 38ch;
}

.site-footer__heading {
  color: #fff;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: var(--space-3);
}

.site-footer__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

.site-footer__list a {
  color: rgba(244, 248, 255, 0.72);
  font-size: 0.92rem;
  text-decoration: none;
}

.site-footer__list a:hover {
  color: #fff;
  text-decoration: none;
}

.site-footer__disclaimer {
  padding-block: var(--space-5);
  font-size: 0.82rem;
  line-height: 1.6;
  color: rgba(244, 248, 255, 0.55);
}

.site-footer__bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding-top: var(--space-4);
  border-top: 1px solid rgba(255,255,255,0.08);
  font-size: 0.82rem;
  color: rgba(244, 248, 255, 0.55);
}

.site-footer__legal {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
}

.site-footer__legal a {
  color: rgba(244, 248, 255, 0.6);
  text-decoration: none;
}

.site-footer__legal a:hover { color: #fff; }

/* --------------------------------------------------------------------------
   Responsive guards, micro-rules
   -------------------------------------------------------------------------- */

.u-no-scroll {
  overflow: hidden;
}

@media (max-width: 480px) {
  .hero__inner { padding-block: 56px; }
  .hero__panel { display: none !important; }
}

/* ==========================================================================
   Phase 3, Catalog page styles
   ========================================================================== */

/* ----- Catalog hero ------------------------------------------------------ */
.catalog-hero {
  position: relative;
  background: var(--surface-dark);
  color: var(--text-on-dark);
  padding-block: clamp(56px, 8vw, 96px) clamp(48px, 6vw, 72px);
  overflow: hidden;
  isolation: isolate;
}

.catalog-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(ellipse at 20% 30%, rgba(31,111,235,0.35), transparent 55%),
    radial-gradient(ellipse at 90% 80%, rgba(34,184,207,0.22), transparent 55%);
  pointer-events: none;
}

.catalog-hero__grid {
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse at center, rgba(0,0,0,0.6), transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at center, rgba(0,0,0,0.6), transparent 75%);
  pointer-events: none;
}

.catalog-hero__inner {
  position: relative;
  z-index: 1;
  display: grid;
  gap: var(--space-4);
  max-width: 760px;
}

.catalog-hero__crumb {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.8rem;
  color: rgba(244,248,255,0.65);
  letter-spacing: 0.02em;
}

.catalog-hero__crumb a {
  color: rgba(244,248,255,0.78);
  text-decoration: none;
}
.catalog-hero__crumb a:hover { color: #fff; text-decoration: underline; }
.catalog-hero__crumb [aria-current="page"] { color: var(--cyan); font-weight: 600; }

.catalog-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  align-self: start;
  font-size: clamp(0.66rem, 0.6rem + 0.4vw, 0.78rem);
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cyan);
  padding: 6px 12px;
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: var(--radius-pill);
  background: rgba(255,255,255,0.04);
  max-width: 100%;
}

.catalog-hero__title {
  font-family: var(--font-display);
  font-size: clamp(1.65rem, 1.1rem + 3.2vw, 3rem);
  line-height: 1.1;
  letter-spacing: -0.015em;
  color: #fff;
  font-weight: 700;
  overflow-wrap: anywhere;
}

.catalog-hero__title .accent {
  background: linear-gradient(90deg, #6FB0FF 0%, #1F6FEB 60%, #22B8CF 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.catalog-hero__lede {
  font-size: 1.0625rem;
  line-height: 1.65;
  color: rgba(244,248,255,0.8);
  max-width: 56ch;
}

.catalog-hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-2);
}

.catalog-hero__disclaimer {
  margin-top: var(--space-3);
  font-size: 0.82rem;
  color: rgba(244,248,255,0.6);
  border-top: 1px dashed rgba(255,255,255,0.12);
  padding-top: var(--space-3);
  max-width: 60ch;
}

.catalog-hero__pdf-note {
  margin-top: var(--space-3);
  font-size: 0.88rem;
  color: rgba(244,248,255,0.72);
  max-width: 60ch;
}

/* ----- Featured categories ----------------------------------------------- */
.featured-cats {
  background: var(--bg-base);
}

.featured-cats__grid {
  display: grid;
  gap: var(--space-3);
  grid-template-columns: 1fr;
}

@media (min-width: 640px) {
  .featured-cats__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 1024px) {
  .featured-cats__grid { grid-template-columns: repeat(3, 1fr); }
}

.featured-cat {
  display: grid;
  grid-template-columns: 88px 1fr 24px;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-3) var(--space-4);
  background: var(--bg-base);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  cursor: pointer;
  text-align: left;
  font: inherit;
  color: var(--text-strong);
  transition: border-color var(--dur-fast) var(--ease),
              box-shadow var(--dur-fast) var(--ease),
              transform var(--dur-fast) var(--ease);
}

.featured-cat:hover {
  border-color: var(--accent);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.featured-cat__visual {
  position: relative;
  height: 72px;
  border-radius: var(--radius-sm);
  background:
    linear-gradient(135deg, #EEF4FF 0%, #DDE7F5 100%);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
}

.featured-cat__visual::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(31,111,235,0.12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(31,111,235,0.12) 1px, transparent 1px);
  background-size: 14px 14px;
}

.featured-cat__glyph {
  position: relative;
  z-index: 3;
  width: 32px;
  height: 32px;
  color: var(--accent);
  opacity: 0.78;
  filter: drop-shadow(0 1px 8px rgba(255,255,255,0.74));
}

.featured-cat__glyph svg { width: 100%; height: 100%; }

.featured-cat__label-mono {
  position: absolute;
  bottom: 4px;
  right: 6px;
  z-index: 3;
  font-size: 0.62rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent);
  background: rgba(255,255,255,0.7);
  padding: 1px 6px;
  border-radius: 999px;
  border: 1px solid rgba(31,111,235,0.2);
}

.featured-cat__body {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.featured-cat__title {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text-strong);
}

.featured-cat__count {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.featured-cat__arrow {
  color: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
}
.featured-cat__arrow svg { width: 18px; height: 18px; }

/* ----- Catalog controls (search + view toggle) --------------------------- */
.catalog-browser { background: var(--bg-soft); border-block: 1px solid var(--border); }

.catalog-controls {
  display: grid;
  gap: var(--space-3);
  grid-template-columns: 1fr;
  margin-bottom: var(--space-4);
}

@media (min-width: 768px) {
  .catalog-controls {
    grid-template-columns: 1fr auto;
    align-items: center;
  }
}

.catalog-search {
  position: relative;
  display: flex;
  align-items: center;
}

.catalog-search__icon {
  position: absolute;
  left: 14px;
  display: inline-flex;
  align-items: center;
  color: var(--text-muted);
  pointer-events: none;
}
.catalog-search__icon svg { width: 18px; height: 18px; }

.catalog-search__input {
  width: 100%;
  min-height: 48px;
  padding: 12px 44px 12px 44px;
  font-family: var(--font-sans);
  font-size: 1rem;
  color: var(--text-strong);
  background: var(--bg-base);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  transition: border-color var(--dur-fast) var(--ease),
              box-shadow var(--dur-fast) var(--ease);
}
.catalog-search__input::placeholder { color: var(--text-muted); }
.catalog-search__input:focus-visible {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.catalog-search__clear {
  position: absolute;
  right: 8px;
  width: 32px;
  height: 32px;
  border: 0;
  background: transparent;
  color: var(--text-muted);
  border-radius: var(--radius-sm);
  cursor: pointer;
}
.catalog-search__clear:hover { background: var(--bg-muted); color: var(--text-strong); }
.catalog-search__clear svg { width: 14px; height: 14px; }

.catalog-view-toggle {
  display: inline-flex;
  align-items: center;
  background: var(--bg-base);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 4px;
  gap: 2px;
  align-self: stretch;
}

@media (min-width: 768px) {
  .catalog-view-toggle { align-self: center; }
}

.catalog-view-toggle__btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: transparent;
  border: 0;
  color: var(--text-muted);
  font-size: 0.88rem;
  font-weight: 600;
  font-family: var(--font-sans);
  padding: 8px 12px;
  border-radius: 8px;
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}

.catalog-view-toggle__btn:hover { background: var(--bg-muted); color: var(--text-strong); }
.catalog-view-toggle__btn.is-active {
  background: var(--accent);
  color: #fff;
}

@media (max-width: 480px) {
  .catalog-view-toggle__btn span { display: none; }
}

/* ----- Filters ----------------------------------------------------------- */
.catalog-filters {
  margin-bottom: var(--space-3);
}

.catalog-filters__scroll {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

/* On very narrow screens, allow horizontal scroll instead of wrapping */
@media (max-width: 640px) {
  .catalog-filters {
    margin-left: calc(-1 * var(--gutter));
    margin-right: calc(-1 * var(--gutter));
  }
  .catalog-filters__scroll {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding: 4px var(--gutter);
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
  }
}

.filter-pill {
  white-space: nowrap;
  font-family: var(--font-sans);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-body);
  background: var(--bg-base);
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  padding: 8px 14px;
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease),
              color var(--dur-fast) var(--ease),
              border-color var(--dur-fast) var(--ease);
}

.filter-pill:hover {
  border-color: var(--border-strong);
  background: var(--bg-muted);
}

.filter-pill.is-active {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

/* Mobile alternative dropdown, hide on larger screens */
.catalog-filter-select {
  display: block;
  margin-bottom: var(--space-3);
}
@media (min-width: 640px) {
  .catalog-filter-select { display: none; }
  .catalog-filters { display: block; }
}
@media (max-width: 639px) {
  .catalog-filters { display: none; }
}

/* ----- Meta row ---------------------------------------------------------- */
.catalog-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  padding-block: var(--space-3);
  border-top: 1px dashed var(--border);
  border-bottom: 1px dashed var(--border);
  margin-bottom: var(--space-5);
}

.catalog-meta__count {
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--text-strong);
  margin: 0;
}

.catalog-meta__hint {
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin: 0;
}

/* ----- Product cards ----------------------------------------------------- */
.catalog-results__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}

@media (min-width: 640px) {
  .catalog-results__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 1024px) {
  .catalog-results__grid { grid-template-columns: repeat(3, 1fr); }
}

@media (min-width: 1280px) {
  .catalog-results__grid { grid-template-columns: repeat(4, 1fr); }
}

.product-card {
  display: flex;
  flex-direction: column;
  background: var(--bg-base);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: border-color var(--dur-mid) var(--ease),
              box-shadow var(--dur-mid) var(--ease),
              transform var(--dur-mid) var(--ease);
}

.product-card:hover {
  border-color: var(--accent);
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
}

.product-card__visual {
  position: relative;
  display: block;
  aspect-ratio: 4 / 3;
  background:
    radial-gradient(ellipse at 30% 30%, rgba(31,111,235,0.16), transparent 55%),
    radial-gradient(ellipse at 70% 70%, rgba(34,184,207,0.12), transparent 55%),
    linear-gradient(160deg, #F3F7FD 0%, #E6EEF8 100%);
  overflow: hidden;
  text-decoration: none;
}

.product-card__visual::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(31,111,235,0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(31,111,235,0.08) 1px, transparent 1px);
  background-size: 24px 24px;
}

.product-card__visual::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    linear-gradient(180deg, rgba(10,26,47,0.00), rgba(10,26,47,0.12)),
    radial-gradient(circle at 50% 38%, rgba(255,255,255,0.10), transparent 58%);
  pointer-events: none;
}

.product-card__sku-badge {
  position: absolute;
  top: 10px;
  left: 10px;
  font-size: 0.66rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
  background: rgba(255,255,255,0.82);
  border: 1px solid var(--border);
  padding: 3px 8px;
  border-radius: 999px;
  z-index: 2;
}

.product-card__molecule {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  opacity: 0.7;
  z-index: 3;
}

.product-card__molecule svg {
  width: 60%;
  height: 60%;
  max-width: 120px;
  max-height: 120px;
}

.product-card__placeholder-label {
  position: absolute;
  bottom: 8px;
  right: 8px;
  font-size: 0.62rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  background: rgba(255,255,255,0.82);
  border: 1px solid var(--border);
  padding: 2px 8px;
  border-radius: 999px;
  z-index: 2;
}

.product-card__body {
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  flex: 1;
}

.product-card__category {
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
}

.product-card__title {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--text-strong);
  line-height: 1.25;
}

.product-card__title a {
  color: inherit;
  text-decoration: none;
}
.product-card__title a:hover { color: var(--accent); text-decoration: none; }

.product-card__note {
  font-size: 0.86rem;
  color: var(--text-muted);
  line-height: 1.5;
  margin: 0;
}

.product-card__meta {
  display: grid;
  grid-template-columns: 1fr;
  gap: 4px;
  margin: var(--space-2) 0 0;
  padding-top: var(--space-3);
  border-top: 1px dashed var(--border);
  font-size: 0.78rem;
}

@media (min-width: 480px) {
  .product-card__meta { grid-template-columns: repeat(2, 1fr); }
}

.product-card__meta > div {
  display: grid;
  gap: 2px;
}

.product-card__meta dt {
  font-size: 0.66rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 600;
}

.product-card__meta dd {
  margin: 0;
  font-size: 0.86rem;
  color: var(--text-strong);
}

.product-card__actions {
  display: flex;
  gap: var(--space-2);
  align-items: center;
  margin-top: var(--space-3);
}

.product-card__cta {
  min-height: 40px;
  padding: 8px 14px;
  font-size: 0.88rem;
  flex: 1;
}

.product-card__detail {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-strong);
  text-decoration: none;
  padding: 8px 10px;
  border-radius: var(--radius-sm);
}
.product-card__detail:hover { background: var(--bg-muted); color: var(--accent); text-decoration: none; }

.product-card__disclaimer {
  font-size: 0.62rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin: var(--space-2) 0 0;
}

/* ----- Empty state ------------------------------------------------------- */
.catalog-empty {
  text-align: center;
  padding: var(--space-7) var(--space-4);
  background: var(--bg-base);
  border: 1px dashed var(--border-strong);
  border-radius: var(--radius-lg);
}

.catalog-empty__icon {
  width: 56px;
  height: 56px;
  margin: 0 auto var(--space-3);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  background: var(--accent-soft);
  border-radius: var(--radius-pill);
}
.catalog-empty__icon svg { width: 26px; height: 26px; }

.catalog-empty__title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--text-strong);
  margin: 0 0 var(--space-2);
}

.catalog-empty__body {
  font-size: 0.95rem;
  color: var(--text-muted);
  max-width: 48ch;
  margin: 0 auto var(--space-4);
}

.catalog-empty__actions {
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-2);
}

/* ----- Table view -------------------------------------------------------- */
.catalog-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--bg-base);
  -webkit-overflow-scrolling: touch;
}

.catalog-table {
  width: 100%;
  min-width: 720px;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.catalog-table thead {
  background: var(--bg-soft);
}

.catalog-table th,
.catalog-table td {
  text-align: left;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}

.catalog-table th {
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 700;
}

.catalog-table tbody tr:last-child td { border-bottom: 0; }

.catalog-table tbody tr:hover {
  background: var(--bg-soft);
}

.catalog-table__product a {
  color: var(--text-strong);
  font-weight: 600;
  text-decoration: none;
}
.catalog-table__product a:hover { color: var(--accent); text-decoration: none; }

.catalog-table__action {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  font-size: 0.82rem;
  font-weight: 600;
  color: #fff;
  background: var(--accent);
  border-radius: var(--radius-pill);
  text-decoration: none;
  transition: background var(--dur-fast) var(--ease);
}
.catalog-table__action:hover { background: var(--accent-hover); text-decoration: none; }
.catalog-table__action-col { text-align: right; }

/* ----- Documentation CTA ------------------------------------------------- */
.docs-cta { background: var(--bg-base); }

.docs-cta__inner {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: 1fr;
  align-items: center;
}

@media (min-width: 1024px) {
  .docs-cta__inner { grid-template-columns: 7fr 5fr; }
}

.docs-cta__panel { display: grid; gap: var(--space-3); }
.docs-cta__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-2);
}

.placeholder-visual--doc { aspect-ratio: 5 / 4; }
.placeholder-visual--product { aspect-ratio: 1 / 1; }

/* ----- Disclaimer block -------------------------------------------------- */
.disclaimer-block { background: var(--bg-soft); }

.disclaimer-block__card {
  padding: var(--space-6);
  border: 1px solid var(--border);
  border-left: 4px solid var(--accent);
  border-radius: var(--radius-md);
  background: var(--bg-base);
}

.disclaimer-block__tag {
  display: inline-block;
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--space-2);
}

.disclaimer-block__body {
  font-size: 0.92rem;
  line-height: 1.7;
  color: var(--text-body);
  margin: 0;
  max-width: 80ch;
}

/* ==========================================================================
   Phase 3, Product Detail page styles
   ========================================================================== */

.detail-hero {
  background: var(--bg-soft);
  padding-block: var(--space-5);
  border-bottom: 1px solid var(--border);
}

.detail-hero .catalog-hero__crumb {
  color: var(--text-muted);
}
.detail-hero .catalog-hero__crumb a { color: var(--text-strong); }
.detail-hero .catalog-hero__crumb [aria-current="page"] { color: var(--accent); }

.detail-main { padding-block: var(--space-7); background: var(--bg-base); }

.detail-grid {
  display: grid;
  gap: var(--space-7);
  grid-template-columns: 1fr;
  align-items: start;
}

@media (min-width: 1024px) {
  .detail-grid { grid-template-columns: 5fr 7fr; gap: var(--space-8); }
}

.detail-visual { display: grid; gap: var(--space-4); }

.detail-side-card {
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-5);
}

.detail-side-card__title {
  margin: 0 0 var(--space-2);
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text-strong);
}

.detail-side-card__body {
  margin: 0 0 var(--space-3);
  font-size: 0.88rem;
  color: var(--text-muted);
  line-height: 1.5;
}

.detail-info { display: grid; gap: var(--space-4); }

.detail-info__category {
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
}

.detail-info__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 1.3rem + 2vw, 2.75rem);
  line-height: 1.1;
  color: var(--text-strong);
  letter-spacing: -0.015em;
}

.detail-info__note {
  margin: 0;
  font-size: 1.0625rem;
  line-height: 1.6;
  color: var(--text-muted);
  max-width: 60ch;
}

.detail-specs {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3);
  margin: 0;
  padding: var(--space-5);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--bg-soft);
}

@media (min-width: 640px) {
  .detail-specs { grid-template-columns: repeat(2, 1fr); }
}

.detail-specs > div {
  display: grid;
  gap: 4px;
  padding: 8px 0;
}

.detail-specs dt {
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 700;
}

.detail-specs dd {
  margin: 0;
  font-size: 1rem;
  color: var(--text-strong);
  font-weight: 600;
}

.detail-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.detail-disclaimer {
  margin-top: var(--space-3);
  padding: var(--space-4);
  border: 1px dashed var(--border-strong);
  border-radius: var(--radius-md);
  font-size: 0.85rem;
  line-height: 1.6;
  color: var(--text-muted);
  background: var(--bg-soft);
}

.detail-disclaimer p { margin: 0; }

/* ==========================================================================
   Phase 3, Form deep-link context banner
   ========================================================================== */
.form-context-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: var(--space-3) var(--space-4);
  margin-bottom: var(--space-4);
  border: 1px solid var(--accent-soft);
  background: var(--accent-soft);
  color: var(--accent);
  border-radius: var(--radius-md);
  font-size: 0.9rem;
  font-weight: 600;
}

.form-context-banner::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 8px var(--accent);
  flex-shrink: 0;
}

/* ==========================================================================
   Phase 4, Quality, Testing, and Compliance page styles
   ========================================================================== */

/* ----- Quality Hero ------------------------------------------------------ */
.quality-hero {
  position: relative;
  background: var(--surface-dark);
  color: var(--text-on-dark);
  padding-block: clamp(56px, 8vw, 96px) clamp(48px, 6vw, 72px);
  overflow: hidden;
  isolation: isolate;
}

.quality-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(ellipse at 15% 25%, rgba(31,111,235,0.32), transparent 55%),
    radial-gradient(ellipse at 85% 75%, rgba(34,184,207,0.18), transparent 55%);
  pointer-events: none;
}

.quality-hero__grid {
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse at center, rgba(0,0,0,0.6), transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at center, rgba(0,0,0,0.6), transparent 75%);
  pointer-events: none;
}

.quality-hero__inner {
  position: relative;
  z-index: 1;
  display: grid;
  gap: var(--space-7);
  grid-template-columns: 1fr;
  align-items: center;
}

@media (min-width: 1024px) {
  .quality-hero__inner {
    grid-template-columns: 7fr 5fr;
    gap: var(--space-8);
  }
}

.quality-hero__copy {
  display: grid;
  gap: var(--space-4);
  max-width: 640px;
}

/* Quality snapshot panel on the hero */
.quality-snapshot {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
}

.quality-snapshot__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px dashed rgba(255,255,255,0.14);
}

.quality-snapshot__title {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--cyan);
}

.quality-snapshot__pulse {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--cyan);
  box-shadow: 0 0 12px var(--cyan);
  animation: bb-pulse 2.4s ease-in-out infinite;
}

@keyframes bb-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.55; transform: scale(0.85); }
}

@media (prefers-reduced-motion: reduce) {
  .quality-snapshot__pulse { animation: none; }
}

.quality-snapshot__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

.quality-snapshot__list li {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-3);
  padding: 8px 0;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  font-size: 0.9rem;
}
.quality-snapshot__list li:last-child { border-bottom: 0; }

.quality-snapshot__key {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(244,248,255,0.55);
}

.quality-snapshot__val {
  color: #fff;
  font-weight: 600;
  text-align: right;
}

.quality-snapshot__foot {
  margin-top: var(--space-4);
  padding-top: var(--space-3);
  border-top: 1px dashed rgba(255,255,255,0.14);
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(244,248,255,0.5);
}

/* ----- Quality standards section ----------------------------------------- */
.quality-standards { background: var(--bg-base); }

/* ----- Documentation availability section -------------------------------- */
.docs-availability { background: var(--bg-soft); border-block: 1px solid var(--border); }

.docs-availability__inner {
  display: grid;
  gap: var(--space-7);
  grid-template-columns: 1fr;
  align-items: start;
}

@media (min-width: 1024px) {
  .docs-availability__inner {
    grid-template-columns: 7fr 5fr;
    gap: var(--space-8);
  }
}

.docs-availability__copy { display: grid; gap: var(--space-4); }

.docs-list {
  list-style: none;
  margin: var(--space-3) 0 0;
  padding: 0;
  display: grid;
  gap: var(--space-3);
}

.docs-list li {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: var(--space-3);
  align-items: start;
  padding: var(--space-4);
  background: var(--bg-base);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
}

.docs-list__icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-sm);
  background: var(--accent-soft);
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.docs-list__icon svg { width: 20px; height: 20px; }

.docs-list__title {
  margin: 0 0 4px;
  font-size: 0.98rem;
  font-weight: 700;
  color: var(--text-strong);
}

.docs-list__body {
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.55;
  color: var(--text-muted);
}

.docs-availability__cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

/* ----- Storage and handling section -------------------------------------- */
.storage-handling { background: var(--bg-base); }

.storage-handling__inner {
  display: grid;
  gap: var(--space-7);
  grid-template-columns: 1fr;
  align-items: center;
}

@media (min-width: 1024px) {
  .storage-handling__inner {
    grid-template-columns: 5fr 7fr;
    gap: var(--space-8);
  }
}

.storage-points {
  list-style: none;
  margin: var(--space-3) 0 0;
  padding: 0;
  display: grid;
  gap: var(--space-3);
}

.storage-points li {
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: var(--space-3);
  align-items: start;
  padding: var(--space-4);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--bg-base);
}

.storage-points__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: var(--radius-sm);
  background: var(--surface-dark);
  color: var(--cyan);
  font-family: var(--font-mono);
  font-size: 0.8rem;
  letter-spacing: 0.12em;
  font-weight: 600;
}

.storage-points h3 {
  margin: 0 0 4px;
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-strong);
}

.storage-points p {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.55;
  color: var(--text-muted);
}

.placeholder-visual--storage { aspect-ratio: 5 / 4; }

/* ----- Qualified buyer verification timeline ----------------------------- */
.buyer-verify { background: var(--bg-soft); border-block: 1px solid var(--border); }

.verify-steps {
  list-style: none;
  counter-reset: bbv;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-4);
  grid-template-columns: 1fr;
  position: relative;
}

@media (min-width: 768px) {
  .verify-steps { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 1024px) {
  .verify-steps { grid-template-columns: repeat(4, 1fr); }
}

.verify-step {
  position: relative;
  padding: var(--space-5);
  background: var(--bg-base);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  transition: border-color var(--dur-mid) var(--ease),
              transform var(--dur-mid) var(--ease),
              box-shadow var(--dur-mid) var(--ease);
}

.verify-step:hover {
  border-color: var(--accent);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.verify-step__marker {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.verify-step__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-pill);
  background: var(--accent-soft);
  color: var(--accent);
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 0.82rem;
  letter-spacing: 0.1em;
}

.verify-step__title {
  margin: 0 0 var(--space-2);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text-strong);
}

.verify-step__body {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.55;
  color: var(--text-muted);
}

/* Connecting line on desktop */
@media (min-width: 1024px) {
  .verify-steps::before {
    content: "";
    position: absolute;
    left: 12%;
    right: 12%;
    top: 64px;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--accent) 20%, var(--accent) 80%, transparent);
    opacity: 0.35;
    z-index: 0;
  }
  .verify-step { z-index: 1; }
}

.buyer-verify__note {
  margin-top: var(--space-6);
  padding: var(--space-4);
  border: 1px dashed var(--border-strong);
  border-radius: var(--radius-md);
  background: var(--bg-base);
  text-align: center;
  font-size: 0.88rem;
  color: var(--text-muted);
}

.buyer-verify__note p { margin: 0; }

/* ----- FAQ --------------------------------------------------------------- */
.faq { background: var(--bg-base); }

.faq-list {
  display: grid;
  gap: var(--space-2);
  max-width: 880px;
}

.faq-item {
  background: var(--bg-base);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  transition: border-color var(--dur-fast) var(--ease),
              box-shadow var(--dur-fast) var(--ease);
}

.faq-item[open] {
  border-color: var(--accent);
  box-shadow: var(--shadow-sm);
}

.faq-item summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  cursor: pointer;
  list-style: none;
  font-weight: 600;
  color: var(--text-strong);
  user-select: none;
}

/* Hide default marker on Webkit and Firefox */
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::marker { display: none; }

.faq-item summary:hover { background: var(--bg-soft); }
.faq-item summary:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--accent-soft);
  border-radius: var(--radius-md);
}

.faq-item__q {
  flex: 1;
  font-size: 1rem;
  line-height: 1.4;
}

.faq-item__icon {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-pill);
  background: var(--bg-muted);
  color: var(--text-strong);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: transform var(--dur-fast) var(--ease),
              background var(--dur-fast) var(--ease);
}
.faq-item__icon svg { width: 16px; height: 16px; }

.faq-item[open] .faq-item__icon {
  transform: rotate(180deg);
  background: var(--accent);
  color: #fff;
}

.faq-item__a {
  padding: 0 var(--space-5) var(--space-5);
  font-size: 0.95rem;
  line-height: 1.65;
  color: var(--text-body);
  border-top: 1px solid var(--border);
}

.faq-item__a p { margin: var(--space-3) 0 0; }
.faq-item__a a { color: var(--accent); font-weight: 600; }

@media (prefers-reduced-motion: reduce) {
  .faq-item__icon { transition: none; }
}

/* ----- Documentation CTA band variant ------------------------------------ */
.docs-cta-band { /* uses .wholesale base styles, no override needed */ }

/* ----- Quality section CTA on homepage ----------------------------------- */
.quality-section-cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  justify-content: center;
  margin-top: var(--space-7);
  padding-top: var(--space-5);
  border-top: 1px dashed var(--border);
}

/* ----- Quality snapshot card on the catalog page ------------------------- */
.quality-snapshot-band { background: var(--bg-base); padding-block: var(--space-7); }

.quality-snapshot-card {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  align-items: center;
  padding: var(--space-5) var(--space-5);
  background: linear-gradient(135deg, #F2F6FC 0%, #E8F1FE 100%);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  position: relative;
  overflow: hidden;
}

.quality-snapshot-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(31,111,235,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(31,111,235,0.06) 1px, transparent 1px);
  background-size: 24px 24px;
  pointer-events: none;
}

@media (min-width: 768px) {
  .quality-snapshot-card {
    grid-template-columns: 56px 1fr auto;
    gap: var(--space-5);
  }
}

.quality-snapshot-card__visual {
  width: 56px;
  height: 56px;
  border-radius: var(--radius-md);
  background: var(--bg-base);
  border: 1px solid var(--border);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  position: relative;
  z-index: 1;
}
.quality-snapshot-card__visual svg { width: 28px; height: 28px; }

.quality-snapshot-card__body {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 4px;
}

.quality-snapshot-card__title {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--text-strong);
  line-height: 1.3;
}

.quality-snapshot-card__lede {
  margin: 0;
  font-size: 0.9rem;
  color: var(--text-muted);
  line-height: 1.5;
}

.quality-snapshot-card__cta {
  position: relative;
  z-index: 1;
}

/* ----- Product detail, documentation side card link --------------------- */
.detail-side-card__actions {
  display: grid;
  gap: var(--space-2);
}

.detail-side-card__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 4px;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
}

.detail-side-card__link:hover {
  text-decoration: underline;
}

.detail-side-card__link svg { transition: transform var(--dur-fast) var(--ease); }
.detail-side-card__link:hover svg { transform: translateX(3px); }

/* ==========================================================================
   Phase 5, Wholesale Account and Application Flow
   ========================================================================== */

/* ----- Wholesale hero (reuses tokens from quality-hero) ------------------- */
.wholesale-hero {
  position: relative;
  background: var(--surface-dark);
  color: var(--text-on-dark);
  padding-block: clamp(56px, 8vw, 96px) clamp(48px, 6vw, 72px);
  overflow: hidden;
  isolation: isolate;
}

.wholesale-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(ellipse at 10% 30%, rgba(31,111,235,0.32), transparent 55%),
    radial-gradient(ellipse at 90% 80%, rgba(34,184,207,0.20), transparent 55%);
  pointer-events: none;
}

.wholesale-hero__grid {
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse at center, rgba(0,0,0,0.6), transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at center, rgba(0,0,0,0.6), transparent 75%);
  pointer-events: none;
}

.wholesale-hero__inner {
  position: relative;
  z-index: 1;
  display: grid;
  gap: var(--space-7);
  grid-template-columns: 1fr;
  align-items: center;
}

@media (min-width: 1024px) {
  .wholesale-hero__inner {
    grid-template-columns: 7fr 5fr;
    gap: var(--space-8);
  }
}

.wholesale-hero__copy { display: grid; gap: var(--space-4); max-width: 640px; }

/* ----- Program overview + Program benefits (use feature-card base) ------- */
.program-overview { background: var(--bg-base); }
.program-benefits { background: var(--bg-soft); border-block: 1px solid var(--border); }

/* ----- Eligibility ------------------------------------------------------- */
.eligibility { background: var(--bg-base); }

.eligibility-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-3);
  grid-template-columns: 1fr;
}

@media (min-width: 640px) {
  .eligibility-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 1024px) {
  .eligibility-grid { grid-template-columns: repeat(3, 1fr); }
}

.eligibility-card {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: var(--space-3);
  align-items: start;
  padding: var(--space-4);
  background: var(--bg-base);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  transition: border-color var(--dur-mid) var(--ease),
              box-shadow var(--dur-mid) var(--ease),
              transform var(--dur-mid) var(--ease);
}

.eligibility-card:hover {
  border-color: var(--border-strong);
  box-shadow: var(--shadow-sm);
  transform: translateY(-2px);
}

.eligibility-card__icon {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-sm);
  background: var(--accent-soft);
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.eligibility-card__icon svg { width: 22px; height: 22px; }

.eligibility-card__title {
  margin: 0 0 4px;
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-strong);
}

.eligibility-card__body {
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.55;
  color: var(--text-muted);
}

.eligibility-note {
  margin-top: var(--space-6);
  padding: var(--space-4);
  border: 1px dashed var(--border-strong);
  border-radius: var(--radius-md);
  background: var(--bg-soft);
  font-size: 0.88rem;
  line-height: 1.6;
  color: var(--text-muted);
}

.eligibility-note p { margin: 0; }

/* ----- Application section ----------------------------------------------- */
.application {
  background: var(--bg-soft);
  border-block: 1px solid var(--border);
}

.application-grid {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: 1fr;
  align-items: start;
}

@media (min-width: 1024px) {
  .application-grid {
    grid-template-columns: 4fr 8fr;
    gap: var(--space-7);
  }
}

.application-aside {
  display: grid;
  gap: var(--space-4);
  align-content: start;
  position: relative;
}

@media (min-width: 1024px) {
  .application-aside { position: sticky; top: 96px; }
}

.application-aside__card {
  padding: var(--space-5);
  background: var(--bg-base);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
}

.application-aside__card--alt {
  background: var(--surface-dark);
  color: var(--text-on-dark);
  border-color: rgba(255,255,255,0.1);
}

.application-aside__card--alt .application-aside__body { color: rgba(244,248,255,0.78); }
.application-aside__card--alt .u-btn--secondary {
  background: transparent;
  border-color: rgba(255,255,255,0.22);
  color: var(--text-on-dark);
}
.application-aside__card--alt .u-btn--secondary:hover { background: rgba(255,255,255,0.06); }

.application-aside__title {
  margin: 0 0 var(--space-3);
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text-strong);
}

.application-aside__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-2);
}

.application-aside__list li {
  position: relative;
  padding-left: 18px;
  font-size: 0.88rem;
  line-height: 1.5;
  color: var(--text-muted);
}

.application-aside__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 7px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
  opacity: 0.7;
}

.application-aside__tag {
  display: inline-block;
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--cyan);
  margin-bottom: var(--space-2);
}

.application-aside__body {
  margin: 0 0 var(--space-3);
  font-size: 0.9rem;
  line-height: 1.55;
}

/* ----- Application form -------------------------------------------------- */
.application-form {
  background: var(--bg-base);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
}

.application-fieldset {
  border: 0;
  margin: 0 0 var(--space-6);
  padding: 0;
}

.application-fieldset:last-of-type { margin-bottom: var(--space-5); }

.application-legend {
  display: block;
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  padding: 0 0 var(--space-3);
  border-bottom: 1px solid var(--border);
  margin-bottom: var(--space-4);
  width: 100%;
}

.required-mark { color: var(--danger); font-weight: 700; margin-left: 2px; }

/* Checkbox chip group, for Interested Categories */
.checkbox-group {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.checkbox-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  background: var(--bg-base);
  font-size: 0.88rem;
  font-weight: 500;
  color: var(--text-body);
  cursor: pointer;
  transition: border-color var(--dur-fast) var(--ease),
              background var(--dur-fast) var(--ease),
              color var(--dur-fast) var(--ease);
}

.checkbox-chip input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--accent);
  margin: 0;
}

.checkbox-chip:hover {
  border-color: var(--border-strong);
  background: var(--bg-soft);
}

.checkbox-chip:has(input:checked) {
  border-color: var(--accent);
  background: var(--accent-soft);
  color: var(--accent);
}

/* Acknowledgments fieldset */
.application-fieldset--ack {
  background: var(--bg-soft);
  padding: var(--space-5);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
}

.application-fieldset--ack .application-legend {
  border-bottom: 0;
  margin-bottom: var(--space-3);
  padding-bottom: 0;
}

.application-fieldset--ack .checkbox-field {
  background: var(--bg-base);
  margin-bottom: var(--space-3);
}

.application-fieldset--ack .checkbox-field:last-child { margin-bottom: 0; }

/* Error state */
.u-field--error .u-input,
.u-field--error .u-select,
.u-field--error .u-textarea {
  border-color: var(--danger);
  box-shadow: 0 0 0 3px rgba(192, 57, 43, 0.12);
}

.checkbox-field--error {
  border-color: var(--danger);
  background: rgba(192, 57, 43, 0.06);
}

.application-actions {
  display: grid;
  gap: var(--space-3);
  margin-top: var(--space-5);
}

@media (min-width: 640px) {
  .application-actions {
    grid-template-columns: auto 1fr;
    align-items: center;
  }
}

.application-submit {
  width: 100%;
}

@media (min-width: 640px) {
  .application-submit { width: auto; }
}

.application-note {
  margin: 0;
  font-size: 0.82rem;
  color: var(--text-muted);
  line-height: 1.5;
}

/* Mock success state */
.application-success {
  text-align: center;
  padding: var(--space-7) var(--space-5);
}

.application-success__icon {
  width: 64px;
  height: 64px;
  margin: 0 auto var(--space-4);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--success);
  background: rgba(30, 158, 106, 0.12);
  border-radius: var(--radius-pill);
}

.application-success__icon svg { width: 32px; height: 32px; }

.application-success__title {
  margin: 0 0 var(--space-2);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--text-strong);
}

.application-success__body {
  margin: 0 auto var(--space-5);
  max-width: 48ch;
  font-size: 0.98rem;
  line-height: 1.65;
  color: var(--text-muted);
}

.application-success__actions {
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-2);
}

/* ----- Catalog Quality Snapshot card, wholesale link --------------------- */
.quality-snapshot-card__cta {
  display: grid;
  gap: var(--space-2);
  justify-items: start;
}

@media (min-width: 768px) {
  .quality-snapshot-card__cta {
    justify-items: end;
    text-align: right;
  }
}

.quality-snapshot-card__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  padding: 6px 4px;
}

.quality-snapshot-card__link:hover { text-decoration: underline; }

.quality-snapshot-card__link svg { transition: transform var(--dur-fast) var(--ease); }
.quality-snapshot-card__link:hover svg { transform: translateX(3px); }

/* ==========================================================================
   Phase 6, Forms wiring (Netlify), honeypot, privacy microcopy, thank-you
   ========================================================================== */

/* ----- Honeypot (visually hidden, accessible to bots) -------------------- */
.u-honeypot {
  position: absolute;
  left: -9999px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
  margin: 0;
  padding: 0;
}

.u-honeypot label,
.u-honeypot input {
  display: block;
}

/* ----- Privacy microcopy near submit buttons ----------------------------- */
.form-privacy {
  margin: var(--space-4) 0 var(--space-4);
  padding: var(--space-3) var(--space-4);
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 0.82rem;
  line-height: 1.55;
  color: var(--text-muted);
}

.inquiry-form .form-privacy {
  /* sits between the acknowledgment checkbox and the submit button */
}

/* ----- Thank-you pages --------------------------------------------------- */
.thanks-hero {
  position: relative;
  background: var(--surface-dark);
  color: var(--text-on-dark);
  min-height: calc(100vh - 140px);
  display: flex;
  align-items: center;
  padding-block: clamp(48px, 8vw, 96px);
  overflow: hidden;
  isolation: isolate;
}

.thanks-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(ellipse at 30% 30%, rgba(31,111,235,0.32), transparent 55%),
    radial-gradient(ellipse at 70% 70%, rgba(34,184,207,0.20), transparent 55%);
  pointer-events: none;
}

.thanks-hero__grid {
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse at center, rgba(0,0,0,0.6), transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at center, rgba(0,0,0,0.6), transparent 75%);
  pointer-events: none;
}

.thanks-card-wrap {
  position: relative;
  z-index: 1;
  display: grid;
  gap: var(--space-4);
  justify-items: center;
  text-align: center;
}

.thanks-card {
  width: 100%;
  max-width: 640px;
  padding: clamp(28px, 5vw, 56px);
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.14);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  display: grid;
  gap: var(--space-4);
  justify-items: center;
}

.thanks-card__icon {
  width: 72px;
  height: 72px;
  border-radius: var(--radius-pill);
  background: rgba(30, 158, 106, 0.18);
  color: #6FE4B4;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(111, 228, 180, 0.25);
}

.thanks-card__icon svg { width: 36px; height: 36px; }

.thanks-card__eyebrow {
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cyan);
}

.thanks-card__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(2rem, 1.4rem + 2.6vw, 3rem);
  line-height: 1.1;
  letter-spacing: -0.015em;
  color: #fff;
}

.thanks-card__body {
  margin: 0;
  font-size: 1.0625rem;
  line-height: 1.65;
  color: rgba(244,248,255,0.8);
  max-width: 52ch;
}

.thanks-card__small {
  margin: 0;
  font-size: 0.85rem;
  line-height: 1.6;
  color: rgba(244,248,255,0.6);
  max-width: 56ch;
  padding-top: var(--space-3);
  border-top: 1px dashed rgba(255,255,255,0.14);
}

.thanks-card__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-3);
  margin-top: var(--space-3);
}

.thanks-card__actions .u-btn--secondary {
  background: transparent;
  border-color: rgba(255,255,255,0.22);
  color: var(--text-on-dark);
}
.thanks-card__actions .u-btn--secondary:hover { background: rgba(255,255,255,0.06); }

.thanks-card__actions .u-btn--ghost {
  color: var(--cyan);
}
.thanks-card__actions .u-btn--ghost:hover { background: rgba(34,184,207,0.08); }

.thanks-foot {
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(244,248,255,0.5);
}

@media (max-width: 480px) {
  .thanks-card__actions { flex-direction: column; align-items: stretch; }
  .thanks-card__actions .u-btn { width: 100%; }
}

/* ==========================================================================
   Phase 7, Legal pages and Notice-at-Collection microcopy
   ========================================================================== */

/* ----- Legal hero (lighter than the wholesale hero) ---------------------- */
.legal-hero {
  position: relative;
  background: var(--bg-soft);
  border-bottom: 1px solid var(--border);
  padding-block: clamp(48px, 6vw, 80px) clamp(40px, 5vw, 64px);
  overflow: hidden;
  isolation: isolate;
}

.legal-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(ellipse at 20% 0%, rgba(31,111,235,0.10), transparent 60%),
    radial-gradient(ellipse at 90% 100%, rgba(34,184,207,0.06), transparent 60%);
  pointer-events: none;
}

.legal-hero__grid {
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image:
    linear-gradient(rgba(31,111,235,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(31,111,235,0.06) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
  mask-image: radial-gradient(ellipse at center, rgba(0,0,0,0.6), transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse at center, rgba(0,0,0,0.6), transparent 70%);
}

.legal-hero__inner {
  position: relative;
  z-index: 1;
  display: grid;
  gap: var(--space-3);
  max-width: 820px;
}

.legal-hero .catalog-hero__crumb { color: var(--text-muted); }
.legal-hero .catalog-hero__crumb a { color: var(--text-strong); }
.legal-hero .catalog-hero__crumb [aria-current="page"] { color: var(--accent); }
.legal-hero .catalog-hero__eyebrow { color: var(--accent); background: var(--bg-base); border-color: var(--border); }
.legal-hero .catalog-hero__title { color: var(--text-strong); }
.legal-hero .catalog-hero__lede { color: var(--text-muted); }
.legal-hero .catalog-hero__disclaimer { color: var(--text-muted); border-top-color: var(--border); }

/* ----- Legal body layout: sidebar TOC + content -------------------------- */
.legal-body { background: var(--bg-base); }

.legal-grid {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: 1fr;
  align-items: start;
}

@media (min-width: 1024px) {
  .legal-grid {
    grid-template-columns: 260px 1fr;
    gap: var(--space-7);
  }
}

/* TOC */
.legal-toc {
  position: relative;
}

@media (min-width: 1024px) {
  .legal-toc__inner {
    position: sticky;
    top: 96px;
  }
}

.legal-toc__inner {
  padding: var(--space-5);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--bg-soft);
}

.legal-toc__title {
  display: inline-block;
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--space-3);
}

.legal-toc__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 4px;
}

.legal-toc__list a {
  display: block;
  padding: 6px 8px;
  font-size: 0.88rem;
  color: var(--text-body);
  text-decoration: none;
  border-radius: var(--radius-sm);
  border-left: 2px solid transparent;
  transition: background var(--dur-fast) var(--ease),
              color var(--dur-fast) var(--ease),
              border-color var(--dur-fast) var(--ease);
}

.legal-toc__list a:hover {
  background: var(--bg-base);
  color: var(--accent);
  border-left-color: var(--accent);
  text-decoration: none;
}

.legal-toc__list a:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--accent-soft);
}

/* Content */
.legal-content {
  max-width: 78ch;
}

.legal-meta {
  margin: 0 0 var(--space-5);
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.legal-content h2 {
  margin: var(--space-7) 0 var(--space-3);
  font-size: clamp(1.2rem, 1.05rem + 0.6vw, 1.5rem);
  font-weight: 700;
  color: var(--text-strong);
  scroll-margin-top: 96px;
}

.legal-content h2:first-of-type { margin-top: var(--space-5); }

.legal-content h3 {
  margin: var(--space-5) 0 var(--space-3);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--text-strong);
}

.legal-content p,
.legal-content li {
  font-size: 1rem;
  line-height: 1.7;
  color: var(--text-body);
}

.legal-content p { margin: 0 0 var(--space-3); }

.legal-content ul {
  margin: 0 0 var(--space-4);
  padding-left: 1.25rem;
}

.legal-content ul li {
  margin-bottom: 6px;
}

.legal-content a {
  color: var(--accent);
  font-weight: 500;
}

/* Buttons inside legal prose must keep their component colors, not the prose
   link color above. Without this, .u-btn--primary text inherits the accent
   color and becomes invisible on its accent background. */
.legal-content .u-btn--primary,
.legal-content .u-btn--primary:hover,
.legal-content .u-btn--primary:focus-visible {
  color: #fff;
}
.legal-content .u-btn--secondary {
  color: var(--text-strong);
}
.legal-content .u-btn--ghost {
  color: var(--accent);
}

/* Legal overview card */
.legal-overview-card,
.legal-draft-card {
  margin: var(--space-3) 0 var(--space-6);
  padding: var(--space-5);
  border: 1px solid var(--border);
  border-left: 4px solid var(--accent);
  border-radius: var(--radius-md);
  background: var(--accent-soft);
}

.legal-overview-card__tag,
.legal-draft-card__tag {
  display: inline-block;
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--space-2);
}

.legal-overview-card p,
.legal-draft-card p {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.6;
  color: var(--text-body);
}

/* Final CTA inside legal content */
.legal-final-cta {
  margin-top: var(--space-7);
  padding: var(--space-6);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--bg-soft);
}

.legal-final-cta h3 {
  margin: 0 0 var(--space-2);
  font-size: 1.15rem;
  color: var(--text-strong);
}

.legal-final-cta p {
  margin: 0 0 var(--space-3);
  color: var(--text-muted);
}

.legal-final-cta__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

/* ----- Notice-at-Collection microcopy tag inside .form-privacy ---------- */
.form-privacy {
  display: block;
}

.form-privacy__tag {
  display: inline-block;
  font-size: 0.66rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 700;
  margin-bottom: 4px;
}

.form-privacy a {
  color: var(--accent);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.form-privacy a:hover { text-decoration-thickness: 2px; }

/* ==========================================================================
   Phase 8, Print stylesheet for legal pages
   Hides chrome, forces black text on white, expands legal content
   ========================================================================== */
@media print {
  /* Hide non-essential chrome */
  .compliance-strip,
  .site-header,
  .site-footer,
  .legal-toc,
  .legal-final-cta,
  .u-skip-link,
  .mobile-menu,
  .form-context-banner {
    display: none !important;
  }

  /* Page background and text */
  html, body {
    background: #fff !important;
    color: #000 !important;
  }

  /* Disable decorative grid texture */
  body::before { display: none !important; }

  /* Legal pages, full width */
  .legal-hero {
    background: #fff !important;
    border-bottom: 1px solid #999 !important;
    padding-block: 12pt !important;
  }
  .legal-hero::before,
  .legal-hero__grid { display: none !important; }

  .legal-hero .catalog-hero__title,
  .legal-content h2,
  .legal-content h3 {
    color: #000 !important;
    page-break-after: avoid;
  }

  .legal-content,
  .legal-grid {
    max-width: 100% !important;
    grid-template-columns: 1fr !important;
  }

  .legal-content p,
  .legal-content li {
    color: #000 !important;
    line-height: 1.55 !important;
    font-size: 11pt !important;
  }

  /* Show full link URLs for clarity */
  .legal-content a[href]::after {
    content: " (" attr(href) ")";
    font-size: 9pt;
    color: #444;
  }
  /* Skip URL footnote for in-page anchors and mailto */
  .legal-content a[href^="#"]::after,
  .legal-content a[href^="mailto:"]::after { content: ""; }

  .legal-overview-card,
  .legal-draft-card {
    background: #f4f4f4 !important;
    border-color: #999 !important;
    border-left-color: #000 !important;
  }

  /* Avoid orphan headings at page bottom */
  h1, h2, h3 { page-break-after: avoid; break-after: avoid; }
  p, li { orphans: 3; widows: 3; }
}

/* ==========================================================================
   Phase 9, AEO FAQ blocks (homepage, catalog, wholesale)
   Lightweight details/summary grid that complements the full FAQ on
   quality.html. Uses the same chevron/animation pattern as .faq-item.
   ========================================================================== */

/* Answer block (AEO) ------------------------------------------------------ */
.answer-band {
  background: var(--bg-soft);
  border-block: 1px solid var(--border);
  padding-block: var(--space-6);
}
.answer-band__inner { max-width: 70ch; }
.answer-band__q {
  margin: 0 0 var(--space-2);
  font-size: 1.15rem;
  line-height: 1.3;
  color: var(--text-strong);
}
.answer-band__a {
  margin: 0;
  color: var(--text-body);
  line-height: 1.7;
}

.aeo-faq { background: var(--bg-soft); border-block: 1px solid var(--border); }

.aeo-faq__grid {
  display: grid;
  gap: var(--space-3);
  grid-template-columns: 1fr;
}

@media (min-width: 768px) {
  .aeo-faq__grid { grid-template-columns: repeat(2, 1fr); }
}

.aeo-faq__item {
  background: var(--bg-base);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  transition: border-color var(--dur-fast) var(--ease),
              box-shadow var(--dur-fast) var(--ease);
}

.aeo-faq__item[open] {
  border-color: var(--accent);
  box-shadow: var(--shadow-sm);
}

.aeo-faq__item summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  cursor: pointer;
  list-style: none;
  font-weight: 600;
  font-size: 0.98rem;
  color: var(--text-strong);
}

.aeo-faq__item summary::-webkit-details-marker { display: none; }
.aeo-faq__item summary::marker { display: none; }

.aeo-faq__item summary::after {
  content: "";
  width: 12px;
  height: 12px;
  border-right: 2px solid var(--text-muted);
  border-bottom: 2px solid var(--text-muted);
  transform: rotate(45deg);
  transition: transform var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease);
  flex-shrink: 0;
  margin-right: 4px;
}

.aeo-faq__item[open] summary::after {
  transform: rotate(-135deg);
  border-color: var(--accent);
}

.aeo-faq__item summary:hover { background: var(--bg-soft); }
.aeo-faq__item summary:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--accent-soft);
  border-radius: var(--radius-md);
}

.aeo-faq__item > div {
  padding: 0 var(--space-5) var(--space-5);
  font-size: 0.92rem;
  line-height: 1.65;
  color: var(--text-body);
  border-top: 1px solid var(--border);
}

.aeo-faq__item > div p {
  margin: var(--space-3) 0 0;
}

.aeo-faq__item a {
  color: var(--accent);
  font-weight: 600;
}

@media (prefers-reduced-motion: reduce) {
  .aeo-faq__item summary::after { transition: none; }
}

/* Reduce heavy backdrop blur on small screens for perf */
@media (max-width: 480px) {
  .quality-snapshot,
  .wholesale__card,
  .thanks-card {
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
  }
}

/* ==========================================================================
   Eligibility card alignment fix
   The card uses a 2-column grid (44px icon | 1fr content). Without explicit
   placement, the title and body land in the wrong cells, so the body wraps
   inside the 44px icon column. Force title/body into column 2 and let the
   icon span both rows. min-width: 0 prevents grid items from blowing past.
   ========================================================================== */
.eligibility-card { min-width: 0; }
.eligibility-card__icon { grid-row: 1 / span 2; }
.eligibility-card__title,
.eligibility-card__body {
  grid-column: 2;
  min-width: 0;
}

/* ==========================================================================
   Pricing preview, homepage "Product Catalog and Wholesale Pricing" section
   ========================================================================== */
.pricing-preview { background: var(--bg-soft); border-block: 1px solid var(--border); }

.pricing-grid {
  display: grid;
  gap: var(--space-3);
  grid-template-columns: 1fr;
  margin-top: var(--space-6);
}
@media (min-width: 640px) {
  .pricing-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .pricing-grid { grid-template-columns: repeat(4, 1fr); }
}

.pricing-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-4);
  background: var(--bg-base);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  min-width: 0;
  transition: border-color var(--dur-mid) var(--ease),
              box-shadow var(--dur-mid) var(--ease),
              transform var(--dur-mid) var(--ease);
}
.pricing-card:hover {
  border-color: var(--border-strong);
  box-shadow: var(--shadow-sm);
  transform: translateY(-2px);
}

.pricing-card__icon {
  width: 44px;
  height: 44px;
  min-width: 44px;
  max-width: 44px;
  min-height: 44px;
  max-height: 44px;
  border-radius: 12px;
  background: var(--accent-soft);
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
}
.pricing-card__icon svg {
  width: 22px !important;
  height: 22px !important;
  max-width: 22px !important;
  max-height: 22px !important;
  display: block;
}

.pricing-card__title {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-strong);
}
.pricing-card__body {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.55;
  color: var(--text-muted);
}

.pricing-preview__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  justify-content: center;
  margin-top: var(--space-6);
}

.pricing-preview__note {
  margin-top: var(--space-4);
  text-align: center;
  font-size: 0.82rem;
  line-height: 1.55;
  color: var(--text-muted);
}

/* ==========================================================================
   Catalog: A-Z letter filter row
   ========================================================================== */
.catalog-letters {
  margin-top: var(--space-3);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.catalog-letters::-webkit-scrollbar { display: none; }
.catalog-letters__scroll {
  display: flex;
  gap: 6px;
  padding-block: 4px;
  white-space: nowrap;
}
.letter-pill {
  flex-shrink: 0;
  padding: 6px 12px;
  min-width: 36px;
  font: 600 0.85rem/1 var(--font-mono, monospace);
  letter-spacing: 0.04em;
  background: var(--bg-base);
  color: var(--text-muted);
  border: 1px solid var(--border);
  border-radius: 999px;
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease),
              color var(--dur-fast) var(--ease),
              border-color var(--dur-fast) var(--ease);
}
.letter-pill:hover { color: var(--accent); border-color: var(--accent); }
.letter-pill.is-active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

/* ==========================================================================
   Catalog: sort dropdown
   ========================================================================== */
.catalog-sort { min-width: 0; flex: 1 1 200px; }
.catalog-sort .u-select { width: 100%; }
@media (min-width: 768px) {
  .catalog-sort { flex: 0 0 220px; }
}

/* ==========================================================================
   Product card (pricing-aware)
   ========================================================================== */
.product-card {
  padding: var(--space-4);
  gap: var(--space-2);
  min-width: 0;
}
.product-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}
.product-card__letter {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent);
  font-size: 0.72rem;
  font-weight: 700;
}
.product-card__strength {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.88rem;
}
.product-card__strength-label {
  display: inline-block;
  margin-right: 4px;
  font-weight: 600;
  color: var(--text);
}
.product-card__prices {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2);
  margin: var(--space-2) 0 0;
  padding: var(--space-2);
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}
.product-card__prices > div { min-width: 0; }
.product-card__prices dt {
  margin: 0;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-muted);
}
.product-card__prices dd {
  margin: 2px 0 0;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text-strong);
  font-variant-numeric: tabular-nums;
}
.product-card__custom-label {
  margin: 0;
  font-size: 0.78rem;
  color: var(--text-muted);
  line-height: 1.4;
}

/* ==========================================================================
   Catalog table: price columns
   ========================================================================== */
.catalog-table__price {
  text-align: right;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

/* ==========================================================================
   Product detail: price block + related strengths
   ========================================================================== */
.detail-info__strength {
  margin: 0 0 var(--space-3);
  color: var(--text-muted);
  font-size: 1rem;
}
.detail-info__strength-label {
  font-weight: 600;
  color: var(--text);
}

.detail-prices {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
  margin: 0 0 var(--space-4);
  padding: var(--space-3);
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
}
.detail-prices > div { min-width: 0; }
.detail-pdf-link {
  margin: calc(var(--space-4) * -1 + var(--space-2)) 0 var(--space-4);
  font-size: 0.85rem;
}
.detail-pdf-link a { color: var(--text-muted); }
.detail-pdf-link a:hover { color: var(--text-strong); }
.detail-prices dt {
  margin: 0;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-muted);
}
.detail-prices dd {
  margin: 4px 0 0;
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--text-strong);
  font-variant-numeric: tabular-nums;
}

.detail-related {
  margin-top: var(--space-5);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border);
}
.detail-related__title {
  margin: 0 0 var(--space-3);
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-strong);
}
.detail-related__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-2);
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
}
.detail-related__list a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  background: var(--bg-base);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-weight: 600;
  color: var(--text);
  text-decoration: none;
  transition: border-color var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.detail-related__list a:hover { border-color: var(--accent); color: var(--accent); }
.detail-related__price {
  font-size: 0.78rem;
  font-weight: 500;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
}

/* ==========================================================================
   Sticky catalog controls
   Desktop/tablet: search + sort + view toggle + category pills stick under
   the header. Mobile (<=767px): only the controls row sticks (search +
   sort + view toggle); category and letter rows scroll normally so they
   don't eat screen height.
   ========================================================================== */
@media (min-width: 768px) {
  .catalog-controls,
  .catalog-filters {
    position: sticky;
    z-index: 5;
    background: var(--bg-base);
    -webkit-backdrop-filter: saturate(180%) blur(8px);
    backdrop-filter: saturate(180%) blur(8px);
  }
  .catalog-controls {
    top: 0;
    padding-block: var(--space-3);
    border-bottom: 1px solid var(--border);
  }
  .catalog-filters {
    top: 64px; /* sits just below the controls row */
    padding-block: 6px;
    border-bottom: 1px solid var(--border);
  }
}

@media (max-width: 767px) {
  .catalog-controls {
    position: sticky;
    top: 0;
    z-index: 5;
    background: var(--bg-base);
    -webkit-backdrop-filter: saturate(180%) blur(8px);
    backdrop-filter: saturate(180%) blur(8px);
    padding-block: var(--space-2);
    border-bottom: 1px solid var(--border);
  }
}

/* ==========================================================================
   Catalog card polish: consistent heights + cleaner spacing
   ========================================================================== */
.catalog-results__grid {
  align-items: stretch;
}
.product-card {
  height: 100%;
}
.product-card__title {
  /* Long names (e.g. KLOW80 (BPC157 10mg+GHK-CU 50mg+TB500 10mg+KPV10mg))
     should wrap by word, never per letter, and never blow out the card. */
  word-break: normal;
  overflow-wrap: anywhere;
  hyphens: none;
}
.product-card__actions {
  margin-top: auto;
}
.product-card__disclaimer {
  margin-top: var(--space-2);
  font-size: 0.66rem;
  letter-spacing: 0.04em;
  color: var(--text-muted);
}

/* ==========================================================================
   Catalog table polish
   ========================================================================== */
.catalog-table__product {
  min-width: 180px;
  font-weight: 600;
}
.catalog-table th.catalog-table__price,
.catalog-table td.catalog-table__price {
  text-align: right;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  width: 1%;
}
.catalog-table__action-col { width: 1%; white-space: nowrap; }

/* ==========================================================================
   FINAL COMPLIANCE STRIP OVERRIDE, must remain at the very bottom of file.
   Desktop: render four discrete items inline. Mobile: render a single
   compact line. Blue dot is always hidden.
   ========================================================================== */
.compliance-strip__mobile { display: none; }

.compliance-strip__desktop {
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
}

.compliance-strip__dot { display: none !important; }

@media (max-width: 767px) {
  .compliance-strip {
    width: 100% !important;
    overflow: hidden !important;
    padding: 0 !important;
  }

  .compliance-strip__inner {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-wrap: nowrap !important;
    gap: 0 !important;
    padding: 6px 6px !important;
    margin: 0 !important;
    min-height: 22px !important;
    max-height: 26px !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    text-align: center !important;
  }

  .compliance-strip__desktop,
  .compliance-strip__item {
    display: none !important;
  }

  .compliance-strip__mobile {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    color: rgba(244, 248, 255, 0.78) !important;
    font-size: clamp(6.8px, 1.95vw, 8.5px) !important;
    line-height: 1 !important;
    letter-spacing: 0.01em !important;
    font-weight: 700 !important;
    text-align: center !important;
    text-transform: uppercase !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: clip !important;
  }

  .compliance-strip__dot { display: none !important; }
}

@media (min-width: 768px) {
  .compliance-strip__mobile { display: none !important; }
  .compliance-strip__desktop { display: inline-flex !important; }
  .compliance-strip__dot { display: none !important; }
}

/* ==========================================================================
   IMAGE-CARD CLEANUP, must remain at the very bottom of file.
   When a real image is present in an image card or placeholder visual, hide
   every decorative overlay (grid, glow, glyph, icon, label, tag) so the
   image renders cleanly inside the rounded card. Image fills the container
   via object-fit: cover and is clipped by overflow: hidden + inherited
   border-radius. Placeholder markup and classes remain intact; only the
   visible overlays are suppressed when an actual <img> is present.
   ========================================================================== */

/* ---- Catalog category cards (homepage Catalog Preview) ---- */
.catalog-card__visual:has(.catalog-card__visual-img:not([hidden]))::before,
.catalog-card__visual:has(.catalog-card__visual-img:not([hidden]))::after,
.catalog-card__visual:has(.catalog-card__visual-img:not([hidden])) .catalog-card__glyph,
.catalog-card__visual:has(.catalog-card__visual-img:not([hidden])) .catalog-card__placeholder-label {
  display: none !important;
}

/* ---- Featured catalog cards (catalog.html featured categories) ---- */
.featured-cat__visual:has(.featured-cat__visual-img:not([hidden]))::before,
.featured-cat__visual:has(.featured-cat__visual-img:not([hidden]))::after,
.featured-cat__visual:has(.featured-cat__visual-img:not([hidden])) .featured-cat__glyph,
.featured-cat__visual:has(.featured-cat__visual-img:not([hidden])) .featured-cat__label-mono {
  display: none !important;
}

/* ---- Product card visual (catalog page cards, if image present) ---- */
.product-card__visual:has(.product-card__visual-img:not([hidden]))::before,
.product-card__visual:has(.product-card__visual-img:not([hidden]))::after,
.product-card__visual:has(.product-card__visual-img:not([hidden])) .product-card__molecule,
.product-card__visual:has(.product-card__visual-img:not([hidden])) .product-card__placeholder-label,
.product-card__visual:has(.product-card__visual-img:not([hidden])) .product-card__sku-badge {
  display: none !important;
}

/* ---- Placeholder visuals (product detail, quality, wholesale, etc.) ---- */
.placeholder-visual:has(.placeholder-visual__img:not([hidden]))::before,
.placeholder-visual:has(.placeholder-visual__img:not([hidden])) .placeholder-visual__core,
.placeholder-visual:has(.placeholder-visual__img:not([hidden])) .placeholder-visual__tag {
  display: none !important;
}

/* ---- Universal image fill + clean clipping for every image card ---- */
.catalog-card__visual-img,
.featured-cat__visual-img,
.product-card__visual-img,
.placeholder-visual__img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
  object-position: center !important;
  border-radius: inherit;
  filter: none !important;       /* drop the saturation/contrast tweak so images look natural */
  z-index: 1 !important;
}

/* ---- Make sure image containers clip cleanly ---- */
.catalog-card__visual,
.featured-cat__visual,
.product-card__visual,
.placeholder-visual {
  position: relative;
  overflow: hidden;
}

/* ==========================================================================
   Homepage Catalog Teaser (alphabetical browsing)
   Replaces the old 6-card category grid with a chip row + A-Z deep-link
   row + CTA cluster. Reuses design tokens so the visual rhythm matches
   .pricing-card and the catalog page letter pills.
   ========================================================================== */
.catalog-teaser__chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  justify-content: center;
  margin-top: var(--space-6);
}
.catalog-teaser__chip {
  display: inline-flex;
  align-items: center;
  padding: 8px 14px;
  background: var(--bg-base);
  color: var(--text-strong);
  font-size: 0.88rem;
  font-weight: 600;
  border: 1px solid var(--border);
  border-radius: 999px;
}

.catalog-teaser__letters {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: center;
  margin-top: var(--space-5);
  padding: var(--space-4);
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
}
.catalog-teaser__letter {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 10px;
  font: 600 0.95rem/1 var(--font-mono, monospace);
  letter-spacing: 0.04em;
  color: var(--text-muted);
  background: var(--bg-base);
  border: 1px solid var(--border);
  border-radius: 999px;
  text-decoration: none;
  transition: background var(--dur-fast) var(--ease),
              color var(--dur-fast) var(--ease),
              border-color var(--dur-fast) var(--ease);
}
.catalog-teaser__letter:hover,
.catalog-teaser__letter:focus-visible {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

.catalog-teaser__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  justify-content: center;
  margin-top: var(--space-5);
}

/* ==========================================================================
   Footer brand contact (Orders / Inquiries email under the company line)
   ========================================================================== */
.footer-contact {
  margin-top: var(--space-3);
}
.footer-contact__label {
  margin: 0 0 4px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(244, 248, 255, 0.92);
}
.footer-contact__link {
  display: inline-block;
  color: rgba(244, 248, 255, 0.7);
  font-size: 0.9rem;
  font-weight: 400;
  text-decoration: none;
  border-bottom: 0;
  transition: color var(--dur-fast) var(--ease);
}
.footer-contact__link:hover,
.footer-contact__link:focus-visible {
  color: var(--accent);
  text-decoration: none;
  border-bottom: 0;
}
