/* Treino Cognitivo Executivo — Sistólica — V23 */
:root {
  --font-title: "Classical Garamond BT", "Classical Garamond", Garamond, "Times New Roman", serif;
  --font-body: "Montserrat", Arial, Helvetica, sans-serif;
  --blue: #0a3f63;
  --blue-deep: #052b46;
  --blue-dark: #001B2E;
  --blue-ink: #0d2740;
  --blue-soft: #0a4b73;
  --blue-royal: #083A5C;
  --blue-royal-2: #083A5C;
  --gold: #cda55e;
  --gold-strong: #b98629;
  --gold-light: #f0c36d;
  --white: #ffffff;
  --paper: #f7f3ea;
  --paper-2: #efe7d7;
  --text: #0d2740;
  --text-soft: #5b6775;
  --line: rgba(10, 63, 99, 0.12);
  --line-light: rgba(255, 255, 255, 0.14);
  --shadow: 0 24px 70px rgba(2, 18, 31, 0.18);
  --shadow-soft: 0 14px 34px rgba(10, 63, 99, 0.08);
  --container: min(1180px, calc(100vw - 32px));
  --radius: 22px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--text);
  background: #fff;
  overflow-x: hidden;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 8% 4%, rgba(205, 165, 94, .08), transparent 28rem),
    radial-gradient(circle at 92% 0%, rgba(10, 63, 99, .07), transparent 24rem);
  z-index: -1;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button, input, textarea { font: inherit; }
button { cursor: pointer; }
::selection { background: rgba(205, 165, 94, .32); }

.container { width: var(--container); margin: 0 auto; }
.section { padding: 96px 0; }
.center { text-align: center; }
.gold { color: var(--gold); }
.skip-link { position: absolute; top: -100px; left: 16px; z-index: 100000; background: var(--gold); color: var(--blue-deep); padding: 10px 14px; border-radius: 8px; font-weight: 800; }
.skip-link:focus { top: 16px; }
.scroll-progress { position: fixed; left: 0; top: 0; z-index: 10001; height: 4px; width: 0; background: linear-gradient(90deg, var(--gold), var(--gold-light)); box-shadow: 0 0 18px rgba(205,165,94,.45); }

h1, h2, h3 { font-family: var(--font-title); margin: 0; letter-spacing: -.025em; line-height: 1.04; }
h1 { font-size: clamp(2.9rem, 4.65vw, 4.9rem); color: #fff; font-weight: 600; }
h2 { font-size: clamp(2.05rem, 4vw, 4rem); color: var(--blue-ink); font-weight: 600; }
h3 { font-size: clamp(1.35rem, 2vw, 1.8rem); color: var(--blue); font-weight: 700; }
p { margin: 0; line-height: 1.72; }
.kicker { margin: 0 0 16px; color: var(--gold); text-transform: uppercase; letter-spacing: .08em; font-size: .82rem; font-weight: 800; line-height: 1.3; }
.kicker.dark { color: var(--blue); }
.kicker.light { color: var(--gold-light); }
.section-head { max-width: 820px; margin: 0 0 44px; }
.section-head.center { margin-left: auto; margin-right: auto; }
.section-head h2 { margin-bottom: 18px; }
.section-head p, .section-copy p { color: var(--text-soft); font-size: 1.08rem; }
.section-copy h2 { margin: 0 0 20px; }
.section-copy p + p { margin-top: 14px; }

.btn { display: inline-flex; align-items: center; justify-content: center; min-height: 54px; padding: 0 25px; border-radius: 15px; border: 1px solid transparent; font-weight: 800; transition: transform .2s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease; text-align: center; }
.btn:hover { transform: translateY(-2px); }
.btn-primary { background: var(--gold); color: #083a5d; box-shadow: 0 18px 36px rgba(205,165,94,.22); }
.btn-primary:hover { background: #dfb45e; }
.btn-secondary { color: #fff; border-color: rgba(205,165,94,.88); background: rgba(255,255,255,.04); }
.btn-secondary:hover { background: rgba(255,255,255,.1); color: var(--gold-light); }

/* HEADER — modelado a partir da home */
.site-header { --header-height: 82px; position: fixed; top: 0; left: 0; width: 100%; z-index: 9998; background: #0a3f63; backdrop-filter: blur(10px); }
.site-header::after { content: ""; position: absolute; left: 0; bottom: 0; width: 100%; height: 4px; background: #cda55e; }
.site-header__inner { min-height: var(--header-height); display: flex; align-items: center; justify-content: space-between; gap: 28px; }
.brand { position: relative; z-index: 82; flex: 0 0 auto; }
.brand img { width: 152px; height: auto; }
.nav-toggle { display: none; width: 46px; height: 46px; border-radius: 12px; border: 1px solid rgba(255,255,255,.12); background: transparent; color: #fff; position: relative; z-index: 82; }
.site-nav { margin-left: auto; position: relative; z-index: 81; }
.site-nav__list, .site-nav ul { list-style: none; display: flex; align-items: center; gap: 28px; padding: 0; margin: 0; }
.site-nav__item { position: relative; }
.site-nav__link, .site-nav__button { color: rgba(255,255,255,.92); font-size: 1rem; line-height: 1; display: inline-flex; align-items: center; gap: 6px; }
.site-nav__button { border: 0 !important; background: transparent !important; cursor: pointer; padding: 0 !important; margin: 0; box-shadow: none !important; border-radius: 0 !important; appearance: none !important; }
.site-nav__caret { font-size: .72rem; line-height: 1; transform: translateY(1px); }
.site-nav__link:hover, .site-nav__link.active, .site-nav__item:hover > .site-nav__link, .site-nav__item:hover > .site-nav__button, .site-nav__item.is-open > .site-nav__button { color: var(--gold); }
.site-nav__item--login { position: absolute; left: calc(100% + 28px); top: 50%; transform: translateY(-50%); z-index: 82; }
.site-nav__login { display: inline-flex; align-items: center; justify-content: center; min-height: 38px; padding: 0 22px; border-radius: 999px; background: var(--gold); color: #083a5d; font-size: .95rem; line-height: 1; font-weight: 800; letter-spacing: .01em; white-space: nowrap; transition: transform .2s ease, background .2s ease; }
.site-nav__login:hover { background: #dfb45e; transform: translateY(-1px); }
.mega-menu { position: fixed; left: 50%; top: calc(var(--header-height) + 10px); transform: translateX(-50%); width: min(1180px, calc(100vw - 56px)); background: rgba(255,255,255,.985); border-radius: 14px; box-shadow: 0 18px 42px rgba(2,18,31,.18); padding: 18px 26px 22px; display: grid; gap: 22px; opacity: 0; visibility: hidden; pointer-events: none; z-index: 9999; }
.mega-menu::before { content: ""; position: absolute; inset: -12px 0 auto; height: 12px; }
.mega-menu--3col { grid-template-columns: repeat(3, minmax(0,1fr)); }
.mega-menu--4col { width: min(1260px, calc(100vw - 56px)); grid-template-columns: repeat(4, minmax(0,1fr)); }
.site-nav__item--has-mega:hover > .mega-menu, .site-nav__item--has-mega:focus-within > .mega-menu, .site-nav__item--has-mega.is-open > .mega-menu { opacity: 1; visibility: visible; pointer-events: auto; }
.mega-menu__card { min-width: 0; text-decoration: none; border-radius: 10px; }
.mega-menu__card.is-current { background: rgba(205,165,94,.12); padding: 10px; margin: -10px; }
.mega-menu__title { margin: 0 0 10px; color: #cda55e; font-family: var(--font-body); font-size: 1rem; line-height: 1.2; font-weight: 800; letter-spacing: 0; }
.mega-menu__text { margin: 0; color: #21394d; font-size: .98rem; line-height: 1.35; }

main { padding-top: 82px; }

/* HERO */
.tc-hero { position: relative; min-height: calc(100svh - 82px); display: flex; align-items: center; background:
  radial-gradient(circle at 88% 2%, rgba(205,165,94,.33), transparent 34rem),
  radial-gradient(circle at 12% 88%, rgba(10,75,115,.45), transparent 28rem),
  linear-gradient(145deg, #031520 0%, #052b46 54%, #02101a 100%); color: #fff; overflow: hidden; }
.tc-hero::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px); background-size: 74px 74px; mask-image: radial-gradient(circle at 55% 45%, #000 45%, transparent 84%); }
.tc-hero__grain { position: absolute; inset: 0; opacity: .42; background: radial-gradient(circle at center, transparent 0 40%, rgba(0,0,0,.35) 100%); pointer-events: none; }
.tc-hero__grid { position: relative; display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(360px, .92fr); gap: 52px; align-items: center; padding: 58px 0 74px; }
.tc-hero__copy { max-width: 820px; }
.tc-hero h1 em { color: var(--gold-light); font-style: italic; font-weight: 500; }
.hero-lead { margin-top: 20px; max-width: 760px; font-size: clamp(1rem, 1.18vw, 1.15rem); color: rgba(255,255,255,.84); line-height: 1.52; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 28px; }
.hero-metrics { margin-top: 42px; padding-top: 26px; border-top: 1px solid rgba(255,255,255,.12); display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.hero-metrics article { min-width: 0; }
.hero-metrics span { display: block; margin-bottom: 6px; color: rgba(255,255,255,.55); text-transform: uppercase; letter-spacing: .11em; font-size: .72rem; font-weight: 800; }
.hero-metrics strong { display: block; font-family: var(--font-title); color: var(--gold-light); font-size: clamp(2rem, 3.2vw, 3rem); line-height: .95; }
.hero-metrics small { color: rgba(255,255,255,.64); font-size: .8rem; }
.tc-hero__visual { position: relative; }
.executive-panel { background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.025)); border: 1px solid rgba(255,255,255,.16); border-radius: 30px; overflow: hidden; box-shadow: 0 45px 110px rgba(0,0,0,.36); backdrop-filter: blur(18px); }
.panel-top { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 15px 18px; border-bottom: 1px solid rgba(255,255,255,.1); background: rgba(255,255,255,.035); }
.panel-top span, .panel-top b { font-size: .68rem; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; color: rgba(255,255,255,.66); }
.panel-top b { color: var(--gold-light); border: 1px solid rgba(240,195,109,.28); border-radius: 999px; padding: 5px 9px; }
.panel-dots { display: flex; gap: 6px; }
.panel-dots i { width: 10px; height: 10px; border-radius: 50%; background: rgba(255,255,255,.18); }
.panel-body { padding: 22px; }
.panel-score-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.panel-score-grid article { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.09); border-radius: 15px; padding: 14px; }
.panel-score-grid span { display: block; color: rgba(255,255,255,.57); font-size: .64rem; letter-spacing: .1em; font-weight: 800; text-transform: uppercase; }
.panel-score-grid strong { display: block; margin-top: 5px; color: #fff; font-family: var(--font-title); font-size: 2rem; line-height: 1; }
.panel-score-grid strong.soft { color: var(--gold-light); }
.radar-card { margin-top: 16px; padding: 18px; border: 1px solid rgba(255,255,255,.09); border-radius: 22px; background: rgba(255,255,255,.04); display: grid; grid-template-columns: 260px 1fr; gap: 16px; align-items: center; }
.radar { width: 100%; height: auto; }
.radar-grid polygon, .radar-grid line { fill: none; stroke: rgba(255,255,255,.16); stroke-width: 1; }
.radar-area { fill: rgba(205,165,94,.28); stroke: var(--gold-light); stroke-width: 2.5; filter: drop-shadow(0 0 16px rgba(205,165,94,.25)); }
.radar-points circle { fill: #fff; stroke: var(--gold); stroke-width: 2; }
.panel-bars { display: grid; gap: 13px; }
.mini-bar { display: grid; grid-template-columns: 105px 1fr 30px; align-items: center; gap: 10px; color: #fff; }
.mini-bar span { font-size: .78rem; color: rgba(255,255,255,.78); }
.mini-bar i { display: block; height: 7px; border-radius: 999px; background: rgba(255,255,255,.1); position: relative; overflow: hidden; }
.mini-bar i::before { content: ""; position: absolute; inset: 0 auto 0 0; width: var(--w); border-radius: inherit; background: linear-gradient(90deg, var(--gold), var(--gold-light)); transform-origin: left; animation: growBar 1.2s cubic-bezier(.22,1,.36,1) forwards; }
.mini-bar b { font-size: .78rem; color: rgba(255,255,255,.85); text-align: right; }
.floating-note { position: absolute; right: -10px; bottom: -28px; max-width: 280px; padding: 18px 20px; border-radius: 18px; background: #fff; color: var(--blue-ink); box-shadow: 0 28px 60px rgba(0,0,0,.26); border: 1px solid rgba(205,165,94,.25); }
.floating-note strong { display: block; color: var(--blue); margin-bottom: 5px; font-family: var(--font-title); font-size: 1.15rem; }
.floating-note span { color: var(--text-soft); font-size: .9rem; line-height: 1.45; }
@keyframes growBar { from { transform: scaleX(0); } to { transform: scaleX(1); } }


/* PROGRAM STRIP — estilo CRISOL */
.program-strip {
  background: #031b2b;
  color: #fff;
  padding: 30px 0 34px;
  border-top: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.program-strip__inner {
  display: grid;
  gap: 26px;
  justify-items: center;
}
.program-stats {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  align-items: start;
  text-align: center;
}
.program-stats article {
  min-width: 0;
}
.program-stats strong {
  display: block;
  font-family: var(--font-title);
  color: var(--gold);
  font-size: clamp(2.35rem, 3.1vw, 3.4rem);
  line-height: .92;
  font-weight: 700;
  letter-spacing: -.02em;
}
.program-stats span {
  display: block;
  margin-top: 10px;
  color: rgba(255,255,255,.82);
  font-size: .9rem;
  line-height: 1.2;
}
.program-strip__button {
  min-width: 280px;
  min-height: 56px;
}

/* TESE + PROBLEMA */
.thesis-problem-section { background: #FFFFFF; }
.thesis-card { max-width: 1040px; margin: 0 auto 54px; text-align: center; }
.thesis-card p:not(.kicker) { margin: 0; color: var(--blue-ink); font-family: var(--font-body); font-size: clamp(1.22rem, 1.9vw, 1.8rem); line-height: 1.42; font-weight: 500; }
.thesis-card em { color: var(--gold-strong); font-style: italic; font-weight: 800; }
.split-grid { display: grid; grid-template-columns: .92fr 1.08fr; gap: 56px; align-items: start; }
.thesis-problem-grid { margin-top: 8px; }
.problem-statement { margin: 0 0 18px !important; color: var(--blue); font-family: var(--font-title); font-size: clamp(1.45rem, 2.3vw, 2.3rem) !important; line-height: 1.15 !important; font-weight: 400; letter-spacing: -.02em; }
.pain-stack { display: grid; gap: 14px; }
.pain-stack article { position: relative; overflow: hidden; background: linear-gradient(135deg, var(--blue-royal) 0%, #052b46 72%); border: 1px solid rgba(205,165,94,.34); border-radius: 18px; padding: 22px; box-shadow: 0 16px 36px rgba(6,74,143,.16); transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.pain-stack article::before { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(205,165,94,.38) 0%, rgba(205,165,94,.10) 38%, transparent 72%); opacity: .78; transform: translateX(-38%); transition: transform .36s ease, opacity .36s ease; pointer-events: none; }
.pain-stack article:hover { transform: translateY(-5px); box-shadow: 0 24px 56px rgba(6,74,143,.25); border-color: rgba(240,195,109,.75); }
.pain-stack article:hover::before { transform: translateX(0); opacity: .98; }
.pain-stack span, .pain-stack strong, .pain-stack p { position: relative; z-index: 1; }
.pain-stack span { display: block; color: var(--gold-light); font-weight: 900; font-size: .75rem; letter-spacing: .12em; margin-bottom: 8px; }
.pain-stack strong { display: block; color: #fff; font-family: var(--font-title); font-size: 1.3rem; margin-bottom: 5px; }
.pain-stack p { color: rgba(255,255,255,.78); font-size: .96rem; }

/* ARCHITECTURE */
.architecture-section { background: linear-gradient(145deg, var(--blue-royal), #052b46 72%, #031b2b); color: #fff; position: relative; overflow: hidden; }
.architecture-section::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px); background-size: 80px 80px; opacity: .72; }
.architecture-section .container { position: relative; }
.architecture-section h2 { color: #fff; }
.architecture-section .section-head p { color: rgba(255,255,255,.76); }
.architecture-section .kicker.dark { color: var(--gold-light); }
.architecture-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.architecture-card { border-radius: 22px; padding: 28px 24px; border: 1px solid rgba(255,255,255,.14); background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.035)); box-shadow: 0 18px 42px rgba(0,0,0,.14); min-height: 270px; transition: transform .25s ease, border-color .25s ease, background .25s ease; }
.architecture-card:hover { transform: translateY(-5px); border-color: rgba(240,195,109,.42); background: linear-gradient(145deg, rgba(205,165,94,.18), rgba(255,255,255,.055)); }
.architecture-card span, .dimension-card span, .frontier-card span, .ethic-card span, .integration-grid span, .specialist-seal span { display: inline-block; color: var(--gold-strong); text-transform: uppercase; letter-spacing: .12em; font-size: .72rem; font-weight: 900; margin-bottom: 14px; }
.architecture-card span { color: var(--gold-light); }
.architecture-card h3 { margin-bottom: 12px; color: #fff; }
.architecture-card p { color: rgba(255,255,255,.74); font-size: .96rem; }

/* DIMENSIONS */
.dimensions-section { background: #FFFFFF; color: var(--text); position: relative; overflow: hidden; }
.dimensions-section::before { content: ""; position: absolute; right: -180px; top: -180px; width: 520px; height: 520px; border-radius: 50%; background: radial-gradient(circle, rgba(205,165,94,.12), transparent 64%); pointer-events: none; }
.dimensions-section .container { position: relative; }
.dimensions-section h2 { color: var(--blue-ink); }
.dimensions-section .section-head p { color: var(--text-soft); }
.dimensions-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.dimension-card { background: #FFFFFF; border: 1px solid var(--line); border-radius: 20px; padding: 24px; min-height: 214px; box-shadow: var(--shadow-soft); transition: transform .25s ease, border-color .25s ease, background .25s ease, box-shadow .25s ease; }
.dimension-card:hover { transform: translateY(-4px); border-color: rgba(205,165,94,.48); background: linear-gradient(180deg, #fff, #fbfaf6); box-shadow: 0 22px 46px rgba(10,63,99,.12); }
.dimension-card h3 { color: var(--blue); margin-bottom: 10px; }
.dimension-card p { color: var(--text-soft); font-size: .94rem; }
.dimension-card--featured { grid-column: span 2; background: linear-gradient(135deg, rgba(205,165,94,.16), rgba(10,63,99,.045)); border-color: rgba(205,165,94,.28); }

/* ASSESSMENT */
.assessment-section { background: linear-gradient(180deg, #fff, var(--paper)); }
.assessment-shell { display: grid; grid-template-columns: .36fr .64fr; gap: 22px; border-radius: 34px; padding: 28px; background: linear-gradient(145deg, #031520, #052b46 58%, #031420); color: #fff; box-shadow: 0 45px 110px rgba(2,18,31,.25); overflow: hidden; position: relative; }
.assessment-shell::before { content: ""; position: absolute; right: -160px; top: -160px; width: 420px; height: 420px; border-radius: 50%; background: rgba(205,165,94,.16); filter: blur(6px); }
.assessment-side, .assessment-main { position: relative; background: rgba(255,255,255,.045); border: 1px solid rgba(255,255,255,.1); border-radius: 24px; padding: 26px; }
.assessment-side h3, .assessment-main h3 { color: #fff; }
.assessment-side p { color: rgba(255,255,255,.7); margin-top: 12px; font-size: .98rem; }
.profile-tabs { display: grid; gap: 9px; margin-top: 24px; }
.profile-tab { width: 100%; display: flex; align-items: center; justify-content: space-between; text-align: left; padding: 15px 16px; color: rgba(255,255,255,.78); background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1); border-radius: 14px; font-weight: 700; transition: all .2s ease; }
.profile-tab:hover { color: #fff; background: rgba(255,255,255,.08); }
.profile-tab.active { background: var(--gold); border-color: var(--gold); color: #083a5d; box-shadow: 0 14px 28px rgba(205,165,94,.22); }
.assessment-note { margin-top: 22px; padding-top: 18px; border-top: 1px dashed rgba(255,255,255,.15); }
.assessment-note span { color: var(--gold-light); text-transform: uppercase; letter-spacing: .12em; font-size: .7rem; font-weight: 900; }
.assessment-note p { color: rgba(255,255,255,.86); font-family: var(--font-title); font-size: 1.16rem; line-height: 1.34; }
.assessment-title-row { display: flex; align-items: start; justify-content: space-between; gap: 18px; margin-bottom: 12px; }
.assessment-badge { color: var(--gold-light); border: 1px solid rgba(240,195,109,.28); border-radius: 999px; padding: 7px 10px; text-transform: uppercase; letter-spacing: .1em; font-size: .64rem; font-weight: 900; white-space: nowrap; }
.profile-text { color: rgba(255,255,255,.76); max-width: 850px; }
.demo-metrics { margin-top: 22px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.demo-metrics article { border-radius: 15px; padding: 16px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.09); }
.demo-metrics span { display: block; color: rgba(255,255,255,.55); text-transform: uppercase; letter-spacing: .1em; font-size: .65rem; font-weight: 900; }
.demo-metrics strong { display: block; margin-top: 5px; color: var(--gold-light); font-family: var(--font-title); font-size: 2.2rem; line-height: 1; }
.assessment-content-grid { display: grid; grid-template-columns: .88fr 1.12fr; gap: 18px; margin-top: 18px; }
.demo-dims { display: grid; gap: 8px; }
.demo-dim { padding: 11px 13px; border-radius: 12px; background: rgba(255,255,255,.045); border: 1px solid rgba(255,255,255,.08); }
.demo-dim__row { display: flex; justify-content: space-between; gap: 10px; color: rgba(255,255,255,.86); font-size: .86rem; font-weight: 700; }
.demo-dim__row b { color: var(--gold-light); }
.demo-track { margin-top: 7px; height: 6px; border-radius: 999px; background: rgba(255,255,255,.09); overflow: hidden; }
.demo-fill { display: block; height: 100%; width: var(--w); border-radius: inherit; background: linear-gradient(90deg, var(--gold), var(--gold-light)); transition: width .45s ease; }
.risk-matrix { position: relative; min-height: 360px; border-radius: 22px; border: 1px solid rgba(255,255,255,.12); background: linear-gradient(135deg, rgba(166,67,55,.24) 0%, rgba(166,67,55,.05) 36%, rgba(76,155,111,.07) 64%, rgba(76,155,111,.24) 100%); overflow: hidden; }
.risk-matrix::before { content: ""; position: absolute; left: 50%; top: 0; bottom: 0; width: 1px; background: rgba(255,255,255,.18); }
.risk-matrix::after { content: ""; position: absolute; left: 0; right: 0; top: 50%; height: 1px; background: rgba(255,255,255,.18); }
.matrix-label { position: absolute; color: rgba(255,255,255,.55); text-transform: uppercase; letter-spacing: .12em; font-size: .62rem; font-weight: 900; z-index: 1; }
.matrix-label--top { top: 10px; left: 50%; transform: translateX(-50%); }
.matrix-label--bottom { bottom: 10px; left: 50%; transform: translateX(-50%); }
.matrix-label--left { top: 50%; left: 8px; transform: rotate(-90deg) translateY(-50%); transform-origin: left top; }
.matrix-label--right { top: 50%; right: 8px; transform: rotate(90deg) translateY(-50%); transform-origin: right top; }
.matrix-quadrant { position: absolute; width: 50%; padding: 28px 18px; color: rgba(255,255,255,.74); font-size: .7rem; text-transform: uppercase; letter-spacing: .09em; font-weight: 900; line-height: 1.3; }
.q-a { right: 0; top: 0; text-align: right; color: #b6efce; }
.q-b { left: 0; top: 0; color: #f7d896; }
.q-c { left: 0; bottom: 0; color: #eaa299; }
.q-d { right: 0; bottom: 0; text-align: right; color: #c7dae8; }
.matrix-dot { position: absolute; width: 22px; height: 22px; border-radius: 50%; background: #fff; border: 5px solid var(--gold); box-shadow: 0 0 0 12px rgba(205,165,94,.18), 0 0 30px rgba(240,195,109,.5); transform: translate(-50%, -50%); z-index: 4; transition: left .5s ease, top .5s ease; }
.matrix-dot::after { content: attr(data-label); position: absolute; left: 28px; top: -5px; background: #fff; color: var(--blue); border-radius: 999px; padding: 6px 10px; white-space: nowrap; font-size: .75rem; font-weight: 900; box-shadow: 0 8px 20px rgba(0,0,0,.18); }


/* AJUSTES V3 — Tese central, arquitetura, dimensões e assessment */
.thesis-problem-section .kicker.dark,
.thesis-problem-section .problem-statement {
  font-family: var(--font-title);
  color: #001b2e;
}

.thesis-card .kicker.dark,
.thesis-problem-section .section-copy .kicker.dark {
  color: #001b2e;
  font-weight: 400;
  letter-spacing: .02em;
}

.thesis-card p:not(.kicker) {
  color: #001b2e;
}

.problem-text-block {
  margin-top: 18px;
  padding: 26px 28px;
  border-radius: 22px;
  background: #053f63;
  border: 1px solid rgba(205,165,94,.34);
  box-shadow: 0 20px 46px rgba(0,27,46,.16);
}

.problem-text-block p {
  color: rgba(255,255,255,.88) !important;
}

.problem-text-block p + p {
  margin-top: 14px;
}

.architecture-section {
  background: linear-gradient(145deg, #053f63, #052b46 72%, #031b2b);
}

.architecture-section .section-head h2 {
  font-weight: 400;
}

.dimensions-section .section-head {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.dimensions-section .section-head h2 {
  font-weight: 400;
}

.assessment-section {
  background: #001b2e;
}

.assessment-section .container {
  width: min(1360px, calc(100vw - 32px));
}

.assessment-section .kicker.dark {
  color: var(--gold-light);
}

.assessment-section h2 {
  color: #fff;
  font-weight: 400;
}

.assessment-section .section-head p {
  color: rgba(255,255,255,.74);
}

.assessment-shell {
  grid-template-columns: .32fr .68fr;
  padding: 32px;
  background: linear-gradient(145deg, #02101a, #052b46 58%, #001b2e);
}


/* JOURNEY */
.journey-section { background: #fff; }
.timeline { position: relative; display: grid; gap: 16px; max-width: 980px; }
.timeline::before { content: ""; position: absolute; left: 31px; top: 26px; bottom: 26px; width: 2px; background: linear-gradient(180deg, var(--gold), rgba(205,165,94,.1)); }
.timeline-step { position: relative; display: grid; grid-template-columns: 64px 1fr; gap: 22px; align-items: start; }
.timeline-step > span { position: relative; z-index: 2; width: 64px; height: 64px; border-radius: 18px; display: grid; place-items: center; background: var(--blue); color: #fff; font-family: var(--font-title); font-size: 1.55rem; box-shadow: 0 14px 28px rgba(10,63,99,.25); }
.timeline-step:nth-child(odd) > span { background: var(--gold); color: #083a5d; }
.timeline-step div { padding: 24px 28px; border-radius: 20px; background: #fff; border: 1px solid var(--line); box-shadow: var(--shadow-soft); }
.timeline-step b { display: block; color: var(--gold-strong); text-transform: uppercase; letter-spacing: .12em; font-size: .72rem; margin-bottom: 8px; }
.timeline-step h3 { margin-bottom: 8px; }
.timeline-step p { color: var(--text-soft); font-size: .98rem; }

/* EVOLUTION */
.evolution-section { background: linear-gradient(150deg, #052b46, #031b2b); color: #fff; overflow: hidden; }
.evolution-grid { display: grid; grid-template-columns: .88fr 1.12fr; gap: 54px; align-items: center; }
.evolution-section h2 { color: #fff; }
.evolution-section .section-copy p { color: rgba(255,255,255,.72); }
.evolution-card { background: rgba(255,255,255,.055); border: 1px solid rgba(255,255,255,.12); border-radius: 28px; padding: 24px; box-shadow: 0 32px 70px rgba(0,0,0,.18); }
.evolution-card svg { width: 100%; height: auto; display: block; }
.chart-grid line { stroke: rgba(255,255,255,.1); stroke-width: 1; }
.curve-area { fill: url(#curveArea); }
.curve-line { fill: none; stroke: url(#curveGold); stroke-width: 5; stroke-linecap: round; filter: drop-shadow(0 0 12px rgba(205,165,94,.3)); }
.curve-points circle { fill: #fff; stroke: var(--gold); stroke-width: 4; }
.evolution-card text { fill: rgba(255,255,255,.72); font-size: 18px; font-family: Arial, sans-serif; font-weight: 700; }
.evolution-legend { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 16px; }
.evolution-legend article { border-radius: 14px; padding: 14px; background: rgba(255,255,255,.055); border: 1px solid rgba(255,255,255,.09); }
.evolution-legend b { display: block; color: var(--gold-light); font-family: var(--font-title); font-size: 1.1rem; margin-bottom: 4px; }
.evolution-legend span { color: rgba(255,255,255,.68); font-size: .88rem; }

/* DELIVERABLES */
.deliverables-section { background: var(--blue); color: #fff; }
.deliverables-section h2 { color: #fff; }
.deliverables-section .section-head p { color: rgba(255,255,255,.72); }
.frontier-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.frontier-card { border-radius: 24px; padding: 34px; background: rgba(255,255,255,.045); border: 1px solid rgba(255,255,255,.13); }
.frontier-card.gold-card { background: linear-gradient(145deg, rgba(205,165,94,.26), rgba(255,255,255,.045)); border-color: rgba(240,195,109,.32); }
.frontier-card h3 { color: #fff; margin-bottom: 16px; }
.frontier-card ul, .ethic-card ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.frontier-card li, .ethic-card li { color: rgba(255,255,255,.78); line-height: 1.55; padding-left: 22px; position: relative; }
.frontier-card li::before, .ethic-card li::before { content: ""; position: absolute; left: 0; top: .72em; width: 12px; height: 2px; background: var(--gold); }

/* WHO */
.who-section { background: #fff; }
.who-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; align-items: start; }
.who-card { border-radius: 26px; border: 1px solid var(--line); background: #fff; padding: 36px; box-shadow: var(--shadow-soft); border-top: 5px solid var(--gold); }
.who-card.muted { background: var(--paper); border-top-color: #87909a; margin-top: 32px; }
.who-card h2 { font-size: clamp(1.9rem, 2.8vw, 2.8rem); margin-bottom: 18px; }
.check-list, .x-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.check-list li, .x-list li { position: relative; padding-left: 28px; color: var(--text-soft); line-height: 1.62; }
.check-list li::before { content: ""; position: absolute; left: 0; top: .76em; width: 16px; height: 2px; background: var(--gold); }
.x-list li::before { content: "×"; position: absolute; left: 1px; top: -2px; color: #87909a; font-size: 1.45rem; font-weight: 900; }

/* INTEGRATION */
.integration-section { background: linear-gradient(160deg, #052b46, #031b2b); color: #fff; }
.integration-section h2 { color: #fff; }
.integration-section .section-head p { color: rgba(255,255,255,.74); }
.integration-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.integration-grid article { border-radius: 20px; padding: 24px; background: rgba(255,255,255,.055); border: 1px solid rgba(255,255,255,.11); }
.integration-grid h3 { color: #fff; margin-bottom: 8px; }
.integration-grid p { color: rgba(255,255,255,.68); font-size: .94rem; }

/* ETHICS */
.ethics-section { background: var(--paper); }
.ethics-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.ethic-card { border-radius: 26px; padding: 34px; background: #fff; border: 1px solid var(--line); box-shadow: var(--shadow-soft); }
.ethic-card.dark-card { background: linear-gradient(150deg, #031b2b, #052b46); color: #fff; }
.ethic-card h3 { margin-bottom: 16px; }
.ethic-card.dark-card h3 { color: #fff; }
.ethic-card:not(.dark-card) li { color: var(--text-soft); }
.ethic-card:not(.dark-card) li::before { background: var(--blue); }

/* SPECIALIST */
.specialist-section { background: #fff; }
.specialist-card { display: grid; grid-template-columns: .42fr .58fr; gap: 42px; align-items: center; border-radius: 30px; padding: 42px; background: linear-gradient(180deg, #fff, #fbfaf6); border: 1px solid var(--line); box-shadow: var(--shadow); }
.specialist-seal { min-height: 270px; border-radius: 24px; padding: 32px; background: linear-gradient(160deg, #031b2b, #052b46); color: #fff; display: flex; flex-direction: column; justify-content: flex-end; position: relative; overflow: hidden; }
.specialist-seal::before { content: ""; position: absolute; right: -80px; top: -80px; width: 220px; height: 220px; border-radius: 50%; background: rgba(205,165,94,.22); }
.specialist-seal strong { position: relative; display: block; font-family: var(--font-title); font-size: clamp(2rem, 3vw, 3rem); line-height: 1.02; margin-bottom: 8px; }
.specialist-seal small { position: relative; color: rgba(255,255,255,.76); font-size: .98rem; }
.specialist-card p { color: var(--text-soft); font-size: 1.04rem; }
.specialist-card p + p { margin-top: 14px; }

/* FAQ */
.faq-section { background: #fff; }
.faq-grid { display: grid; grid-template-columns: .42fr .58fr; gap: 52px; align-items: start; }
.faq { display: grid; gap: 10px; }
.faq-item { border-radius: 18px; border: 1px solid var(--line); background: #fff; box-shadow: var(--shadow-soft); overflow: hidden; }
.faq-q { width: 100%; padding: 20px 22px; border: 0; background: transparent; text-align: left; color: var(--blue); font-weight: 900; display: flex; justify-content: space-between; gap: 16px; }
.faq-q::after { content: "+"; color: var(--gold); font-size: 1.35rem; line-height: 1; }
.faq-item.is-open .faq-q::after { content: "−"; }
.faq-a { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .28s ease; }
.faq-item.is-open .faq-a { grid-template-rows: 1fr; }
.faq-a p { overflow: hidden; padding: 0 22px; color: var(--text-soft); }
.faq-item.is-open .faq-a p { padding-bottom: 20px; }

/* CONTACT */
.contact-section { padding: 98px 0; background:
  radial-gradient(circle at 85% 10%, rgba(205,165,94,.24), transparent 28rem),
  linear-gradient(145deg, #031520, #052b46 58%, #031420); color: #fff; }
.contact-grid { display: grid; grid-template-columns: .95fr .65fr; gap: 48px; align-items: center; }
.contact-copy h2 { color: #fff; margin-bottom: 18px; }
.contact-copy p { color: rgba(255,255,255,.76); font-size: 1.06rem; }
.contact-proof { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 28px; }
.contact-proof article { border-radius: 18px; border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.05); padding: 20px; }
.contact-proof span { color: var(--gold-light); font-size: .72rem; font-weight: 900; letter-spacing: .12em; }
.contact-proof b { display: block; margin: 8px 0; color: #fff; font-family: var(--font-title); font-size: 1.22rem; }
.contact-proof p { color: rgba(255,255,255,.66); font-size: .92rem; line-height: 1.5; }
.contact-form { border-radius: 26px; background: #fff; color: var(--text); padding: 32px; box-shadow: 0 32px 70px rgba(0,0,0,.24); }
.contact-form h3 { margin-bottom: 20px; }
.contact-form label { display: grid; gap: 8px; color: var(--blue); font-weight: 900; margin-bottom: 14px; }
.contact-form input, .contact-form textarea { width: 100%; border: 1px solid var(--line); border-radius: 14px; padding: 14px 14px; background: #fbfaf6; color: var(--text); outline: none; resize: vertical; }
.contact-form input:focus, .contact-form textarea:focus { border-color: var(--gold); box-shadow: 0 0 0 4px rgba(205,165,94,.14); }
.contact-form .btn { width: 100%; margin-top: 6px; }
.form-note { margin-top: 12px; color: var(--text-soft); font-size: .85rem; text-align: center; }

/* FOOTER */
.site-footer { background: #083a5d; color: #fff; padding-top: 38px; }
.site-footer__grid { display: grid; grid-template-columns: 1.55fr 1fr 1fr 1fr 1.15fr; gap: 44px; align-items: start; }
.footer-brand img { width: 320px; max-width: 100%; height: auto; }
.footer-address { margin-top: 22px; color: rgba(255,255,255,.95); line-height: 1.45; font-size: .98rem; }
.footer-social { margin-top: 48px; display: flex; gap: 12px; flex-wrap: wrap; }
.footer-social-link { width: 44px; height: 44px; border-radius: 8px; background: #f2f2f2; display: inline-flex; align-items: center; justify-content: center; transition: transform .2s ease, opacity .2s ease; }
.footer-social-link:hover { transform: translateY(-2px); opacity: .95; }
.footer-social-link img { width: 24px; height: 24px; object-fit: contain; }
.footer-column h4 { margin: 0 0 14px; font-size: 1.05rem; font-weight: 800; color: #fff; }
.footer-column a, .footer-column span { display: block; margin: 0 0 10px; color: rgba(255,255,255,.92); font-size: .96rem; line-height: 1.3; }
.footer-column a:hover { color: var(--gold); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.1); margin-top: 34px; padding: 18px 0 22px; text-align: center; color: rgba(255,255,255,.9); font-size: .92rem; }
.floating-whatsapp { position: fixed; right: 22px; bottom: 22px; width: 64px; height: 64px; display: flex; align-items: center; justify-content: center; z-index: 99999; background: transparent; border: none; box-shadow: none; }
.floating-whatsapp:hover { transform: translateY(-3px) scale(1.03); transition: transform .2s ease; }
.floating-whatsapp img { width: 64px; height: 64px; object-fit: contain; }

/* REVEAL */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
.reveal.in { opacity: 1; transform: translateY(0); }

/* RESPONSIVO */
@media (max-width: 1160px) and (min-width: 821px) {
  .site-nav__item--login { left: calc(100% + 18px); }
  .site-nav__login { min-height: 36px; padding: 0 18px; font-size: .92rem; }
  .site-nav__list, .site-nav ul { gap: 22px; }
  .mega-menu { width: min(1060px, calc(100vw - 48px)); }
  .mega-menu--4col { width: min(1120px, calc(100vw - 48px)); }
}

@media (max-width: 1100px) {
  .tc-hero__grid, .split-grid, .evolution-grid, .specialist-card, .faq-grid, .contact-grid { grid-template-columns: 1fr; }
  .tc-hero__visual { max-width: 780px; }
  .architecture-grid, .dimensions-grid, .integration-grid { grid-template-columns: repeat(2, 1fr); }
  .assessment-shell, .assessment-content-grid { grid-template-columns: 1fr; }
  .risk-matrix { min-height: 320px; }
  .site-footer__grid { grid-template-columns: 1.4fr 1fr 1fr; gap: 32px; }
  .footer-brand { grid-column: 1 / -1; }
}

@media (max-width: 820px) {
  .program-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px 14px; }
  .program-strip { padding: 28px 0 32px; }
  .program-strip__button { width: min(92vw, 340px); min-width: 0; }
  .site-header { --header-height: 72px; }
  main { padding-top: 72px; }
  .nav-toggle { display: inline-flex; align-items: center; justify-content: center; }
  .site-nav { position: absolute; top: calc(100% + 8px); right: 16px; left: 16px; background: rgba(255,255,255,.98); border: 1px solid rgba(8,53,86,.08); border-radius: 12px; padding: 12px 14px; display: none; box-shadow: 0 8px 18px rgba(2,18,31,.08); backdrop-filter: blur(6px); }
  .site-nav.is-open { display: block; }
  .site-nav__link, .site-nav__button { color: #083a5d; width: 100%; justify-content: space-between; font-size: 1rem; }
  .site-nav__caret { color: #cda55e; }
  .site-nav__list, .site-nav ul { flex-direction: column; align-items: stretch; gap: 10px; }
  .site-nav__item--login { position: static; left: auto; top: auto; transform: none; z-index: auto; }
  .site-nav__login { width: 100%; min-height: 42px; padding: 0 16px; border-radius: 10px; justify-content: center; }
  .mega-menu, .mega-menu--4col { position: static; left: auto; top: auto; transform: none; width: 100%; margin-top: 8px; padding: 10px 12px; display: none; grid-template-columns: 1fr; opacity: 1; visibility: visible; pointer-events: auto; background: rgba(255,255,255,.72); border: 1px solid rgba(8,53,86,.06); border-radius: 10px; box-shadow: none; }
  .site-nav__item--has-mega.is-open > .mega-menu { display: grid; }
  .mega-menu__card + .mega-menu__card { border-top: 1px solid rgba(8,53,86,.07); padding-top: 10px; }
  .mega-menu__card.is-current { margin: 0; padding: 10px; }

  .section { padding: 72px 0; }
  .tc-hero { min-height: auto; }
  .tc-hero__grid { grid-template-columns: 1fr; padding: 56px 0 78px; gap: 38px; }
  h1 { font-size: clamp(2.35rem, 9.2vw, 3.9rem); }
  .hero-actions { flex-direction: column; }
  .hero-actions .btn { width: 100%; }
  .hero-metrics { grid-template-columns: repeat(2, 1fr); }
  .radar-card { grid-template-columns: 1fr; }
  .radar { max-width: 260px; margin: 0 auto; }
  .floating-note { position: static; max-width: none; margin-top: 14px; }
  .frontier-grid, .who-grid, .ethics-grid, .contact-proof { grid-template-columns: 1fr; }
  .who-card.muted { margin-top: 0; }
  .evolution-legend { grid-template-columns: 1fr; }
  .site-footer__grid { grid-template-columns: 1fr; gap: 28px; }
  .footer-brand img { width: 240px; }
  .footer-social { margin-top: 28px; }
  .footer-bottom { font-size: .84rem; line-height: 1.4; padding-left: 12px; padding-right: 12px; }
  .floating-whatsapp { right: 16px; bottom: 16px; width: 58px; height: 58px; }
  .floating-whatsapp img { width: 58px; height: 58px; }
}

@media (max-width: 620px) {
  .program-stats { grid-template-columns: 1fr; gap: 18px; }
  .program-stats strong { font-size: 3rem; }
  .container { width: min(100vw - 28px, 1180px); }
  .brand img { width: 134px; }
  .architecture-grid, .dimensions-grid, .integration-grid { grid-template-columns: 1fr; }
  .dimension-card--featured { grid-column: auto; }
  .panel-score-grid, .demo-metrics { grid-template-columns: 1fr; }
  .assessment-shell { padding: 14px; border-radius: 24px; }
  .assessment-side, .assessment-main, .contact-form, .specialist-card, .frontier-card, .who-card, .ethic-card { padding: 24px; }
  .timeline::before { left: 23px; }
  .timeline-step { grid-template-columns: 48px 1fr; gap: 14px; }
  .timeline-step > span { width: 48px; height: 48px; border-radius: 14px; font-size: 1.15rem; }
  .timeline-step div { padding: 20px; }
  .assessment-title-row { display: block; }
  .assessment-badge { display: inline-block; margin-top: 12px; }
  .risk-matrix { min-height: 280px; }
  .matrix-dot::after { left: auto; right: 26px; }
}


/* AJUSTES V4 — refinamentos solicitados */
.tc-hero h1 {
  font-weight: 400;
}

.tc-hero h1 .hero-title-light {
  font-weight: 400;
}

.tc-hero h1 em {
  font-weight: 500;
}

.thesis-card p:not(.kicker) {
  font-family: var(--font-title);
  color: #001b2e;
  font-weight: 400;
  letter-spacing: -0.025em;
}

.thesis-card .kicker.dark,
.thesis-problem-section .section-copy .kicker.dark {
  font-weight: 400 !important;
}

.thesis-problem-section .section-copy > p:not(.kicker):not(.problem-statement) {
  color: var(--text-soft);
  font-size: 1.08rem;
  line-height: 1.72;
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
  border-radius: 0;
}

.architecture-section .section-head {
  max-width: 1180px;
}

.architecture-section .section-head h2 {
  font-weight: 400;
  font-size: clamp(2.25rem, 3.35vw, 3.45rem);
  line-height: 1.08;
}

.architecture-section .section-head h2 .title-line {
  display: block;
  white-space: nowrap;
}

@media (max-width: 820px) {
  .architecture-section .section-head h2 .title-line {
    white-space: normal;
  }
}

/* AJUSTES V5 — alterações Treino Cognitivo */
:root {
  --blue-royal: #083A5C;
  --blue-royal-2: #083A5C;
  --blue-dark: #001B2E;
}

.btn {
  transition: transform .22s ease, background .22s ease, border-color .22s ease, box-shadow .22s ease, color .22s ease;
}

.hero-actions .btn-secondary {
  color: var(--gold-light);
}

.program-strip__button.btn-primary:hover {
  background: transparent;
  color: var(--gold);
  border-color: var(--gold);
  box-shadow: none;
}

.program-stats article {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  text-align: left;
}

.program-stats strong {
  display: inline-flex;
  align-items: baseline;
  flex: 0 0 auto;
  gap: 0;
}

.program-stats .stat-count,
.program-stats .stat-separator {
  display: inline;
  margin: 0;
  color: inherit;
  font: inherit;
  line-height: inherit;
}

.program-stats .stat-label {
  display: inline-block;
  margin-top: 0;
  max-width: 118px;
  color: rgba(255,255,255,.84);
  font-size: .92rem;
  line-height: 1.18;
}

.thesis-card .kicker.dark,
.thesis-problem-section .section-copy .kicker.dark {
  font-family: var(--font-body);
  text-transform: uppercase;
  letter-spacing: .08em;
}

.thesis-card em {
  font-weight: 400;
}

.thesis-problem-section .section-copy > p:not(.kicker):not(.problem-statement) {
  color: #001B2E;
}

.pain-stack strong,
.architecture-card h3,
.dimension-card h3,
.timeline-step h3,
.frontier-card h3,
.integration-grid h3,
.ethic-card h3 {
  font-weight: 400;
}

.architecture-section {
  background: #083A5C;
}

.architecture-section h2 em {
  color: var(--gold-light);
  font-style: italic;
  font-weight: 400;
}

.architecture-grid {
  perspective: 1200px;
}

.architecture-card {
  position: relative;
  overflow: hidden;
  transform: translateY(0) scale(1);
  transition: transform .52s cubic-bezier(.22,1,.36,1), border-color .52s cubic-bezier(.22,1,.36,1), background .52s cubic-bezier(.22,1,.36,1), box-shadow .52s cubic-bezier(.22,1,.36,1), opacity .32s ease;
}

.architecture-card::before {
  content: "";
  position: absolute;
  inset: -45% -35%;
  background: radial-gradient(circle at 50% 50%, rgba(240,195,109,.24), transparent 54%);
  opacity: 0;
  transform: scale(.72) rotate(8deg);
  transition: opacity .55s ease, transform .55s cubic-bezier(.22,1,.36,1);
  pointer-events: none;
}

.architecture-card span,
.architecture-card h3,
.architecture-card p {
  position: relative;
  z-index: 1;
}

.architecture-card h3,
.architecture-card p {
  transition: transform .45s cubic-bezier(.22,1,.36,1), color .32s ease;
}

.architecture-card:hover {
  transform: translateY(-10px) scale(1.025) rotateX(2deg);
  border-color: rgba(240,195,109,.62);
  box-shadow: 0 32px 74px rgba(0,0,0,.24);
  background: linear-gradient(145deg, rgba(205,165,94,.20), rgba(255,255,255,.06));
}

.architecture-card:hover::before {
  opacity: 1;
  transform: scale(1) rotate(0deg);
}

.architecture-card:hover h3,
.architecture-card:hover p {
  transform: translateY(-2px);
}

.architecture-grid:hover .architecture-card:not(:hover) {
  opacity: .82;
  transform: scale(.985);
}

.assessment-section {
  background: #001B2E;
}

.evolution-section {
  background: #083A5C;
}

.deliverables-section {
  background: #FFFFFF;
  color: var(--text);
}

.deliverables-section h2 {
  color: var(--blue-ink);
}

.deliverables-section .section-head p {
  color: var(--text-soft);
}

.deliverables-section .kicker.light {
  color: var(--blue);
}

.frontier-card {
  background: #FFFFFF;
  border: 1px solid var(--line);
  box-shadow: var(--shadow-soft);
}

.frontier-card.gold-card {
  background: linear-gradient(135deg, rgba(205,165,94,.14), rgba(10,63,99,.035));
  border-color: rgba(205,165,94,.28);
}

.frontier-card h3 {
  color: var(--blue-ink);
}

.frontier-card li {
  color: var(--text-soft);
}

.integration-section {
  background: #001B2E;
}

.ethics-section {
  background: #FFFFFF;
}

.specialist-section {
  background: #083A5C;
}

.contact-section {
  background: #FFFFFF;
  color: var(--text);
}

.contact-copy h2 {
  color: var(--blue-ink);
}

.contact-copy p {
  color: var(--text-soft);
}

.contact-section .kicker.light {
  color: var(--blue);
}

.contact-proof article {
  border: 1px solid var(--line);
  background: #FFFFFF;
  box-shadow: var(--shadow-soft);
}

.contact-proof span {
  color: var(--gold-strong);
}

.contact-proof b {
  color: var(--blue-ink);
  font-weight: 400;
}

.contact-proof p {
  color: var(--text-soft);
}

@media (max-width: 820px) {
  .program-stats article {
    text-align: center;
  }

  .program-stats .stat-label {
    max-width: 150px;
  }
}

@media (max-width: 620px) {
  .program-stats article {
    display: flex;
    justify-content: center;
  }
}

/* AJUSTES V6 — refinamentos pontuais solicitados */
.thesis-card {
  margin-bottom: 24px;
}

.thesis-problem-section .problem-kicker {
  font-weight: 800 !important;
}

.dimensions-section h2 em,
.assessment-section h2 em,
.journey-section h2 em,
.evolution-section h2 em {
  color: var(--gold-light);
  font-style: italic;
  font-weight: 400;
}

.dimensions-section .section-head p,
.dimension-card p,
.journey-section .section-head p,
.timeline-step p {
  color: #001B2E;
}

.journey-section .section-head {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.journey-section .section-head h2 {
  font-weight: 400;
}

.evolution-grid {
  grid-template-columns: minmax(0, 1.08fr) minmax(360px, .92fr);
  gap: 42px;
}

.evolution-section .section-copy {
  max-width: 760px;
  margin-left: clamp(24px, 4vw, 70px);
}

.evolution-section .section-copy h2 {
  font-weight: 400;
}

@media (max-width: 1100px) {
  .evolution-section .section-copy {
    max-width: none;
    margin-left: 0;
  }
}


/* AJUSTES V7 — refinamentos pontuais solicitados */
:root {
  --gold-white: #C17D09;
}

.scroll-progress {
  display: none !important;
}

.thesis-card {
  display: none;
  margin: 0;
}

.thesis-problem-grid {
  margin-top: 0;
}

.thesis-problem-section .problem-kicker,
.thesis-problem-section .problem-kicker strong {
  font-weight: 800 !important;
}

.problem-statement em {
  color: var(--gold-white);
  font-style: italic;
  font-weight: 400;
}

.thesis-problem-section .pain-stack span,
.dimensions-section h2 em,
.journey-section h2 em,
.deliverables-section .kicker.light,
.deliverables-section h2 em,
.deliverables-title-gold,
.ethics-section .ethic-card span,
.faq-section .kicker.dark,
.contact-section .contact-proof span {
  color: var(--gold-white) !important;
}

.dimensions-section h2 em {
  font-style: italic;
  font-weight: 400;
}

.dimensions-grid {
  perspective: 1200px;
}

.dimension-card,
.dimension-card--featured {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 84% 12%, rgba(193,125,9,.28), transparent 34%),
    linear-gradient(145deg, #083A5C 0%, #052B46 76%);
  border-color: rgba(193,125,9,.32);
  box-shadow: 0 18px 44px rgba(0,27,46,.15);
  transform: translateY(0) scale(1);
  transition:
    transform .52s cubic-bezier(.22,1,.36,1),
    box-shadow .52s cubic-bezier(.22,1,.36,1),
    border-color .52s cubic-bezier(.22,1,.36,1),
    opacity .32s ease;
}

.dimension-card::before {
  content: "";
  position: absolute;
  inset: -45% -35%;
  background: radial-gradient(circle at 50% 50%, rgba(193,125,9,.22), transparent 56%);
  opacity: 0;
  transform: scale(.72) rotate(8deg);
  transition: opacity .55s ease, transform .55s cubic-bezier(.22,1,.36,1);
  pointer-events: none;
}

.dimension-card span,
.dimension-card h3,
.dimension-card p {
  position: relative;
  z-index: 1;
}

.dimension-card span {
  color: #f0c36d;
}

.dimension-card h3 {
  color: #ffffff;
}

.dimension-card p {
  color: rgba(255,255,255,.80);
}

.dimension-card:hover {
  transform: translateY(-10px) scale(1.025) rotateX(2deg);
  border-color: rgba(193,125,9,.62);
  box-shadow: 0 32px 74px rgba(0,27,46,.25);
  background:
    radial-gradient(circle at 84% 12%, rgba(193,125,9,.36), transparent 36%),
    linear-gradient(145deg, #083A5C 0%, #031B2B 76%);
}

.dimension-card:hover::before {
  opacity: 1;
  transform: scale(1) rotate(0deg);
}

.dimensions-grid:hover .dimension-card:not(:hover) {
  opacity: .86;
  transform: scale(.985);
}

.timeline-step div {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(193,125,9,.13), rgba(255,255,255,.96) 42%, rgba(193,125,9,.06));
  border-color: rgba(193,125,9,.18);
}

.timeline-step b {
  color: var(--gold-white);
}

.deliverables-section .section-head h2 {
  font-weight: 400;
}

.deliverables-title-line {
  display: block;
}

.deliverables-title-gold {
  color: var(--gold-white);
  font-style: italic;
  font-weight: 400;
}

.frontier-card {
  position: relative;
  overflow: hidden;
  transition:
    transform .48s cubic-bezier(.22,1,.36,1),
    box-shadow .48s cubic-bezier(.22,1,.36,1),
    border-color .48s cubic-bezier(.22,1,.36,1),
    background .48s cubic-bezier(.22,1,.36,1);
}

.frontier-card::before {
  content: "";
  position: absolute;
  inset: -40% -30%;
  background: radial-gradient(circle at 50% 50%, rgba(193,125,9,.18), transparent 58%);
  opacity: 0;
  transform: scale(.75);
  transition: opacity .5s ease, transform .5s cubic-bezier(.22,1,.36,1);
  pointer-events: none;
}

.frontier-card span,
.frontier-card h3,
.frontier-card ul {
  position: relative;
  z-index: 1;
}

.frontier-card:hover {
  transform: translateY(-8px);
  border-color: rgba(193,125,9,.42);
  box-shadow: 0 28px 62px rgba(0,27,46,.16);
}

.frontier-card:hover::before {
  opacity: 1;
  transform: scale(1);
}

.frontier-card.gold-card:hover {
  background: linear-gradient(135deg, rgba(193,125,9,.18), rgba(10,63,99,.04));
}


/* AJUSTES V8 — refinamentos finais solicitados */
/* V9 — correção estrutural e JS sem alterar layout */
.timeline {
  margin-left: auto;
  margin-right: auto;
}

.integration-section .section-head {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
  max-width: 1160px;
}

.integration-section .section-head h2 {
  max-width: 1060px;
  margin-left: auto;
  margin-right: auto;
  font-weight: 400;
  font-size: clamp(2rem, 3vw, 3.25rem);
  line-height: 1.08;
}

.integration-section .section-head h2 span {
  display: block;
}

.integration-section .section-head p {
  max-width: 1020px;
  margin-left: auto;
  margin-right: auto;
}

.integration-grid {
  perspective: 1200px;
}

.integration-grid article {
  position: relative;
  overflow: hidden;
  text-align: center;
  box-shadow: 0 18px 42px rgba(0,0,0,.14);
  transform: translateY(0) scale(1);
  transition:
    transform .52s cubic-bezier(.22,1,.36,1),
    box-shadow .52s cubic-bezier(.22,1,.36,1),
    border-color .52s cubic-bezier(.22,1,.36,1),
    background .52s cubic-bezier(.22,1,.36,1),
    opacity .32s ease;
}

.integration-grid article::before {
  content: "";
  position: absolute;
  inset: -45% -35%;
  background: radial-gradient(circle at 50% 50%, rgba(193,125,9,.22), transparent 56%);
  opacity: 0;
  transform: scale(.72) rotate(8deg);
  transition: opacity .55s ease, transform .55s cubic-bezier(.22,1,.36,1);
  pointer-events: none;
}

.integration-grid article span,
.integration-grid article h3,
.integration-grid article p {
  position: relative;
  z-index: 1;
}

.integration-grid article:hover {
  transform: translateY(-10px) scale(1.025) rotateX(2deg);
  border-color: rgba(193,125,9,.54);
  box-shadow: 0 32px 74px rgba(0,0,0,.24);
  background: linear-gradient(145deg, rgba(193,125,9,.20), rgba(255,255,255,.06));
}

.integration-grid article:hover::before {
  opacity: 1;
  transform: scale(1) rotate(0deg);
}

.integration-grid:hover article:not(:hover) {
  opacity: .86;
  transform: scale(.985);
}

.ethics-section h2 {
  font-weight: 400;
}

.ethics-section .section-head p,
.ethic-card:not(.dark-card) h3,
.ethic-card:not(.dark-card) li {
  color: #001B2E;
}

.ethics-grid {
  perspective: 1200px;
}

.ethic-card {
  position: relative;
  overflow: hidden;
  box-shadow: 0 18px 46px rgba(0,27,46,.14);
  transition:
    transform .5s cubic-bezier(.22,1,.36,1),
    box-shadow .5s cubic-bezier(.22,1,.36,1),
    border-color .5s cubic-bezier(.22,1,.36,1),
    background .5s cubic-bezier(.22,1,.36,1),
    opacity .32s ease;
}

.ethic-card::before {
  content: "";
  position: absolute;
  inset: -45% -35%;
  background: radial-gradient(circle at 50% 50%, rgba(193,125,9,.18), transparent 58%);
  opacity: 0;
  transform: scale(.72) rotate(8deg);
  transition: opacity .5s ease, transform .5s cubic-bezier(.22,1,.36,1);
  pointer-events: none;
}

.ethic-card span,
.ethic-card h3,
.ethic-card ul {
  position: relative;
  z-index: 1;
}

.ethic-card:hover {
  transform: translateY(-10px) scale(1.015);
  border-color: rgba(193,125,9,.42);
  box-shadow: 0 32px 72px rgba(0,27,46,.20);
}

.ethic-card:hover::before {
  opacity: 1;
  transform: scale(1) rotate(0deg);
}

.ethics-grid:hover .ethic-card:not(:hover) {
  opacity: .88;
}

.ethic-card.dark-card li,
.ethic-card.dark-card p,
.ethic-card.dark-card h3 {
  color: rgba(255,255,255,.82);
}

.specialist-card {
  grid-template-columns: .38fr .62fr;
}

.specialist-card h2 {
  font-weight: 400;
}

.specialist-portrait-link {
  display: block;
  border-radius: 24px;
  overflow: hidden;
  background: #ffffff;
  box-shadow: 0 28px 64px rgba(0,27,46,.28);
  border: 1px solid rgba(193,125,9,.24);
  transition: transform .45s cubic-bezier(.22,1,.36,1), box-shadow .45s cubic-bezier(.22,1,.36,1), border-color .45s ease;
}

.specialist-portrait-link:hover {
  transform: translateY(-8px) scale(1.015);
  box-shadow: 0 36px 82px rgba(0,27,46,.34);
  border-color: rgba(193,125,9,.54);
}

.specialist-portrait-link img {
  width: 100%;
  height: auto;
  display: block;
}

.help-center-section {
  background: #ffffff;
  padding: 72px 0;
}

.help-center-section .container {
  width: min(1420px, calc(100vw - 48px));
}

.help-center-header {
  margin: 0 auto 26px;
  max-width: 1080px;
  text-align: center;
}

.help-center-title {
  margin: 0 0 14px;
  color: #0a2438;
  font-family: var(--font-title);
  font-weight: 400;
  font-size: clamp(2.4rem, 4vw, 4rem);
  line-height: 1.02;
  letter-spacing: -0.03em;
}

.help-center-lead {
  margin: 0 auto;
  max-width: 980px;
  color: #355067;
  font-family: var(--font-body);
  font-size: 1.12rem;
  line-height: 1.55;
}

.help-center-panel {
  max-width: 1420px;
  margin: 0 auto;
  background: #ffffff;
  border: 1px solid rgba(8, 53, 86, 0.20);
  border-radius: 16px;
  overflow: hidden;
}

.help-center-content {
  min-width: 0;
}

.faq-group {
  margin: 0;
}

.faq-group-title {
  display: none;
}

.help-center-section .faq-item {
  margin: 0;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  background: #ffffff;
}

.help-center-section .faq-item + .faq-item {
  border-top: 1px solid rgba(8, 53, 86, 0.16);
}

.faq-question {
  width: 100%;
  min-height: 84px;
  border: 0;
  border-radius: 0;
  background: #ffffff;
  color: #0a2438;
  padding: 0 38px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  font-family: var(--font-body);
  font-size: 1.08rem;
  font-weight: 500;
  cursor: pointer;
  text-align: left;
}

.faq-question:hover {
  background: #fafbfd;
}

.faq-icon {
  flex: 0 0 auto;
  color: #0a2438;
  font-size: 18px;
  line-height: 1;
  transition: transform .28s ease;
}

.faq-item.is-open .faq-icon {
  transform: rotate(180deg);
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  padding: 0 38px;
  transition:
    max-height .34s ease,
    opacity .22s ease,
    padding-top .34s ease,
    padding-bottom .34s ease;
}

.faq-item.is-open .faq-answer {
  max-height: 520px;
  opacity: 1;
  padding-top: 0;
  padding-bottom: 26px;
}

.faq-answer p {
  margin: 0;
  max-width: 1280px;
  color: #355067;
  font-family: var(--font-body);
  font-size: 1.04rem;
  line-height: 1.7;
}

.contact-section {
  background: #ffffff;
  padding: 72px 0;
}

.contact-section .container {
  width: var(--container);
}

.contact-shell {
  display: grid;
  grid-template-columns: minmax(320px, 1fr) minmax(620px, 1.18fr);
  gap: 0;
  background: linear-gradient(180deg, #0a3f63 0%, #052b46 100%);
  border: 0;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(2, 18, 31, 0.18);
  padding: 0;
}

.contact-copy-side {
  min-width: 0;
  padding: 56px;
  color: #ffffff;
  display: flex;
  align-items: center;
  background:
    radial-gradient(circle at 18% 16%, rgba(209, 162, 69, 0.10), transparent 28%),
    linear-gradient(180deg, #0d2740 0%, #083a5d 100%);
  border-right: 28px solid #ffffff;
}

.contact-copy-inner {
  max-width: 520px;
}

.contact-title-display {
  margin: 0 0 14px;
  color: #ffffff;
  font-family: var(--font-title);
  font-weight: 700;
  font-size: clamp(3rem, 4vw, 4.2rem);
  line-height: .95;
  letter-spacing: 0;
}

.contact-subtitle {
  margin: 0 0 16px;
  color: #cda55e;
  font-family: var(--font-title);
  font-size: clamp(1.35rem, 2vw, 2rem);
  line-height: 1.1;
  font-style: italic;
  font-weight: 400;
}

.contact-copy-text {
  margin: 0;
  color: rgba(255,255,255,.86) !important;
  font-size: 1rem;
  line-height: 1.62;
}

.contact-form-side {
  padding: 38px 42px 40px;
  background: #ffffff;
}

.contact-shell .contact-form {
  background: transparent;
  box-shadow: none;
  border-radius: 0;
  padding: 0;
  color: var(--text);
}

.contact-shell .contact-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  align-items: initial;
}

.contact-shell .contact-grid + .contact-grid {
  margin-top: 16px;
}

.contact-shell .contact-grid-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.contact-shell .contact-grid-phone {
  grid-template-columns: minmax(180px, .8fr) 100px minmax(220px, 1fr);
}

.contact-field {
  display: grid;
  gap: 7px;
  margin: 0;
}

.contact-label {
  color: #083a5d;
  font-weight: 700;
  font-size: .9rem;
}

.contact-label.is-error {
  color: #b3261e;
}

.contact-input,
.contact-textarea,
.contact-select {
  width: 100%;
  min-height: 48px;
  height: auto;
  padding: 12px 14px;
  border: 1px solid rgba(8, 53, 86, 0.16);
  border-radius: 10px;
  background: #f7f9fb;
  color: #0d2740;
  font-family: var(--font-body);
  font-size: .96rem;
  outline: none;
  box-shadow: none;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  transition: border-color .2s ease, background .2s ease, box-shadow .2s ease;
}

.contact-input:focus,
.contact-textarea:focus,
.contact-select:focus {
  border-color: #cda55e;
  background: #ffffff;
  box-shadow: 0 0 0 4px rgba(205, 165, 94, 0.12);
}

.contact-input.is-error,
.contact-textarea.is-error,
.contact-select.is-error {
  border-color: #b3261e;
  box-shadow: 0 0 0 4px rgba(179, 38, 30, 0.08);
}

.contact-input-disabled {
  background: #eef3f7;
  color: #4b5c6b;
}

.contact-textarea {
  resize: vertical;
  min-height: 118px;
}

.contact-disclaimer {
  font-size: .78rem;
  color: #5b6775;
  line-height: 1.45;
  margin: 14px 0 0;
  max-width: none;
}

.contact-actions {
  padding-top: 18px;
}

.contact-submit {
  background: #cda55e;
  color: #102033;
  border: 0;
  padding: 14px 32px;
  border-radius: 14px;
  min-width: 190px;
  height: auto;
  font-weight: 700;
  font-size: 1rem;
  box-shadow: 0 16px 28px rgba(209, 162, 69, .22);
  cursor: pointer;
  transition: transform .2s ease, background .2s ease, box-shadow .2s ease;
}

.contact-submit:hover {
  background: #dfb45e;
  transform: translateY(-1px);
}

@media (max-width: 1100px) {
  .contact-shell {
    grid-template-columns: 1fr;
  }

  .contact-copy-side {
    border-right: 0;
    border-bottom: 18px solid #ffffff;
  }
}

@media (max-width: 980px) {
  .help-center-section .container {
    width: calc(100vw - 28px);
  }

  .help-center-title {
    font-size: clamp(2.1rem, 6vw, 3.4rem);
  }

  .faq-question {
    min-height: 76px;
    padding: 0 26px;
    font-size: 1rem;
  }

  .faq-answer {
    padding-left: 26px;
    padding-right: 26px;
  }
}

@media (max-width: 820px) {
  .integration-section .section-head h2 span {
    display: inline;
  }

  .specialist-card {
    grid-template-columns: 1fr;
  }

  .help-center-section {
    padding: 44px 0 22px;
  }

  .help-center-section .container {
    width: calc(100vw - 18px);
  }

  .help-center-header {
    margin-bottom: 20px;
  }

  .faq-question {
    min-height: 70px;
    padding: 0 18px;
    font-size: .98rem;
    line-height: 1.28;
  }

  .faq-icon {
    font-size: 16px;
  }

  .faq-answer {
    padding-left: 18px;
    padding-right: 18px;
  }

  .faq-answer p {
    font-size: .96rem;
    line-height: 1.54;
  }

  .contact-section {
    padding: 28px 0 42px;
  }

  .contact-shell {
    border-radius: 22px;
  }

  .contact-copy-side {
    padding: 40px 22px 14px;
  }

  .contact-form-side {
    padding: 26px 22px 24px;
  }

  .contact-title-display {
    font-size: clamp(2.8rem, 13vw, 4.4rem);
    line-height: .92;
    margin-bottom: 16px;
  }

  .contact-subtitle {
    font-size: clamp(1.05rem, 6vw, 1.6rem);
    margin-bottom: 14px;
  }

  .contact-copy-text {
    font-size: .96rem;
    line-height: 1.56;
  }

  .contact-shell .contact-grid-2,
  .contact-shell .contact-grid-phone {
    grid-template-columns: 1fr;
  }

  .contact-input,
  .contact-textarea,
  .contact-select {
    min-height: 50px;
  }

  .contact-textarea {
    min-height: 160px;
  }

  .contact-submit {
    width: 100%;
    min-width: 0;
  }
}

/* AJUSTES V10 — cabeçalho, rodapé e formulário modelados pela Home + refinamentos solicitados */
/* HEADER */

.site-header {
  --header-height: 82px;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 9998;
  background: #0a3f63;
  backdrop-filter: blur(10px);
  border-bottom: none;
}

.site-header::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 4px;
  background: #cda55e;
}

.site-header__inner {
  min-height: var(--header-height);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
}

.brand {
  position: relative;
  z-index: 82;
  flex: 0 0 auto;
}

.brand img {
  width: 152px;
  height: auto;
}

.nav-toggle {
  display: none;
  width: 46px;
  height: 46px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: transparent;
  color: #fff;
  position: relative;
  z-index: 82;
}

.site-nav {
  margin-left: auto;
  position: relative;
  z-index: 81;
}

.site-nav__list,
.site-nav ul {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 28px;
  padding: 0;
  margin: 0;
}

.site-nav__item {
  position: relative;
}

.site-nav__link,
.site-nav__button {
  color: rgba(255,255,255,.92);
  font-size: 1rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.site-nav__button {
  border: 0 !important;
  background: transparent !important;
  cursor: pointer;
  padding: 0 !important;
  margin: 0;
  box-shadow: none !important;
  border-radius: 0 !important;
  appearance: none !important;
  -webkit-appearance: none !important;
}

.site-nav__caret {
  font-size: .72rem;
  line-height: 1;
  transform: translateY(1px);
}

.site-nav__link:hover,
.site-nav__link.active,
.site-nav__item:hover > .site-nav__link,
.site-nav__item:hover > .site-nav__button,
.site-nav__item.is-open > .site-nav__button {
  color: var(--gold);
}

/* LOGIN HEADER — V425 */
.site-nav__item--login {
  position: absolute;
  left: calc(100% + 28px);
  top: 50%;
  transform: translateY(-50%);
  z-index: 82;
}

.site-nav__login {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 22px;
  border-radius: 999px;
  background: var(--gold);
  color: #083a5d;
  font-size: 0.95rem;
  line-height: 1;
  font-weight: 800;
  letter-spacing: 0.01em;
  box-shadow: none;
  white-space: nowrap;
  transition: transform .2s ease, background .2s ease;
}

.site-nav__login:hover {
  background: #dfb45e;
  color: #083a5d;
  transform: translateY(-1px);
}

@media (max-width: 1160px) and (min-width: 821px) {
  .site-nav__item--login {
    left: calc(100% + 18px);
  }

  .site-nav__login {
    min-height: 36px;
    padding: 0 18px;
    font-size: 0.92rem;
  }
}

@media (max-width: 820px) {
  .site-nav__item--login {
    position: static;
    left: auto;
    top: auto;
    transform: none;
    z-index: auto;
  }

  .site-nav__login {
    width: 100%;
    min-height: 42px;
    padding: 0 16px;
    border-radius: 10px;
    justify-content: center;
  }
}

.mega-menu {
  position: fixed;
  left: 50%;
  top: calc(var(--header-height) + 10px);
  transform: translateX(-50%);
  width: min(1180px, calc(100vw - 56px));
  background: rgba(255, 255, 255, 0.985);
  border-radius: 14px;
  box-shadow: 0 18px 42px rgba(2, 18, 31, 0.18);
  padding: 18px 26px 22px;
  display: grid;
  gap: 22px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  z-index: 9999;
}

.mega-menu::before {
  content: "";
  position: absolute;
  inset: -12px 0 auto;
  height: 12px;
}

.mega-menu--3col {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.mega-menu--4col {
  width: min(1260px, calc(100vw - 56px));
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.mega-menu--content,
.mega-menu--about {
  left: 50%;
  transform: translateX(-50%);
}

.site-nav__item--has-mega:hover > .mega-menu,
.site-nav__item--has-mega:focus-within > .mega-menu,
.site-nav__item--has-mega.is-open > .mega-menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.mega-menu__card {
  min-width: 0;
  text-decoration: none;
}

.mega-menu__heading {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}

.mega-menu__icon {
  width: 22px;
  height: 22px;
  object-fit: contain;
  flex: 0 0 22px;
}

.mega-menu__title {
  margin: 0;
  color: #cda55e;
  font-size: 1rem;
  line-height: 1.2;
  font-weight: 700;
}

.mega-menu__text {
  margin: 0;
  color: #21394d;
  font-size: .98rem;
  line-height: 1.28;
}

@media (max-width: 1160px) {
  .site-nav__list,
  .site-nav ul {
    gap: 22px;
  }

  .mega-menu {
    width: min(1060px, calc(100vw - 48px));
  }

  .mega-menu--4col {
    width: min(1120px, calc(100vw - 48px));
  }
}

@media (max-width: 980px) {
  .site-nav__list,
  .site-nav ul {
    gap: 18px;
  }

  .site-nav__link,
  .site-nav__button {
    font-size: .96rem;
  }

  .mega-menu,
  .mega-menu--4col {
    width: calc(100vw - 44px);
  }
}

@media (max-width: 820px) {
  .site-header {
    --header-height: 72px;
  }

  .nav-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

.site-nav {
  position: absolute;
  top: calc(100% + 8px);
  right: 16px;
  left: 16px;
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(8, 53, 86, 0.08);
  border-radius: 12px;
  padding: 12px 14px;
  display: none;
  box-shadow: 0 8px 18px rgba(2, 18, 31, 0.08);
  backdrop-filter: blur(6px);
}

  .site-nav.is-open { display: block; }

  .site-nav__link,
  .site-nav__button {
    color: #083a5d;
  }

  .site-nav__caret {
    color: #cda55e;
  }

  .site-nav__list,
.site-nav ul {
  flex-direction: column;
  align-items: stretch;
  gap: 10px;
}

  .site-nav__link,
  .site-nav__button {
    width: 100%;
    justify-content: space-between;
    font-size: 1rem;
  }

    .mega-menu,
.mega-menu--4col {
  position: static;
  left: auto;
  top: auto;
  transform: none;
  width: 100%;
  margin-top: 8px;
  padding: 10px 12px;
  display: none;
  grid-template-columns: 1fr;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(8, 53, 86, 0.06);
  border-radius: 10px;
  box-shadow: none;
}

  .site-nav__item--has-mega.is-open > .mega-menu {
    display: grid;
  }

.mega-menu__card + .mega-menu__card {
  border-top: 1px solid rgba(8, 53, 86, 0.07);
  padding-top: 10px;
}

  .mega-menu__text {
    font-size: .94rem;
    line-height: 1.32;
  }
}
/* FOOTER */

.site-footer {
  background: #083a5d;
  color: #fff;
  padding-top: 38px;
}

.site-footer__grid {
  display: grid;
  grid-template-columns: 1.55fr 1fr 1fr 1fr 1.15fr;
  gap: 44px;
  align-items: start;
}

.footer-brand img {
  width: 320px;
  max-width: 100%;
  height: auto;
}

.footer-address {
  margin-top: 22px;
  color: rgba(255,255,255,.95);
  line-height: 1.45;
  font-size: .98rem;
}

.footer-social {
  margin-top: 48px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.footer-social-link {
  width: 44px;
  height: 44px;
  border-radius: 8px;
  background: #f2f2f2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform .2s ease, opacity .2s ease;
}

.footer-social-link:hover {
  transform: translateY(-2px);
  opacity: .95;
}

.footer-social-link img {
  width: 24px;
  height: 24px;
  object-fit: contain;
}

.footer-column h4 {
  margin: 0 0 14px;
  font-size: 1.05rem;
  font-weight: 700;
  color: #fff;
}

.footer-column a,
.footer-column span {
  display: block;
  margin: 0 0 10px;
  color: rgba(255,255,255,.92);
  font-size: .96rem;
  line-height: 1.3;
}

.footer-column a:hover {
  color: var(--gold);
}

.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.1);
  margin-top: 34px;
  padding: 18px 0 22px;
  text-align: center;
  color: rgba(255,255,255,.9);
  font-size: .92rem;
}
/* ===== FORMULÁRIO FALE CONOSCO ===== */

.contact-section {
  background: #ffffff;
  padding: 44px 0 86px;
}

.contact-section .container {
  width: min(1360px, calc(100vw - 34px));
}

.contact-shell {
  background: #ffffff;
  border: 2px solid rgba(8, 53, 86, 0.78);
  border-radius: 18px;
  padding: 34px 28px 28px;
  display: grid;
  grid-template-columns: minmax(320px, 0.92fr) minmax(620px, 1.2fr);
  column-gap: 72px;
  align-items: start;
}

.contact-copy-side {
  min-width: 0;
  padding: 18px 0 0 6px;
}

.contact-copy-inner {
  max-width: 520px;
}

.contact-title-display {
  margin: 0 0 22px;
  color: #083a5d;
  font-family: var(--font-body);
  font-weight: 800;
  font-size: clamp(4rem, 6vw, 6.2rem);
  line-height: 0.9;
  letter-spacing: -0.04em;
}

.contact-subtitle {
  margin: 0 0 16px;
  color: #083a5d;
  font-family: var(--font-body);
  font-size: clamp(2rem, 2.1vw, 3rem);
  line-height: 1.08;
  font-weight: 800;
}

.contact-copy-text {
  margin: 0;
  max-width: 520px;
  color: #083a5d;
  font-family: var(--font-body);
  font-size: 1.08rem;
  line-height: 1.6;
}

.contact-form-side {
  min-width: 0;
  max-width: none;
  padding-left: 0;
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.contact-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}

.contact-grid-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.contact-grid-phone {
  grid-template-columns: 150px 96px minmax(0, 1fr);
  gap: 14px;
}

.contact-field {
  position: relative;
}

.contact-label {
  position: absolute;
  top: -12px;
  left: 12px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 12px;
  border-radius: 4px;
  background: #0a3f63;
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  line-height: 1;
  white-space: nowrap;
}

.contact-label-static {
  background: #0a3f63;
}

.contact-label.is-error {
  background: #d73a30;
  color: #fff;
}

.contact-input {
  width: 100%;
  height: 48px;
  border: 1.5px solid rgba(55, 55, 55, 0.55);
  border-radius: 2px;
  background: #ffffff;
  color: #202020;
  padding: 10px 12px;
  font-size: 14px;
  outline: none;
  box-shadow: none;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}

.contact-input:focus {
  border-color: #083a5d;
}

.contact-input-disabled {
  background: #ffffff;
  color: #202020;
}

.contact-select {
  background-image:
    linear-gradient(45deg, transparent 50%, #083a5d 50%),
    linear-gradient(135deg, #083a5d 50%, transparent 50%);
  background-position:
    calc(100% - 18px) calc(50% - 3px),
    calc(100% - 12px) calc(50% - 3px);
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  padding-right: 34px;
}

.contact-textarea {
  height: 122px;
  min-height: 122px;
  resize: none;
  padding-top: 14px;
}

.contact-disclaimer {
  margin: 2px 0 0;
  max-width: 760px;
  color: #3e3e3e;
  font-size: 12.5px;
  line-height: 1.45;
}

.contact-actions {
  display: flex;
  justify-content: flex-start;
  padding-top: 4px;
}

.contact-submit {
  min-width: 180px;
  height: 52px;
  border: 1px solid #083a5d;
  border-radius: 4px;
  background: #083a5d;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  cursor: pointer;
  transition: transform .2s ease, background .2s ease;
}

.contact-submit:hover {
  transform: translateY(-1px);
  background: #062d48;
}

.contact-disclaimer a {
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1.5px;
  color: inherit;
}

.contact-disclaimer a:hover {
  color: #cda55e;
}

@media (max-width: 1100px) {
  .contact-shell {
    grid-template-columns: 1fr;
    row-gap: 28px;
    padding: 28px 22px 24px;
  }

  .contact-copy-side {
    padding: 0;
  }

  .contact-copy-inner {
    max-width: 760px;
  }

  .contact-title-display {
    font-size: clamp(3.4rem, 8vw, 5.2rem);
    margin-bottom: 18px;
  }

  .contact-subtitle {
    font-size: clamp(1.7rem, 3.5vw, 2.4rem);
  }
}

@media (max-width: 820px) {
  .contact-section {
    padding: 26px 0 42px;
  }

  .contact-section .container {
    width: calc(100vw - 18px);
  }

  .contact-shell {
    background: #ffffff;
    border: 2px solid rgba(8, 53, 86, 0.78);
    border-radius: 18px;
    padding: 24px 16px 22px;
    row-gap: 20px;
    grid-template-columns: 1fr;
  }

  .contact-title-display {
    font-size: clamp(2.8rem, 13vw, 4.9rem);
    line-height: 0.9;
    margin-bottom: 16px;
  }

  .contact-subtitle {
    font-size: clamp(1.1rem, 6.8vw, 2.1rem);
    line-height: 1.12;
    margin-bottom: 14px;
  }

  .contact-copy-text {
    font-size: 0.98rem;
    line-height: 1.56;
  }

  .contact-grid-2,
  .contact-grid-phone {
    grid-template-columns: 1fr;
  }

  .contact-input {
    height: 50px;
  }

  .contact-textarea {
    height: 160px;
    min-height: 160px;
  }

  .contact-disclaimer {
    max-width: 100%;
    font-size: 12px;
    line-height: 1.5;
  }

  .contact-actions {
    padding-top: 6px;
  }

  .contact-submit {
    width: 100%;
    min-width: 0;
    height: 56px;
    border-radius: 8px;
    font-size: 15px;
  }
}

@media (max-width: 560px) {
  .contact-title-display {
    font-size: clamp(2.6rem, 14vw, 4.2rem);
  }

  .contact-subtitle {
    font-size: clamp(1rem, 7vw, 1.7rem);
  }

  .contact-copy-text {
    font-size: 0.94rem;
  }
}
/* ===== CENTRAL DE AJUDA / FAQ ===== */

.help-center-section {
  background: #ffffff;
  padding: 56px 0 36px;
}

.help-center-section .container {
  width: min(1420px, calc(100vw - 48px));
}

.help-center-header {
  margin: 0 auto 26px;
  max-width: 1080px;
  text-align: center;
}

.help-center-title {
  margin: 0 0 14px;
  color: #0a2438;
  font-family: var(--font-title);
  font-size: clamp(2.4rem, 4vw, 4rem);
  line-height: 1.02;
  letter-spacing: -0.03em;
}

.help-center-title .gold {
  color: #cda55e;
}

.help-center-lead {
  margin: 0 auto;
  max-width: 980px;
  color: #355067;
  font-family: var(--font-body);
  font-size: 1.12rem;
  line-height: 1.55;
}

.help-center-panel {
  max-width: 1420px;
  margin: 0 auto;
  background: #ffffff;
  border: 1px solid rgba(8, 53, 86, 0.14);
  border-radius: 16px;
  overflow: hidden;
}

.help-center-content {
  min-width: 0;
}

.faq-group {
  margin: 0;
}

.faq-group + .faq-group {
  border-top: 1px solid rgba(8, 53, 86, 0.10);
}

.faq-group-title {
  display: none;
}

.faq-item {
  margin: 0;
}

.faq-item + .faq-item {
  border-top: 1px solid rgba(8, 53, 86, 0.10);
}

.faq-question {
  width: 100%;
  min-height: 84px;
  border: 0;
  border-radius: 0;
  background: #ffffff;
  color: #0a2438;
  padding: 0 38px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  font-family: var(--font-body);
  font-size: 1.08rem;
  font-weight: 500;
  cursor: pointer;
  text-align: left;
}

.faq-question:hover {
  background: #fafbfd;
}

.faq-item.is-open .faq-question {
  background: #ffffff;
  color: #0a2438;
}

.faq-icon {
  flex: 0 0 auto;
  color: #0a2438;
  font-size: 18px;
  line-height: 1;
  transition: transform .28s ease;
}

.faq-item.is-open .faq-icon {
  transform: rotate(180deg);
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  padding: 0 38px;
  transition:
    max-height 0.34s ease,
    opacity 0.22s ease,
    padding-top 0.34s ease,
    padding-bottom 0.34s ease;
}

.faq-item.is-open .faq-answer {
  max-height: 520px;
  opacity: 1;
  padding-top: 0;
  padding-bottom: 26px;
}

.faq-answer p {
  margin: 0;
  max-width: 1280px;
  color: #355067;
  font-family: var(--font-body);
  font-size: 1.04rem;
  line-height: 1.7;
}

@media (max-width: 980px) {
  .help-center-section .container {
    width: calc(100vw - 28px);
  }

  .help-center-title {
    font-size: clamp(2.1rem, 6vw, 3.4rem);
  }

  .help-center-lead {
    font-size: 1rem;
    line-height: 1.5;
  }

  .faq-question {
    min-height: 76px;
    padding: 0 26px;
    font-size: 1rem;
  }

  .faq-answer {
    padding-left: 26px;
    padding-right: 26px;
  }

  .faq-answer p {
    font-size: 0.98rem;
    line-height: 1.62;
  }
}

@media (max-width: 820px) {
  .help-center-section {
    padding: 44px 0 22px;
  }

  .help-center-section .container {
    width: calc(100vw - 18px);
  }

  .help-center-header {
    margin-bottom: 20px;
  }

  .help-center-title {
    font-size: clamp(2rem, 10vw, 3.4rem);
    line-height: 0.98;
  }

  .help-center-lead {
    max-width: 94%;
    font-size: 0.98rem;
    line-height: 1.48;
  }

  .help-center-panel {
    border-radius: 14px;
  }

  .faq-question {
    min-height: 70px;
    padding: 0 18px;
    font-size: 0.98rem;
    line-height: 1.28;
  }

  .faq-icon {
    font-size: 16px;
  }

  .faq-answer {
    padding-left: 18px;
    padding-right: 18px;
  }

  .faq-item.is-open .faq-answer {
    padding-bottom: 20px;
  }

  .faq-answer p {
    font-size: 0.96rem;
    line-height: 1.54;
  }
}
/* =========================================================
   AJUSTE V269 — SEPARAÇÃO VISUAL DO FORMULÁRIO
========================================================= */

.contact-shell {
  background: #ffffff !important;
  border-right-color: transparent !important;
}

.contact-copy-side {
  background:
    radial-gradient(circle at 18% 16%, rgba(209, 162, 69, 0.10), transparent 28%),
    linear-gradient(180deg, #0d2740 0%, #083a5d 100%) !important;
  border-right: 28px solid #ffffff !important;
}

.contact-form-side {
  background: #ffffff !important;
  padding-left: 18px !important;
}
/* =========================================================
   AJUSTE V270 — AUMENTAR APENAS TEXTOS DA ÁREA AZUL
========================================================= */

.contact-title-display {
  font-size: clamp(3.45rem, 4.6vw, 4.8rem) !important;
  line-height: 0.94 !important;
  margin-bottom: 16px !important;
}

.contact-subtitle {
  font-size: 1.46rem !important;
  line-height: 1.24 !important;
  margin-bottom: 18px !important;
}

.contact-copy-text {
  font-size: 1.28rem !important;
  line-height: 1.58 !important;
  max-width: 560px !important;
}

@media (max-width: 1100px) {
  .contact-title-display {
    font-size: clamp(3.5rem, 8.6vw, 5.5rem) !important;
  }

  .contact-subtitle {
    font-size: clamp(1.45rem, 3.8vw, 2rem) !important;
  }

  .contact-copy-text {
    font-size: 1.16rem !important;
  }
}

@media (max-width: 820px) {
  .contact-title-display {
    font-size: clamp(3.15rem, 13.5vw, 5.1rem) !important;
  }

  .contact-subtitle {
    font-size: clamp(1.28rem, 6.2vw, 1.82rem) !important;
    line-height: 1.2 !important;
  }

  .contact-copy-text {
    font-size: 1.06rem !important;
    line-height: 1.56 !important;
  }
}
/* =========================================================
   AJUSTES V386 — IMS MOBILE + FORMULÁRIO MOBILE
   Escopo: remover gradiente do IMS mobile, texto azul escuro e formulário com apenas a área textual em azul.
========================================================= */

@media (max-width: 820px) {
  .slide-ims .hero-slide__overlay {
    display: none !important;
    background: transparent !important;
  }

  .slide-ims .ims-main-title,
  .slide-ims .hero-copy,
  .slide-ims .hero-copy:first-of-type,
  .slide-ims .hero-copy:last-of-type {
    color: #083a5d !important;
  }

  .contact-shell {
    background: #ffffff !important;
    border-color: rgba(8, 53, 86, 0.18) !important;
  }

  .contact-copy-side {
    background: linear-gradient(180deg, #0d2740 0%, #083a5d 100%) !important;
    border-right: 0 !important;
  }

  .contact-form-side {
    background: #ffffff !important;
    padding: 8px 16px 18px !important;
  }

  .contact-label,
  .contact-label-static {
    color: #5b6775 !important;
  }

  .contact-input,
  .contact-select,
  .contact-textarea,
  .contact-input-disabled {
    background: #ffffff !important;
    color: #0d2740 !important;
    border-color: rgba(8, 53, 86, 0.16) !important;
    box-shadow: none !important;
  }

  .contact-input:focus,
  .contact-select:focus,
  .contact-textarea:focus {
    background: #ffffff !important;
    border-color: #cda55e !important;
    box-shadow: 0 0 0 4px rgba(205, 165, 94, 0.12) !important;
  }

  .contact-disclaimer {
    color: #5b6775 !important;
  }

  .contact-disclaimer a {
    color: #083a5d !important;
  }
}

/* Correções de contexto da página Treino Cognitivo */
main { padding-top: 82px; }
@media (max-width: 820px) { main { padding-top: 72px; } }
.anchor-preserve { position: relative; top: -82px; display: block; height: 0; width: 0; overflow: hidden; }
@media (max-width: 820px) { .anchor-preserve { top: -72px; } }

/* Renata — espaçamento e destaque solicitado */
.specialist-card { gap: 54px; }
.specialist-card > div:last-child { display: flex; flex-direction: column; gap: 20px; }
.specialist-card .kicker { margin-bottom: 4px; }
.specialist-card h2 { margin: 0; font-weight: 400; }
.specialist-card h2 em { color: #C17D09; font-style: italic; font-weight: 400; }
.specialist-card p { margin: 0; }
.specialist-card p + p { margin-top: 0; }

/* Formulário no contexto da subpágina */
.contact-section { background: #ffffff !important; }
.contact-section .container { width: min(1360px, calc(100vw - 34px)) !important; }
.contact-shell .contact-form { background: transparent !important; box-shadow: none !important; border-radius: 0 !important; padding: 0 !important; color: var(--text) !important; }
.contact-grid { align-items: start; }
.contact-form-side { min-width: 0; }

/* FAQ igual Central de Ajuda da Home */
.help-center-section .faq-item { background: #ffffff; }
.help-center-section .faq-item + .faq-item { border-top: 1px solid rgba(8, 53, 86, 0.10); }
.help-center-title { font-weight: 400; }

/* Header da Home em contexto de subpágina */
.mega-menu__heading { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.mega-menu__icon { width: 22px; height: 22px; object-fit: contain; flex: 0 0 22px; }
.mega-menu__card.is-current { background: transparent; padding: 0; margin: 0; }

/* =========================================================
   AJUSTE V11 — FORMULÁRIO IDÊNTICO AO DA HOME
   Escopo: corrigir somente o visual do formulário Fale Conosco.
========================================================= */

.contact-section {
  background: #ffffff !important;
  padding: 56px 0 150px !important;
}

.contact-section .container {
  width: min(1360px, calc(100vw - 34px)) !important;
}

.contact-shell {
  position: relative !important;
  display: grid !important;
  grid-template-columns: minmax(250px, 0.76fr) minmax(520px, 1.24fr) !important;
  column-gap: 28px !important;
  row-gap: 0 !important;
  align-items: stretch !important;
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: 22px !important;
  border: 1px solid rgba(8, 53, 86, 0.18) !important;
  border-right-color: transparent !important;
  background: #ffffff !important;
  box-shadow:
    0 0 0 1px rgba(8, 53, 86, 0.24),
    0 0 60px rgba(2, 18, 31, 0.34),
    0 0 120px rgba(2, 18, 31, 0.20) !important;
}

.contact-copy-side {
  min-width: 0 !important;
  padding: 30px 24px 26px 34px !important;
  background:
    radial-gradient(circle at 18% 16%, rgba(209, 162, 69, 0.10), transparent 28%),
    linear-gradient(180deg, #0d2740 0%, #083a5d 100%) !important;
  border-right: 28px solid #ffffff !important;
  color: #ffffff !important;
  display: flex !important;
  align-items: center !important;
  min-height: 100% !important;
}

.contact-copy-inner {
  max-width: 360px !important;
}

.contact-title-display {
  margin: 0 0 16px !important;
  color: #ffffff !important;
  font-family: var(--font-title) !important;
  font-weight: 700 !important;
  font-size: clamp(3.45rem, 4.6vw, 4.8rem) !important;
  line-height: 0.94 !important;
  letter-spacing: 0 !important;
}

.contact-subtitle {
  margin: 0 0 18px !important;
  color: #d1a245 !important;
  font-family: var(--font-title) !important;
  font-style: italic !important;
  font-weight: 400 !important;
  font-size: 1.46rem !important;
  line-height: 1.24 !important;
}

.contact-copy-text {
  margin: 0 !important;
  max-width: 560px !important;
  color: rgba(255, 255, 255, 0.92) !important;
  font-family: var(--font-body) !important;
  font-size: 1.28rem !important;
  line-height: 1.58 !important;
}

.contact-form-side {
  min-width: 0 !important;
  max-width: none !important;
  padding: 18px 18px 18px 18px !important;
  background: #ffffff !important;
}

.contact-shell .contact-form,
.contact-form {
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  color: var(--text) !important;
}

.contact-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 8px !important;
  margin: 0 0 9px !important;
  align-items: start !important;
}

.contact-grid-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.contact-grid-phone {
  grid-template-columns: 118px 74px minmax(0, 1fr) !important;
  gap: 8px !important;
}

.contact-field {
  position: relative !important;
  display: block !important;
  min-width: 0 !important;
  margin: 0 !important;
}

.contact-label,
.contact-label-static {
  position: static !important;
  top: auto !important;
  left: auto !important;
  z-index: auto !important;
  display: block !important;
  align-items: initial !important;
  min-height: 0 !important;
  padding: 0 !important;
  margin: 0 0 5px !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: #415262 !important;
  font-size: 13.5px !important;
  font-weight: 600 !important;
  line-height: 1.22 !important;
  white-space: normal !important;
}

.contact-label.is-error {
  background: transparent !important;
  color: #d73a30 !important;
}

.contact-input,
.contact-select {
  width: 100% !important;
  height: 36px !important;
  min-height: 36px !important;
  padding: 6px 10px !important;
  border: 1px solid rgba(8, 53, 86, 0.18) !important;
  border-radius: 10px !important;
  background-color: #f7f9fb !important;
  color: #0d2740 !important;
  font-family: var(--font-body) !important;
  font-size: 13.5px !important;
  line-height: 1.2 !important;
  outline: none !important;
  box-shadow: none !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease !important;
}

.contact-textarea {
  width: 100% !important;
  height: 64px !important;
  min-height: 64px !important;
  padding: 10px !important;
  border: 1px solid rgba(8, 53, 86, 0.18) !important;
  border-radius: 10px !important;
  background: #f7f9fb !important;
  color: #0d2740 !important;
  font-family: var(--font-body) !important;
  font-size: 13.5px !important;
  line-height: 1.35 !important;
  resize: none !important;
  outline: none !important;
  box-shadow: none !important;
}

.contact-input:focus,
.contact-select:focus,
.contact-textarea:focus {
  border-color: #d1a245 !important;
  background: #ffffff !important;
  box-shadow: 0 0 0 3px rgba(209, 162, 69, 0.12) !important;
}

.contact-input.is-error,
.contact-select.is-error,
.contact-textarea.is-error {
  border-color: #d73a30 !important;
  box-shadow: 0 0 0 3px rgba(215, 58, 48, 0.10) !important;
}

.contact-select {
  padding-right: 30px !important;
  background-image:
    linear-gradient(45deg, transparent 50%, #083a5d 50%),
    linear-gradient(135deg, #083a5d 50%, transparent 50%) !important;
  background-position:
    calc(100% - 16px) calc(50% - 3px),
    calc(100% - 11px) calc(50% - 3px) !important;
  background-size: 5px 5px, 5px 5px !important;
  background-repeat: no-repeat !important;
}

.contact-input-disabled {
  background: #eef3f7 !important;
  color: #4a5a6a !important;
}

.contact-disclaimer {
  margin: 4px 0 0 !important;
  max-width: none !important;
  color: #3f5060 !important;
  font-size: 12px !important;
  line-height: 1.45 !important;
}

.contact-disclaimer a {
  color: #083a5d !important;
  text-decoration: underline !important;
  text-underline-offset: 3px !important;
}

.contact-actions {
  display: flex !important;
  justify-content: flex-start !important;
  padding-top: 18px !important;
}

.contact-submit {
  min-width: 140px !important;
  height: 40px !important;
  padding: 0 18px !important;
  border-radius: 12px !important;
  background: #d1a245 !important;
  border: 0 !important;
  color: #102033 !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  box-shadow: 0 16px 28px rgba(209, 162, 69, 0.22) !important;
  cursor: pointer !important;
  transition: transform .2s ease, background .2s ease, box-shadow .2s ease !important;
}

.contact-submit:hover {
  background: #dfb45e !important;
  transform: translateY(-1px) !important;
}

@media (max-width: 1100px) {
  .contact-shell {
    grid-template-columns: 1fr !important;
    row-gap: 14px !important;
    background: #ffffff !important;
  }

  .contact-copy-side {
    padding: 24px 20px 10px !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(8, 53, 86, 0.08) !important;
  }

  .contact-copy-inner {
    max-width: 760px !important;
  }

  .contact-title-display {
    font-size: clamp(3.5rem, 8.6vw, 5.5rem) !important;
  }

  .contact-subtitle {
    font-size: clamp(1.45rem, 3.8vw, 2rem) !important;
  }

  .contact-copy-text {
    max-width: 760px !important;
    font-size: 1.16rem !important;
  }

  .contact-form-side {
    padding: 10px 18px 18px !important;
  }
}

@media (max-width: 820px) {
  .contact-section {
    padding: 20px 0 30px !important;
  }

  .contact-section .container {
    width: calc(100vw - 18px) !important;
  }

  .contact-shell {
    grid-template-columns: 1fr !important;
    row-gap: 14px !important;
    background: #ffffff !important;
    border-color: rgba(8, 53, 86, 0.18) !important;
  }

  .contact-copy-side {
    padding: 24px 16px 8px !important;
    background: linear-gradient(180deg, #0d2740 0%, #083a5d 100%) !important;
    border-right: 0 !important;
  }

  .contact-title-display {
    font-size: clamp(3.15rem, 13.5vw, 5.1rem) !important;
    margin-bottom: 12px !important;
  }

  .contact-subtitle {
    font-size: clamp(1.28rem, 6.2vw, 1.82rem) !important;
    line-height: 1.2 !important;
    margin-bottom: 10px !important;
  }

  .contact-copy-text {
    font-size: 1.06rem !important;
    line-height: 1.56 !important;
  }

  .contact-form-side {
    background: #ffffff !important;
    padding: 8px 16px 16px !important;
  }

  .contact-grid-2,
  .contact-grid-phone {
    grid-template-columns: 1fr !important;
  }

  .contact-label,
  .contact-label-static {
    color: #5b6775 !important;
    font-size: 13px !important;
  }

  .contact-input,
  .contact-select,
  .contact-input-disabled {
    height: 40px !important;
    min-height: 40px !important;
    font-size: 13px !important;
    background: #ffffff !important;
    color: #0d2740 !important;
    border-color: rgba(8, 53, 86, 0.16) !important;
    box-shadow: none !important;
  }

  .contact-textarea {
    height: 100px !important;
    min-height: 100px !important;
    font-size: 13px !important;
    background: #ffffff !important;
    color: #0d2740 !important;
    border-color: rgba(8, 53, 86, 0.16) !important;
    box-shadow: none !important;
  }

  .contact-input:focus,
  .contact-select:focus,
  .contact-textarea:focus {
    background: #ffffff !important;
    border-color: #cda55e !important;
    box-shadow: 0 0 0 4px rgba(205, 165, 94, 0.12) !important;
  }

  .contact-disclaimer {
    color: #5b6775 !important;
    font-size: 11.5px !important;
    line-height: 1.42 !important;
  }

  .contact-disclaimer a {
    color: #083a5d !important;
  }

  .contact-submit {
    width: 100% !important;
    min-width: 0 !important;
    height: 44px !important;
  }
}

/* =========================================================
   AJUSTES V13 — CTAs, fronteira ética, evolução e refinamentos solicitados
   Escopo: alterações pontuais da página Treino Cognitivo Executivo.
========================================================= */

.btn-primary,
.contact-submit {
  border: 1px solid var(--gold) !important;
  background: var(--gold) !important;
  color: #083a5d !important;
  box-shadow: 0 16px 32px rgba(205, 165, 94, 0.22) !important;
}

.btn-primary:hover,
.program-strip__button.btn-primary:hover,
.hero-actions .btn-primary:hover,
.specialist-actions .btn-primary:hover,
.contact-submit:hover {
  background: transparent !important;
  color: #083a5d !important;
  border-color: #083a5d !important;
  box-shadow: none !important;
  transform: translateY(-2px);
}

.section-cta {
  margin-top: 32px;
}

.section-cta .btn,
.specialist-actions .btn {
  min-width: 260px;
}

.section-copy .section-cta {
  margin-top: 28px;
}

.hero-actions .btn-primary {
  color: #083a5d !important;
}

.evolution-section .section-copy h2 {
  max-width: 780px;
}

.evolution-card svg {
  overflow: visible;
}

.frontier-card:hover,
.frontier-card.gold-card:hover {
  background:
    radial-gradient(circle at 18% 12%, rgba(240, 195, 109, 0.18), transparent 34%),
    linear-gradient(135deg, #0b4f7c 0%, #083a5c 52%, #001b2e 100%) !important;
  border-color: rgba(240, 195, 109, 0.48) !important;
  box-shadow: 0 32px 74px rgba(0, 27, 46, 0.24) !important;
}

.frontier-card:hover span,
.frontier-card.gold-card:hover span {
  color: var(--gold-light) !important;
}

.frontier-card:hover h3,
.frontier-card.gold-card:hover h3 {
  color: #ffffff !important;
}

.frontier-card:hover li,
.frontier-card.gold-card:hover li {
  color: rgba(255, 255, 255, 0.84) !important;
}

.frontier-card:hover li::before,
.frontier-card.gold-card:hover li::before {
  background: var(--gold-light) !important;
}

.specialist-actions {
  margin-top: 4px;
}

.help-center-panel + .section-cta {
  margin-top: 28px;
}

@media (max-width: 820px) {
  .section-cta .btn,
  .specialist-actions .btn {
    width: 100%;
    min-width: 0;
  }

  .section-cta {
    margin-top: 26px;
  }
}

/* =========================================================
   AJUSTES V14 — CTAs em seções escuras + FAQ
   Escopo: ajustes pontuais solicitados sem alterar estrutura da página.
========================================================= */

.program-strip .btn-primary:hover,
.architecture-section .section-cta .btn-primary:hover,
.assessment-section .section-cta .btn-primary:hover,
.evolution-section .section-cta .btn-primary:hover,
.integration-section .section-cta .btn-primary:hover,
.specialist-section .specialist-actions .btn-primary:hover {
  background: transparent !important;
  color: var(--gold-light) !important;
  border-color: var(--gold-light) !important;
  box-shadow: none !important;
  transform: translateY(-2px);
}

.help-center-section .section-cta .btn-primary[href*="central-de-ajuda"]:hover {
  background: transparent !important;
  color: #083a5d !important;
  border-color: #083a5d !important;
  box-shadow: none !important;
}

/* =========================================================
   AJUSTES V16 — links, formulário e menu Sobre Nós sem Carreiras
   Escopo: remover Carreiras e alinhar Contato/Trabalhe Conosco ao formulário da página.
========================================================= */
.mega-menu--about {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  width: min(930px, calc(100vw - 48px));
}

#formulario-contato {
  scroll-margin-top: 108px;
}

@media (max-width: 820px) {
  #formulario-contato {
    scroll-margin-top: 92px;
  }
}

/* =========================================================
   AJUSTES V17 — vídeo no fundo do banner Treino Cognitivo
   Escopo: substituir apenas o fundo do hero por vídeo responsivo
   e aplicar película azul escura transparente sobre o vídeo.
========================================================= */
.tc-hero {
  background: #031b2b !important;
  isolation: isolate;
}

.tc-hero__video {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  background: #031b2b;
  pointer-events: none;
}

.tc-hero__video-media {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
}

.tc-hero__video-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: rgba(0, 27, 46, 0.26);
  pointer-events: none;
}

.tc-hero::before {
  z-index: 2;
  pointer-events: none;
}

.tc-hero__grain {
  z-index: 3;
}

.tc-hero__grid {
  z-index: 4;
}



/* =========================================================
   AJUSTES V18 — camada azul no vídeo + degradê dourado suave
   Escopo: reforçar apenas a película do hero e as seções já escuras.
========================================================= */

.tc-hero__video-overlay {
  background:
    linear-gradient(90deg, rgba(0, 27, 46, 0.58) 0%, rgba(0, 27, 46, 0.44) 48%, rgba(0, 27, 46, 0.34) 100%),
    rgba(0, 27, 46, 0.18) !important;
}

.program-strip {
  background:
    radial-gradient(circle at 14% 0%, rgba(240, 195, 109, 0.16), transparent 32rem),
    linear-gradient(135deg, rgba(193, 125, 9, 0.08), transparent 38%),
    linear-gradient(145deg, #031b2b 0%, #083a5c 58%, #001b2e 100%) !important;
}

.architecture-section {
  background:
    radial-gradient(circle at 88% 8%, rgba(240, 195, 109, 0.18), transparent 34rem),
    linear-gradient(135deg, rgba(193, 125, 9, 0.08), transparent 42%),
    linear-gradient(145deg, #083a5c 0%, #052b46 64%, #031b2b 100%) !important;
}

.assessment-section {
  background:
    radial-gradient(circle at 12% 0%, rgba(240, 195, 109, 0.14), transparent 34rem),
    linear-gradient(135deg, rgba(193, 125, 9, 0.07), transparent 42%),
    linear-gradient(145deg, #001b2e 0%, #052b46 58%, #001b2e 100%) !important;
}

.evolution-section {
  background:
    radial-gradient(circle at 86% 12%, rgba(240, 195, 109, 0.16), transparent 34rem),
    linear-gradient(135deg, rgba(193, 125, 9, 0.08), transparent 42%),
    linear-gradient(150deg, #083a5c 0%, #052b46 62%, #001b2e 100%) !important;
}

.integration-section {
  background:
    radial-gradient(circle at 15% 8%, rgba(240, 195, 109, 0.15), transparent 34rem),
    linear-gradient(135deg, rgba(193, 125, 9, 0.08), transparent 40%),
    linear-gradient(160deg, #001b2e 0%, #052b46 58%, #083a5c 100%) !important;
}

.specialist-section {
  background:
    radial-gradient(circle at 84% 12%, rgba(240, 195, 109, 0.15), transparent 32rem),
    linear-gradient(135deg, rgba(193, 125, 9, 0.08), transparent 40%),
    linear-gradient(160deg, #083a5c 0%, #052b46 65%, #001b2e 100%) !important;
}

/* =========================================================
   AJUSTES V19 — MOBILE TREINO COGNITIVO
   Escopo: corrigir apenas o mobile: remover faixa branca lateral,
   centralizar banner, alinhar a linha pós-banner, centralizar
   "O PROBLEMA REAL" e corrigir Jornada de Evolução.
========================================================= */

@media (max-width: 820px) {
  html,
  body {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
  }

  body {
    position: relative;
  }

  main,
  .site-header,
  .site-footer,
  section {
    max-width: 100vw !important;
    overflow-x: hidden !important;
  }

  .container,
  .assessment-section .container,
  .help-center-section .container,
  .contact-section .container {
    width: calc(100% - 28px) !important;
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .tc-hero__grid,
  .split-grid,
  .architecture-grid,
  .dimensions-grid,
  .assessment-shell,
  .assessment-content-grid,
  .timeline,
  .evolution-grid,
  .frontier-grid,
  .integration-grid,
  .ethics-grid,
  .specialist-card {
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .tc-hero__copy {
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    text-align: center !important;
  }

  .tc-hero h1,
  .tc-hero .hero-lead {
    text-align: center !important;
  }

  .hero-lead {
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .hero-actions {
    justify-content: center !important;
  }

  .program-strip__inner,
  .program-stats {
    justify-items: stretch !important;
    text-align: left !important;
  }

  .program-stats article {
    justify-content: flex-start !important;
    text-align: left !important;
  }

  .program-stats .stat-label {
    text-align: left !important;
  }

  .thesis-problem-section .problem-kicker,
  .thesis-problem-section .problem-kicker strong {
    display: block !important;
    width: 100% !important;
    text-align: center !important;
  }

  .evolution-grid {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
    align-items: stretch !important;
  }

  .evolution-section .section-copy {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    text-align: center !important;
  }

  .evolution-section .section-copy h2,
  .evolution-section .section-copy p,
  .evolution-section .section-copy .kicker {
    max-width: 100% !important;
    text-align: center !important;
  }

  .evolution-section .section-copy h2 {
    font-size: clamp(2.05rem, 10.5vw, 3.25rem) !important;
    line-height: 1.02 !important;
  }

  .evolution-section .section-copy .section-cta {
    display: flex !important;
    justify-content: center !important;
  }

  .evolution-card {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    padding: 18px !important;
    border-radius: 24px !important;
    overflow: hidden !important;
  }

  .evolution-card svg {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    overflow: visible !important;
  }

  .evolution-legend {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 620px) {
  .container,
  .assessment-section .container,
  .help-center-section .container,
  .contact-section .container {
    width: calc(100% - 24px) !important;
  }

  .tc-hero__grid {
    padding-top: 46px !important;
    padding-bottom: 58px !important;
  }

  .tc-hero__visual,
  .executive-panel,
  .floating-note,
  .evolution-card,
  .assessment-shell,
  .contact-shell,
  .help-center-panel {
    max-width: 100% !important;
  }

  .program-stats {
    grid-template-columns: 1fr !important;
  }

  .program-stats article {
    width: 100% !important;
  }

  .evolution-card text {
    font-size: 15px !important;
  }

  .evolution-legend article {
    padding: 16px !important;
  }
}



/* =========================================================
   AJUSTE V21 — RODAPÉ RESPONSIVO
   Escopo: corrigir somente o rodapé no mobile, evitando corte
   lateral das colunas e mantendo o restante da página intacto.
========================================================= */

@media (max-width: 1100px) and (min-width: 821px) {
  .site-footer__grid {
    grid-template-columns: 1.35fr 1fr 1fr !important;
    gap: 32px !important;
  }

  .footer-brand {
    grid-column: 1 / -1 !important;
  }
}

@media (max-width: 820px) {
  .site-footer {
    padding-top: 42px !important;
    overflow: visible !important;
  }

  .site-footer .container {
    width: calc(100% - 32px) !important;
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .site-footer__grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 28px !important;
    align-items: start !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .footer-brand {
    grid-column: auto !important;
    min-width: 0 !important;
    width: 100% !important;
  }

  .footer-brand img {
    width: min(300px, 82vw) !important;
    max-width: 100% !important;
    height: auto !important;
  }

  .footer-address {
    margin-top: 22px !important;
    max-width: 100% !important;
    font-size: 1rem !important;
    line-height: 1.5 !important;
  }

  .footer-social {
    margin-top: 26px !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 12px !important;
  }

  .footer-social-link {
    width: 52px !important;
    height: 52px !important;
    flex: 0 0 52px !important;
    border-radius: 10px !important;
  }

  .footer-social-link img {
    width: 26px !important;
    height: 26px !important;
    object-fit: contain !important;
  }

  .footer-column {
    min-width: 0 !important;
    width: 100% !important;
  }

  .footer-column h4 {
    margin: 0 0 12px !important;
    font-size: 1.15rem !important;
    line-height: 1.15 !important;
  }

  .footer-column a,
  .footer-column span {
    max-width: 100% !important;
    margin-bottom: 9px !important;
    font-size: 1rem !important;
    line-height: 1.38 !important;
    overflow-wrap: break-word !important;
    word-break: normal !important;
  }

  .footer-bottom {
    margin-top: 28px !important;
    padding: 18px 16px 22px !important;
    font-size: .82rem !important;
    line-height: 1.5 !important;
  }
}

@media (max-width: 480px) {
  .site-footer .container {
    width: calc(100% - 28px) !important;
  }

  .footer-brand img {
    width: min(280px, 78vw) !important;
  }

  .footer-address {
    font-size: .98rem !important;
  }

  .footer-social-link {
    width: 48px !important;
    height: 48px !important;
    flex-basis: 48px !important;
  }

  .footer-social-link img {
    width: 25px !important;
    height: 25px !important;
  }
}

@media (max-width: 360px) {
  .footer-brand img {
    width: min(240px, 76vw) !important;
  }
}


/* =========================================================
   AJUSTE V22 — MENU MOBILE DO CABEÇALHO
   Escopo: corrigir somente a abertura do menu mobile.
   O menu estava sendo recortado pelo overflow aplicado ao header.
========================================================= */

@media (max-width: 820px) {
  .site-header {
    overflow: visible !important;
  }

  .site-header__inner {
    overflow: visible !important;
  }

  .site-nav {
    z-index: 10002 !important;
  }

  .site-nav.is-open {
    display: block !important;
  }

  .nav-toggle {
    z-index: 10003 !important;
    pointer-events: auto !important;
  }
}


/* =========================================================
   AJUSTE V23 — SOBRE NÓS NO MENU MOBILE
   Escopo: alinhar somente o submenu "Sobre Nós" ao comportamento da Home.
   Corrige o override desktop que forçava 3 colunas também no mobile.
========================================================= */

@media (max-width: 820px) {
  .site-nav .mega-menu--about {
    position: static !important;
    left: auto !important;
    top: auto !important;
    transform: none !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin-top: 8px !important;
    padding: 10px 12px !important;
    grid-template-columns: 1fr !important;
  }

  .site-nav__item--has-mega.is-open > .mega-menu--about {
    display: grid !important;
  }

  .mega-menu--about .mega-menu__card {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .mega-menu--about .mega-menu__card + .mega-menu__card {
    border-top: 1px solid rgba(8, 53, 86, 0.07) !important;
    padding-top: 10px !important;
  }

  .mega-menu--about .mega-menu__heading {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin-bottom: 10px !important;
  }

  .mega-menu--about .mega-menu__icon {
    width: 22px !important;
    height: 22px !important;
    flex: 0 0 22px !important;
    object-fit: contain !important;
  }
}
