/* infer360 brand overrides — loaded last
   Source of truth: Infer360-brand guideline.pdf
   Display headline: Clash Display. Body: Creato Display. */

/* Recoleta — licensed family (Latinotype). woff2 primary + otf fallback. */
@font-face {
  font-family: 'Recoleta';
  src: url('fonts/recoleta/Recoleta-Thin.woff2') format('woff2'),
       url('fonts/recoleta/Recoleta-Thin.otf') format('opentype');
  font-weight: 100; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Recoleta';
  src: url('fonts/recoleta/Recoleta-Light.woff2') format('woff2'),
       url('fonts/recoleta/Recoleta-Light.otf') format('opentype');
  font-weight: 300; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Recoleta';
  src: url('fonts/recoleta/Recoleta-Regular.woff2') format('woff2'),
       url('fonts/recoleta/Recoleta-Regular.otf') format('opentype');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Recoleta';
  src: url('fonts/recoleta/Recoleta-Medium.woff2') format('woff2'),
       url('fonts/recoleta/Recoleta-Medium.otf') format('opentype');
  font-weight: 500; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Recoleta';
  src: url('fonts/recoleta/Recoleta-SemiBold.woff2') format('woff2'),
       url('fonts/recoleta/Recoleta-SemiBold.otf') format('opentype');
  font-weight: 600; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Recoleta';
  src: url('fonts/recoleta/Recoleta-Bold.woff2') format('woff2'),
       url('fonts/recoleta/Recoleta-Bold.otf') format('opentype');
  font-weight: 700; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Recoleta';
  src: url('fonts/recoleta/Recoleta-Black.woff2') format('woff2'),
       url('fonts/recoleta/Recoleta-Black.otf') format('opentype');
  font-weight: 900; font-style: normal; font-display: swap;
}

/* Clash Display — fallback display */
@font-face {
  font-family: 'Clash Display';
  src: url('fonts/clash-display/ClashDisplay-Extralight.otf') format('opentype');
  font-weight: 200; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Clash Display';
  src: url('fonts/clash-display/ClashDisplay-Light.otf') format('opentype');
  font-weight: 300; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Clash Display';
  src: url('fonts/clash-display/ClashDisplay-Regular.otf') format('opentype');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Clash Display';
  src: url('fonts/clash-display/ClashDisplay-Medium.otf') format('opentype');
  font-weight: 500; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Clash Display';
  src: url('fonts/clash-display/ClashDisplay-Semibold.otf') format('opentype');
  font-weight: 600; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Clash Display';
  src: url('fonts/clash-display/ClashDisplay-Bold.otf') format('opentype');
  font-weight: 700; font-style: normal; font-display: swap;
}

/* Creato Display — body */
@font-face {
  font-family: 'Creato Display';
  src: url('fonts/creato-display/CreatoDisplay-Thin.otf') format('opentype');
  font-weight: 100; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Creato Display';
  src: url('fonts/creato-display/CreatoDisplay-ThinItalic.otf') format('opentype');
  font-weight: 100; font-style: italic; font-display: swap;
}
@font-face {
  font-family: 'Creato Display';
  src: url('fonts/creato-display/CreatoDisplay-Light.otf') format('opentype');
  font-weight: 300; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Creato Display';
  src: url('fonts/creato-display/CreatoDisplay-LightItalic.otf') format('opentype');
  font-weight: 300; font-style: italic; font-display: swap;
}
@font-face {
  font-family: 'Creato Display';
  src: url('fonts/creato-display/CreatoDisplay-Regular.otf') format('opentype');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Creato Display';
  src: url('fonts/creato-display/CreatoDisplay-RegularItalic.otf') format('opentype');
  font-weight: 400; font-style: italic; font-display: swap;
}
@font-face {
  font-family: 'Creato Display';
  src: url('fonts/creato-display/CreatoDisplay-Medium.otf') format('opentype');
  font-weight: 500; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Creato Display';
  src: url('fonts/creato-display/CreatoDisplay-MediumItalic.otf') format('opentype');
  font-weight: 500; font-style: italic; font-display: swap;
}
@font-face {
  font-family: 'Creato Display';
  src: url('fonts/creato-display/CreatoDisplay-Bold.otf') format('opentype');
  font-weight: 700; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Creato Display';
  src: url('fonts/creato-display/CreatoDisplay-BoldItalic.otf') format('opentype');
  font-weight: 700; font-style: italic; font-display: swap;
}
@font-face {
  font-family: 'Creato Display';
  src: url('fonts/creato-display/CreatoDisplay-ExtraBold.otf') format('opentype');
  font-weight: 800; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Creato Display';
  src: url('fonts/creato-display/CreatoDisplay-ExtraBoldItalic.otf') format('opentype');
  font-weight: 800; font-style: italic; font-display: swap;
}
@font-face {
  font-family: 'Creato Display';
  src: url('fonts/creato-display/CreatoDisplay-Black.otf') format('opentype');
  font-weight: 900; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Creato Display';
  src: url('fonts/creato-display/CreatoDisplay-BlackItalic.otf') format('opentype');
  font-weight: 900; font-style: italic; font-display: swap;
}

:root {
  /* Brand palette — exact from guideline */
  --brand-navy:        #073149;
  --brand-charcoal:    #333134;
  --brand-teal:        #27bfd4;
  --brand-mint:        #c1dfdf;
  --brand-warm:        #ffc469;
  --brand-orange:      #fe6710;
  --brand-red-orange:  #ff340e;
  --brand-sky:         #8cd5ff;
  --brand-lavender:    #b5b5ff;
  --brand-pink:        #e8affe;

  /* Override Solvior theme tokens so brand cascades through main.css */
  --tj-color-theme-dark:    #073149;
  --tj-color-theme-primary: #27bfd4;

  /* Roles */
  --infer-primary: var(--brand-navy);
  --infer-accent:  var(--brand-teal);
  --infer-text:    var(--brand-charcoal);

  /* Typography — brand fonts (loaded via @font-face above) */
  --font-display: 'Recoleta', 'Clash Display', 'Fraunces', Georgia, serif;
  --font-serif:   'Recoleta', 'Clash Display', 'Fraunces', Georgia, serif;
  --font-sans:    'Creato Display', 'Manrope', system-ui, -apple-system, 'Segoe UI', sans-serif;
}

/* Apply brand fonts globally */
html, body { font-family: var(--font-sans); margin: 0 !important; padding: 0 !important; }
/* Clip horizontal overflow from off-screen drawers/popovers without creating a
   scroll container (overflow-x:clip does NOT break position:sticky like hidden). */
html { overflow-x: clip; }
body main { padding-top: 0 !important; margin-top: 0 !important; }
.tj-header-area.header-absolute { top: 0 !important; margin-top: 0 !important; }
h1, h2, h3, h4, h5, h6,
.hero-title, .sec-title, .h6-footer-widget-title,
.title, .accordion_title .title {
  font-family: var(--font-serif);
}

/* Sub-titles in brand teal */
.sec-heading .sub-title { color: var(--brand-teal); letter-spacing: 0.18em; font-size: 18px; }

/* Logo wordmark sizing */
.site-logo .logo img,
.h6-footer-logo .footer-logo img,
.hamburger_logo .mobile_logo img { height: 36px; width: auto; }

/* Section 2 — Diagnose: flask shape bridges into Strategic Shield section */
.diagnose-section {
  overflow: visible !important;
  position: relative;
  z-index: 2;
  padding-bottom: 0 !important;
  background-image: url('images/brand/v2/trans-gap-flask.png');
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
}
.diagnose-section::before {
  /* light overlay so text stays readable; bg-image still shows through */
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.55);
  z-index: 0;
  pointer-events: none;
}
/* Dotted ring decoration top-right (per Figma) */
.diagnose-section::after {
  content: "";
  position: absolute;
  top: 60px;
  right: 60px;
  width: 220px;
  height: 220px;
  background-image: url('images/logos/infer360-logo-dotted.svg');
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  opacity: 0.6;
  z-index: 0;
  pointer-events: none;
}
@media (max-width: 991px) {
  .diagnose-section::after { display: none; }
}
.diagnose-section > .container { position: relative; z-index: 1; }
.diagnose-section .diagnose-row { margin-top: 60px; min-height: 380px; position: relative; }

/* Re-anchor flask containing block to .diagnose-section so bottom: -X reaches Strategic Shield reliably */
.diagnose-section .h6-about-video { position: static !important; }
.diagnose-section .h6-about-video .about-shape-1 {
  position: absolute !important;
  bottom: -100px !important;        /* extends 100px below section bottom into navy */
  inset-inline-start: 8% !important;
  inset-inline-end: auto;
  top: auto !important;
  background: var(--brand-navy) !important;
  z-index: 3;
  max-width: 360px;
  height: 410px;
}
@media (max-width: 991px) {
  .diagnose-section .h6-about-video .about-shape-1 {
    position: relative !important;
    bottom: 0 !important;
    inset-inline-start: auto !important;
    margin: 0 auto;
  }
}

/* Section 2 — Diagnose accordion (matches Figma: rounded outer, dividers between items, gray bg on open) */
.diagnose-section .h6-insight_accordion {
  max-width: 760px;
  margin-left: auto;
  border: 1px solid rgba(7, 49, 73, 0.10) !important;
  border-radius: 10px;
  overflow: hidden;
  background: transparent !important;
}
.diagnose-section .h6-insight_accordion .accordion_item {
  padding: 0;
  border: none !important;
  background: transparent !important;
}
.diagnose-section .h6-insight_accordion .accordion_item:not(:last-child) {
  border-bottom: 1px solid rgba(7, 49, 73, 0.08) !important;
}
.diagnose-section .h6-insight_accordion .accordion_title {
  width: 100%;
  border: 0;
  padding: 26px 60px 26px 32px;     /* leave room for +/- icon on right */
  text-align: left;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  background: transparent !important;
  box-shadow: none !important;
  outline: none !important;
  position: relative;
}
.diagnose-section .h6-insight_accordion .accordion_title:focus,
.diagnose-section .h6-insight_accordion .accordion_title:focus-visible {
  box-shadow: none !important;
  outline: none !important;
}
/* Open item: light gray bg highlight on title + body */
.diagnose-section .h6-insight_accordion .accordion_title:not(.collapsed),
.diagnose-section .h6-insight_accordion .accordion_title:not(.collapsed) ~ .accordion_desc.show,
.diagnose-section .h6-insight_accordion .accordion_title:not(.collapsed) ~ .accordion_desc.show .accordion-body {
  background: #e9ecef !important;
}
.diagnose-section .h6-insight_accordion .accordion_title {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  width: 100%;
  border: 0;
  padding: 0;
  text-align: left;
}
.diagnose-section .h6-insight_accordion .accordion_title .subtitle {
  font: 600 14px/1 var(--font-sans);
  letter-spacing: 0.04em;
  color: var(--brand-charcoal);
  opacity: 0.55;
}
.diagnose-section .h6-insight_accordion .accordion_title .title {
  font: 600 26px/1.3 var(--font-serif);
  color: var(--brand-charcoal);
}
.diagnose-section .h6-insight_accordion .accordion_title:not(.collapsed) .subtitle { color: var(--brand-teal); opacity: 1; }
.diagnose-section .h6-insight_accordion .accordion_desc .accordion-body {
  padding: 0 60px 26px 32px;
  font-size: 16px;
  line-height: 1.6;
  color: var(--brand-charcoal);
  opacity: 0.85;
}

/* Section 3 — Defend: dark navy backdrop, no tiled badge */
.defend-section.project-section-three {
  background-color: var(--brand-navy);
  background-image: none;
  color: #fff;
  position: relative;
  z-index: 1;
  margin-top: 0;
  padding-top: 130px;       /* clears flask -100px overflow from diagnose */
  padding-bottom: 120px;
}
.defend-section .sec-title { color: #fff; }
.defend-section .sec-heading p,
.defend-section .sec-desc p { color: rgba(255,255,255,0.8); }
.defend-section .sec-heading .sec-desc { margin-top: 22px; }
/* Center the project carousel horizontally so the active card sits in the middle
   of the visible area regardless of which card is active. */
.defend-section .project-wrapper-two {
  max-width: 1180px;
  margin: 60px auto 0;
  padding: 0 28px;
  justify-content: center;     /* keep group centered so leftover space splits evenly */
}
.defend-section .project-wrapper-two ~ * { margin-top: 48px; }

/* Defend collapsed strips: keep Solvior default widths (120/90/80) so
   the active card still expands to 735px. Only re-position label + arrow. */

/* Vertical label: native vertical-rl (no rotate transform). Text column is just
   font-size wide so it cleanly fits the 120px strip. Anchored low and centered. */
.defend-section .project-style-3:not(.active) .project-thumb .project-default-content .title {
  position: absolute !important;
  top: auto !important;
  bottom: 60px !important;            /* shift label up so it does not clip at strip edge */
  inset-inline-start: 50% !important;
  transform: translateX(-50%) !important;
  writing-mode: vertical-rl !important;
  text-orientation: mixed !important;
  font: 700 22px/1 var(--font-serif) !important;
  letter-spacing: 0 !important;
  white-space: nowrap !important;
  margin: 0 !important;
  color: #fff !important;
  width: auto !important;
}
/* Move the ↗ arrow inside the strip, slightly larger, never cuts */
.defend-section .project-style-3:not(.active) .project-thumb .project-default-content span {
  top: 24px;
  inset-inline-start: 50%;
  transform: translateX(-50%) rotate(-45deg);
  width: 52px;
  height: 52px;
  font-size: 22px;
}

/* Section 4 — Vertically Integrated TP Solutions */
.vti-section .sec-heading .sub-title { color: var(--brand-teal); }
.vti-section.h6-project-section { background-color: #f6f8fa; }

/* Section 5 — Framework360 Walk-up panels */
.framework360-section { background: #eef2f4; }
.framework360-section .sec-title { color: var(--brand-navy); }
.framework360-section .walkup-tabs {
  display: inline-flex;
  gap: 8px;
  margin: 22px 0 32px;
  background: #fff;
  border-radius: 999px;
  padding: 6px;
  border: 1px solid #d8dde2;
}
.framework360-section .walkup-tab {
  border: 0;
  background: transparent;
  color: var(--brand-charcoal);
  padding: 10px 20px;
  border-radius: 999px;
  font: 600 14px/1 var(--font-sans);
  cursor: pointer;
  transition: all 0.25s ease;
}
.framework360-section .walkup-tab.active {
  background: var(--brand-teal);
  color: #fff;
}
.framework360-section .walkup-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.framework360-section .walkup-item {
  position: relative;
  display: flex;
  align-items: center;
  border-radius: 14px;
  overflow: hidden;
  background: #fff;
  border: 1px solid #d8dde2;
  min-height: 72px;
  cursor: pointer;
  transition: min-height 0.45s ease, background-color 0.35s ease;
}
.framework360-section .walkup-item .walkup-bg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 0.45s ease;
  z-index: 0;
}
.framework360-section .walkup-item .walkup-body {
  position: relative; z-index: 2;
  display: grid;
  grid-template-columns: 64px 220px 1fr;
  align-items: center;
  gap: 24px;
  padding: 18px 28px;
  width: 100%;
  color: var(--brand-charcoal);
  transition: color 0.35s ease;
}
.framework360-section .walkup-item .walkup-num { font: 600 13px/1 var(--font-sans); opacity: 0.6; }
.framework360-section .walkup-item .walkup-title { font: 600 22px/1.2 var(--font-serif); margin: 0; }
.framework360-section .walkup-item .walkup-desc { font-size: 14px; line-height: 1.5; }
.framework360-section .walkup-item.active {
  min-height: 220px;
  border-color: transparent;
}
.framework360-section .walkup-item.active::before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(7,49,73,0.85) 0%, rgba(7,49,73,0.45) 60%, rgba(7,49,73,0.15) 100%);
  z-index: 1;
}
.framework360-section .walkup-item.active .walkup-bg { opacity: 1; }
.framework360-section .walkup-item.active .walkup-body,
.framework360-section .walkup-item.active .walkup-num,
.framework360-section .walkup-item.active .walkup-title { color: #fff; }
.framework360-section .walkup-item.active .walkup-num { opacity: 1; }
.framework360-section .walkup-item.active .walkup-desc { color: rgba(255,255,255,0.9); }

/* Section 6 — Don't Just Automate—Transform */
.dont-just-automate-section .sec-eyebrow {
  display: block;
  font-size: 14px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--brand-teal);
  margin-bottom: 12px;
}

/* Hero copy width */
.h6-hero-content .desc p { max-width: 540px; }

/* Section 7 — Footer: re-tune metrics for Clash Display + Creato Display */
.h6-footer-widget-title {
  font-family: var(--font-display);
  font-weight: 600;
  line-height: 1.08;
  letter-spacing: -0.01em;
}
.h6-footer-widget-title span { color: var(--brand-teal); }
.contact-form-one .title {
  font-family: var(--font-display);
  font-weight: 600;
  line-height: 1.25;
  letter-spacing: -0.005em;
}
/* Let's Connect form — inline validation feedback (light on dark footer) */
.contact-form-one .form-feedback {
  margin: 2px 0 -6px;
  font-family: var(--font-sans);
  font-size: 13px;
  line-height: 1.4;
}
.contact-form-one .form-feedback.is-error { color: var(--brand-warm); }
.contact-form-one .form-feedback.is-ok    { color: var(--brand-sky); }
.h6-footer .footer-contact-infos .infos-item span,
.h6-footer .footer-contact-infos .infos-item p,
.h6-footer .footer-contact-infos .infos-item a,
.h6-footer-menu ul li a,
.h6-footer .copyright-content-area,
.h6-footer .copyright-text p,
.h6-footer .copyright-menu ul li a {
  font-family: var(--font-sans);
}
.h6-footer .contact-form-one .form-input input,
.h6-footer .contact-form-one .form-input textarea,
.h6-footer .contact-form-one .nice-select,
.h6-footer .contact-form-one .nice-select .list,
.h6-footer .contact-form-one .nice-select .option {
  font-family: var(--font-sans);
}
.h6-footer .tj-submit-btn,
.h6-footer .btn_inner .btn_text span {
  font-family: var(--font-sans);
}

/* Footer menu: spread items evenly across available width */
.h6-footer .h6-footer-menu ul {
  display: flex !important;
  justify-content: flex-end !important;
  align-items: center !important;
  column-gap: 36px !important;
  row-gap: 12px !important;
  flex-wrap: wrap !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
.h6-footer .h6-footer-menu ul li {
  padding: 0 !important;
  margin: 0 !important;
  flex: 0 0 auto;
}
.h6-footer .h6-footer-menu ul li::before,
.h6-footer .h6-footer-menu ul li:not(:first-child)::before {
  display: none !important;
  content: none !important;
  width: 0 !important;
  height: 0 !important;
  background: transparent !important;
}
@media (max-width: 991px) {
  .h6-footer .h6-footer-menu ul { justify-content: center !important; column-gap: 20px !important; }
}

/* ================================================================ */
/* Button variants                                                    */
/* ================================================================ */
/* Orange icon pill (override Solvior teal ::before) */
.tj-primary-btn .btn_inner.btn-orange::before {
  background: var(--brand-orange) !important;
}
/* light-btn alias for white-btn (kept for back-compat) */
.tj-primary-btn.light-btn { background-color: #fff; }
.tj-primary-btn.light-btn .btn_inner .btn_text { color: var(--brand-charcoal); }

/* ================================================================ */
/* Section 3 — The Strategic Shield                                   */
/* ================================================================ */
.strategic-shield-section {
  background: var(--brand-navy);
  color: #fff;
  position: relative;
  z-index: 1;
  padding-top: 180px;        /* leave room for diagnose flask stem */
  padding-bottom: 120px;
}
.strategic-shield-section .sec-title { color: #fff; }
.strategic-shield-section .sec-desc p { color: rgba(255,255,255,0.8); }
.strategic-shield-section .strategic-shield-content { padding-right: 40px; }
.strategic-shield-section .shield-pillars {
  list-style: none;
  padding: 0;
  margin: 36px 0 36px;
  display: flex;
  flex-direction: column;
  gap: 22px;
}
.strategic-shield-section .shield-pillars li {
  display: flex;
  gap: 18px;
  align-items: flex-start;
}
.strategic-shield-section .shield-pillars .pillar-icon {
  flex: 0 0 auto;
  width: 48px;
  height: 48px;
  border-radius: 12px;
  background: rgba(39,191,212,0.14);
  color: var(--brand-teal);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
}
.strategic-shield-section .shield-pillars h4 {
  font: 600 22px/1.2 var(--font-display);
  margin: 0 0 6px;
  color: #fff;
}
.strategic-shield-section .shield-pillars p {
  margin: 0;
  font-size: 15px;
  line-height: 1.55;
  color: rgba(255,255,255,0.78);
}
.strategic-shield-section .strategic-shield-image img {
  width: 100%;
  height: auto;
  border-radius: 18px;
  box-shadow: 0 30px 80px rgba(0,0,0,0.35);
}
@media (max-width: 991px) {
  .strategic-shield-section { padding-top: 120px; padding-bottom: 80px; }
  .strategic-shield-section .strategic-shield-content { padding-right: 0; margin-bottom: 50px; }
}

/* ================================================================ */
/* Section 6 — Prove the Model: section bg + outline-btn light variant */
/* ================================================================ */
.prove-model-section { background: #f6f8fa; }
.prove-model-section .sec-title { color: var(--brand-navy); }

/* ================================================================ */
/* Section 7 — Our Mission & Team                                    */
/* ================================================================ */
.our-mission-section {
  background: #fff;
  padding-top: 100px;
  padding-bottom: 100px;
}
.our-mission-section .sec-title { color: var(--brand-charcoal); }
.team-card {
  background: #e1e8f0;
  border-radius: 18px;
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
  transition: transform 0.35s ease, box-shadow 0.35s ease;
}
.team-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 22px 60px rgba(7,49,73,0.12);
}
.team-card .team-photo {
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: #cfd8e3;
}
.team-card .team-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.team-card .team-body {
  padding: 26px 28px 28px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}
.team-card .team-body .title {
  font: 600 22px/1.25 var(--font-display);
  color: var(--brand-charcoal);
  margin: 0;
}
.team-card .team-body .title a { color: inherit; }
.team-card .team-body .role {
  font: 500 14px/1.4 var(--font-sans);
  color: var(--brand-teal);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.team-card .team-body p {
  font-size: 15px;
  line-height: 1.55;
  color: rgba(51,49,52,0.82);
  margin: 0;
}
.team-card .team-social {
  margin-top: auto;
  padding-top: 14px;
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.team-card .team-social .follow-label {
  font-size: 13px;
  color: rgba(51,49,52,0.65);
}
.team-card .team-social ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 8px;
}
.team-card .team-social ul li a {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(7,49,73,0.08);
  color: var(--brand-navy);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  transition: background 0.25s ease, color 0.25s ease;
}
.team-card .team-social ul li a:hover {
  background: var(--brand-teal);
  color: #fff;
}

/* Solutions tier image fallback (object-fit) */
.vti-section .h6-project-item .project_image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ================================================================ */
/* Hero — headline charcoal, no pill, orange-accent secondary button  */
/* ================================================================ */
.h6-hero-content .hero-title { color: var(--brand-charcoal) !important; }
.h6-hero-content .desc p { color: rgba(51,49,52,0.78); }
.h6-hero-content .desc strong { color: var(--brand-charcoal); font-weight: 700; }

/* Hero CTA: button 2 = orange accent on icon pill (::before is the actual pill) */
.h6-hero-content .hero-btn-area .tj-primary-btn:nth-child(2) .btn_inner::before {
  background: var(--brand-orange) !important;
}

/* Diagnose CTA below accordion */
.diagnose-section .diagnose-cta { margin-top: 36px; }

/* ================================================================ */
/* Section 5 — Roadmap (Framework360) full-bleed bg + glass panel    */
/* ================================================================ */
.roadmap-section {
  position: relative;
  padding: 120px 0;
  overflow: hidden;
  z-index: 1;
}
.roadmap-section .tj-growth-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  z-index: 0;
}
.roadmap-section .tj-growth-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(5,18,41,0.55);
}
.roadmap-section .container { position: relative; z-index: 2; }
.roadmap-section .row { justify-content: flex-end; }
.roadmap-section .roadmap-panel {
  max-width: 460px;
  margin-left: auto;
  background: rgba(255,255,255,0.10);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  padding: 40px 36px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.18);
}
.roadmap-section .roadmap-panel .sub-title { color: var(--brand-teal); }
.roadmap-section .roadmap-panel .sec-title { color: #fff; font-size: 48px; line-height: 1.15; }
.roadmap-section .roadmap-body { color: #fff; font-size: 16px; line-height: 1.6; margin: 22px 0 30px; }
.roadmap-section .roadmap-body strong { color: #fff; font-weight: 700; }
.tj-primary-btn.light-btn .btn_inner { background: #fff; color: var(--brand-charcoal); }
.tj-primary-btn.light-btn .btn_inner .btn_text span { color: var(--brand-charcoal); }
@media (max-width: 991px) {
  .roadmap-section { padding: 80px 0; }
  .roadmap-section .row { justify-content: center; }
  .roadmap-section .roadmap-panel { margin: 0 auto; }
}

/* ================================================================ */
/* Section 6 — Prove the Model (text-left + image-right layout)      */
/* ================================================================ */
.prove-model-section {
  background: #e1e8f0;
  padding: 120px 0;
}
.prove-model-section .sec-title {
  color: var(--brand-charcoal);
  font-size: 48px;
  line-height: 1.15;
}
.prove-model-section .sub-title { color: var(--brand-teal); }
.prove-model-section .prove-model-body p {
  margin-top: 22px;
  color: var(--brand-charcoal);
  font-size: 16px;
  line-height: 1.6;
}
.prove-model-section .prove-model-cta { margin-top: 30px; }
.prove-model-section .prove-model-image img {
  width: 100%;
  height: auto;
  border-radius: 18px;
  box-shadow: 0 28px 70px rgba(7,49,73,0.18);
}
@media (max-width: 991px) {
  .prove-model-section { padding: 80px 0; }
  .prove-model-section .prove-model-image { margin-top: 40px; }
}

/* ================================================================ */
/* Section 7 — Mission & Team (3-card horizontal expand carousel)    */
/* ================================================================ */
.our-mission-section { background: #f6f8fa; }
.our-mission-section .sec-title { color: var(--brand-charcoal); }
.team-carousel {
  display: flex;
  gap: 16px;
  width: 100%;
  height: 380px;
  align-items: stretch;
}
.team-card-strip {
  position: relative;
  flex: 0 0 130px;
  background: #e1e8f0;
  border-radius: 14px;
  overflow: hidden;
  cursor: pointer;
  transition: flex-basis 0.6s cubic-bezier(0.65, 0, 0.35, 1), background-color 0.4s ease, transform 0.3s ease;
}
.team-card-strip:not(.active):hover {
  transform: translateY(-3px);
}
.team-card-strip.active {
  flex: 1 1 0;
  background: #e6ecf2;
  animation: cardFadeIn 0.6s cubic-bezier(0.65, 0, 0.35, 1) both;
}
@keyframes cardFadeIn {
  0% { opacity: 0.85; }
  100% { opacity: 1; }
}
.team-card-strip .strip-photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.team-card-strip .strip-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  transition: transform 0.6s cubic-bezier(0.65, 0, 0.35, 1);
}
.team-card-strip:not(.active):hover .strip-photo img {
  transform: scale(1.04);
}
.team-card-strip:not(.active) .strip-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(7,49,73,0.05) 0%, rgba(7,49,73,0.55) 100%);
}
.team-card-strip .strip-collapsed-label {
  position: absolute;
  bottom: 26px;
  left: 50%;
  transform: translateX(-50%);
  writing-mode: vertical-rl;
  text-orientation: mixed;
  font: 600 16px/1 var(--font-display);
  color: #fff;
  letter-spacing: 0.02em;
  white-space: nowrap;
  z-index: 2;
  opacity: 1;
  transition: opacity 0.3s ease;
  display: none;
}
.team-card-strip:not(.active) .strip-collapsed-label { display: block; }
.team-card-strip .strip-expanded-content {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: 280px 1fr;
  align-items: center;
  gap: 28px;
  padding: 30px 30px 30px 0;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s ease 0.1s, visibility 0s linear 0.5s;
}
.team-card-strip.active .strip-expanded-content {
  opacity: 1;
  visibility: visible;
  transition: opacity 0.4s ease 0.25s, visibility 0s;
}
.team-card-strip.active .strip-photo {
  position: relative;
  width: 42%;
  min-width: 300px;
  max-width: 480px;
  height: 100%;
  flex-shrink: 0;
  inset: auto;
}
.team-card-strip.active .strip-photo img {
  object-position: center top;
  animation: photoZoomIn 0.7s cubic-bezier(0.65, 0, 0.35, 1) both;
}
@keyframes photoZoomIn {
  0%   { transform: scale(1.10); opacity: 0.85; }
  100% { transform: scale(1.00); opacity: 1; }
}
.team-card-strip.active .strip-expanded-content::before {
  content: "";
}
/* override: when active, photo is in flow on left */
.team-card-strip.active {
  display: flex;
  align-items: stretch;
}
.team-card-strip.active > .strip-photo {
  position: relative;
  width: 42%;
  min-width: 300px;
  max-width: 480px;
  height: 100%;
}
.team-card-strip.active .strip-photo::after { display: none; }
.team-card-strip.active .strip-expanded-content {
  position: relative;
  inset: auto;
  flex: 1;
  padding: 40px 50px 40px 40px;
  animation: contentSlideIn 0.6s cubic-bezier(0.65, 0, 0.35, 1) both;
  animation-delay: 0.15s;
  display: flex !important;
  flex-direction: column;
  justify-content: center;
}
@keyframes contentSlideIn {
  0%   { opacity: 0; transform: translateX(12px); }
  100% { opacity: 1; transform: translateX(0); }
}
.strip-expanded-content .title {
  font: 600 28px/1.2 var(--font-display);
  color: var(--brand-charcoal);
  margin: 0 0 8px;
  letter-spacing: -0.015em;
}
.strip-expanded-content .role {
  display: inline-block;
  font: 400 15px/1.4 var(--font-sans);
  color: rgba(51,49,52,0.78);
  letter-spacing: 0;
  text-transform: none;
  margin-bottom: 22px;
}
.strip-expanded-content p {
  font-size: 16px;
  line-height: 1.6;
  color: rgba(51,49,52,0.82);
  margin: 0 0 22px;
  max-width: 520px;
}
.strip-social {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.strip-social ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 8px;
}
.strip-social ul li a {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(7,49,73,0.20);
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  transition: background 0.25s ease, color 0.25s ease, transform 0.2s ease;
}
.strip-social ul li a:hover { transform: translateY(-2px); }
.strip-social ul li a:hover { background: var(--brand-teal); color: #fff; }
.strip-social .follow-label {
  font: 400 14px/1 var(--font-sans);
  color: var(--brand-charcoal);
  margin-right: 4px;
}

@media (max-width: 991px) {
  .team-carousel { height: auto; flex-direction: column; gap: 14px; }
  .team-card-strip { flex: 0 0 auto; height: 110px; }
  .team-card-strip.active { height: auto; }
  .team-card-strip .strip-collapsed-label { bottom: 50%; transform: translate(-50%, 50%); writing-mode: horizontal-tb; }
  .team-card-strip.active { flex-direction: column; }
  .team-card-strip.active > .strip-photo { width: 100%; height: 280px; }
  .team-card-strip.active .strip-expanded-content { grid-template-columns: 1fr; padding: 24px; }
}

/* ================================================================ */
/* Team bio modal                                                     */
/* ================================================================ */
.team-bio-modal .modal-content {
  border-radius: 18px;
  border: none;
  background: #fff;
  position: relative;
}
.team-bio-modal .modal-body { padding: 50px 50px; }
.team-bio-modal .btn-close-custom {
  position: absolute;
  top: 18px;
  right: 18px;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: rgba(7,49,73,0.08);
  border: 0;
  color: var(--brand-navy);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  z-index: 5;
  cursor: pointer;
  transition: background 0.2s ease;
}
.team-bio-modal .btn-close-custom:hover { background: var(--brand-teal); color: #fff; }
.team-bio-modal .bio-grid {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 36px;
  align-items: start;
}
.team-bio-modal .bio-photo img {
  width: 100%;
  height: auto;
  border-radius: 12px;
  display: block;
}
.team-bio-modal .bio-text h3 {
  font: 600 32px/1.2 var(--font-display);
  color: var(--brand-charcoal);
  margin: 0 0 6px;
}
.team-bio-modal .bio-text .role {
  display: inline-block;
  font: 500 13px/1.4 var(--font-sans);
  color: var(--brand-teal);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.team-bio-modal .bio-points {
  list-style: disc outside;
  padding-left: 20px;
  margin: 0;
  font-size: 15px;
  line-height: 1.62;
  color: var(--brand-charcoal);
}
.team-bio-modal .bio-points li { margin-bottom: 12px; }
@media (max-width: 767px) {
  .team-bio-modal .modal-body { padding: 30px 24px; }
  .team-bio-modal .bio-grid { grid-template-columns: 1fr; gap: 24px; }
  .team-bio-modal .bio-photo img { max-width: 200px; margin: 0 auto; }
}

/* ================================================================ */
/* Footer overrides — match Figma reference                          */
/* ================================================================ */

/* Background palette — gray tones (not navy) per Figma */
.h6-footer.tj-footer-area {
  background: #2a292b !important;
  background-image: none !important;
}
.h6-footer .h6-footer-top {
  background: #393638;
  padding-top: 90px;
  padding-bottom: 90px;
}
.h6-footer .h6-footer-top .contact-form-one {
  background: #4a4749;
  padding: 50px 50px 60px;
  border-radius: 0;
}
.h6-footer .h6-footer-middle {
  background: #2a292b;
  padding-top: 30px;
  padding-bottom: 30px;
  border-top: 1px solid rgba(255,255,255,0.06);
}
.h6-footer .footer-copyright-area {
  background: #1f1e20;
  padding-top: 22px;
  padding-bottom: 22px;
  border-top: 1px solid rgba(255,255,255,0.05);
}

/* Form input styling for darker panel */
.h6-footer .contact-form-one .form-input input,
.h6-footer .contact-form-one .form-input textarea {
  background: transparent;
  border: 0;
  border-bottom: 1px solid rgba(255,255,255,0.18);
  color: #fff;
  padding: 14px 0;
}
.h6-footer .contact-form-one .form-input input::placeholder,
.h6-footer .contact-form-one .form-input textarea::placeholder {
  color: rgba(255,255,255,0.55);
}
.h6-footer .contact-form-one .title {
  color: #fff;
  margin-bottom: 30px;
}

/* Single-column address (no left/right split) */
.h6-footer .footer-contact-infos.single-col {
  display: block;
}
.h6-footer .footer-contact-infos.single-col .infos-item {
  max-width: 360px;
}
.h6-footer .footer-contact-infos .footer-phone {
  margin-top: 6px;
}
.h6-footer .footer-contact-infos .footer-phone a {
  color: inherit;
  text-decoration: none;
}

/* Full-width teal pill submit button */
.h6-footer .submit-button-wrap {
  margin-top: 18px;
  padding: 0 12px;
}
.h6-footer .tj-submit-btn.submit-btn-pill {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  height: 64px;
  border-radius: 50px;
  background: var(--brand-teal);
  color: #fff;
  border: 0;
  font: 500 16px/1 var(--font-sans);
  cursor: pointer;
  transition: background 0.25s ease, transform 0.15s ease;
}
.h6-footer .tj-submit-btn.submit-btn-pill:hover {
  background: #1aa9bd;
}
.h6-footer .tj-submit-btn.submit-btn-pill .btn-text {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

/* Bullet separator between Policy & privacy / Terms & conditions */
/* Override Solvior's right-side dot to fully kill it, then add ONE between items */
.h6-footer .copyright-menu ul {
  display: flex !important;
  gap: 26px !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  align-items: center !important;
}
.h6-footer .copyright-menu ul li,
.copyright-content-area .copyright-menu ul li {
  position: relative !important;
  margin: 0 !important;
  padding: 0 !important;
}
.h6-footer .copyright-menu ul li::before,
.copyright-content-area .copyright-menu ul li::before,
.copyright-content-area .copyright-menu ul li:last-child::before {
  content: none !important;
  display: none !important;
  width: 0 !important;
  height: 0 !important;
  background: transparent !important;
}
.h6-footer .copyright-menu ul li + li::before {
  content: "•" !important;
  display: inline-block !important;
  position: absolute !important;
  left: -16px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: auto !important;
  height: auto !important;
  background: transparent !important;
  border-radius: 0 !important;
  color: rgba(255,255,255,0.55) !important;
  font-size: 14px !important;
  line-height: 1 !important;
}

/* 3-icon social row */
.h6-footer .copyright-socails ul {
  display: flex;
  gap: 10px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.h6-footer .copyright-socails ul li a {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.75);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  transition: background 0.25s ease, color 0.25s ease;
}
.h6-footer .copyright-socails ul li a:hover {
  background: var(--brand-teal);
  color: #fff;
}

/* Orange backtop circle */
.h6-footer .backtop {
  background: var(--brand-orange);
  color: #fff;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.h6-footer .backtop:hover {
  background: var(--brand-red-orange);
}

/* ================================================================ */
/* Diagnose page                                                     */
/* ================================================================ */

/* Active menu highlight */
.tj-header-area .mainmenu ul li.has-dropdown.active > a,
.tj-header-area .mainmenu ul li.active > a {
  color: var(--brand-orange) !important;
}

/* Page hero — title only, with dotted ring decorations on both sides */
.diagnose-page-hero {
  position: relative;
  padding-top: 160px;
  padding-bottom: 70px;
  background: #f4f4f5;
  overflow: hidden;
}
.diagnose-page-hero .dotted-shape {
  position: absolute;
  top: 180px;
  width: 220px;
  height: 220px;
  background-image: url('images/logos/infer360-logo-dotted.svg');
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  opacity: 0.5;
  pointer-events: none;
}
.diagnose-page-hero .dotted-shape.shape-left  { left: -90px; }
.diagnose-page-hero .dotted-shape.shape-right { right: -90px; }
.diagnose-page-hero .page-hero-inner {
  text-align: center;
  max-width: 1024px;
  margin: 0 auto;
}
.diagnose-page-hero .page-hero-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(32px, 3.2vw, 46px);
  line-height: 1.12;
  letter-spacing: -0.01em;
  color: var(--brand-charcoal);
  margin: 0;
}
/* Wrap long faded section titles (e.g. "Framework360 & The Intelligence Stack") */
.diagnose-page-hero .suite-toptitle .strip-title {
  white-space: normal;
  max-width: 1024px;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 991px) {
  .diagnose-page-hero { padding-top: 130px; padding-bottom: 50px; }
  .diagnose-page-hero .dotted-shape { display: none; }
}

/* Suite stack — section bg light gray (per Figma) */
.diagnose-suite-section {
  padding-top: 30px;
  padding-bottom: 90px;
  background: #f4f4f5;
}
.suite-card {
  margin-bottom: 30px;
}
.suite-card:last-of-type { margin-bottom: 80px; }
.suite-card-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  background: var(--brand-navy);
  border-radius: 6px;
  overflow: hidden;
  min-height: 540px;
}
.suite-content {
  padding: 60px 60px 60px 65px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  color: #ffffff;
}
.suite-meta {
  position: absolute;
  top: 60px;
  left: 65px;
  font-family: var(--font-sans);
  display: flex;
  align-items: baseline;
  gap: 2px;
  line-height: 1;
}
.suite-meta .num {
  font-size: 18px;
  color: #f7f7f7;
  font-weight: 400;
}
.suite-meta .num-total {
  font-size: 14px;
  color: #676e7a;
}
.suite-icon {
  font-size: 62px;
  line-height: 1;
  color: var(--brand-teal);
  margin-bottom: 32px;
  margin-top: 8px;
  letter-spacing: -0.01em;
}
.suite-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 32px;
  line-height: 1.2;
  letter-spacing: -0.025em;
  color: #ffffff;
  margin: 0 0 22px;
  max-width: 500px;
}
.suite-desc {
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.6;
  color: #e1e8f0;
  margin: 0;
  max-width: 500px;
}
.suite-image {
  position: relative;
  overflow: hidden;
  background: #0b2436;
}
.suite-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
@media (max-width: 991px) {
  .suite-card-inner { grid-template-columns: 1fr; min-height: 0; }
  .suite-content { padding: 80px 30px 40px; }
  .suite-meta { top: 30px; left: 30px; }
  .suite-image { height: 280px; }
  .suite-title { font-size: 26px; }
}

/* Faded big title above hero — "The Diagnose Suite" */
.suite-toptitle {
  text-align: center;
  margin-bottom: 18px;
}
.suite-toptitle .strip-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(36px, 5vw, 72px);
  line-height: 1.08;
  letter-spacing: -0.01em;
  color: rgba(7, 49, 73, 0.10);
  margin: 0;
  text-align: center;
  white-space: nowrap;
}
@media (max-width: 767px) {
  .suite-toptitle .strip-title { font-size: 32px; white-space: normal; }
}

/* ================================================================ */
/* Defend page — full-bleed bg cards with glass content panel        */
/* ================================================================ */
.defend-suite-section {
  padding-top: 30px;
  padding-bottom: 90px;
  background: #f4f4f5;
}
.defend-card {
  position: relative;
  min-height: 670px;
  margin-bottom: 30px;
  border-radius: 6px;
  overflow: hidden;
  background-color: #0e0e0f;
  background-size: contain;
  background-position: right center;
  background-repeat: no-repeat;
  display: flex;
  align-items: flex-end;
  padding: 60px;
}
/* Secure card aspect 1296×670 matches card — let it fill via cover */
.defend-card#secure {
  background-size: cover;
  background-position: center;
}
.defend-card:last-of-type { margin-bottom: 0; }
.defend-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(7,49,73,0) 50%, #073149 100%);
  pointer-events: none;
}
.defend-glass {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 460px;
  padding: 30px;
  background: rgba(255,255,255,0.10);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.defend-icon {
  font-size: 62px;
  line-height: 1;
  color: var(--brand-teal);
  letter-spacing: -0.01em;
  height: 67px;
  display: flex;
  align-items: center;
}
.defend-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 32px;
  line-height: 1.2;
  letter-spacing: -0.025em;
  color: #ffffff;
  margin: 0;
  max-width: 400px;
}
.defend-desc {
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.6;
  color: #e1e8f0;
  margin: 0;
  max-width: 400px;
}
@media (max-width: 991px) {
  .defend-card { padding: 30px; min-height: 520px; }
  .defend-glass { max-width: 100%; padding: 24px; }
  .defend-title { font-size: 26px; }
}

/* ================================================================ */
/* Solutions — Core Suite (3-step horizontal timeline)                */
/* ================================================================ */
.core-suite-section {
  padding: 30px 0 60px;
  background: #f4f4f5;
}
.core-suite-heading {
  margin-bottom: 60px;
  text-align: center;
}
.core-suite-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(34px, 3.6vw, 48px);
  line-height: 1.1;
  letter-spacing: -0.015em;
  color: var(--brand-charcoal);
  margin: 0 0 18px;
}
.core-suite-sub {
  font-family: var(--font-sans);
  font-size: 17px;
  line-height: 1.5;
  color: rgba(51,49,52,0.78);
  margin: 0;
}

/* Horizontal 3-step timeline — pin/balloon bubbles on a horizontal line */
.process-timeline.horizontal {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  padding-top: 96px;   /* room for bubble + pin above card */
}
.process-timeline.horizontal .timeline-line {
  position: absolute;
  top: 28px;           /* through bubble center */
  left: 0;
  right: 0;
  height: 1px;
  background: rgba(7,49,73,0.20);
  z-index: 0;
}
.process-timeline.horizontal .timeline-line-active {
  display: none;       /* not used in Figma — line is uniform gray */
}
.process-timeline .process-item {
  position: relative;
  background: #e6ecf2;
  border-radius: 4px;
  text-align: left;
  display: flex;
  flex-direction: column;
  cursor: default;
  transition: background 0.3s ease;
}
.process-timeline .process-item .process-content {
  padding: 70px 30px 40px;
}
.process-timeline .process-item .process-title,
.process-timeline .process-item .process-desc {
  transition: color 0.3s ease;
}

/* Bubble = pill (circle + stem). Inner span is the numbered disc.
   Inactive (02/03): short charcoal pill, number on dark.
   Active (01): tall teal pill that visually merges with teal card,
                inner white disc with dark number. */
.process-timeline .process-bubble {
  position: absolute;
  top: -28px;            /* circle center sits on horizontal line */
  left: 50%;
  transform: translateX(-50%);
  width: 52px;
  height: 52px;
  background: #333134;
  border-radius: 50%;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.3s ease;
}
.process-timeline .process-bubble::before {
  /* stem dropping toward card */
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  width: 26px;
  height: 28px;
  background: inherit;
  border-radius: 0 0 13px 13px;
  transition: height 0.3s ease;
}
.process-timeline .process-bubble::after { display: none; }
.process-timeline .process-bubble span {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font: 600 13px/1 var(--font-sans);
  color: #ffffff;
  background: transparent;
  transition: background 0.3s ease, color 0.3s ease;
}

/* Active state — 01 (default): teal pin merges into teal card; inner white disc */
.process-timeline .process-item.active {
  background: var(--brand-teal);
}
.process-timeline .process-item.active .process-title,
.process-timeline .process-item.active .process-desc { color: #ffffff; }
.process-timeline .process-item.active .process-bubble {
  background: var(--brand-teal);
}
.process-timeline .process-item.active .process-bubble::before {
  height: 70px;     /* extends into card top */
}
.process-timeline .process-item.active .process-bubble span {
  background: #ffffff;
  color: var(--brand-charcoal);
}

/* Hover any non-active item → that becomes active style; default 01 demotes */
.process-timeline .process-item:not(.active):hover {
  background: var(--brand-teal);
}
.process-timeline .process-item:not(.active):hover .process-title,
.process-timeline .process-item:not(.active):hover .process-desc {
  color: #ffffff;
}
.process-timeline .process-item:not(.active):hover .process-bubble {
  background: var(--brand-teal);
}
.process-timeline .process-item:not(.active):hover .process-bubble::before {
  height: 70px;
}
.process-timeline .process-item:not(.active):hover .process-bubble span {
  background: #ffffff;
  color: var(--brand-charcoal);
}
.core-suite-section:has(.process-item:not(.active):hover) .process-item.active,
.fw360-agentic-section:has(.process-item:not(.active):hover) .process-item.active {
  background: #e6ecf2;
}
.core-suite-section:has(.process-item:not(.active):hover) .process-item.active .process-title,
.core-suite-section:has(.process-item:not(.active):hover) .process-item.active .process-desc,
.fw360-agentic-section:has(.process-item:not(.active):hover) .process-item.active .process-title,
.fw360-agentic-section:has(.process-item:not(.active):hover) .process-item.active .process-desc {
  color: var(--brand-charcoal);
}
.core-suite-section:has(.process-item:not(.active):hover) .process-item.active .process-bubble,
.fw360-agentic-section:has(.process-item:not(.active):hover) .process-item.active .process-bubble {
  background: #333134;
}
.core-suite-section:has(.process-item:not(.active):hover) .process-item.active .process-bubble::before,
.fw360-agentic-section:has(.process-item:not(.active):hover) .process-item.active .process-bubble::before {
  height: 28px;
}
.core-suite-section:has(.process-item:not(.active):hover) .process-item.active .process-bubble span,
.fw360-agentic-section:has(.process-item:not(.active):hover) .process-item.active .process-bubble span {
  background: transparent;
  color: #ffffff;
}
.process-timeline .process-bubble {
  position: absolute;
  top: -56px;
  left: 50%;
  transform: translateX(-50%);
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #333134;
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font: 600 14px/1 var(--font-sans);
}
.process-timeline .process-bubble::after {
  content: "";
  position: absolute;
  bottom: -10px;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-top: 10px solid #333134;
}
.process-timeline .process-item.active .process-bubble {
  background: var(--brand-teal);
  color: #ffffff;
}
.process-timeline .process-item.active .process-bubble::after { border-top-color: var(--brand-teal); }
.process-timeline .process-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 26px;
  line-height: 1.1;
  letter-spacing: -0.015em;
  color: var(--brand-charcoal);
  margin: 0 0 16px;
}
.process-timeline .process-desc {
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.65;
  color: rgba(51,49,52,0.82);
  margin: 0;
}
@media (max-width: 991px) {
  .process-timeline.horizontal,
  .process-timeline.horizontal.three,
  .process-timeline.horizontal.two { grid-template-columns: 1fr; gap: 60px; padding-top: 60px; max-width: 100%; }
  .process-timeline.horizontal .timeline-line { display: none; }
  .process-timeline .process-item { padding-top: 50px; }
}

/* ================================================================ */
/* Solutions — DEFEND & Operational TP (vertical 04/05 + banner)      */
/* ================================================================ */
.defend-ops-section {
  padding: 70px 0 90px;
  background: #f4f4f5;
}
.defend-ops-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(34px, 3.6vw, 48px);
  line-height: 1.1;
  letter-spacing: -0.015em;
  color: var(--brand-charcoal);
  margin: 0 0 50px;
}
.defend-ops-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 50px;
  align-items: stretch;
}
.defend-ops-steps {
  position: relative;
  padding-left: 70px;
  display: flex;
  flex-direction: column;
  gap: 50px;
}
.defend-ops-vline {
  position: absolute;
  left: 28px;
  top: 30px;
  bottom: 30px;
  width: 1px;
  background: rgba(7,49,73,0.20);
}
.defend-ops-item {
  position: relative;
}
.defend-ops-item .process-bubble {
  position: absolute;
  top: 0;
  left: -70px;
  transform: none;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #333134;
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font: 600 14px/1 var(--font-sans);
}
.defend-ops-item .process-bubble::after { display: none; }
.defend-ops-item .process-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 24px;
  letter-spacing: -0.01em;
  color: var(--brand-charcoal);
  margin: 0 0 14px;
  padding-top: 6px;
}
.defend-ops-item .process-desc {
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.65;
  color: rgba(51,49,52,0.82);
  margin: 0 0 18px;
}
.process-bullets {
  list-style: none;
  margin: 0;
  padding: 0;
}
.process-bullets li {
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.55;
  color: rgba(51,49,52,0.78);
  padding-left: 20px;
  position: relative;
  margin-bottom: 6px;
}
.process-bullets li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 9px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--brand-teal);
}

.defend-ops-banner {
  border-radius: 12px;
  background-color: #073149;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  aspect-ratio: 630 / 719;
  min-height: 0;
  position: relative;
  overflow: hidden;
}
.defend-ops-banner::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(7,49,73,0.10) 0%, rgba(7,49,73,0.60) 100%);
  pointer-events: none;
}
@media (max-width: 991px) {
  .defend-ops-grid { grid-template-columns: 1fr; gap: 30px; }
  .defend-ops-banner { aspect-ratio: 630 / 519; }
}

/* ================================================================ */
/* Solutions page — pricing/comparison table                          */
/* ================================================================ */
.solutions-table-section {
  padding-top: 30px;
  padding-bottom: 100px;
  background: #f4f4f5;
}
.solutions-table-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(34px, 3.6vw, 48px);
  line-height: 1.1;
  letter-spacing: -0.015em;
  color: var(--brand-charcoal);
  margin: 0 0 50px;
}
.solutions-table {
  display: grid;
  grid-template-columns: minmax(180px, 1.27fr) repeat(3, 1fr);
  gap: 0;
  align-items: stretch;
  position: relative;
}
.tier-col {
  padding: 30px 30px 40px;
  display: flex;
  flex-direction: column;
  position: relative;
  background: #ffffff;
  border-radius: 18px;
  min-height: 710px;
  cursor: default;
  transition: background 0.3s ease, color 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease;
}
/* Hover: tint Foundation/Command to teal — Professional stays teal (no change) */
.tier-col:not(.tier-features):not(.tier-featured):hover {
  background: var(--brand-teal);
  transform: translateY(-4px);
  box-shadow: 0 24px 60px rgba(7,49,73,0.18);
}
.tier-col:not(.tier-features):not(.tier-featured):hover .tier-name,
.tier-col:not(.tier-features):not(.tier-featured):hover .tier-sub,
.tier-col:not(.tier-features):not(.tier-featured):hover .tier-row {
  color: #ffffff;
}
.tier-col:not(.tier-features):not(.tier-featured):hover .tier-head { border-bottom-color: rgba(255,255,255,0.30); }
.tier-col:not(.tier-features):not(.tier-featured):hover .tier-row { border-bottom-color: rgba(255,255,255,0.20); }
/* Features col hover: subtle highlight */
.tier-col.tier-features:hover .tier-row { color: var(--brand-teal); }

/* When hovering Foundation/Command, demote Professional to white */
.solutions-table:has(.tier-foundation:hover) .tier-featured:not(:hover),
.solutions-table:has(.tier-command:hover) .tier-featured:not(:hover) {
  background: #ffffff;
}
.solutions-table:has(.tier-foundation:hover) .tier-featured:not(:hover) .tier-name,
.solutions-table:has(.tier-command:hover) .tier-featured:not(:hover) .tier-name,
.solutions-table:has(.tier-foundation:hover) .tier-featured:not(:hover) .tier-sub,
.solutions-table:has(.tier-command:hover) .tier-featured:not(:hover) .tier-sub,
.solutions-table:has(.tier-foundation:hover) .tier-featured:not(:hover) .tier-row,
.solutions-table:has(.tier-command:hover) .tier-featured:not(:hover) .tier-row {
  color: var(--brand-charcoal);
}
.solutions-table:has(.tier-foundation:hover) .tier-featured:not(:hover) .tier-head,
.solutions-table:has(.tier-command:hover) .tier-featured:not(:hover) .tier-head {
  border-bottom-color: rgba(7,49,73,0.10);
}
.solutions-table:has(.tier-foundation:hover) .tier-featured:not(:hover) .tier-row,
.solutions-table:has(.tier-command:hover) .tier-featured:not(:hover) .tier-row {
  border-bottom-color: rgba(7,49,73,0.08);
}
/* Features column has no card chrome */
.tier-col.tier-features {
  background: transparent;
  border-radius: 0;
  padding-left: 0;
  padding-right: 24px;
}
/* Top-right corner notch on tier cards (visual cue per Figma) */
.tier-col:not(.tier-features)::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 40px;
  height: 28px;
  background: #f4f4f5;
  border-bottom-left-radius: 14px;
}
/* Featured column — teal, raised */
.tier-col.tier-featured {
  background: var(--brand-teal);
  color: #ffffff;
  margin: -10px 0;
  z-index: 2;
  box-shadow: 0 24px 60px rgba(7,49,73,0.18);
}
.tier-col.tier-featured::after { background: #f4f4f5; }
.tier-head {
  text-align: center;
  padding: 18px 0 30px;
  border-bottom: 1px solid rgba(7,49,73,0.10);
  margin-bottom: 0;
}
.tier-features .tier-head { text-align: left; padding-left: 0; }
.tier-featured .tier-head { border-bottom-color: rgba(255,255,255,0.30); }
.tier-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 36px;
  line-height: 1.1;
  letter-spacing: -0.01em;
  color: var(--brand-charcoal);
  margin: 0 0 6px;
}
.tier-features .tier-name { font-size: 18px; font-weight: 700; }
.tier-featured .tier-name { color: #ffffff; }
.tier-sub {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 500;
  color: var(--brand-charcoal);
  letter-spacing: -0.01em;
}
.tier-featured .tier-sub { color: #ffffff; }
.tier-row {
  text-align: center;
  padding: 28px 12px;
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.45;
  color: var(--brand-charcoal);
  border-bottom: 1px solid rgba(7,49,73,0.08);
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  justify-content: center;
}
.tier-features .tier-row {
  text-align: left;
  font-weight: 500;
  justify-content: flex-start;
}
.tier-featured .tier-row {
  color: #ffffff;
  border-bottom-color: rgba(255,255,255,0.20);
}
.tier-col .tier-row:last-child { border-bottom: 0; }

@media (max-width: 991px) {
  .solutions-table {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .tier-col.tier-featured { margin: 0; }
  .tier-col.tier-features {
    display: none; /* feature labels merged into each tier card on mobile */
  }
  .tier-col:not(.tier-features)::after { display: none; }
}

/* ================================================================ */
/* Framework360 page                                                 */
/* ================================================================ */

/* Section 1 — Transformation Walk-up */
.fw360-walkup-section {
  padding-top: 30px;
  padding-bottom: 100px;
  background: #f4f4f5;
}
.walkup-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: stretch;
}
.walkup-banner {
  position: relative;
  min-height: 730px;
  border-radius: 12px;
  overflow: hidden;
  background-color: #050b1a;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.walkup-banner-overlay {
  /* no full-card overlay; chart should remain visible */
  display: none;
}
.walkup-banner-glass {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  padding: 40px 40px 36px;
  background: rgba(7,11,26,0.55);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.walkup-banner-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 48px;
  line-height: 1.2;
  letter-spacing: -0.025em;
  color: #ffffff;
  margin: 0 0 18px;
  max-width: 400px;
}
.walkup-banner-body {
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.5;
  color: #ffffff;
  margin: 0;
  max-width: 400px;
}

/* 3-step walkup — card-style with teal numbered circles on a vertical line */
.walkup-steps {
  display: flex;
  flex-direction: column;
  gap: 18px;
  position: relative;
  padding-left: 70px;
}
.walkup-steps::before {
  content: "";
  position: absolute;
  top: 24px;
  bottom: 24px;
  left: 24px;
  width: 1px;
  background: rgba(7,49,73,0.18);
}
.walkup-step {
  position: relative;
  background: #ffffff;
  border: 1px solid rgba(7,49,73,0.10);
  border-radius: 8px;
  padding: 22px 28px 24px;
  box-shadow: 0 6px 18px rgba(7,49,73,0.04);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.walkup-step:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(7,49,73,0.08);
}
.walkup-step .step-num {
  position: absolute;
  top: 22px;
  left: -70px;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--brand-teal);
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font: 600 16px/1 var(--font-sans);
  z-index: 1;
}
.walkup-step .step-content { padding: 0; }
.walkup-step .step-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 20px;
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--brand-charcoal);
  margin: 0 0 8px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.walkup-step .step-title i {
  color: var(--brand-charcoal);
  font-size: 18px;
}
.walkup-step .step-desc {
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.55;
  color: rgba(51,49,52,0.78);
  margin: 0;
}
.walkup-step .step-desc strong {
  color: var(--brand-charcoal);
  font-weight: 600;
}

@media (max-width: 991px) {
  .walkup-grid { grid-template-columns: 1fr; gap: 30px; }
  .walkup-banner { min-height: 400px; }
  .walkup-banner-title { font-size: 36px; }
  .walkup-steps { padding-left: 30px; }
  .walkup-steps::before { left: 14px; }
  .walkup-step .step-num {
    position: static;
    margin-left: -54px;
    width: 50px;
    height: 50px;
    font-size: 16px;
  }
  .walkup-step .step-content { margin-left: 14px; }
}

/* Hero stat cards (3-up + Promise strip) */
.fw360-stats-section {
  padding: 0 0 0;
  background: #f4f4f5;
  position: relative;
  z-index: 1;
}
.fw360-stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 0;
}
.fw360-stat-card {
  background: #ffffff;
  border: 1px solid rgba(7,49,73,0.10);
  border-radius: 4px;
  padding: 36px 32px 38px;
  text-align: left;
  display: flex;
  flex-direction: column;
}
.fw360-stat-icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(7,49,73,0.08);
  color: var(--brand-charcoal);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 26px;
  margin-bottom: 30px;
}
.fw360-stat-num {
  font-family: var(--font-sans);
  font-size: 13px;
  color: rgba(51,49,52,0.55);
  margin-bottom: 6px;
  letter-spacing: 0.04em;
}
.fw360-stat-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  letter-spacing: -0.01em;
  color: var(--brand-charcoal);
  margin: 0 0 14px;
}
.fw360-stat-desc {
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.55;
  color: rgba(51,49,52,0.78);
  margin: 0;
}
.fw360-promise {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  background: var(--brand-teal);
  color: #ffffff;
  padding: 22px 30px;
  border-radius: 4px;
  margin-top: 28px;
}
.fw360-promise i {
  flex-shrink: 0;
  font-size: 22px;
  margin-top: 2px;
}
.fw360-promise p {
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.55;
  margin: 0;
}
@media (max-width: 991px) {
  .fw360-stats-grid { grid-template-columns: 1fr; }
}

/* Generic Framework360 section heading */
.fw360-section-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(34px, 3.6vw, 48px);
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--brand-charcoal);
  margin: 0 0 18px;
}
.fw360-section-body {
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.55;
  color: rgba(51,49,52,0.78);
  margin: 0 0 40px;
  max-width: 760px;
}
.fw360-agentic-heading .fw360-section-body { margin-left: auto; margin-right: auto; }

/* The Data Foundation */
.fw360-data-section {
  padding: 90px 0 70px;
  background: #f4f4f5;
}
.fw360-data-heading { margin-bottom: 40px; }
.fw360-data-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
  align-items: stretch;
}
.fw360-data-image {
  border-radius: 6px;
  overflow: hidden;
  background: #073149;
}
.fw360-data-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.fw360-data-cards {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.fw360-data-card {
  background: #ffffff;
  border: 1px solid rgba(7,49,73,0.10);
  border-radius: 8px;
  padding: 30px 36px;
}
.fw360-data-card-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  letter-spacing: -0.01em;
  color: var(--brand-charcoal);
  margin: 0 0 12px;
}
.fw360-data-card p {
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.55;
  color: rgba(51,49,52,0.78);
  margin: 0;
}
@media (max-width: 991px) {
  .fw360-data-grid { grid-template-columns: 1fr; }
  .fw360-data-image { min-height: 280px; }
}

/* The Agentic Process Layer */
.fw360-agentic-section {
  padding: 90px 0;
  background: #ffffff;
}
.fw360-trust-strip {
  margin-top: 50px;
  background: var(--brand-navy);
  color: #ffffff;
  padding: 24px 32px;
  border-radius: 4px;
}
.fw360-trust-strip p {
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.55;
  margin: 0;
}

/* The Command Center */
.fw360-command-section {
  padding: 90px 0;
  background: #f4f4f5;
}
.fw360-command-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}
.fw360-command-image {
  border-radius: 999px 999px 12px 12px;
  overflow: hidden;
  aspect-ratio: 1 / 1.05;
  background: #073149;
}
.fw360-command-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
.fw360-command-card {
  border-radius: 8px;
  padding: 26px 30px 28px;
  margin-bottom: 18px;
  cursor: default;
  transition: background 0.3s ease, color 0.3s ease, transform 0.3s ease, border-color 0.3s ease;
}
.fw360-command-card.teal {
  background: var(--brand-teal);
  color: #ffffff;
  border: 1px solid var(--brand-teal);
}
.fw360-command-card.light {
  background: #ffffff;
  border: 1px solid rgba(7,49,73,0.10);
}
/* Hover Co-Pilot (light) → it turns teal, Core Features (teal) demotes to white */
.fw360-command-card.light:hover {
  background: var(--brand-teal);
  color: #ffffff;
  border-color: var(--brand-teal);
  transform: translateY(-2px);
}
.fw360-command-card.light:hover .fw360-command-card-title { color: #ffffff; }
.fw360-command-card.light:hover p { color: #ffffff; }
.fw360-command-content:has(.fw360-command-card.light:hover) .fw360-command-card.teal {
  background: #ffffff;
  color: var(--brand-charcoal);
  border-color: rgba(7,49,73,0.10);
}
.fw360-command-content:has(.fw360-command-card.light:hover) .fw360-command-card.teal .fw360-command-card-title {
  color: var(--brand-charcoal);
}
.fw360-command-content:has(.fw360-command-card.light:hover) .fw360-command-card.teal .fw360-bullet-list li {
  color: var(--brand-charcoal);
}
.fw360-command-content:has(.fw360-command-card.light:hover) .fw360-command-card.teal .fw360-bullet-list li::before {
  color: var(--brand-teal);
}
.fw360-command-card-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 20px;
  letter-spacing: -0.005em;
  margin: 0 0 12px;
}
.fw360-command-card.teal .fw360-command-card-title { color: #ffffff; }
.fw360-command-card.light .fw360-command-card-title { color: var(--brand-charcoal); }
.fw360-command-card p {
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.55;
  color: rgba(51,49,52,0.82);
  margin: 0;
}
.fw360-bullet-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.fw360-bullet-list li {
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.55;
  padding-left: 18px;
  position: relative;
  margin-bottom: 6px;
}
.fw360-bullet-list li::before {
  content: "•";
  position: absolute;
  left: 0;
  color: #ffffff;
}
@media (max-width: 991px) {
  .fw360-command-grid { grid-template-columns: 1fr; gap: 30px; }
}

/* Section 2 — TP Intelligence Stack */
.fw360-stack-section {
  position: relative;
  background-color: #073149;
  background-size: contain;
  background-position: left center;
  background-repeat: no-repeat;
  min-height: 600px;
  padding: 130px 0;
  display: flex;
  align-items: center;
}
.fw360-stack-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(7,49,73,0.0) 0%, rgba(7,49,73,0.45) 60%, rgba(7,49,73,0.85) 100%);
  pointer-events: none;
}
.fw360-stack-section .container {
  position: relative;
  z-index: 1;
}
.fw360-stack-content {
  color: #ffffff;
  max-width: 460px;
  padding: 30px;
  background: rgba(7,49,73,0.40);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  border-radius: 8px;
}
.fw360-stack-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 48px;
  line-height: 1.15;
  letter-spacing: -0.025em;
  color: #ffffff;
  margin: 0 0 24px;
}
.fw360-stack-body {
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.6;
  color: #e1e8f0;
  margin: 0;
}

@media (max-width: 991px) {
  .fw360-stack-section { padding: 80px 0; min-height: 480px; }
  .fw360-stack-title { font-size: 34px; }
  .fw360-stack-content { max-width: 100%; }
}

/* ================================================================ */
/* Resources & Team page                                              */
/* ================================================================ */
.resources-feature-section {
  position: relative;
  padding: 60px 0 100px;
  background: #f4f4f5;
  overflow: hidden;
}
.resources-feature-bg {
  position: absolute;
  top: 30px;
  right: -90px;
  width: 850px;
  height: 600px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  pointer-events: none;
  border-radius: 0 0 0 50px;
  z-index: 0;
  box-shadow: -20px 20px 60px rgba(7,49,73,0.18);
}
.resources-feature-section::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(244,244,245,1) 0%, rgba(244,244,245,0.95) 35%, rgba(244,244,245,0.0) 60%);
  pointer-events: none;
  z-index: 1;
}
.resources-feature-section .container { position: relative; z-index: 2; }
.resource-center-content {
  background: rgba(255,255,255,0.96);
  padding: 40px 44px;
  border-radius: 8px;
  max-width: 700px;
  box-shadow: 0 20px 50px rgba(7,49,73,0.10);
  margin-right: -40px;
}
.resource-center-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 36px;
  line-height: 1.1;
  letter-spacing: -0.01em;
  color: var(--brand-charcoal);
  margin: 0 0 30px;
}
.resource-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.resource-card {
  padding: 0;
}
.resource-icon {
  font-size: 32px;
  color: var(--brand-charcoal);
  margin-bottom: 16px;
}
.resource-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 20px;
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--brand-charcoal);
  margin: 0 0 10px;
}
.resource-desc {
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.55;
  color: rgba(51,49,52,0.78);
  margin: 0;
}
@media (max-width: 991px) {
  .resources-feature-bg { display: none; }
  .resource-center-content { max-width: 100%; }
  .resource-cards { grid-template-columns: 1fr; }
}

/* Mission & Team section */
.resources-team-section {
  padding: 90px 0;
  background: #ffffff;
}
.resources-team-heading {
  text-align: center;
  margin-bottom: 60px;
}
.resources-team-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(34px, 4vw, 52px);
  line-height: 1.1;
  letter-spacing: -0.015em;
  color: var(--brand-charcoal);
  margin: 0 0 18px;
}
.resources-team-body {
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.6;
  color: rgba(51,49,52,0.82);
  margin: 0 auto;
  max-width: 760px;
}

.team-tabs-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 50px;
}
.team-tab {
  position: relative;
  border: 0;
  background: transparent;
  padding: 0;
  cursor: pointer;
  border-radius: 8px;
  overflow: hidden;
  aspect-ratio: 1 / 1;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.team-tab img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.team-tab.active {
  outline: 3px solid var(--brand-teal);
  outline-offset: 4px;
}
.team-tab:hover { transform: translateY(-2px); }

.team-tab-info {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 60px;
  background: #f4f4f5;
  border-radius: 8px;
  padding: 50px;
  align-items: start;
}
.team-tab-info[hidden] { display: none; }
.team-info-left {
  position: relative;
  min-height: 240px;
}
.team-info-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 32px;
  line-height: 1.1;
  letter-spacing: -0.015em;
  color: var(--brand-charcoal);
  margin: 0 0 6px;
}
.team-info-role {
  display: inline-block;
  font: 500 14px/1.4 var(--font-sans);
  color: var(--brand-teal);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 22px;
}
.team-info-social {
  list-style: none;
  margin: 0 0 30px;
  padding: 0;
  display: flex;
  gap: 8px;
}
.team-info-social li a {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(7,49,73,0.10);
  color: var(--brand-navy);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  transition: background 0.2s ease, color 0.2s ease;
}
.team-info-social li a:hover {
  background: var(--brand-teal);
  color: #ffffff;
}
.team-info-shape {
  position: absolute;
  bottom: -10px;
  left: 0;
  width: 200px;
  height: 200px;
  background-image: url('images/logos/infer360-logo-dotted.svg');
  background-repeat: no-repeat;
  background-size: contain;
  background-position: bottom left;
  opacity: 0.35;
  pointer-events: none;
}
.team-info-right p {
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.65;
  color: rgba(51,49,52,0.85);
  margin: 0;
}
@media (max-width: 991px) {
  .team-tabs-grid { grid-template-columns: 1fr 1fr; }
  .team-tab-info { grid-template-columns: 1fr; gap: 30px; padding: 30px; }
  .team-info-shape { display: none; }
}

/* Section 3 — CTA strip */
.resources-cta-section {
  position: relative;
  padding: 50px 0;
  background-color: var(--brand-teal);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-blend-mode: multiply;
}
.resources-cta-section .cta-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  flex-wrap: wrap;
}
.resources-cta-section .cta-icon {
  width: 66px;
  height: 66px;
  border-radius: 50%;
  background: var(--brand-charcoal);
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  flex-shrink: 0;
}
.resources-cta-section .cta-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(28px, 3.4vw, 48px);
  line-height: 1.15;
  letter-spacing: -0.015em;
  color: #f7f7f7;
  margin: 0;
  flex: 1 1 auto;
  text-align: left;
}
.resources-cta-section .cta-btn {
  background: #f7f7f7;
  border-radius: 50px;
  padding: 5.5px;
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  flex-shrink: 0;
  transition: transform 0.2s ease;
}
.resources-cta-section .cta-btn:hover { transform: translateY(-1px); }
.resources-cta-section .cta-btn-icon {
  width: 45px;
  height: 46px;
  border-radius: 50px;
  background: var(--brand-teal);
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
}
.resources-cta-section .cta-btn-text {
  font: 700 15px/1 var(--font-sans);
  color: var(--brand-charcoal);
  padding: 0 22px 0 16px;
}
@media (max-width: 767px) {
  .resources-cta-section .cta-row { flex-direction: column; text-align: center; gap: 18px; }
  .resources-cta-section .cta-title { text-align: center; }
}

/* ================================================================ */
/* Contact page                                                       */
/* ================================================================ */
.diagnose-page-hero .page-hero-body {
  font-family: var(--font-sans);
  font-size: 17px;
  line-height: 1.55;
  color: rgba(51,49,52,0.78);
  margin: 24px auto 0;
  max-width: 720px;
}

/* Section 1 — Info cards (4-col, centered, mint icon circles) */
.contact-info-section {
  padding: 20px 0 70px;
  background: #F7F7F7;
}
.contact-info-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.contact-info-grid--3 {
  grid-template-columns: repeat(3, 1fr);
  max-width: 1320px;
  margin: 0 auto;
  gap: 36px;
}
.contact-info-card {
  background: #ffffff;
  padding: 40px 24px 36px;
  border: 1px solid rgba(7,49,73,0.10);
  border-radius: 6px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  min-height: 280px;
}
.contact-info-icon {
  width: 78px;
  height: 78px;
  border-radius: 50%;
  background: rgba(39,191,212,0.18);
  color: var(--brand-teal);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  margin-bottom: 28px;
}
.contact-info-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  letter-spacing: -0.01em;
  color: var(--brand-charcoal);
  margin: 0 0 14px;
}
.contact-info-text {
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.6;
  color: rgba(51,49,52,0.78);
  margin: 0;
}
.contact-info-text a {
  color: var(--brand-charcoal);
  text-decoration: none;
}
.contact-info-text a:hover { color: var(--brand-teal); }

.contact-social-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 8px;
}
.contact-social-list li a {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(7,49,73,0.10);
  color: var(--brand-charcoal);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  transition: background 0.2s ease, color 0.2s ease;
}
.contact-social-list li a:hover { background: var(--brand-teal); color: #fff; }

@media (max-width: 991px) {
  .contact-info-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 575px) {
  .contact-info-grid { grid-template-columns: 1fr; }
}

/* Topic tabs above form */
.contact-tabs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  max-width: 1020px;
  margin: 0 auto 30px;
}
.contact-tab {
  background: #ffffff;
  border: 2px solid transparent;
  border-radius: 10px;
  padding: 22px 18px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  transition: border-color 0.2s ease, background 0.2s ease, transform 0.15s ease;
  box-shadow: 0 6px 16px rgba(7,49,73,0.06);
}
.contact-tab i {
  font-size: 26px;
  color: var(--brand-charcoal);
}
.contact-tab span {
  font: 600 14px/1.2 var(--font-sans);
  color: var(--brand-charcoal);
  text-align: center;
}
.contact-tab:hover {
  transform: translateY(-2px);
  border-color: rgba(39,191,212,0.30);
}
.contact-tab.active {
  background: var(--brand-teal);
  border-color: var(--brand-teal);
}
.contact-tab.active i,
.contact-tab.active span {
  color: #ffffff;
}
@media (max-width: 767px) {
  .contact-tabs { grid-template-columns: 1fr 1fr; }
}

/* Section 2 — Main form */
.contact-form-section {
  padding: 30px 0 90px;
  background: #f4f4f5;
}
.contact-form-wrap {
  background: #393638;
  border-radius: 8px;
  padding: 60px 60px 70px;
  max-width: 1020px;
  margin: 0 auto;
}
.contact-form-heading {
  text-align: center;
  margin-bottom: 40px;
}
.contact-form-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1.2;
  letter-spacing: -0.015em;
  color: #ffffff;
  margin: 0 0 14px;
}
.contact-form-sub {
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.55;
  color: rgba(255,255,255,0.65);
  margin: 0;
}

.contact-main-form .form-input input,
.contact-main-form .form-input textarea {
  width: 100%;
  background: transparent;
  border: 0;
  border-bottom: 1px solid rgba(255,255,255,0.18);
  color: #fff;
  padding: 16px 0;
  font: 400 15px/1.4 var(--font-sans);
  outline: none;
  transition: border-color 0.2s ease;
}
.contact-main-form .form-input input:focus,
.contact-main-form .form-input textarea:focus {
  border-bottom-color: var(--brand-teal);
}
.contact-main-form .form-input input::placeholder,
.contact-main-form .form-input textarea::placeholder {
  color: rgba(255,255,255,0.55);
}
.contact-main-form .form-input { margin-bottom: 22px; }
.contact-main-form .submit-button-wrap {
  margin-top: 18px;
}
@media (max-width: 767px) {
  .contact-form-wrap { padding: 40px 28px 50px; }
}

/* Section 3 — Map (grayscale, light blue-gray gutter per Figma) */
.contact-map-section {
  padding: 60px 0 100px;
  background: #ffffff;
}
.contact-map-wrap {
  background: transparent;
}

/* --- Dotted world map + office pins ----------------------- */
.world-map {
  position: relative;
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
}
.world-map-img {
  display: block;
  width: 100%;
  height: auto;
  user-select: none;
  pointer-events: none;
}
.map-pin-wrap {
  position: absolute;
  transform: translate(-50%, -100%);
  z-index: 2;
}
.map-pin {
  position: relative;
  display: block;
  padding: 0;
  border: 0;
  background: none;
  cursor: pointer;
  line-height: 0;
}
.map-pin img {
  width: 26px;
  height: auto;
  display: block;
  filter: drop-shadow(0 4px 6px rgba(7,49,73,0.35));
  transition: transform 0.18s ease;
}
.map-pin::after {            /* pulse ring at pin tip */
  content: "";
  position: absolute;
  left: 50%;
  bottom: -4px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: rgba(39,191,212,0.45);
  transform: translate(-50%, 0);
  animation: map-pin-pulse 2s ease-out infinite;
  z-index: -1;
}
@keyframes map-pin-pulse {
  0%   { transform: translate(-50%,0) scale(0.6); opacity: 0.8; }
  100% { transform: translate(-50%,0) scale(2.6); opacity: 0; }
}
.map-pin:hover img,
.map-pin-wrap.is-open .map-pin img { transform: translateY(-3px) scale(1.08); }

.map-popup {
  position: absolute;
  bottom: calc(100% + 14px);
  left: 50%;
  transform: translate(-50%, 6px);
  width: 290px;
  max-width: 78vw;
  background: var(--brand-orange);
  border: 0;
  box-shadow: 0 18px 40px rgba(254,103,16,0.32);
  padding: 16px 18px;
  text-align: left;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s;
  z-index: 5;
}
.map-popup::after {          /* pointer tail */
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 8px solid transparent;
  border-top-color: var(--brand-orange);
}
.map-pin-wrap.is-open .map-popup {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translate(-50%, 0);
}
.map-popup-title {
  font-family: var(--font-sans);
  font-size: 15px;
  font-weight: 500;
  color: #ffffff;
  margin: 0 0 6px;
}
.map-popup-title strong { font-weight: 700; }
.map-popup-addr {
  font-family: var(--font-sans);
  font-size: 12.5px;
  line-height: 1.55;
  color: rgba(255,255,255,0.88);
  margin: 0;
}

@media (max-width: 575px) {
  .map-pin img { width: 20px; }
  .map-popup { width: 220px; padding: 13px 14px; }
  /* QA: long pill buttons must wrap rather than overflow viewport */
  .btn-pill { white-space: normal; max-width: 100%; }
  .btn-pill .pill-label { white-space: normal; line-height: 1.25; }
}
/* ============================================================ */
/* HOME V2 — restructured Figma home page                       */
/* ============================================================ */

/* --- btn-pill system: clean, replaces tj-primary-btn for v2 -- */
.btn-pill {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 6px 22px 6px 6px;
  border-radius: 999px;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 600;
  line-height: 1;
  text-decoration: none !important;
  border: none;
  cursor: pointer;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
  white-space: nowrap;
}
.btn-pill .pill-icon {
  width: 38px; height: 38px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center; justify-content: center;
  font-size: 13px;
  flex-shrink: 0;
}
.btn-pill .pill-label { display: inline-block; }
.btn-pill:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(7,49,73,0.18); }

.btn-pill.btn-sky { background: var(--brand-sky); color: var(--brand-navy); }
.btn-pill.btn-sky .pill-icon { background: var(--brand-navy); color: #fff; }

.btn-pill.btn-outline {
  background: transparent;
  color: var(--brand-navy);
  border: 1.5px solid var(--brand-navy);
  padding: 4.5px 22px 4.5px 4.5px;
}
.btn-pill.btn-outline .pill-icon { background: var(--brand-navy); color: #fff; }

.btn-pill.btn-dark { background: var(--brand-charcoal); color: #fff; }
.btn-pill.btn-dark .pill-icon { background: var(--brand-teal); color: #fff; }

.btn-pill.btn-white { background: #fff; color: var(--brand-charcoal); box-shadow: 0 4px 14px rgba(7,49,73,0.10); }
.btn-pill.btn-white .pill-icon { background: var(--brand-teal); color: #fff; }

.btn-pill.btn-orange { background: var(--brand-orange); color: #fff; }
.btn-pill.btn-orange .pill-icon { background: #fff; color: var(--brand-orange); }

/* grey bg + blue (sky) arrow circle — hero v3 primary */
.btn-pill.btn-grey-blue {
  background: #e5ebf2;
  color: var(--brand-navy);
}
.btn-pill.btn-grey-blue .pill-icon {
  background: var(--brand-sky);
  color: var(--brand-navy);
}
.btn-pill.btn-grey-blue:hover {
  background: #d8dfe8;
}

/* header Workshop CTA — dark bg + orange arrow circle + white text */
/* Header — opaque white on home (matches Figma 735:12551 reference) */
.tj-header-area.header-absolute {
  background-color: #fff !important;
  border-bottom: 1px solid rgba(7,49,73,0.08);
}
.tj-header-area.header-absolute .header-bottom { padding-top: 0; padding-bottom: 0; }
.tj-header-area.header-absolute .header-wrapper { min-height: 76px; align-items: center; }
.tj-header-area.header-absolute .mainmenu > ul > li > a { color: var(--brand-charcoal); }
.tj-header-area.header-absolute .mainmenu > ul > li.active > a { color: var(--brand-orange); }

/* Book a Workshop CTA — dark bg + orange icon */
.header-workshop-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 6px 22px 6px 6px;
  border-radius: 999px;
  background: var(--brand-charcoal);
  color: #fff !important;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none !important;
  transition: background .2s ease, transform .2s ease, box-shadow .2s ease;
}
.header-workshop-cta:hover {
  background: #1f1d20;
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(7,49,73,0.20);
}
.header-workshop-cta .pill-icon {
  width: 36px; height: 36px;
  background: var(--brand-orange);
  color: #fff;
  border-radius: 50%;
  display: inline-flex;
  align-items: center; justify-content: center;
  font-size: 12px;
  flex-shrink: 0;
}
.header-sticky .header-workshop-cta { background: var(--brand-charcoal); color: #fff !important; }
.header-grid-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  margin-right: 10px;
  color: var(--brand-charcoal);
  font-size: 18px;
  cursor: pointer;
}

/* ============================================================
   Grid-icon slide-out info drawer (Figma 781:23573)
   Reuses .hamburger-area; styled navy with contact + socials + image.
   ============================================================ */
/* Pin to the right edge. The closed drawer is fully removed from layout
   (display:none) so it can't expand page width / cause horizontal scroll
   (a fixed off-screen drawer is NOT clipped by html overflow). */
.hamburger-area {
  width: 450px;
  max-width: 90vw;
  left: auto !important;
  right: 0 !important;
}
.hamburger-area:not(.opened) { display: none !important; }
.hamburger-area .hamburger_search { display: none; }   /* Figma drawer has no search */
.hamburger-area.opened { transform: none !important; animation: drawer-in .4s cubic-bezier(.4, 0, .2, 1); }
@keyframes drawer-in { from { transform: translateX(100%); } to { transform: translateX(0); } }
.hamburger-area .hamburger_bg { background: #073149 !important; }
.hamburger-area .hamburger_wrapper { padding: 45px 45px 60px; gap: 30px; }
.hamburger-area .hamburger-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 25px;
  letter-spacing: -0.025em;
  color: #f7f7f7;
  margin: 0 0 20px;
}
.hamburger-area .contact-info > .contact_item:first-child {
  border-top: 1px solid rgba(255,255,255,0.10);
  padding-top: 21px;
}
.hamburger-area .contact-info > .contact_item + .contact_item { padding-top: 20px; }
.hamburger-area .contact_item .subtitle {
  display: block;
  font-family: var(--font-sans);
  font-size: 15px;
  color: #969ca5;
  margin-bottom: 8px;
}
.hamburger-area .contact_item .text,
.hamburger-area .contact_item .text a {
  font-family: var(--font-sans);
  font-size: 18px;
  line-height: 1.3;
  color: #f7f7f7;
  text-decoration: none;
}
.hamburger-area .contact_item .text a:hover { color: var(--brand-teal); }
.hamburger-area .hamburger-socials ul {
  list-style: none;
  margin: 0;
  padding: 21px 0 0;
  border-top: 1px solid rgba(255,255,255,0.10);
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
}
.hamburger-area .hamburger-socials ul li a {
  width: 35px;
  height: 35px;
  border-radius: 50%;
  background: rgba(247,247,247,0.30);
  color: #333134;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  transition: background .2s ease, color .2s ease;
}
.hamburger-area .hamburger-socials ul li a:hover { background: var(--brand-teal); color: #fff; }
.hamburger-area .hamburger-figure { width: 100%; margin-top: 16px; }
.hamburger-area .hamburger-figure img { width: 100%; height: auto; display: block; border-radius: 0; }
.hamburger-area .hamburger_close .hamburger_close_btn { color: #f7f7f7; font-size: 30px; background: none; border: none; }
/* Desktop drawer (grid-icon) carries no nav menu — only mobile populates it */
@media (min-width: 992px) { .hamburger-area .hamburger_menu { display: none; } }

/* --- HERO V2 ------------------------------------------------ */
.home-hero-v2 {
  position: relative;
  padding-top: 160px;
  padding-bottom: 60px;
  background: #f3f7fb;
  overflow: hidden;
  text-align: center;
}
.home-hero-v2 .h6-slider-area,
.home-hero-v2 .hero-shapes-1,
.home-hero-v2 .hero-shapes-2 { display: none; }
.home-hero-v2 .hero-eyebrow-pill {
  display: inline-flex;
  margin: 0 auto 28px;
}
.home-hero-v2 .hero-eyebrow-pill a {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 6px 6px 6px 20px;
  background: #fff;
  border: 1px solid rgba(7,49,73,0.10);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  color: var(--brand-charcoal);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
}
.home-hero-v2 .hero-eyebrow-pill a i {
  width: 28px; height: 28px;
  background: var(--brand-orange);
  color: #fff;
  border-radius: 50%;
  display: inline-flex;
  align-items: center; justify-content: center;
  font-size: 11px;
}
.home-hero-v2 .hero-title {
  font-family: var(--font-display);
  font-weight: 600;
  color: var(--brand-navy);
  font-size: clamp(40px, 5vw, 72px);
  line-height: 1.05;
  letter-spacing: -0.01em;
  margin-bottom: 22px;
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
}
.home-hero-v2 .hero-desc p {
  font-size: 16px;
  line-height: 1.7;
  color: rgba(51,49,52,0.75);
  max-width: 760px;
  margin: 0 auto 32px;
}
.home-hero-v2 .hero-btn-area {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 56px;
}
.home-hero-v2 .hero-collage-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  max-width: 1200px;
  margin: 0 auto;
}
.home-hero-v2 .hero-collage-item {
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  aspect-ratio: 16/10;
  box-shadow: 0 14px 38px rgba(7,49,73,0.14);
  transform: perspective(1200px) rotateX(2deg);
  transition: transform .4s ease;
}
.home-hero-v2 .hero-collage-item:nth-child(1) { transform: perspective(1200px) rotateX(2deg) rotateY(5deg); }
.home-hero-v2 .hero-collage-item:nth-child(3) { transform: perspective(1200px) rotateX(2deg) rotateY(-5deg); }
.home-hero-v2 .hero-collage-item img { width: 100%; height: 100%; object-fit: cover; }
.home-hero-v2 .hero-collage-item:hover { transform: perspective(1200px) rotateX(0) rotateY(0) translateY(-6px); }

/* --- Section 2: teal credibility strip ---------------------- */
.home-credibility-strip {
  background: var(--brand-teal);
  position: relative;
  padding: 36px 0;
  overflow: hidden;
}
.home-credibility-strip::before {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 100% 50%, rgba(255,255,255,0.20), transparent 60%);
  pointer-events: none;
}
.home-credibility-strip p {
  font-family: var(--font-display);
  font-size: clamp(18px, 1.9vw, 26px);
  line-height: 1.45;
  color: #fff;
  text-align: center;
  max-width: 1100px;
  margin: 0 auto;
  font-weight: 400;
  position: relative;
}
.home-credibility-strip strong { font-weight: 700; color: #fff; }
.home-credibility-strip em { font-style: italic; font-weight: 500; }

/* --- Decades header: title + button on SAME row ----------- */
.home-team-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.home-team-title-row .sec-title { margin: 0; flex: 1 1 auto; }
.home-team-cta { flex: 0 0 auto; }

/* --- Team flask card (vertical w/ SVG mask shape) --------- */
.team-flask-card {
  position: relative;
  background: #fff;
  border: 1px solid rgba(7,49,73,0.08);
  border-radius: 14px;
  padding: 28px 24px 26px;
  display: flex;
  flex-direction: column;
  height: 100%;
  box-shadow: 0 8px 24px rgba(7,49,73,0.05);
  transition: transform .3s ease, box-shadow .3s ease;
}
.team-flask-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 38px rgba(7,49,73,0.12);
}
.team-flask-card .flask-shape {
  position: relative;
  width: 100%;
  aspect-ratio: 188/215;
  max-width: 320px;
  margin: 0 auto 24px;
  background-color: #e3eaf2;
  -webkit-mask-image: url('images/shapes/about-mark-2.svg');
          mask-image: url('images/shapes/about-mark-2.svg');
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-size: contain;
          mask-size: contain;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color .3s ease;
}
.team-flask-card:hover .flask-shape { background-color: var(--brand-mint); }
.team-flask-card .flask-photo {
  width: 72%;
  aspect-ratio: 1/1;
  border-radius: 50%;
  overflow: hidden;
  background: #cdd6df;
  position: relative;
  z-index: 1;
  margin-top: 4%;
}
.team-flask-card .flask-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}
.team-flask-card .flask-body { padding: 0 8px; }
.team-flask-card .title {
  font-family: var(--font-display);
  color: var(--brand-navy);
  font-size: 22px;
  font-weight: 600;
  margin-bottom: 14px;
}
.team-flask-card p {
  font-size: 13px;
  line-height: 1.65;
  color: rgba(51,49,52,0.82);
  margin-bottom: 16px;
}
.flask-social {
  padding-top: 12px;
  border-top: 1px solid rgba(7,49,73,0.08);
  font-size: 12px;
  color: rgba(51,49,52,0.7);
}
.flask-social ul {
  list-style: none;
  padding: 0;
  margin: 8px 0 0;
  display: flex;
  gap: 10px;
}
.flask-social a {
  width: 30px; height: 30px;
  background: #e8eef4;
  color: var(--brand-charcoal);
  border-radius: 50%;
  display: inline-flex;
  align-items: center; justify-content: center;
  font-size: 12px;
  transition: background .2s ease, color .2s ease;
}
.flask-social a:hover { background: var(--brand-teal); color: #fff; }
@media (max-width: 991px) {
  .home-team-title-row { flex-direction: column; align-items: flex-start; }
  .team-flask-card .flask-shape { max-width: 260px; }
}

/* --- Section 3: Team / Decades ------------------------------ */
.home-team-section { background: #f3f7fb; }
.home-team-section .sec-title {
  font-family: var(--font-display);
  color: var(--brand-navy);
  font-size: clamp(34px, 4vw, 52px);
  line-height: 1.1;
}
.home-team-section .sub-title { color: var(--brand-teal); }
.home-team-section .sec-desc {
  font-size: 15px;
  color: rgba(51,49,52,0.75);
  max-width: 720px;
  margin-top: 14px;
}
.home-team-head { margin-bottom: 48px; }
.home-team-grid > [class*=col-] { display: flex; }

.home-team-card {
  position: relative;
  background: #fff;
  border: 1px solid rgba(7,49,73,0.06);
  border-radius: 14px;
  padding: 0 28px 26px;
  flex: 1;
  display: flex;
  flex-direction: column;
  box-shadow: 0 8px 24px rgba(7,49,73,0.06);
  overflow: hidden;
  transition: transform .3s ease, box-shadow .3s ease;
}
.home-team-card:hover { transform: translateY(-6px); box-shadow: 0 18px 38px rgba(7,49,73,0.14); }
/* arch: tall pill-shaped backdrop behind photo */
.home-team-arch {
  position: relative;
  width: 180px;
  height: 260px;
  margin: 0 auto 22px;
  background: #e3eaf2;
  border-radius: 999px 999px 0 0;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding-bottom: 28px;
}
.home-team-arch::before {
  content: "";
  position: absolute;
  inset: -6px -6px auto -6px;
  height: calc(100% + 6px);
  border-radius: 999px 999px 0 0;
  border: 1.5px dashed rgba(39,191,212,0.35);
  pointer-events: none;
}
.home-team-photo {
  width: 140px; height: 140px;
  border-radius: 50%;
  overflow: hidden;
  background: #cdd6df;
  position: relative;
  z-index: 1;
  box-shadow: 0 6px 16px rgba(7,49,73,0.16);
}
.home-team-photo img { width: 100%; height: 100%; object-fit: cover; object-position: center top; }
.home-team-card .title {
  font-family: var(--font-display);
  color: var(--brand-navy);
  font-size: 22px;
  font-weight: 600;
  margin-bottom: 14px;
}
.home-team-card p {
  font-size: 13px;
  line-height: 1.65;
  color: rgba(51,49,52,0.82);
  margin-bottom: 16px;
}
.home-team-social {
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid rgba(7,49,73,0.08);
  font-size: 12px;
  color: rgba(51,49,52,0.7);
}
.home-team-social ul { list-style: none; padding: 0; margin: 8px 0 0; display: flex; gap: 10px; }
.home-team-social a {
  width: 30px; height: 30px;
  background: #e8eef4;
  color: var(--brand-charcoal);
  border-radius: 50%;
  display: inline-flex;
  align-items: center; justify-content: center;
  font-size: 12px;
  transition: background .2s ease, color .2s ease;
}
.home-team-social a:hover { background: var(--brand-teal); color: #fff; }

/* --- Section 4: VCA + Porter chart -------------------------- */
.home-vca-section { background: #fff; }
.home-vca-section .sec-title {
  font-family: var(--font-display);
  color: var(--brand-navy);
  font-size: clamp(34px, 4vw, 52px);
  line-height: 1.1;
}
.home-vca-section .sub-title { color: var(--brand-teal); }
.home-vca-section .sec-desc {
  font-size: 15px;
  color: rgba(51,49,52,0.78);
  max-width: 820px;
  margin-top: 14px;
}
.home-vca-section { position: relative; overflow: hidden; }
.home-vca-head { margin-bottom: 70px; position: relative; z-index: 2; max-width: 900px; }
.vca-dotted-bg {
  position: absolute;
  top: 60px;
  right: 60px;
  width: 160px;
  height: auto;
  opacity: 0.30;
  pointer-events: none;
  z-index: 1;
}
.vca-dotted-ring { width: 130px; height: auto; opacity: 0.45; }

/* --- VCA pin cards (Figma 352:8893) ----------------------- */
.vca-pin-track {
  position: relative;
  margin: 80px 0 50px;
}
.vca-pin-line {
  position: absolute;
  top: 36px;
  left: 4%;
  right: 4%;
  height: 1px;
  background: rgba(7,49,73,0.18);
  z-index: 0;
}
.vca-pin-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  position: relative;
  z-index: 1;
}
.vca-pin {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.vca-pin-top {
  position: relative;
  width: 100%;
  height: 72px;
  display: flex;
  justify-content: center;
  pointer-events: none;
}
.vca-pin-stem {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 56px;
  height: 56px;
  background: #e7eaf0;
  border-radius: 28px 28px 0 0;
}
.vca-pin-circle {
  position: relative;
  z-index: 1;
  margin-top: 0;
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: var(--brand-charcoal);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-sans);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 0.02em;
  border: 6px solid #e7eaf0;
}
.vca-pin-circle span { line-height: 1; }
.vca-pin-box {
  width: 100%;
  background: #e7eaf0;
  border-radius: 0;
  padding: 26px 26px 30px;
  min-height: 150px;
  margin-top: -1px;
}
.vca-pin-box p {
  font-size: 16px;
  line-height: 1.45;
  color: var(--brand-charcoal);
  margin: 0;
  font-weight: 500;
}

/* Active state — teal box, teal stem, white circle w/ teal ring */
.vca-pin.active .vca-pin-stem { background: var(--brand-teal); }
.vca-pin.active .vca-pin-box  { background: var(--brand-teal); }
.vca-pin.active .vca-pin-box p { color: #fff; }
.vca-pin.active .vca-pin-circle {
  background: #fff;
  color: var(--brand-charcoal);
  border-color: var(--brand-teal);
}

/* Hover demote: hovering inactive activates it, demotes active */
.vca-pin-grid:has(.vca-pin:not(.active):hover) .vca-pin.active .vca-pin-stem,
.vca-pin-grid:has(.vca-pin:not(.active):hover) .vca-pin.active .vca-pin-box {
  background: #e7eaf0;
}
.vca-pin-grid:has(.vca-pin:not(.active):hover) .vca-pin.active .vca-pin-box p { color: var(--brand-charcoal); }
.vca-pin-grid:has(.vca-pin:not(.active):hover) .vca-pin.active .vca-pin-circle {
  background: var(--brand-charcoal);
  color: #fff;
  border-color: #e7eaf0;
}
.vca-pin:not(.active):hover .vca-pin-stem,
.vca-pin:not(.active):hover .vca-pin-box {
  background: var(--brand-teal);
  cursor: default;
}
.vca-pin:not(.active):hover .vca-pin-box p { color: #fff; }
.vca-pin:not(.active):hover .vca-pin-circle {
  background: #fff;
  color: var(--brand-charcoal);
  border-color: var(--brand-teal);
}

@media (max-width: 991px) {
  .vca-pin-grid { grid-template-columns: 1fr; gap: 40px; max-width: 540px; margin: 0 auto; }
  .vca-pin-line { display: none; }
}

.vca-pin-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  max-width: 1080px;
  margin: 0 auto 60px;
  position: relative;
}
.vca-pin-row::before {
  content: "";
  position: absolute;
  top: 26px; left: 8%; right: 8%;
  height: 1px;
  background: rgba(7,49,73,0.12);
  z-index: 0;
}
.vca-pin-card {
  position: relative;
  background: #f1f4f7;
  border-radius: 8px;
  padding: 48px 22px 22px;
  min-height: 120px;
  display: flex;
  align-items: flex-start;
}
.vca-pin-card.active { background: var(--brand-teal); }
.vca-pin-card.active p { color: #fff; }
.vca-pin-bubble {
  position: absolute;
  top: -2px; left: 50%;
  transform: translate(-50%, -50%);
  width: 56px; height: 56px;
  background: #fff;
  border: 1px solid rgba(7,49,73,0.10);
  border-radius: 50%;
  display: flex;
  align-items: center; justify-content: center;
  z-index: 2;
  box-shadow: 0 4px 10px rgba(7,49,73,0.08);
}
.vca-pin-bubble span {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 600;
  color: var(--brand-charcoal);
}
.vca-pin-card.active .vca-pin-bubble { background: var(--brand-teal); border-color: var(--brand-teal); }
.vca-pin-card.active .vca-pin-bubble span { color: #fff; }
.vca-pin-card p { font-size: 14px; line-height: 1.55; color: var(--brand-charcoal); margin: 0; }
.home-vca-section:has(.vca-pin-card:not(.active):hover) .vca-pin-card.active { background: #f1f4f7; }
.home-vca-section:has(.vca-pin-card:not(.active):hover) .vca-pin-card.active p { color: var(--brand-charcoal); }
.home-vca-section:has(.vca-pin-card:not(.active):hover) .vca-pin-card.active .vca-pin-bubble { background: #fff; border-color: rgba(7,49,73,0.10); }
.home-vca-section:has(.vca-pin-card:not(.active):hover) .vca-pin-card.active .vca-pin-bubble span { color: var(--brand-charcoal); }
.vca-pin-card:not(.active):hover { background: var(--brand-teal); cursor: default; }
.vca-pin-card:not(.active):hover p { color: #fff; }
.vca-pin-card:not(.active):hover .vca-pin-bubble { background: var(--brand-teal); border-color: var(--brand-teal); }
.vca-pin-card:not(.active):hover .vca-pin-bubble span { color: #fff; }

/* Porter chart — single image */
.porter-chart-img {
  max-width: 1180px;
  margin: 60px auto 40px;
  padding: 0 20px;
}
.porter-chart-img img {
  display: block;
  width: 100%;
  height: auto;
}
/* legacy HTML porter — keep rules but unused now */
.porter-chart {
  position: relative;
  margin: 60px auto 40px;
  max-width: 1120px;
  padding: 0 40px 0 40px;
}
.porter-support-label {
  position: absolute;
  left: 0;
  top: 0;
  width: 32px;
  height: 195px;
  background: var(--brand-navy);
  color: #fff;
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 500;
  border-radius: 6px 0 0 6px;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  display: flex;
  align-items: center;
  justify-content: center;
  transform: rotate(180deg);
}
.porter-arrow-shape {
  position: relative;
  background: var(--brand-navy);
  padding: 18px 90px 18px 24px;
  border-radius: 0 0 0 0;
  min-height: 195px;
  margin-left: 32px;
}
.porter-arrow-shape::after {
  content: "";
  position: absolute;
  top: 0; right: -97px;
  width: 0; height: 0;
  border-top: 97px solid transparent;
  border-bottom: 97px solid transparent;
  border-left: 100px solid var(--brand-navy);
}
.porter-margin-label {
  position: absolute;
  right: 14px;
  top: 80px;
  color: #fff;
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 500;
  z-index: 3;
  writing-mode: vertical-rl;
  text-orientation: mixed;
}
.porter-support-rows {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.porter-support-row {
  border-radius: 999px;
  padding: 9px 22px;
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 500;
}
.porter-support-row.mint { background: var(--brand-mint); color: var(--brand-navy); }
.porter-support-row.teal { background: var(--brand-teal); color: #fff; }

.porter-primary-row {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  margin: 24px 90px 0 70px;
}
.porter-primary-item {
  text-align: center;
  position: relative;
}
.porter-pin-circle {
  width: 70px; height: 70px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center; justify-content: center;
  font-size: 26px;
  color: #fff;
  position: relative;
  margin-bottom: 14px;
}
.porter-pin-circle::after {
  content: "";
  position: absolute;
  bottom: -12px; left: 50%;
  transform: translateX(-50%);
  width: 22px; height: 18px;
  background: inherit;
  border-radius: 0 0 11px 11px;
}
.porter-pin-label {
  background: inherit;
  border-radius: 8px;
  padding: 9px 12px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 13px;
  color: #fff;
  display: inline-block;
  min-width: 130px;
}
.tone-red .porter-pin-circle, .tone-red .porter-pin-label { background: #ff5f48; }
.tone-orange .porter-pin-circle, .tone-orange .porter-pin-label { background: var(--brand-orange); }
.tone-yellow .porter-pin-circle, .tone-yellow .porter-pin-label { background: var(--brand-warm); color: var(--brand-charcoal); }
.tone-yellow .porter-pin-circle { color: #fff; }
.tone-pink .porter-pin-circle, .tone-pink .porter-pin-label { background: var(--brand-pink); color: var(--brand-navy); }
.tone-pink .porter-pin-circle { color: #fff; }
.tone-lavender .porter-pin-circle, .tone-lavender .porter-pin-label { background: var(--brand-lavender); color: var(--brand-navy); }
.tone-lavender .porter-pin-circle { color: #fff; }
.porter-primary-band {
  margin: 8px 90px 0 70px;
  background: var(--brand-navy);
  color: #fff;
  text-align: center;
  font-family: var(--font-display);
  padding: 9px 20px;
  border-radius: 0 0 8px 8px;
  font-size: 14px;
  font-weight: 500;
}
.home-vca-cta { margin-top: 40px; }

/* --- Section 5: TP Intelligence Stack (text + hub image + CTA) - */
.home-stack-section-v2 {
  position: relative;
  background: var(--brand-navy);
  padding: 90px 0 90px;
  color: #fff;
}
.home-stack-section-v2 .sec-title { color: #fff; font-family: var(--font-display); font-size: clamp(36px, 4vw, 56px); }
.home-stack-section-v2 .sub-title { color: var(--brand-teal); }
.home-stack-section-v2 .sec-desc { color: rgba(255,255,255,0.78); max-width: 720px; margin: 14px auto 0; }
.home-stack-heading { margin-bottom: 30px; }
.home-stack-hub {
  max-width: 1240px;
  margin: 0 auto 30px;
  padding: 0 10px;
}
.home-stack-hub img {
  display: block;
  width: 100%;
  height: auto;
}
.home-stack-cta { margin-top: 6px; }

/* --- Section 6: TP Architecture (stacked split cards) ------- */
.home-arch-v2 { background: #f3f7fb; }
.home-arch-v2 .sec-title {
  font-family: var(--font-display);
  color: var(--brand-navy);
  font-size: clamp(34px, 4vw, 52px);
  line-height: 1.1;
}
.home-arch-v2 .sub-title { color: var(--brand-teal); }
.home-arch-v2 .sec-desc { font-size: 15px; color: rgba(51,49,52,0.78); margin-top: 14px; }
.home-arch-heading { margin-bottom: 50px; max-width: 760px; margin-left: auto; margin-right: auto; }

.arch-split {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: stretch;
  background: var(--brand-navy);
  border-radius: 14px;
  overflow: hidden;
  margin-bottom: 28px;
  text-decoration: none !important;
  min-height: 320px;
  box-shadow: 0 12px 32px rgba(7,49,73,0.14);
  transition: transform .35s ease, box-shadow .35s ease;
}
.arch-split:hover { transform: translateY(-4px); box-shadow: 0 22px 48px rgba(7,49,73,0.22); }
.arch-image-right { grid-template-columns: 1fr 1fr; }
.arch-photo {
  overflow: hidden;
  min-height: 280px;
}
.arch-photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .5s ease;
}
.arch-split:hover .arch-photo img { transform: scale(1.05); }
.arch-body {
  position: relative;
  padding: 40px 44px;
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.arch-step {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 500;
  color: rgba(255,255,255,0.5);
  margin-bottom: 8px;
}
.arch-watermark {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 600;
  color: rgba(255,255,255,0.22);
  letter-spacing: 0.01em;
  line-height: 1;
  margin-bottom: 8px;
}
.arch-image-right .arch-watermark { color: rgba(255,255,255,0.22); }
.arch-title {
  font-family: var(--font-display);
  color: #fff;
  font-size: clamp(22px, 2.4vw, 30px);
  font-weight: 600;
  margin-bottom: 14px;
  position: relative;
}
.arch-body p {
  font-size: 14px;
  line-height: 1.65;
  color: rgba(255,255,255,0.78);
  margin: 0;
  max-width: 460px;
  position: relative;
}
.home-arch-cta { margin-top: 40px; }

/* --- Section 7: Roadmap to Global Tax Command -------------- */
.home-roadmap-v2 {
  position: relative;
  padding: 110px 0;
  color: #fff;
  overflow: hidden;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(39,191,212,0.20) 0%, transparent 55%),
    radial-gradient(ellipse at 10% 100%, rgba(140,213,255,0.10) 0%, transparent 50%),
    radial-gradient(ellipse at 90% 100%, rgba(254,103,16,0.10) 0%, transparent 50%),
    var(--brand-navy);
}
.home-roadmap-bg {
  position: absolute;
  left: 50%; bottom: 0;
  transform: translateX(-50%);
  width: 100%;
  max-width: 720px;
  height: 60%;
  background-image:
    radial-gradient(ellipse at 50% 100%, rgba(255,255,255,0.10) 0%, transparent 60%),
    linear-gradient(135deg, transparent 47%, rgba(255,255,255,0.06) 48%, rgba(255,255,255,0.06) 52%, transparent 53%);
  opacity: 0.7;
  pointer-events: none;
}
.home-roadmap-bg::before, .home-roadmap-bg::after {
  /* abstract mountain triangles */
  content: "";
  position: absolute;
  bottom: 0;
  border-style: solid;
  border-color: transparent transparent rgba(7,49,73,0.65) transparent;
}
.home-roadmap-bg::before { left: 50%; transform: translateX(-50%); border-width: 0 220px 280px 220px; }
.home-roadmap-bg::after  { left: calc(50% - 90px); border-width: 0 140px 200px 140px; border-bottom-color: rgba(39,191,212,0.20); }
.home-roadmap-overlay { display: none; }
.home-roadmap-v2 .container { position: relative; z-index: 2; }
.home-roadmap-v2 .sec-title { color: #fff; font-family: var(--font-display); font-size: clamp(32px, 3.6vw, 48px); }
.home-roadmap-v2 .sub-title { color: var(--brand-teal); }
.home-roadmap-v2 .sec-desc { color: rgba(255,255,255,0.82); max-width: 720px; margin: 14px auto 0; }
.home-roadmap-heading { margin-bottom: 60px; }
.home-roadmap-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}
.home-roadmap-title-row .sec-title { margin: 0; flex: 1 1 auto; color: #fff; }
.home-roadmap-cta { flex: 0 0 auto; position: relative; overflow: hidden; isolation: isolate; transition: color .3s ease; }
.home-roadmap-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--brand-teal);
  border-radius: inherit;
  transform: translateX(-101%);
  transition: transform .45s cubic-bezier(.22,.61,.36,1);
  z-index: -1;
}
.home-roadmap-cta:hover::before { transform: translateX(0); }
.home-roadmap-cta:hover { color: #fff; }
.home-roadmap-cta:hover .pill-icon { background: #fff; color: var(--brand-teal); }
@media (max-width: 991px) {
  .home-roadmap-title-row { flex-direction: column; align-items: flex-start; }
}
.home-roadmap-grid > [class*=col-] { display: flex; }
.roadmap-phase {
  position: relative;
  background: rgba(7,49,73,0.55);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 0;
  padding: 28px 28px 28px;
  text-align: left;
  backdrop-filter: blur(8px);
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  transition: transform .3s ease, background .3s ease;
}
.roadmap-phase:hover { transform: translateY(-6px); background: rgba(7,49,73,0.75); }
.roadmap-icon {
  width: 64px; height: 64px;
  border-radius: 50%;
  background: var(--brand-teal);
  color: #fff;
  display: inline-flex;
  align-items: center; justify-content: center;
  font-size: 24px;
  margin-bottom: 20px;
}
.roadmap-icon img {
  width: 32px;
  height: 32px;
  filter: brightness(0) invert(1);
}
.roadmap-step {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 500;
  color: rgba(255,255,255,0.55);
  margin-bottom: 4px;
}
.roadmap-phase .title {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 600;
  color: #fff;
  margin-bottom: 12px;
}
.roadmap-phase p {
  font-size: 14px;
  line-height: 1.6;
  color: rgba(255,255,255,0.82);
  margin: 0;
}

/* --- Section 8: Building Your Strategic Foundation --------- */
.home-workshop-v2 { background: #f3f7fb; }
.home-workshop-v2 .sec-title {
  font-family: var(--font-display);
  color: var(--brand-navy);
  font-size: clamp(34px, 4vw, 52px);
}
.home-workshop-v2 .sub-title { color: var(--brand-teal); }
.home-workshop-heading { margin-bottom: 50px; max-width: 860px; margin-left: auto; margin-right: auto; }
.home-workshop-heading .sec-desc { font-size: 15px; color: rgba(51,49,52,0.78); margin-top: 14px; }
.home-workshop-img {
  border-radius: 0;
  overflow: hidden;
  box-shadow: 0 16px 36px rgba(7,49,73,0.14);
}
.home-workshop-img img {
  display: block;
  width: 100%;
  height: auto;
}
.home-workshop-agenda { padding-left: 12px; }
.home-workshop-agenda .agenda-title {
  font-family: var(--font-display);
  font-size: clamp(24px, 2.4vw, 32px);
  font-weight: 600;
  color: var(--brand-navy);
  margin-bottom: 12px;
}
.home-workshop-agenda .agenda-intro {
  font-size: 14px;
  line-height: 1.65;
  color: rgba(51,49,52,0.8);
  margin-bottom: 20px;
  max-width: 460px;
}
.agenda-card {
  background: #fff;
  border-radius: 0;
  padding: 6px 26px;
  border: 1px solid rgba(7,49,73,0.08);
  box-shadow: 0 8px 24px rgba(7,49,73,0.06);
}
.home-workshop-list { list-style: none; padding: 0; margin: 0; }
.home-workshop-list li {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 0;
  border-top: 1px solid rgba(7,49,73,0.08);
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 500;
  color: var(--brand-navy);
}
.home-workshop-list li:first-child { border-top: none; }
.home-workshop-list li .check {
  width: 24px; height: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background: transparent;
}
.home-workshop-list li .check img {
  display: block;
  width: 100%; height: auto;
}

/* --- Section 9: Exclusive Workshop Deliverables ------------ */
.home-deliverables-v2 { background: #fff; }
.home-deliverables-v2 .sec-title {
  font-family: var(--font-display);
  color: var(--brand-navy);
  font-size: clamp(32px, 3.8vw, 48px);
}
.home-deliv-heading { margin-bottom: 50px; max-width: 860px; margin-left: auto; margin-right: auto; }
.home-deliv-heading .sec-desc { font-size: 15px; color: rgba(51,49,52,0.78); margin-top: 14px; }
.home-deliv-card {
  position: relative;
  background-size: cover;
  background-position: center;
  background-color: var(--brand-navy);
  background-repeat: no-repeat;
  color: #fff;
  border-radius: 0;
  padding: 60px;
  /* Square aspect — matches Figma 620×620 */
  aspect-ratio: 1 / 1;
  width: 100%;
  overflow: hidden;
  box-shadow: 0 12px 32px rgba(7,49,73,0.16);
  transition: transform .3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}
.home-deliv-card:hover { transform: translateY(-6px); }
.home-deliv-box {
  position: relative;
  z-index: 1;
  background: rgba(255,255,255,0.10);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
  padding: 30px;
  width: 100%;
  max-width: 460px;
  border-radius: 0;
}
.home-deliv-card .title {
  font-family: var(--font-display);
  color: #fff;
  font-size: 26px;
  font-weight: 600;
  margin-bottom: 12px;
}
.home-deliv-card .intro {
  font-size: 14px;
  line-height: 1.55;
  color: rgba(255,255,255,0.88);
  margin-bottom: 14px;
}
.home-deliv-card strong { color: var(--brand-teal); }
.home-deliv-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.home-deliv-list li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 13px;
  line-height: 1.55;
  color: rgba(255,255,255,0.88);
}
.home-deliv-list .check {
  flex-shrink: 0;
  width: 22px;
  margin-top: 5px;
}
.home-deliv-list .check img { display: block; width: 100%; height: auto; }

/* --- Section 10: Who Should Attend -------------------------- */
.home-attend-v2 {
  padding: 30px 0 70px;
  background: #f3f7fb;
}
.home-attend-panel {
  background: var(--brand-teal);
  border-radius: 18px;
  padding: 56px 40px;
  text-align: center;
  position: relative;
  overflow: hidden;
  box-shadow: 0 18px 50px rgba(39,191,212,0.30);
}
.home-attend-panel::before, .home-attend-panel::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  background: rgba(255,255,255,0.12);
  pointer-events: none;
}
.home-attend-panel::before { width: 260px; height: 260px; top: -120px; left: -80px; }
.home-attend-panel::after  { width: 200px; height: 200px; bottom: -100px; right: -60px; }
.home-attend-panel .title {
  font-family: var(--font-display);
  font-size: clamp(28px, 3.4vw, 42px);
  color: #fff;
  font-weight: 600;
  margin-bottom: 14px;
  position: relative;
}
.home-attend-panel p {
  font-size: 16px;
  line-height: 1.6;
  color: rgba(255,255,255,0.92);
  max-width: 720px;
  margin: 0 auto 26px;
  position: relative;
}
.home-attend-panel .btn-pill { position: relative; }

/* --- Footer/global nav adjustments ------------------------- */
.footer-middle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.h6-footer-menu ul { justify-content: center !important; column-gap: 36px !important; margin: 0; }
.footer-workshop-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 6px 22px 6px 6px;
  border-radius: 999px;
  background: #fff;
  color: var(--brand-charcoal) !important;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 700;
  text-decoration: none !important;
  transition: transform .2s ease, box-shadow .2s ease;
}
.footer-workshop-cta:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(255,255,255,0.18); }
.footer-workshop-cta .pill-icon {
  width: 36px; height: 36px;
  background: var(--brand-orange);
  color: #fff;
  border-radius: 50%;
  display: inline-flex;
  align-items: center; justify-content: center;
  font-size: 12px;
  flex-shrink: 0;
}

/* Remove top space above header content */
.tj-header-area.header-absolute .header-bottom { padding-top: 0 !important; padding-bottom: 0 !important; }
.tj-header-area.header-absolute .header-wrapper { min-height: 70px; padding-top: 0; padding-bottom: 0; }

/* --- Responsive --------------------------------------------- */
@media (max-width: 991px) {
  .home-hero-v2 { padding-top: 130px; padding-bottom: 50px; }
  .home-hero-v2 .hero-collage-strip { gap: 12px; }
  .home-team-head { margin-bottom: 32px; }
  .vca-pin-row { grid-template-columns: 1fr; gap: 40px; max-width: 540px; margin-bottom: 50px; }
  .vca-pin-row::before { display: none; }
  .porter-chart { overflow-x: auto; padding: 0 10px; }
  .porter-arrow-shape::after { display: none; }
  .porter-arrow-shape { padding-right: 24px; }
  .porter-margin-label { display: none; }
  .porter-primary-row, .porter-primary-band { margin: 24px 0 0 0; grid-template-columns: repeat(2, 1fr); }
  .porter-primary-band { margin-top: 14px; }
  .arch-split { grid-template-columns: 1fr; }
  .arch-image-right { grid-template-columns: 1fr; }
  .arch-image-right .arch-photo { order: 2; }
  .arch-photo { min-height: 220px; }
  .arch-body { padding: 28px; }
  .home-roadmap-grid { gap: 16px 0; }
}
@media (max-width: 767px) {
  .home-hero-v2 .hero-collage-strip { grid-template-columns: 1fr; }
  .home-credibility-strip p { font-size: 16px; }
  .porter-primary-row { grid-template-columns: 1fr; }
  .porter-support-label { display: none; }
  .home-attend-panel { padding: 40px 22px; }
}

.contact-map-wrap iframe {
  display: block;
  width: 100%;
  border: 0;
}

/* ============================================================ */
/* HOME V3 — section additions/overrides                        */
/* ============================================================ */

/* --- Hero V3 (light, centered) ---------------------------- */
.home-v3-hero {
  position: relative;
  background: #fff;
  padding: 180px 0 80px;
  text-align: center;
}
.home-v3-hero .hero-title {
  font-family: var(--font-display);
  color: var(--brand-navy);
  font-weight: 600;
  font-size: clamp(40px, 5vw, 76px);
  line-height: 1.05;
  letter-spacing: -0.01em;
  margin-bottom: 22px;
  max-width: 1100px;
  margin-left: auto; margin-right: auto;
}
.home-v3-hero .hero-desc p {
  font-size: 16px;
  line-height: 1.7;
  color: rgba(51,49,52,0.78);
  max-width: 760px;
  margin: 0 auto 28px;
}
.home-v3-hero .hero-btn-area {
  display: flex; justify-content: center;
}

/* --- Globe band (video bg sub-hero) ----------------------- */
.home-v3-globe-band {
  position: relative;
  background: var(--brand-navy);
  padding: 80px 0 120px;
  overflow: hidden;
  text-align: center;
  color: #fff;
}
.home-v3-globe-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}
.home-v3-globe-bg {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(7,49,73,0.55) 0%, rgba(7,49,73,0.45) 50%, rgba(7,49,73,0.75) 100%),
    radial-gradient(ellipse at 50% 40%, rgba(39,191,212,0.30) 0%, transparent 55%),
    radial-gradient(circle at 50% 60%, rgba(140,213,255,0.16) 0%, transparent 50%),
    radial-gradient(circle at 50% 50%, rgba(0,0,0,0.35) 0%, transparent 70%);
  pointer-events: none;
  z-index: 1;
}
.home-v3-globe-band::before {
  /* dotted globe svg outline */
  content: "";
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 700px; height: 700px;
  border-radius: 50%;
  background:
    radial-gradient(circle, transparent 64%, rgba(39,191,212,0.22) 65%, transparent 66%),
    radial-gradient(circle, transparent 50%, rgba(140,213,255,0.10) 51%, transparent 52%),
    repeating-radial-gradient(circle at 50% 50%, rgba(255,255,255,0.05) 0 2px, transparent 2px 14px);
  opacity: 0.7;
  pointer-events: none;
}
.home-v3-globe-band .container { position: relative; z-index: 2; }
.globe-band-title {
  font-family: var(--font-display);
  color: #fff;
  font-weight: 600;
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: 1.15;
  margin: 0 auto 26px;
  max-width: 760px;
}
.globe-band-cta { margin-bottom: 24px; }
.globe-band-sub {
  font-size: 14px;
  color: rgba(255,255,255,0.78);
  max-width: 540px;
  margin: 0 auto;
}

/* --- 3-item teal stat strip (Figma copy) ------------------ */
.home-v3-stats {
  position: relative;
  background: var(--brand-teal);
  padding: 40px 0;
  overflow: hidden;
}
.home-v3-stats::before {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 100% 50%, rgba(255,255,255,0.18), transparent 60%);
  pointer-events: none;
}
.home-v3-stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  align-items: center;
  position: relative;
  z-index: 1;
}
.home-v3-stat-card {
  position: relative;
  padding: 8px 30px;
  text-align: center;
  color: #fff;
}
.home-v3-stat-card + .home-v3-stat-card { border-left: 1px solid rgba(255,255,255,0.30); }
.home-v3-stat-card + .home-v3-stat-card::before {
  content: "";
  position: absolute;
  top: 50%; left: -8px;
  transform: translateY(-50%);
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--brand-teal);
  border: 3px solid #fff;
  z-index: 2;
}
.home-v3-stat-card .stat-label {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(22px, 2.4vw, 32px);
  line-height: 1.15;
  color: #fff;
  letter-spacing: -0.01em;
  text-align: center;
}
@media (max-width: 991px) {
  .home-v3-stats-grid { grid-template-columns: 1fr; gap: 16px; }
  .home-v3-stat-card + .home-v3-stat-card { border-left: none; border-top: 1px solid rgba(255,255,255,0.30); padding-top: 16px; }
  .home-v3-stat-card + .home-v3-stat-card::before { top: -8px; left: 50%; transform: translateX(-50%); }
}

/* --- Override existing v2 hero rules (don't fight) -------- */
.home-v3-hero .h6-slider-area,
.home-v3-hero .hero-shapes-1,
.home-v3-hero .hero-shapes-2 { display: none; }

/* --- VCA pin bubble variant: white outer + colored inner -- */
.vca-pin-bubble.dark { background: #fff; border: 1px solid rgba(7,49,73,0.10); }
.vca-pin-bubble.dark span { color: #fff; }
.vca-pin-bubble.dark::before {
  content: "";
  position: absolute;
  inset: 8px;
  background: var(--brand-charcoal);
  border-radius: 50%;
  z-index: 0;
}
.vca-pin-bubble.dark span { position: relative; z-index: 1; }
.vca-pin-bubble {
  position: relative;
  overflow: visible;
}

/* --- Section 6: Strategic Shield swiper coverflow --------- */
.home-shield-section {
  background: #eef2f6;
  position: relative;
  overflow: hidden;
}
.home-shield-section .sub-title { color: var(--brand-teal); }
.home-shield-section .sec-title {
  color: var(--brand-navy);
  font-family: var(--font-display);
  font-size: clamp(42px, 5vw, 72px);
  font-weight: 600;
}
.home-shield-section .sec-desc { color: rgba(51,49,52,0.78); max-width: 720px; margin: 14px auto 0; }
.home-shield-heading { margin-bottom: 50px; text-align: center; }

.shield-slider-inner {
  position: relative;
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 40px;
}
.home-shield-section .h7-case-study-slider {
  overflow: visible;
  padding: 30px 0 60px;
}
.home-shield-section .h7-case-study-slider .swiper-slide {
  width: 540px;
  max-width: 72vw;
  transition: opacity .4s ease;
}
.home-shield-section .h7-case-study-slider .swiper-slide:not(.swiper-slide-active) { opacity: 0.55; }
.home-shield-section .h5-case-study-item-inner {
  position: relative;
  width: 100%;
  aspect-ratio: 16/10;
  border-radius: 12px;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  box-shadow: 0 20px 40px rgba(7,49,73,0.18);
}
.home-shield-section .h5-case-study-item-inner::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(7,49,73,0.0) 0%, rgba(7,49,73,0.20) 40%, rgba(7,49,73,0.85) 100%);
}
.home-shield-section .case-study-content {
  position: absolute !important;
  inset: auto 0 0 0 !important;
  z-index: 2;
  padding: 24px 28px 26px !important;
  background: transparent !important;
  max-width: 100% !important;
  width: 100% !important;
  transform: none !important;
}
.home-shield-section .h5-case-study-item:hover .case-study-content { transform: none !important; }
.home-shield-section .case-study-text {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
}
.home-shield-section .case-study-text .title h3 {
  font-family: var(--font-display);
  color: #fff;
  font-size: clamp(26px, 2.4vw, 34px);
  font-weight: 600;
  margin: 0 0 8px;
}
.home-shield-section .case-study-text .category {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  gap: 8px;
}
.home-shield-section .case-study-text .category li {
  font-size: 13px;
  font-weight: 500;
  color: rgba(255,255,255,0.85);
  background: rgba(255,255,255,0.14);
  border-radius: 999px;
  padding: 4px 12px;
  backdrop-filter: blur(4px);
}
.home-shield-section .case-study-text .icon-btn {
  width: 46px; height: 46px;
  border-radius: 50%;
  background: var(--brand-teal);
  color: #fff;
  display: inline-flex;
  align-items: center; justify-content: center;
  text-decoration: none;
  flex-shrink: 0;
  transition: transform .2s ease;
}
.home-shield-section .case-study-text .icon-btn:hover { transform: translateY(-2px); }

/* Pagination dots */
.home-shield-section .shield-pagination {
  position: relative;
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 30px;
}
.home-shield-section .shield-pagination .swiper-pagination-bullet {
  width: 10px; height: 10px;
  background: rgba(7,49,73,0.25);
  border-radius: 50%;
  opacity: 1;
  cursor: pointer;
  transition: background .2s ease, transform .2s ease;
}
.home-shield-section .shield-pagination .swiper-pagination-bullet-active {
  background: var(--brand-teal);
  transform: scale(1.2);
}

@media (max-width: 767px) {
  .home-shield-section .h7-case-study-slider .swiper-slide { width: 88vw; }
}

/* --- Roadmap v3 (mountain bg image) ----------------------- */
.home-roadmap-v3 {
  position: relative;
  /* big top padding so the heading starts BELOW the flag in the bg art */
  padding: 300px 0 110px;
  color: #fff;
  overflow: hidden;
  background: var(--brand-navy);
}
.home-roadmap-v3 .home-roadmap-bg {
  position: absolute !important;
  inset: 0 !important;
  top: 0 !important; right: 0 !important; bottom: 0 !important; left: 0 !important;
  width: 100% !important;
  max-width: none !important;
  height: 100% !important;
  transform: none !important;
  opacity: 1 !important;
  background-image: url('images/brand/v2/home-roadmap-bg.png') !important;
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat;
  pointer-events: none;
}
.home-roadmap-v3 .home-roadmap-bg::before,
.home-roadmap-v3 .home-roadmap-bg::after { display: none !important; }
.home-roadmap-v3::before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(7,49,73,0.25) 0%, rgba(7,49,73,0.20) 40%, rgba(7,49,73,0.70) 100%);
  z-index: 1;
}
.home-roadmap-v3 .container { position: relative; z-index: 2; }
.home-roadmap-v3 .sec-title { color: #fff; font-family: var(--font-display); font-size: clamp(34px, 4vw, 52px); }
.home-roadmap-v3 .sub-title { color: var(--brand-teal); }
.home-roadmap-v3 .sec-desc { color: rgba(255,255,255,0.82); max-width: 680px; margin-left: auto; margin-right: auto; }
.home-roadmap-head { margin-bottom: 50px; }
/* Review 2026-06-10: heading centered under the flag; CTA moved below the 3 cards */
.home-roadmap-v3 .home-roadmap-head { text-align: center; }
.home-roadmap-cta-row { display: flex; justify-content: center; margin-top: 44px; }
@media (max-width: 767px) {
  .home-roadmap-v3 { padding-top: 190px; }
}

/* --- Attend v3 (uses existing .home-attend-v2 styles) ----- */
.home-attend-v3 {
  padding: 30px 0 60px;
  background: #f3f7fb;
}
.home-attend-v3 .home-attend-panel {
  background: var(--brand-teal);
  border-radius: 0;
  padding: 56px 40px;
  text-align: center;
  position: relative;
  overflow: hidden;
  box-shadow: 0 18px 50px rgba(39,191,212,0.30);
  color: #fff;
}
.home-attend-v3 .home-attend-panel::before {
  content: ""; position: absolute; top: 0; right: 0; bottom: 0;
  width: 280px;
  background: url('images/brand/v2/attend-bg-right.png') right center / cover no-repeat;
  pointer-events: none;
  opacity: 0.9;
}
.home-attend-v3 .home-attend-panel::after  {
  content: ""; position: absolute; top: 0; left: 0; bottom: 0;
  width: 280px;
  background: url('images/brand/v2/attend-bg-right.png') left center / cover no-repeat;
  transform: scaleX(-1);
  pointer-events: none;
  opacity: 0.6;
}
.home-attend-v3 .home-attend-panel .title {
  font-family: var(--font-display);
  font-size: clamp(26px, 3vw, 32px);
  color: #fff;
  font-weight: 600;
  letter-spacing: -0.013em;
  margin-bottom: 16px;
  position: relative;
}
.home-attend-v3 .home-attend-panel p {
  font-size: 18px; line-height: 1.34;
  color: #fff;
  max-width: 788px; margin: 0 auto 28px;
  position: relative;
}
.home-attend-v3 .btn-pill { position: relative; }

/* --- Blogs section ---------------------------------------- */
.home-blogs-section { background: #fff; }
.home-blogs-section .sec-title {
  font-family: var(--font-display);
  color: var(--brand-navy);
  font-size: clamp(34px, 4vw, 52px);
}
.home-blogs-section .sub-title { color: var(--brand-teal); }
.home-blogs-section .sec-desc { font-size: 15px; color: rgba(51,49,52,0.75); max-width: 640px; margin-top: 12px; }
.home-blogs-head { margin-bottom: 40px; }
.home-blogs-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}
.home-blogs-title-row .sec-title { margin: 0; flex: 1 1 auto; }
.home-blogs-cta { flex: 0 0 auto; }
@media (max-width: 991px) {
  .home-blogs-title-row { flex-direction: column; align-items: flex-start; }
}

/* Card 1 — full bg image w/ overlay (left) */
.blog-card-full {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  border-radius: 0;
  overflow: hidden;
  min-height: 460px;
  text-decoration: none;
  color: #fff;
  box-shadow: 0 12px 28px rgba(7,49,73,0.10);
  transition: transform .3s ease, box-shadow .3s ease;
}
.blog-card-full:hover { transform: translateY(-6px); box-shadow: 0 22px 48px rgba(7,49,73,0.18); }
.blog-card-full .blog-card-img {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
}
.blog-card-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(5,18,41,0) 0%, rgba(5,18,41,0.55) 55%, #051229 100%);
}
/* Date badge — glass blur over photo (Figma rgba(247,247,247,0.1) + blur) */
.blog-card-date {
  position: absolute;
  top: 15px; left: 15px;
  background: var(--brand-navy);
  border-radius: 0;
  padding: 14px 20px;
  text-align: center;
  font-family: var(--font-display);
  line-height: 1;
  z-index: 2;
}
.blog-card-date strong { font-size: 30px; font-weight: 600; display: block; color: #f7f7f7; }
.blog-card-date span { font-size: 13px; color: #a9b0b8; text-transform: uppercase; letter-spacing: 0.24em; margin-top: 8px; display: block; }
.blog-card-full .blog-card-body {
  position: relative;
  z-index: 2;
  padding: 40px 25px;
  margin-top: auto;
}
.blog-card-full .blog-card-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
  font-size: 14px;
  font-weight: 400;
}
.blog-card-full .blog-card-meta .meta-cat {
  background: transparent;
  border: 1px solid var(--brand-navy);
  border-radius: 40px;
  padding: 6px 11px;
  color: #a9b0b8;
}
.blog-card-full .blog-card-meta .meta-comments { color: #a9b0b8; }
.blog-card-full .blog-card-title {
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.018em;
  color: #f7f7f7;
  margin: 0;
}

/* Cards 2/3 — split: image top (no border), white bordered body below */
.blog-card-split {
  position: relative;
  display: flex;
  flex-direction: column;
  border-radius: 0;
  overflow: hidden;
  min-height: 460px;
  text-decoration: none;
  background: #fff;
  transition: transform .3s ease, box-shadow .3s ease;
}
.blog-card-split:hover { transform: translateY(-6px); box-shadow: 0 22px 48px rgba(7,49,73,0.14); }
.blog-card-img-top {
  position: relative;
  height: 290px;
  background-size: cover;
  background-position: center;
}
.blog-card-img-top .blog-card-date {
  position: absolute;
  top: 15px; left: 15px;
}
.blog-card-body-white {
  padding: 31px 26px 35px;
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 17px;
  border: 1px solid #ced7e0;
}
.blog-card-body-white .blog-card-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 0;
  font-size: 14px;
  font-weight: 400;
}
.blog-card-body-white .blog-card-meta .meta-cat {
  background: transparent;
  border: 1px solid #ced7e0;
  color: #676e7a;
  border-radius: 40px;
  padding: 6px 11px;
}
.blog-card-body-white .blog-card-meta .meta-comments { color: #676e7a; }
.blog-card-body-white .blog-card-title {
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.018em;
  color: #051229;
  margin: 0;
}
/* Learn more + teal circle arrow (Figma) */
.blog-read-more {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 15px;
  font-weight: 700;
  color: #051229;
  margin-top: auto;
}
.blog-read-arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--brand-teal);
  color: #f7f7f7;
  font-size: 11px;
  transition: transform .25s ease;
}
.blog-card-split:hover .blog-read-arrow { transform: translateX(3px); }

.blog-card-list {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.blog-list-item {
  display: block;
  padding: 18px 0;
  border-bottom: 1px solid rgba(7,49,73,0.10);
  text-decoration: none;
  transition: padding-left .2s ease;
}
.blog-list-item:first-child { padding-top: 0; }
.blog-list-item:last-child { border-bottom: none; }
.blog-list-item:hover { padding-left: 6px; }
.blog-list-item .meta-cat {
  font-size: 12px;
  font-weight: 500;
  color: var(--brand-teal);
  margin-bottom: 6px;
}
.blog-list-item .meta-dot { color: rgba(51,49,52,0.4); margin: 0 4px; }
.blog-list-item .meta-comments { color: rgba(51,49,52,0.6); font-size: 12px; }
.blog-list-title {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 600;
  line-height: 1.3;
  color: var(--brand-navy);
  margin: 0;
}

/* --- Responsive --------------------------------------------- */
@media (max-width: 991px) {
  .home-v3-hero { padding-top: 130px; padding-bottom: 50px; }
  .home-v3-stats-grid { grid-template-columns: 1fr; gap: 16px; }
  .home-v3-stat-card + .home-v3-stat-card { border-left: none; border-top: 1px solid rgba(255,255,255,0.30); padding-top: 16px; }
  .shield-carousel { grid-template-columns: 1fr; gap: 16px; max-width: 540px; }
  .shield-card-side { min-height: 200px; }
  .blog-card-list { margin-top: 20px; }
}
@media (max-width: 767px) {
  .home-v3-globe-band { padding: 60px 0 90px; }
  .home-v3-globe-band::before { width: 380px; height: 380px; }
}

/* --- Let's connect layout (footer top) -------------------- */
.connect-left {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding-right: 40px;
}
.connect-title {
  font-family: var(--font-display);
  font-size: clamp(48px, 6vw, 88px);
  font-weight: 600;
  color: #fff;
  line-height: 1;
  letter-spacing: -0.02em;
  margin: 0 0 34px;
}
/* Footer — Let's connect: global-offices map with always-on location badges */
.connect-map { position: relative; width: 100%; max-width: 580px; }
.connect-map-img { display: block; width: 100%; height: auto; }
/* Each pin = a dot at the exact spot + a pulsing ring, with the name label
   floating above (ref: animated-map-pins). Always visible, no click. */
.connect-pin {
  position: absolute;
  width: 11px;
  height: 11px;
  transform: translate(-50%, -50%);   /* dot centred on the coordinate */
  z-index: 2;
}
.connect-pin::before {               /* the dot marker */
  content: "";
  position: absolute;
  inset: 0;
  background: var(--brand-orange);
  border-radius: 50%;
  box-shadow: 0 0 0 3px rgba(254,103,16,0.30);
  z-index: 2;
}
.connect-pin::after {                /* pulsing ring */
  content: "";
  position: absolute;
  left: 50%; top: 50%;
  width: 34px; height: 34px;
  border: 2px solid var(--brand-orange);
  border-radius: 50%;
  opacity: 0;
  transform: translate(-50%, -50%) scale(0.2);
  animation: connect-pulse 2s ease-in-out infinite;
  z-index: 1;
}
.connect-pin-label {                 /* the orange name tag above the dot */
  position: absolute;
  bottom: calc(100% + 9px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--brand-orange);
  color: #fff;
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.03em;
  padding: 5px 10px;
  border-radius: 5px;
  white-space: nowrap;
  box-shadow: 0 6px 16px rgba(254,103,16,0.40);
}
.connect-pin-label::after {          /* tail from label down to the dot */
  content: "";
  position: absolute;
  top: 100%; left: 50%;
  transform: translateX(-50%);
  border: 5px solid transparent;
  border-top-color: var(--brand-orange);
}
/* Label placement variants (so clustered pins don't overlap) */
.connect-pin[data-pos="left"] .connect-pin-label {
  bottom: auto; top: 50%; left: auto; right: calc(100% + 11px);
  transform: translateY(-50%);
}
.connect-pin[data-pos="left"] .connect-pin-label::after {
  top: 50%; left: 100%; transform: translateY(-50%);
  border-top-color: transparent; border-left-color: var(--brand-orange);
}
.connect-pin[data-pos="right"] .connect-pin-label {
  bottom: auto; top: 50%; left: calc(100% + 11px);
  transform: translateY(-50%);
}
.connect-pin[data-pos="right"] .connect-pin-label::after {
  top: 50%; left: auto; right: 100%; transform: translateY(-50%);
  border-top-color: transparent; border-right-color: var(--brand-orange);
}
.connect-pin[data-pos="bottom"] .connect-pin-label {
  bottom: auto; top: calc(100% + 9px); transform: translateX(-50%);
}
.connect-pin[data-pos="bottom"] .connect-pin-label::after {
  top: auto; bottom: 100%; left: 50%; transform: translateX(-50%);
  border-top-color: transparent; border-bottom-color: var(--brand-orange);
}
@keyframes connect-pulse {
  0%   { opacity: 1; transform: translate(-50%, -50%) scale(0.25); }
  100% { opacity: 0; transform: translate(-50%, -50%) scale(1.35); }
}
@media (max-width: 991px) {
  .connect-map { max-width: 480px; margin: 0 auto 10px; }
  .connect-pin-label { font-size: 10px; padding: 4px 7px; }
}
@media (max-width: 480px) {
  .connect-pin-label { font-size: 8.5px; padding: 3px 6px; border-radius: 4px; }
}
@media (prefers-reduced-motion: reduce) {
  .connect-pin::after { animation: none; opacity: 0; }
}
.connect-divider {
  height: 1px;
  background: rgba(255,255,255,0.18);
  margin: 0 0 36px;
  max-width: 90%;
}
.connect-address {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.connect-label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  color: rgba(255,255,255,0.50);
  font-weight: 500;
}
.connect-address p {
  font-size: 14px;
  line-height: 1.65;
  color: rgba(255,255,255,0.88);
  margin: 0;
}
.connect-address a {
  font-size: 14px;
  color: rgba(255,255,255,0.88);
  text-decoration: none;
  transition: color .2s ease;
}
.connect-address a:hover { color: var(--brand-teal); }
.connect-address .footer-phone a { display: inline; }

/* Submit button — sharp-rounded teal pill, full-width */
.h6-footer .tj-submit-btn.submit-btn-pill {
  border-radius: 999px;
  background: var(--brand-teal) !important;
}
@media (max-width: 991px) {
  .connect-title { margin-bottom: 40px; font-size: 56px; }
  .connect-left { padding-right: 0; }
}

/* ============================================================ */
/* Framework360 — Section 1: VCA hero                          */
/* ============================================================ */
/* Outer = white shows through the curve cutout (blends into next section) */
.fw360-vca-section {
  background: #fff;
  padding: 0;
  position: relative;
}
/* Panel with a big bottom-right curve (Figma 363:21719) */
.fw360-vca-bg {
  background: #F7F7F7;
  border-bottom-right-radius: 200px;
  padding: 150px 0 90px;
  position: relative;
  overflow: hidden;
}
.fw360-vca-heading { margin-bottom: 50px; position: relative; }
.fw360-vca-eyebrow {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(36px, 4.5vw, 64px);
  font-weight: 600;
  color: rgba(7,49,73,0.18);
  letter-spacing: -0.01em;
  line-height: 1;
  margin-bottom: 4px;
}
.fw360-vca-title {
  font-family: var(--font-display);
  color: var(--brand-navy);
  font-size: clamp(40px, 5vw, 72px);
  line-height: 1.05;
  font-weight: 600;
  margin: 0 0 18px;
}
.fw360-vca-desc {
  font-size: 16px;
  line-height: 1.7;
  color: rgba(51,49,52,0.78);
  max-width: 880px;
  margin: 0 auto;
}

.fw360-vca-media-wrap {
  position: relative;
  width: 100%;
  max-width: 520px;
  margin: 0 auto;
  padding-right: 40px;
  padding-bottom: 40px;
}
.fw360-vca-media-img {
  display: block;
  width: 100%;
  aspect-ratio: 1/1;
  object-fit: cover;
  border-radius: 50%;
  /* Ring around the circle (like home portraits) + soft drop shadow */
  box-shadow: 0 0 0 12px #e8eef4, 0 0 0 13px rgba(7,49,73,0.06), 0 24px 60px rgba(7,49,73,0.18);
}
.fw360-star {
  position: absolute;
  width: 32px;
  height: 32px;
  bottom: 0;
  right: 0;
  z-index: 2;
}

.fw360-vca-cards {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.fw360-vca-card {
  position: relative;
  padding: 28px 30px 28px;
  background: #e7eaf0;
  border-radius: 0;
  transition: background .3s ease, color .3s ease;
  cursor: default;
}
.fw360-vca-card .title {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 600;
  color: var(--brand-navy);
  margin-bottom: 10px;
  transition: color .3s ease;
}
.fw360-vca-card p {
  font-size: 14px;
  line-height: 1.65;
  color: rgba(51,49,52,0.85);
  margin: 0;
  transition: color .3s ease;
}
.fw360-vca-card.active {
  background: var(--brand-teal);
}
/* Curve only on the "Power of Agile VCA" box (2nd/last card) */
.fw360-vca-card:last-child { border-bottom-right-radius: 56px; }
.fw360-vca-card.active .title { color: #fff; }
.fw360-vca-card.active p { color: rgba(255,255,255,0.92); }

/* Hover swap: hovering non-active activates it, demotes active */
.fw360-vca-cards:has(.fw360-vca-card:not(.active):hover) .fw360-vca-card.active {
  background: #e7eaf0;
}
.fw360-vca-cards:has(.fw360-vca-card:not(.active):hover) .fw360-vca-card.active .title { color: var(--brand-navy); }
.fw360-vca-cards:has(.fw360-vca-card:not(.active):hover) .fw360-vca-card.active p { color: rgba(51,49,52,0.85); }
.fw360-vca-card:not(.active):hover { background: var(--brand-teal); }
.fw360-vca-card:not(.active):hover .title { color: #fff; }
.fw360-vca-card:not(.active):hover p { color: rgba(255,255,255,0.92); }

@media (max-width: 991px) {
  .fw360-vca-section { padding-top: 130px; }
  .fw360-vca-media-wrap { max-width: 360px; }
}

/* --- FW360 Section 2: 3 pins + teal banner --------------- */
.fw360-pins-section { background: #fff; padding-top: 30px; padding-bottom: 30px; }
.fw360-pin-track { margin-top: 40px; margin-bottom: 0; }
.fw360-pin-track .vca-pin-box {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.fw360-pin-track .vca-pin-box .pin-title {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 600;
  color: var(--brand-navy);
  margin: 0;
  transition: color .3s ease;
}
.fw360-pin-track .vca-pin.active .vca-pin-box .pin-title { color: #fff; }
.fw360-pin-track:has(.vca-pin:not(.active):hover) .vca-pin.active .vca-pin-box .pin-title { color: var(--brand-navy); }
.fw360-pin-track .vca-pin:not(.active):hover .vca-pin-box .pin-title { color: #fff; }

.fw360-pin-banner {
  margin-top: 28px;
  background: var(--brand-teal);
  padding: 26px 36px;
  border-radius: 0;
  display: flex;
  align-items: center;
  gap: 20px;
  color: #fff;
}
.fw360-pin-banner-icon {
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 1.5px solid #fff;
  display: inline-flex;
  align-items: center; justify-content: center;
  font-size: 12px;
  color: #fff;
  flex-shrink: 0;
}
.fw360-pin-banner p {
  font-size: 15px;
  line-height: 1.55;
  margin: 0;
  color: #fff;
}
.fw360-pin-banner strong { font-weight: 600; }

/* --- FW360 Section 3: 5 image bands ----------------------- */
.fw360-bands-section {
  background: #E1E8F0;
  padding: 60px 0 80px;
}
.fw360-bands-section .container {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.fw360-band {
  position: relative;
  background-color: #062a3f;
  border-radius: 0;
  display: flex;
  align-items: center;
  overflow: hidden;
}
.fw360-band-bg {
  position: relative;
  display: block;
  width: 100%;
  height: auto;
  max-height: none;
  object-fit: contain;
  z-index: 0;
}
.fw360-band::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(7,49,73,0.55) 0%, rgba(7,49,73,0.20) 40%, rgba(7,49,73,0.00) 65%);
  pointer-events: none;
  z-index: 1;
}
.fw360-band-card {
  position: absolute;
  left: 40px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  width: 100%;
  max-width: 460px;
  padding: 28px 30px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  color: #fff;
  text-align: left;
  background: rgba(7,49,73,0.78);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.08);
}
.fw360-band-icon-img {
  width: 44px;
  height: auto;
  margin-bottom: 16px;
  display: block;
}
@media (max-width: 991px) {
  .fw360-band { flex-direction: column; }
  .fw360-band-card {
    position: relative;
    left: auto; top: auto; transform: none;
    margin: -60px 20px 20px;
    max-width: calc(100% - 40px);
  }
  .fw360-band::after { background: linear-gradient(180deg, rgba(7,49,73,0.20) 0%, rgba(7,49,73,0.60) 100%); }
}
.fw360-band-title {
  font-family: var(--font-display);
  font-size: clamp(20px, 1.8vw, 26px);
  font-weight: 600;
  line-height: 1.2;
  color: #fff;
  margin: 0 0 10px;
}
.fw360-band-card p {
  font-size: 14px;
  line-height: 1.6;
  color: rgba(255,255,255,0.85);
  margin: 0;
}
@media (max-width: 767px) {
  .fw360-band { min-height: 240px; }
  .fw360-band-card { max-width: 100%; padding: 24px; }
  .fw360-band::after { background: linear-gradient(180deg, rgba(7,49,73,0.40) 0%, rgba(7,49,73,0.85) 100%); }
}

/* ------------------------------------------------------------------
   Scroll-driven sticky-stack parallax for the 5 bands (desktop + mobile),
   mirroring the home Diagnose section. Card design is unchanged — only
   positioning + a scale-on-exit animation are layered on top.
   ------------------------------------------------------------------ */
@media (min-width: 360px) {
  .fw360-bands-section .container {
    --numcards: 5;
    display: block;                 /* was flex column */
    padding-bottom: calc(var(--numcards) * 1.4em);
  }
  .fw360-band {
    position: sticky;
    top: 100px;
    margin-bottom: 24px;
    transform-origin: 50% 0%;
    will-change: transform;
  }
  .fw360-band:last-child { margin-bottom: 0; }
  @supports (animation-timeline: view()) {
    .fw360-bands-section .container { view-timeline-name: --fw-bands; }
    .fw360-band:nth-child(1) { --index: 1; }
    .fw360-band:nth-child(2) { --index: 2; }
    .fw360-band:nth-child(3) { --index: 3; }
    .fw360-band:nth-child(4) { --index: 4; }
    .fw360-band:nth-child(5) { --index: 5; }
    .fw360-band {
      --index0: calc(var(--index) - 1);
      --reverse-index: calc(var(--numcards) - var(--index0));
      --start-range: calc(var(--index0) / var(--numcards) * 100%);
      --end-range:   calc(var(--index)  / var(--numcards) * 100%);
      animation: fw-band-scale linear forwards;
      animation-timeline: --fw-bands;
      animation-range: exit-crossing var(--start-range) exit-crossing var(--end-range);
    }
    @keyframes fw-band-scale {
      to { transform: scale(calc(1.1 - calc(0.1 * var(--reverse-index)))); }
    }
  }
}

/* ============================================================ */
/* Intelligence Stack page                                       */
/* ============================================================ */
.is-hero-section {
  background: #eaeef3;
  padding-top: 180px;
  padding-bottom: 50px;
}
.is-hero { max-width: 880px; margin: 0 auto; }
.is-hero-eyebrow {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(40px, 5vw, 72px);
  font-weight: 600;
  color: rgba(7,49,73,0.18);
  letter-spacing: -0.01em;
  line-height: 1;
  margin-bottom: 10px;
}
.is-hero-title {
  font-family: var(--font-display);
  color: var(--brand-navy);
  font-size: clamp(36px, 4.4vw, 56px);
  font-weight: 600;
  line-height: 1.1;
  margin: 0 0 18px;
}
.is-hero-desc {
  font-size: 15px;
  line-height: 1.7;
  color: rgba(51,49,52,0.78);
  margin: 0;
}

.is-stack-section {
  background: #eaeef3;
  padding: 30px 0 80px;
}
.is-row {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 60px;
  align-items: center;
  padding: 60px 0;
  border-top: 1px solid rgba(7,49,73,0.08);
}
.is-row:first-of-type { border-top: none; }
.is-col-left { padding: 0 20px 0 40px; }
.is-step {
  font-family: var(--font-display);
  font-size: 44px;
  font-weight: 600;
  color: rgba(7,49,73,0.30);
  line-height: 1;
  margin-bottom: 20px;
}
.is-step span {
  font-size: 18px;
  vertical-align: super;
  color: rgba(7,49,73,0.40);
}
.is-icon {
  width: 56px; height: 56px;
  border-radius: 50%;
  background: var(--brand-charcoal);
  color: #fff;
  display: inline-flex;
  align-items: center; justify-content: center;
  margin-bottom: 20px;
}
.is-icon img {
  width: 28px; height: 28px;
  filter: brightness(0) invert(1);
}
.is-eyebrow {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--brand-teal);
  background: rgba(39,191,212,0.10);
  padding: 6px 12px;
  border-radius: 0;
  margin-bottom: 12px;
}
.is-title {
  font-family: var(--font-display);
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 700;
  color: var(--brand-navy);
  margin: 0 0 14px;
  line-height: 1.1;
  letter-spacing: -0.02em;
}
.is-headline {
  font-family: var(--font-display);
  font-size: clamp(16px, 1.5vw, 20px);
  font-weight: 600;
  color: var(--brand-charcoal);
  line-height: 1.3;
  margin: 0 0 16px;
  max-width: 540px;
}
.is-col-left p.is-body {
  font-size: 14px;
  line-height: 1.6;
  color: rgba(51,49,52,0.82);
  max-width: 540px;
  margin: 0 0 12px;
}
.is-col-left p.is-body:last-child { margin-bottom: 0; }
.is-col-left p.is-body strong {
  color: var(--brand-navy);
  font-weight: 700;
}
.is-col-right { display: flex; justify-content: center; align-items: center; }
.is-circle {
  display: block;
  width: 100%;
  max-width: 420px;
  height: auto;
}
@media (max-width: 991px) {
  .is-row { grid-template-columns: 1fr; gap: 30px; padding: 40px 0; }
  .is-col-left { padding: 0 20px; }
  .is-col-right { order: -1; }
  .is-circle { max-width: 320px; }
}

/* --- IS Vertically Integrated TP Solutions ---------------- */
/* Top bg image (Figma) — anchored top, full-width but aspect kept (not
   stretched/cropped); rest of the section stays white.
   Licensed source: web-reference/infer360 Assets 2/Solve/Vertically Integrated TP Solutions BG.jpg */
.is-vti-section {
  background: #fff url('images/brand/v2/is/first-section-bg.jpg') top center / 100% auto no-repeat;
  padding-top: 150px;
}
.is-vti-section .sub-title { color: var(--brand-teal); }
.is-vti-section .sec-title {
  font-family: var(--font-display);
  color: var(--brand-navy);
  font-size: clamp(34px, 4vw, 52px);
  line-height: 1.1;
}
.is-vti-section .sec-desc {
  font-size: 15px;
  color: rgba(51,49,52,0.78);
  max-width: 720px;
  margin: 14px auto 0;
}
.is-vti-heading { margin-bottom: 50px; max-width: 760px; margin-left: auto; margin-right: auto; }

.is-vti-card {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  background: var(--brand-navy);
  border-radius: 0;
  overflow: hidden;
  margin-bottom: 28px;
  text-decoration: none !important;
  min-height: 320px;
  box-shadow: 0 12px 32px rgba(7,49,73,0.14);
  transition: transform .35s ease, box-shadow .35s ease;
}
.is-vti-card:hover { transform: translateY(-4px); box-shadow: 0 22px 48px rgba(7,49,73,0.22); }

/* ============================================================
   Product Architecture — scroll-driven sticky deck-stack
   (same pattern as home Diagnose: pure CSS view-timeline)
   ============================================================ */
.is-vti-stack {
  --numcards: 3;
  --is-card-height: clamp(420px, 56vh, 560px);
  --is-top-offset: 2.2em;
  --is-gap: 4vw;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: repeat(var(--numcards), var(--is-card-height));
  gap: var(--is-gap);
  margin-top: 50px;
  padding-bottom: calc(var(--numcards) * var(--is-top-offset));
}
.is-vti-item {
  position: sticky;
  top: 100px;   /* header offset */
  padding-top: calc(var(--index) * var(--is-top-offset));
}
.is-vti-item:nth-child(1) { --index: 1; }
.is-vti-item:nth-child(2) { --index: 2; }
.is-vti-item:nth-child(3) { --index: 3; }
.is-vti-stack .is-vti-card {
  height: var(--is-card-height);
  min-height: 0;
  margin-bottom: 0;
  transform-origin: 50% 0%;
  will-change: transform;
}
.is-vti-stack .is-vti-card:hover { transform: none; }   /* scale owns transform */
@supports (animation-timeline: view()) {
  .is-vti-stack { view-timeline-name: --is-cards; }
  .is-vti-item {
    --index0: calc(var(--index) - 1);
    --reverse-index: calc(var(--numcards) - var(--index0));
  }
  .is-vti-stack .is-vti-card {
    --start-range: calc(var(--index0) / var(--numcards) * 100%);
    --end-range:   calc(var(--index)  / var(--numcards) * 100%);
    animation: is-card-scale linear forwards;
    animation-timeline: --is-cards;
    animation-range: exit-crossing var(--start-range) exit-crossing var(--end-range);
  }
  @keyframes is-card-scale {
    to { transform: scale(calc(1.1 - calc(0.1 * var(--reverse-index)))); }
  }
}
/* Mobile: disable sticky stack — cards flow naturally */
@media (max-width: 991px) {
  /* Keep the deck-stack parallax on mobile too: single-column cards that grow
     to their content (no fixed height = no clipped text). */
  .is-vti-stack {
    --is-top-offset: 1.3em;
    grid-template-rows: repeat(var(--numcards), auto);
    margin-top: 28px;
  }
  .is-vti-item {
    top: 84px;
    padding-top: calc(var(--index) * var(--is-top-offset));
  }
  .is-vti-stack .is-vti-card {
    height: auto;
    min-height: 340px;
  }
}
.is-vti-body {
  position: relative;
  padding: 40px 44px;
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.is-vti-watermark {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(44px, 5.5vw, 92px);
  font-weight: 600;
  color: rgba(255,255,255,0.12);
  letter-spacing: 0.01em;
  line-height: 1;
  margin-bottom: 10px;
}
.is-vti-title {
  font-family: var(--font-display);
  color: #fff;
  font-size: clamp(22px, 2.4vw, 30px);
  font-weight: 600;
  margin: 0 0 12px;
}
.is-vti-body p {
  font-size: 14px;
  line-height: 1.6;
  color: rgba(255,255,255,0.78);
  margin: 0;
  max-width: 420px;
}
.is-vti-photo {
  overflow: hidden;
  min-height: 280px;
}
.is-vti-photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .5s ease;
}
.is-vti-card:hover .is-vti-photo img { transform: scale(1.05); }
.is-vti-cta { margin-top: 40px; }

/* infer360 Product Architecture heading (Figma 363:23015) */
.is-vti-eyebrow {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(34px, 4.5vw, 56px);
  font-weight: 600;
  color: rgba(7,49,73,0.16);
  line-height: 1;
  margin-bottom: 4px;
}
.is-vti-main-title {
  font-family: var(--font-display);
  color: var(--brand-navy);
  font-size: clamp(34px, 4vw, 52px);
  line-height: 1.1;
  font-weight: 600;
  margin: 0 0 14px;
}
.is-vti-desc {
  font-size: 16px;
  color: rgba(51,49,52,0.78);
  max-width: 720px;
  margin: 0 auto;
}
/* Checklist inside the navy card body (teal line icons + light text) */
.is-vti-list {
  list-style: none;
  margin: 6px 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 18px;
  max-width: 470px;
}
.is-vti-list li {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}
.is-vti-list li img {
  width: 26px;
  height: 26px;
  flex-shrink: 0;
  margin-top: 1px;
}
.is-vti-list li span {
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.6;
  color: #a9b0b8;            /* Figma grey/69 */
}

@media (max-width: 991px) {
  .is-vti-card { grid-template-columns: 1fr; }
  .is-vti-photo { min-height: 220px; order: 2; }
  .is-vti-body { padding: 32px 28px; }
  .is-vti-list li span { font-size: 15px; }
}

/* ============================================================ */
/* Intelligence That Compounds slider (Figma 802:18230)          */
/* ============================================================ */
.is-slider-section { background: #073149; padding: 90px 0 110px; }
.is-slider-head { max-width: 840px; margin: 0 auto 56px; }
.is-slider-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(34px, 4.4vw, 56px);
  color: #f7f7f7;
  margin: 0 0 16px;
}
.is-slider-desc {
  font-size: 16px; line-height: 1.6;
  color: rgba(247,247,247,0.78);
  max-width: 760px; margin: 0 auto;
}
.is-slider { position: relative; max-width: 1120px; margin: 0 auto; }
.is-slide { display: none; position: relative; }
.is-slide.active { display: block; }
/* White card; left padding leaves room for the overlapping image */
/* Desktop: head wrapper is transparent — icon flows, media stays absolute
   (the mobile layout rows the icon + image inside this wrapper). */
.is-slide-head { display: contents; }
.is-slide-card {
  background: #fff;
  min-height: 460px;
  padding: 56px 150px 56px 320px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.is-slide-media {
  position: absolute;
  left: -150px;            /* straddles the left edge of the white box */
  top: 50%;
  transform: translateY(-50%);   /* vertically centred on the box's left line */
  width: 410px;
  z-index: 3;
}
.is-slide-media img {
  width: 100%; height: auto; display: block;
  /* PNG already carries its own soft shadow — no extra box/shadow */
}
.is-slide-icon {
  width: 88px; height: 88px; border-radius: 50%;
  background: var(--ic, var(--brand-teal));
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 26px;
}
.is-slide-icon img { width: 44px; height: 44px; display: block; }
.is-slide-eyebrow {
  display: inline-block;
  align-self: flex-start;
  background: #eef2f6;
  color: var(--brand-charcoal);
  font-family: var(--font-sans);
  font-size: 13px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  padding: 9px 16px; margin-bottom: 18px;
}
.is-slide-title {
  font-family: var(--font-display);
  font-size: clamp(30px, 3.4vw, 44px);
  font-weight: 600; color: var(--brand-navy);
  margin: 0 0 14px;
}
.is-slide-desc {
  font-size: 18px; line-height: 1.5;
  color: var(--brand-charcoal);
  max-width: 430px; margin: 0 0 26px;
}
.is-slide-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 12px; }
.is-slide-list li { display: flex; align-items: center; gap: 12px; }
.is-slide-list li i { color: var(--brand-teal); font-size: 15px; }
.is-slide-list li span { font-size: 15px; color: var(--brand-charcoal); }
/* Counter + vertical dots on the right of the card */
.is-slider-side {
  position: absolute;
  right: 34px; top: 50%; transform: translateY(-50%);
  display: flex; align-items: center; gap: 22px;
  z-index: 4; pointer-events: none;
}
.is-slider-counter {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 56px; line-height: 1;
  color: rgba(7,49,73,0.13);
}
.is-slider-counter span { font-size: 26px; }
.is-slider-dots { display: flex; flex-direction: column; gap: 18px; pointer-events: auto; }
.is-dot {
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--brand-teal); border: none; padding: 0; cursor: pointer;
  box-sizing: border-box;
  flex: 0 0 9px;            /* fixed cell so the active ring doesn't shift others */
  transition: box-shadow .25s ease;
}
/* Active = teal dot + concentric ring with a clear white gap. box-shadow keeps
   the 9px footprint, so it stays perfectly aligned with the other dots. */
.is-dot.active {
  background: var(--brand-teal);
  box-shadow: 0 0 0 4px #fff, 0 0 0 6px var(--brand-teal);
}
.is-slider-dots { align-items: center; }
@media (max-width: 991px) {
  /* Compact: icon + image share a top row, smaller icon → whole card in one view */
  .is-slide-card { padding: 30px 24px 34px; min-height: 0; text-align: left; }
  .is-slide-head {
    display: flex; align-items: center; gap: 18px; margin-bottom: 18px;
  }
  .is-slide-icon {
    width: 54px; height: 54px; margin-bottom: 0; flex: 0 0 54px;
  }
  .is-slide-icon img { width: 28px; height: 28px; }
  .is-slide-media {
    position: static; left: auto; top: auto; transform: none;
    width: 150px; flex: 0 0 150px;
  }
  /* Counter + dots centered below the card, on the navy bg */
  .is-slider-side {
    position: static; transform: none;
    justify-content: center; align-items: center;
    margin-top: 28px; gap: 16px;
  }
  .is-slider-counter { color: rgba(247,247,247,0.55); font-size: 34px; }
  .is-slider-counter span { font-size: 20px; }
  .is-slider-dots { flex-direction: row; align-items: center; }
  .is-slide-eyebrow, .is-slide-desc, .is-slide-list { margin-left: 0; }
}

/* ============================================================ */
/* Framework360 page (under Expertise)                           */
/* ============================================================ */
.fw-hero-section {
  background: #F7F7F7;
  padding-top: 180px;
  padding-bottom: 60px;
}
.fw-hero { max-width: 1000px; margin: 0 auto 50px; }
.fw-hero-eyebrow {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(34px, 4.4vw, 56px);
  font-weight: 600;
  color: rgba(7,49,73,0.18);
  letter-spacing: -0.01em;
  line-height: 1.1;
  margin-bottom: 14px;
}
.fw-hero-title {
  font-family: var(--font-display);
  color: var(--brand-navy);
  font-size: clamp(36px, 4.4vw, 56px);
  font-weight: 600;
  line-height: 1.1;
  margin: 0 0 22px;
}
.fw-hero-desc {
  font-size: 15px;
  line-height: 1.7;
  color: rgba(51,49,52,0.78);
  max-width: 920px;
  margin: 0 auto;
}
.fw-hero-image {
  max-width: 960px;
  margin: 0 auto;
  border-radius: 0;
  overflow: hidden;
  box-shadow: 0 20px 50px rgba(7,49,73,0.16);
}
.fw-hero-image img {
  display: block;
  width: 100%;
  height: auto;
}

/* --- FW Section 2: 3 Phase pin cards (extended) ----------- */
.fw-phases-section { background: #E1E8F0; padding-top: 60px; padding-bottom: 80px; }
.fw-pin-track { margin-top: 0; }
.fw-pin-track .vca-pin-circle {
  width: 92px;
  height: 92px;
  font-size: 14px;
  text-align: center;
}
.fw-pin-track .vca-pin-circle span { line-height: 1.15; }
.fw-pin-track .vca-pin-stem { width: 76px; height: 76px; border-radius: 38px 38px 0 0; }
.fw-pin-track .vca-pin-box.fw-phase-box {
  padding: 32px 30px 30px;
  min-height: 540px;
  display: flex;
  flex-direction: column;
}
.fw-phase-icon {
  width: 48px; height: 48px;
  margin-bottom: 14px;
  display: block;
}
.fw-phase-icon-light { display: none; }
.fw-phase.active .fw-phase-icon-light { display: block; }
.fw-phase.active .fw-phase-icon-dark { display: none; }
.fw-pin-track:has(.vca-pin:not(.active):hover) .fw-phase.active .fw-phase-icon-light { display: none; }
.fw-pin-track:has(.vca-pin:not(.active):hover) .fw-phase.active .fw-phase-icon-dark { display: block; }
.fw-phase:not(.active):hover .fw-phase-icon-light { display: block; }
.fw-phase:not(.active):hover .fw-phase-icon-dark { display: none; }

.fw-phase-title {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 600;
  color: var(--brand-navy);
  margin: 0 0 12px;
  line-height: 1.2;
  transition: color .3s ease;
}
.fw-phase-intro {
  font-size: 14px;
  line-height: 1.55;
  margin-bottom: 18px;
  color: var(--brand-charcoal);
}
.fw-phase-box p {
  font-size: 13px;
  line-height: 1.6;
  color: rgba(51,49,52,0.85);
  margin: 0 0 12px;
  transition: color .3s ease;
}
.fw-phase-box p strong { color: var(--brand-navy); transition: color .3s ease; }
.fw-phase.active .fw-phase-title { color: #fff; }
.fw-phase.active .fw-phase-box p,
.fw-phase.active .fw-phase-intro { color: #fff; }
.fw-phase.active .fw-phase-box p strong { color: #fff; }

/* Hover demote */
.fw-pin-track:has(.vca-pin:not(.active):hover) .fw-phase.active .fw-phase-title { color: var(--brand-navy); }
.fw-pin-track:has(.vca-pin:not(.active):hover) .fw-phase.active .fw-phase-box p,
.fw-pin-track:has(.vca-pin:not(.active):hover) .fw-phase.active .fw-phase-intro { color: rgba(51,49,52,0.85); }
.fw-pin-track:has(.vca-pin:not(.active):hover) .fw-phase.active .fw-phase-box p strong { color: var(--brand-navy); }
.fw-phase:not(.active):hover .fw-phase-title { color: #fff; }
.fw-phase:not(.active):hover .fw-phase-box p,
.fw-phase:not(.active):hover .fw-phase-intro { color: #fff; }
.fw-phase:not(.active):hover .fw-phase-box p strong { color: #fff; }

/* Phase circle curve "shoulder" — slight widening on stem base */
.fw-pin-track .vca-pin-stem {
  width: 64px;
  height: 60px;
  border-radius: 32px 32px 0 0;
}
.fw-pin-track .vca-pin-circle {
  border: 7px solid #e7eaf0;
  box-shadow: 0 0 0 0 transparent;
}
.fw-pin-track .vca-pin.active .vca-pin-circle {
  border-color: var(--brand-teal);
}
.fw-pin-track:has(.vca-pin:not(.active):hover) .vca-pin.active .vca-pin-circle {
  border-color: #e7eaf0;
}
.fw-pin-track .vca-pin:not(.active):hover .vca-pin-circle {
  border-color: var(--brand-teal);
}

/* Phase banner (navy bg + info icon + body) */
.fw-phase-banner {
  margin-top: 36px;
  background: var(--brand-navy);
  padding: 24px 32px;
  border-radius: 0;
  display: flex;
  align-items: flex-start;
  gap: 18px;
  color: #fff;
}
.fw-phase-banner-icon {
  width: 30px; height: 30px;
  border-radius: 50%;
  border: 1.5px solid #fff;
  display: inline-flex;
  align-items: center; justify-content: center;
  font-size: 14px;
  color: #fff;
  flex-shrink: 0;
  margin-top: 2px;
  background: transparent;
}
.fw-phase-banner-icon i { font-size: 14px; }
.fw-phase-banner p {
  font-size: 14px;
  line-height: 1.6;
  margin: 0;
  color: #fff;
}
.fw-phase-banner strong { color: #fff; font-weight: 600; }
.fw-phase-cta { margin-top: 32px; }

/* --- FW Section 3: Intelligence That Compounds ----------- */
.fw-itc-section { background: #fff; padding: 80px 0; }
.fw-itc-heading { max-width: 720px; margin: 0 auto 50px; }
.fw-itc-title {
  font-family: var(--font-display);
  color: var(--brand-navy);
  font-size: clamp(34px, 4vw, 52px);
  line-height: 1.1;
  font-weight: 600;
  margin: 0 0 16px;
}
.fw-itc-desc {
  font-size: 15px;
  line-height: 1.65;
  color: rgba(51,49,52,0.78);
}
.fw-itc-grid > [class*=col-] { display: flex; }
.fw-itc-card {
  background: #f1f4f7;
  border: 1px solid rgba(7,49,73,0.08);
  border-radius: 0;
  padding: 36px 30px;
  text-align: left;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-height: 320px;
}
.fw-itc-icon {
  width: 78px; height: 78px;
  border-radius: 50%;
  background: #fff;
  display: inline-flex;
  align-items: center; justify-content: center;
  margin-bottom: 24px;
  color: var(--brand-charcoal);
  font-size: 32px;
}
.fw-itc-icon img { width: 38px; height: 38px; }
.fw-itc-num {
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 500;
  color: rgba(51,49,52,0.55);
  margin-bottom: 6px;
}
.fw-itc-card-title {
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 600;
  color: var(--brand-navy);
  margin: 0 0 14px;
}
.fw-itc-card p {
  font-size: 14px;
  line-height: 1.6;
  color: rgba(51,49,52,0.85);
  margin: 0;
}

.fw-itc-promise {
  margin-top: 28px;
  background: var(--brand-teal);
  padding: 26px 36px;
  display: flex;
  align-items: flex-start;
  gap: 18px;
  color: #fff;
}
.fw-itc-promise-icon {
  width: 30px; height: 30px;
  display: inline-flex;
  align-items: center; justify-content: center;
  font-size: 20px;
  color: #fff;
  flex-shrink: 0;
  margin-top: 1px;
}
.fw-itc-promise p {
  font-size: 14px;
  line-height: 1.6;
  margin: 0;
  color: #fff;
}
.fw-itc-promise strong { color: #fff; font-weight: 600; }

/* --- FW Section 4: TP Intelligence Stack (full bg + right card) - */
.fw-tp-section {
  position: relative;
  background: #0c4350;
  color: #fff;
  overflow: hidden;
}
.fw-tp-bg {
  display: block;
  width: 100%;
  height: auto;
}
.fw-tp-section .container {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  z-index: 2;
  pointer-events: none;
}
.fw-tp-card {
  position: relative;
  pointer-events: auto;
  max-width: 540px;
  margin-right: 0;
  padding: 36px 36px 36px;
  background: rgba(7,49,73,0.72);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 0;
  color: #fff;
}
.fw-tp-eyebrow {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--brand-teal);
  letter-spacing: 0.10em;
  text-transform: uppercase;
  margin-bottom: 12px;
}
.fw-tp-title {
  font-family: var(--font-display);
  font-size: clamp(26px, 2.8vw, 38px);
  font-weight: 600;
  line-height: 1.15;
  color: #fff;
  margin: 0 0 14px;
}
.fw-tp-card > p {
  font-size: 14px;
  line-height: 1.6;
  color: rgba(255,255,255,0.85);
  margin: 0 0 18px;
}
.fw-tp-list {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.fw-tp-list li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 13px;
  line-height: 1.55;
  color: rgba(255,255,255,0.85);
}
.fw-tp-list strong { color: #fff; font-weight: 600; margin-right: 4px; }
.fw-tp-dot {
  flex-shrink: 0;
  width: 12px; height: 12px;
  border-radius: 50%;
  margin-top: 4px;
}
.fw-tp-dot.tone-red   { background: #ef3c2d; }
.fw-tp-dot.tone-green { background: #8fc742; }
.fw-tp-dot.tone-blue  { background: #2da9e0; }
.fw-tp-cta { margin-top: 8px; }

@media (max-width: 991px) {
  .fw-tp-section .container { position: relative; padding: 30px 20px; }
  .fw-tp-card { max-width: 100%; }
}

/* --- FW Section 5: Data Foundation ------------------------ */
.fw-df-section { background: #E1E8F0; padding: 80px 0; }
.fw-df-heading { max-width: 720px; margin-bottom: 40px; }
.fw-df-title {
  font-family: var(--font-display);
  color: var(--brand-navy);
  font-size: clamp(34px, 4vw, 52px);
  line-height: 1.1;
  font-weight: 600;
  margin: 0 0 14px;
}
.fw-df-heading p {
  font-size: 15px;
  line-height: 1.65;
  color: rgba(51,49,52,0.78);
  margin: 0;
}
.fw-df-main {
  border-radius: 0;
  overflow: hidden;
  height: 100%;
  min-height: 380px;
  box-shadow: 0 12px 32px rgba(7,49,73,0.10);
}
.fw-df-main img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.fw-df-cards {
  display: flex;
  flex-direction: column;
  gap: 20px;
  height: 100%;
}
.fw-df-card {
  display: flex;
  align-items: stretch;
  background: #f4f7fa;
  border: 1px solid rgba(7,49,73,0.08);
  border-radius: 0;
  overflow: hidden;
  flex: 1;
  min-height: 180px;
}
.fw-df-card-img {
  flex: 0 0 140px;
  overflow: hidden;
}
.fw-df-card-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.fw-df-card-body {
  padding: 22px 24px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.fw-df-card-body h3 {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 600;
  color: var(--brand-navy);
  margin: 0 0 8px;
}
.fw-df-card-body p {
  font-size: 13px;
  line-height: 1.6;
  color: rgba(51,49,52,0.85);
  margin: 0;
}
@media (max-width: 991px) {
  .fw-df-card { flex-direction: column; }
  .fw-df-card-img { flex: 0 0 160px; }
}

/* ============================================================
   FW360 — The Agentic Process Layer (Section 6, 371:26966)
   ============================================================ */
.fw-apl-section {
  background: #e1e8f0;
  padding: 80px 0 90px;
}
.fw-apl-heading {
  max-width: 760px;
  margin: 0 auto 60px;
  text-align: center;
}
.fw-apl-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 48px;
  line-height: 1.2;
  letter-spacing: -0.04em;
  color: var(--brand-charcoal);
  margin: 0 0 18px;
}
.fw-apl-heading > p {
  font-size: 18px;
  line-height: 1.45;
  color: var(--brand-charcoal);
  margin: 0;
}

/* Track + line */
.fw-apl-track {
  position: relative;
  margin: 30px 0 40px;
}
.fw-apl-line {
  position: absolute;
  top: 50px;
  left: 12px;
  right: 12px;
  height: 1px;
  background: #ced7e0;
  z-index: 0;
  overflow: hidden;
}
.fw-apl-line-active {
  position: absolute;
  inset: 0 66% 0 0;
  background: var(--brand-charcoal);
}
.fw-apl-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  position: relative;
  z-index: 1;
}

/* Pin */
.fw-apl-pin {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  z-index: 1;
}
/* Pin top = workshop curve blob rotated 90° (tail points down into card) */
.fw-apl-top {
  position: relative;
  width: 98px;
  height: 112px;
  margin: 0 auto;
  display: block;
  pointer-events: none;
  z-index: 2;
}
.fw-apl-shape {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 112px;
  height: 98px;
  transform: translate(-50%, -50%) rotate(90deg);
  display: block;
  /* Mask the curve, fill with EXACT card colour so overlap merges seamlessly.
     White by default — sits over the light #e1e8f0 section. */
  background-color: #fff;
  -webkit-mask: url('images/brand/v2/h7-process.svg') center / contain no-repeat;
          mask: url('images/brand/v2/h7-process.svg') center / contain no-repeat;
}
.fw-apl-circle {
  position: absolute;
  top: 15px;
  left: 15px;
  z-index: 1;
  width: 68px;
  height: 68px;
  border-radius: 50%;
  background: var(--brand-charcoal);
  color: #f7f7f7;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 20px;
  letter-spacing: -0.025em;
}
.fw-apl-box {
  position: relative;
  width: 100%;
  background: #fff;
  border-radius: 0;
  padding: 30px 30px 36px;
  min-height: 200px;
  margin-top: 0;
}
.fw-apl-box h3 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 24px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--brand-charcoal);
  margin: 0 0 18px;
}
.fw-apl-box p {
  font-size: 16px;
  line-height: 1.5;
  color: var(--brand-charcoal);
  margin: 0;
}

/* Active state — teal curve, teal box, teal circle w/ white num */
.fw-apl-pin.active .fw-apl-shape { background-color: var(--brand-teal); }
.fw-apl-pin.active .fw-apl-box  { background: var(--brand-teal); }
.fw-apl-pin.active .fw-apl-box h3,
.fw-apl-pin.active .fw-apl-box p { color: #f7f7f7; }
.fw-apl-pin.active .fw-apl-circle {
  background: var(--brand-teal);
  color: #fff;
}

/* Hover demote: hovering an inactive activates it, demotes active */
.fw-apl-grid:has(.fw-apl-pin:not(.active):hover) .fw-apl-pin.active .fw-apl-shape {
  background-color: #fff;
}
.fw-apl-grid:has(.fw-apl-pin:not(.active):hover) .fw-apl-pin.active .fw-apl-box {
  background: #fff;
}
.fw-apl-grid:has(.fw-apl-pin:not(.active):hover) .fw-apl-pin.active .fw-apl-box h3,
.fw-apl-grid:has(.fw-apl-pin:not(.active):hover) .fw-apl-pin.active .fw-apl-box p {
  color: var(--brand-charcoal);
}
.fw-apl-grid:has(.fw-apl-pin:not(.active):hover) .fw-apl-pin.active .fw-apl-circle {
  background: var(--brand-charcoal);
  color: #f7f7f7;
}
.fw-apl-pin:not(.active):hover .fw-apl-shape {
  background-color: var(--brand-teal);
}
.fw-apl-pin:not(.active):hover .fw-apl-box {
  background: var(--brand-teal);
  cursor: default;
}
.fw-apl-pin:not(.active):hover .fw-apl-box h3,
.fw-apl-pin:not(.active):hover .fw-apl-box p { color: #f7f7f7; }
.fw-apl-pin:not(.active):hover .fw-apl-circle {
  background: var(--brand-teal);
  color: #fff;
}

/* Trust band — navy */
.fw-apl-trust {
  display: flex;
  align-items: flex-start;
  gap: 22px;
  background: var(--brand-navy);
  padding: 38px 50px;
  border-radius: 0;
}
.fw-apl-trust-icon {
  flex: 0 0 22px;
  color: #fff;
  font-size: 20px;
  line-height: 1.5;
  padding-top: 2px;
}
.fw-apl-trust p {
  font-size: 16px;
  line-height: 1.5;
  color: #fff;
  margin: 0;
  flex: 1;
}
.fw-apl-trust p strong {
  font-weight: 700;
}

@media (max-width: 991px) {
  .fw-apl-title { font-size: 38px; }
  .fw-apl-grid { grid-template-columns: 1fr; gap: 36px; max-width: 540px; margin: 0 auto; }
  .fw-apl-line { display: none; }
  .fw-apl-trust { flex-direction: column; gap: 14px; padding: 28px 24px; }
}

/* ============================================================
   FW360 — The Command Center (Section 7, 371:27017)
   Pattern mirrors Why Infer360 first section: circular image
   on left, title + desc + 2 stacked cards on right, star at
   bottom right.
   ============================================================ */
.fw-cc-section {
  background: #e1e8f0;
  padding: 60px 0;
}
.fw-cc-bg {
  background: #fff;
  border-bottom-right-radius: 200px;
  padding: 80px 0 90px;
}
.fw-cc-row {
  position: relative;
}
.fw-cc-media-wrap {
  position: relative;
  width: 100%;
  max-width: 540px;
  margin: 0 auto;
  padding: 20px 30px;
}
.fw-cc-media-img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 50%;
  /* Ring around the circle (like why-infer360) + soft drop shadow */
  box-shadow: 0 0 0 12px #e8eef4, 0 0 0 13px rgba(7,49,73,0.06), 0 24px 60px rgba(7,49,73,0.18);
}
.fw-cc-content {
  position: relative;
  padding-right: 30px;
  padding-bottom: 20px;
}
.fw-cc-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 48px;
  line-height: 1.2;
  letter-spacing: -0.025em;
  color: var(--brand-charcoal);
  margin: 0 0 18px;
}
.fw-cc-desc {
  font-size: 16px;
  line-height: 1.6;
  color: var(--brand-charcoal);
  margin: 0 0 28px;
  max-width: 540px;
}
.fw-cc-cards {
  display: flex;
  flex-direction: column;
  gap: 16px;
  max-width: 560px;
}
.fw-cc-card {
  padding: 26px 30px 28px;
  background: #fff;
  border: 1px solid #ced7e0;
  border-radius: 0;
  transition: background .3s ease, color .3s ease, border-color .3s ease;
  cursor: default;
}
/* Curve on the 2nd text box (like why-infer360 Power of Agile VCA) */
.fw-cc-card:last-child { border-bottom-right-radius: 56px; }
.fw-cc-card .title {
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--brand-charcoal);
  margin: 0 0 12px;
  transition: color .3s ease;
}
.fw-cc-card p {
  font-size: 16px;
  line-height: 1.6;
  color: var(--brand-charcoal);
  margin: 0;
  transition: color .3s ease;
}
.fw-cc-card ul {
  margin: 0;
  padding-left: 22px;
  list-style: disc;
}
.fw-cc-card ul li {
  font-size: 16px;
  line-height: 1.6;
  color: var(--brand-charcoal);
  margin: 0;
  transition: color .3s ease;
}
.fw-cc-card.active {
  background: var(--brand-teal);
  border-color: var(--brand-teal);
}
.fw-cc-card.active .title,
.fw-cc-card.active p,
.fw-cc-card.active ul li { color: #fff; }

/* Hover swap: hovering non-active activates it, demotes active */
.fw-cc-cards:has(.fw-cc-card:not(.active):hover) .fw-cc-card.active {
  background: #fff;
  border-color: #ced7e0;
}
.fw-cc-cards:has(.fw-cc-card:not(.active):hover) .fw-cc-card.active .title,
.fw-cc-cards:has(.fw-cc-card:not(.active):hover) .fw-cc-card.active p,
.fw-cc-cards:has(.fw-cc-card:not(.active):hover) .fw-cc-card.active ul li {
  color: var(--brand-charcoal);
}
.fw-cc-card:not(.active):hover {
  background: var(--brand-teal);
  border-color: var(--brand-teal);
}
.fw-cc-card:not(.active):hover .title,
.fw-cc-card:not(.active):hover p,
.fw-cc-card:not(.active):hover ul li { color: #fff; }

/* Star sits at the bottom-right of the circle (like why-infer360) */
.fw-cc-star {
  position: absolute;
  width: 42px;
  height: 42px;
  bottom: 26px;
  right: 44px;
  z-index: 2;
}

@media (max-width: 991px) {
  .fw-cc-bg { border-bottom-right-radius: 100px; padding: 60px 0; }
  .fw-cc-title { font-size: 38px; }
  .fw-cc-content { padding-right: 16px; padding-top: 20px; }
  .fw-cc-media-wrap { max-width: 380px; padding: 10px; }
}

/* ============================================================
   TP Diagnostic Workshop — page (374:28376)
   ============================================================ */
.ws-hero-section {
  background: #fff;
  padding: 180px 0 50px;
}
.ws-hero { max-width: 980px; margin: 0 auto; }
/* Faded big display eyebrow — matches Intelligence Stack / Why Infer360 */
.ws-hero-eyebrow {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(36px, 4.5vw, 64px);
  font-weight: 600;
  color: rgba(7,49,73,0.18);
  letter-spacing: -0.01em;
  line-height: 1;
  margin-bottom: 10px;
}
.ws-hero-title {
  font-family: var(--font-display);
  color: var(--brand-navy);
  font-size: clamp(36px, 4.4vw, 56px);
  font-weight: 600;
  line-height: 1.1;
  margin: 0 0 18px;
}
.ws-hero-desc {
  font-size: 16px;
  line-height: 1.7;
  color: rgba(51,49,52,0.78);
  margin: 0 auto;
  max-width: 880px;
}

/* Agenda section */
.ws-agenda-section {
  background: #fff;
  padding: 60px 0 100px;
}
.ws-agenda-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(34px, 4.4vw, 56px);
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--brand-charcoal);
  margin: 0 auto 50px;
  text-align: center;
}
.ws-agenda-row { position: relative; }

/* Vertical step list — based on vca-pin idiom, rotated to vertical */
.ws-steps {
  position: relative;
  padding-left: 0;
}
/* Vertical divider line through pin circles */
.ws-steps::before {
  content: "";
  position: absolute;
  left: 56px;
  top: 110px;
  bottom: 110px;
  width: 1px;
  background: rgba(7,49,73,0.18);
  z-index: 0;
}
.ws-steps::after {
  /* Active dark segment covering first step */
  content: "";
  position: absolute;
  left: 56px;
  top: 0;
  height: 110px;
  width: 1px;
  background: var(--brand-charcoal);
  z-index: 1;
}
.ws-step {
  position: relative;
  display: flex;
  align-items: stretch;
  gap: 0;
  margin-bottom: 30px;
  z-index: 2;
}
.ws-step:last-child { margin-bottom: 0; }
.ws-step-pin {
  position: relative;
  flex: 0 0 112px;
  width: 112px;
  height: 98px;
  align-self: flex-start;
  margin-top: 12px;
}
.ws-step-shape {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  /* White by default — sits over light section */
  filter: brightness(0) invert(1);
}
.ws-step-num {
  position: absolute;
  top: 15px;
  left: 15px;
  width: 68px;
  height: 68px;
  border-radius: 50%;
  background: #e1e8f0;
  color: var(--brand-charcoal);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 20px;
  letter-spacing: -0.025em;
  z-index: 1;
}
.ws-step-body {
  flex: 1;
  padding: 22px 30px;
  background: #fff;
  border: 1px solid rgba(7,49,73,0.08);
}
.ws-step-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--brand-charcoal);
  margin: 0 0 10px;
}
.ws-step-body p {
  font-size: 15px;
  line-height: 1.55;
  color: var(--brand-charcoal);
  margin: 0;
}

/* Active step — teal pin + teal circle (white num) */
.ws-step.active .ws-step-shape {
  filter: brightness(0) saturate(100%) invert(64%) sepia(96%) saturate(388%) hue-rotate(143deg) brightness(94%) contrast(86%);
}
.ws-step.active .ws-step-num {
  background: var(--brand-teal);
  color: #fff;
}

/* Hover swap: inactive becomes active visually, real-active demotes */
.ws-steps:has(.ws-step:not(.active):hover) .ws-step.active .ws-step-shape {
  filter: brightness(0) invert(1);
}
.ws-steps:has(.ws-step:not(.active):hover) .ws-step.active .ws-step-num {
  background: #e1e8f0;
  color: var(--brand-charcoal);
}
.ws-step:not(.active):hover .ws-step-shape {
  filter: brightness(0) saturate(100%) invert(64%) sepia(96%) saturate(388%) hue-rotate(143deg) brightness(94%) contrast(86%);
}
.ws-step:not(.active):hover .ws-step-num {
  background: var(--brand-teal);
  color: #fff;
}

/* Right banner image with transparent overlay caption (title + desc) */
.ws-banner {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 760px;
  overflow: hidden;
  border-radius: 0;
}
.ws-banner-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.ws-banner-overlay {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: calc(100% - 90px);
  max-width: 480px;
  padding: 30px 30px 50px;
  background: rgba(255,255,255,0.10);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 0;
}
.ws-banner-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 40px;
  line-height: 1.1;
  letter-spacing: -0.025em;
  color: #fff;
  margin: 0 0 18px;
}
.ws-banner-overlay p {
  font-size: 16px;
  line-height: 1.5;
  color: #fff;
  margin: 0;
}

/* Active state for Workshop CTA in header */
/* Workshop page active — colors reversed: bg orange, arrow circle dark */
.header-workshop-cta.active,
.header-sticky .header-workshop-cta.active {
  background: var(--brand-orange);
  color: #fff !important;
}
.header-workshop-cta.active:hover,
.header-sticky .header-workshop-cta.active:hover {
  background: #e8550a;
}
.header-workshop-cta.active .pill-icon {
  background: var(--brand-charcoal);
  color: #fff;
}

@media (max-width: 991px) {
  .ws-hero-section { padding-top: 140px; }
  .ws-banner { min-height: 480px; margin-top: 30px; }
  .ws-step { margin-bottom: 24px; }
  .ws-step-pin { flex: 0 0 92px; width: 92px; height: 80px; }
  .ws-step-num { width: 56px; height: 56px; top: 12px; left: 12px; font-size: 18px; }
  .ws-step-body { padding: 18px 22px; }
  .ws-steps::before { left: 46px; }
  .ws-steps::after { left: 46px; }
  .ws-banner-title { font-size: 30px; }
}

/* ============================================================
   Workshop — Section 3: Unlock Foundational Assets (374:29568)
   ============================================================ */
.ws-deliv-section {
  background: #eaeef3;
  padding: 80px 0 100px;
}
.ws-deliv-row { position: relative; }

.ws-deliv-media-wrap {
  position: relative;
  width: 100%;
  max-width: 600px;
  margin: 0 auto;
  padding: 30px 30px 30px 90px;
}
.ws-deliv-curve {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 110px;
  height: auto;
  z-index: 0;
  pointer-events: none;
  /* Curve fill is #E1E8F0; section bg is #eaeef3 — slight contrast keeps it visible */
}
.ws-deliv-media-img {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 50%;
  /* Ring around the circle (like framework360 Command Center / why-infer360) */
  box-shadow: 0 0 0 12px #e8eef4, 0 0 0 13px rgba(7,49,73,0.06), 0 24px 60px rgba(7,49,73,0.18);
}

.ws-deliv-content {
  position: relative;
  padding-right: 20px;
}
.ws-deliv-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(34px, 4vw, 48px);
  line-height: 1.1;
  letter-spacing: -0.025em;
  color: var(--brand-charcoal);
  margin: 0 0 30px;
}
.ws-deliv-cards {
  display: flex;
  flex-direction: column;
  gap: 18px;
  max-width: 560px;
}
.ws-deliv-card {
  padding: 26px 30px 28px;
  background: #fff;
  border: 1px solid #ced7e0;
  border-radius: 0;
  transition: background .3s ease, color .3s ease, border-color .3s ease;
  cursor: default;
}
.ws-deliv-label {
  display: block;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 20px;
  line-height: 1.3;
  letter-spacing: -0.02em;
  color: var(--brand-charcoal);
  margin: 0 0 6px;
  transition: color .3s ease;
}
.ws-deliv-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 28px;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--brand-charcoal);
  margin: 0 0 14px;
  transition: color .3s ease;
}
.ws-deliv-card p {
  font-size: 16px;
  line-height: 1.6;
  color: var(--brand-charcoal);
  margin: 0 0 4px;
  transition: color .3s ease;
}
.ws-deliv-card p:last-child { margin-bottom: 0; }
.ws-deliv-lead em {
  font-style: italic;
  font-weight: 500;
}

/* Active state — teal */
.ws-deliv-card.active {
  background: var(--brand-teal);
  border-color: var(--brand-teal);
}
.ws-deliv-card.active .ws-deliv-label,
.ws-deliv-card.active .ws-deliv-name,
.ws-deliv-card.active p { color: #fff; }

/* Hover swap */
.ws-deliv-cards:has(.ws-deliv-card:not(.active):hover) .ws-deliv-card.active {
  background: #fff;
  border-color: #ced7e0;
}
.ws-deliv-cards:has(.ws-deliv-card:not(.active):hover) .ws-deliv-card.active .ws-deliv-label,
.ws-deliv-cards:has(.ws-deliv-card:not(.active):hover) .ws-deliv-card.active .ws-deliv-name,
.ws-deliv-cards:has(.ws-deliv-card:not(.active):hover) .ws-deliv-card.active p {
  color: var(--brand-charcoal);
}
.ws-deliv-card:not(.active):hover {
  background: var(--brand-teal);
  border-color: var(--brand-teal);
}
.ws-deliv-card:not(.active):hover .ws-deliv-label,
.ws-deliv-card:not(.active):hover .ws-deliv-name,
.ws-deliv-card:not(.active):hover p { color: #fff; }

.ws-deliv-star {
  position: absolute;
  width: 44px;
  height: 44px;
  bottom: 56px;
  right: 26px;
  left: auto;
  z-index: 2;   /* diagonally bottom-right of the circle */
}

@media (max-width: 991px) {
  .ws-deliv-media-wrap { max-width: 420px; padding: 20px 10px 20px 60px; }
  .ws-deliv-curve { width: 70px; }
  .ws-deliv-title { font-size: 32px; }
  .ws-deliv-name { font-size: 24px; }
  .ws-deliv-star { display: none; }
}

/* ============================================================
   Workshop — Section 4: Is This Workshop Right For You? (374:29606)
   ============================================================ */
.ws-fit-section {
  background: var(--brand-navy);
  padding: 90px 0 100px;
}
.ws-fit-heading {
  max-width: 880px;
  margin: 0 auto 50px;
  text-align: center;
}
.ws-fit-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(36px, 4.6vw, 56px);
  line-height: 1.15;
  letter-spacing: -0.025em;
  color: #fff;
  margin: 0 0 14px;
}
.ws-fit-desc {
  font-size: 18px;
  line-height: 1.5;
  color: #a9b0b8;
  margin: 0 auto;
  max-width: 700px;
}

.ws-fit-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 40px;
}
.ws-fit-card {
  background: var(--brand-navy);
  border: 1px solid rgba(206,215,224,0.18);
  border-radius: 0;
  padding: 40px 30px 44px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  transition: background .3s ease, border-color .3s ease;
}
.ws-fit-icon {
  width: 88px;
  height: 88px;
  border-radius: 50%;
  background: #e1e8f0;
  color: var(--brand-navy);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 40px;
  margin-bottom: 50px;
  transition: background .3s ease, color .3s ease;
}
.ws-fit-num {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.05em;
  color: #a9b0b8;
  margin: 0 0 14px;
}
.ws-fit-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 24px;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: #fff;
  margin: 0 0 14px;
}
.ws-fit-card p {
  font-size: 16px;
  line-height: 1.6;
  color: #a9b0b8;
  margin: 0;
}
.ws-fit-card:hover {
  border-color: var(--brand-teal);
}
.ws-fit-card:hover .ws-fit-icon {
  background: var(--brand-teal);
  color: #fff;
}

/* White quote banner */
.ws-fit-quote {
  background: #fff;
  border-radius: 0;
  padding: 36px 50px;
  margin-bottom: 18px;
  text-align: center;
}
.ws-fit-quote p {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 22px;
  line-height: 1.3;
  letter-spacing: -0.02em;
  color: var(--brand-navy);
  margin: 0;
}

/* Teal CTA banner */
.ws-fit-cta {
  display: flex;
  align-items: flex-start;
  gap: 22px;
  background: var(--brand-teal);
  border-radius: 0;
  padding: 28px 50px;
}
.ws-fit-cta-icon {
  flex: 0 0 22px;
  color: #fff;
  font-size: 20px;
  line-height: 1.5;
  padding-top: 2px;
}
.ws-fit-cta p {
  font-size: 16px;
  line-height: 1.5;
  color: #fff;
  margin: 0;
  flex: 1;
}

@media (max-width: 991px) {
  .ws-fit-grid { grid-template-columns: 1fr; gap: 20px; max-width: 460px; margin: 0 auto 30px; }
  .ws-fit-title { font-size: 34px; }
  .ws-fit-quote { padding: 26px 24px; }
  .ws-fit-quote p { font-size: 18px; }
  .ws-fit-cta { flex-direction: column; gap: 12px; padding: 22px 24px; }
}

/* ============================================================
   Workshop — Section 5: Registration Form (376:31996)
   ============================================================ */
.ws-register-section {
  background: #f3f5f8;
  padding: 100px 0 120px;
}
.ws-register-row { position: relative; }

.ws-register-intro {
  position: relative;
  padding-right: 40px;
}
.ws-register-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(36px, 4.4vw, 48px);
  line-height: 1.2;
  letter-spacing: -0.025em;
  color: var(--brand-charcoal);
  margin: 0 0 50px;
  max-width: 520px;
}
.ws-register-link {
  padding: 6px 22px 6px 6px;
}
.ws-register-dotted {
  display: block;
  width: 220px;
  height: 220px;
  margin-top: 30px;
  opacity: 0.7;
}

/* Form card */
.ws-register-card {
  background: var(--brand-navy);
  border: 1px solid #ced7e0;
  border-top-right-radius: 100px;
  padding: 60px 50px 50px;
  position: relative;
}
.ws-register-form .row { --bs-gutter-x: 32px; --bs-gutter-y: 40px; }
.ws-field {
  position: relative;
  border-bottom: 1px solid #676e7a;
  display: flex;
  align-items: center;
  height: 38px;
  padding-right: 28px;
}
.ws-field input,
.ws-field select {
  width: 100%;
  background: transparent !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
  color: #fff !important;
  font-family: var(--font-sans);
  font-size: 16px;
  appearance: none;
  -webkit-appearance: none;
  border-radius: 0 !important;
  height: 36px !important;
  line-height: 36px !important;
}
.ws-field input:focus,
.ws-field select:focus { background: transparent !important; color: #fff !important; }
.ws-field input::placeholder { color: #a9b0b8; }
.ws-field select option { color: var(--brand-charcoal); background: #fff; }
.ws-field .ws-field-icon {
  position: absolute;
  right: 4px;
  top: 8px;
  color: #a9b0b8;
  font-size: 16px;
  pointer-events: none;
  line-height: 1;
}
.ws-field-select .ws-field-icon { font-size: 14px; }
.ws-field-date input { color-scheme: dark; }

.ws-register-submit-wrap {
  margin-top: 36px;
}
.ws-register-submit {
  width: 100%;
  background: var(--brand-orange);
  color: #fff;
  border: none;
  border-radius: 999px;
  padding: 18px 30px;
  font-family: var(--font-sans);
  font-size: 16px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.01em;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  transition: background .2s ease, transform .2s ease;
}
.ws-register-submit:hover { background: #e8550a; transform: translateY(-1px); }
.ws-register-submit i { font-size: 14px; }

@media (max-width: 991px) {
  .ws-register-section { padding: 70px 0 80px; }
  .ws-register-intro { padding-right: 0; margin-bottom: 40px; }
  .ws-register-title { font-size: 34px; }
  .ws-register-card { padding: 40px 26px; border-top-right-radius: 60px; }
  .ws-register-dotted { width: 160px; height: 160px; }
}

/* ============================================================
   Workshop — Section 6: Partner-Led Intelligence (376:32604)
   ============================================================ */
.ws-partner-section {
  background: #e1e8f0;
  padding: 90px 0 100px;
}
.ws-partner-heading {
  max-width: 760px;
  margin: 0 auto 50px;
  text-align: center;
}
.ws-partner-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(36px, 4.6vw, 56px);
  line-height: 1.2;
  letter-spacing: -0.025em;
  color: var(--brand-charcoal);
  margin: 0 0 18px;
}
.ws-partner-desc {
  font-size: 18px;
  line-height: 1.45;
  color: var(--brand-charcoal);
  margin: 0;
}

/* Stage: image right-aligned, cards overlay from left */
.ws-partner-stage {
  position: relative;
  padding-top: 60px;
}
.ws-partner-bg {
  display: block;
  width: 62%;
  aspect-ratio: 850 / 640;
  object-fit: cover;
  margin-left: auto;
  border-radius: 0;
}
.ws-partner-cards {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 70px;
  display: grid;
  grid-template-columns: repeat(3, 330px);
  gap: 20px;
  pointer-events: none;
}
.ws-partner-card {
  background: #f7f7f7;
  border: 1px solid #ced7e0;
  border-radius: 0;
  padding: 36px 30px;
  min-height: 265px;
  pointer-events: auto;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 24px;
}
.ws-partner-num {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  color: #051229;
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1;
}
.ws-partner-num .big { font-size: 44px; line-height: 1; }
.ws-partner-num .suffix { font-size: 24px; line-height: 1; }
.ws-partner-title .nowrap { white-space: normal; }
@media (min-width: 576px) { .ws-partner-title .nowrap { white-space: nowrap; } }
.ws-partner-card p {
  font-size: 16px;
  line-height: 1.5;
  color: #364052;
  margin: 0;
}

@media (max-width: 1199px) {
  .ws-partner-cards { grid-template-columns: repeat(3, minmax(0, 1fr)); max-width: 920px; }
  .ws-partner-card { min-height: 240px; padding: 28px 24px; }
}
@media (max-width: 991px) {
  .ws-partner-title { font-size: 34px; }
  .ws-partner-bg { width: 100%; margin: 0 0 -30px; }
  .ws-partner-cards { position: static; grid-template-columns: 1fr; gap: 16px; max-width: 460px; margin: 30px auto 0; }
  .ws-partner-num .big { font-size: 38px; }
}

/* ============================================================
   Workshop — Section 7: CTA band (376:33443)
   ============================================================ */
.ws-cta-band {
  position: relative;
  background-color: var(--brand-teal);
  padding: 60px 0;
  overflow: hidden;
  isolation: isolate;
}
.ws-cta-band::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url('images/brand/v2/workshop-cta-bg.png') center / cover no-repeat;
  mix-blend-mode: multiply;
  pointer-events: none;
  z-index: 0;
}
.ws-cta-band > .container { position: relative; z-index: 1; }
.ws-cta-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
  flex-wrap: wrap;
}
.ws-cta-copy { flex: 1; min-width: 0; }
.ws-cta-headline {
  margin: 0;
  color: #f7f7f7;
  font-family: var(--font-display);
  letter-spacing: -0.02em;
  line-height: 1.2;
}
.ws-cta-brand {
  display: block;
  font-size: clamp(36px, 4.4vw, 54px);
  font-weight: 700;
  margin-bottom: 8px;
}
.ws-cta-body {
  display: block;
  font-family: var(--font-sans);
  font-size: clamp(20px, 2.2vw, 30px);
  font-weight: 500;
  line-height: 1.3;
}
.ws-cta-body strong {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.2em;
  display: inline;
}
.ws-cta-action { flex-shrink: 0; }
.ws-cta-btn { padding: 6px 24px 6px 6px; font-size: 15px; }

@media (max-width: 991px) {
  .ws-cta-band { padding: 50px 0; }
  .ws-cta-inner { flex-direction: column; align-items: flex-start; gap: 28px; }
  .ws-cta-body { font-size: 20px; }
}

/* ============================================================
   Resources page (475:8839)
   ============================================================ */
.res-hero-section {
  background: #fff;
  padding: 140px 0 30px;
  text-align: center;
}
.res-hero { max-width: 880px; margin: 0 auto; }
.res-hero-eyebrow {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(36px, 4.5vw, 64px);
  font-weight: 600;
  color: rgba(7,49,73,0.18);
  letter-spacing: -0.01em;
  line-height: 1;
  margin-bottom: 10px;
}
.res-hero-title {
  font-family: var(--font-display);
  color: var(--brand-navy);
  font-size: clamp(40px, 5vw, 64px);
  font-weight: 600;
  line-height: 1.05;
  margin: 0 0 18px;
}
.res-hero-desc {
  font-size: 16px;
  line-height: 1.7;
  color: rgba(51,49,52,0.78);
  margin: 0 auto;
  max-width: 720px;
}

/* Blogs */
.res-blogs-section {
  background: #fff;
  padding: 40px 0 100px;
}
.res-blogs-heading {
  max-width: 880px;
  margin: 0 auto 50px;
  text-align: center;
}
.res-blogs-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(36px, 4.4vw, 56px);
  line-height: 1.1;
  letter-spacing: -0.025em;
  color: var(--brand-charcoal);
  margin: 0 0 14px;
}
.res-blogs-desc {
  font-size: 16px;
  line-height: 1.7;
  color: rgba(51,49,52,0.78);
  margin: 0 auto;
  max-width: 720px;
}
.res-blogs-grid { --bs-gutter-x: 30px; --bs-gutter-y: 30px; }

.res-blog-card {
  background: #fff;
  border: 1px solid #ced7e0;
  border-radius: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  height: 100%;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.res-blog-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 36px rgba(7,49,73,0.10);
  border-color: var(--brand-teal);
}
.res-blog-media {
  position: relative;
  aspect-ratio: 416 / 238;
  overflow: hidden;
}
.res-blog-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .35s ease;
}
.res-blog-card:hover .res-blog-media img { transform: scale(1.04); }
.res-blog-date {
  position: absolute;
  right: 15px;
  bottom: 0;
  transform: translateY(50%);
  background: var(--brand-teal);
  color: #fff;
  padding: 14px 18px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 80px;
  z-index: 2;
  border-radius: 0;
}
.res-blog-date .day {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 28px;
  line-height: 1;
  letter-spacing: -0.02em;
}
.res-blog-date .mon {
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-top: 4px;
}
.res-blog-body {
  padding: 36px 30px 28px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.res-blog-meta {
  list-style: none;
  margin: 0 0 14px;
  padding: 0;
  display: flex;
  gap: 22px;
  font-size: 13px;
  color: rgba(51,49,52,0.7);
}
.res-blog-meta li { display: inline-flex; align-items: center; gap: 6px; }
.res-blog-meta li i { color: var(--brand-teal); font-size: 13px; }
.res-blog-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  line-height: 1.25;
  letter-spacing: -0.02em;
  margin: 0 0 14px;
}
.res-blog-title a {
  color: var(--brand-charcoal);
  text-decoration: none;
  cursor: pointer;
}
.res-blog-title a:hover { color: var(--brand-teal); }
.res-blog-card p {
  font-size: 15px;
  line-height: 1.55;
  color: rgba(51,49,52,0.78);
  margin: 0 0 22px;
  flex: 1;
}
.res-blog-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--brand-charcoal);
  text-decoration: none;
  cursor: pointer;
}
.res-blog-btn .dot {
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background: var(--brand-teal);
  display: inline-block;
}
.res-blog-btn i {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--brand-charcoal);
  color: #fff;
  font-size: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background .2s ease;
}
.res-blog-btn:hover { color: var(--brand-teal); }
.res-blog-btn:hover i { background: var(--brand-teal); }

/* Pagination */
.res-pagination {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 50px;
}
.res-page {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: #f4f7fa;
  color: var(--brand-charcoal);
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.02em;
  text-decoration: none;
  cursor: default;
  transition: background .2s ease, color .2s ease;
}
.res-page.current,
.res-page:hover {
  background: var(--brand-teal);
  color: #fff;
}
.res-page-next i { font-size: 13px; }

/* Sidebar widgets */
.res-sidebar { padding-left: 12px; }
.res-widget {
  background: #f4f7fa;
  border: 1px solid #ced7e0;
  border-radius: 0;
  padding: 30px;
  margin-bottom: 30px;
}
.res-widget:last-child { margin-bottom: 0; }
.res-widget-title {
  position: relative;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--brand-charcoal);
  margin: 0 0 30px;
  padding-bottom: 14px;
}
.res-widget-title::before,
.res-widget-title::after {
  content: "";
  position: absolute;
  bottom: 0;
  height: 3px;
  background: var(--brand-teal);
}
.res-widget-title::before { left: 0; width: 40px; }
.res-widget-title::after { left: 45px; width: 10px; }

/* Search */
.res-widget-search {
  position: relative;
}
.res-widget-search input {
  width: 100%;
  background: #fff !important;
  border: 1px solid #ced7e0 !important;
  border-radius: 0 !important;
  padding: 18px 50px 18px 20px !important;
  height: auto !important;
  font-size: 14px;
  color: var(--brand-charcoal) !important;
  outline: none !important;
  font-family: var(--font-sans);
}
.res-widget-search input::placeholder { color: rgba(51,49,52,0.55); }
.res-widget-search button {
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  background: transparent;
  border: none;
  color: var(--brand-charcoal);
  font-size: 16px;
  cursor: pointer;
  padding: 6px;
}

/* Recent Post */
.res-recent {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.res-recent li {
  display: flex;
  gap: 16px;
  align-items: center;
}
.res-recent .thumb {
  flex: 0 0 96px;
  width: 96px;
  height: 100px;
  display: block;
  overflow: hidden;
}
.res-recent .thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.res-recent .body { flex: 1; min-width: 0; }
.res-recent .title {
  display: block;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 16px;
  line-height: 1.35;
  letter-spacing: -0.02em;
  color: var(--brand-charcoal);
  text-decoration: none;
  margin-bottom: 8px;
  cursor: pointer;
}
.res-recent .title:hover { color: var(--brand-teal); }
.res-recent .date {
  font-size: 12px;
  color: rgba(51,49,52,0.65);
  font-family: var(--font-sans);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.res-recent .date i { color: var(--brand-teal); }

/* Categories */
.res-categories {
  list-style: none;
  margin: 0;
  padding: 0;
}
.res-categories li { border-bottom: 1px solid #ced7e0; }
.res-categories li:last-child { border-bottom: none; }
.res-categories a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 4px;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 600;
  color: var(--brand-charcoal);
  text-decoration: none;
  cursor: default;
  transition: color .2s ease, padding-left .2s ease;
}
.res-categories a:hover { color: var(--brand-teal); padding-left: 8px; }
.res-categories .count { color: rgba(51,49,52,0.55); font-weight: 500; }

/* Tags */
.res-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.res-tags a {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  background: #fff;
  border: 1px solid #ced7e0;
  border-radius: 0;
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  color: var(--brand-charcoal);
  text-decoration: none;
  cursor: default;
  transition: background .2s ease, color .2s ease, border-color .2s ease;
}
.res-tags a:hover {
  background: var(--brand-teal);
  border-color: var(--brand-teal);
  color: #fff;
}

@media (max-width: 991px) {
  .res-hero-section { padding-top: 130px; }
  .res-blogs-title { font-size: 34px; }
  .res-blog-body { padding: 30px 22px 22px; }
  .res-sidebar { padding-left: 12px; margin-top: 40px; }
}

/* ============================================================
   Resources — Section 3: Videos (441:17791)
   ============================================================ */
.res-videos-section {
  background: var(--brand-navy);
  padding: 100px 0;
}
.res-videos-heading {
  text-align: center;
  max-width: 760px;
  margin: 0 auto 50px;
}
.res-videos-eyebrow {
  display: block;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.18em;
  color: var(--brand-teal);
  text-transform: uppercase;
  margin-bottom: 14px;
}
.res-videos-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(36px, 4.6vw, 56px);
  line-height: 1.1;
  letter-spacing: -0.025em;
  color: #fff;
  margin: 0 0 14px;
}
.res-videos-desc {
  font-size: 18px;
  line-height: 1.45;
  color: #e1e8f0;
  margin: 0 auto;
  max-width: 720px;
}

.res-videos-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  margin-bottom: 40px;
}
.res-video-card {
  display: flex;
  flex-direction: column;
}
.res-video-media {
  position: relative;
  aspect-ratio: 420 / 290;
  overflow: hidden;
}
.res-video-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.res-video-play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: var(--brand-teal);
  color: var(--brand-charcoal);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  pointer-events: none;
}
.res-video-caption {
  background: #e1e8f0;
  border: 1px solid #ced7e0;
  padding: 28px 26px;
}
.res-video-caption h3 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: #051229;
  margin: 0;
}

.res-videos-dots {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
}
.res-videos-dots .dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--brand-teal);
  display: inline-block;
}
.res-videos-dots .dot.active {
  width: 20px;
  height: 20px;
  background: var(--brand-navy);
  border: 2px solid var(--brand-teal);
  position: relative;
}
.res-videos-dots .dot.active::after {
  content: "";
  position: absolute;
  inset: 3px;
  border-radius: 50%;
  background: var(--brand-teal);
}

@media (max-width: 991px) {
  .res-videos-grid { grid-template-columns: 1fr; max-width: 460px; margin: 0 auto 30px; }
  .res-videos-title { font-size: 34px; }
}

/* ============================================================
   Resources — Section 4: Events (499:25283)
   ============================================================ */
.res-events-section {
  background: #f4f7fa;
  padding: 100px 0;
}
.res-events-heading {
  max-width: 760px;
  margin: 0 0 50px;
  text-align: left;
}
.res-events-eyebrow {
  display: block;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.18em;
  color: var(--brand-teal);
  text-transform: uppercase;
  margin-bottom: 14px;
}
.res-events-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(36px, 4.6vw, 56px);
  line-height: 1.1;
  letter-spacing: -0.025em;
  color: var(--brand-charcoal);
  margin: 0 0 14px;
}
.res-events-desc {
  font-size: 18px;
  line-height: 1.45;
  color: var(--brand-charcoal);
  margin: 0;
}

.res-events-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  margin-bottom: 40px;
}
.res-event-card {
  display: flex;
  flex-direction: column;
}
.res-event-media {
  position: relative;
  aspect-ratio: 420 / 290;
  overflow: hidden;
}
.res-event-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* Glass date badge top-left */
.res-event-date {
  position: absolute;
  top: 15px;
  left: 15px;
  background: rgba(247,247,247,0.10);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: 14px 18px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  z-index: 2;
}
.res-event-date .day {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 28px;
  line-height: 1;
  letter-spacing: -0.03em;
  color: #f7f7f7;
}
.res-event-date .mon {
  font-family: var(--font-sans);
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #a9b0b8;
  font-weight: 500;
}
.res-event-body {
  background: #e1e8f0;
  border: 1px solid #ced7e0;
  padding: 28px 26px 30px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  flex: 1;
}
.res-event-meta {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  gap: 14px;
  font-size: 13px;
  color: #676e7a;
  font-family: var(--font-sans);
}
.res-event-meta .tag {
  display: inline-block;
  padding: 5px 12px;
  border: 1px solid #ced7e0;
  border-radius: 40px;
  font-size: 13px;
  color: #676e7a;
  background: transparent;
}
.res-event-body h3 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: #051229;
  margin: 0;
}
.res-event-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 14px;
  color: #051229;
  text-decoration: none;
  cursor: default;
  margin-top: auto;
}
.res-event-link i {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--brand-teal);
  color: #fff;
  font-size: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.res-event-link:hover { color: var(--brand-teal); }

.res-events-dots {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
}
.res-events-dots .dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--brand-teal);
  display: inline-block;
}
.res-events-dots .dot.active {
  width: 20px;
  height: 20px;
  background: #fff;
  border: 2px solid var(--brand-teal);
  position: relative;
}
.res-events-dots .dot.active::after {
  content: "";
  position: absolute;
  inset: 3px;
  border-radius: 50%;
  background: var(--brand-teal);
}

@media (max-width: 991px) {
  .res-events-grid { grid-template-columns: 1fr; max-width: 460px; margin: 0 auto 30px; }
  .res-events-title { font-size: 34px; }
}

/* ============================================================
   Resources — Section 5: Our Mission & Team (437:17343)
   ============================================================ */
.res-team-section {
  background: #e1e8f0;
  padding: 90px 0 100px;
}
.res-team-heading {
  max-width: 760px;
  margin: 0 auto 50px;
}
.res-team-eyebrow {
  display: block;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.18em;
  color: var(--brand-teal);
  text-transform: uppercase;
  margin-bottom: 14px;
}
.res-team-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(36px, 4.6vw, 56px);
  line-height: 1.1;
  letter-spacing: -0.025em;
  color: var(--brand-charcoal);
  margin: 0 0 14px;
}
.res-team-desc {
  font-size: 18px;
  line-height: 1.5;
  color: var(--brand-charcoal);
  margin: 0 auto;
  max-width: 760px;
}

.team-tabs-wrap { position: relative; }

.team-tabs-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  margin-bottom: 0;
}
.team-tab {
  position: relative;
  background: #073149;
  border: 0;
  padding: 0;
  margin: 0;
  cursor: pointer;
  overflow: hidden;
  aspect-ratio: 4 / 5; /* portrait rectangle per review — was near-square 412/420 */
}
.team-tab img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 20%;
  display: block;
  transition: transform .35s ease;
}
.team-tab::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(7,49,73,0.5);
  transition: background .25s ease;
}
.team-tab.active::after { background: rgba(7,49,73,0); }
.team-tab:not(.active):hover::after { background: rgba(7,49,73,0.3); }

/* Triangle arrow below active photo, pointing down into info panel */
.team-tab.active::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -16px;
  transform: translateX(-50%) rotate(45deg);
  width: 30px;
  height: 30px;
  background: #fff;
  z-index: 3;
}

/* Info panel */
.team-tab-info {
  background: #fff;
  padding: 60px;
  margin-top: 30px;
  display: flex;
  align-items: stretch;
  gap: 0;
  position: relative;
}
.team-tab-info[hidden] { display: none; }

.team-info-left {
  position: relative;
  flex: 0 0 360px;
  padding-right: 30px;
  border-right: 1px solid #ced7e0;
  min-height: 380px;
}
.team-info-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 32px;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--brand-charcoal);
  margin: 0 0 6px;
}
.team-info-role {
  display: block;
  font-family: var(--font-sans);
  font-size: 16px;
  color: var(--brand-charcoal);
  margin-bottom: 30px;
}
.team-info-social {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 7px;
}
.team-info-social li a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: #aeb2b9;
  color: #f7f7f7;
  font-size: 14px;
  text-decoration: none;
  cursor: default;
  transition: background .2s ease;
}
.team-info-social li a:hover { background: var(--brand-teal); }
.team-info-shape {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 220px;
  height: 220px;
  opacity: 0.85;
}

.team-info-right {
  flex: 1;
  padding-left: 60px;
}
.team-info-right ul {
  margin: 0;
  padding-left: 22px;
  list-style: disc;
}
.team-info-right ul li {
  font-size: 16px;
  line-height: 1.6;
  color: var(--brand-charcoal);
  margin-bottom: 14px;
}
.team-info-right ul li:last-child { margin-bottom: 0; }
.team-info-right p {
  font-size: 16px;
  line-height: 1.6;
  color: var(--brand-charcoal);
  margin: 0;
}

@media (max-width: 991px) {
  .team-tabs-grid { grid-template-columns: 1fr; gap: 18px; max-width: 460px; margin: 0 auto; }
  .res-team-title { font-size: 34px; }
  .team-tab-info { flex-direction: column; padding: 40px 24px; gap: 24px; }
  .team-info-left { flex: 1; border-right: 0; border-bottom: 1px solid #ced7e0; padding-right: 0; padding-bottom: 24px; min-height: 0; }
  .team-info-right { padding-left: 0; }
  .team-info-shape { position: static; width: 160px; height: 160px; margin-top: 18px; }
}

/* ============================================================
   Home — Diagnose CTA: floating button + click-to-open form
   (Figma 455:4189). Button is in-flow at first; JS pins to
   fixed bottom-right when user scrolls past its original spot
   (within Diagnose section only).
   ============================================================ */
.home-team-cta-wrap {
  position: relative;
  display: inline-block;
}
.home-team-cta-wrap .home-team-cta {
  position: relative;
  z-index: 30;
  transition: none;
}
/* Floating mode — pinned to viewport bottom-right while in Diagnose section */
.home-team-cta-wrap.is-floating {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 100;
  display: inline-block;
}
.home-team-cta-wrap.is-floating .home-team-cta {
  box-shadow: 0 14px 36px rgba(7,49,73,0.25);
}
/* Form popover — toggled via .is-open class only (no hover) */
.home-team-form {
  position: absolute;
  top: calc(100% + 18px);
  right: 0;
  width: 480px;
  max-width: calc(100vw - 40px);
  background: var(--brand-navy);
  border-radius: 12px;
  box-shadow: 0 0 18px rgba(254,103,16,0.5), 0 14px 40px rgba(7,49,73,0.25);
  padding: 28px 30px 26px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: opacity .25s ease, transform .25s ease, visibility .25s;
  z-index: 40;
}
.home-team-form::before {
  content: "";
  position: absolute;
  top: -10px;
  right: 32px;
  width: 18px;
  height: 18px;
  background: var(--brand-navy);
  transform: rotate(45deg);
  box-shadow: -2px -2px 4px rgba(254,103,16,0.18);
}
.home-team-form.is-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
/* Floating mode: form opens upward from bottom-right */
.home-team-cta-wrap.is-floating .home-team-form {
  top: auto;
  bottom: calc(100% + 18px);
  right: 0;
}
.home-team-cta-wrap.is-floating .home-team-form::before {
  top: auto;
  bottom: -10px;
  box-shadow: 2px 2px 4px rgba(254,103,16,0.18);
}
.home-team-form-close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 0;
  background: var(--brand-teal);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 13px;
}
.home-team-form-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 28px;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: #fff;
  margin: 0 0 22px;
}
.home-team-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 26px 22px;
}
.home-team-form-grid .ws-field {
  position: relative;
  border-bottom: 1px solid #676e7a;
  display: flex;
  align-items: center;
  height: 36px;
  padding-right: 26px;
}
.home-team-form-grid .ws-field input {
  width: 100%;
  background: transparent !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
  color: #fff !important;
  font-family: var(--font-sans);
  font-size: 14px;
  height: 34px !important;
  line-height: 34px !important;
  border-radius: 0 !important;
}
.home-team-form-grid .ws-field input::placeholder { color: #a9b0b8; }
.home-team-form-grid .ws-field .ws-field-icon {
  position: absolute;
  right: 4px;
  top: 8px;
  color: #a9b0b8;
  font-size: 14px;
  line-height: 1;
}
.home-team-form-submit {
  grid-column: 1 / -1;
  margin-top: 14px;
  width: 100%;
  background: var(--brand-orange);
  color: #fff;
  border: none;
  border-radius: 999px;
  padding: 16px 30px;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 15px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
.home-team-form-submit:hover { background: #e8550a; }

@media (max-width: 991px) {
  /* In-flow (non-floating) mobile state: button + form stack natively */
  .home-team-cta-wrap:not(.is-floating) .home-team-cta { position: static; }
  .home-team-cta-wrap:not(.is-floating) .home-team-form { position: static; width: 100%; margin-top: 14px; transform: none; }
  .home-team-cta-wrap:not(.is-floating) .home-team-form::before { display: none; }
  /* Floating mode on mobile: keep fixed bottom-right, smaller form opens upward */
  .home-team-cta-wrap.is-floating { right: 16px; bottom: 16px; }
  .home-team-cta-wrap.is-floating .home-team-form { width: calc(100vw - 32px); max-width: 360px; padding: 22px 22px 20px; }
  .home-team-form-grid { grid-template-columns: 1fr; gap: 18px; }
  .home-team-form-title { font-size: 22px; margin-bottom: 14px; }
}

/* ============================================================
   Home — #BuildToDefend stacked-peek carousel
   Center card large & forward; side cards peek behind from L/R
   with smooth slide-on-swap animation.
   ============================================================ */
.home-shield-section {
  background: #fff;
  padding: 80px 0 100px;
  overflow-x: clip;   /* QA: clip side-peek cards so they never add page scroll */
}
.shield-carousel {
  margin: 50px auto 0;
  position: relative;
  max-width: 1100px;
}
/* Track is the absolute-positioning stage */
.shield-track {
  position: relative;
  height: 560px;
  display: block;
  overflow: visible;
}
.shield-card {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 64%;
  height: 100%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  cursor: pointer;
  overflow: hidden;
  border-radius: 14px;
  box-shadow: 0 30px 60px -20px rgba(7,49,73,0.35);
  transform: translate(-50%, -50%) scale(1);
  transition: transform .55s cubic-bezier(.22,.61,.36,1),
              opacity .45s ease,
              filter .45s ease,
              box-shadow .45s ease;
  z-index: 1;
  opacity: 0.55;
  filter: brightness(0.7);
}
/* Center — large, sharp, on top */
.shield-card[data-pos="center"] {
  transform: translate(-50%, -50%) scale(1);
  z-index: 3;
  opacity: 1;
  filter: brightness(1);
  box-shadow: 0 40px 80px -16px rgba(7,49,73,0.45);
}
/* Side cards — slide partially out from behind center */
.shield-card[data-pos="left"] {
  transform: translate(calc(-50% - 38%), -50%) scale(0.86);
  z-index: 2;
}
.shield-card[data-pos="right"] {
  transform: translate(calc(-50% + 38%), -50%) scale(0.86);
  z-index: 2;
}
.shield-card[data-pos="left"]:hover  { transform: translate(calc(-50% - 40%), -50%) scale(0.88); opacity: 0.75; filter: brightness(0.8); }
.shield-card[data-pos="right"]:hover { transform: translate(calc(-50% + 40%), -50%) scale(0.88); opacity: 0.75; filter: brightness(0.8); }

.shield-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(7,49,73,0) 30%, rgba(7,49,73,0.78) 100%);
  pointer-events: none;
}
.shield-card-title {
  position: absolute;
  left: 24px;
  right: 24px;
  bottom: 24px;
  z-index: 2;
  color: #fff;
  background: rgba(7,49,73,0.45);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 0;
  padding: 20px 22px;
}
.shield-card-title h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 28px;
  letter-spacing: -0.02em;
  margin: 0 0 4px;
}
.shield-card-title p {
  font-size: 14px;
  margin: 0;
  opacity: 0.95;
}
.shield-card[data-pos="center"] .shield-card-title h3 { font-size: 36px; }

.shield-dots {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
  margin-top: 40px;
}
.shield-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #ced7e0;
  border: 0;
  padding: 0;
  cursor: pointer;
  transition: background .25s ease, transform .25s ease, width .25s ease;
}
.shield-dot:hover { background: var(--brand-teal); }
.shield-dot.active {
  background: var(--brand-teal);
  width: 28px;
  border-radius: 6px;
}

@media (max-width: 991px) {
  .shield-track { height: 380px; }
  .shield-card { width: 78%; border-radius: 10px; }
  .shield-card[data-pos="left"]  { transform: translate(calc(-50% - 30%), -50%) scale(0.82); }
  .shield-card[data-pos="right"] { transform: translate(calc(-50% + 30%), -50%) scale(0.82); }
  .shield-card-title h3 { font-size: 26px; }
  .shield-card[data-pos="center"] .shield-card-title h3 { font-size: 30px; }
}




/* ============================================================
   Home v4 — Hero (video bg, curved top, Figma 735:12551)
   ============================================================ */
.home-v4-hero {
  position: relative;
  width: 100%;
  min-height: 760px;
  overflow: hidden;
  background: #000;
  /* No gap above hero — header sits over it as absolute white bar */
  margin-top: 0;
  isolation: isolate;
}
.home-v4-hero-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  z-index: 0;
}
.home-v4-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(7,49,73,0.30) 0%, rgba(7,49,73,0.55) 100%);
  z-index: 1;
}
.home-v4-hero > .container {
  position: relative;
  z-index: 2;
}
.home-v4-hero-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 760px;
  padding: 140px 20px 120px;
  text-align: center;
  gap: 28px;
}
.home-v4-hero-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(40px, 5.5vw, 72px);
  line-height: 1.08;
  letter-spacing: -0.025em;
  color: #fff;
  margin: 0;
  max-width: 1100px;
}
.home-v4-hero-subwrap {
  position: relative;
  display: inline-block;
  padding: 22px 44px 28px;
  background: rgba(0, 0, 0, 0.38);
  border-radius: 0;
  max-width: 760px;
}
.home-v4-hero-desc {
  font-family: var(--font-sans);
  font-size: clamp(18px, 1.6vw, 24px);
  line-height: 1.4;
  color: #fff;
  margin: 0 0 14px;
}
.home-v4-hero-tag {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(22px, 2vw, 32px);
  line-height: 1.2;
  color: var(--brand-teal);
  margin: 0;
  font-style: normal;
}

@media (max-width: 991px) {
  .home-v4-hero { min-height: 560px; margin-top: 0; }
  .home-v4-hero::before { height: 60px; }
  .home-v4-hero-inner { min-height: 560px; padding: 100px 16px 80px; gap: 22px; }
  .home-v4-hero-subwrap { padding: 18px 22px 22px; }
}

/* ============================================================
   Floating cluster — Workshop pill + Scroll-to-top (home global)
   ============================================================ */
.home-floating-cluster {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 110;
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 12px;
  pointer-events: none;
  transition: opacity .3s ease, transform .3s ease;
}
.home-floating-cluster > * { pointer-events: auto; }
/* Fade the floating CTA out of the way while the Diagnose deck-stack is in
   view on mobile, so it never covers the bottom of a parallax card. */
.home-floating-cluster.cta-dimmed {
  opacity: 0;
  transform: translateY(26px);
  pointer-events: none;
}
.home-floating-cluster.cta-dimmed > * { pointer-events: none; }

/* Workshop pill — always visible on home (orange, dark arrow circle) */
.home-team-cta-wrap.is-pinned {
  position: relative;
  display: inline-block;
}
.home-team-cta-orange {
  position: relative;
  overflow: hidden;   /* clip the charcoal slide ::before so it can't peek left */
  background: var(--brand-orange) !important;
  color: #fff !important;
  padding: 6px 22px 6px 6px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border-radius: 999px;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: -0.005em;
  box-shadow: 0 14px 36px rgba(7,49,73,0.30);
  text-decoration: none;
  transition: background .2s ease, transform .2s ease;
}
.home-team-cta-orange:hover { background: #e8550a !important; transform: translateY(-1px); }
.home-team-cta-orange .pill-icon {
  background: var(--brand-charcoal);
  color: #fff;
  width: 36px; height: 36px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center; justify-content: center;
  font-size: 14px;
}

/* Form popover opens upward from pinned button */
.home-team-cta-wrap.is-pinned .home-team-form {
  position: absolute;
  bottom: calc(100% + 14px);
  right: -100px;
  top: auto;
  left: auto;
  width: 460px;
  max-width: calc(100vw - 48px);
  transform: translateY(8px);
}
.home-team-cta-wrap.is-pinned .home-team-form::before {
  top: auto;
  bottom: -10px;
  right: 32px;
  box-shadow: 2px 2px 4px rgba(254,103,16,0.18);
}
.home-team-cta-wrap.is-pinned .home-team-form.is-open {
  transform: translateY(0);
}

/* Scroll-to-top — teal, appears only after scroll */
.home-scroll-top {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: var(--brand-teal);
  color: #fff;
  border: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(7,49,73,0.20);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity .25s ease, transform .25s ease, visibility .25s, background .2s ease;
}
.home-scroll-top.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.home-scroll-top:hover { background: #1ea8bb; }

@media (max-width: 991px) {
  .home-floating-cluster { right: 14px; bottom: 14px; gap: 10px; }
  .home-team-cta-orange { padding: 4px 18px 4px 4px; font-size: 13px; }
  .home-team-cta-orange .pill-icon { width: 30px; height: 30px; font-size: 12px; }
  .home-team-cta-wrap.is-pinned .home-team-form { width: calc(100vw - 28px); max-width: 360px; }
  .home-scroll-top { width: 42px; height: 42px; font-size: 16px; }
}

/* ============================================================
   Home v4 — Team section (Figma 352:8406)
   3 white cards w/ circular photo, name, bio, follow icons
   ============================================================ */
.home-team-v4-section {
  background: #e1e8f0;
  padding: 100px 0 120px;
}
.home-team-v4-head {
  margin-bottom: 50px;
  max-width: 900px;
}
.home-team-v4-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(36px, 4.4vw, 48px);
  line-height: 1.15;
  letter-spacing: -0.025em;
  color: var(--brand-charcoal);
  margin: 0 0 18px;
}
.home-team-v4-desc {
  font-family: var(--font-sans);
  font-size: clamp(16px, 1.4vw, 20px);
  line-height: 1.45;
  color: var(--brand-charcoal);
  margin: 0;
}
.home-team-v4-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.home-team-v4-card {
  background: #fff;
  border-radius: 0;
  padding: 42px 31px 36px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  min-height: 670px;
}
.home-team-v4-photo {
  width: min(300px, 100%);   /* shrink with the column so it can't overflow */
  height: auto;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  overflow: hidden;
  background: #e1e8f0;
  margin-bottom: 50px;
  position: relative;
}
.home-team-v4-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.home-team-v4-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 24px;
  line-height: 1.3;
  letter-spacing: -0.02em;
  color: #051229;
  margin: 0 0 14px;
}
.home-team-v4-bio {
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.6;
  color: #364052;
  margin: 0 0 24px;
  flex: 1;
}
.home-team-v4-bio em {
  font-style: italic;
  font-weight: 700;
}
.home-team-v4-follow {
  margin-top: auto;
}
.home-team-v4-follow > span {
  display: block;
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--brand-charcoal);
  margin-bottom: 10px;
}
.home-team-v4-follow ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: center;
  gap: 10px;
}
.home-team-v4-follow li a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: rgba(5,18,41,0.40);
  color: #e1e8f0;
  font-size: 13px;
  text-decoration: none;
  transition: background .2s ease;
}
.home-team-v4-follow li a:hover { background: var(--brand-teal); color: #fff; }

@media (max-width: 991px) {
  .home-team-v4-grid { grid-template-columns: 1fr; max-width: 460px; margin: 0 auto; }
  .home-team-v4-title { font-size: 32px; }
  .home-team-v4-photo { width: 240px; height: 240px; margin-bottom: 30px; }
  .home-team-v4-card { min-height: auto; padding: 32px 22px 28px; }
}

/* ============================================================
   Home v4 — Strategic Diagnosis (Figma 703:16284)
   3 navy cards with image/copy split. Sticky-stack scroll FX.
   ============================================================ */
.home-diag-section {
  background: #fff;
  padding: 80px 0 60px;
  position: relative;
}
/* Faint tech texture over white (Figma 703:16284). Licensed v4 asset
   "Vertically Integrated TP Solutions BG". */
.home-diag-section::after {
  content: "";
  position: absolute;
  inset: 0;
  background: url('images/brand/v2/diag-section-bg.png') top center / 100% 100% no-repeat;
  opacity: 0.75;
  pointer-events: none;
  z-index: 0;
}
.home-diag-section > .container { position: relative; z-index: 1; }
.home-diag-head { margin: 0 auto 40px; max-width: 760px; }
.home-diag-eyebrow {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.22em;
  color: var(--brand-teal);
  text-transform: uppercase;
  margin-bottom: 12px;
}
.home-diag-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(36px, 4.6vw, 56px);
  line-height: 1.1;
  letter-spacing: -0.025em;
  color: var(--brand-charcoal);
  margin: 0 0 18px;
}
.home-diag-desc {
  font-family: var(--font-sans);
  font-size: 18px;
  line-height: 1.5;
  color: var(--brand-charcoal);
  margin: 0 auto;
  max-width: 720px;
}

/* Scroll-driven sticky stack (pure CSS — no JS).
   Ref: web-reference/scrolldriven-animationstack-cards (CodePen ferleonardo/rNEgxGW).
   Each .home-diag-item is sticky; the stack is a view-timeline. As the stack
   scrolls out, each card scales down (by --reverse-index) during its slice of
   the exit phase, producing the deck-stacking depth effect.
   Degrades gracefully: without animation-timeline support, cards still pile
   sticky with a staggered top offset (no scale). */
.home-diag-stack {
  --numcards: 3;
  --diag-card-height: clamp(440px, 60vh, 600px);
  --diag-top-offset: 2.2em;   /* staggered reveal of stacked card tops */
  --diag-gap: 4vw;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: repeat(var(--numcards), var(--diag-card-height));
  gap: var(--diag-gap);
  margin-bottom: 0;
  padding-bottom: calc(var(--numcards) * var(--diag-top-offset));
}
.home-diag-item {
  position: sticky;
  top: 100px;   /* header offset */
  padding-top: calc(var(--index) * var(--diag-top-offset));
}
.home-diag-item:nth-child(1) { --index: 1; }
.home-diag-item:nth-child(2) { --index: 2; }
.home-diag-item:nth-child(3) { --index: 3; }
.home-diag-card {
  height: var(--diag-card-height);
  width: 100%;
  background: var(--brand-navy);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  overflow: hidden;
  border-radius: 0;
  box-shadow: 0 -10px 30px -10px rgba(7,49,73,0.30), 0 30px 60px -20px rgba(7,49,73,0.35);
  transform-origin: 50% 0%;
  will-change: transform;
}
@supports (animation-timeline: view()) {
  .home-diag-stack { view-timeline-name: --diag-cards; }
  .home-diag-item {
    --index0: calc(var(--index) - 1);
    --reverse-index: calc(var(--numcards) - var(--index0));
  }
  .home-diag-card {
    --start-range: calc(var(--index0) / var(--numcards) * 100%);
    --end-range:   calc(var(--index)  / var(--numcards) * 100%);
    animation: diag-card-scale linear forwards;
    animation-timeline: --diag-cards;
    animation-range: exit-crossing var(--start-range) exit-crossing var(--end-range);
  }
  @keyframes diag-card-scale {
    to { transform: scale(calc(1.1 - calc(0.1 * var(--reverse-index)))); }
  }
}

.home-diag-card.layout-image-left .home-diag-media { order: 0; }
.home-diag-card.layout-image-left .home-diag-body  { order: 1; }
.home-diag-card.layout-image-right .home-diag-media { order: 1; }
.home-diag-card.layout-image-right .home-diag-body  { order: 0; }

.home-diag-media {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 480px;
  overflow: hidden;
}
.home-diag-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.home-diag-body {
  padding: 40px;
  display: flex;
  flex-direction: column;
  justify-content: center;   /* vertical centre */
  align-items: center;       /* centre the 440px content block */
  color: #fff;
}
/* Constrain to a centred 440px block (Figma project_content_inner) */
.home-diag-num,
.home-diag-card-title,
.home-diag-body p { width: 100%; max-width: 440px; }
.home-diag-num {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 64px;
  line-height: 1;
  color: rgba(255,255,255,0.20);
  letter-spacing: -0.03em;
  margin-bottom: 18px;
}
.home-diag-card-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(22px, 2.3vw, 30px);
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: #fff;
  margin: 0 0 18px;
  max-width: 460px;
}
.home-diag-body p {
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.6;
  color: rgba(255,255,255,0.78);
  margin: 0;
  max-width: 460px;
}
.home-diag-body p strong { color: #fff; font-weight: 700; }

.home-diag-cta { margin-top: 40px; padding-top: 20px; }

@media (max-width: 991px) {
  /* Keep the desktop scroll-driven sticky-stack effect, but single-column cards
     that GROW to their content (no fixed height = no clipped text). */
  .home-diag-stack {
    --diag-top-offset: 0.85em;   /* smaller stagger = less vertical eaten */
    grid-template-rows: repeat(var(--numcards), auto);
  }
  .home-diag-item { top: 72px; }
  .home-diag-card {
    height: auto;
    grid-template-columns: 1fr;
    grid-template-rows: 108px auto;   /* slim image band, then body grows */
  }
  .home-diag-card.layout-image-right .home-diag-media { order: 0; }
  .home-diag-card.layout-image-right .home-diag-body  { order: 1; }
  .home-diag-media { height: 108px; min-height: 0; }
  .home-diag-body { padding: 16px 18px 18px; justify-content: flex-start; }
  .home-diag-num { font-size: 26px; margin-bottom: 3px; }
  .home-diag-card-title { font-size: 17px; line-height: 1.22; margin-bottom: 7px; }
  .home-diag-body p { font-size: 12.5px; line-height: 1.42; }
}

/* ============================================================
   Home v4 — Solve / TP Intelligence Stack
   Desktop: hex diagram PNG + video in center circle
   Mobile: vertical PNG (no video)
   ============================================================ */
.home-solve-section {
  background: var(--brand-navy);
  padding: 100px 0 120px;
}
.home-solve-head { max-width: 800px; margin: 0 auto 50px; }
.home-solve-eyebrow {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.22em;
  color: var(--brand-teal);
  text-transform: uppercase;
  margin-bottom: 12px;
}
.home-solve-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(36px, 4.6vw, 56px);
  line-height: 1.1;
  letter-spacing: -0.025em;
  color: #fff;
  margin: 0 0 18px;
}
.home-solve-desc {
  font-family: var(--font-sans);
  font-size: 18px;
  line-height: 1.5;
  color: rgba(255,255,255,0.85);
  margin: 0 auto;
  max-width: 720px;
}

.home-solve-diagram {
  position: relative;
  max-width: 1280px;
  margin: 0 auto;
}
.home-solve-desktop-wrap {
  position: relative;
  width: 100%;
  display: block;
}
.home-solve-bg {
  display: block;
  width: 100%;
  height: auto;
}
.home-solve-video {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 11%;
  aspect-ratio: 1 / 1;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  overflow: hidden;
  box-shadow: 0 8px 20px rgba(7,49,73,0.18);
  background: #000;
}
.home-solve-video video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.home-solve-mobile-wrap { display: none; }
.home-solve-mobile { display: block; width: 100%; height: auto; }

@media (max-width: 767px) {
  .home-solve-desktop-wrap { display: none; }
  .home-solve-mobile-wrap {
    display: block;
    position: relative;
    width: 100%;
    max-width: 400px;
    margin: 0 auto;
  }
  /* Video over the empty hub circle at top-left of mobile PNG.
     PNG hub center ≈ (155, 155) of 621×2014 (25% x, 7.7% y). Diameter ≈ 50% w. */
  .home-solve-video-mobile {
    position: absolute;
    top: 7.7%;
    left: 25%;
    transform: translate(-50%, -50%);
    width: 46%;
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    overflow: hidden;
    background: #000;
    /* Thin dark-navy ring hugging the video, mirroring the desktop hub ring */
    box-shadow: 0 0 0 3px #0a2540, 0 6px 14px rgba(7,49,73,0.20);
  }
  .home-solve-video-mobile video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
}
/* SVG connector ring path only — behind pillars + hub */
.home-solve-connector {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 60%;
  max-width: 760px;
  height: auto;
  z-index: 0;
  opacity: 1;
  pointer-events: none;
}
.home-solve-diagram > .solve-pillar,
.home-solve-diagram > .solve-hub { position: relative; z-index: 2; }
/* Place pillars in grid */
.solve-pillar { display: flex; align-items: center; gap: 18px; }
.solve-pillar.p-1 { grid-row: 1; grid-column: 1; justify-content: flex-end; text-align: right; }
.solve-pillar.p-2 { grid-row: 1; grid-column: 3; justify-content: flex-start; text-align: left; }
.solve-pillar.p-3 { grid-row: 2; grid-column: 1; justify-content: flex-end; text-align: right; }
.solve-pillar.p-4 { grid-row: 2; grid-column: 3; justify-content: flex-start; text-align: left; }
.solve-pillar.p-5 { grid-row: 3; grid-column: 1; justify-content: flex-end; text-align: right; }
.solve-pillar.p-6 { grid-row: 3; grid-column: 3; justify-content: flex-start; text-align: left; }

.solve-text { max-width: 340px; }
.solve-pillar-label {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 30px;
  line-height: 1.1;
  letter-spacing: -0.015em;
  margin: 0 0 10px;
}
.solve-pillar p {
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.5;
  color: rgba(255,255,255,0.82);
  margin: 0;
}
.solve-icon-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}
.solve-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 110px;
  height: 110px;
  border-radius: 50%;
  background: currentColor;
  position: relative;
}
.solve-icon img {
  width: 50px;
  height: 50px;
  display: block;
  /* SVG icons are dark — force white via filter */
  filter: brightness(0) invert(1);
}
.solve-num {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  color: #fff;
  line-height: 1;
  opacity: 0.85;
}

/* Per-pillar accent colors */
.solve-pillar.p-1 .solve-pillar-label { color: var(--pillar-1); }
.solve-pillar.p-1 .solve-icon { color: var(--pillar-1); }
.solve-pillar.p-2 .solve-pillar-label { color: var(--pillar-2); }
.solve-pillar.p-2 .solve-icon { color: var(--pillar-2); }
.solve-pillar.p-3 .solve-pillar-label { color: var(--pillar-3); }
.solve-pillar.p-3 .solve-icon { color: var(--pillar-3); }
.solve-pillar.p-4 .solve-pillar-label { color: var(--pillar-4); }
.solve-pillar.p-4 .solve-icon { color: var(--pillar-4); }
.solve-pillar.p-5 .solve-pillar-label { color: var(--pillar-5); }
.solve-pillar.p-5 .solve-icon { color: var(--pillar-5); }
.solve-pillar.p-6 .solve-pillar-label { color: var(--pillar-6); }
.solve-pillar.p-6 .solve-icon { color: var(--pillar-6); }

/* Center hub — small ring around video */
.solve-hub {
  grid-row: 1 / span 3;
  grid-column: 2;
  display: flex;
  align-items: center;
  justify-content: center;
}
.solve-hub-ring {
  width: 260px;
  height: 260px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.12);
  padding: 22px;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.02);
}
.solve-hub-video {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  overflow: hidden;
  position: relative;
}
.solve-hub-video video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.home-solve-cta { margin-top: 60px; }

@media (max-width: 991px) {
  .home-solve-diagram {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    gap: 24px;
  }
  .solve-pillar.p-1, .solve-pillar.p-3, .solve-pillar.p-5,
  .solve-pillar.p-2, .solve-pillar.p-4, .solve-pillar.p-6 {
    grid-column: 1;
    grid-row: auto;
    justify-content: flex-start;
    text-align: left;
    flex-direction: row;
  }
  .solve-pillar.p-1 { grid-row: 1; }
  .solve-hub { grid-row: 2; grid-column: 1; }
  .solve-pillar.p-2 { grid-row: 3; }
  .solve-pillar.p-3 { grid-row: 4; }
  .solve-pillar.p-4 { grid-row: 5; }
  .solve-pillar.p-5 { grid-row: 6; }
  .solve-pillar.p-6 { grid-row: 7; }
  .solve-pillar { flex-direction: row !important; }
  .solve-icon-wrap { order: 0; }
  .solve-text { order: 1; }
  .solve-icon { width: 80px; height: 80px; }
  .solve-icon img { width: 36px; height: 36px; }
  .solve-pillar-label { font-size: 24px; }
  .solve-hub-ring { width: 200px; height: 200px; padding: 16px; }
}

/* ============================================================
   Global button hover slide effect.
   The .pill-icon background color slides from left → right
   filling the whole button. Label color inverts to icon's color.
   ============================================================ */
.btn-pill,
.header-workshop-cta,
.footer-workshop-cta {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.btn-pill::before,
.header-workshop-cta::before,
.footer-workshop-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  transform: translateX(-101%);
  transition: transform .45s cubic-bezier(.22,.61,.36,1);
  z-index: -1;
}
.btn-pill:hover::before,
.header-workshop-cta:hover::before,
.footer-workshop-cta:hover::before {
  transform: translateX(0);
}

/* Per-variant slide colors — match the pill-icon background */
.btn-pill.btn-sky::before          { background: var(--brand-navy); }
.btn-pill.btn-sky:hover            { color: #fff; }
.btn-pill.btn-sky:hover .pill-icon { background: var(--brand-sky); color: var(--brand-navy); }

.btn-pill.btn-outline::before          { background: var(--brand-navy); }
.btn-pill.btn-outline:hover            { color: #fff; border-color: var(--brand-navy); }
.btn-pill.btn-outline:hover .pill-icon { background: #fff; color: var(--brand-navy); }

.btn-pill.btn-dark::before          { background: var(--brand-teal); }
.btn-pill.btn-dark:hover            { color: #fff; }
.btn-pill.btn-dark:hover .pill-icon { background: #fff; color: var(--brand-teal); }

.btn-pill.btn-white::before          { background: var(--brand-teal); }
.btn-pill.btn-white:hover            { color: #fff; }
.btn-pill.btn-white:hover .pill-icon { background: #fff; color: var(--brand-teal); }

.btn-pill.btn-orange::before          { background: #fff; }
.btn-pill.btn-orange:hover            { color: var(--brand-orange); }
.btn-pill.btn-orange:hover .pill-icon { background: var(--brand-orange); color: #fff; }

/* Sticky workshop pill (orange bg → dark slide) */
/* Floating CTA: no slide overlay — it was leaking a grey sliver left of the
   pill on some mobile widths. Plain orange + darken-on-hover instead. */
.home-team-cta-orange::before { display: none !important; }
.home-team-cta-orange:hover { color: #fff !important; }
.home-team-cta-orange:hover .pill-icon { background: var(--brand-orange); color: #fff; }

/* Header CTA dark → orange */
.header-workshop-cta::before { background: var(--brand-orange); }
.header-workshop-cta:hover { color: #fff !important; }
.header-workshop-cta:hover .pill-icon { background: #fff; color: var(--brand-orange); }

/* Footer CTA white → orange */
.footer-workshop-cta::before { background: var(--brand-orange); }
.footer-workshop-cta:hover { color: #fff !important; }
.footer-workshop-cta:hover .pill-icon { background: #fff; color: var(--brand-orange); }

/* Pill-icon color transition for smooth swap */
.btn-pill .pill-icon,
.header-workshop-cta .pill-icon,
.footer-workshop-cta .pill-icon {
  transition: background .3s ease, color .3s ease;
}

/* ============================================================
   Sticky "Request your FREE Workshop" — soft pulse glow
   ============================================================ */
@keyframes pulse-cta {
  0%, 100% { box-shadow: 0 0 0 0 rgba(254,103,16,0.55), 0 14px 36px rgba(7,49,73,0.30); }
  70%      { box-shadow: 0 0 0 16px rgba(254,103,16,0),  0 14px 36px rgba(7,49,73,0.30); }
}
.home-team-cta-wrap.is-pinned .home-team-cta-orange {
  animation: pulse-cta 2.4s ease-in-out infinite;
}
.home-team-cta-wrap.is-pinned .home-team-cta-orange:hover {
  animation-play-state: paused;
}

/* ============================================================
   QA-PASS-1 — Designer QA feedback (May 2026)
   Source: /Users/yatingodse/Downloads/Homepage - Design QA.pdf
   Tokens: --bg-soft #E1E8F0, --bg-card-light #F7F7F7, --footer-dark #333134
   ============================================================ */
:root {
  --bg-soft: #E1E8F0;
  --bg-card-light: #F7F7F7;
  --footer-dark: #333134;
}

/* --- Menu font 18px (desktop nav) ----------------------------- */
.tj-header-area .mainmenu > ul > li > a { font-size: 18px; }
/* Selected/active menu item — larger (Figma 24px) */
.tj-header-area .mainmenu > ul > li.active > a { font-size: 24px; line-height: 1; }

/* --- Header CTA + grid icon over dark hero (sticky duplicate) -- */
.header-sticky .header-workshop-cta {
  background: #fff !important;
  color: var(--brand-charcoal) !important;
}
.header-sticky .header-workshop-cta::before { background: var(--brand-orange); }
.header-sticky .header-workshop-cta:hover { color: #fff !important; }
.header-sticky .header-workshop-cta .pill-icon {
  background: var(--brand-orange);
  color: #fff;
}
.header-sticky .header-grid-icon { color: #fff; }

/* --- Hero curves top + bottom (per reference figma-home-proper) - */
.home-v4-hero { isolation: isolate; overflow: visible !important; }
.home-v4-hero-video { z-index: 0; }
.home-v4-hero-overlay { z-index: 1; }
/* Header: visible divider line below menu + gentle curve dipping into hero */
.tj-header-area.header-absolute .header-bottom {
  position: relative;
  border-bottom: none !important;
  /* Clip the curve's 4% horizontal bleed (width:108%) so it can't cause a
     page-wide horizontal scroll; vertical (downward) curve stays visible. */
  overflow-x: clip;
}
/* Divider line as a separate pseudo, stacked above the curve so it's visible */
.tj-header-area.header-absolute .header-bottom::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: rgba(7,49,73,0.28);
  z-index: 4;
  pointer-events: none;
}
/* Header curve — home page only. Gentle full-width white arc so the video
   starts AFTER the curve across the whole width (a small vertical radius keeps
   the skirt present at the edges instead of curling up to zero). */
.is-home .tj-header-area.header-absolute .header-bottom::after {
  content: "";
  position: absolute;
  top: 100%;
  left: -4%;
  width: 108%;
  height: 46px;
  background: #fff;
  border-radius: 0 0 50% 50% / 0 0 30px 30px;
  pointer-events: none;
  z-index: 1;
}
/* Cancel old hero pseudo curves (now on header) */
.home-v4-hero::before { content: none !important; }
.home-v4-hero::after { content: none !important; }
.home-v4-hero-inner { padding-top: 200px; }
.home-v4-hero-tag {
  font-weight: 400;
  font-style: normal;
  font-size: clamp(24px, 2.2vw, 36px);
  font-family: var(--font-display);
  color: var(--brand-teal);
}
/* Bottom curve = stats strip arcs upward over hero */
.home-v3-stats {
  position: relative;
  z-index: 10;
  margin-top: -96px;
  padding: 120px 0 60px;
  /* Smooth elliptical dome top (replaces the jagged polygon tent) */
  clip-path: none;
  border-radius: 50% 50% 0 0 / 96px 96px 0 0;
}
@media (max-width: 991px) {
  .is-home .tj-header-area.header-absolute .header-bottom::after { height: 24px; }
  .home-v4-hero-inner { padding-top: 80px; padding-bottom: 40px; }
  /* Polygon arc becomes a sharp tent on narrow screens — swap for a smooth
     elliptical dome top. */
  .home-v3-stats {
    margin-top: -48px;
    padding: 64px 0 40px;
    clip-path: none;
    border-radius: 50% 50% 0 0 / 46px 46px 0 0;
  }
}

/* --- Stats band: teal + v4 wave (AI-Native Intelligence Stack BG),
   wave multiply-blended so the teal brand colour stays. ------------- */
.home-v3-stats {
  padding: 60px 0;
  background-color: #27bfd4;
  background-image: url('images/brand/v2/solve-section-bg.png');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-blend-mode: multiply;
}
.home-v3-stat-card .stat-label {
  font-size: clamp(26px, 2.8vw, 36px);
  font-weight: 600;
  line-height: 1.18;
  color: #fff;
}

/* --- Team v4: outer ring on portraits, section bg ------------ */
.home-team-v4-section {
  background: #e1e8f0;   /* Figma 352:8406 — bg-soft, not near-white */
  padding-top: 90px;
  padding-bottom: 90px;
}
.home-team-v4-photo {
  border: 10px solid #e0e8f0;
  border-radius: 50%;
  padding: 0;
  background: #d7e1eb;
  box-shadow: none;
  box-sizing: border-box;
  overflow: hidden;
}
.home-team-v4-photo img {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
  object-position: center top;
}
@media (max-width: 991px) {
  .home-team-v4-section { padding-top: 40px; padding-bottom: 40px; }
}

/* --- Diagnose: bigger fonts, faded 01 ------------------------ */
.home-diag-eyebrow { font-size: 18px; letter-spacing: 0.24em; }
.home-diag-title { font-size: clamp(34px, 4vw, 48px); }   /* Figma 48px */
.home-diag-desc { font-size: 18px; line-height: 1.44; }    /* Figma 18/26 */
/* Figma 703:16284 — num 88, title 32/38.4, desc 16/25.6 */
.home-diag-num {
  color: rgba(247,247,247,0.10) !important;
  font-size: 88px;
  margin-bottom: 10px;
}
.home-diag-card-title { font-size: 32px; line-height: 38.4px; margin-bottom: 10px; }
.home-diag-body p { font-size: 16px; line-height: 25.6px; color: #a9b0b8; }

/* --- Solve: Read More pill → white bg ------------------------ */
.home-solve-cta .btn-pill {
  background: #fff !important;
  color: var(--brand-charcoal) !important;
}
.home-solve-cta .btn-pill::before { background: var(--brand-teal); }
.home-solve-cta .btn-pill:hover { color: #fff !important; }
.home-solve-cta .btn-pill .pill-icon {
  background: var(--brand-teal);
  color: #fff;
}
.home-solve-cta .btn-pill:hover .pill-icon { background: #fff; color: var(--brand-teal); }

/* --- Shield slider: glass cards, no border, sharp, light bg -- */
.home-shield-section {
  background: var(--bg-soft);
  padding: 100px 0 110px;
}
.home-shield-section .sec-title { color: #fff; }
.home-shield-section .sec-title,
.home-shield-section .sec-desc { color: var(--brand-charcoal); }
.shield-card {
  border-radius: 0 !important;
  border: none !important;
  width: 60%;
}
.shield-card[data-pos="left"]  { transform: translate(calc(-50% - 36%), -50%) scale(0.88); }
.shield-card[data-pos="right"] { transform: translate(calc(-50% + 36%), -50%) scale(0.88); }
/* Responsive track: height tracks width so the centre card always keeps the
   source image's 1.38 aspect — no side/top crop at any viewport.
   centre card = 60% width, aspect 1.376 → height = 0.60/1.376 = 0.436 × trackW
   → track aspect-ratio = 1 / 0.436 ≈ 2.29. */
.shield-track { height: auto; aspect-ratio: 2.29; max-height: 520px; }
.shield-card { background-position: center; background-size: cover; }
.shield-card-title {
  background: rgba(255,255,255,0.10) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  border: none !important;
  border-radius: 0 !important;
  color: #fff;
}
.shield-card-title h3 { color: #fff; }
.shield-dot {
  width: 8px;
  height: 8px;
  background: rgba(7,49,73,0.20);
}
.shield-dot.active {
  background: var(--brand-teal);
  width: 8px;
  border-radius: 50%;
  transform: scale(1.4);
}

/* --- Transform: bigger fonts, white icon circle + dark glyph - */
.home-roadmap-v3 .sec-title { font-size: clamp(42px, 4.4vw, 60px); }
.home-roadmap-v3 .sec-desc { font-size: 17px; }
.roadmap-phase .title { font-size: 26px; }
.roadmap-phase p { font-size: 15px; }
.roadmap-icon { background: #ffffff !important; }
.roadmap-icon img {
  filter: brightness(0) saturate(100%);
  width: 30px;
  height: 30px;
  opacity: 0.85;
}

/* --- Workshop Strategic Foundation: bigger, bg soft, card lt - */
.home-workshop-v2 { background: var(--bg-soft) !important; }
.home-workshop-v2 .sec-title { font-size: clamp(38px, 4.4vw, 58px); }
.home-workshop-v2 .agenda-title { font-size: clamp(28px, 2.6vw, 36px); }
.home-workshop-v2 .agenda-intro { font-size: 16px; }
.agenda-card { background: var(--bg-card-light) !important; }

/* --- Exclusive Deliverables: bg, taller boxes, 40px padding -- */
.home-deliverables-v2 { background: var(--bg-soft) !important; padding-top: 100px; padding-bottom: 100px; }
/* Deliverables heading matches The Workshop Agenda title */
.home-deliverables-v2 .sec-title { font-size: clamp(28px, 2.6vw, 36px); letter-spacing: -0.025em; }
.home-deliv-card {
  aspect-ratio: auto;
  min-height: 640px;
  padding: 40px;
}
.home-deliv-box { padding: 40px; }

/* --- Who Should Attend: teal banner per Figma 352:9207 ------- */
.home-attend-v3 { background: var(--bg-soft) !important; padding: 80px 0; }
/* Teal banner + flowing-curve overlay (exact Figma asset), blended via
   background-blend-mode so the curves multiply only over the teal fill. */
.home-attend-v3 .home-attend-panel {
  background-color: var(--brand-teal);
  background-image: url('images/brand/v2/attend-bg-full.png');
  background-size: 100% 100%;
  background-repeat: no-repeat;
  background-position: center;
  background-blend-mode: multiply;
  box-shadow: 0 18px 50px rgba(39,191,212,0.30);
  padding: 60px 40px;
}
.home-attend-v3 .home-attend-panel::before,
.home-attend-v3 .home-attend-panel::after { display: none; }

/* --- Blogs: bigger fonts -------------------------------------- */
.home-blogs-section { padding-top: 90px; padding-bottom: 90px; }
.home-blogs-section .sec-title { font-size: clamp(38px, 4.4vw, 58px); }
.home-blogs-section .sec-desc { font-size: 17px; }
/* Date box: solid navy — the old frosted-glass version was unreadable on
   light cover images (CMS covers are mostly white). */
.blog-card-date,
.blog-card-img-top .blog-card-date {
  background: var(--brand-navy) !important;
  border: none;
  color: #ffffff;
}
.blog-card-date strong { color: #ffffff; }
.blog-card-date span { color: #8cd5ff; }

/* --- Footer: connect band #333134, footer-middle #F7F7F7 ----- */
.h6-footer.tj-footer-area { background: var(--footer-dark) !important; }
.h6-footer .h6-footer-top {
  background: var(--footer-dark);
  padding-top: 0;            /* form panel reaches the very top — no gap */
  padding-bottom: 0;
  border-bottom: 1px solid rgba(255,255,255,0.10);
}
/* Figma 352:9215 — title at top, divider + address pushed to bottom */
.h6-footer .h6-footer-top .row { align-items: stretch; }
/* Figma 352:9240 — frosted glass form panel, flush to top */
.h6-footer .h6-footer-top .contact-form-one {
  background: rgba(247,247,247,0.10);
  -webkit-backdrop-filter: blur(5px);
  backdrop-filter: blur(5px);
  padding: 70px 38px 60px;
  height: 100%;
}
.h6-footer .connect-left {
  padding-top: 70px;         /* top spacing lives in the left column now */
  padding-right: 30px;
  min-height: 540px;
  padding-bottom: 0;         /* map attached to the bottom of the column */
}
.h6-footer .connect-title { margin-bottom: 0; font-size: clamp(46px, 5vw, 68px); }
/* Push the map to the bottom of the column so it bottom-aligns with the form. */
.h6-footer .connect-map { margin-top: auto; }
.h6-footer .connect-divider {
  margin-top: auto;          /* push line + address down to lower area */
  margin-bottom: 28px;
  max-width: 100%;
  background: #474548;       /* Figma divider colour */
}
.h6-footer .connect-address { padding-bottom: 0; gap: 6px; }
.h6-footer .connect-label {
  color: #676e7a; font-size: 14px; letter-spacing: 0; text-transform: none;
}
.h6-footer .connect-address p { font-size: 16px; line-height: 1.6; color: #a9b0b8; }
.h6-footer .connect-address a { font-size: 16px; color: #f7f7f7; }
.h6-footer .connect-address .footer-phone { display: none; }
.h6-footer .connect-address strong,
.h6-footer .connect-address p strong { font-weight: 700; color: #fff; }
.h6-footer .h6-footer-middle {
  background: var(--footer-dark);
  border-top: none;
  padding: 28px 0;
}
.h6-footer .h6-footer-middle .h6-footer-logo .footer-logo img { filter: none; }
.h6-footer .h6-footer-menu ul li a { color: #f7f7f7 !important; }
.h6-footer .h6-footer-menu ul li::before,
.h6-footer .h6-footer-menu ul li:not(:first-child)::before { background: var(--brand-navy); }
.h6-footer .footer-workshop-cta { color: var(--brand-charcoal); }
/* Copyright bar: subtle lighten over charcoal (Figma rgba(247,247,247,0.1)) */
.h6-footer .footer-copyright-area {
  background: rgba(247,247,247,0.10);
  border-top: none;
  color: #a9b0b8;
}
.h6-footer .copyright-text p,
.h6-footer .copyright-content-area .copyright-menu ul li a {
  color: #a9b0b8 !important;
}
.h6-footer .copyright-text p strong { font-weight: 700; color: #f7f7f7; }
/* Social pills: light circle, dark glyph */
.h6-footer .copyright-socails ul li a {
  background: rgba(247,247,247,0.30);
  color: var(--brand-charcoal) !important;
}

/* --- Mobile sweep -------------------------------------------- */
@media (max-width: 991px) {
  /* Kill phantom horizontal scroll on mobile. Use clip (NOT hidden) so it does
     not create a scroll container — keeps position:sticky working for the
     mobile deck-stack parallax sections. */
  html, body { overflow-x: clip; max-width: 100%; }
  /* Floating cluster: center the orange CTA cluster */
  .home-floating-cluster {
    left: 50%;
    right: auto;
    transform: translateX(-50%);
    justify-content: center;
    flex-wrap: nowrap;
    width: max-content;
    max-width: calc(100vw - 32px);
  }
  /* Stop the "black blob" — kill the .is-pinned ::before halo on mobile */
  .home-team-cta-wrap.is-pinned::before { display: none !important; }
  /* Shield heading: shrink so the unbreakable #BuildToDefend word fits 1 line */
  .home-shield-section .sec-title { font-size: 30px; letter-spacing: -0.01em; }
  /* Shield slider: responsive aspect so the 70%-wide centre card keeps 1.38
     (0.70/1.376 = 0.509 → track aspect 1/0.509 ≈ 1.97). */
  .shield-track { height: auto; aspect-ratio: 1.97; max-height: 460px; }
  .shield-card { width: 70%; border-radius: 0; }
  .shield-card-title {
    background: rgba(255,255,255,0.10) !important;
    backdrop-filter: blur(10px) !important;
  }
  /* Transform: horizontal swipe carousel */
  .home-roadmap-grid {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    gap: 16px;
    padding-bottom: 12px;
    -webkit-overflow-scrolling: touch;
  }
  .home-roadmap-grid > [class*=col-] {
    flex: 0 0 84%;
    max-width: 84%;
    scroll-snap-align: center;
  }
  /* Agenda: equal L/R padding */
  .agenda-card { padding: 24px 22px !important; margin: 0; }
  /* Who Should Attend CTA center */
  .home-attend-v3 .home-attend-panel { padding: 56px 22px; }
  .home-attend-v3 .home-attend-panel .btn-pill { margin: 0 auto; display: inline-flex; }
  /* Footer middle: stack column, center */
  .footer-middle-row {
    flex-direction: column !important;
    align-items: center !important;
    gap: 22px !important;
  }
  .h6-footer .h6-footer-menu ul {
    flex-wrap: wrap !important;
    justify-content: center !important;
    column-gap: 24px !important;
    row-gap: 8px !important;
  }
  /* Footer top: tighter padding on mobile */
  .h6-footer .h6-footer-top { padding-top: 60px; }
  .h6-footer .h6-footer-top .contact-form-one { padding-bottom: 20px; }
}

/* ============================================================
   QA-PASS-2 — round 2 designer feedback
   ============================================================ */
/* Solve: thinner ring around center video (larger video = less PNG ring shows) */
.home-solve-video {
  width: 14%;
  box-shadow: 0 6px 16px rgba(0,0,0,0.30);
  background: transparent;
}

/* Defend slider: more transparent text panel */
.shield-card-title {
  background: rgba(255,255,255,0.05) !important;
  backdrop-filter: blur(6px) !important;
  -webkit-backdrop-filter: blur(6px) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
}

/* Continuous gray band: Workshop Foundation → Deliverables → Who Should Attend */
.home-workshop-v2,
.home-deliverables-v2,
.home-attend-v3 {
  background: var(--bg-soft) !important;
}
/* Tighten gaps between the 3 sections so band reads as one continuous panel */
.home-workshop-v2 { padding-bottom: 40px; }
.home-deliverables-v2 { padding-top: 20px; padding-bottom: 60px; }
.home-attend-v3 { padding: 40px 0 80px; }

/* Floating workshop popup: re-anchor so it doesn't go off-screen
   when cluster centers on mobile or sits at right on desktop */
.home-team-cta-wrap.is-pinned .home-team-form {
  right: 0;
  left: auto;
}
@media (max-width: 991px) {
  .home-team-cta-wrap.is-pinned .home-team-form {
    left: 50%;
    right: auto;
    transform: translate(-50%, 8px);
    width: min(360px, calc(100vw - 28px));
  }
  .home-team-cta-wrap.is-pinned .home-team-form.is-open {
    transform: translate(-50%, 0);
  }
  .home-team-cta-wrap.is-pinned .home-team-form::before {
    right: auto;
    left: 50%;
    transform: translateX(-50%) rotate(45deg);
  }
}

/* ============================================================
   QA-PASS-3 — FREE Diagnostic Workshop popup (Figma 455:6948)
   ============================================================ */
.home-team-form {
  width: 557px;
  max-width: calc(100vw - 32px);
  background: #0a2540;
  border-radius: 30px;
  padding: 50px 35px 40px;
  box-shadow: 0 0 7.5px rgba(254,103,16,0.60), 0 22px 50px rgba(7,49,73,0.45);
  overflow: visible;
}
.home-team-form-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 32px;
  line-height: 1.18;
  letter-spacing: -0.013em;
  color: #fff;
  margin: 0 0 28px;
  max-width: 460px;
}
.home-team-form-close {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--brand-teal);
  color: #fff;
  border: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  cursor: pointer;
  transition: background .2s ease, transform .2s ease;
}
.home-team-form-close:hover { background: #1ea8bb; transform: scale(1.06); }
.home-team-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px 36px;
}
.home-team-form-grid .ws-field {
  position: relative;
  border-bottom: 1px solid #676e7a;
  height: 40px;
  padding-right: 24px;
}
.home-team-form-grid .ws-field input {
  font-family: var(--font-sans) !important;
  font-size: 16px !important;
  height: 38px !important;
  line-height: 38px !important;
  color: #fff !important;
}
.home-team-form-grid .ws-field input::placeholder { color: #a9b0b8; opacity: 1; }
.home-team-form-grid .ws-field .ws-field-icon {
  position: absolute;
  right: 4px;
  top: 50%;
  transform: translateY(-50%);
  color: #a9b0b8;
  font-size: 16px;
  pointer-events: none;
}
.home-team-form-submit {
  grid-column: 1 / -1;
  margin: 18px 0 0;
  height: 56px;
  padding: 0 30px;
  background: var(--brand-orange);
  color: #fff;
  border: none;
  border-radius: 30px;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 16px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  transition: background .2s ease, transform .2s ease;
}
.home-team-form-submit:hover { background: #e8550a; transform: translateY(-1px); }
.home-team-form-submit i { font-size: 14px; }

/* Bottom-center tail pointing down toward CTA */
.home-team-cta-wrap.is-pinned .home-team-form::before {
  content: "";
  position: absolute;
  bottom: -10px;
  left: auto;
  right: 112px;          /* sit above the CTA (form is right-aligned now) */
  top: auto;
  width: 20px;
  height: 20px;
  background: #0a2540;
  transform: rotate(45deg);
  box-shadow: 4px 4px 6px rgba(254,103,16,0.20);
  z-index: -1;
}

/* Center the pinned popup over CTA cluster (desktop + mobile) */
/* Right-align the popover so it opens leftward and never spills past the
   viewport (the CTA sits at the far-right, so left:50% overflowed). */
.home-team-cta-wrap.is-pinned .home-team-form {
  bottom: calc(100% + 18px);
  left: auto;
  right: 0;
  transform: translate(0, 8px);
}
.home-team-cta-wrap.is-pinned .home-team-form.is-open {
  transform: translate(0, 0);
}

/* Mobile: anchor popover to the VIEWPORT (not the pill, which sits inset
   from the right edge behind the scroll-top button) so it never clips left. */
@media (max-width: 991px) {
  .home-team-cta-wrap.is-pinned .home-team-form {
    position: fixed;
    left: 50%;
    right: auto;
    bottom: 88px;
    transform: translate(-50%, 8px);
    width: min(360px, calc(100vw - 24px));
  }
  .home-team-cta-wrap.is-pinned .home-team-form.is-open {
    transform: translate(-50%, 0);
  }
  .home-team-cta-wrap.is-pinned .home-team-form::before { display: none; }
}

@media (max-width: 991px) {
  .home-team-form { padding: 40px 24px 30px; border-radius: 24px; }
  .home-team-form-title { font-size: 24px; margin-bottom: 22px; }
  .home-team-form-grid { grid-template-columns: 1fr; gap: 22px; }
  .home-team-form-submit { height: 52px; font-size: 15px; }
}

/* ============================================================
   #BuiltToDefend — MOBILE: full-card swipe slider
   Replaces the desktop deck-of-cards peek (which clipped the side
   cards to unreadable slivers below ~992px). One portrait card per
   view, native scroll-snap swipe, a sliver of the next peeks, dots
   sync via IntersectionObserver (initShieldMobile in infer360.js).
   ============================================================ */
@media (max-width: 991px) {
  .shield-track {
    height: auto !important;
    aspect-ratio: auto !important;
    max-height: none !important;
    display: flex !important;
    gap: 14px;
    overflow-x: auto;
    overflow-y: visible;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding: 4px 0 8px;
    scrollbar-width: none;
  }
  .shield-track::-webkit-scrollbar { display: none; }

  .shield-card,
  .shield-card[data-pos] {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    flex: 0 0 84vw;
    width: 84vw !important;
    height: auto !important;
    aspect-ratio: 3 / 4;
    transform: none !important;
    opacity: 1 !important;
    filter: none !important;
    scroll-snap-align: center;
    border-radius: 16px !important;
    box-shadow: 0 18px 40px -16px rgba(7,49,73,0.45);
  }
  .shield-card:first-child { margin-left: 8vw; }
  .shield-card:last-child  { margin-right: 8vw; }

  /* Active card pops slightly forward */
  .shield-card.active {
    box-shadow: 0 24px 52px -14px rgba(7,49,73,0.55);
  }

  .shield-card-title { left: 16px; right: 16px; bottom: 16px; padding: 18px 18px; }
  .shield-card-title h3,
  .shield-card[data-pos] .shield-card-title h3,
  .shield-card[data-pos="center"] .shield-card-title h3 { font-size: 26px !important; }
  .shield-card-title p { font-size: 13.5px; }

  .shield-dots { margin-top: 22px; }
}

/* ============================================================
   QA mobile-spacing pass — trim hero top gap, kill footer map dead space,
   contain blog-grid gutter overflow. (header bar ≈ 71px tall on mobile)
   ============================================================ */
@media (max-width: 991px) {
  /* Subpage heroes: oversized top padding left a big empty band under the
     absolute header. Normalise to ~header + 30px breathing room. */
  .fw-hero-section    { padding-top: 104px; }
  .is-vti-section     { padding-top: 112px; }
  .ws-hero-section    { padding-top: 104px; }
  .diagnose-page-hero { padding-top: 104px; }
  .fw360-vca-section  { padding-top: 104px; }
  .res-hero-section   { padding-top: 104px; }

  /* Footer "Let's connect": the left column is now map-only (divider/address
     removed), so the desktop min-height that matched the form panel just
     produced ~270px of dead space below the map when stacked. Collapse it. */
  .h6-footer .connect-left {
    min-height: 0;
    padding-top: 6px;
    padding-bottom: 26px;
    padding-left: 0;
    padding-right: 0;          /* equal left/right page-edge gap for the map */
  }
  /* Mobile: map stretches full content width with equal side gaps + gap below
     "Let's connect" (override the desktop margin-top:auto). */
  .h6-footer .connect-title { margin-bottom: 28px; }
  .h6-footer .connect-map { margin: 0 auto; max-width: none; }

  /* Learn blog grid: 30px Bootstrap gutter (-15px row margins) overran the
     12px container padding by ~6px → hairline horizontal overflow. */
  .res-blogs-grid { --bs-gutter-x: 24px; }
}

/* ============================================================
   DESIGN QA v2 — Batch 1: mobile type scale ("apply to all sections")
   Normalises section eyebrow / title / deck-number / card-title sizes
   on phones. Hero titles intentionally excluded (own scale).
   ============================================================ */
@media (max-width: 767px) {
  /* Section eyebrow → 16px */
  .sub-title,
  .sec-eyebrow,
  .home-diag-eyebrow,
  .home-solve-eyebrow,
  .fw360-vca-eyebrow,
  .fw-tp-eyebrow,
  .is-eyebrow,
  .is-vti-eyebrow,
  .is-slide-eyebrow,
  .res-team-eyebrow,
  .res-videos-eyebrow,
  .res-events-eyebrow {
    font-size: 16px !important;
    line-height: 1.2;
  }

  /* Section title → 30px */
  .sec-title,
  .home-diag-title,
  .home-solve-title,
  .home-roadmap-title,
  .home-team-title,
  .home-team-v4-title,
  .home-blogs-title,
  .fw-apl-title,
  .fw-cc-title,
  .fw-df-title,
  .fw-itc-title,
  .fw-phase-title,
  .fw-tp-title,
  .fw360-vca-title,
  .fw360-band-title,
  .fw360-section-title,
  .fw360-stack-title,
  .is-slide-title,
  .is-slider-title,
  .is-vti-main-title,
  .is-vti-title,
  .is-title,
  .ws-agenda-title,
  .ws-deliv-title,
  .ws-fit-title,
  .ws-partner-title,
  .ws-register-title,
  .res-team-title,
  .res-videos-title,
  .res-events-title,
  .res-blogs-title {
    font-size: 30px !important;
    line-height: 1.15;
  }

  /* Deck big number (01./02./03.) → 50px */
  .home-diag-num {
    font-size: 50px !important;
  }

  /* Card title → 24px */
  .home-diag-card-title,
  .fw-itc-card-title,
  .fw360-command-card-title,
  .fw360-data-card-title,
  .shield-card-title h3,
  .blog-card-title {
    font-size: 24px !important;
    line-height: 1.25;
  }
}


/* ============================================================
   Blog article page (/learn/<slug>) — CMS-rendered rich HTML
   ============================================================ */
.blog-article-hero { padding-bottom: 20px; }
.blog-article-hero .blog-article-title {
  max-width: 880px;
  margin-left: auto;
  margin-right: auto;
}
.blog-article-meta {
  color: #6b7280;
  font-size: 15px;
  margin-top: 14px;
}
.blog-article-meta .sep { margin: 0 10px; }
.blog-article-section { padding-bottom: 110px; }
.blog-article {
  max-width: 880px;
  margin: 0 auto;
}
.blog-article-cover { margin-bottom: 36px; }
.blog-article-cover img {
  width: 100%;
  max-height: 420px;
  object-fit: cover;
  display: block;
}
.blog-article-body {
  color: var(--infer-text);
  font-size: 17px;
  line-height: 1.7;
}
.blog-article-body h2 {
  color: var(--brand-navy);
  font-size: 30px;
  margin: 40px 0 16px;
}
.blog-article-body h3 { line-height: 1.3; }
.blog-article-body p { margin-bottom: 16px; }
.blog-article-body img { max-width: 100%; height: auto; display: block; margin: 0 auto; }
.blog-article-body figure.image { margin: 30px auto; }
.blog-article-body figure.image figcaption {
  font-size: 13px;
  color: #6b7280;
  text-align: center;
  margin-top: 10px;
}
.blog-article-back { margin-top: 48px; }
/* Tag pills rendered as spans (non-link) on the Learn sidebar */
.res-tags span {
  display: inline-block;
  background: #f1f3f5;
  color: var(--infer-text);
  font-size: 14px;
  padding: 8px 16px;
  margin: 0 8px 8px 0;
}
@media (max-width: 767px) {
  .blog-article-body { font-size: 16px; }
  .blog-article-body h2 { font-size: 24px; }
  .blog-article-section { padding-bottom: 70px; }
}
/* Workshop popup form feedback */
.home-team-form-note {
  grid-column: 1 / -1;
  margin: 8px 0 0;
  font-size: 14px;
  line-height: 1.4;
}
.home-team-form-note.is-ok { color: #9be8c4; }
.home-team-form-note.is-error { color: #ffb3a0; }
.home-team-form-submit:disabled { opacity: 0.6; cursor: wait; }
/* ============================================================
   Client Testimonials (Figma 1025:12628) — home, above Blogs
   ============================================================ */
.home-testi-section {
  background: #f7f7f7;
  padding-top: 110px;
  padding-bottom: 110px;
}
.home-testi-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 40px;
}
.home-testi-quote-icon {
  display: block;
  font-size: 70px;
  line-height: 1;
  color: var(--brand-teal);
  margin-bottom: 18px;
}
.home-testi-heading .sec-title { font-size: clamp(34px, 4vw, 48px); margin: 0; }
.home-testi-track {
  display: flex;
  column-gap: 24px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
}
.home-testi-track::-webkit-scrollbar { display: none; }
.home-testi-card {
  flex: 0 0 calc(50% - 12px);
  scroll-snap-align: start;
  background: #fff;
  padding: 26px 30px 30px;
  display: flex;
  flex-direction: column;
}
.home-testi-text {
  font-size: 18px;
  line-height: 1.5;
  color: var(--infer-text);
  margin: 0 0 26px;
}
.home-testi-divider {
  border-top: 1px dashed #ced7e0;
  margin-top: auto;
}
.home-testi-attribution {
  font-family: var(--font-serif);
  font-size: 24px;
  line-height: 1.2;
  letter-spacing: -0.6px;
  color: var(--infer-text);
  margin: 22px 0 0;
  max-width: 580px;
  white-space: pre-line; /* attribution can be authored as multiple lines */
}
.home-testi-dots {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-top: 34px;
}
.home-testi-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  border: none;
  padding: 0;
  background: var(--brand-teal);
  opacity: 0.85;
  cursor: pointer;
}
.home-testi-dot.is-active {
  background: transparent;
  box-shadow: 0 0 0 1.5px var(--brand-teal);
  position: relative;
}
.home-testi-dot.is-active::after {
  content: "";
  position: absolute;
  inset: 2.5px;
  border-radius: 50%;
  background: var(--brand-teal);
}
@media (max-width: 991px) {
  .home-testi-section { padding-top: 70px; padding-bottom: 70px; }
  .home-testi-card { flex-basis: 100%; }
  .home-testi-quote-icon { font-size: 52px; }
}
