*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: 'DM Sans', sans-serif;
  background: #f7f6f3;
  color: #1a0f3c;
  overflow-x: clip;
  -webkit-font-smoothing: antialiased;
}

/* ── GIANT HERO ── */
.hero-giant {
  padding-top: 80px;
  padding-bottom: 40px;
  min-height: 100vh;
  background: #1a0f3c;
  /* Atominc Dark Navy */
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
  color: #fff;
}

/* ── ANIMATED SQUARES CANVAS ── */
#hero-squares-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  z-index: 1;
  pointer-events: none;
}

/* Lift all hero content above the canvas */
.hero-content,
.marquee-section {
  position: relative;
  z-index: 10;
}

.hero-content {
  text-align: center;
  z-index: 10;
  padding: 0 20px;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.giant-heading {
  font-family: 'DM Sans', sans-serif;
  font-size: clamp(4rem, 15vw, 13rem);
  font-weight: 700;
  line-height: 1.0;
  letter-spacing: -0.05em;
  margin: 0;
  color: #e63975;
  /* Vibrant Pink */
}

.giant-heading-sub {
  font-family: 'DM Sans', sans-serif;
  font-size: clamp(2.5rem, 6vw, 5.5rem);
  font-weight: 500;
  line-height: 1.1;
  letter-spacing: -0.03em;
  margin: 10px 0 50px;
  color: rgba(255, 255, 255, 0.9);
}

.giant-heading-sub strong {
  font-weight: 700;
  color: #fff;
}

.btn-neon-pink {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #e63975;
  color: #fff;
  font-size: 1.4rem;
  font-weight: 700;
  padding: 24px 56px;
  border-radius: 60px;
  text-decoration: none;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 8px 32px rgba(230, 57, 117, 0.4);
  border: 2px solid #e63975;
  margin-bottom: 20px;
}

.btn-neon-pink:hover {
  background: transparent;
  color: #e63975;
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(230, 57, 117, 0.2);
}

.hero-support {
  max-width: 720px;
  margin: 5px auto 1px;
  font-size: 1.05rem;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.78);
}

/* ── MARQUEE ── */
.marquee-section {
  width: 100%;
  margin-top: auto;
  padding-bottom: 40px;
  z-index: 10;
}

.marquee-title {
  text-align: center;
  color: rgba(226, 52, 117, 1);
  font-size: 1.2rem;
  font-family: 'DM Serif Display', serif;
  margin-bottom: 30px;
}

.marquee {
  width: 100%;
  overflow: hidden;
  display: flex;
  white-space: nowrap;
  mask-image: linear-gradient(to right, transparent, black 15%, black 85%, transparent);
  -webkit-mask-image: linear-gradient(to right, transparent, black 15%, black 85%, transparent);
}

.marquee-inner {
  display: flex;
  gap: 80px;
  align-items: center;
  padding-left: 80px;
  animation: scrollMarquee 35s linear infinite;
}

.marquee-inner span {
  font-size: 1.8rem;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.3);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  transition: color 0.3s;
}

.marquee-inner span:hover {
  color: #fff;
}

@keyframes scrollMarquee {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-50%);
  }
}

/* ── SECTIONS ── */




.section-teal {
  background: #17474a;
  padding: 100px 0;
  position: relative;
  overflow: hidden;
}

.section-teal::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 50% 0%, rgba(230, 57, 117, 0.18) 0%, transparent 60%);
}

.container {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 40px;
}

.eyebrow {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #e63975;
  margin-bottom: 14px;
}

.h2 em {
  font-style: italic;
  color: #e63975;
}

.h2.light {
  color: white;
}

.h2.light em {
  color: #f8a4c0;
}

.body-lg {
  font-size: 1rem;
  color: #5a5080;
  line-height: 1.75;
  max-width: 520px;
}

.body-light {
  color: rgba(255, 255, 255, 0.65);
}

.section-header {
  margin-bottom: 56px;
}

/* ── WHY BRANDS / WHY SELLERS ── */
.split-section {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}

.split-right {}

.split-left {}

.brand-features {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 28px;
}

.brand-feature {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 16px 18px;
  background: #f7f6f3;
  border-radius: 12px;
  border: 1px solid rgba(0, 0, 0, 0.05);
  transition: all 0.25s;
}

.brand-feature:hover {
  background: white;
  box-shadow: 0 4px 16px rgba(26, 15, 60, 0.06);
  transform: translateX(4px);
}

.bf-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: linear-gradient(135deg, #fce4ec, #f8bbd0);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
}

.bf-text h4 {
  font-size: 0.88rem;
  font-weight: 700;
  color: #1a0f3c;
  margin-bottom: 4px;
}

.bf-text p {
  font-size: 0.8rem;
  color: #5a5080;
  line-height: 1.6;
}

/* ── 4 PILLARS (WHY SELLERS) ── */
.pillars-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-top: 56px;
}

.pillar-card {
  background: white;
  border-radius: 20px;
  padding: 32px 24px;
  border: 1px solid rgba(0, 0, 0, 0.06);
  text-align: center;
  transition: all 0.3s;
}

.pillar-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 48px rgba(26, 15, 60, 0.10);
}

.pc-icon-wrap {
  width: 64px;
  height: 64px;
  border-radius: 16px;
  margin: 0 auto 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
}

.pc-teal {
  background: linear-gradient(135deg, #b2dfdb, #80cbc4);
}

.pc-pink {
  background: linear-gradient(135deg, #f8bbd0, #f48fb1);
}

.pc-navy {
  background: linear-gradient(135deg, #c5cae9, #9fa8da);
}

.pc-gold {
  background: linear-gradient(135deg, #ffe0b2, #ffcc80);
}

.pillar-card h3 {
  font-family: 'DM Serif Display', serif;
  font-size: 1.1rem;
  color: #1a0f3c;
  margin-bottom: 10px;
}

.pillar-card p {
  font-size: 0.82rem;
  color: #5a5080;
  line-height: 1.65;
}

/* ── HOW IT WORKS ── */
.steps-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  margin-top: 56px;
  position: relative;
}

.steps-grid::before {
  content: '';
  position: absolute;
  top: 36px;
  left: 12%;
  right: 12%;
  height: 2px;
  background: linear-gradient(90deg, #e63975, #26878a, #e63975);
  opacity: 0.25;
}

.step {
  text-align: center;
  padding: 0 16px;
}

.step-num {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: white;
  border: 2px solid rgba(230, 57, 117, 0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
  font-family: 'DM Serif Display', serif;
  font-size: 1.5rem;
  color: #e63975;
  position: relative;
  z-index: 2;
  box-shadow: 0 4px 20px rgba(230, 57, 117, 0.1);
  transition: all 0.3s;
}

.step:hover .step-num {
  background: #e63975;
  color: white;
  transform: scale(1.1);
}

.step h4 {
  font-family: 'DM Serif Display', serif;
  font-size: 1rem;
  color: #1a0f3c;
  margin-bottom: 8px;
}

.step p {
  font-size: 0.8rem;
  color: #5a5080;
  line-height: 1.65;
}

/* ── SECTIONS (RESTORED & BOLDED) ── */
.section-white {
  background: #fff;
  padding: 140px 0;
}

.section-light {
  background: #f7f6f3;
  padding: 140px 0;
}

.section-teal {
  background: #17474a;
  padding: 140px 0;
}

.container {
  max-width: 1700px;
  margin: 0 auto;
  padding: 0 40px;
}

.eyebrow {
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: #e63975;
  margin-bottom: 24px;
}

.h2 {
  font-family: 'DM Sans', sans-serif;
  font-size: clamp(2.5rem, 5vw, 4.2rem);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.03em;
  color: #1a0f3c;
  margin-bottom: 24px;
}

.h2 em {
  font-weight: 800;
  font-style: normal;
  color: #17474a;
}

.h2.light {
  color: white;
}

.h2.light em {
  color: #f8a4c0;
}

.body-lg {
  font-size: 1.2rem;
  color: #5a5080;
  line-height: 1.6;
  max-width: 600px;
  font-weight: 500;
}

.body-light {
  color: rgba(255, 255, 255, 0.8);
}

.split-section {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 80px;
  align-items: center;
}

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

.brand-feature {
  display: flex;
  gap: 20px;
}

.bf-icon {
  font-size: 1.8rem;
  background: rgba(230, 57, 117, 0.1);
  width: 64px;
  height: 64px;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.bf-text h4 {
  font-family: 'DM Sans', sans-serif;
  font-size: 1.35rem;
  font-weight: 700;
  color: #1a0f3c;
  margin-bottom: 8px;
}

.bf-text p {
  font-size: 1rem;
  color: #5a5080;
  line-height: 1.6;
}

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

.pillar-card {
  background: white;
  border-radius: 24px;
  padding: 40px 32px;
  border: 1px solid rgba(0, 0, 0, 0.04);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.02);
  transition: transform 0.3s ease;
}

.pillar-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 40px rgba(26, 15, 60, 0.08);
}

.pc-icon-wrap {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  margin-bottom: 24px;
}

.pc-pink {
  background: #fce7f3;
}

.pc-teal {
  background: #ccfbf1;
}

.pc-navy {
  background: #e0e7ff;
}

.pc-gold {
  background: #fef3c7;
}

.pillar-card h3 {
  font-family: 'DM Sans', sans-serif;
  font-size: 1.4rem;
  font-weight: 700;
  color: #1a0f3c;
  margin-bottom: 12px;
}

.pillar-card p {
  font-size: 1rem;
  color: #5a5080;
  line-height: 1.6;
}

.steps-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px;
  margin-top: 80px;
  position: relative;
}

.steps-grid::before {
  content: '';
  position: absolute;
  top: 24px;
  left: 0;
  right: 0;
  height: 2px;
  background: rgba(26, 15, 60, 0.08);
  z-index: 1;
}

.step {
  position: relative;
  z-index: 2;
}

.step-num {
  width: 48px;
  height: 48px;
  background: white;
  border: 3px solid #e63975;
  border-radius: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  font-weight: 800;
  color: #e63975;
  margin-bottom: 24px;
  transition: all 0.3s;
}

.step:hover .step-num {
  background: #e63975;
  color: white;
  transform: scale(1.1);
}

.step h4 {
  font-family: 'DM Sans', sans-serif;
  font-size: 1.3rem;
  font-weight: 700;
  color: #1a0f3c;
  margin-bottom: 10px;
}

.step p {
  font-size: 1rem;
  color: #5a5080;
  line-height: 1.6;
}

/* ── STATS STRIP ── */
.stats-strip {
  background: #17474a;
  padding: 56px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.stats-inner {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  text-align: center;
}

.stat-item {
  padding: 0 20px;
  border-right: 1px solid rgba(255, 255, 255, 0.1);
}

.stat-item:last-child {
  border-right: none;
}

.stat-num {
  font-family: 'DM Serif Display', serif;
  font-size: 2.8rem;
  color: white;
}

.stat-num span {
  color: #f8a4c0;
}

.stat-label {
  font-size: 0.82rem;
  color: rgba(255, 255, 255, 0.55);
  margin-top: 6px;
}

/* ── SERVICE CARDS ── */
.services-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-top: 56px;
}

.service-card {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 20px;
  padding: 36px;
  transition: all 0.3s;
}

.service-card:hover {
  background: rgba(255, 255, 255, 0.1);
  transform: translateY(-4px);
}

.sc-icon {
  font-size: 1.8rem;
  margin-bottom: 18px;
  display: block;
}

.service-card h3 {
  font-family: 'DM Serif Display', serif;
  font-size: 1.2rem;
  color: white;
  margin-bottom: 10px;
}

.service-card p {
  font-size: 0.85rem;
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.7;
}

.pricing-teaser-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin-top: 56px;
}

.pricing-teaser-card {
  background: white;
  border-radius: 24px;
  padding: 32px 28px;
  border: 1px solid rgba(0, 0, 0, 0.06);
  box-shadow: 0 12px 36px rgba(26, 15, 60, 0.04);
}

.pricing-teaser-card .label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #e63975;
  margin-bottom: 10px;
}

.pricing-teaser-card h3 {
  font-family: 'DM Serif Display', serif;
  font-size: 1.4rem;
  color: #1a0f3c;
  margin-bottom: 10px;
}

.pricing-teaser-card .price {
  font-family: 'DM Serif Display', serif;
  font-size: 2rem;
  color: #17474a;
  margin-bottom: 10px;
}

.pricing-teaser-card p {
  font-size: 0.84rem;
  color: #5a5080;
  line-height: 1.7;
}

.sc-items {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
}

.sc-tag {
  font-size: 0.7rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.7);
  background: rgba(255, 255, 255, 0.1);
  padding: 4px 12px;
  border-radius: 50px;
}

/* ── CTA ── */
.cta-section {
  padding: 100px 0 0;
  background: #f7f6f3;
}

.cta-inner {
  text-align: center;
  max-width: 680px;
  margin: 0 auto;
  padding-bottom: 80px;
}

.cta-inner .h2 {
  max-width: none;
}

.cta-btns {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 32px;
}

.btn-cta-primary {
  text-decoration: none;
  color: #fff;
  font-size: 0.95rem;
  font-weight: 700;
  padding: 14px 32px;
  border-radius: 50px;
  background: #e63975;
  box-shadow: 0 4px 24px rgba(230, 57, 117, 0.4);
  transition: all 0.25s;
}

.btn-cta-primary:hover {
  background: #c8255e;
  transform: translateY(-2px);
}

.btn-cta-outline {
  text-decoration: none;
  color: #1a0f3c;
  font-size: 0.95rem;
  font-weight: 500;
  padding: 14px 32px;
  border-radius: 50px;
  border: 1.5px solid rgba(26, 15, 60, 0.18);
  transition: all 0.25s;
}

.btn-cta-outline:hover {
  border-color: #1a0f3c;
  transform: translateY(-2px);
}

.gradient-band {
  height: 100px;
  background: linear-gradient(90deg, #f8bbd0, #b2dfdb, #c5cae9, #ffe0b2);
  opacity: 0.4;
}

/* ── FOOTER ── */
footer {
  background: #17474a;
  padding: 64px 0 36px;
}

.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 48px;
  margin-bottom: 48px;
}

.footer-brand p {
  font-size: 0.85rem;
  color: rgba(255, 255, 255, 0.55);
  line-height: 1.7;
  margin-top: 12px;
  max-width: 260px;
}

.footer-logo {
  font-family: 'DM Serif Display', serif;
  font-size: 1.3rem;
  color: white;
  text-decoration: none;
  display: block;
  margin-bottom: 4px;
}

.footer-col h4 {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.4);
  margin-bottom: 16px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.footer-col ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.footer-col li a {
  text-decoration: none;
  font-size: 0.875rem;
  color: rgba(255, 255, 255, 0.6);
  transition: color 0.2s;
}

.footer-col li a:hover {
  color: white;
}

.footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 28px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.footer-copy {
  font-size: 0.8rem;
  color: rgba(255, 255, 255, 0.35);
}

.footer-socials {
  display: flex;
  gap: 10px;
}

.social-link {
  width: 34px;
  height: 34px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-size: 0.82rem;
  color: rgba(255, 255, 255, 0.6);
  transition: all 0.2s;
}

.social-link:hover {
  background: #e63975;
  color: white;
  transform: translateY(-2px);
}

.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}

.reveal.in {
  opacity: 1;
  transform: none;
}


@media(max-width:600px) {
  nav {
    padding: 0 20px;
  }

  .container {
    padding: 0 20px;
  }

  .pillars-grid,
  .stats-inner {
    grid-template-columns: 1fr;
  }

  .footer-grid {
    grid-template-columns: 1fr;
  }

  .footer-bottom {
    flex-direction: column;
    gap: 14px;
  }

  .hero-inner {
    gap: 40px;
  }
}

/* ══════════════════════════════════════════
           NEW SECTIONS — SHARED TOKENS
           ══════════════════════════════════════════ */
:root {
  --green: #16a34a;
  --green-light: #dcfce7;
  --green-mid: #22c55e;
  --ink: #0d1a0f;
  --ink-muted: #4b5563;
  --surface: #f9fafb;
  --surface2: #f0fdf4;
  --border: #e5e7eb;
  --radius-lg: 20px;
  --radius-md: 12px;
  --radius-sm: 8px;
}

/* ── REVEAL ANIMATION ── */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .55s cubic-bezier(.22, 1, .36, 1), transform .55s cubic-bezier(.22, 1, .36, 1);
}

.reveal.in {
  opacity: 1;
  transform: none;
}

/* ── SHARED NEW TYPOGRAPHY ── */
.s-eyebrow {
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #0d1a0f;
  margin-bottom: 14px;
}

.s-h2 {
  font-family: 'DM Sans', sans-serif;
  font-size: clamp(2.2rem, 4.5vw, 3.6rem);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.03em;
  color: var(--ink);
  margin-bottom: 18px;
}

.s-h2 em {
  font-style: normal;
  color: var(--green);
}

.s-h3 {
  font-family: 'DM Sans', sans-serif;
  font-size: clamp(1.3rem, 2.5vw, 1.8rem);
  font-weight: 700;
  color: var(--ink);
}

.s-body {
  font-size: 1.05rem;
  color: var(--ink-muted);
  line-height: 1.7;
  max-width: 560px;
}

.s-btn-green {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--green);
  color: #fff;
  font-size: .95rem;
  font-weight: 700;
  padding: 14px 32px;
  border-radius: 50px;
  text-decoration: none;
  transition: all .25s;
  box-shadow: 0 4px 20px rgba(22, 163, 74, .3);
}

.s-btn-green:hover {
  background: #15803d;
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(22, 163, 74, .35);
}

.s-btn-outline {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  color: var(--ink);
  font-size: .95rem;
  font-weight: 700;
  padding: 13px 30px;
  border-radius: 50px;
  text-decoration: none;
  border: 2px solid var(--border);
  transition: all .25s;
}

.s-btn-outline:hover {
  border-color: var(--green);
  color: var(--green);
}

/* ══════════════════════════════
           1. COMMERCE IN YOUR CONTROL
           ══════════════════════════════ */
.s-control {
  background: #fff;
  padding: 120px 0 100px;
}

.s-control-inner {
  text-align: center;
  max-width: 880px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.s-control-inner .s-body {
  text-align: center;
  max-width: 600px;
  margin: 0 auto 48px;
}

.s-dashboard-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  width: 100%;
  max-width: 720px;
  margin-bottom: 40px;
  box-shadow: 0 8px 40px rgba(0, 0, 0, .07);
}

.sdc-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  background: #fff;
  border-bottom: 1px solid var(--border);
}

.sdc-dots {
  display: flex;
  gap: 6px;
}

.sdc-dots span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #e5e7eb;
}

.sdc-dots span:first-child {
  background: #f87171;
}

.sdc-dots span:nth-child(2) {
  background: #fbbf24;
}

.sdc-dots span:nth-child(3) {
  background: #34d399;
}

.sdc-title {
  font-size: .8rem;
  font-weight: 600;
  color: var(--ink-muted);
  flex: 1;
}

.sdc-badge {
  font-size: .72rem;
  font-weight: 700;
  color: #16a34a;
  background: var(--green-light);
  padding: 3px 10px;
  border-radius: 50px;
}

.sdc-body {
  padding: 24px;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 16px;
  align-items: start;
}

.sdc-metrics {
  grid-column: 1;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.sdc-metric {
  background: #fff;
  border-radius: var(--radius-sm);
  padding: 12px 14px;
  border: 1px solid var(--border);
  text-align: left;
}

.sdc-m-val {
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--ink);
}

.sdc-m-lbl {
  font-size: .72rem;
  color: var(--ink-muted);
  margin: 2px 0;
}

.sdc-m-up {
  font-size: .72rem;
  font-weight: 700;
  color: #16a34a;
}

.sdc-markets {
  grid-column: 2;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.sdc-mkt {
  font-size: .8rem;
  font-weight: 500;
  color: var(--ink);
  background: #fff;
  padding: 8px 12px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.s-live {
  font-size: .65rem;
  font-weight: 700;
  color: #16a34a;
  background: var(--green-light);
  padding: 2px 8px;
  border-radius: 20px;
}

.s-pending {
  font-size: .65rem;
  font-weight: 700;
  color: #d97706;
  background: #fef3c7;
  padding: 2px 8px;
  border-radius: 20px;
}

.s-soon {
  font-size: .65rem;
  font-weight: 700;
  color: #e63975;
  background: #fce7f3;
  padding: 2px 8px;
  border-radius: 20px;
}

.sdc-chart {
  grid-column: 3;
  display: flex;
  align-items: flex-end;
  height: 100%;
}

.sdc-bar-row {
  display: flex;
  align-items: flex-end;
  gap: 5px;
  width: 100%;
  height: 100px;
}

.sdc-bar {
  flex: 1;
  background: var(--green-light);
  border-radius: 4px 4px 0 0;
  transition: background .3s;
}

.sdc-bar:hover,
.s-active-bar {
  background: var(--green-mid);
}

/* ══════════════════════════════
           2. INTEGRATIONS
           ══════════════════════════════ */
.s-integrations {
  background: var(--surface);
  padding: 80px 0 40px;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

.s-logo-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
}

.s-logo-grid-7 {
  grid-template-columns: repeat(7, 1fr);
}

.s-logo-item {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 20px 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .3s cubic-bezier(.22, 1, .36, 1);
  cursor: default;
  min-height: 80px;
}

.s-logo-item:hover {
  border-color: var(--green);
  box-shadow: 0 0 0 1px rgba(22, 163, 74, .3), 0 4px 20px rgba(22, 163, 74, .15);
  transform: translateY(-3px);
  background: #fff;
}

.s-logo-item img {
  max-height: 36px;
  max-width: 110px;
  width: auto;
  object-fit: contain;
  filter: grayscale(100%) opacity(0.45);
  transition: filter .3s ease;
  display: block;
}

.s-logo-item:hover img {
  filter: grayscale(0%) opacity(1);
}

.s-logo-text {
  font-size: .88rem;
  font-weight: 700;
  color: #9ca3af;
  letter-spacing: .02em;
  transition: color .25s;
}

.s-logo-item:hover .s-logo-text {
  color: var(--green);
}

/* ══════════════════════════════
           3. FEATURE SHOWCASE
           ══════════════════════════════ */
.s-feature-showcase {
  background: #fff;
  padding: 120px 0;
}

.s-feature-inner {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 80px;
  align-items: center;
}

.s-mockup-shell {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0, 0, 0, .1);
}

.s-mockup-bar {
  background: #fff;
  border-bottom: 1px solid var(--border);
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
}

.s-mock-dots {
  display: flex;
  gap: 5px;
}

.s-mock-dots span {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #e5e7eb;
}

.s-mock-dots span:first-child {
  background: #f87171;
}

.s-mock-dots span:nth-child(2) {
  background: #fbbf24;
}

.s-mock-dots span:nth-child(3) {
  background: #34d399;
}

.s-mock-addr {
  font-size: .75rem;
  color: #9ca3af;
  background: var(--surface);
  border: 1px solid var(--border);
  padding: 4px 12px;
  border-radius: 6px;
  flex: 1;
  font-family: monospace;
}

.s-mockup-content {
  padding: 16px;
}

.s-mock-nav {
  display: flex;
  gap: 4px;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--border);
  padding-bottom: 12px;
}

.s-mock-nav-item {
  font-size: .78rem;
  font-weight: 600;
  color: var(--ink-muted);
  padding: 6px 12px;
  border-radius: 6px;
  cursor: pointer;
}

.s-mock-nav-item.active {
  background: var(--green-light);
  color: var(--green);
}

.s-mock-table-head {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  padding: 6px 10px;
  font-size: .68rem;
  font-weight: 700;
  color: #9ca3af;
  text-transform: uppercase;
  letter-spacing: .05em;
}

.s-mock-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  padding: 10px;
  border-radius: 8px;
  margin-bottom: 4px;
  font-size: .8rem;
  color: var(--ink);
  background: #fff;
  border: 1px solid var(--border);
  align-items: center;
}

.s-mock-row:hover {
  background: var(--surface2);
}

.s-tag-shipped {
  font-size: .68rem;
  font-weight: 700;
  color: #16a34a;
  background: var(--green-light);
  padding: 2px 8px;
  border-radius: 20px;
  display: inline-block;
}

.s-tag-processing {
  font-size: .68rem;
  font-weight: 700;
  color: #d97706;
  background: #fef3c7;
  padding: 2px 8px;
  border-radius: 20px;
  display: inline-block;
}

.s-tag-delivered {
  font-size: .68rem;
  font-weight: 700;
  color: #7c3aed;
  background: #ede9fe;
  padding: 2px 8px;
  border-radius: 20px;
  display: inline-block;
}

.s-feature-list {
  list-style: none;
  padding: 0;
  margin: 24px 0 32px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.s-feature-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: .95rem;
  color: var(--ink);
  line-height: 1.5;
}

.s-check {
  color: var(--green);
  font-weight: 700;
  font-size: 1rem;
  flex-shrink: 0;
  margin-top: 1px;
}

/* ══════════════════════════════
           4. PLATFORM MODULES
           ══════════════════════════════ */
.s-modules {
  background: var(--surface);
  padding: 120px 0;
}

.s-modules-header {
  text-align: center;
  max-width: 600px;
  margin: 0 auto 60px;
}

.s-modules-header .s-body {
  margin: 0 auto;
  text-align: center;
}

.s-modules-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.s-module-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 32px 28px;
  transition: all .3s;
}

.s-module-card:hover {
  box-shadow: 0 16px 48px rgba(0, 0, 0, .08);
  transform: translateY(-6px);
  border-color: transparent;
}

.s-mod-icon {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  margin-bottom: 20px;
}

.s-module-card h4 {
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--ink);
  margin-bottom: 10px;
}

.s-module-card p {
  font-size: .88rem;
  color: var(--ink-muted);
  line-height: 1.65;
  margin-bottom: 20px;
}

.s-mod-link {
  font-size: .82rem;
  font-weight: 700;
  color: var(--green);
  text-decoration: none;
}

.s-mod-link:hover {
  text-decoration: underline;
}

/* ══════════════════════════════
           5. METRICS
           ══════════════════════════════ */
.s-metrics {
  background: #fff;
  padding: 80px 0;
}

.s-metrics-label {
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #9ca3af;
  text-align: center;
  margin-bottom: 60px;
}

.s-metrics-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
}

.s-metric-block {
  padding: 48px 40px;
  text-align: center;
  border-right: 1px solid var(--border);
}

.s-metric-block:last-child {
  border-right: none;
}

.s-met-num {
  font-size: clamp(3.5rem, 7vw, 6rem);
  font-weight: 900;
  color: var(--ink);
  line-height: 1;
  margin-bottom: 14px;
}

.s-met-x,
.s-met-pct {
  font-size: .5em;
  font-weight: 700;
  color: var(--green);
  vertical-align: super;
}

.s-met-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 10px;
}

.s-met-desc {
  font-size: .85rem;
  color: var(--ink-muted);
  line-height: 1.6;
  max-width: 240px;
  margin: 0 auto;
}

.s-metrics-quotes {
  margin-top: 60px;
}

.s-quote-band {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  justify-content: center;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 50px;
  padding: 16px 24px;
}

.s-qb-item span {
  font-size: .82rem;
  font-weight: 600;
  color: var(--ink-muted);
  white-space: nowrap;
}

.s-qb-sep {
  font-size: .82rem;
  color: #d1d5db;
  padding: 0 12px;
  display: flex;
  align-items: center;
}

/* ══════════════════════════════
           6. PLATFORM DEMO CARDS
           ══════════════════════════════ */
.s-platform-demo {
  background: var(--surface2);
  padding: 120px 0;
}

.s-pd-header {
  text-align: center;
  max-width: 560px;
  margin: 0 auto 60px;
}

.s-pd-header .s-body {
  margin: 0 auto;
  text-align: center;
}

.s-pd-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}

.s-pd-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px;
}

.s-pd-card-top {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
  border-bottom: 1px solid var(--border);
  padding-bottom: 16px;
}

.s-pd-icon {
  font-size: 1.3rem;
}

.s-pd-card-title {
  font-size: .95rem;
  font-weight: 700;
  color: var(--ink);
}

/* order table */
.s-pd-mini-row {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  padding: 8px 0;
  font-size: .8rem;
  border-bottom: 1px solid var(--border);
  align-items: center;
}

.s-pd-mini-row.head {
  color: #9ca3af;
  font-weight: 700;
  font-size: .7rem;
  text-transform: uppercase;
}

.s-dot-green {
  color: #16a34a;
  font-size: .9rem;
}

.s-dot-amber {
  color: #d97706;
  font-size: .9rem;
}

/* product listing */
.s-pd-product {
  display: flex;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--border);
}

.s-pd-product:last-child {
  border-bottom: none;
}

.s-pd-prod-img {
  width: 44px;
  height: 44px;
  border-radius: 10px;
  background: var(--surface);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  flex-shrink: 0;
}

.s-pd-prod-name {
  font-size: .82rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 2px;
}

.s-pd-prod-channels {
  font-size: .72rem;
  color: var(--ink-muted);
  margin-bottom: 6px;
}

.s-pd-prog {
  height: 4px;
  background: var(--border);
  border-radius: 4px;
  overflow: hidden;
  margin-bottom: 4px;
}

.s-pd-prog-fill {
  height: 100%;
  background: var(--green-mid);
  border-radius: 4px;
}

.s-pd-prod-stat {
  font-size: .7rem;
  font-weight: 700;
  color: var(--green);
}

/* inventory */
.s-pd-inv-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
}

.s-pd-inv-row:last-child {
  border-bottom: none;
}

.s-pd-inv-loc {
  font-size: .78rem;
  font-weight: 600;
  color: var(--ink);
  width: 90px;
  flex-shrink: 0;
}

.s-pd-inv-bar {
  flex: 1;
  height: 6px;
  background: var(--border);
  border-radius: 4px;
  overflow: hidden;
}

.s-pd-inv-bar div {
  height: 100%;
  background: linear-gradient(90deg, var(--green-mid), #16a34a);
  border-radius: 4px;
}

.s-pd-inv-num {
  font-size: .78rem;
  font-weight: 700;
  color: var(--ink-muted);
  width: 42px;
  text-align: right;
  flex-shrink: 0;
}

/* shipping */
.s-pd-ship-item {
  padding: 12px 0;
  border-bottom: 1px solid var(--border);
}

.s-pd-ship-item:last-child {
  border-bottom: none;
}

.s-pd-ship-id {
  font-size: .72rem;
  font-weight: 700;
  color: var(--green);
  margin-bottom: 2px;
}

.s-pd-ship-dest {
  font-size: .8rem;
  color: var(--ink);
  font-weight: 600;
  margin-bottom: 10px;
}

.s-pd-ship-progress {
  display: flex;
  align-items: center;
  gap: 0;
}

.s-pd-ship-step {
  font-size: .65rem;
  font-weight: 600;
  color: #9ca3af;
  white-space: nowrap;
}

.s-pd-ship-step.done {
  color: var(--green);
}

.s-pd-ship-line {
  flex: 1;
  height: 2px;
  background: var(--border);
  margin: 0 6px;
}

.s-pd-ship-line.done {
  background: var(--green-mid);
}

/* ══════════════════════════════
           7. CUSTOMER BRANDS
           ══════════════════════════════ */
.s-brands {
  background: #fff;
  padding: 56px 0 120px;
}

.s-brands-header {
  text-align: center;
  max-width: 560px;
  margin: 0 auto 56px;
}

.s-brands-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.s-brand-card {
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--border);
  transition: all .3s;
}

.s-brand-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 50px rgba(0, 0, 0, .1);
}

.s-brand-img-placeholder {
  height: 180px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3rem;
}

.s-brand-content {
  padding: 24px;
}

.s-brand-name {
  font-size: .95rem;
  font-weight: 800;
  margin-bottom: 10px;
}

.s-brand-quote {
  font-size: .88rem;
  line-height: 1.65;
  margin-bottom: 14px;
  opacity: .85;
}

.s-brand-meta {
  font-size: .72rem;
  font-weight: 700;
  color: #9ca3af;
  text-transform: uppercase;
  letter-spacing: .06em;
}

/* ══════════════════════════════
           8. RESOURCES
           ══════════════════════════════ */
.s-resources {
  background: var(--surface);
  padding: 120px 0 80px;
}

.s-resources-header {
  text-align: center;
  max-width: 560px;
  margin: 0 auto 56px;
}

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

.s-res-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: all .3s;
}

.s-res-card:hover {
  box-shadow: 0 16px 40px rgba(0, 0, 0, .08);
  transform: translateY(-5px);
}

.s-res-thumb {
  height: 140px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
  overflow: hidden;
  padding: 0;
}

.s-res-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 0;
}

.s-res-content {
  padding: 20px;
}

.s-res-tag {
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 8px;
}

.s-res-content h4 {
  font-size: .92rem;
  font-weight: 800;
  color: var(--ink);
  margin-bottom: 8px;
  line-height: 1.3;
}

.s-res-content p {
  font-size: .8rem;
  color: var(--ink-muted);
  line-height: 1.6;
  margin-bottom: 14px;
}

.s-res-link {
  font-size: .82rem;
  font-weight: 700;
  color: var(--green);
  text-decoration: none;
}

.s-res-link:hover {
  text-decoration: underline;
}

/* ══════════════════════════════
           9. DEMO BOOKING
           ══════════════════════════════ */
.s-demo {
  background: linear-gradient(135deg, #14532d 0%, #16a34a 60%, #15803d 100%);
  padding: 120px 0;
  position: relative;
  overflow: hidden;
}

.s-demo::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 70% 50%, rgba(134, 239, 172, .2) 0%, transparent 60%);
}

.s-demo-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
  position: relative;
  z-index: 2;
}

.s-demo-left .s-body {
  max-width: 480px;
}

.s-demo-perks {
  margin-top: 28px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.s-demo-perk {
  font-size: .9rem;
  color: rgba(255, 255, 255, .85);
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 8px;
}

.s-demo-form {
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 36px 32px;
}

.s-demo-form h3 {
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--ink);
  margin-bottom: 6px;
}

.s-demo-form>p {
  font-size: .82rem;
  color: var(--ink-muted);
  margin-bottom: 24px;
}

.s-form-group {
  margin-bottom: 16px;
}

.s-form-group label {
  display: block;
  font-size: .8rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 6px;
}

.s-form-group input,
.s-form-group select {
  width: 100%;
  padding: 12px 14px;
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  font-family: 'DM Sans', sans-serif;
  font-size: .9rem;
  color: var(--ink);
  background: #fff;
  outline: none;
  transition: border-color .2s;
  -webkit-appearance: none;
}

.s-form-group input:focus,
.s-form-group select:focus {
  border-color: var(--green);
}

.s-form-submit {
  width: 100%;
  padding: 15px;
  background: var(--green);
  color: #fff;
  font-family: 'DM Sans', sans-serif;
  font-size: 1rem;
  font-weight: 700;
  border: none;
  border-radius: 50px;
  cursor: pointer;
  transition: all .25s;
  box-shadow: 0 4px 16px rgba(22, 163, 74, .3);
  margin-top: 8px;
}

.s-form-submit:hover {
  background: #15803d;
  transform: translateY(-2px);
}

/* ══════════════════════════════
           10. FOOTER
           ══════════════════════════════ */
.s-footer {
  background: #0d1a0f;
  padding: 80px 0 0;
  color: rgba(255, 255, 255, .65);
}

.s-footer-top {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 80px;
  padding-bottom: 60px;
  border-bottom: 1px solid rgba(255, 255, 255, .08);
}

.s-footer-brand p {
  font-size: .88rem;
  line-height: 1.7;
  color: rgba(255, 255, 255, .5);
}

.s-footer-socials {
  display: flex;
  gap: 10px;
  margin-top: 20px;
}

.s-social {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, .15);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, .5);
  text-decoration: none;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  transition: all .2s;
}

.s-social:hover {
  border-color: var(--green-mid);
  color: var(--green-mid);
}

.s-footer-cols {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 32px;
}

.s-footer-col h5 {
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #fff;
  margin-bottom: 16px;
}

.s-footer-col ul {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.s-footer-col ul a {
  font-size: .85rem;
  color: rgba(255, 255, 255, .5);
  text-decoration: none;
  transition: color .2s;
}

.s-footer-col ul a:hover {
  color: #fff;
}

.s-footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 0;
  font-size: .78rem;
  color: rgba(255, 255, 255, .3);
}

/* ══════════════════════════════
           RESPONSIVE
           ══════════════════════════════ */
@media (max-width: 1024px) {
  .sdc-body {
    grid-template-columns: 1fr 1fr;
  }

  .sdc-chart {
    display: none;
  }

  .s-logo-grid {
    grid-template-columns: repeat(4, 1fr);
  }

  .s-logo-grid-7 {
    grid-template-columns: repeat(4, 1fr);
  }

  .s-feature-inner {
    grid-template-columns: 1fr;
  }

  .s-modules-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .s-metrics-grid {
    grid-template-columns: 1fr;
  }

  .s-metric-block {
    border-right: none;
    border-bottom: 1px solid var(--border);
  }

  .s-metric-block:last-child {
    border-bottom: none;
  }

  .s-pd-grid {
    grid-template-columns: 1fr;
  }

  .s-brands-grid {
    grid-template-columns: 1fr 1fr;
  }

  .s-resources-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .s-demo-inner {
    grid-template-columns: 1fr;
  }

  .s-footer-top {
    grid-template-columns: 1fr;
  }

  .s-footer-cols {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 480px) {
  .s-logo-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .s-logo-grid-7 {
    grid-template-columns: repeat(2, 1fr);
  }

  .s-footer-cols {
    grid-template-columns: 1fr 1fr;
  }

  .s-footer-bottom {
    flex-direction: column;
    gap: 8px;
    text-align: center;
  }
}

/* ══════════════════════════════════════════
           SITE NAV — fully self-contained
           ══════════════════════════════════════════ */
.site-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 500;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 48px;
  height: 72px;
  background: #1a0f3c;
  border-bottom: 1px solid rgba(255, 255, 255, .08);
  transition: box-shadow .3s;
}

.nav-menu {
  display: flex;
  align-items: center;
  gap: 2px;
  list-style: none;
  padding: 0;
  margin: 0;
  flex: 1;
  justify-content: center;
}

.nav-item {
  position: relative;
}

.nav-trigger {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 8px 16px;
  font-size: .88rem;
  font-weight: 500;
  color: rgba(255, 255, 255, .75);
  text-decoration: none;
  border-radius: 8px;
  cursor: pointer;
  transition: background .18s, color .18s;
  white-space: nowrap;
  background: none;
  border: none;
  font-family: 'DM Sans', sans-serif;
  line-height: 1;
}

.nav-trigger:hover,
.nav-item:hover>.nav-trigger {
  background: rgba(255, 255, 255, .09);
  color: #fff;
}

.nav-trigger.active {
  color: #e63975;
  font-weight: 600;
}

.nav-trigger .chev {
  font-size: .57rem;
  opacity: .5;
  transition: transform .2s;
}

.nav-item:hover>.nav-trigger .chev {
  transform: rotate(180deg);
  opacity: .9;
}

.nav-right {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}

.btn-ghost-nav {
  text-decoration: none;
  color: #fff;
  font-size: .875rem;
  font-weight: 500;
  padding: 10px 24px;
  border-radius: 50px;
  border: 1.5px solid rgba(255, 255, 255, .22);
  transition: all .2s;
}

.btn-ghost-nav:hover {
  background: rgba(255, 255, 255, .1);
  border-color: rgba(255, 255, 255, .5);
}

.btn-pill-nav {
  text-decoration: none;
  color: #1a0f3c;
  font-size: .875rem;
  font-weight: 700;
  padding: 11px 26px;
  border-radius: 50px;
  background: #fff;
  transition: all .25s;
  box-shadow: 0 4px 14px rgba(0, 0, 0, .2);
}

.btn-pill-nav:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, .3);
}

/* Dropdown */
.nav-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  padding: 10px;
  box-shadow: 0 24px 64px rgba(0, 0, 0, .14);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(8px);
  transition: opacity .2s, transform .2s, visibility .2s;
  transition-delay: 0.12s;
  z-index: 600;
  min-width: 220px;
}

.nav-dropdown::before {
  content: "";
  position: absolute;
  top: -12px;
  left: 0;
  right: 0;
  height: 12px;
  background: transparent;
}

.nav-item:hover>.nav-dropdown {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
  transition-delay: 0s;
}

.nav-dropdown.wide {
  min-width: 720px;
  padding: 22px 18px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
}

.nav-dropdown.wide2 {
  min-width: 480px;
  padding: 18px 14px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
}

.ndp-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  text-decoration: none;
  transition: background .15s;
}

.ndp-item:hover {
  background: #f0fdf4;
}

.ndp-icon {
  width: 36px;
  height: 36px;
  background: #000;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.ndp-name {
  font-size: .84rem;
  font-weight: 700;
  color: #0d1a0f;
  margin-bottom: 1px;
}

.ndp-desc {
  font-size: .73rem;
  color: #6b7280;
  line-height: 1.35;
}

.ndp-simple a {
  display: block;
  padding: 9px 14px;
  font-size: .84rem;
  font-weight: 500;
  color: #374151;
  text-decoration: none;
  border-radius: 8px;
  transition: all .15s;
}

.ndp-simple a:hover {
  background: #f0fdf4;
  color: #16a34a;
  font-weight: 600;
}

.ndp-label {
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #9ca3af;
  padding: 4px 14px 8px;
  display: block;
}

.nav-hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  padding: 8px;
  background: none;
  border: none;
}

.nav-hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: #fff;
  border-radius: 2px;
}

@media (max-width: 1100px) {
  .nav-dropdown.wide {
    grid-template-columns: 1fr 1fr;
    min-width: 460px;
  }
}



/* ══════════════════════════════════════════════════════════
       SECTION-FAILURE — Live System Failure Narrative
       All classes are scoped to .section-failure or uniquely
       named to avoid conflicts with the base design system.
       ══════════════════════════════════════════════════════════ */

/* CSS tokens — all new names, safe to add globally */
:root {
  --sf-rose-500: #f43f5e;
  --sf-rose-400: #fb7185;
  --sf-rose-100: #ffe4e6;
  --sf-amber-500: #f59e0b;
  --sf-amber-400: #fbbf24;
  --sf-amber-100: #fef3c7;
  --sf-neutral-900: #0f0f10;
  --sf-neutral-800: #1c1c1e;
  --sf-neutral-700: #2c2c2e;
  --sf-neutral-500: #6b6b6e;
  --sf-neutral-400: #9a9a9e;
  --sf-neutral-200: #e5e5e8;
  --sf-neutral-100: #f4f4f6;
  --sf-panel-bg: rgba(255, 255, 255, 0.92);
  --sf-panel-border: rgba(0, 0, 0, 0.07);
  --sf-shadow-panel: 0 8px 40px rgba(0, 0, 0, 0.10), 0 2px 8px rgba(0, 0, 0, 0.06);
}

/* ── Section wrapper ── */
.section-failure {
  position: relative;
  overflow: hidden;
  padding: 96px 0 80px;
  background: linear-gradient(145deg,
      #e8f8f2 0%,
      #f0fdf8 18%,
      #ffffff 42%,
      #fff5f7 68%,
      #fce7eb 85%,
      #fde8ee 100%);
}

.section-failure::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

/* ── Scoped container (renamed sf-container to avoid base .container conflict) ── */
.sf-container {
  position: relative;
  z-index: 1;
  max-width: 1700px;
  margin: 0 auto;
  padding: 0 40px;
}

/* ── Eyebrow (scoped — base .eyebrow is defined but never used in HTML) ── */
.sf-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #ffffff;
  background: rgba(243, 52, 52, 0.72);
  border: 1px solid var(--sf-neutral-200);
  border-radius: 100px;
  padding: 5px 12px;
  margin-bottom: 28px;
  backdrop-filter: blur(8px);
}

.sf-eyebrow-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #ffffff;
  animation: sf-pulse-dot 2s ease-in-out infinite;
}

/* ── Section heading & subtext ── */
.section-failure .section-heading {
  font-family: 'DM Sans', sans-serif;
  font-size: clamp(32px, 4.1vw, 200px);
  font-weight: 800;
  line-height: 1.12;
  letter-spacing: -0.03em;
  color: var(--sf-neutral-900);
  margin-bottom: 20px;
  max-width: 7000px;
}

.section-failure .section-heading .highlight {
  color: var(--sf-rose-500);
}

.section-failure .section-subtext {
  font-family: 'DM Sans', sans-serif;
  font-size: 18px;
  line-height: 1.7;
  color: var(--sf-neutral-500);
  max-width: 1000px;
  margin-bottom: 56px;
}

.section-failure .section-subtext strong {
  color: var(--sf-neutral-700);
  font-weight: 600;
}

/* ── Two-column grid ── */
.grid-two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

/* ── Problem cards (left) ── */
.problem-cards {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.problem-card {
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid var(--sf-panel-border);
  border-radius: 16px;
  padding: 24px 24px 24px 20px;
  display: grid;
  grid-template-columns: 48px 1fr;
  grid-template-rows: auto auto;
  column-gap: 16px;
  row-gap: 0;
  backdrop-filter: blur(12px);
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
  cursor: default;
}

.problem-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.09);
  border-color: rgba(0, 0, 0, 0.12);
}

.card-icon-wrap {
  grid-row: 1 / 3;
  grid-column: 1;
  display: flex;
  align-items: flex-start;
  padding-top: 2px;
}

.card-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: var(--sf-neutral-900);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.card-icon svg {
  width: 18px;
  height: 18px;
  stroke: #fff;
  fill: none;
  stroke-width: 1.6;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.card-number {
  grid-column: 1;
  grid-row: 2;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--sf-neutral-400);
  text-align: center;
  margin-top: 8px;
}

.card-title {
  grid-column: 2;
  grid-row: 1;
  font-family: 'DM Sans', sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: var(--sf-neutral-900);
  margin-bottom: 6px;
  letter-spacing: -0.01em;
}

.card-desc {
  grid-column: 2;
  grid-row: 2;
  font-family: 'DM Sans', sans-serif;
  font-size: 13.5px;
  line-height: 1.6;
  color: var(--sf-neutral-500);
}

/* ── Animated panels wrapper (right) ── */
.panels-wrap {
  position: relative;
  height: 510px;
}

/* Keyframes — all prefixed sf- to avoid any potential collision */
@keyframes sf-float-a {

  0%,
  100% {
    transform: translateY(0px) rotate(0deg);
  }

  33% {
    transform: translateY(-8px) rotate(0.3deg);
  }

  66% {
    transform: translateY(-4px) rotate(-0.2deg);
  }
}

@keyframes sf-float-b {

  0%,
  100% {
    transform: translateY(0px) rotate(0deg);
  }

  33% {
    transform: translateY(-5px) rotate(-0.4deg);
  }

  66% {
    transform: translateY(-10px) rotate(0.2deg);
  }
}

@keyframes sf-float-c {

  0%,
  100% {
    transform: translateY(0px) rotate(0deg);
  }

  40% {
    transform: translateY(-7px) rotate(0.25deg);
  }

  70% {
    transform: translateY(-3px) rotate(-0.3deg);
  }
}

@keyframes sf-fade-up {
  from {
    opacity: 0;
    transform: translateY(12px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes sf-badge-pop {
  0% {
    opacity: 0;
    transform: scale(0.7);
  }

  70% {
    transform: scale(1.08);
  }

  100% {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes sf-bar-drop {
  from {
    transform: scaleY(0);
    opacity: 0;
  }

  to {
    transform: scaleY(1);
    opacity: 1;
  }
}

@keyframes sf-pulse-amber {

  0%,
  100% {
    box-shadow: 0 0 0 0 rgba(245, 158, 11, 0.5);
  }

  50% {
    box-shadow: 0 0 0 5px rgba(245, 158, 11, 0);
  }
}

@keyframes sf-pulse-rose {

  0%,
  100% {
    box-shadow: 0 0 0 0 rgba(244, 63, 94, 0.4);
  }

  50% {
    box-shadow: 0 0 0 5px rgba(244, 63, 94, 0);
  }
}

@keyframes sf-progress-stall {
  0% {
    width: 0%;
  }

  30% {
    width: 38%;
  }

  60% {
    width: 40%;
  }

  80% {
    width: 41%;
  }

  100% {
    width: 42%;
  }
}

@keyframes sf-pulse-dot {

  0%,
  100% {
    opacity: 1;
    transform: scale(1);
  }

  50% {
    opacity: 0.5;
    transform: scale(0.75);
  }
}

/* ── Panel base ── */
.sf-panel {
  position: absolute;
  background: var(--sf-panel-bg);
  border: 1px solid var(--sf-panel-border);
  border-radius: 18px;
  box-shadow: var(--sf-shadow-panel);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  overflow: hidden;
}

/* ── Panel 1: Shipment ── */
.sf-panel-shipment {
  top: 0;
  left: 0;
  right: 0;
  padding: 20px 22px;
  animation: sf-float-a 7s ease-in-out infinite;
  z-index: 3;
}

.sf-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}

.sf-panel-title-group {
  display: flex;
  align-items: center;
  gap: 10px;
}

.sf-panel-icon-sm {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  background: var(--sf-neutral-900);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.sf-panel-icon-sm svg {
  width: 14px;
  height: 14px;
  stroke: #fff;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.sf-panel-label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--sf-neutral-400);
  margin-bottom: 2px;
}

.sf-panel-id {
  font-size: 13px;
  font-weight: 700;
  color: var(--sf-neutral-900);
  letter-spacing: -0.01em;
}

/* ── Badges ── */
.sf-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 100px;
  animation: sf-badge-pop 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

.sf-badge-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
}

.sf-badge-rose {
  background: var(--sf-rose-100);
  color: var(--sf-rose-500);
}

.sf-badge-rose .sf-badge-dot {
  background: var(--sf-rose-500);
  animation: sf-pulse-rose 1.8s ease-in-out infinite;
}

.sf-badge-blocked {
  background: #fff0f3;
  color: var(--sf-rose-500);
  border: 1px solid rgba(244, 63, 94, 0.15);
  animation: sf-badge-pop 0.4s 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

.sf-badge-blocked .sf-badge-dot {
  background: var(--sf-rose-500);
  animation: sf-pulse-rose 1.8s ease-in-out infinite;
}

.sf-badge-pending {
  background: var(--sf-amber-100);
  color: #92400e;
  border: 1px solid rgba(245, 158, 11, 0.2);
  animation: sf-badge-pop 0.4s 0.75s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

.sf-badge-pending .sf-badge-dot {
  background: var(--sf-amber-500);
  animation: sf-pulse-amber 1.8s ease-in-out infinite;
}

.sf-badge-rejected {
  background: #fff0f3;
  color: var(--sf-rose-500);
  border: 1px solid rgba(244, 63, 94, 0.15);
  animation: sf-badge-pop 0.4s 0.9s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

.sf-badge-atrisk {
  background: var(--sf-amber-100);
  color: #92400e;
  border: 1px solid rgba(245, 158, 11, 0.2);
  animation: sf-badge-pop 0.4s 1.05s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

.sf-badge-atrisk .sf-badge-dot {
  background: var(--sf-amber-500);
  animation: sf-pulse-amber 1.8s ease-in-out infinite;
}

/* ── Progress bar (shipment) ── */
.sf-progress-track {
  position: relative;
  height: 4px;
  background: var(--sf-neutral-200);
  border-radius: 100px;
  margin-bottom: 10px;
  overflow: hidden;
}

.sf-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--sf-amber-400), var(--sf-rose-400));
  border-radius: 100px;
  animation: sf-progress-stall 3.5s ease-out forwards;
}

/* ── Shipment steps (renamed sf-step to avoid base .step conflict) ── */
.sf-steps-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
}

.sf-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  animation: sf-fade-up 0.4s ease both;
}

.sf-step:nth-child(1) {
  animation-delay: 0.1s;
}

.sf-step:nth-child(2) {
  animation-delay: 0.25s;
}

.sf-step:nth-child(3) {
  animation-delay: 0.4s;
}

.sf-step:nth-child(4) {
  animation-delay: 0.55s;
}

.sf-step-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 2px solid var(--sf-neutral-200);
  background: #ffffff;
  position: relative;
}

.sf-step-dot.done {
  background: var(--sf-amber-400);
  border-color: var(--sf-amber-400);
}

.sf-step-dot.active {
  background: var(--sf-amber-400);
  border-color: var(--sf-amber-400);
  animation: sf-pulse-amber 1.8s ease-in-out infinite;
}

.sf-step-dot.warning {
  background: var(--sf-rose-400);
  border-color: var(--sf-rose-400);
  animation: sf-pulse-rose 1.6s ease-in-out infinite;
}

.sf-step-label {
  font-size: 10px;
  color: var(--sf-neutral-400);
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
}

.sf-step-label.active-label {
  color: var(--sf-amber-500);
  font-weight: 700;
}

.sf-step-label.warning-label {
  color: var(--sf-rose-500);
  font-weight: 700;
}

/* ── Panel 2: Compliance Engine ── */
.sf-panel-compliance {
  top: 120px;
  left: 48px;
  right: 0;
  padding: 20px 22px;
  animation: sf-float-b 9s ease-in-out 1s infinite;
  z-index: 2;
}

.sf-comp-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}

.sf-comp-title-group {
  display: flex;
  align-items: center;
  gap: 10px;
}

.sf-comp-icon {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  background: #fff0f3;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(244, 63, 94, 0.15);
}

.sf-comp-icon svg {
  width: 14px;
  height: 14px;
  stroke: var(--sf-rose-500);
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.sf-comp-name {
  font-size: 13px;
  font-weight: 700;
  color: var(--sf-neutral-900);
}

.sf-comp-subtitle {
  font-size: 11px;
  color: var(--sf-rose-500);
  font-weight: 500;
}

.sf-comp-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 0;
  border-top: 1px solid var(--sf-neutral-100);
  animation: sf-fade-up 0.5s ease both;
}

.sf-comp-row:nth-child(2) {
  animation-delay: 0.15s;
}

.sf-comp-row:nth-child(3) {
  animation-delay: 0.30s;
}

.sf-comp-row:nth-child(4) {
  animation-delay: 0.45s;
}

.sf-comp-row-left {
  display: flex;
  align-items: center;
  gap: 10px;
}

.sf-comp-row-icon {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  background: var(--sf-neutral-100);
  flex-shrink: 0;
}

.sf-comp-row-icon svg {
  width: 12px;
  height: 12px;
  stroke: var(--sf-neutral-500);
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.sf-comp-row-title {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--sf-neutral-800);
}

.sf-comp-row-sub {
  font-size: 11px;
  color: var(--sf-neutral-400);
  margin-top: 1px;
}

/* ── Panel 3: KPI card (dark) ── */
.sf-panel-kpi {
  top: 310px;
  left: 20px;
  width: 220px;
  padding: 18px 20px;
  background: rgba(15, 15, 16, 0.94);
  border-color: rgba(255, 255, 255, 0.08);
  animation: sf-float-c 8s ease-in-out 0.5s infinite;
  z-index: 4;
}

.sf-kpi-label {
  font-size: 9.5px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.35);
  margin-bottom: 4px;
}

.sf-kpi-value-row {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 12px;
}

.sf-kpi-value {
  font-size: 26px;
  font-weight: 800;
  color: var(--sf-rose-400);
  letter-spacing: -0.03em;
  animation: sf-fade-up 0.6s 0.2s ease both;
}

.sf-kpi-delta {
  font-size: 12px;
  font-weight: 600;
  color: var(--sf-rose-400);
  background: rgba(244, 63, 94, 0.15);
  border-radius: 6px;
  padding: 2px 6px;
  animation: sf-badge-pop 0.4s 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

.sf-bar-chart {
  display: flex;
  align-items: flex-end;
  gap: 5px;
  height: 44px;
  margin-bottom: 10px;
}

.sf-bar {
  flex: 1;
  border-radius: 3px 3px 0 0;
  transform-origin: bottom;
  animation: sf-bar-drop 0.5s ease both;
}

.sf-bar:nth-child(1) {
  animation-delay: 0.10s;
  height: 82%;
  background: rgba(244, 63, 94, 0.55);
}

.sf-bar:nth-child(2) {
  animation-delay: 0.18s;
  height: 76%;
  background: rgba(244, 63, 94, 0.60);
}

.sf-bar:nth-child(3) {
  animation-delay: 0.26s;
  height: 68%;
  background: rgba(244, 63, 94, 0.65);
}

.sf-bar:nth-child(4) {
  animation-delay: 0.34s;
  height: 60%;
  background: rgba(244, 63, 94, 0.70);
}

.sf-bar:nth-child(5) {
  animation-delay: 0.42s;
  height: 52%;
  background: rgba(244, 63, 94, 0.75);
}

.sf-bar:nth-child(6) {
  animation-delay: 0.50s;
  height: 42%;
  background: rgba(244, 63, 94, 0.80);
}

.sf-bar:nth-child(7) {
  animation-delay: 0.58s;
  height: 32%;
  background: rgba(244, 63, 94, 0.85);
}

.sf-bar:nth-child(8) {
  animation-delay: 0.66s;
  height: 22%;
  background: var(--sf-rose-400);
}

.sf-bar:nth-child(9) {
  animation-delay: 0.74s;
  height: 14%;
  background: var(--sf-rose-400);
}

.sf-kpi-markets {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.sf-kpi-market-tags {
  display: flex;
  gap: 5px;
}

.sf-market-tag {
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: rgba(255, 255, 255, 0.35);
}

.sf-kpi-unreconciled {
  font-size: 9px;
  font-weight: 500;
  color: rgba(244, 63, 94, 0.7);
  display: flex;
  align-items: center;
  gap: 4px;
}

.sf-kpi-unreconciled svg {
  width: 9px;
  height: 9px;
  stroke: rgba(244, 63, 94, 0.7);
  fill: none;
  stroke-width: 2;
}

/* ── Responsive ── */



/* ══════════════════════════════════════════════════════════
       EXEC-SWAP SECTION — Scroll-driven card stack
       All classes prefixed exec- to avoid any conflicts.
       ══════════════════════════════════════════════════════════ */

/* ── Section shell ── */
#exec-swap-section {
  position: relative;
  background: #fff !important;
  margin: 0 !important;
  padding: 0 !important;
  /* height set inline by JS once DOM is ready */
}

/* ── Sticky viewport ── */
.exec-sticky {
  position: sticky;
  top: 0;
  height: 100vh;
  min-height: 600px;
  overflow: hidden;
  display: flex;
  align-items: stretch;
  background: #fff;
}

/* ── Inner layout ── */
.exec-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
  width: 100%;
  max-width: 1700px;
  margin: 0 auto;
  padding: 0 40px;
}

/* ── LEFT: Text side ── */
.exec-left {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.exec-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #0d1a0f;
  margin-bottom: 20px;
}

.exec-eyebrow-pip {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #16a34a;
  animation: exec-pip-pulse 2.4s ease-in-out infinite;
}

@keyframes exec-pip-pulse {

  0%,
  100% {
    transform: scale(1);
    opacity: 1;
  }

  50% {
    transform: scale(0.65);
    opacity: 0.5;
  }
}

.exec-heading {
  font-family: 'DM Sans', sans-serif;
  font-size: clamp(5rem, 1vw, 1rem);
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -0.03em;
  color: #0d1a0f;
  margin-bottom: 20px;
}

.exec-heading em {
  font-style: normal;
  color: #16a34a;
}

.exec-subtext {
  font-family: 'DM Sans', sans-serif;
  font-size: 1.05rem;
  line-height: 1.7;
  color: #4b5563;
  max-width: 420px;
  margin-bottom: 28px;
}

/* ── Points list ── */
.exec-points {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 32px;
}

.exec-points li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.95rem;
  font-weight: 600;
  color: #0d1a0f;
}

.exec-check {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #dcfce7;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.exec-check svg {
  width: 10px;
  height: 10px;
  stroke: #16a34a;
  fill: none;
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.exec-closing {
  font-size: 0.95rem;
  font-style: italic;
  color: #6b7280;
  padding-left: 4px;
  border-left: 3px solid #16a34a;
  padding-left: 12px;
}

/* ── Scroll progress bar ── */
.exec-progress-track {
  margin-top: 28px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.exec-progress-bar {
  flex: 1;
  height: 3px;
  background: #e5e7eb;
  border-radius: 100px;
  overflow: hidden;
  max-width: 200px;
}

.exec-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, #16a34a, #22c55e);
  border-radius: 100px;
  width: 0%;
  transition: width 0.15s ease;
}

.exec-progress-label {
  font-size: 0.72rem;
  font-weight: 600;
  color: #9ca3af;
  letter-spacing: 0.06em;
}

/* ── RIGHT: Card stack ── */
.exec-right {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
}

.exec-cards-stage {
  position: relative;
  width: 100%;
  max-width: 460px;
  height: 340px;
}

/* ── Individual card ── */
.exec-card {
  position: absolute;
  inset: 0;
  border-radius: 20px;
  padding: 32px 36px;
  border: 1px solid rgba(0, 0, 0, 0.06);
  box-shadow: 0 8px 40px rgba(0, 0, 0, 0.07), 0 2px 8px rgba(0, 0, 0, 0.04);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  will-change: transform, opacity;
  /* JS sets initial transforms */
}

/* Per-card tint backgrounds */
.exec-card[data-card="0"] {
  background: linear-gradient(135deg, #f0fdf4 0%, #ffffff 100%);
}

.exec-card[data-card="1"] {
  background: linear-gradient(135deg, #eff6ff 0%, #ffffff 100%);
}

.exec-card[data-card="2"] {
  background: linear-gradient(135deg, #fffbeb 0%, #ffffff 100%);
}

.exec-card[data-card="3"] {
  background: linear-gradient(135deg, #faf5ff 0%, #ffffff 100%);
}

.exec-card[data-card="4"] {
  background: linear-gradient(135deg, #fff1f2 0%, #ffffff 100%);
}

/* ── Card inner parts ── */
.exec-card-top {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.exec-card-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 1.3rem;
}

.exec-card-icon.green {
  background: #dcfce7;
}

.exec-card-icon.blue {
  background: #dbeafe;
}

.exec-card-icon.amber {
  background: #fef3c7;
}

.exec-card-icon.purple {
  background: #ede9fe;
}

.exec-card-icon.rose {
  background: #ffe4e6;
}

.exec-card-meta {
  flex: 1;
}

.exec-card-step {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #9ca3af;
  margin-bottom: 4px;
}

.exec-card-title {
  font-family: 'DM Sans', sans-serif;
  font-size: 1.25rem;
  font-weight: 800;
  color: #0d1a0f;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.exec-card-body {
  font-size: 0.88rem;
  line-height: 1.65;
  color: #4b5563;
  margin-top: 16px;
}

/* ── Status chips at bottom of card ── */
.exec-card-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 20px;
}

.exec-card-chips {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.exec-chip {
  font-size: 0.68rem;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 100px;
  letter-spacing: 0.04em;
}

.exec-chip.green {
  background: #dcfce7;
  color: #15803d;
}

.exec-chip.blue {
  background: #dbeafe;
  color: #1d4ed8;
}

.exec-chip.amber {
  background: #fef3c7;
  color: #92400e;
}

.exec-chip.purple {
  background: #ede9fe;
  color: #6d28d9;
}

.exec-chip.rose {
  background: #ffe4e6;
  color: #be123c;
}

.exec-chip.neutral {
  background: #f3f4f6;
  color: #6b7280;
}

.exec-card-num {
  font-size: 2.4rem;
  font-weight: 800;
  opacity: 0.06;
  color: #0d1a0f;
  letter-spacing: -0.06em;
  line-height: 1;
  flex-shrink: 0;
}

/* ── Shadow cards (depth behind) ── */
.exec-shadow-card {
  position: absolute;
  inset: 0;
  border-radius: 20px;
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.05);
  pointer-events: none;
}

.exec-shadow-card-1 {
  transform: translateY(10px) scale(0.97);
  opacity: 0.55;
  z-index: 0;
}

.exec-shadow-card-2 {
  transform: translateY(20px) scale(0.94);
  opacity: 0.3;
  z-index: -1;
}

/* ── Idle float animation (active card only) ── */
@keyframes exec-float-idle {

  0%,
  100% {
    transform: translateY(0) scale(1);
  }

  50% {
    transform: translateY(-6px) scale(1.005);
  }
}

.exec-card.is-idle {
  animation: exec-float-idle 4s ease-in-out infinite;
}

/* ── Responsive ── */


/* ── HERO PAGE SWITCH ── */
.hero-page-switch {
  display: inline-flex;
  align-items: center;
  position: absolute;
  top: 80px;
  left: 24px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 999px;
  padding: 4px;
  gap: 0;
  z-index: 20;
}

.hps-tab {
  display: inline-flex;
  align-items: center;
  padding: 9px 24px;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  color: rgba(255, 255, 255, 0.38);
  transition: color 0.3s ease;
  white-space: nowrap;
}

.hps-tab:not(.active):hover {
  color: rgba(255, 255, 255, 0.7);
}

.hps-tab.active {
  color: #fff;
  background: linear-gradient(135deg, #e63975 0%, #b5174a 100%);
  box-shadow:
    0 0 18px rgba(230, 57, 117, 0.55),
    0 4px 12px rgba(230, 57, 117, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
  animation: hps-pulse 2.8s ease-in-out infinite;
}

@keyframes hps-pulse {

  0%,
  100% {
    box-shadow:
      0 0 18px rgba(230, 57, 117, 0.55),
      0 4px 12px rgba(230, 57, 117, 0.3),
      inset 0 1px 0 rgba(255, 255, 255, 0.18);
  }

  50% {
    box-shadow:
      0 0 32px rgba(230, 57, 117, 0.8),
      0 0 60px rgba(230, 57, 117, 0.2),
      0 4px 12px rgba(230, 57, 117, 0.35),
      inset 0 1px 0 rgba(255, 255, 255, 0.18);
  }
}


/* ── UNIFIED OPS SECTION ── */
.unified-ops {
  background: #fff;
  padding: 80px 0 100px;
  margin-top: 0 !important;
}

.unified-tabs {
  display: flex;
  gap: 0;
  background: #f7f6f3;
  border-radius: 16px;
  padding: 6px;
  margin-bottom: 56px;
  max-width: 900px;
}

.utab {
  flex: 1;
  padding: 14px 20px;
  border-radius: 12px;
  font-size: .9rem;
  font-weight: 700;
  color: #5a5080;
  cursor: pointer;
  text-align: center;
  transition: all .25s;
  border: none;
  background: transparent;
  font-family: 'DM Sans', sans-serif;
}

.utab.active {
  background: #fff;
  color: #1a0f3c;
  box-shadow: 0 2px 12px rgba(0, 0, 0, .08);
}

.utab-panel {
  display: none;
}

.utab-panel.active {
  display: block;
}

/* ═══════════════════════════════════════════════
           PREMIUM CARD HOVER SYSTEM — Brand Gradient
           ═══════════════════════════════════════════════ */

/* ── Base state: clean white, smooth transition on everything ── */
.brand-feature,
.s-module-card {
  position: relative;
  isolation: isolate;
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 20px;
  transition:
    transform .32s cubic-bezier(.22, 1, .36, 1),
    box-shadow .32s cubic-bezier(.22, 1, .36, 1),
    background .32s ease,
    border-color .32s ease,
    opacity .28s ease;
}

/* Pseudo-element holds the gradient overlay — fades in on hover */
.brand-feature::before,
.s-module-card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  opacity: 0;
  transition: opacity .38s cubic-bezier(.22, 1, .36, 1);
  pointer-events: none;
  z-index: 0;
}

/* All children sit above the gradient layer */
.brand-feature>*,
.s-module-card>* {
  position: relative;
  z-index: 1;
}

/* ── GRID DIMMING: sibling cards fade when any card is hovered ── */
.brand-features:hover .brand-feature,
.s-modules-grid:hover .s-module-card {
  opacity: 0.42;
  transform: scale(0.982);
}

/* ── THE HOVERED CARD: lift + gradient border + shadow ── */
.brand-features:hover .brand-feature:hover,
.s-modules-grid:hover .s-module-card:hover {
  opacity: 1;
  transform: translateY(-6px) scale(1.012);
  box-shadow:
    0 0 0 1px rgba(22, 163, 74, .35),
    0 4px 24px rgba(22, 163, 74, .18),
    0 12px 40px rgba(22, 163, 74, .10),
    0 20px 60px rgba(26, 15, 60, .06);
  /* Gradient border via padding-box / border-box trick */
  background:
    linear-gradient(#fff, #fff) padding-box,
    linear-gradient(135deg, #e63975, #1a0f3c) border-box;
  border: 1px solid transparent;
  z-index: 3;
}

/* Subtle gradient wash fades in on the hovered card */
.brand-features:hover .brand-feature:hover::before,
.s-modules-grid:hover .s-module-card:hover::before {
  opacity: 1;
}

/* ── GRADIENT WASH VARIANTS: rotate through brand palette ── */
.brand-feature:nth-child(odd)::before {
  background: linear-gradient(145deg,
      rgba(230, 57, 117, .05) 0%,
      rgba(26, 15, 60, .04) 60%,
      rgba(255, 255, 255, 0) 100%);
}

.brand-feature:nth-child(even)::before {
  background: linear-gradient(145deg,
      rgba(23, 71, 74, .06) 0%,
      rgba(230, 57, 117, .03) 70%,
      rgba(255, 255, 255, 0) 100%);
}

.s-module-card::before {
  background: linear-gradient(145deg,
      rgba(230, 57, 117, .05) 0%,
      rgba(26, 15, 60, .04) 60%,
      rgba(255, 255, 255, 0) 100%);
}

/* ── ICON GLOW on hovered card ── */
.brand-features:hover .brand-feature:hover .bf-icon,
.s-modules-grid:hover .s-module-card:hover .s-mod-icon {
  transform: scale(1.08) translateY(-2px);
  filter: brightness(1.08) saturate(1.15);
  box-shadow: 0 6px 20px rgba(230, 57, 117, .18);
  transition: transform .28s cubic-bezier(.22, 1, .36, 1), filter .28s ease, box-shadow .28s ease;
}

.bf-icon,
.s-mod-icon {
  transition: transform .3s ease, filter .3s ease, box-shadow .3s ease;
}

/* ── HEADING subtle darkening on hover ── */
.brand-features:hover .brand-feature:hover .bf-text h4,
.s-modules-grid:hover .s-module-card:hover h4 {
  color: #1a0f3c;
  transition: color .22s ease;
}

/* ── Dark navy card (Full Brand Representation) — special treatment ── */
.brand-features .brand-feature[style*="linear-gradient(135deg,#1a0f3c"] {
  transition: transform .32s cubic-bezier(.22, 1, .36, 1), box-shadow .32s ease, opacity .28s ease;
}

.brand-features:hover .brand-feature[style*="linear-gradient(135deg,#1a0f3c"] {
  opacity: 0.65;
}

.brand-features:hover .brand-feature[style*="linear-gradient(135deg,#1a0f3c"]:hover {
  opacity: 1;
  transform: translateY(-6px) scale(1.012);
  background: linear-gradient(135deg, #1a0f3c, #2d1b6e) !important;
  border: 1px solid rgba(230, 57, 117, .35) !important;
  box-shadow:
    0 2px 0 0 rgba(230, 57, 117, .4),
    0 20px 60px rgba(10, 5, 30, .35);
}

.brand-feature[style*="linear-gradient(135deg,#1a0f3c"]::before {
  background: linear-gradient(145deg,
      rgba(230, 57, 117, .14) 0%,
      rgba(255, 255, 255, .02) 100%);
}

/* ── OPS MODAL ── */
.ops-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(10, 5, 30, .6);
  z-index: 9000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s ease;
  backdrop-filter: blur(4px);
}

.ops-modal-overlay.open {
  opacity: 1;
  pointer-events: all;
}

.ops-modal {
  background: #fff;
  border-radius: 28px;
  width: 92vw;
  max-width: 1000px;
  max-height: 90vh;
  overflow-y: auto;
  padding: 0;
  position: relative;
  transform: translateY(32px) scale(.97);
  transition: transform .35s cubic-bezier(.22, 1, .36, 1);
  box-shadow: 0 40px 100px rgba(0, 0, 0, .25);
}

.ops-modal-overlay.open .ops-modal {
  transform: translateY(0) scale(1);
}

.ops-modal-header {
  position: sticky;
  top: 0;
  background: #fff;
  border-bottom: 1px solid #eee;
  padding: 24px 36px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  z-index: 10;
  border-radius: 28px 28px 0 0;
}

.ops-modal-header h3 {
  font-family: 'DM Sans', sans-serif;
  font-size: 1.3rem;
  font-weight: 800;
  color: #1a0f3c;
}

.ops-modal-close {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #f7f6f3;
  border: none;
  cursor: pointer;
  font-size: 1.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s;
}

.ops-modal-close:hover {
  background: #fce7f3;
}

.ops-modal-body {
  padding: 36px;
}

/* Modal tabs */
.modal-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 40px;
  flex-wrap: wrap;
}

.mtab {
  padding: 10px 20px;
  border-radius: 50px;
  font-size: .85rem;
  font-weight: 700;
  cursor: pointer;
  transition: all .2s;
  border: 2px solid transparent;
  background: #f7f6f3;
  color: #5a5080;
  font-family: 'DM Sans', sans-serif;
}

.mtab.active {
  background: #1a0f3c;
  color: #fff;
}

.mtab-panel {
  display: none;
}

.mtab-panel.active {
  display: block;
}

/* Detail cards in modal */
.modal-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}

@media(max-width:640px) {
  .modal-detail-grid {
    grid-template-columns: 1fr;
  }
}

.mdc {
  border-radius: 18px;
  padding: 28px;
  border: 1px solid rgba(0, 0, 0, .07);
}

.mdc-icon {
  font-size: 1.8rem;
  margin-bottom: 14px;
  display: block;
}

.mdc h4 {
  font-size: 1rem;
  font-weight: 800;
  color: #1a0f3c;
  margin-bottom: 8px;
}

.mdc p {
  font-size: .88rem;
  color: #5a5080;
  line-height: 1.7;
}

.mdc ul {
  margin: 10px 0 0 0;
  padding-left: 18px;
}

.mdc ul li {
  font-size: .85rem;
  color: #5a5080;
  line-height: 1.7;
}

.modal-hero-banner {
  background: linear-gradient(135deg, #1a0f3c 0%, #2d1b6e 50%, #17474a 100%);
  border-radius: 20px;
  padding: 36px;
  margin-bottom: 32px;
  color: #fff;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
}

.modal-hero-banner h4 {
  font-size: 1.4rem;
  font-weight: 800;
  margin-bottom: 8px;
}

.modal-hero-banner p {
  font-size: .92rem;
  color: rgba(255, 255, 255, .8);
  line-height: 1.7;
  max-width: 560px;
}

.modal-stats {
  display: flex;
  gap: 28px;
  flex-wrap: wrap;
}

.modal-stat {
  text-align: center;
}

.modal-stat-num {
  font-size: 2rem;
  font-weight: 900;
  color: #6ee7b7;
  line-height: 1;
}

.modal-stat-lbl {
  font-size: .72rem;
  color: rgba(255, 255, 255, .65);
  margin-top: 4px;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.modal-section-heading {
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #e63975;
  margin: 32px 0 16px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.modal-section-heading::after {
  content: '';
  flex: 1;
  height: 1px;
  background: #f0eef8;
}

/* Journey timeline in modal */
.journey-timeline {
  display: flex;
  gap: 0;
  margin: 28px 0 36px;
  overflow-x: auto;
}

.jt-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
  min-width: 100px;
}

.jt-dot {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  margin-bottom: 10px;
  flex-shrink: 0;
}

.jt-line {
  flex: 1;
  height: 2px;
  background: linear-gradient(90deg, #22c55e, #17474a);
  margin: 24px -1px 0;
  align-self: flex-start;
}

.jt-label {
  font-size: .75rem;
  font-weight: 700;
  color: #1a0f3c;
  text-align: center;
}

.jt-sub {
  font-size: .68rem;
  color: #5a5080;
  text-align: center;
  margin-top: 3px;
}

@media (max-width: 900px) {

  .nav-center {
    display: none;
  }

  .hero-inner,
  .split-section {
    grid-template-columns: 1fr;
  }

  .pillars-grid,
  .steps-grid {
    grid-template-columns: 1fr 1fr;
  }

  .steps-grid::before {
    display: none;
  }

  .stats-inner {
    grid-template-columns: 1fr 1fr;
  }

  .stat-item {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    padding: 20px;
  }

  .footer-grid {
    grid-template-columns: 1fr 1fr;
  }

  .services-grid {
    grid-template-columns: 1fr;
  }

  .pricing-teaser-grid {
    grid-template-columns: 1fr;
  }

  .site-nav {
    padding: 0 20px;
    height: 64px;
  }

  .nav-menu {
    display: none;
  }

  .nav-hamburger {
    display: flex;
  }

  .exec-inner {
    grid-template-columns: 1fr;
    gap: 40px;
    padding: 60px 24px;
  }

  .exec-sticky {
    height: auto;
    min-height: unset;
    position: relative;
  }

  #exec-swap-section {
    height: auto !important;
  }

  .exec-cards-stage {
    max-width: 100%;
    height: 300px;
  }

  /* On mobile: auto-play timer instead of scroll */
  .exec-card {
    position: absolute;
  }
}

@media (max-width: 768px) {

  .s-logo-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .s-logo-grid-7 {
    grid-template-columns: repeat(3, 1fr);
  }

  .s-modules-grid {
    grid-template-columns: 1fr;
  }

  .s-brands-grid {
    grid-template-columns: 1fr;
  }

  .s-resources-grid {
    grid-template-columns: 1fr;
  }

  .s-footer-cols {
    grid-template-columns: repeat(2, 1fr);
  }

  .grid-two-col {
    grid-template-columns: 1fr;
  }

  .panels-wrap {
    height: 520px;
  }

  .sf-panel-compliance {
    left: 0;
  }
}

/* ── INDEX: Responsive section padding ── */
@media (max-width: 1024px) {

  .section-white,
  .section-light,
  .section-teal {
    padding: 100px 0;
  }

  .unified-ops,
  .s-control {
    padding: 100px 0 80px;
  }

  .s-brands {
    padding: 48px 0 100px;
  }

  .s-demo,
  .s-resources,
  .s-modules {
    padding: 100px 0;
  }

  .s-metrics {
    padding: 72px 0;
  }

  .s-integrations {
    padding: 64px 0 32px;
  }

  .stats-strip {
    padding: 48px 0;
  }

  .section-failure {
    padding: 80px 0 64px;
  }

  .s-footer {
    padding: 64px 0 0;
  }
}

@media (max-width: 768px) {

  .section-white,
  .section-light,
  .section-teal {
    padding: 72px 0;
  }

  .unified-ops,
  .s-control {
    padding: 72px 0 56px;
  }

  .s-brands {
    padding: 40px 0 72px;
  }

  .s-demo,
  .s-resources,
  .s-modules {
    padding: 72px 0;
  }

  .s-metrics {
    padding: 56px 0;
  }

  .s-integrations {
    padding: 48px 0 24px;
  }

  .stats-strip {
    padding: 40px 0;
  }

  .section-failure {
    padding: 64px 0 48px;
  }

  .s-footer {
    padding: 48px 0 0;
  }

  .s-footer-top {
    padding-bottom: 40px;
  }
}

@media (max-width: 480px) {

  .section-white,
  .section-light,
  .section-teal {
    padding: 56px 0;
  }

  .unified-ops,
  .s-control {
    padding: 56px 0 40px;
  }

  .s-brands {
    padding: 32px 0 56px;
  }

  .s-demo,
  .s-resources,
  .s-modules {
    padding: 56px 0;
  }

  .s-metrics {
    padding: 40px 0;
  }

  .s-integrations {
    padding: 40px 0 20px;
  }

  .stats-strip {
    padding: 32px 0;
  }

  .section-failure {
    padding: 48px 0 40px;
  }

  .s-footer {
    padding: 40px 0 0;
  }

  .s-footer-top {
    padding-bottom: 32px;
  }
}


/* ================================================================
       RESPONSIVE OVERRIDES — Added below (media queries only)
       ================================================================ */

/* ================================================================
   ATOMINC — MOBILE RESPONSIVE OVERRIDES
   ================================================================
   CRITICAL RULE: This file contains ONLY additive overrides.
   Zero desktop styles have been modified, removed, or rewritten.
   All rules are scoped exclusively inside media queries.

   Breakpoint Strategy:
     max-width: 1024px  →  Small Desktop
     max-width: 768px   →  Tablet
     max-width: 480px   →  Mobile (primary focus)
     max-width: 360px   →  Extra Small (safety net)
   ================================================================ */


/* ════════════════════════════════════════════════════════════
   ① SMALL DESKTOP — max-width: 1024px
   ════════════════════════════════════════════════════════════ */

@media (max-width: 1024px) {

  /* ── Container ── */
  .container,
  .sf-container {
    padding: 0 32px;
  }

  /* ── Navigation ── */
  .site-nav {
    padding: 0 32px;
  }

  /* ── Hero typography — pull back the extremes ── */
  .giant-heading {
    font-size: clamp(3.5rem, 11vw, 10rem);
  }

  .giant-heading-sub {
    font-size: clamp(2rem, 5vw, 4rem);
    margin: 8px 0 40px;
  }

  .btn-neon-pink {
    font-size: 1.2rem;
    padding: 20px 44px;
  }

  /* ── Stats strip: 4-col → 2×2 grid ── */
  /* NOTE: 900px already handles 1fr 1fr but this sets borders cleanly */
}


/* ════════════════════════════════════════════════════════════
   ② TABLET — max-width: 768px
   ════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {

  /* ── NAVIGATION ──────────────────────────────────────── */

  /* Hide CTA buttons — hamburger menu carries all navigation */
  .nav-right {
    display: none;
  }

  /* nav-menu and hamburger already handled by existing 900px query */

  /* ── HERO ────────────────────────────────────────────── */

  .hero-giant {
    padding-top: 64px;
    min-height: 88vh;
    /* Breathe: down from 100vh */
    padding-bottom: 28px;
  }

  .hero-content {
    padding: 0 20px;
  }

  .giant-heading {
    font-size: clamp(2.8rem, 12vw, 6rem);
    letter-spacing: -0.04em;
  }

  .giant-heading-sub {
    font-size: clamp(1.5rem, 5.5vw, 2.8rem);
    margin: 8px 0 26px;
  }

  .hero-support {
    font-size: 0.95rem;
    margin-bottom: 22px;
    padding: 0 4px;
  }

  .btn-neon-pink {
    font-size: 1.05rem;
    padding: 18px 36px;
    width: 100%;
    max-width: 340px;
  }

  /* Center the AtomInc / Partner tab switcher on mobile */
  .hero-page-switch {
    align-self: center;
    margin-bottom: 24px;
  }

  /* ── MARQUEE ─────────────────────────────────────────── */

  .marquee-inner {
    gap: 48px;
    padding-left: 48px;
    animation-duration: 28s;
    /* Slightly slower for readability */
  }

  .marquee-inner span {
    font-size: 1.35rem;
  }

  .marquee-title {
    font-size: 0.95rem;
    padding: 0 20px;
    margin-bottom: 20px;
  }

  .marquee-section {
    padding-bottom: 30px;
  }

  /* ── GLOBAL TYPOGRAPHY ───────────────────────────────── */

  .h2 {
    font-size: clamp(1.8rem, 5.5vw, 3rem);
  }

  .s-h2 {
    font-size: clamp(1.8rem, 5.5vw, 3rem) !important;
    /* Override inline style font-size */
    max-width: 100% !important;
  }

  .body-lg {
    font-size: 1rem;
    max-width: 100%;
  }

  .section-header {
    margin-bottom: 36px;
  }

  .eyebrow {
    font-size: 0.78rem;
    margin-bottom: 16px;
  }

  /* ── SECTION FAILURE — Stacked panels ───────────────── */

  /* Override absolute positioning — stack panels vertically */
  .panels-wrap {
    position: relative !important;
    height: auto !important;
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-top: 8px;
  }

  .sf-panel {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    width: 100% !important;
    animation: none !important;
    /* Kill float animations on mobile */
    transform: none !important;
  }

  /* ── UNIFIED OPS TABS — horizontal scroll ────────────── */

  .unified-tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 4px;
    max-width: 100%;
    gap: 2px;
  }

  .unified-tabs::-webkit-scrollbar {
    display: none;
  }

  .utab {
    font-size: 0.82rem;
    padding: 12px 14px;
    white-space: nowrap;
    flex: 0 0 auto;
    /* Don't squeeze — allow scroll */
  }

  /* ── SPLIT SECTION ───────────────────────────────────── */
  /* grid-template-columns already 1fr via 900px query */
  .split-section {
    gap: 36px;
  }

  /* ── BRAND FEATURES ──────────────────────────────────── */
  .brand-features {
    display: grid !important;
    /* Override inline style="display:grid" */
    grid-template-columns: 1fr 1fr !important;
    /* Tablet: 3-col → 2-col */
    gap: 14px !important;
    margin-top: 24px !important;
  }

  .bf-text h4 {
    font-size: 1.15rem;
  }

  /* ── PILLAR CARDS ────────────────────────────────────── */
  /* Already 1fr 1fr grid via 900px — just tighten padding */
  .pillar-card {
    padding: 28px 20px;
  }

  /* ── STEPS ───────────────────────────────────────────── */
  /* Already 1fr 1fr via 900px */
  .step h4 {
    font-size: 1.1rem;
  }

  /* ── STATS STRIP ─────────────────────────────────────── */
  /* Already 1fr 1fr via 900px */
  .stat-num {
    font-size: 2.2rem;
  }

  .stat-item {
    padding: 20px 16px;
  }

  /* ── DASHBOARD CARD ──────────────────────────────────── */

  .s-dashboard-card {
    margin-bottom: 28px;
  }

  /* Collapse 2-col (from 1024px) → 1-col on tablet */
  .sdc-body {
    grid-template-columns: 1fr;
    padding: 16px;
    gap: 12px;
  }

  /* ── EXEC CARD SECTION ───────────────────────────────── */
  /* Already 1-col at 900px — fix broken desktop font-size clamp */
  .exec-heading {
    font-size: clamp(2rem, 7vw, 3rem) !important;
  }

  .exec-cards-stage {
    height: 300px;
  }

  /* ── METRICS ─────────────────────────────────────────── */
  /* Already 1-col at 1024px */
  .s-metric-block {
    padding: 36px 28px;
  }

  /* ── QUOTE BAND ──────────────────────────────────────── */
  .s-quote-band {
    border-radius: 16px;
    padding: 14px 20px;
    flex-wrap: wrap;
    gap: 4px 0;
  }

  .s-qb-item span {
    font-size: 0.78rem;
  }

  /* ── CTA SECTION ─────────────────────────────────────── */
  .cta-inner {
    padding: 0 20px 60px;
  }

  .cta-btns {
    flex-direction: column;
    align-items: center;
    gap: 10px;
  }

  .btn-cta-primary,
  .btn-cta-outline {
    width: 100%;
    max-width: 320px;
    justify-content: center;
    text-align: center;
  }

  /* ── FOOTER ──────────────────────────────────────────── */
  /* Already 1fr 1fr at 900px */
  .footer-brand p {
    max-width: 100%;
  }

  /* ── OPS MODAL ───────────────────────────────────────── */
  .ops-modal {
    border-radius: 20px;
    max-height: 96vh;
  }

  .ops-modal-header {
    padding: 18px 24px;
  }

  .ops-modal-body {
    padding: 24px;
  }

  .modal-hero-banner {
    grid-template-columns: 1fr;
    gap: 20px;
    padding: 24px;
  }

  .modal-stats {
    gap: 20px;
  }

  /* ── DEMO FORM ───────────────────────────────────────── */
  .s-demo-form {
    padding: 28px 24px;
  }
}


/* ════════════════════════════════════════════════════════════
   ③ MOBILE — max-width: 480px
   (Primary mobile optimization layer)
   ════════════════════════════════════════════════════════════ */

@media (max-width: 480px) {

  /* ── CONTAINER ───────────────────────────────────────── */
  .container,
  .sf-container {
    padding: 0 16px;
  }

  /* ── HERO ────────────────────────────────────────────── */

  .hero-giant {
    padding-top: 64px;
    min-height: 82vh;
    padding-bottom: 20px;
  }

  .hero-content {
    padding: 0 16px;
  }

  .giant-heading {
    font-size: clamp(2.3rem, 13vw, 4rem);
    letter-spacing: -0.04em;
    line-height: 1.0;
  }

  .giant-heading-sub {
    font-size: clamp(1.2rem, 5.5vw, 1.8rem);
    margin: 6px 0 22px;
    letter-spacing: -0.02em;
  }

  .hero-support {
    font-size: 0.88rem;
    line-height: 1.65;
    margin-bottom: 18px;
  }

  .btn-neon-pink {
    font-size: 0.95rem;
    padding: 16px 28px;
    width: 100%;
    max-width: 300px;
    border-radius: 50px;
    margin-bottom: 16px;
  }

  .hero-page-switch {
    margin-bottom: 18px;
  }

  .hps-tab {
    padding: 8px 18px;
    font-size: 0.68rem;
  }

  /* ── MARQUEE ─────────────────────────────────────────── */

  .marquee-inner {
    gap: 32px;
    padding-left: 32px;
    animation-duration: 22s;
  }

  .marquee-inner span {
    font-size: 1.1rem;
  }

  .marquee-title {
    font-size: 0.82rem;
    padding: 0 16px;
    margin-bottom: 14px;
  }

  .marquee-section {
    padding-bottom: 22px;
  }

  /* ── GLOBAL TYPOGRAPHY ───────────────────────────────── */

  .h2 {
    font-size: clamp(1.55rem, 7.5vw, 2.4rem);
    letter-spacing: -0.025em;
  }

  .s-h2 {
    font-size: clamp(1.55rem, 7.5vw, 2.4rem) !important;
    /* Override inline style */
    max-width: 100% !important;
    letter-spacing: -0.025em;
  }

  .s-h3 {
    font-size: clamp(1.1rem, 4vw, 1.4rem);
  }

  .body-lg,
  .s-body {
    font-size: 0.92rem;
    line-height: 1.7;
  }

  .eyebrow {
    font-size: 0.7rem;
    letter-spacing: 0.1em;
  }

  .section-header {
    margin-bottom: 22px;
  }

  /* ── BRAND FEATURES GRID — override inline 3-col ──────── */

  .brand-features {
    display: grid !important;
    /* Override inline style="display:grid" */
    grid-template-columns: 1fr !important;
    /* Mobile: collapse to 1-col */
    gap: 12px !important;
    margin-top: 20px !important;
  }

  .brand-feature {
    display: flex !important;
    /* Keep flex for icon+text layout */
    gap: 16px !important;
  }

  /* ── PILLARS GRID — 2-col → 1-col ───────────────────── */

  .pillars-grid {
    grid-template-columns: 1fr;
    gap: 12px;
    margin-top: 28px;
  }

  .pillar-card {
    padding: 24px 20px;
    border-radius: 18px;
  }

  .pillar-card h3 {
    font-size: 1.1rem;
  }

  /* ── STEPS — 2-col → 1-col, horizontal layout ───────── */

  .steps-grid {
    grid-template-columns: 1fr;
    gap: 20px;
    margin-top: 28px;
  }

  /* Reflow into horizontal icon + text layout */
  .step {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    text-align: left;
    padding: 0;
  }

  .step-num {
    margin: 0;
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    font-size: 0.9rem;
  }

  .step h4 {
    font-size: 1.05rem;
    margin-bottom: 6px;
  }

  .step p {
    font-size: 0.88rem;
  }

  /* ── STATS STRIP ─────────────────────────────────────── */

  .stat-item {
    padding: 16px 12px;
  }

  .stat-num {
    font-size: 1.9rem;
  }

  .stat-label {
    font-size: 0.76rem;
  }

  /* ── SECTION FAILURE ─────────────────────────────────── */

  .section-failure .section-heading {
    font-size: clamp(1.6rem, 8vw, 2.4rem);
    letter-spacing: -0.025em;
  }

  .section-failure .section-subtext {
    font-size: 0.88rem;
    margin-bottom: 32px;
  }

  .sf-eyebrow {
    font-size: 10px;
  }

  /* Panels already stacked at 768px — refine padding */
  .sf-panel-shipment,
  .sf-panel-compliance {
    padding: 16px 18px !important;
  }

  /* KPI panel: override the 220px desktop fixed-width */
  .sf-panel-kpi {
    width: 100% !important;
    padding: 18px 18px !important;
  }

  /* ── DASHBOARD CARD ──────────────────────────────────── */

  .sdc-body {
    padding: 14px;
    gap: 10px;
  }

  .s-dashboard-card {
    margin-bottom: 20px;
    border-radius: 14px;
  }

  .sdc-metrics {
    gap: 8px;
  }

  /* ── MODULES ─────────────────────────────────────────── */
  /* Already 1-col at 768px */
  .s-module-card {
    padding: 24px 20px;
    border-radius: 16px;
  }

  .s-mod-icon {
    width: 44px;
    height: 44px;
    font-size: 1.2rem;
    margin-bottom: 14px;
    border-radius: 12px;
  }

  .s-module-card h4 {
    font-size: 0.98rem;
  }

  /* ── LOGO GRID ───────────────────────────────────────── */

  .s-logo-item {
    padding: 14px 12px;
    min-height: 64px;
    border-radius: 10px;
  }

  .s-logo-item img {
    max-height: 28px;
    max-width: 80px;
  }

  /* ── METRICS ─────────────────────────────────────────── */

  .s-met-num {
    font-size: clamp(2.8rem, 10vw, 4.5rem);
  }

  .s-met-title {
    font-size: 0.92rem;
  }

  .s-met-desc {
    font-size: 0.8rem;
  }

  .s-metrics-label {
    font-size: 0.68rem;
    margin-bottom: 40px;
    padding: 0 8px;
  }

  .s-metrics-quotes {
    margin-top: 40px;
  }

  /* ── QUOTE BAND — stacks vertically ─────────────────── */

  .s-quote-band {
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 16px 20px;
    border-radius: 14px;
  }

  .s-qb-sep {
    display: none;
    /* Hide separators when vertical */
  }

  /* ── BRANDS ──────────────────────────────────────────── */
  /* Already 1-col at 768px */
  .s-brand-img-placeholder {
    height: 140px;
    font-size: 2.2rem;
  }

  .s-brand-content {
    padding: 18px 20px;
  }

  /* ── RESOURCES ───────────────────────────────────────── */
  /* Already 1-col at 768px */
  .s-res-thumb {
    height: 110px;
  }

  .s-res-content {
    padding: 16px;
  }

  /* ── EXEC SECTION ────────────────────────────────────── */

  .exec-inner {
    padding: 40px 16px;
    gap: 28px;
  }

  .exec-heading {
    font-size: clamp(1.8rem, 7vw, 2.6rem) !important;
  }

  .exec-cards-stage {
    height: 264px;
  }

  .exec-card {
    padding: 22px 22px !important;
    border-radius: 16px;
  }

  .exec-card-title {
    font-size: 1.05rem;
  }

  .exec-card-body {
    font-size: 0.82rem;
    margin-top: 10px;
  }

  .exec-card-bottom {
    margin-top: 14px;
  }

  .exec-progress-track {
    margin-top: 20px;
  }

  /* ── S-BTN-GREEN — override inline font-size + padding ─── */

  .s-btn-green {
    font-size: 0.9rem !important;
    /* Override inline style="font-size:1rem" */
    padding: 13px 28px !important;
    /* Override inline style="padding:18px 44px" */
    min-height: 48px;
  }

  /* ── UNIFIED OPS TABS ────────────────────────────────── */

  .unified-tabs {
    margin-bottom: 32px;
    border-radius: 14px;
  }

  .utab {
    font-size: 0.75rem;
    padding: 10px 12px;
  }

  /* ── BRAND FEATURES ──────────────────────────────────── */

  .brand-feature {
    border-radius: 16px !important;
    padding: 16px !important;
    /* Override inline styles if any */
  }

  .bf-icon {
    width: 52px;
    height: 52px;
    border-radius: 14px;
    font-size: 1.4rem;
  }

  .bf-text h4 {
    font-size: 1.05rem;
    margin-bottom: 6px;
  }

  .bf-text p {
    font-size: 0.88rem;
  }

  /* ── SERVICE CARDS ───────────────────────────────────── */

  .service-card {
    padding: 24px 20px;
    border-radius: 16px;
  }

  .service-card h3 {
    font-size: 1.05rem;
  }

  .service-card p {
    font-size: 0.83rem;
  }

  /* ── PRICING TEASER ──────────────────────────────────── */

  .pricing-teaser-card {
    padding: 24px 20px;
    border-radius: 18px;
  }

  .pricing-teaser-card .price {
    font-size: 1.7rem;
  }

  .pricing-teaser-card h3 {
    font-size: 1.2rem;
  }

  /* ── CTA ─────────────────────────────────────────────── */

  .cta-section {
    padding: 48px 0 0;
  }

  .cta-inner {
    padding: 0 16px 48px;
  }

  .btn-cta-primary,
  .btn-cta-outline {
    padding: 14px 24px;
    font-size: 0.9rem;
    min-height: 48px;
    /* WCAG touch target */
    width: 100%;
    max-width: 300px;
  }

  /* ── FOOTER (existing classes) ───────────────────────── */

  /* Already 1-col at 600px */
  .footer-brand p {
    font-size: 0.82rem;
  }

  .social-link {
    width: 38px;
    height: 38px;
    /* Larger touch target */
  }

  .footer-bottom {
    gap: 10px;
  }

  /* ── DEMO FORM ───────────────────────────────────────── */

  .s-demo-form {
    padding: 24px 20px;
    border-radius: 16px;
  }

  /* Prevent iOS from zooming on input focus (< 16px triggers zoom) */
  .s-form-group input,
  .s-form-group select {
    padding: 13px 14px;
    font-size: 1rem;
  }

  .s-form-submit {
    padding: 15px;
    font-size: 0.95rem;
  }

  /* ── NEW FOOTER (s- classes) ─────────────────────────── */

  .s-footer-bottom {
    flex-direction: column;
    gap: 8px;
    text-align: center;
    padding: 16px 0;
  }

  .s-social {
    width: 38px;
    height: 38px;
  }

  /* ── GENERAL TOUCH TARGETS ───────────────────────────── */

  .s-btn-green,
  .s-btn-outline {
    padding: 13px 28px;
    min-height: 48px;
    font-size: 0.9rem;
  }

  /* ── OPS MODAL ───────────────────────────────────────── */

  .ops-modal-header {
    padding: 16px 20px;
    border-radius: 20px 20px 0 0;
  }

  .ops-modal-body {
    padding: 20px 16px;
  }

  .modal-tabs {
    gap: 6px;
    margin-bottom: 28px;
  }

  .mtab {
    padding: 8px 16px;
    font-size: 0.8rem;
  }
}


/* ════════════════════════════════════════════════════════════
   ④ EXTRA SMALL — max-width: 360px
   (Safety net for the smallest common devices)
   ════════════════════════════════════════════════════════════ */

@media (max-width: 360px) {

  .container,
  .sf-container {
    padding: 0 14px;
  }

  /* Hero — final floor for readability */
  .giant-heading {
    font-size: 2.1rem;
    letter-spacing: -0.03em;
  }

  .giant-heading-sub {
    font-size: 1.15rem;
  }

  .btn-neon-pink {
    font-size: 0.88rem;
    padding: 14px 22px;
  }

  /* Typography floor */
  .h2,
  .s-h2 {
    font-size: 1.45rem !important;
    /* Override inline style */
  }

  .section-failure .section-heading {
    font-size: 1.5rem;
  }

  .exec-heading {
    font-size: 1.65rem !important;
  }

  /* Layout tightening */
  .pillars-grid {
    gap: 10px;
  }

  .pillar-card {
    padding: 20px 16px;
  }

  .exec-inner {
    padding: 32px 14px;
  }

  .exec-cards-stage {
    height: 240px;
  }
}

/* ══════════════════════════════════════════
   S-DEMO BOOKING ENHANCEMENTS
   ══════════════════════════════════════════ */
.s-demo-form-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 24px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--border);
}

.s-demo-form-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: var(--green-light);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.s-demo-form-icon img {
  border-radius: 10px;
  width: 44px;
  height: 44px;
}

.s-demo-form-title {
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--ink);
  margin: 0;
  line-height: 1.2;
}

.s-demo-form-badges {
  display: flex;
  gap: 8px;
  margin-top: 4px;
}

.s-demo-form-badge {
  font-size: 0.65rem;
  font-weight: 700;
  color: var(--green);
  background: var(--green-light);
  padding: 2px 10px;
  border-radius: 20px;
}

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

.s-form-slots-label {
  display: block;
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 10px;
  margin-top: 10px;
}

.s-time-slots-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-bottom: 20px;
}

.s-time-slot {
  padding: 10px 4px;
  border-radius: 10px;
  border: 1.5px solid var(--border);
  background: #fff;
  text-align: center;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--ink);
  cursor: pointer;
  transition: all 0.18s;
}

.s-time-slot:hover {
  border-color: var(--green);
  background: var(--green-light);
}

.s-time-slot.selected {
  background: var(--green);
  color: #fff;
  border-color: var(--green);
  box-shadow: 0 4px 12px rgba(22, 163, 74, 0.25);
}

.s-form-error {
  display: none;
  background: #fff1f2;
  border: 1px solid #fecdd3;
  color: #be123c;
  font-size: 0.85rem;
  padding: 10px;
  border-radius: 10px;
  text-align: center;
  margin-bottom: 16px;
}

.s-form-error.show {
  display: block;
}

.s-form-success {
  display: none;
  text-align: center;
  padding: 40px 20px;
}

.s-form-success.show {
  display: block;
}

.s-form-success-icon {
  width: 60px;
  height: 60px;
  background: var(--green-light);
  color: var(--green);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  margin: 0 auto 16px;
}
/* ════════════════════════════════════════════════════════════
   MOBILE NAV — Premium Accordion Mega Menu
   ════════════════════════════════════════════════════════════ */

.mobile-nav-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: #1a0f3c;
  z-index: 490;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  opacity: 0;
  transition: opacity .35s cubic-bezier(.4, 0, .2, 1);
}

.mobile-nav-overlay.is-open {
  opacity: 1;
}

.mobile-nav-close {
  position: absolute;
  top: 18px;
  right: 20px;
  background: none;
  border: none;
  color: rgba(255,255,255,.7);
  font-size: 1.75rem;
  cursor: pointer;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  transition: background .2s, color .2s;
  z-index: 2;
}

.mobile-nav-close:hover,
.mobile-nav-close:active {
  background: rgba(255,255,255,.08);
  color: #fff;
}

.mobile-nav-inner {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 80px 20px 40px;
  max-width: 480px;
  margin: 0 auto;
}

/* ── Accordion Trigger ── */
.mob-accordion-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 16px;
  background: none;
  border: none;
  border-bottom: 1px solid rgba(255,255,255,.08);
  color: #fff;
  font-family: 'DM Sans', sans-serif;
  font-size: 1.05rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .2s, color .2s;
  border-radius: 10px 10px 0 0;
  -webkit-tap-highlight-color: transparent;
}

.mob-accordion-trigger:hover,
.mob-accordion-trigger:active {
  background: rgba(255,255,255,.04);
}

.mob-accordion-trigger[aria-expanded="true"] {
  color: #e63975;
  border-bottom-color: rgba(230,57,117,.2);
}

/* ── Chevron rotation ── */
.mob-chev {
  color: rgba(255,255,255,.45);
  transition: transform .3s cubic-bezier(.4, 0, .2, 1), color .3s;
  flex-shrink: 0;
}

.mob-accordion-trigger[aria-expanded="true"] .mob-chev {
  transform: rotate(180deg);
  color: #e63975;
}

/* ── Accordion Panel ── */
.mob-accordion-panel {
  max-height: 0;
  overflow: hidden;
  transition: max-height .35s cubic-bezier(.4, 0, .2, 1);
  padding: 0 4px;
}

/* ── Mobile Nav Card Items — reuse desktop ndp-icon, ndp-name, ndp-desc ── */
.mob-ndp-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 14px;
  margin: 4px 0;
  border-radius: 12px;
  text-decoration: none;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.06);
  transition: background .2s, border-color .2s, transform .15s;
}

.mob-ndp-item:active {
  transform: scale(.98);
}

.mob-ndp-item:hover {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.12);
}

/* Override ndp-icon for dark-on-dark context */
.mob-ndp-item .ndp-icon {
  width: 38px;
  height: 38px;
  background: rgba(255,255,255,.1);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  border: 1px solid rgba(255,255,255,.08);
}

/* Override text colors for dark background */
.mob-ndp-item .ndp-name {
  color: #fff;
  font-size: .88rem;
  font-weight: 600;
  margin-bottom: 2px;
}

.mob-ndp-item .ndp-desc {
  color: rgba(255,255,255,.5);
  font-size: .76rem;
  line-height: 1.35;
}

/* ── Section Label ── */
.mob-ndp-label {
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255,255,255,.35);
  padding: 10px 14px 4px;
  display: block;
}

/* ── CTA Buttons ── */
.mob-nav-cta {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 28px;
  padding: 0 4px;
}

.mob-btn-ghost {
  display: block;
  text-align: center;
  text-decoration: none;
  color: #fff;
  font-size: .92rem;
  font-weight: 500;
  padding: 14px 24px;
  border-radius: 50px;
  border: 1.5px solid rgba(255,255,255,.18);
  transition: all .2s;
}

.mob-btn-ghost:hover,
.mob-btn-ghost:active {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.35);
}

.mob-btn-primary {
  display: block;
  text-align: center;
  text-decoration: none;
  color: #fff;
  font-size: .95rem;
  font-weight: 700;
  padding: 16px 28px;
  border-radius: 50px;
  background: linear-gradient(135deg, #16a34a 0%, #15803d 100%);
  box-shadow: 0 4px 20px rgba(22,163,74,.3);
  transition: all .25s;
}

.mob-btn-primary:hover,
.mob-btn-primary:active {
  box-shadow: 0 6px 28px rgba(22,163,74,.45);
  transform: translateY(-1px);
}

/* ── Hide mobile nav on desktop ── */
@media (min-width: 901px) {
  .mobile-nav-overlay {
    display: none !important;
  }
}
