/* ============================================================
   Mediaology — Home page styles
   Sections specific to the Home page.
   ============================================================ */

/* ============================================================
   HERO (Section 1) — full-bleed video background
   ============================================================ */
.home-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: stretch;
  background: var(--surface-black);
  color: var(--text-on-dark-primary);
  overflow: hidden;
}
.home-hero__video,
.home-hero__poster {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.home-hero__poster { z-index: 0; }
.home-hero__video {
  z-index: 0;
  /* Hidden by default. The :not([src=""]) selector reveals it once admin sets src. */
  opacity: 0;
  transition: opacity 600ms var(--ease-out);
}
.home-hero__video[src]:not([src=""]) {
  opacity: 1;
  z-index: 1;
}

/* YouTube-iframe variant. <iframe> ignores object-fit, so we mimic
   "cover" by sizing it to whichever dimension is larger relative to
   a 16:9 frame. Centered with translate so the iframe always
   fills the hero edge-to-edge regardless of viewport aspect.
   pointer-events:none so the video can't intercept clicks on the
   hero CTAs / stats sitting on top. */
.home-hero__video--iframe {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: max(100vw, calc(100vh * 16 / 9));
  height: max(100vh, calc(100vw * 9 / 16));
  border: 0;
  pointer-events: none;
  z-index: 1;
  opacity: 1;
  /* The iframe takes ~1s to start playing on slow networks; fade-in
     keeps the gradient poster visible underneath until then. */
  transition: opacity 600ms var(--ease-out);
}
.home-hero__poster {
  background-size: cover;
  background-position: center;
  background-image:
    radial-gradient(ellipse at 20% 30%, rgba(236, 26, 100, 0.35) 0%, transparent 45%),
    radial-gradient(ellipse at 80% 60%, rgba(56, 100, 255, 0.45) 0%, transparent 50%),
    radial-gradient(ellipse at 50% 90%, rgba(236, 26, 100, 0.3) 0%, transparent 50%),
    linear-gradient(135deg, #0A0A2A 0%, #1A0A2A 50%, #2A0820 100%);
}
.home-hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(180deg,
    rgba(0, 0, 0, 0.35) 0%,
    rgba(0, 0, 0, 0.25) 30%,
    rgba(0, 0, 0, 0.55) 65%,
    rgba(0, 0, 0, 0.85) 100%
  );
  pointer-events: none;
}
.home-hero__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  display: flex;
  flex-direction: column;
  padding-top: 160px;
  padding-bottom: var(--space-12);
}
.home-hero__content {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  max-width: 760px;
  margin-bottom: var(--space-16);
}
.home-hero__eyebrow {
  font-family: var(--font-body);
  font-size: var(--fs-body-lg);
  font-weight: var(--fw-regular);
  color: var(--text-on-dark-secondary);
  margin-bottom: var(--space-6);
}
.home-hero__title {
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 5vw + 1rem, 5rem);
  font-weight: var(--fw-regular);
  line-height: 1.1;
  letter-spacing: var(--tracking-tight);
  color: var(--text-on-dark-primary);
  margin-bottom: var(--space-10);
  max-width: 14ch;
}
.home-hero__cta {
  align-self: flex-start;
  font-size: var(--fs-body);
  padding: 16px 32px;
}
.home-hero__cta .arrow-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--brand-white);
  color: var(--brand-primary);
  margin-left: var(--space-2);
  transition: transform var(--duration-base) var(--ease-out);
}
.home-hero__cta:hover .arrow-pill { transform: translateX(2px); }

/* Stats row (bottom of hero) */
.home-hero__stats {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: var(--space-12);
  position: relative;
  z-index: 2;
}
.home-hero__stat {
  display: flex;
  flex-direction: column;
  cursor: pointer;
  transition: transform var(--duration-base) var(--ease-out);
  text-decoration: none;
  color: inherit;
}
.home-hero__stat:hover { transform: translateY(-4px); }
.home-hero__stat-label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--text-on-dark-primary);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid rgba(255, 255, 255, 0.3);
  margin-bottom: var(--space-6);
  transition: color var(--duration-base) var(--ease-out), border-color var(--duration-base) var(--ease-out);
}
.home-hero__stat-label svg {
  width: 14px;
  height: 14px;
  fill: currentColor;
}
.home-hero__stat:hover .home-hero__stat-label {
  color: var(--brand-primary);
  border-bottom-color: var(--brand-primary);
}
.home-hero__stat-number {
  font-family: var(--font-display);
  font-size: clamp(3.5rem, 6vw + 1rem, 6.5rem);
  font-weight: var(--fw-regular);
  line-height: 1;
  color: var(--text-on-dark-primary);
  margin-bottom: var(--space-4);
}
.home-hero__stat-caption {
  font-size: var(--fs-body-sm);
  line-height: var(--lh-relaxed);
  color: var(--text-on-dark-secondary);
  max-width: 28ch;
}

@media (max-width: 900px) {
  .home-hero__stats { grid-template-columns: 1fr; gap: var(--space-8); }
  .home-hero__inner { padding-top: 120px; }
}

/* ============================================================
   SECTION 2 — White background + capability cards + services grid
   ============================================================ */
.home-magenta-section {
  background: var(--surface-white);
  color: var(--text-on-light-primary);
  padding: var(--space-32) 0 var(--space-24);
  position: relative;
}
.home-magenta-section .container { position: relative; z-index: 1; }
.home-magenta__intro {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--space-16);
  margin-bottom: var(--space-16);
}
.home-magenta__intro h2 {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 2vw + 1rem, 2.25rem);
  font-weight: var(--fw-regular);
  line-height: 1.3;
  color: var(--text-on-light-primary);
}
.home-magenta__intro-right p {
  font-size: var(--fs-body);
  color: var(--text-on-light-secondary);
  line-height: var(--lh-relaxed);
  margin-bottom: var(--space-6);
}
.home-magenta__intro-right .btn-text-link { color: var(--text-on-light-primary); }
.home-magenta__intro-right .btn-text-link:hover { color: var(--brand-primary); }

.home-capabilities {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}
.home-capability {
  background: var(--surface-off-white);
  border: 1px solid var(--surface-card-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  text-decoration: none;
  color: inherit;
  transition: transform var(--duration-base) var(--ease-out),
              background-color var(--duration-base) var(--ease-out),
              border-color var(--duration-base) var(--ease-out),
              box-shadow var(--duration-base) var(--ease-out);
}
.home-capability:hover {
  transform: translateY(-6px);
  background: var(--surface-white);
  border-color: var(--brand-primary);
  box-shadow: var(--shadow-md);
}
.home-capability__image {
  aspect-ratio: 16 / 10;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--surface-near-black);
  margin-bottom: var(--space-2);
}
.home-capability__image img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform var(--duration-slow) var(--ease-out);
  display: block;
}
/* Hide the placeholder <img> until admin sets a real src on it,
   so the wrapper's gradient fallback shows on a fresh load instead
   of the browser's broken-image icon. */
.home-capability__image img:not([src]),
.home-capability__image img[src=""] { display: none; }
.home-capability:hover .home-capability__image img { transform: scale(1.04); }
.home-capability__title {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  font-weight: var(--fw-medium);
  color: var(--text-on-light-primary);
}
.home-capability__tagline {
  font-size: var(--fs-body);
  font-weight: var(--fw-medium);
  color: var(--text-on-light-primary);
  margin-bottom: var(--space-2);
}
.home-capability__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.home-capability__list li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--fs-body-sm);
  color: var(--text-on-light-secondary);
  line-height: var(--lh-base);
}
.home-capability__list li::before {
  content: '';
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  margin-top: 4px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path d='M3 8l3.5 3.5L13 5' stroke='%23EC1A64' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-size: contain;
  background-repeat: no-repeat;
}

.home-magenta__services-label {
  margin-top: var(--space-20);
  margin-bottom: var(--space-8);
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--brand-primary);
}

/* 2x2 service category grid */
.home-services-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-5);
}
.home-service-tile {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: var(--space-6);
  padding: var(--space-8);
  min-height: 200px;
  background: var(--surface-black);
  color: var(--text-on-dark-primary);
  border-radius: var(--radius-lg);
  text-decoration: none;
  overflow: hidden;
  transition: transform var(--duration-base) var(--ease-out);
}
.home-service-tile::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--brand-primary) 0%, transparent 60%);
  opacity: 0;
  transition: opacity var(--duration-slow) var(--ease-out);
  z-index: 0;
}
.home-service-tile > * { position: relative; z-index: 1; }
.home-service-tile:hover { transform: translateY(-4px); }
.home-service-tile:hover::before { opacity: 0.85; }

.home-service-tile__top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-4);
}
.home-service-tile__title {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 1.5vw + 0.75rem, 1.875rem);
  font-weight: var(--fw-medium);
  line-height: 1.15;
}
.home-service-tile__num {
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tracking-eyebrow);
  color: var(--brand-primary);
  flex-shrink: 0;
}
.home-service-tile:hover .home-service-tile__num { color: var(--text-on-dark-primary); }
.home-service-tile__bottom {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: var(--space-4);
}
.home-service-tile__desc {
  font-size: var(--fs-body-sm);
  color: var(--text-on-dark-secondary);
  line-height: var(--lh-relaxed);
  max-width: 32ch;
}
.home-service-tile:hover .home-service-tile__desc { color: var(--text-on-dark-primary); }
.home-service-tile__arrow {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--text-on-dark-primary);
  transition: background-color var(--duration-base) var(--ease-out), transform var(--duration-base) var(--ease-out);
}
.home-service-tile__arrow svg { width: 16px; height: 16px; }
.home-service-tile:hover .home-service-tile__arrow {
  background: var(--brand-white);
  color: var(--brand-primary);
  transform: translateX(4px);
}

@media (max-width: 960px) {
  .home-magenta__intro { grid-template-columns: 1fr; gap: var(--space-8); }
  .home-capabilities { grid-template-columns: 1fr; }
  .home-services-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   FINAL CTA (before footer) — bold, brand-aligned
   ============================================================ */
.home-final-cta {
  position: relative;
  background: var(--surface-black);
  color: var(--text-on-dark-primary);
  padding: var(--space-32) 0;
  text-align: center;
  overflow: hidden;
}
.home-final-cta::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 50% at 25% 30%, rgba(236, 26, 100, 0.18) 0%, transparent 60%),
    radial-gradient(ellipse 50% 50% at 80% 70%, rgba(173, 20, 79, 0.22) 0%, transparent 60%);
  pointer-events: none;
  z-index: 0;
}
.home-final-cta .container { position: relative; z-index: 1; }
.home-final-cta__eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--brand-primary);
  margin-bottom: var(--space-6);
}
.home-final-cta__title {
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 5vw + 1rem, 4.75rem);
  font-weight: var(--fw-medium);
  line-height: 1.1;
  letter-spacing: var(--tracking-tight);
  text-transform: uppercase;
  margin-bottom: var(--space-6);
  max-width: 18ch;
  margin-inline: auto;
}
.home-final-cta__subhead {
  font-size: var(--fs-body-lg);
  color: var(--text-on-dark-secondary);
  line-height: var(--lh-relaxed);
  max-width: 56ch;
  margin: 0 auto var(--space-10);
}
.home-final-cta__actions {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
  flex-wrap: wrap;
}
.home-final-cta__actions .btn { padding: 16px 32px; font-size: var(--fs-body); }

/* ============================================================
   SECTION 3 — Team / capability statement (black)
   ============================================================ */
.home-team-section {
  background: var(--surface-black);
  color: var(--text-on-dark-primary);
  padding: var(--space-32) 0;
}
.home-team__grid {
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: var(--space-16);
  align-items: start;
}
.home-team__intro h2 {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 2.5vw + 1rem, 2.75rem);
  font-weight: var(--fw-regular);
  line-height: 1.25;
  margin-bottom: var(--space-6);
}
.home-team__intro p {
  font-size: var(--fs-body);
  color: var(--text-on-dark-secondary);
  line-height: var(--lh-relaxed);
  margin-bottom: var(--space-8);
}
.home-team__cta {
  border-color: var(--brand-primary);
  color: var(--brand-primary);
}
.home-team__cta:hover {
  background: var(--brand-primary);
  color: var(--brand-white);
}

.home-team__tiles {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-10);
}
.home-team__tile {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  transition: transform var(--duration-base) var(--ease-out);
}
.home-team__tile:hover { transform: translateY(-4px); }
.home-team__tile-icon {
  width: 56px;
  height: 56px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--text-on-dark-primary);
  transition: transform var(--duration-base) var(--ease-out);
}
.home-team__tile:hover .home-team__tile-icon { transform: translateY(-2px); }
.home-team__tile-icon svg {
  width: 100%;
  height: 100%;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.home-team__tile-title {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  font-weight: var(--fw-medium);
  color: var(--brand-primary);
}
.home-team__tile-body {
  font-size: var(--fs-body-sm);
  color: var(--text-on-dark-secondary);
  line-height: var(--lh-relaxed);
}

@media (max-width: 960px) {
  .home-team__grid { grid-template-columns: 1fr; gap: var(--space-10); }
  .home-team__tiles { gap: var(--space-8); }
}
@media (max-width: 600px) {
  .home-team__tiles { grid-template-columns: 1fr; }
}

/* ============================================================
   SECTION 4 — Content that Captivates (white)
   ============================================================ */
.home-content-section {
  background: var(--surface-white);
  color: var(--text-on-light-primary);
  padding: var(--space-32) 0 var(--space-24);
}
.home-content__intro {
  margin-bottom: var(--space-16);
  max-width: 880px;
}
.home-content__eyebrow {
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--text-on-light-primary);
  margin-bottom: var(--space-4);
  display: block;
}
.home-content__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw + 0.5rem, 3.75rem);
  font-weight: var(--fw-regular);
  line-height: 1.1;
  letter-spacing: var(--tracking-tight);
  margin-bottom: var(--space-6);
}
.home-content__subhead {
  font-size: var(--fs-body-lg);
  line-height: var(--lh-relaxed);
  color: var(--text-on-light-secondary);
  max-width: 720px;
}
.home-content__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-8);
}
.home-content__card {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  text-decoration: none;
  color: inherit;
  transition: transform var(--duration-base) var(--ease-out);
}
.home-content__card:hover { transform: translateY(-4px); }
.home-content__card-image {
  aspect-ratio: 4 / 3;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--surface-off-white);
  margin-bottom: var(--space-2);
}
.home-content__card-image img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform var(--duration-slow) var(--ease-out);
  display: block;
}
/* Same fallback pattern as the capability cards: hide the empty
   <img> until admin sets a real src so the wrapper's gradient
   shows through cleanly on first load. */
.home-content__card-image img:not([src]),
.home-content__card-image img[src=""] { display: none; }
.home-content__card:hover .home-content__card-image img { transform: scale(1.04); }
.home-content__card-label {
  position: relative;
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--text-on-light-primary);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--surface-card-border);
  display: block;
}
.home-content__card-title {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  font-weight: var(--fw-medium);
  color: var(--brand-primary);
  line-height: 1.25;
}
.home-content__card-body {
  font-size: var(--fs-body);
  color: var(--text-on-light-secondary);
  line-height: var(--lh-relaxed);
}

@media (max-width: 900px) {
  .home-content__grid { grid-template-columns: 1fr; }
}

/* ============================================================
   Home — Partner Network teaser
   ============================================================ */
.home-partner-network {
  background: var(--surface-white);
  color: var(--text-on-light-primary);
  padding: var(--section-py) 0;
  border-top: 1px solid var(--surface-card-border);
}
.home-partner-network__intro {
  text-align: center;
  max-width: 760px;
  margin: 0 auto var(--space-12);
}
.home-partner-network__eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.16em;
  color: var(--brand-primary);
  text-transform: uppercase;
  margin-bottom: var(--space-4);
}
.home-partner-network__title {
  font-family: var(--font-display);
  font-size: clamp(1.85rem, 3vw + 0.5rem, 2.75rem);
  font-weight: var(--fw-medium);
  line-height: 1.15;
  letter-spacing: var(--tracking-tight);
  margin: 0;
}
.home-partner-network__subhead {
  font-family: var(--font-body);
  font-size: var(--fs-body-lg);
  color: var(--text-on-light-secondary);
  line-height: 1.55;
  margin: var(--space-5) 0 0;
}
.home-partner-network__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  margin-bottom: var(--space-10);
}
.partner-mini-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: var(--space-7) var(--space-6);
  background: linear-gradient(135deg, #FFFFFF 0%, #FFF6FA 100%);
  border: 1px solid var(--surface-card-border);
  border-radius: var(--radius-md, 16px);
  text-align: center;
  transition: transform 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}
.partner-mini-card:hover {
  transform: translateY(-3px);
  border-color: rgba(236, 26, 100, 0.28);
  box-shadow: 0 16px 36px -22px rgba(236, 26, 100, 0.28);
}
.partner-mini-card__name {
  font-family: var(--font-display);
  font-size: clamp(1.15rem, 1.4vw + 0.6rem, 1.4rem);
  font-weight: var(--fw-semibold);
  color: var(--text-on-light-primary);
  letter-spacing: -0.01em;
}
.partner-mini-card__category {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-on-light-secondary);
  letter-spacing: 0.01em;
}
.home-partner-network__cta {
  text-align: center;
}
@media (max-width: 900px) {
  .home-partner-network__grid { grid-template-columns: 1fr; max-width: 460px; margin-left: auto; margin-right: auto; margin-bottom: var(--space-8); }
}

/* ============================================================
   AI-Enhanced Content Workflows — interactive supporting card
   Floating orbs, pulsing rings, twinkling sparkles, animated
   gradient sheen. All effects respect prefers-reduced-motion.
   ============================================================ */
.home-content__ai-card {
  margin-top: var(--space-10);
}
.home-content__ai-card-inner {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--space-6);
  padding: var(--space-7) var(--space-8);
  background:
    radial-gradient(circle at 0% 0%, rgba(236, 26, 100, 0.06) 0%, transparent 35%),
    radial-gradient(circle at 100% 100%, rgba(173, 20, 79, 0.05) 0%, transparent 40%),
    linear-gradient(135deg, #FFFFFF 0%, #FFF7FB 60%, #FFEEF6 100%);
  background-size: 100% 100%, 100% 100%, 200% 200%;
  background-position: 0% 0%, 100% 100%, 0% 0%;
  border: 1px solid rgba(236, 26, 100, 0.14);
  border-radius: var(--radius-lg, 18px);
  text-decoration: none;
  color: inherit;
  overflow: hidden;
  transition: transform 0.35s var(--ease-out, ease), box-shadow 0.35s var(--ease-out, ease), border-color 0.35s var(--ease-out, ease);
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.02);
  animation: aiCardGradient 12s ease-in-out infinite;
}
@keyframes aiCardGradient {
  0%, 100% { background-position: 0% 0%, 100% 100%, 0% 0%; }
  50%      { background-position: 0% 0%, 100% 100%, 100% 100%; }
}
.home-content__ai-card-inner::before {
  /* Subtle sheen sweep on hover only */
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(115deg, transparent 35%, rgba(236, 26, 100, 0.08) 50%, transparent 65%);
  transform: translateX(-100%);
  transition: transform 0.9s var(--ease-out, ease);
  pointer-events: none;
  z-index: 0;
}
.home-content__ai-card-inner:hover {
  transform: translateY(-3px);
  border-color: rgba(236, 26, 100, 0.32);
  box-shadow: 0 22px 48px -22px rgba(236, 26, 100, 0.32);
}
.home-content__ai-card-inner:hover::before {
  transform: translateX(100%);
}

/* Decorative floating orbs in the background */
.home-content__ai-card-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(20px);
  opacity: 0.55;
  pointer-events: none;
  z-index: 0;
}
.home-content__ai-card-orb--1 {
  width: 120px; height: 120px;
  left: 6%; top: -30px;
  background: radial-gradient(circle, rgba(236, 26, 100, 0.55) 0%, transparent 70%);
  animation: aiOrbFloat1 9s ease-in-out infinite;
}
.home-content__ai-card-orb--2 {
  width: 90px; height: 90px;
  right: 18%; bottom: -25px;
  background: radial-gradient(circle, rgba(173, 20, 79, 0.45) 0%, transparent 70%);
  animation: aiOrbFloat2 11s ease-in-out infinite;
}
.home-content__ai-card-orb--3 {
  width: 70px; height: 70px;
  right: 4%; top: 14%;
  background: radial-gradient(circle, rgba(255, 105, 160, 0.4) 0%, transparent 70%);
  animation: aiOrbFloat3 7s ease-in-out infinite;
}
@keyframes aiOrbFloat1 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50%      { transform: translate(18px, 14px) scale(1.06); }
}
@keyframes aiOrbFloat2 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50%      { transform: translate(-22px, -10px) scale(0.94); }
}
@keyframes aiOrbFloat3 {
  0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.4; }
  50%      { transform: translate(8px, -12px) scale(1.1); opacity: 0.65; }
}

/* Icon container with pulsing rings */
.home-content__ai-card-icon {
  position: relative;
  width: 60px;
  height: 60px;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--brand-primary);
  background: rgba(236, 26, 100, 0.10);
  flex-shrink: 0;
  z-index: 1;
}
.home-content__ai-card-icon-ring {
  position: absolute;
  inset: 0;
  border-radius: 16px;
  border: 1.5px solid rgba(236, 26, 100, 0.5);
  opacity: 0;
  animation: aiRingPulse 2.6s ease-out infinite;
}
.home-content__ai-card-icon-ring--2 { animation-delay: 1.3s; }
@keyframes aiRingPulse {
  0%   { transform: scale(1);    opacity: 0.6; }
  80%  { transform: scale(1.45); opacity: 0; }
  100% { transform: scale(1.45); opacity: 0; }
}
.home-content__ai-card-icon-svg {
  width: 30px;
  height: 30px;
  position: relative;
  z-index: 2;
  animation: aiIconFloat 4.5s ease-in-out infinite;
}
@keyframes aiIconFloat {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-3px); }
}
.ai-spark {
  transform-origin: center;
  transform-box: fill-box;
}
.ai-spark--main {
  animation: aiSparkMain 3.2s ease-in-out infinite;
}
.ai-spark--small {
  animation: aiSparkSmall 2.4s ease-in-out infinite;
  animation-delay: 0.6s;
}
@keyframes aiSparkMain {
  0%, 100% { transform: scale(1)    rotate(0deg);   opacity: 1; }
  50%      { transform: scale(1.08) rotate(8deg);   opacity: 0.85; }
}
@keyframes aiSparkSmall {
  0%, 100% { transform: scale(0.9) rotate(0deg);    opacity: 0.7; }
  50%      { transform: scale(1.2) rotate(-12deg);  opacity: 1; }
}

.home-content__ai-card-text {
  position: relative;
  z-index: 1;
}
.home-content__ai-card-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.14em;
  color: var(--brand-primary);
  text-transform: uppercase;
  margin-bottom: 6px;
}
.home-content__ai-card-label-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--brand-primary);
  box-shadow: 0 0 0 0 rgba(236, 26, 100, 0.6);
  animation: aiDotPulse 1.8s ease-out infinite;
}
@keyframes aiDotPulse {
  0%   { box-shadow: 0 0 0 0   rgba(236, 26, 100, 0.55); }
  70%  { box-shadow: 0 0 0 8px rgba(236, 26, 100, 0); }
  100% { box-shadow: 0 0 0 0   rgba(236, 26, 100, 0); }
}
.home-content__ai-card-title {
  font-family: var(--font-display);
  font-size: clamp(20px, 2vw, 24px);
  font-weight: var(--fw-semibold);
  color: var(--text-on-light-primary);
  margin: 0 0 6px;
  letter-spacing: -0.01em;
  position: relative;
}
.home-content__ai-card-body {
  font-size: 15px;
  color: var(--text-on-light-secondary);
  line-height: var(--lh-relaxed);
  margin: 0;
}
.home-content__ai-card-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: var(--fw-semibold);
  color: var(--brand-primary);
  white-space: nowrap;
  position: relative;
  z-index: 1;
}
.home-content__ai-card-cta-arrow {
  display: inline-flex;
  transition: transform 0.3s var(--ease-out, ease);
}
.home-content__ai-card-inner:hover .home-content__ai-card-cta-arrow {
  transform: translateX(4px);
}
.home-content__ai-card-inner:hover .home-content__ai-card-icon {
  background: rgba(236, 26, 100, 0.15);
}

@media (max-width: 720px) {
  .home-content__ai-card-inner {
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto;
    text-align: left;
    padding: var(--space-6);
    gap: var(--space-4);
  }
  .home-content__ai-card-icon { grid-row: 1; }
  .home-content__ai-card-text { grid-row: 1; grid-column: 2; }
  .home-content__ai-card-cta {
    grid-row: 2;
    grid-column: 1 / -1;
    justify-self: start;
  }
}

@media (prefers-reduced-motion: reduce) {
  .home-content__ai-card-inner,
  .home-content__ai-card-orb--1,
  .home-content__ai-card-orb--2,
  .home-content__ai-card-orb--3,
  .home-content__ai-card-icon-ring,
  .home-content__ai-card-icon-svg,
  .ai-spark--main,
  .ai-spark--small,
  .home-content__ai-card-label-dot {
    animation: none !important;
  }
}

/* ============================================================
   SECTION 5 — Client logo marquee (black)
   ============================================================ */
.home-marquee-section {
  background: var(--surface-black);
  color: var(--text-on-dark-primary);
  padding: var(--space-24) 0 0;
  overflow: hidden;
}
.home-marquee__header {
  text-align: center;
  margin-bottom: var(--space-16);
  max-width: 880px;
  margin-inline: auto;
}
.home-marquee__eyebrow {
  display: block;
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--text-on-dark-primary);
  margin-bottom: var(--space-4);
}
.home-marquee__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3vw + 1rem, 3rem);
  font-weight: var(--fw-regular);
  line-height: 1.15;
  margin-bottom: var(--space-6);
}
.home-marquee__subhead {
  font-size: var(--fs-body);
  color: var(--text-on-dark-secondary);
  line-height: var(--lh-relaxed);
}
.home-marquee__growth-label {
  text-align: center;
  font-family: var(--font-body);
  font-size: var(--fs-body-sm);
  color: var(--text-on-dark-secondary);
  margin-bottom: var(--space-8);
}

/* The actual scrolling marquee */
.marquee {
  width: 100%;
  overflow: hidden;
  position: relative;
  -webkit-mask-image: linear-gradient(90deg, transparent 0, black 8%, black 92%, transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0, black 8%, black 92%, transparent 100%);
}
.marquee__track {
  display: inline-flex;
  width: max-content;
  animation: marquee-scroll 25s linear infinite;
  gap: var(--space-16);
  align-items: center;
  /* Force GPU acceleration for the animated transform */
  will-change: transform;
  transform: translate3d(0, 0, 0);
}
.marquee__item {
  flex-shrink: 0;
  height: 60px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  /* Item is now an <a> so admin-supplied client URLs work — strip the
     default link styling that would otherwise underline the text fallback
     and tint it blue. */
  color: inherit;
  text-decoration: none;
}
/* Image logos display in their original brand colors at full opacity.
   No filter, no hover swap — the marquee scrolls continuously and every
   logo is always recognizable. translateZ(0) keeps the GPU compositor
   happy with the animated parent track. */
.marquee__item img {
  height: 100%;
  width: auto;
  max-width: 180px;
  object-fit: contain;
  transform: translateZ(0);
}
.marquee__item img:not([src]),
.marquee__item img[src=""] { display: none; }
.marquee__item img[src] + .marquee__item--text { display: none; }
/* Text fallback when no logo image is uploaded yet:
   clearly-visible medium gray by default, brand pink on hover.
   Mirrors the gray→color story the image filter does. */
.marquee__item--text {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: var(--fw-bold);
  letter-spacing: 0.05em;
  color: rgba(255, 255, 255, 0.6);
  white-space: nowrap;
  padding: 0 var(--space-4);
  transition: color var(--duration-base) var(--ease-out);
}
.marquee__item:hover .marquee__item--text,
.marquee__item.marquee__item--text:hover {
  color: var(--brand-primary);
}

@keyframes marquee-scroll {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

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

/* ============================================================
   SECTION 6 — FAQ (white)
   ============================================================ */
.home-faq-section {
  background: var(--surface-white);
  color: var(--text-on-light-primary);
  padding: var(--space-16) 0 var(--space-20);
}
.home-faq__grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--space-12);
  align-items: start;
}
.home-faq__left {
  position: sticky;
  top: 90px;
}
.home-faq__left h2 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 3vw + 1rem, 3rem);
  font-weight: var(--fw-regular);
  line-height: 1.15;
  margin-bottom: var(--space-6);
}
.home-faq__eyebrow {
  display: block;
  font-family: var(--font-body);
  font-size: var(--fs-eyebrow);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  margin-bottom: var(--space-4);
}
/* Image blob removed — no longer rendered. Kept rule for safety. */
.home-faq__image {
  display: none;
}
.home-faq__intro {
  font-size: var(--fs-body);
  color: var(--text-on-light-secondary);
  line-height: var(--lh-relaxed);
  margin-bottom: var(--space-6);
}

@media (max-width: 960px) {
  .home-faq__grid { grid-template-columns: 1fr; gap: var(--space-8); }
  .home-faq__left { position: static; }
}

/* ============================================================
   PAGE-LEVEL: ensure fixed nav doesn't push hero down
   ============================================================ */
body.home main { padding-top: 0; }
