@font-face {
  font-family: "Marcellus";
  src: url("../fonts/marcellus-400.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Montserrat";
  src: url("../fonts/montserrat-400.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Montserrat";
  src: url("../fonts/montserrat-600.ttf") format("truetype");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
:root {
  --primary: #17587F;
  --primary-dark: #0F3B5A;
  --accent: #e7f2fa;
  --warm: #4F93BD;
  --ink: #0b1a2b;
  --text: #0b1a2b;
  --muted: #5f6f7d;
  --line: #d7e5ee;
  --paper: #eef6fb;
  --surface: #fbfdff;
  --soft: #e7f2f9;
  --dark: #02001C;
  --dark-text: #f3f6fa;
  --radius: 2px;
  --serif: Marcellus, Georgia, "Times New Roman", serif;
  --sans: Montserrat, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --shadow: 0 18px 48px rgba(23, 88, 127, .11);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }
body { margin: 0; min-width: 320px; font-family: var(--sans); color: var(--text); background: var(--paper); font-size: 16px; line-height: 1.75; -webkit-font-smoothing: antialiased; }
body.nav-open { overflow: hidden; }
a { color: inherit; }
img, video { max-width: 100%; display: block; }
select { font: inherit; }
.container { width: min(1080px, calc(100% - 48px)); margin: 0 auto; }
.skip-link { position: absolute; left: -999px; top: 12px; background: var(--dark-text); color: var(--dark); padding: 10px 14px; z-index: 20; }
.skip-link:focus { left: 12px; }
.site-header { position: sticky; top: 0; z-index: 10; padding-top: env(safe-area-inset-top, 0px); background: rgba(2, 0, 28, .9); border-bottom: 1px solid rgba(230, 244, 252, .06); backdrop-filter: blur(16px) saturate(1.2); }
.header-inner { min-height: 64px; display: flex; align-items: center; justify-content: space-between; gap: 24px; width: min(1240px, calc(100% - 48px)); }
.header-brand { display: inline-flex; align-items: center; gap: .9rem; min-width: 0; }
.brand { display: inline-flex; align-items: center; min-height: 44px; gap: 12px; text-decoration: none; color: var(--dark-text); }
.brand img { width: 178px; height: auto; }
.language-switch { display: inline-flex; align-items: center; gap: 2px; border-left: 1px solid rgba(230, 244, 252, .13); padding-left: .8rem; }
.language-switch a { min-width: 34px; min-height: 34px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid transparent; color: rgba(230, 244, 252, .45); font-size: .66rem; font-weight: 600; text-decoration: none; text-transform: uppercase; }
.language-switch a:hover { color: var(--dark-text); }
.language-switch a.is-active { border-color: rgba(230, 244, 252, .18); color: rgba(230, 244, 252, .82); }
.site-nav { display: flex; align-items: center; gap: 15px; flex-wrap: wrap; justify-content: flex-end; }
.site-nav a { display: inline-flex; align-items: center; min-height: 34px; text-decoration: none; padding: 0; border-radius: var(--radius); font-size: .68rem; font-weight: 600; color: rgba(230, 244, 252, .42); text-transform: uppercase; }
.site-nav a:hover, .site-nav a.is-active { color: var(--dark-text); background: transparent; }
.site-nav a:last-child { border: 1px solid rgba(230, 244, 252, .13); padding: .46rem .58rem; }
.site-nav .site-nav__sidebar-only { display: none; }
.nav-toggle { display: none; width: 44px; height: 44px; border: 1px solid rgba(230, 244, 252, .14); background: transparent; border-radius: var(--radius); color: var(--dark-text); }
.nav-toggle span { display: block; width: 18px; height: 1px; background: currentColor; margin: 4px auto; }
.hero { min-height: calc(100vh - 64px); min-height: calc(100svh - 64px - env(safe-area-inset-top, 0px)); position: relative; display: flex; align-items: center; overflow: hidden; color: var(--dark-text); background: var(--dark); }
.hero--lead { min-height: calc(100vh - 64px); min-height: calc(100svh - 64px - env(safe-area-inset-top, 0px)); }
.hero-video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center center; opacity: .82; background: var(--dark); }
.hero-shade { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,.38) 0%, rgba(0,26,61,.48) 58%, rgba(2,0,28,.96) 100%), linear-gradient(90deg, rgba(2,0,28,.92) 0%, rgba(0,26,61,.64) 42%, rgba(2,0,28,.18) 100%); }
.hero-content { position: relative; padding: 96px 0 68px; z-index: 1; }
.hero h1 { max-width: 880px; margin: 0 0 22px; color: var(--dark-text); font-family: var(--serif); font-weight: 400; font-size: clamp(48px, 7vw, 96px); line-height: 1.02; letter-spacing: 0; }
.hero p { max-width: 680px; color: rgba(230, 244, 252, .68); font-size: 1.05rem; }
.eyebrow { margin: 0 0 1rem; color: var(--primary); font-size: .72rem; font-weight: 600; letter-spacing: 0; text-transform: uppercase; opacity: .72; }
.hero .eyebrow { display: none; }
.button { display: inline-flex; align-items: center; justify-content: center; min-width: 0; min-height: 48px; padding: .95rem 1.45rem; border-radius: var(--radius); text-align: center; line-height: 1.25; text-decoration: none; font-size: .78rem; font-weight: 600; text-transform: uppercase; border: 1px solid transparent; cursor: pointer; transition: background .25s ease, color .25s ease, border-color .25s ease; }
.button--primary { border-color: rgba(230, 244, 252, .26); background: transparent; color: rgba(230, 244, 252, .9); }
.button--primary:hover { background: rgba(230, 244, 252, .1); color: #fff; }
.button--light { border-color: rgba(230, 244, 252, .14); background: transparent; color: rgba(230, 244, 252, .78); }
.button--light:hover { color: var(--dark-text); border-color: rgba(230, 244, 252, .36); }
.button--ink { border-color: rgba(10, 22, 40, .22); background: transparent; color: var(--ink); }
.button--ink:hover { background: var(--ink); color: var(--dark-text); }
.button--solid { border-color: var(--primary); background: var(--primary); color: var(--dark-text); box-shadow: 0 16px 34px rgba(23, 88, 127, .18); }
.button--solid:hover { background: var(--primary-dark); border-color: var(--primary-dark); }
.hero-actions { display: flex; flex-wrap: wrap; gap: .85rem; margin-top: 2.2rem; max-width: 980px; }
.hero-stats { display: grid; grid-template-columns: repeat(2, minmax(0, 260px)); gap: 1.2rem; margin-top: 3.4rem; max-width: 620px; border-top: 1px solid rgba(230, 244, 252, .08); padding-top: 1.65rem; }
.hero-stats article { border: 0; background: transparent; border-radius: 0; padding: 0; }
.hero-stats strong { display: block; margin-bottom: .55rem; color: var(--dark-text); font-family: var(--serif); font-size: 1.35rem; font-weight: 400; line-height: 1.18; }
.hero-stats span { display: block; max-width: 240px; color: rgba(230, 244, 252, .38); font-size: .78rem; line-height: 1.5; }
.section { padding: 6rem 0; background: linear-gradient(180deg, #f8fbfe 0%, #edf6fb 100%); }
.section--tight { padding: 2.2rem 0; }
.section--muted, .section--intro { background: #eef6fb; }
.split { display: grid; grid-template-columns: minmax(0, .85fr) minmax(0, 1.15fr); gap: 56px; align-items: start; }
.lead, .page-lead { font-size: 1.08rem; color: rgba(11, 26, 43, .62); }
h1, h2, h3 { color: var(--ink); font-family: var(--serif); font-weight: 400; line-height: 1.1; letter-spacing: 0; overflow-wrap: anywhere; }
h2 { font-size: clamp(2.2rem, 4vw, 3.85rem); margin: 0 0 1.35rem; }
h3 { margin: 0 0 .75rem; font-size: 1.22rem; }
p { margin: 0 0 16px; }
.page-hero { border-bottom: 1px solid rgba(23, 88, 127, .1); background: #eef6fb; color: var(--ink); padding: 5.5rem 0; }
.page-hero h1 { color: var(--ink); font-size: clamp(2.55rem, 5vw, 4.4rem); max-width: 920px; margin: 0 0 1.35rem; }
.page-hero .page-lead { color: rgba(11, 26, 43, .62); max-width: 760px; }
.section-heading { margin-bottom: 2.1rem; }
.card-grid, .intent-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 2px; }
.card, .intent { display: block; text-decoration: none; background: rgba(251, 253, 255, .86); border: 1px solid rgba(23, 88, 127, .1); border-radius: var(--radius); padding: 1.65rem; min-height: 226px; box-shadow: none; color: inherit; transition: transform .25s ease, box-shadow .25s ease; }
.card:hover, .intent:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.card span, .intent span, .topic-list article span { display: inline-block; color: var(--primary); font-weight: 600; margin-bottom: 1.2rem; font-size: .68rem; text-transform: uppercase; opacity: .72; }
.intent h2 { font-size: 1.55rem; }
.line-icon { width: 62px; height: 62px; margin-bottom: 1.4rem; color: var(--primary); fill: none; stroke: currentColor; stroke-width: 2.6; stroke-linecap: round; stroke-linejoin: round; }
.line-icon--small { width: 38px; height: 38px; margin-bottom: 1.1rem; stroke-width: 2.8; }
.focus-card-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 32px; }
.focus-card { min-height: 360px; padding: clamp(1.6rem, 4vw, 3.6rem); background: rgba(251, 253, 255, .92); border: 1px solid rgba(23, 88, 127, .08); border-bottom: 5px solid var(--primary); box-shadow: 0 22px 60px rgba(23, 88, 127, .08); }
.focus-card h3 { font-family: var(--sans); font-size: clamp(1.55rem, 2.4vw, 2.05rem); font-weight: 600; color: var(--ink); }
.focus-card p { max-width: 650px; color: rgba(10, 22, 40, .72); font-size: 1rem; line-height: 1.75; }
.proof-strip { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 2px; margin-top: 2px; }
.proof-strip span { padding: 1rem 1.15rem; background: rgba(251, 253, 255, .72); border: 1px solid rgba(23, 88, 127, .08); color: rgba(10, 22, 40, .64); font-size: .82rem; font-weight: 600; }
.proof-strip strong { color: var(--ink); font-family: var(--serif); font-size: 1.35rem; font-weight: 400; }
.service-snapshot { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: clamp(1.8rem, 4vw, 4rem) 42px; }
.service-snapshot article { min-height: 184px; }
.service-snapshot h3 { font-family: var(--sans); font-size: clamp(1.05rem, 1.5vw, 1.35rem); font-weight: 600; line-height: 1.28; color: var(--ink); }
.service-snapshot p { color: rgba(10, 22, 40, .64); font-size: .9rem; line-height: 1.7; }
.cta-band { display: flex; align-items: center; justify-content: center; gap: 1.2rem; margin-top: 3.5rem; text-align: center; }
.cta-band p { max-width: 360px; margin: 0; color: rgba(10, 22, 40, .58); font-size: .86rem; line-height: 1.55; }
.mini-list, .check-panel, .process-grid { display: grid; gap: 10px; }
.mini-list span, .check-panel span { padding: 1rem 1.1rem; background: rgba(251, 253, 255, .86); border: 1px solid rgba(23, 88, 127, .1); border-radius: var(--radius); color: rgba(10, 22, 40, .72); font-weight: 600; }
.check-panel { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.process-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.process-grid article { min-height: 160px; padding: 1.25rem; background: rgba(251, 253, 255, .86); border: 1px solid rgba(23, 88, 127, .1); border-radius: var(--radius); }
.process-grid span { display: inline-block; margin-bottom: .85rem; color: var(--primary); font-size: .68rem; font-weight: 600; text-transform: uppercase; opacity: .72; }
.process-grid h3 { font-size: 1.08rem; }
.process-grid p { color: rgba(10, 22, 40, .62); font-size: .88rem; line-height: 1.6; }
.legal-note { font-size: 14px; color: var(--muted); border-left: 3px solid var(--primary); padding-left: 14px; }
.logo-marquee { width: 100%; overflow: hidden; align-self: center; padding: 1.1rem 0; -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent); mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent); }
.logo-marquee__track { display: flex; width: max-content; align-items: center; animation: logo-scroll 45s linear infinite; }
.logo-marquee__track img { width: auto; height: 52px; margin-right: 56px; object-fit: contain; user-select: none; -webkit-user-drag: none; filter: none; }
.logo-marquee:hover .logo-marquee__track { animation-play-state: paused; }
.logo-marquee--empty { min-height: 84px; border: 1px solid rgba(23, 88, 127, .1); }
@keyframes logo-scroll { to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) {
  .logo-marquee__track { animation: none; }
  .logo-marquee { overflow: auto; }
}
.topic-list { display: grid; gap: 18px; }
.topic-list article { border-top: 1px solid rgba(23, 88, 127, .1); padding-top: 24px; }
.content-narrow { max-width: 820px; }
.check-list { padding-left: 20px; }
.check-list li { margin: 9px 0; }
.potential-layout { display: grid; grid-template-columns: minmax(0, 1fr) minmax(280px, .42fr); gap: 42px; align-items: start; }
.potential-check { min-height: 640px; overflow: hidden; }
.quiz-progress { display: grid; gap: .7rem; margin-bottom: 1.6rem; color: rgba(10, 22, 40, .52); font-size: .76rem; font-weight: 600; text-transform: uppercase; }
.quiz-progress__rail { height: 2px; background: rgba(23, 88, 127, .12); overflow: hidden; }
.quiz-progress__rail div { width: 14%; height: 100%; background: var(--primary); transition: width .25s ease; }
.quiz-step { display: none; margin: 0; padding: 0; border: 0; }
.quiz-step.is-active { display: grid; gap: 1.1rem; }
.quiz-step legend { margin: 0; color: var(--ink); font-family: var(--serif); font-size: clamp(2rem, 4vw, 3.2rem); font-weight: 400; line-height: 1.08; }
.quiz-step > p { max-width: 760px; color: rgba(10, 22, 40, .62); }
.quiz-options { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.quiz-option { display: grid; grid-template-columns: auto minmax(0, 1fr); column-gap: .8rem; align-items: start; min-height: 118px; padding: 1rem; border: 1px solid rgba(23, 88, 127, .12); background: rgba(255, 255, 255, .42); color: rgba(10, 22, 40, .54); text-transform: none; cursor: pointer; }
.quiz-option:hover { border-color: rgba(23, 88, 127, .32); background: rgba(255, 255, 255, .74); }
.quiz-option input { width: auto; min-height: auto; margin: .28rem 0 0; accent-color: var(--primary); }
.quiz-option span { color: var(--ink); font-size: .88rem; font-weight: 600; line-height: 1.35; }
.quiz-option small { grid-column: 2; color: rgba(10, 22, 40, .56); font-size: .78rem; line-height: 1.55; }
.quiz-contact-grid { display: grid; gap: 16px; }
.quiz-nav { display: flex; flex-wrap: wrap; justify-content: space-between; gap: .75rem; margin-top: .5rem; }
.button[disabled] { opacity: .38; cursor: not-allowed; }
.quiz-error { color: #9a2d2d; font-weight: 800; }
.potential-side { display: grid; gap: 1.2rem; position: sticky; top: 92px; background: rgba(251, 253, 255, .86); border: 1px solid rgba(23, 88, 127, .1); border-radius: var(--radius); padding: 1.65rem; }
.potential-side h2 { font-size: clamp(1.7rem, 3vw, 2.5rem); margin-bottom: 0; }
.quiz-summary { display: grid; gap: .7rem; color: rgba(10, 22, 40, .62); }
.quiz-summary dl { display: grid; gap: .7rem; margin: 0; }
.quiz-summary div { border-top: 1px solid rgba(23, 88, 127, .1); padding-top: .7rem; }
.quiz-summary dt { color: var(--primary); font-size: .68rem; font-weight: 600; text-transform: uppercase; }
.quiz-summary dd { margin: .2rem 0 0; color: var(--ink); font-weight: 600; line-height: 1.45; }
.form-layout { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(280px, .9fr); gap: 42px; }
.contact-form { display: grid; gap: 16px; border: 1px solid rgba(23, 88, 127, .1); border-radius: var(--radius); background: rgba(251, 253, 255, .86); padding: 1.65rem; }
label { display: grid; gap: .25rem; color: rgba(10, 22, 40, .45); font-size: .78rem; font-weight: 600; text-transform: uppercase; }
input, textarea, select { width: 100%; min-height: 44px; border: 0; border-bottom: 1.5px solid rgba(10, 22, 40, .12); border-radius: 0; background: transparent; color: var(--ink); padding: .75rem 0; font: inherit; font-size: 16px; outline: none; }
input:focus, textarea:focus, select:focus { border-bottom-color: var(--ink); }
.form-error { color: #9a2d2d; font-weight: 800; }
.form-success { color: #17623a; font-weight: 800; }
.form-submit-error { color: #9a2d2d; font-weight: 800; }
.form-hp { position: absolute; left: -10000px; width: 1px; height: 1px; overflow: hidden; opacity: 0; pointer-events: none; }
.contact-side { background: rgba(251, 253, 255, .86); border: 1px solid rgba(23, 88, 127, .1); border-radius: var(--radius); padding: 1.65rem; }
.cookie-category-list { display: grid; gap: 12px; margin: 1.4rem 0 2rem; }
.cookie-category-list article { padding: 1.25rem; background: rgba(251, 253, 255, .86); border: 1px solid rgba(23, 88, 127, .1); }
.cookie-category-list span { display: inline-block; margin-bottom: .7rem; color: var(--primary); font-size: .68rem; font-weight: 600; text-transform: uppercase; }
.cookie-consent { position: fixed; left: 18px; right: 18px; bottom: max(18px, env(safe-area-inset-bottom, 0px)); z-index: 30; color: var(--ink); }
.cookie-consent[hidden] { display: none; }
.cookie-consent__inner { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 1rem; align-items: start; width: min(1040px, 100%); margin: 0 auto; padding: 1.25rem; background: rgba(251, 253, 255, .98); border: 1px solid rgba(23, 88, 127, .16); box-shadow: 0 22px 70px rgba(2, 0, 28, .18); }
.cookie-consent h2 { margin: 0 0 .4rem; font-size: 1.25rem; font-family: var(--sans); font-weight: 600; }
.cookie-consent p { margin: 0 0 .45rem; color: rgba(10, 22, 40, .68); font-size: .86rem; line-height: 1.55; }
.cookie-consent a { color: var(--primary); font-weight: 600; font-size: .78rem; }
.cookie-consent__actions { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: .55rem; }
.cookie-consent__settings { grid-column: 1 / -1; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: .8rem; align-items: end; border-top: 1px solid rgba(23, 88, 127, .1); padding-top: 1rem; }
.cookie-consent__settings[hidden] { display: none; }
.cookie-consent__settings label { display: flex; align-items: center; gap: .6rem; min-height: 48px; padding: .8rem; border: 1px solid rgba(23, 88, 127, .12); color: rgba(10, 22, 40, .72); text-transform: none; background: rgba(238, 246, 251, .56); }
.cookie-consent__settings input { width: auto; min-height: auto; accent-color: var(--primary); }
.whatsapp { position: fixed; right: max(18px, env(safe-area-inset-right, 0px)); bottom: max(18px, env(safe-area-inset-bottom, 0px)); z-index: 11; width: 52px; height: 52px; display: inline-flex; align-items: center; justify-content: center; background: #25d366; color: #fff; border: 1px solid rgba(255,255,255,.18); border-radius: 50%; text-decoration: none; box-shadow: 0 14px 34px rgba(2, 0, 28, .24); }
.whatsapp svg { width: 27px; height: 27px; display: block; fill: currentColor; }
.whatsapp:hover { transform: translateY(-1px); box-shadow: 0 18px 42px rgba(2, 0, 28, .28); }
.site-footer { border-top: 1px solid rgba(230, 244, 252, .05); background: var(--dark); color: var(--dark-text); padding: 3.2rem 0 2rem; }
.site-footer h2, .site-footer strong { color: var(--dark-text); }
.site-footer a, .site-footer p { color: rgba(230, 244, 252, .45); }
.footer-grid { display: grid; grid-template-columns: 1.4fr .8fr .6fr; gap: 2rem; }
.brand--footer img { filter: brightness(0) invert(1); }
.footer-bottom { border-top: 1px solid rgba(230, 244, 252, .08); margin-top: 2.2rem; padding-top: 1.2rem; display: flex; gap: 1rem; justify-content: space-between; color: rgba(230, 244, 252, .42); font-size: .72rem; }
@supports (height: 100dvh) {
  .hero, .hero--lead { min-height: calc(100dvh - 64px - env(safe-area-inset-top, 0px)); }
}
@media (max-width: 900px) {
  .header-inner { gap: 12px; width: min(1240px, calc(100% - 32px)); }
  .brand img { width: 142px; }
  .language-switch { padding-left: .6rem; }
  .language-switch a { min-width: 32px; min-height: 32px; font-size: .62rem; }
  .nav-toggle { display: inline-flex; align-items: center; justify-content: center; flex-direction: column; flex: 0 0 auto; }
  .site-nav { display: none; position: absolute; left: 16px; right: 16px; top: calc(64px + env(safe-area-inset-top, 0px)); max-height: calc(100svh - 84px - env(safe-area-inset-top, 0px)); overflow-y: auto; overscroll-behavior: contain; padding: 12px; background: rgba(2, 0, 28, .98); border: 1px solid rgba(230, 244, 252, .14); border-radius: var(--radius); box-shadow: 0 18px 48px rgba(2, 0, 28, .32); }
  .site-nav.is-open { display: grid; gap: 4px; }
  .site-nav a { min-height: 44px; padding: 13px; color: rgba(230, 244, 252, .78); }
  .site-nav a:last-child { padding: 13px; }
  .site-nav .site-nav__sidebar-only { display: block; border: 1px solid rgba(230, 244, 252, .18); margin-top: 8px; }
  .hero { min-height: calc(100svh - 64px - env(safe-area-inset-top, 0px)); }
  .hero h1 { font-size: clamp(40px, 13vw, 58px); }
  .hero-content { padding: clamp(76px, 12svh, 110px) 0 clamp(44px, 8svh, 72px); }
  .hero-actions { display: grid; grid-template-columns: minmax(0, 1fr); width: 100%; max-width: 520px; gap: .65rem; }
  .hero-actions .button { width: 100%; }
  .logo-marquee__track img { height: 44px; margin-right: 42px; }
  .hero-stats, .split, .form-layout, .potential-layout, .footer-grid { grid-template-columns: 1fr; }
  .potential-side { position: static; }
  .card-grid, .intent-grid, .focus-card-grid, .service-snapshot { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .proof-strip { grid-template-columns: 1fr; }
  .cta-band { display: grid; justify-items: stretch; text-align: left; }
  .cookie-consent__inner, .cookie-consent__settings { grid-template-columns: 1fr; }
  .cookie-consent__actions { justify-content: stretch; }
  .cookie-consent__actions .button, .cookie-consent__settings .button { width: 100%; }
  .card, .intent { min-height: auto; }
}
@media (max-width: 620px) {
  .container { width: min(100% - 28px, 1180px); }
  .brand img { width: 126px; }
  .language-switch { gap: 0; padding-left: .45rem; }
  .language-switch a { min-width: 30px; min-height: 30px; }
  .logo-marquee__track img { height: 38px; margin-right: 34px; }
  .card-grid, .intent-grid, .focus-card-grid, .service-snapshot, .check-panel, .process-grid, .quiz-options { grid-template-columns: 1fr; }
  .focus-card { min-height: auto; }
  .potential-check { min-height: auto; }
  .quiz-option { min-height: auto; }
  .quiz-nav .button { width: 100%; }
  .hero-content { padding: 92px 0 44px; }
  .hero-stats { gap: 1rem; }
  .page-hero { padding: 4rem 0; }
  .section { padding: 56px 0; }
  .contact-form, .contact-side, .potential-side, .card, .intent { padding: 1.25rem; }
  .footer-bottom { display: grid; }
}
@supports (height: 100dvh) {
  @media (max-width: 900px) {
    .hero, .hero--lead { min-height: calc(100dvh - 64px - env(safe-area-inset-top, 0px)); }
    .site-nav { max-height: calc(100dvh - 84px - env(safe-area-inset-top, 0px)); }
  }
}
