/* Framer-style theme tokens and components */
:root {
  --fr-bg: #050403;
  --fr-surface: #080705;
  --fr-elev: #0c0b08;
  --fr-text: #F5F4F4;
  --fr-muted: #b8b8bf;
  --fr-border: rgba(255,255,255,0.08);
  --fr-border-strong: rgba(255,255,255,0.14);
  --fr-accent: #d8ac0e; /* brand yellow */
  --fr-radius: 16px;
  --fr-radius-lg: 20px;
  --fr-gap: 24px;
  --fr-gap-lg: 40px;
  --fr-shadow: 0 10px 30px rgba(16, 16, 15, 0.35);
  --vh-section-space: 80px;
  --vh-editorial-bg: #070706;
  --vh-editorial-panel: rgba(18, 18, 16, 0.76);
  --vh-editorial-line: rgba(253, 250, 240, 0.16);
  --vh-editorial-line-strong: rgba(216, 172, 14, 0.38);
  --vh-editorial-text: #f7f2e7;
  --vh-editorial-muted: rgba(247, 242, 231, 0.68);
}

/* Base surface */
body {
  background: var(--fr-bg);
  color: var(--fr-text);
}

/* About-inspired editorial system for primary subpages */
body.vh-editorial-page {
  background: var(--vh-editorial-bg) !important;
  color: var(--vh-editorial-text);
  font-family: var(--vh-font-body, 'Satoshi', sans-serif) !important;
  overflow-x: hidden;
}

body.vh-editorial-page main,
body.vh-editorial-page #main-content {
  display: block;
  width: 100%;
  min-height: auto;
  padding: 0;
}

body.vh-editorial-page [data-aos] {
  opacity: 1 !important;
  transform: none !important;
}

body.vh-editorial-page .vh-page-hero,
body.vh-editorial-page .fr-hero--full {
  position: relative;
  min-height: min(92vh, 900px) !important;
  margin: 0 !important;
  overflow: hidden;
  border-top: 0 !important;
  border-bottom: 1px solid var(--vh-editorial-line) !important;
  background: #050504;
}

body.vh-editorial-page .vh-page-hero__media,
body.vh-editorial-page .fr-hero--full .fr-hero-media {
  position: absolute;
  inset: 0;
}

body.vh-editorial-page .vh-page-hero__video,
body.vh-editorial-page .fr-hero--full .fr-hero-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: 0.72;
  filter: saturate(0.82) contrast(1.06);
}

body.vh-editorial-page .vh-page-hero__overlay,
body.vh-editorial-page .fr-hero-overlay {
  position: relative;
  z-index: 1;
  min-height: min(92vh, 900px) !important;
  display: flex;
  align-items: flex-end;
  padding: clamp(130px, 16vh, 210px) 0 clamp(48px, 8vh, 88px) !important;
  background:
    linear-gradient(180deg, rgba(7, 7, 6, 0.22) 0%, rgba(7, 7, 6, 0.48) 48%, rgba(7, 7, 6, 0.96) 100%),
    radial-gradient(80% 70% at 50% 34%, transparent 0%, rgba(7, 7, 6, 0.44) 72%) !important;
}

body.vh-editorial-page .fr-hero-overlay .fr-container {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

body.vh-editorial-page .vh-page-hero__copy,
body.vh-editorial-page .fr-hero--full .fr-hero-copy {
  max-width: 980px !important;
  margin: 0;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

body.vh-editorial-page .vh-page-hero__eyebrow,
body.vh-editorial-page .work-eyebrow,
body.vh-editorial-page .pill {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 18px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  color: var(--fr-accent) !important;
  background: transparent !important;
  font-family: var(--vh-font-body, 'Satoshi', sans-serif);
  font-size: 0.76rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.18em !important;
  line-height: 1.2;
  text-transform: uppercase;
}

body.vh-editorial-page .vh-page-hero__eyebrow::before,
body.vh-editorial-page .work-eyebrow::before,
body.vh-editorial-page .pill::before {
  content: "";
  width: 40px;
  height: 1px;
  background: currentColor;
}

body.vh-editorial-page .vh-page-hero__title,
body.vh-editorial-page .work-page-title {
  max-width: 980px;
  margin: 0 !important;
  color: var(--vh-editorial-text) !important;
  font-family: var(--vh-font-heading, 'Montserrat', sans-serif);
  font-size: clamp(3.3rem, 10.8vw, 9.4rem) !important;
  font-weight: 800;
  line-height: 0.86 !important;
  letter-spacing: -0.085em !important;
  text-wrap: balance;
  text-shadow: 0 18px 54px rgba(0, 0, 0, 0.72) !important;
  overflow-wrap: break-word;
}

body.vh-editorial-page .vh-page-hero__lead,
body.vh-editorial-page .work-hero-lead,
body.vh-editorial-page .blog-hero p {
  max-width: 740px !important;
  margin: clamp(22px, 3vw, 34px) 0 0 !important;
  color: rgba(253, 250, 240, 0.82) !important;
  font-size: clamp(1.05rem, 1.9vw, 1.4rem) !important;
  line-height: 1.45 !important;
  text-shadow: 0 2px 18px rgba(0, 0, 0, 0.6);
}

body.vh-editorial-page .vh-partner-proof__card {
  box-sizing: border-box;
}

body.vh-editorial-page .vh-partner-proof__title,
body.vh-editorial-page .vh-partner-proof__text {
  overflow-wrap: anywhere;
}

body.vh-editorial-page .blog-hero.vh-page-hero {
  width: min(1160px, calc(100% - 32px));
  min-height: auto !important;
  margin: 0 auto !important;
  padding: clamp(150px, 18vh, 220px) 0 clamp(58px, 8vw, 110px);
  border-bottom: 1px solid var(--vh-editorial-line) !important;
  background: transparent;
  text-align: left;
}

body.vh-editorial-page .blog-hero h1 {
  max-width: 980px;
}

body.vh-editorial-page .blog-hero p {
  text-align: left;
}

body.vh-editorial-page .work-hero-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  width: min(100%, 980px);
  margin-top: clamp(28px, 5vw, 54px) !important;
  padding: 0;
  overflow: hidden;
  border: 1px solid var(--vh-editorial-line);
  border-radius: 24px;
  background: rgba(253, 250, 240, 0.1);
  box-shadow: 0 30px 90px rgba(0, 0, 0, 0.36);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

body.vh-editorial-page .work-hero-metrics li {
  display: flex;
  align-items: center;
  min-height: 96px;
  margin: 0;
  padding: clamp(16px, 2.2vw, 24px);
  border: 0;
  border-radius: 0;
  color: var(--vh-editorial-text);
  background: rgba(7, 7, 6, 0.58);
  font-size: clamp(1rem, 1.7vw, 1.2rem);
  font-weight: 800;
  line-height: 1.15;
}

body.vh-editorial-page .vh-section,
body.vh-editorial-page .blog-start,
body.vh-editorial-page .blog-grid {
  padding-top: clamp(64px, 10vw, 120px);
  padding-bottom: clamp(64px, 10vw, 120px);
}

body.vh-editorial-page .bento-item,
body.vh-editorial-page .vh-content-panel,
body.vh-editorial-page .vh-info-card,
body.vh-editorial-page .vh-route-card,
body.vh-editorial-page .vh-process-card,
body.vh-editorial-page .work-item,
body.vh-editorial-page .work-post-cta,
body.vh-editorial-page .blog-start__panel,
body.vh-editorial-page .blog-start__card,
body.vh-editorial-page .blog-card,
body.vh-editorial-page .card {
  border: 1px solid var(--vh-editorial-line) !important;
  border-radius: 30px !important;
  background: rgba(18, 18, 16, 0.86) !important;
  box-shadow: 0 28px 80px rgba(0, 0, 0, 0.28) !important;
}

body.vh-editorial-page .work-item,
body.vh-editorial-page .blog-card,
body.vh-editorial-page .card {
  overflow: hidden;
}

body.vh-editorial-page .bento-item:hover,
body.vh-editorial-page .vh-route-card:hover,
body.vh-editorial-page .work-item:hover,
body.vh-editorial-page .blog-start__card:hover,
body.vh-editorial-page .blog-card:hover,
body.vh-editorial-page .card:hover {
  transform: translateY(-6px);
  border-color: var(--vh-editorial-line-strong) !important;
  box-shadow: 0 34px 92px rgba(0, 0, 0, 0.42) !important;
}

body.vh-editorial-page .vh-content-panel h2,
body.vh-editorial-page .work-post-cta h2,
body.vh-editorial-page .blog-start__copy h2,
body.vh-editorial-page .blog-hero h1 {
  margin: 0;
  color: var(--vh-editorial-text) !important;
  font-family: var(--vh-font-heading, 'Montserrat', sans-serif);
  font-size: clamp(2rem, 4.6vw, 4.8rem) !important;
  line-height: 0.96 !important;
  letter-spacing: -0.055em !important;
  text-wrap: balance;
}

body.vh-editorial-page .vh-content-panel h2,
body.vh-editorial-page .work-post-cta h2,
body.vh-editorial-page .blog-start__copy h2 {
  margin-bottom: clamp(12px, 1.8vw, 20px) !important;
  line-height: 1.02 !important;
}

body.vh-editorial-page .vh-content-panel > p,
body.vh-editorial-page .vh-info-card p,
body.vh-editorial-page .vh-route-card p,
body.vh-editorial-page .vh-process-card p,
body.vh-editorial-page .work-item p,
body.vh-editorial-page .work-post-cta p,
body.vh-editorial-page .blog-start__copy p,
body.vh-editorial-page .blog-start__card span,
body.vh-editorial-page .blog-card p,
body.vh-editorial-page .card p,
body.vh-editorial-page .card li {
  color: var(--vh-editorial-muted) !important;
}

body.vh-editorial-page .vh-route-card .vh-btn,
body.vh-editorial-page .blog-start__card,
body.vh-editorial-page .blog-card__title,
body.vh-editorial-page .work-item h2 {
  max-width: 100%;
  overflow-wrap: break-word;
}

body.vh-editorial-page .vh-route-card .vh-btn {
  white-space: normal;
  text-align: center;
}

body.vh-editorial-page .vh-media-section {
  border-color: var(--vh-editorial-line) !important;
  border-radius: 30px !important;
  min-height: clamp(520px, 56vw, 780px);
  overflow: hidden;
}

body.vh-editorial-page .vh-media-section__overlay {
  position: relative;
  z-index: 1;
  min-height: inherit !important;
  box-sizing: border-box;
  align-items: flex-end !important;
  padding: clamp(34px, 6vw, 76px) 0 !important;
  background:
    radial-gradient(92% 88% at 28% 84%, rgba(7, 7, 6, 0.92) 0%, rgba(7, 7, 6, 0.62) 34%, rgba(7, 7, 6, 0.28) 58%, rgba(7, 7, 6, 0) 82%),
    radial-gradient(118% 104% at 0% 100%, rgba(7, 7, 6, 0.54) 0%, rgba(7, 7, 6, 0.18) 42%, rgba(7, 7, 6, 0) 68%) !important;
}

body.vh-no-video-scrim .vh-media-section__overlay {
  background: transparent !important;
}

body.vh-no-video-scrim .vh-page-hero__overlay,
body.vh-no-video-scrim .fr-hero-overlay {
  background: transparent !important;
}

body.vh-no-video-scrim .vh-partner-proof__card {
  background: rgba(7, 7, 6, 0.82) !important;
}

body.vh-no-video-scrim .vh-media-section .hero-title {
  font-size: clamp(2rem, 4.8vw, 5rem) !important;
  line-height: 1 !important;
  letter-spacing: -0.055em !important;
}

body.vh-no-video-scrim .vh-media-section .hero-subtext {
  max-width: 48ch !important;
  line-height: 1.45 !important;
}

body.vh-editorial-page .vh-media-section .bento-item {
  max-width: 740px;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

body.vh-editorial-page .vh-media-section .hero-title {
  font-size: clamp(2.6rem, 7vw, 6.6rem) !important;
  line-height: 0.9 !important;
  letter-spacing: -0.07em;
}

body.vh-editorial-page .vh-media-section .hero-subtext {
  max-width: 56ch;
  color: rgba(253, 250, 240, 0.82) !important;
  font-size: clamp(1rem, 1.5vw, 1.16rem) !important;
  text-shadow: 0 2px 18px rgba(0, 0, 0, 0.92);
}

body.vh-editorial-page .work-item::before {
  content: none !important;
}

.vh-mobile-break {
  display: none;
}

@media (max-width: 640px) {
  body.vh-editorial-page header.burger-header {
    padding: 0 10px;
  }
  body.vh-editorial-page .burger-container {
    width: 100%;
  }
  body.vh-editorial-page .vh-container,
  body.vh-editorial-page .fr-container {
    width: 100%;
    max-width: 100%;
    padding-left: 16px;
    padding-right: 16px;
  }
  body.vh-editorial-page .section-grid,
  body.vh-editorial-page .vh-page-hero__copy,
  body.vh-editorial-page .vh-media-section .bento-item,
  body.vh-editorial-page .vh-partner-proof,
  body.vh-editorial-page .vh-partner-proof__card,
  body.vh-editorial-page .vh-partner-proof__content {
    min-width: 0;
    max-width: 100% !important;
  }
  body.vh-editorial-page .vh-page-hero__lead,
  body.vh-editorial-page .vh-media-section .hero-subtext,
  body.vh-editorial-page .vh-partner-proof__text {
    overflow-wrap: break-word;
  }
  body.vh-editorial-page .vh-page-hero,
  body.vh-editorial-page .fr-hero--full {
    min-height: min(84svh, 760px) !important;
  }
  body.vh-editorial-page .vh-page-hero__overlay,
  body.vh-editorial-page .fr-hero-overlay {
    min-height: min(84svh, 760px) !important;
    padding: clamp(120px, 25vh, 170px) 0 clamp(42px, 10vh, 76px) !important;
  }
  body.vh-editorial-page .vh-page-hero__title,
  body.vh-editorial-page .work-page-title {
    font-size: clamp(2.25rem, 11vw, 4.1rem) !important;
    line-height: 0.9 !important;
    letter-spacing: -0.08em !important;
  }
  .vh-mobile-break {
    display: initial;
  }
  body.vh-editorial-page .vh-page-hero__lead,
  body.vh-editorial-page .work-hero-lead,
  body.vh-editorial-page .blog-hero p {
    max-width: 31ch !important;
    font-size: 1rem !important;
  }
  body.vh-editorial-page .blog-hero.vh-page-hero {
    width: min(100% - 28px, 1160px);
    padding-top: clamp(136px, 22vh, 180px);
  }
  body.vh-editorial-page .work-hero-metrics {
    grid-template-columns: 1fr;
  }
  body.vh-editorial-page .work-hero-metrics li {
    min-height: auto;
  }
  body.vh-editorial-page .vh-section,
  body.vh-editorial-page .blog-start,
  body.vh-editorial-page .blog-grid {
    padding-top: 58px;
    padding-bottom: 58px;
  }
  body.vh-editorial-page .vh-content-panel,
  body.vh-editorial-page .work-item,
  body.vh-editorial-page .work-post-cta,
  body.vh-editorial-page .blog-start__panel,
  body.vh-editorial-page .blog-card,
  body.vh-editorial-page .card {
    border-radius: 24px !important;
  }
  body.vh-editorial-page .vh-media-section .hero-title {
    font-size: clamp(2rem, 10vw, 3rem) !important;
  }
}

/* Container + sections */
.fr-container, .vh-container { max-width: 1160px; margin: 0 auto; padding: 0 24px; }
.fr-section, .vh-section { padding: var(--vh-section-space) 0; }
.fr-hero { padding: 120px 0 72px; }
.fr-hero--full {
  position: relative;
  padding: 0;
  min-height: 100vh;
  overflow: hidden;
  display: flex;
  align-items: stretch;
}
.fr-hero--full .fr-hero-media {
  position: absolute;
  inset: 0;
  border-radius: 0;
  border: 0;
  box-shadow: none;
}
.fr-hero--full .fr-hero-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.fr-hero--full { margin-bottom: var(--vh-section-space); }
.fr-hero-overlay {
  position: relative;
  z-index: 1;
  width: 100%;
  flex: 1;
  display: flex;
  align-items: flex-end;
  background: linear-gradient(180deg, rgba(10,10,10,0.05) 0%, rgba(10,10,10,0.45) 55%, rgba(10,10,10,0.8) 100%);
}
.fr-hero-overlay .fr-container {
  width: 100%;
  padding-top: clamp(48px, 10vh, 120px);
  padding-bottom: clamp(48px, 12vh, 140px);
}
.fr-hero--full .fr-hero-copy {
  max-width: 520px;
}
@media (max-width: 640px) {
  .fr-hero-overlay {
    align-items: flex-end;
    background: linear-gradient(180deg, rgba(10,10,10,0.25) 0%, rgba(10,10,10,0.8) 100%);
  }
  .fr-hero-overlay .fr-container {
    padding-top: clamp(32px, 12vh, 72px);
    padding-bottom: clamp(40px, 14vh, 120px);
  }
}

.fr-media-cta {
  position: relative;
  min-height: 70vh;
  overflow: hidden;
  display: flex;
  align-items: stretch;
  margin: var(--vh-section-space) 0;
}
.fr-media-cta__media {
  position: absolute;
  inset: 0;
}
.fr-media-cta__video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.fr-media-cta__overlay {
  position: relative;
  z-index: 1;
  flex: 1;
  display: flex;
  align-items: center;
  background: linear-gradient(180deg, rgba(10,10,10,0.15) 0%, rgba(10,10,10,0.75) 65%, rgba(10,10,10,0.9) 100%);
}
.fr-media-cta__overlay .fr-container {
  width: 100%;
  padding-top: clamp(48px, 12vh, 120px);
  padding-bottom: clamp(48px, 12vh, 120px);
}
.fr-media-cta__copy {
  max-width: 680px;
  margin: 0 auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.fr-media-cta__copy--glass {
  max-width: 920px;
  background: linear-gradient(145deg, rgba(9, 9, 9, 0.55), rgba(9, 9, 9, 0.28));
  backdrop-filter: blur(6px);
  border: 1px solid rgba(253, 250, 240, 0.2);
  box-shadow: 0 30px 60px rgba(16, 16, 15, 0.42);
  border-radius: 22px;
  padding: clamp(18px, 3.4vw, 34px);
}
.fr-media-cta__copy .vh-subtitle {
  font-size: clamp(4rem, 9vw, 7.2rem) !important;
  font-weight: 500;
  color: #FDFAF0;
  letter-spacing: -0.02em;
  line-height: 1;
  text-shadow: 0 18px 54px rgba(16, 16, 15, 0.75);
}
.fr-media-cta__headline {
  font-size: clamp(4.4rem, 10vw, 8.2rem) !important;
  letter-spacing: -0.03em;
}
.fr-media-cta__headline--strong {
  text-shadow: 0 20px 60px rgba(16, 16, 15, 0.78);
  font-weight: 600;
}
.fr-media-cta__brand-lockup {
  display: inline-flex;
  align-items: center;
  gap: clamp(0.2em, 0.45vw, 0.4em);
  vertical-align: middle;
}
.fr-media-cta__brand-logo {
  height: clamp(0.84em, 1.22em, 1.18em);
  width: auto;
  vertical-align: middle;
}
.fr-media-cta__brand-logo--dazn {
  height: clamp(0.9em, 1.28em, 1.24em);
}
.fr-media-cta__brand-logo--qp {
  height: clamp(0.7em, 1.02em, 0.98em);
}
.fr-media-cta__brand-sep {
  display: inline-block;
  font-size: 0.58em;
  font-weight: 400;
  color: rgba(253, 250, 240, 0.88);
  line-height: 1;
  transform: translateY(-0.02em);
}
.fr-media-cta__copy .fr-buttons {
  justify-content: center;
}
.fr-media-cta__impact {
  text-wrap: balance;
}
.fr-media-cta--story .fr-media-cta__copy--glass {
  width: min(100%, 1120px);
  max-width: 1120px;
}
.fr-media-cta--story .fr-media-cta__embed {
  width: 100%;
  max-width: 920px;
  margin: 0 auto;
  aspect-ratio: 16 / 9;
}
.fr-media-cta--story .fr-media-cta__embed iframe {
  width: 100%;
  height: 100%;
  aspect-ratio: 16 / 9;
}
.fr-media-cta__embed,
.fr-media-cta__embed.recent-work__media,
.fr-media-cta__embed.recent-work__media--wide {
  width: 100%;
  max-width: 920px;
  margin: 0 auto;
  aspect-ratio: 16 / 9;
}
.fr-media-cta__embed iframe,
.fr-media-cta__embed .recent-work__frame {
  width: 100%;
  height: 100%;
  aspect-ratio: 16 / 9;
}
.fr-impact-key {
  display: inline-block;
  margin: 0 .1em;
  font-size: clamp(1.2em, 2.8vw, 1.7em);
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.02em;
  color: #fff4cf;
  text-shadow: 0 12px 28px rgba(16, 16, 15, 0.65);
  opacity: 0;
  transform: translateY(16px) scale(0.92);
  will-change: transform, opacity;
}
.fr-impact-key__num {
  display: inline-block;
  min-width: 0;
  text-align: left;
}
.fr-impact-key__suffix {
  margin-left: 0.12em;
}
section[data-aos].aos-animate .fr-impact-key {
  animation: fr-impact-pop 0.62s cubic-bezier(0.16, 0.9, 0.25, 1) forwards;
  animation-delay: var(--impact-delay, 0s);
}
@keyframes fr-impact-pop {
  0% {
    opacity: 0;
    transform: translateY(16px) scale(0.92);
  }
  62% {
    opacity: 1;
    transform: translateY(-2px) scale(1.04);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
@media (max-width: 768px) {
  .fr-media-cta {
    min-height: 60vh;
  }
  .fr-media-cta__overlay {
    background: linear-gradient(180deg, rgba(10,10,10,0.35) 0%, rgba(10,10,10,0.9) 100%);
  }
  .fr-media-cta__overlay .fr-container {
    padding-top: clamp(32px, 16vh, 88px);
    padding-bottom: clamp(32px, 16vh, 88px);
  }
  .fr-media-cta__copy {
    gap: 14px;
  }
}
@media (max-width: 640px) {
  .fr-media-cta {
    min-height: clamp(360px, 62svh, 480px);
    margin: 32px 0;
  }
  .fr-media-cta__overlay .fr-container {
    padding-top: 14px;
    padding-bottom: 14px;
  }
  .fr-media-cta__copy {
    max-width: 100%;
    gap: 10px;
    padding-inline: 8px;
  }
  .fr-media-cta__copy .fr-media-cta__headline {
    font-size: clamp(1.8rem, 8.8vw, 2.45rem) !important;
    line-height: 1.06 !important;
    letter-spacing: -0.02em !important;
    text-wrap: balance;
  }
  .fr-media-cta__brand-logo {
    height: 0.92em;
  }
  .fr-media-cta__brand-logo--dazn {
    height: 0.98em;
  }
  .fr-media-cta__brand-logo--qp {
    height: 0.78em;
  }
  .fr-media-cta__copy .vh-lead {
    font-size: 0.95rem;
    line-height: 1.4;
  }
  .fr-impact-key {
    font-size: 1.32em;
  }
  .fr-media-cta__copy--glass {
    border-radius: 16px;
    padding: 16px;
  }
  .fr-media-cta__copy .fr-buttons .vh-btn {
    width: 100%;
    max-width: 280px;
    text-align: center;
  }
}
@media (prefers-reduced-motion: reduce) {
  .fr-impact-key {
    opacity: 1;
    transform: none;
    animation: none !important;
  }
}

/* Typography */
.fr-eyebrow, .vh-eyebrow { color: var(--fr-muted); letter-spacing: .02em; font-weight: 600; margin: 0 0 8px 0; }
.fr-h1, .vh-title-xl { font-weight: 500; letter-spacing: -0.02em; line-height: 1.06; color: var(--fr-text); }
.fr-lead, .vh-lead { color: #d7d7dc; line-height: 1.65; font-size: clamp(1rem, 2.2vw, 1.15rem); }

/* Grid */
.fr-grid { display: grid; gap: var(--fr-gap); }
.fr-grid-2 { grid-template-columns: 1fr; }
.fr-grid-3 { grid-template-columns: 1fr; }
@media (min-width: 900px) {
  .fr-grid-2 { grid-template-columns: 1.1fr 0.9fr; align-items: center; }
  .fr-grid-3, .vh-cols-3 { grid-template-columns: repeat(3, 1fr); }
}
.service-panels {
  gap: clamp(18px, 3vw, 28px);
}
@media (max-width: 760px){
  .service-panels { grid-template-columns: 1fr; }
}


/* Service panels */
.service-panel{
  position:relative;
  display:flex;
  flex-direction:column;
  background:linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
  border:1px solid var(--fr-border);
  border-radius:var(--fr-radius-lg);
  overflow:hidden;
  min-height:320px;
  cursor:pointer;
  transition:transform .28s ease, border-color .28s ease, box-shadow .28s ease;
}
.service-panel::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(120% 80% at 0% 0%, rgba(216,172,14,0.12) 0%, rgba(216,172,14,0) 70%);
  opacity:0;
  transition:opacity .28s ease;
  pointer-events:none;
}
.service-panel__media{
  position:relative;
  width:100%;
  aspect-ratio:16 / 9;
  overflow:hidden;
  border-bottom:1px solid var(--fr-border);
  background:#0b0b0b;
}
.service-panel__video{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.service-panel__overlay{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:clamp(16px,2.4vw,22px);
  background:linear-gradient(180deg, rgba(16, 16, 15, 0) 45%, rgba(16, 16, 15, 0.65) 100%);
}
.service-panel__overlay h3{
  font-family:'Montserrat',sans-serif;
  font-size:clamp(1.4rem,2.6vw,1.7rem);
  margin:0;
  letter-spacing:-0.01em;
  text-shadow:0 8px 18px rgba(16, 16, 15, 0.55);
}
.service-panel__tag{
  margin:0;
  font-family:'Satoshi',sans-serif;
  color:var(--fr-muted);
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.85rem;
}
.service-panel__overlay .service-panel__tag{
  color:#f4f4f4;
  text-shadow:0 6px 14px rgba(16, 16, 15, 0.55);
}
.service-panel__body{
  padding:clamp(18px,2.6vw,26px);
  display:flex;
  flex-direction:column;
  gap:16px;
  flex:1;
}
.service-panel__body p{
  margin:0;
  color:#d9d9de;
  line-height:1.6;
}
.service-panel__body .vh-btn{
  align-self:flex-start;
  margin-top:auto;
}
.service-panel:hover,
.service-panel:focus-within{
  transform:translateY(-6px);
  border-color:var(--fr-border-strong);
  box-shadow:0 24px 44px rgba(16, 16, 15, 0.36);
}
.service-panel:hover::before,
.service-panel:focus-within::before{
  opacity:1;
}
.service-panel:hover h3,
.service-panel:focus-within h3{
  color:var(--fr-accent);
}

/* Phase 2: shared subpage components */
.vh-bento-grid{
  display:grid;
  gap:16px;
  grid-template-columns:1fr;
  align-items:start;
}
.vh-bento-item{
  --bento-warm: 255,138,0;
  --bento-cool: 20,184,166;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  padding:18px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,0.08);
  background:
    radial-gradient(140% 90% at 0% 0%, rgba(var(--bento-warm),0.14) 0%, rgba(var(--bento-warm),0.06) 32%, rgba(var(--bento-warm),0) 62%),
    radial-gradient(120% 80% at 100% 100%, rgba(var(--bento-cool),0.14) 0%, rgba(var(--bento-cool),0.06) 30%, rgba(var(--bento-cool),0) 60%),
    linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.02));
  box-shadow:0 10px 30px rgba(16, 16, 15, .35);
  position:relative;
  z-index:1;
}
.vh-bento-media{
  padding:0;
  overflow:hidden;
}
.vh-bento-media img,
.vh-bento-media video{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.vh-cta-band{
  background:var(--fr-accent, #d8ac0e);
  color:#10100F;
  border:1px solid rgba(16, 16, 15, 0.2);
}
.vh-cta-band a,
.vh-cta-band h3,
.vh-cta-band p{
  color:#10100F !important;
}

.vh-card-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:22px;
}
@media (min-width:768px){
  .vh-card-grid{
    grid-template-columns:repeat(3,1fr);
  }
}
.vh-card-grid .vh-card{
  background:#121212;
  border:1px solid #2a2a2a;
  border-radius:12px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:transform .22s ease, border-color .22s ease, box-shadow .22s ease;
}
.vh-card-grid .vh-card:hover{
  transform:translateY(-4px);
  border-color:var(--fr-border-strong);
  box-shadow:0 18px 34px rgba(16,16,15,.3);
}
.vh-card-grid .vh-card-media{
  width:100%;
  height:200px;
  object-fit:cover;
  display:block;
}
.vh-card-body{
  padding:16px 16px 18px;
}
.vh-card-title{
  font-family:'Montserrat',sans-serif;
  font-weight:800;
  font-size:1.05rem;
  margin:0 0 .35rem;
}
.vh-card-meta{
  font-family:'Satoshi',sans-serif;
  color:#9a9a9a;
  font-size:.85rem;
  margin:0 0 .5rem;
}
.vh-card-text{
  font-family:'Satoshi',sans-serif;
  color:#ddd;
  line-height:1.5;
  margin:0 0 .75rem;
}
.vh-card-link{
  font-weight:600;
  color:var(--fr-accent, #d8ac0e);
}

/* Phase 2b: shared blog article layout */
.vh-article-hero{
  padding:clamp(156px, 15vh, 190px) var(--vh-shell-pad-inline) 24px;
  max-width:1100px;
  margin:0 auto;
}
.vh-article-figure{
  max-width:1100px;
  margin:0 auto 28px;
  padding:0 var(--vh-shell-pad-inline);
}
.vh-article-body{
  max-width:840px;
  margin:0 auto;
  padding:0 var(--vh-shell-pad-inline) 60px;
  line-height:1.75;
  color:#ddd;
  font-family:'Satoshi',sans-serif;
}
.vh-article-hero,
.vh-article-figure,
.vh-article-body{
  width:100%;
  min-width:0;
}
.vh-article-body > *,
.vh-article-figure > *{
  max-width:100%;
}
.vh-article-body :where(h1, h2, h3, h4, h5, h6, p, li, a, figcaption, blockquote, td, th, code){
  overflow-wrap:anywhere;
}
.vh-article-body :where(img, iframe, video, table),
.vh-article-body :where(.twitter-tweet, .instagram-media){
  max-width:100%;
}
@media (max-width: 760px){
  .vh-article-hero{
    padding-top: clamp(126px, 18vh, 150px);
  }
  .vh-article-body{
    overflow-x:clip;
  }
  .vh-article-body :where(.twitter-tweet, .instagram-media){
    width:100% !important;
    min-width:0 !important;
  }
  .vh-article-body table{
    display:block;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }
}
.service-panel:hover .service-panel__tag,
.service-panel:focus-within .service-panel__tag{
  color:rgba(255,255,255,0.7);
}
@media (max-width:900px){
  .service-panel{ min-height:280px; }
}
@media (max-width:760px){
  .service-panel{ transform:none !important; }
  .service-panel::before{ opacity:1; }
}
@media (prefers-reduced-motion: reduce){
  .service-panel,
  .service-panel::before{ transition:none !important; }
  .service-panel{ transform:none !important; }
}

/* Glassy nav (Framer-like) - homepage only */
body.home-solid header.burger-header {
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  background: transparent;
  border-bottom: 0;
}

/* Cinematic scroll layers (homepage) */
body.home-solid .vh-scroll-ambience {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}
body.home-solid #main-content,
body.home-solid .vh-footer {
  position: relative;
  z-index: 1;
}
body.home-solid .vh-ambience-orb {
  position: absolute;
  border-radius: 999px;
  filter: blur(90px);
  opacity: 0.25;
  mix-blend-mode: screen;
  animation: vh-ambience-float 16s ease-in-out infinite alternate;
}
body.home-solid .vh-ambience-orb--one {
  width: clamp(260px, 34vw, 520px);
  height: clamp(260px, 34vw, 520px);
  top: -12%;
  left: -6%;
  background: radial-gradient(circle at 35% 35%, rgba(216, 172, 14, 0.4), rgba(216, 172, 14, 0));
}
body.home-solid .vh-ambience-orb--two {
  width: clamp(320px, 38vw, 620px);
  height: clamp(320px, 38vw, 620px);
  right: -12%;
  top: 22%;
  background: radial-gradient(circle at 40% 40%, rgba(128, 180, 255, 0.35), rgba(128, 180, 255, 0));
  animation-delay: 2.4s;
}
body.home-solid .vh-ambience-grid {
  position: absolute;
  inset: 0;
  opacity: 0.2;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.04) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: radial-gradient(circle at 50% 35%, rgba(255, 255, 255, 0.9), transparent 72%);
}
body.home-solid .vh-scroll-chapter {
  position: relative;
  opacity: 0.72;
  transform: translate3d(0, 34px, 0) scale(0.988);
  transition: opacity 0.9s ease, transform 0.9s cubic-bezier(0.2, 0.72, 0.2, 1);
  will-change: transform, opacity;
}
body.home-solid .vh-scroll-chapter.is-inview,
body.home-solid .vh-scroll-chapter--hero {
  opacity: 1;
  transform: none;
}
body.home-solid .vh-scroll-chapter::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.05), transparent 38%);
  opacity: 0;
  transition: opacity 0.7s ease;
}
body.home-solid .vh-scroll-chapter.is-inview::before {
  opacity: 0.7;
}
body.home-solid .vh-parallax-layer {
  transform: translate3d(0, var(--vh-parallax-y, 0), 0);
  will-change: transform;
}
body.home-solid .vh-parallax-layer video {
  transform: scale(1.12);
}
@keyframes vh-ambience-float {
  0% { transform: translate3d(0, 0, 0) scale(1); }
  100% { transform: translate3d(0, -42px, 0) scale(1.08); }
}
@media (max-width: 900px) {
  body.home-solid .vh-scroll-chapter {
    opacity: 1;
    transform: none;
  }
  body.home-solid .vh-scroll-chapter::before {
    opacity: 0.28;
  }
  body.home-solid .vh-ambience-orb {
    opacity: 0.16;
    filter: blur(72px);
  }
}
@media (prefers-reduced-motion: reduce) {
  body.home-solid .vh-ambience-orb {
    animation: none;
  }
  body.home-solid .vh-scroll-chapter,
  body.home-solid .vh-parallax-layer {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* Recent work */
.recent-work__header {
  max-width: 920px;
  margin: 0 auto 40px;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: clamp(18px, 3.4vw, 34px);
  border-radius: 22px;
  border: 1px solid rgba(253, 250, 240, 0.2);
  background: linear-gradient(145deg, rgba(9, 9, 9, 0.55), rgba(9, 9, 9, 0.28));
  backdrop-filter: blur(6px);
  box-shadow: 0 30px 60px rgba(16, 16, 15, 0.42);
}
.recent-work__grid {
  display: grid;
  gap: 28px;
  justify-content: center;
}
.recent-work__grid--four {
  grid-template-columns: 1fr;
}
.recent-work__duo-grid{
  display:grid;
  gap:24px;
}
.recent-work__card {
  border: 1px solid rgba(253, 250, 240, 0.2);
  border-radius: 22px;
  padding: clamp(14px, 2.2vw, 22px);
  background: linear-gradient(145deg, rgba(9, 9, 9, 0.55), rgba(9, 9, 9, 0.28));
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  box-shadow: 0 30px 60px rgba(16, 16, 15, 0.42);
  display: grid;
  gap: 20px;
  position: relative;
  overflow: hidden;
  transition: transform .32s ease, border-color .32s ease, box-shadow .32s ease;
}
.recent-work__card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(120deg, rgba(216, 172, 14, 0.16), transparent 46%);
  opacity: 0;
  transition: opacity .32s ease;
}
.recent-work__card:hover,
.recent-work__card:focus-within {
  transform: translateY(-6px);
  border-color: rgba(216, 172, 14, 0.5);
  box-shadow: 0 30px 58px rgba(16, 16, 15, 0.48);
}
.recent-work__card:hover::before,
.recent-work__card:focus-within::before {
  opacity: 1;
}
.recent-work__media {
  border-radius: 16px;
  border: 1px solid rgba(253, 250, 240, 0.14);
  overflow: hidden;
  background: #050505;
  box-shadow: inset 0 0 0 1px rgba(16, 16, 15, 0.2);
}
.recent-work__frame {
  width: 100%;
  aspect-ratio: 9 / 16;
  border: 0;
  display: block;
}
.recent-work__card--wide .recent-work__frame,
.recent-work__frame--wide {
  aspect-ratio: 16 / 9;
}
.recent-work__card--wide .recent-work__media,
.recent-work__media--wide {
  aspect-ratio: 16 / 9;
}
.recent-work__media--four-three,
.recent-work__frame--four-three {
  aspect-ratio: 4 / 3;
}
.recent-work__body h3 {
  margin: 0 0 12px;
  font-size: clamp(1.35rem, 3vw, 1.95rem);
  color: #fff5d5;
}
.recent-work__body p {
  margin: 0 0 14px;
  color: #d5d4cf;
  line-height: 1.62;
}
.recent-work__body {
  position: relative;
  z-index: 1;
}
.recent-work__item{
  display:grid;
  gap:18px;
}
.recent-work__card--duo{
  grid-template-columns: 1fr;
}
@media (min-width: 900px){
  .recent-work__duo-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .recent-work__card {
    grid-template-columns: minmax(0, 420px) minmax(0, 1fr);
    align-items: center;
  }
  .recent-work__card--duo{
    grid-template-columns: 1fr;
  }
  .recent-work__media { aspect-ratio: 9 / 16; }
  .recent-work__frame { height: 100%; }
  .recent-work__card--wide {
    grid-template-columns: minmax(0, 540px) minmax(0, 1fr);
  }
  .recent-work__card--wide .recent-work__media {
    aspect-ratio: 16 / 9;
  }
  .fr-media-cta__embed,
  .fr-media-cta__embed.recent-work__media,
  .fr-media-cta__embed.recent-work__media--wide {
    aspect-ratio: 16 / 9;
  }
  .recent-work__grid--four {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .recent-work__grid--four .recent-work__card,
  .recent-work__grid--four .recent-work__card--wide {
    grid-template-columns: 1fr;
    align-items: stretch;
  }
}
@media (max-width: 520px){
  .recent-work__header {
    border-radius: 16px;
    padding: 16px;
  }
  .recent-work__card { padding: 18px; }
}

/* Cards */
.fr-card, .vh-card, .work-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.02));
  border: 1px solid var(--fr-border);
  border-radius: var(--fr-radius);
  padding: 22px;
  box-shadow: var(--fr-shadow);
  transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}
.fr-card:hover, .vh-card:hover, .work-card:hover { transform: translateY(-4px); border-color: var(--fr-border-strong); box-shadow: 0 20px 40px rgba(16, 16, 15, 0.35); }
.work-card h3 { margin: 8px 0 6px; }
.work-card p { color: var(--fr-muted); }

/* Media in cards */
.work-card img, .fr-card img, img.vh-img {
  border-radius: calc(var(--fr-radius) - 4px);
  border: 1px solid var(--fr-border);
}

/* Buttons */
.fr-buttons { display: flex; gap: 12px; flex-wrap: wrap; }
.hero-buttons { margin-top: 18px; justify-content: flex-start; }
.fr-button, .vh-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 44px;
  padding: 0 18px;
  border-radius: 999px;
  font-weight: 800;
  text-decoration: none;
  cursor: pointer;
  background: #f7f7f7;
  color: #10100F;
  border: 1px solid rgba(16, 16, 15, 0.12);
  position: relative;
  overflow: hidden;
  transition: transform .22s ease, opacity .18s ease, box-shadow .22s ease;
}
.fr-button::after, .vh-btn::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, rgba(255,255,255,0), rgba(255,255,255,0.25), rgba(255,255,255,0));
  transform: translateX(-100%);
  opacity: 0;
  transition: transform .5s ease, opacity .5s ease;
  pointer-events: none;
}
.fr-button--secondary, .vh-btn.vh-btn-alt { background: transparent; color: var(--fr-text); border: 1px solid var(--fr-border-strong); }
.fr-button--primary, .vh-btn-cta { background: var(--fr-accent); color: #10100F; border: 1px solid rgba(16, 16, 15, 0.2); }
.fr-button--primary, .vh-btn-cta { color: #10100F !important; }
.fr-button--primary:hover, .vh-btn-cta:hover { color: #10100F !important; text-decoration: none; }
.fr-button:hover, .vh-btn:hover { transform: translateY(-2px); opacity: .95; box-shadow: 0 16px 24px rgba(16, 16, 15, 0.32); }
.fr-button:hover::after, .vh-btn:hover::after { transform: translateX(110%); opacity: 1; }
.fr-button:active, .vh-btn:active { transform: translateY(0); box-shadow: 0 8px 16px rgba(16, 16, 15, 0.26); }

.fr-buttons .fr-button,
.fr-buttons .vh-btn {
  opacity: 0;
  transform: translateY(12px);
  animation: vh-cta-intro .6s ease forwards;
}
.fr-buttons .fr-button:nth-child(2),
.fr-buttons .vh-btn:nth-child(2) { animation-delay: .12s; }
.fr-buttons .fr-button:nth-child(3),
.fr-buttons .vh-btn:nth-child(3) { animation-delay: .24s; }

@keyframes vh-cta-intro {
  from { opacity: 0; transform: translateY(16px); }
  to { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
  .fr-button, .vh-btn { transition: none; }
  .fr-button::after, .vh-btn::after { display: none; }
  .fr-buttons .fr-button,
  .fr-buttons .vh-btn { animation: none; opacity: 1; transform: none; }
}

/* Hero image treatment */
.fr-hero-media { border-radius: var(--fr-radius-lg); overflow: hidden; border: 1px solid var(--fr-border); box-shadow: var(--fr-shadow); }
.fr-hero-media img { width: 100%; height: auto; display: block; }

/* Shared parallax media layer */
[data-parallax] {
  transform: translate3d(0, var(--vh-parallax-y, 0px), 0);
  will-change: auto;
}
[data-parallax].is-parallax-active {
  will-change: transform;
}
[data-parallax] video,
[data-parallax] img {
  transform: scale(var(--vh-parallax-scale, 1.08));
  transform-origin: center center;
}
@media (max-width: 900px), (prefers-reduced-motion: reduce) {
  [data-parallax] {
    transform: none !important;
  }
  [data-parallax] video,
  [data-parallax] img {
    transform: none !important;
  }
}

/* Footer */
.vh-footer { border-top: 1px solid var(--fr-border); background: rgba(10,10,10,0.6); backdrop-filter: blur(6px); }
.vh-tiny { color: var(--fr-muted); font-size: .875rem; }

/* Footer layout */
.fr-footer { padding: 48px 0 28px; }
.fr-footer .fr-footer-grid { display: grid; gap: 24px; grid-template-columns: 1fr; }
@media (min-width: 900px){ .fr-footer .fr-footer-grid { grid-template-columns: 1.3fr .9fr .9fr; } }
.fr-footer h4 { margin: 0 0 10px 0; font-family: 'Montserrat', sans-serif; font-weight: 600; font-size: 1rem; color: var(--fr-text); }
.fr-footer p, .fr-footer a, .fr-footer li { color: var(--fr-muted); font-family: 'Satoshi', sans-serif; }
.fr-footer a { margin: 0; }
.fr-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.fr-footer a:hover { color: var(--fr-accent); }

/* Newsletter */
.fr-news { display: grid; gap: 10px; }
.fr-footer .fr-buttons { display: inline-flex; margin-top: 10px; justify-content: flex-start; }
.fr-footer .fr-buttons .fr-button { text-align: center; }
@media (max-width: 768px){
  .fr-footer .fr-buttons { display: flex; justify-content: center; width: 100%; }
  .fr-footer .fr-buttons .fr-button { width: 100%; max-width: 320px; }
}
.fr-footer .fr-news { margin-top: 18px; }
.fr-footer .fr-footer-grid > section { text-align: left; }
.fr-footer .fr-news label { display: block; margin: 6px 0 8px; text-align: left; }
.fr-footer .fr-news > div { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.fr-footer .fr-news .fr-input { flex: 1 1 260px; max-width: 420px; }
.fr-input { background: #151517; border: 1px solid var(--fr-border-strong); color: var(--fr-text); border-radius: 10px; height: 42px; padding: 0 12px; width: 100%; }
.fr-submit { height: 42px; padding: 0 16px; border-radius: 999px; border: 1px solid rgba(16, 16, 15, 0.2); background: var(--fr-accent); color: #10100F; font-weight: 800; cursor: pointer; }
.fr-submit:hover { opacity: .95; transform: translateY(-1px); }

/* (footer CTA sizes reverted to defaults) */

.fr-footer-bottom { border-top: 1px solid var(--fr-border); margin-top: 28px; padding-top: 16px; display: flex; gap: 12px; align-items: center; justify-content: space-between; flex-wrap: wrap; }
.fr-socials { display: flex; gap: 12px; align-items: center; }
.fr-socials img { width: 22px; height: 22px; opacity: .85; }
.fr-socials a:hover img { opacity: 1; }

/* Simple reveal utility (works alongside AOS) */
.fr-reveal { opacity: 0; transform: translateY(16px); transition: opacity .6s ease, transform .6s ease; }
.fr-reveal.is-inview { opacity: 1; transform: translateY(0); }

/* Tighter, consistent spacing for section subtitles */
.vh-subtitle { color: var(--fr-accent); letter-spacing: .01em; }

/* Make site title feel like Framer hero text scale */
.site-title.site-title--xl { letter-spacing: -0.02em; }

/* Chatbot case studies grid */
.chatbot-case-grid { margin-top: 32px; display: grid; gap: 20px; }
@media (min-width: 700px){ .chatbot-case-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (min-width: 1024px){ .chatbot-case-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
.chatbot-case-card { position: relative; display: block; border-radius: 16px; overflow: hidden; border: 1px solid var(--fr-border); text-decoration: none; min-height: 260px; background: #0f0f0f; }
.chatbot-case-card__image { position: absolute; inset: 0; }
.chatbot-case-card__image img { width: 100%; height: 100%; object-fit: cover; display: block; filter: brightness(.72); transition: transform .4s ease, filter .3s ease; }
.chatbot-case-card__overlay { position: relative; z-index: 1; padding: 24px; display: flex; flex-direction: column; justify-content: flex-end; height: 100%; background: linear-gradient(180deg, rgba(10,10,10,0.05) 0%, rgba(10,10,10,0.75) 100%); }
.chatbot-case-card__overlay h3 { margin: 0 0 10px 0; font-size: clamp(1.15rem, 2.4vw, 1.35rem); font-family: 'Montserrat', sans-serif; color: #FDFAF0; }
.chatbot-case-card__overlay p { margin: 0 0 14px 0; color: #e2e2e2; font-family: 'Satoshi', sans-serif; line-height: 1.55; }
.chatbot-case-card__cta { font-weight: 700; color: var(--fr-accent); font-family: 'Satoshi', sans-serif; }
.chatbot-case-card::after { content: ""; position: absolute; inset: 0; border-radius: inherit; box-shadow: 0 18px 40px rgba(16, 16, 15, 0.35); opacity: 0; transition: opacity .3s ease; }
.chatbot-case-card:hover .chatbot-case-card__image img { transform: scale(1.05); filter: brightness(.85); }
.chatbot-case-card:hover::after { opacity: 1; }

/* Adjust the main progress bar to accent color */
#scroll-progress { background: var(--fr-accent); }

/* Trusted-by strip */
.fr-trust { padding: var(--vh-section-space) 0; border-top: 1px solid var(--fr-border); }
.fr-trust-eyebrow { color: var(--fr-muted); text-transform: uppercase; letter-spacing: .14em; font-size: .78rem; margin: 0 0 14px 0; text-align: center; }
.fr-trust-marquee { overflow: hidden; }
.fr-trust-carousel { position: relative; max-width: 760px; margin: 0 auto; padding-bottom: 12px; }
.fr-trust-logos { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 24px 28px; align-items: center; justify-content: center; }
.fr-trust-logos li { display: flex; align-items: center; justify-content: center; opacity: .9; filter: grayscale(100%) contrast(1.05); transition: opacity .3s ease, filter .3s ease, transform .3s ease; }
.fr-trust-logos li:hover { opacity: 1; filter: grayscale(0%); }
.fr-trust-logo { height: 34px; width: auto; max-width: 170px; display: block; }
.fr-trust-logo--disney { height: 89px; max-width: 446px; }
.fr-trust-logo--qp { height: 30px; max-width: 170px; }

.fr-trust-carousel.is-ready .fr-trust-logos {
  display: block;
  position: relative;
  min-height: 120px;
}
.fr-trust-carousel.is-ready .fr-trust-logos li {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(.7);
  opacity: 0;
  pointer-events: none;
  transition: transform .7s cubic-bezier(.4,.18,0,1), opacity .6s ease, filter .6s ease;
}
.fr-trust-carousel.is-ready .fr-trust-logos li.is-active {
  transform: translate(-50%, -50%) scale(2);
  opacity: 1;
  z-index: 3;
  filter: grayscale(0%) contrast(1.1);
  pointer-events: auto;
}
.fr-trust-carousel.is-ready .fr-trust-logos li.is-prev {
  transform: translate(calc(-50% - 160px), -50%) scale(.92);
  opacity: .82;
  z-index: 2;
}
.fr-trust-carousel.is-ready .fr-trust-logos li.is-next {
  transform: translate(calc(-50% + 160px), -50%) scale(.92);
  opacity: .82;
  z-index: 2;
}
.fr-trust-carousel.is-ready .fr-trust-logos li.is-hidden {
  opacity: 0;
  z-index: 1;
}

@media (max-width: 720px){
  .fr-trust-carousel { max-width: 620px; }
  .fr-trust-carousel.is-ready .fr-trust-logos { min-height: 100px; }
  .fr-trust-carousel.is-ready .fr-trust-logos li.is-prev {
    transform: translate(calc(-50% - 110px), -50%) scale(.9);
  }
  .fr-trust-carousel.is-ready .fr-trust-logos li.is-next {
    transform: translate(calc(-50% + 110px), -50%) scale(.9);
  }
}
@media (max-width: 600px){
  .fr-trust { padding: 22px 0 14px; }
  .fr-trust-eyebrow { font-size: .72rem; margin-bottom: 10px; }
  .fr-trust-logos { gap: 16px 20px; }
  .fr-trust-logo { height: 24px; max-width: 130px; }
  .fr-trust-logo--disney { height: 63px; max-width: 341px; }
  .fr-trust-logo--qp { height: 21px; max-width: 130px; }
}
@media (max-width: 520px){
  .fr-trust-carousel.is-ready .fr-trust-logos {
    display: flex;
    min-height: auto;
  }
  .fr-trust-carousel.is-ready .fr-trust-logos li {
    position: static;
    transform: none !important;
    opacity: 1 !important;
    pointer-events: auto;
  }
}
@media (prefers-reduced-motion: reduce) {
  .fr-trust-carousel.is-ready .fr-trust-logos li { transition: none; }
}

.vh-mail-link {
  color: var(--fr-accent);
  font-weight: 600;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: color .2s ease, opacity .2s ease;
}
.vh-mail-link:hover { opacity: .88; }
.vh-mail-link::before {
  content: "@";
  font-size: .9em;
  opacity: .7;
}

/* Alternating section themes */
.section-dark {
  background: #050403;
  color: var(--fr-text);
}

.section-light {
  background: #F4F1E9;
  color: #21170e;
}
.section-light p,
.section-light li,
.section-light label {
  color: #2b2415;
}
.section-light .vh-lead,
.section-light .fr-lead {
  color: #3b3120;
}
.section-light .vh-muted {
  color: #6f6657;
}
.section-light .vh-eyebrow,
.section-light .fr-trust-eyebrow {
  color: #5d5243;
}
.section-light .vh-subtitle {
  color: #10100F;
}
.section-light .vh-title-xl,
.section-light h2,
.section-light h3,
.section-light h4 {
  color: #1a1208;
}
.section-light a {
  color: var(--fr-accent);
}
.section-light a:hover {
  color: #b98c1a;
}
.section-light.fr-trust {
  background: #efe6d6;
  border-top: 1px solid rgba(16, 16, 15, 0.08);
}
.section-light.fr-media-cta .fr-media-cta__overlay {
  background: linear-gradient(180deg, rgba(244,241,233,0.35) 0%, rgba(244,241,233,0.92) 65%, rgba(244,241,233,0.98) 100%);
}
.section-light.fr-media-cta .fr-media-cta__copy,
.section-light.fr-media-cta .fr-media-cta__copy h3,
.section-light.fr-media-cta .fr-media-cta__copy p {
  color: inherit;
}
.section-light .flow-chart {
  background: linear-gradient(180deg, rgba(255,255,255,0.92), rgba(255,255,255,0.65));
  border: 1px solid rgba(16, 16, 15, 0.08);
  box-shadow: 0 20px 45px rgba(33,23,14,0.12);
}
.section-light .step-label {
  color: #21170e;
}
.section-light .contact-form input,
.section-light .contact-form textarea {
  background: #FDFAF0;
  border-color: #c7c2b6;
  color: #1b1206;
}
