/* ============================================================
   ISTEK — Design tokens (derived from provided Figma CSS export)
   ============================================================ */
:root{
  /* ---- Color (color-dark.css) ---- */
  --background-primary:#0f172a;
  --background-secondary:#1e293b;
  --background-tertiary:#263244;
  --background-side-bars:#1e293b;
  --surface-hover:#2e3949;
  --surface-pressed:#3d4656;
  --surface-selected:#2e3859;
  --text-primary:#f8fafc;
  --text-secondary:#bfc4ca;
  --text-subtle:#959ca6;
  --text-muted:#868b95;
  --text-disabled:#505a69;
  --border-default:#1e293b;
  --border-strong:#334155;
  --accent-primary-default:#0091ff;
  --accent-primary-hover:#3d9eff;
  --accent-primary-soft:#062e4b;
  --accent-ai-default:#db34f2;
  --accent-ai-hover:#d189f6;
  --accent-ai-soft:#410949;
  --semantic-success:#30d158;
  --semantic-success-soft:#11401d;
  --semantic-warning:#ff9f0a;
  --semantic-warning-soft:#3b2a11;
  --semantic-danger:#ff4245;
  --semantic-danger-soft:#4b0607;
  --semantic-info:#64d2ff;
  --semantic-info-soft:#162c37;

  /* ---- Typography size (font-size-mode-1.css), floor raised to 14px min ---- */
  --fs-display:36px;
  --fs-h1:32px;
  --fs-h2:24px;
  --fs-h3:20px;
  --fs-h4:18px;
  --fs-body-l:16px;
  --fs-body-m:14px;
  --fs-body-s:14px;
  --fs-caption:14px;
  --fs-label-m:14px;
  --fs-label-s:14px;
  --fs-overline:14px;

  /* ---- Line height (line-height-mode-1.css) ---- */
  --lh-display:44px;
  --lh-h1:40px;
  --lh-h2:32px;
  --lh-h3:28px;
  --lh-h4:26px;
  --lh-body-l:24px;
  --lh-body-m:20px;
  --lh-body-s:18px;
  --lh-label-s:16px;

  /* ---- Font weight (font-weight-mode-1.css) ---- */
  --fw-regular:400;
  --fw-medium:500;
  --fw-semibold:600;
  --fw-bold:700;

  /* ---- Gap / spacing (gap-mode-1.css) ---- */
  --g-0:0px; --g-2:2px; --g-4:4px; --g-6:6px; --g-8:8px; --g-10:10px;
  --g-12:12px; --g-16:16px; --g-20:20px; --g-24:24px; --g-32:32px;
  --g-40:40px; --g-48:48px; --g-56:56px; --g-64:64px; --g-72:72px; --g-88:88px;

  /* ---- Radius (radius-mode-1.css) ---- */
  --r-sx:4px; --r-sm:6px; --r-md:8px; --r-lg:12px; --r-xl:16px; --r-pill:999px;

  /* ---- Type families ---- */
  --font-display:'Space Grotesk', 'Inter', sans-serif;
  --font-body:'Inter', sans-serif;
  --font-mono:'IBM Plex Mono', monospace;

  --max-w:1180px;
  --ease:cubic-bezier(.16,.84,.32,1);
}

*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  *{animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important;}
}

body{
  background:var(--background-primary);
  color:var(--text-primary);
  font-family:var(--font-body);
  font-size:var(--fs-body-l);
  line-height:var(--lh-body-l);
  font-weight:var(--fw-regular);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}
ul{list-style:none;}
button{font-family:inherit; cursor:pointer; border:none; background:none; color:inherit;}

.container{
  width:100%;
  max-width:var(--max-w);
  margin:0 auto;
  padding:0 var(--g-24);
}

/* ---------- Background ambience ---------- */
.bg-grid{
  position:fixed; inset:0; z-index:-2; pointer-events:none;
  background-image:
    linear-gradient(rgba(148,163,184,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(148,163,184,.05) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 70% 60% at 50% 0%, black 0%, transparent 70%);
}

/* ---------- Eyebrow / brand bracket label ---------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:var(--g-8);
  font-family:var(--font-mono);
  font-size:var(--fs-overline);
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--accent-primary-hover);
  margin-bottom:var(--g-16);
}
.eyebrow .br{color:var(--accent-ai-default);}

/* ---------- Nav ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:200;
  border-bottom:1px solid transparent;
  transition:border-color .3s var(--ease), background .3s var(--ease);
}
.nav.scrolled{
  background:rgba(15,23,42,.78);
  backdrop-filter:blur(16px) saturate(140%);
  border-color:var(--border-default);
}
.nav-inner{
  max-width:var(--max-w); margin:0 auto; padding:0 var(--g-24);
  height:72px; display:flex; align-items:center; justify-content:space-between;
}
.brand{display:flex; align-items:center; gap:var(--g-12); font-weight:var(--fw-semibold);}
.brand img{width:34px; height:34px; border-radius:var(--r-sm);}
.brand-text{font-family:var(--font-display); font-size:var(--fs-h4); letter-spacing:-.01em;}
.brand-text .accent{
  background:linear-gradient(90deg,var(--accent-ai-default),var(--accent-ai-hover));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.nav-links{display:flex; align-items:center; gap:var(--g-32);}
.nav-links a{
  font-size:var(--fs-body-m); color:var(--text-secondary); font-weight:var(--fw-medium);
  position:relative; padding:var(--g-4) 0; transition:color .2s var(--ease);
}
.nav-links a:hover, .nav-links a.active{color:var(--text-primary);}
.nav-links a.active::after{
  content:''; position:absolute; left:0; right:0; bottom:-6px; height:2px;
  background:linear-gradient(90deg,var(--accent-primary-default),var(--accent-ai-default));
  border-radius:var(--r-pill);
}
.nav-cta{display:flex; align-items:center; gap:var(--g-16);}
.nav-toggle{display:none;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:var(--g-8);
  font-size:var(--fs-body-m); font-weight:var(--fw-semibold);
  padding:var(--g-12) var(--g-20); border-radius:var(--r-md);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease);
  white-space:nowrap;
}
.btn-primary{
  background:var(--accent-primary-default); color:#fff;
  box-shadow:0 0 0 0 rgba(0,145,255,0);
}
.btn-primary:hover{background:var(--accent-primary-hover); transform:translateY(-1px); box-shadow:0 8px 24px -8px rgba(0,145,255,.55);}
.btn-ghost{
  background:transparent; color:var(--text-primary);
  border:1px solid var(--border-strong);
}
.btn-ghost:hover{background:var(--surface-hover); border-color:var(--text-muted);}
.btn-sm{padding:var(--g-10) var(--g-16); font-size:var(--fs-body-s);}
.btn:focus-visible{outline:2px solid var(--accent-primary-hover); outline-offset:3px;}

/* ---------- Sections ---------- */
section{position:relative; padding:var(--g-88) 0;}
.section-tight{padding:var(--g-64) 0;}
.section-head{max-width:680px; margin-bottom:var(--g-56);}
.section-head.center{margin-left:auto; margin-right:auto; text-align:center;}
h1,h2,h3,h4{font-family:var(--font-display); font-weight:var(--fw-semibold); letter-spacing:-.015em;}
h1{font-size:var(--fs-display); line-height:var(--lh-display);}
h2{font-size:var(--fs-h1); line-height:var(--lh-h1);}
h3{font-size:var(--fs-h2); line-height:var(--lh-h2);}
h4{font-size:var(--fs-h3); line-height:var(--lh-h3);}
p{color:var(--text-secondary);}
.lede{font-size:var(--fs-body-l); line-height:var(--lh-body-l); color:var(--text-secondary);}

/* ---------- Hero ---------- */
.hero{
  padding:calc(var(--g-88) + 56px) 0 var(--g-64);
  display:grid; grid-template-columns:1fr; gap:var(--g-48);
  min-height:92vh; align-items:center;
}
.hero-grid{display:grid; grid-template-columns:1.05fr 1fr; gap:var(--g-48); align-items:center;}
.hero-copy{max-width:680px;}
.hero h1{margin-bottom:var(--g-24);}
.hero h1 .grad{
  background:linear-gradient(100deg,var(--accent-primary-hover) 0%, var(--accent-ai-default) 60%, var(--accent-ai-hover) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero p{font-size:var(--fs-body-l); max-width:520px; margin-bottom:var(--g-32);}
.hero-actions{display:flex; gap:var(--g-16); align-items:center; flex-wrap:wrap; margin-bottom:var(--g-48);}
.hero-stats{display:flex; gap:var(--g-40); flex-wrap:wrap;}
.hero-stat b{display:block; font-family:var(--font-display); font-size:var(--fs-h2); font-weight:var(--fw-semibold); color:var(--text-primary);}
.hero-stat span{font-size:var(--fs-body-s); color:var(--text-muted);}

.hero-visual{
  position:relative; width:100%; height:420px; border-radius:var(--r-xl);
  background:radial-gradient(ellipse at 50% 0%, rgba(0,145,255,.12), transparent 60%), var(--background-secondary);
  border:1px solid var(--border-default);
  overflow:hidden;
}
#network-canvas{position:absolute; inset:0; width:100%; height:100%;}
.hero-visual-label{
  position:absolute; bottom:var(--g-20); left:var(--g-20);
  font-family:var(--font-mono); font-size:var(--fs-caption); color:var(--text-muted);
  letter-spacing:.06em;
}

/* ---------- Trust strip ---------- */
.trust{
  border-top:1px solid var(--border-default); border-bottom:1px solid var(--border-default);
  padding:var(--g-40) 0;
}
.trust-row{display:flex; align-items:center; gap:var(--g-24); flex-wrap:wrap; justify-content:space-between;}
.trust-label{font-size:var(--fs-body-s); color:var(--text-muted); white-space:nowrap;}
.trust-logos{display:flex; gap:var(--g-20); flex-wrap:wrap; align-items:center;}
.trust-logo{
  display:flex; align-items:center; justify-content:center;
  height:64px; padding:var(--g-12) var(--g-24);
  background:#fff; border-radius:var(--r-md);
  opacity:.95; transition:opacity .2s var(--ease), transform .2s var(--ease);
}
.trust-logo:hover{opacity:1; transform:translateY(-2px);}
.trust-logo img{height:100%; width:auto; max-width:160px; object-fit:contain;}

/* ---------- Cards grid ---------- */
.grid{display:grid; gap:var(--g-24);}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-4{grid-template-columns:repeat(4,1fr);}
.grid-2{grid-template-columns:repeat(2,1fr);}

.card{
  background:var(--background-secondary);
  border:1px solid var(--border-default);
  border-radius:var(--r-lg);
  padding:var(--g-32);
  transition:transform .35s var(--ease), border-color .35s var(--ease), background .35s var(--ease);
}
.card:hover{transform:translateY(-4px); border-color:var(--border-strong); background:var(--background-tertiary);}
.card-icon{
  width:44px; height:44px; border-radius:var(--r-md); display:flex; align-items:center; justify-content:center;
  background:var(--accent-primary-soft); color:var(--accent-primary-hover); margin-bottom:var(--g-20);
}
.card.ai .card-icon{background:var(--accent-ai-soft); color:var(--accent-ai-hover);}
.card h4{margin-bottom:var(--g-12);}
.card p{font-size:var(--fs-body-m); line-height:var(--lh-body-m);}
.card-link{
  display:inline-flex; align-items:center; gap:var(--g-6); margin-top:var(--g-20);
  font-size:var(--fs-body-s); font-weight:var(--fw-semibold); color:var(--accent-primary-hover);
}
.card-link svg{transition:transform .25s var(--ease);}
.card:hover .card-link svg{transform:translateX(3px);}

.feature-list{margin-top:var(--g-16); display:flex; flex-direction:column; gap:var(--g-10);}
.feature-list li{
  display:flex; align-items:flex-start; gap:var(--g-10);
  font-size:var(--fs-body-s); color:var(--text-secondary); line-height:var(--lh-body-s);
}
.feature-list svg{flex-shrink:0; margin-top:3px; color:var(--semantic-success);}

/* ---------- Price tag ---------- */
.price-tag{
  display:flex; align-items:baseline; gap:var(--g-8); margin:var(--g-20) 0;
  padding-top:var(--g-20); border-top:1px solid var(--border-default);
}
.price-tag .amount{font-family:var(--font-display); font-size:var(--fs-h2); font-weight:var(--fw-semibold);}
.price-tag .unit{font-size:var(--fs-body-s); color:var(--text-muted);}

/* ---------- Process ---------- */
.process{position:relative;}
.process-row{
  display:grid; grid-template-columns:80px 1fr; gap:var(--g-24);
  padding:var(--g-32) 0; border-bottom:1px solid var(--border-default);
}
.process-row:first-child{padding-top:0;}
.process-row:last-child{border-bottom:none;}
.process-index{font-family:var(--font-mono); font-size:var(--fs-h3); color:var(--text-disabled);}
.process-row.active .process-index{color:var(--accent-ai-default);}
.process-body h4{margin-bottom:var(--g-8);}
.process-body p{font-size:var(--fs-body-m);}

/* ---------- CTA banner ---------- */
.cta-banner{
  border-radius:var(--r-xl);
  background:linear-gradient(135deg, var(--accent-primary-soft), var(--accent-ai-soft));
  border:1px solid var(--border-strong);
  padding:var(--g-64) var(--g-48);
  display:flex; align-items:center; justify-content:space-between; gap:var(--g-32);
  flex-wrap:wrap;
  position:relative; overflow:hidden;
}
.cta-banner::before{
  content:''; position:absolute; width:480px; height:480px; right:-160px; top:-160px;
  background:radial-gradient(circle, rgba(219,52,242,.18), transparent 70%);
}
.cta-banner h3{max-width:420px; margin-bottom:var(--g-8);}
.cta-banner p{max-width:420px;}

/* ---------- Footer ---------- */
footer{border-top:1px solid var(--border-default); padding:var(--g-64) 0 var(--g-32);}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:var(--g-32); margin-bottom:var(--g-48);}
.footer-brand p{font-size:var(--fs-body-s); margin-top:var(--g-16); max-width:280px;}
.footer-col h5{font-size:var(--fs-label-s); text-transform:uppercase; letter-spacing:.06em; color:var(--text-muted); margin-bottom:var(--g-16); font-weight:var(--fw-semibold);}
.footer-col ul{display:flex; flex-direction:column; gap:var(--g-10);}
.footer-col a, .footer-col li{font-size:var(--fs-body-s); color:var(--text-subtle);}
.footer-col a:hover{color:var(--text-primary);}
.footer-bottom{
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:var(--g-12);
  border-top:1px solid var(--border-default); padding-top:var(--g-24);
  font-size:var(--fs-caption); color:var(--text-disabled);
}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0; transform:translateY(24px); transition:opacity .7s var(--ease), transform .7s var(--ease);}
.reveal.in{opacity:1; transform:translateY(0);}

/* ---------- Page header (sub pages) ---------- */
.page-header{padding:calc(var(--g-88) + 56px) 0 var(--g-56); border-bottom:1px solid var(--border-default);}
.breadcrumb{font-family:var(--font-mono); font-size:var(--fs-caption); color:var(--text-muted); margin-bottom:var(--g-20); letter-spacing:.04em;}
.breadcrumb a{color:var(--text-subtle);}
.breadcrumb a:hover{color:var(--accent-primary-hover);}

/* ---------- Pricing card grid (products page) ---------- */
.pricing-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:var(--g-24); align-items:stretch; margin-top:var(--g-16);}
.pricing-card{
  background:var(--background-secondary); border:1px solid var(--border-default); border-radius:var(--r-lg);
  padding:var(--g-32); display:flex; flex-direction:column;
  transition:transform .3s var(--ease), border-color .3s var(--ease), background .3s var(--ease);
}
.pricing-card:hover{transform:translateY(-4px); border-color:var(--border-strong); background:var(--background-tertiary);}
.pricing-card .product-num{margin-bottom:var(--g-12);}
.pricing-card h3{margin-bottom:var(--g-12);}
.pricing-desc{font-size:var(--fs-body-s); color:var(--text-secondary); line-height:var(--lh-body-s); margin-bottom:var(--g-20);}
.pricing-price{
  display:flex; align-items:baseline; gap:var(--g-8);
  padding-top:var(--g-20); border-top:1px solid var(--border-default); margin-bottom:var(--g-20);
}
.pricing-price .amount{font-family:var(--font-display); font-size:var(--fs-h2); font-weight:var(--fw-semibold); color:var(--text-primary);}
.pricing-price .unit{font-size:var(--fs-body-s); color:var(--text-muted);}
.pricing-card > .btn{margin-bottom:var(--g-24);}
.pricing-features{border-top:1px solid var(--border-default); padding-top:var(--g-20); flex-grow:1;}

/* ---------- Product detail sections ---------- */
.product-block{padding:var(--g-72) 0; border-bottom:1px solid var(--border-default);}
.product-block:last-of-type{border-bottom:none;}
.product-grid{display:grid; grid-template-columns:1fr 1fr; gap:var(--g-56); align-items:start;}
.product-num{font-family:var(--font-mono); font-size:var(--fs-body-s); color:var(--accent-ai-default); margin-bottom:var(--g-12); letter-spacing:.06em;}
.product-summary{margin:var(--g-20) 0 var(--g-24);}
.spec-panel{
  background:var(--background-secondary); border:1px solid var(--border-default); border-radius:var(--r-lg);
  padding:var(--g-32);
}
.spec-panel h5{font-size:var(--fs-label-s); text-transform:uppercase; letter-spacing:.06em; color:var(--text-muted); margin-bottom:var(--g-20); font-weight:var(--fw-semibold);}

/* ---------- Contact modal (popup form used across all CTAs) ---------- */
.modal-overlay{
  position:fixed; inset:0; z-index:300; display:flex; align-items:center; justify-content:center;
  padding:var(--g-24); background:rgba(5,9,18,.72); backdrop-filter:blur(6px);
  opacity:0; pointer-events:none; transition:opacity .25s var(--ease);
}
.modal-overlay.open{opacity:1; pointer-events:auto;}
.modal-panel{
  position:relative; width:100%; max-width:560px; max-height:88vh; overflow-y:auto;
  background:var(--background-secondary); border:1px solid var(--border-strong); border-radius:var(--r-xl);
  padding:var(--g-40); transform:translateY(16px) scale(.98); transition:transform .3s var(--ease);
}
.modal-overlay.open .modal-panel{transform:translateY(0) scale(1);}
.modal-close{
  position:absolute; top:var(--g-20); right:var(--g-20); width:36px; height:36px; border-radius:var(--r-md);
  display:flex; align-items:center; justify-content:center; color:var(--text-muted);
  transition:background .2s var(--ease), color .2s var(--ease);
}
.modal-close:hover{background:var(--surface-hover); color:var(--text-primary);}
.modal-panel h3{margin-bottom:var(--g-8); padding-right:var(--g-32);}
.modal-panel .modal-lede{font-size:var(--fs-body-s); color:var(--text-secondary); margin-bottom:var(--g-24);}
body.modal-locked{overflow:hidden;}
@media (max-width:560px){
  .modal-panel{padding:var(--g-24);}
}

/* ---------- Contact page (inline, full) ---------- */
.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:var(--g-56);}
.info-row{display:flex; gap:var(--g-16); padding:var(--g-20) 0; border-bottom:1px solid var(--border-default);}
.info-row:first-child{padding-top:0;}
.info-row .ic{
  width:40px; height:40px; border-radius:var(--r-md); background:var(--accent-primary-soft); color:var(--accent-primary-hover);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.info-row h5{font-size:var(--fs-body-s); color:var(--text-muted); font-weight:var(--fw-medium); margin-bottom:var(--g-4);}
.info-row p{color:var(--text-primary); font-size:var(--fs-body-m);}
.map-frame{
  width:100%; height:220px; border-radius:var(--r-lg); border:1px solid var(--border-default); margin-top:var(--g-24);
  overflow:hidden; filter:grayscale(.3) invert(.92) contrast(.88);
}
.map-frame iframe{width:100%; height:100%; border:0;}

.field{margin-bottom:var(--g-20);}
.field label{display:block; font-size:var(--fs-body-s); color:var(--text-secondary); margin-bottom:var(--g-8); font-weight:var(--fw-medium);}
.field input, .field textarea, .field select{
  width:100%; background:var(--background-secondary); border:1px solid var(--border-default);
  border-radius:var(--r-md); padding:var(--g-12) var(--g-16); color:var(--text-primary);
  font-family:inherit; font-size:var(--fs-body-m); transition:border-color .2s var(--ease), background .2s var(--ease);
}
.field input::placeholder, .field textarea::placeholder{color:var(--text-disabled);}
.field input:focus, .field textarea:focus, .field select:focus{
  outline:none; border-color:var(--accent-primary-default); background:var(--background-tertiary);
}
.field textarea{resize:vertical; min-height:120px;}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:var(--g-16);}
.form-note{font-size:var(--fs-caption); color:var(--text-disabled); margin-top:var(--g-16);}
.toast{
  display:none; align-items:center; gap:var(--g-10); background:var(--semantic-success-soft); color:#7fe3a0;
  border:1px solid rgba(48,209,88,.3); border-radius:var(--r-md); padding:var(--g-12) var(--g-16);
  font-size:var(--fs-body-s); margin-top:var(--g-16);
}
.toast.show{display:flex;}

/* ---------- Mobile ---------- */
@media (max-width:920px){
  .grid-4{grid-template-columns:repeat(2,1fr);}
  .grid-3, .pricing-grid{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .product-grid, .contact-grid{grid-template-columns:1fr;}
}
@media (max-width:720px){
  body.menu-open{overflow:hidden;}
  body.menu-open .nav{
    background:rgba(15,23,42,.98);
    backdrop-filter:blur(20px) saturate(140%);
    border-color:var(--border-default);
  }
  .nav-links{
    position:fixed; top:72px; left:0; right:0; bottom:0; z-index:199;
    min-height:calc(100vh - 72px);
    min-height:calc(100dvh - 72px);
    overflow-y:auto;
    background:rgba(15,23,42,.98); backdrop-filter:blur(20px);
    flex-direction:column; justify-content:flex-start; padding:var(--g-40) var(--g-24);
    gap:var(--g-24); transform:translateY(-12px); opacity:0; pointer-events:none;
    transition:opacity .25s var(--ease), transform .25s var(--ease);
  }
  .nav-links.open{opacity:1; pointer-events:auto; transform:translateY(0);}
  .nav-links a{font-size:var(--fs-h3);}
  .nav-toggle{
    display:flex; flex-direction:column; gap:5px; width:24px; z-index:101;
  }
  .nav-toggle span{height:2px; width:100%; background:var(--text-primary); transition:.25s var(--ease);}
  .nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  .nav-toggle.open span:nth-child(2){opacity:0;}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

  .grid-3, .grid-4, .grid-2, .pricing-grid{grid-template-columns:1fr;}
  .hero{min-height:auto;}
  .hero-grid{grid-template-columns:1fr; gap:var(--g-32);}
  .hero-visual{height:240px; order:-1;}
  h1{font-size:28px; line-height:36px;}
  .cta-banner{flex-direction:column; align-items:flex-start;}
  .footer-grid{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .trust-row{flex-direction:column; align-items:flex-start; gap:var(--g-20);}
  .trust-logos{gap:var(--g-16); width:100%;}
  .trust-logo{height:56px; padding:var(--g-10) var(--g-16); flex:0 0 auto;}
  .trust-logo img{max-width:130px;}
}
