
:root {
  --blue:       #3A4FC1;
  --blue-dark:  #2B3A9E;
  --blue-deep:  #1A2770;
  --blue-light: #5468D4;
  --yellow:     #F5C800;
  --yellow-lt:  #FFF3B0;
  --white:      #FFFFFF;
  --off-white:  #F6F8FF;
  --dark:       #0F1530;
  --text:       #1E2340;
  --text-mid:   #4A5270;
  --text-lt:    #8890B5;
  --border:     rgba(58,79,193,0.10);
  --shadow:     0 6px 32px rgba(58,79,193,0.10);
  --shadow-lg:  0 20px 60px rgba(58,79,193,0.16);
}

*,*::before,*::after{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  /*font-family:'Inter',sans-serif;*/
  font-family: 'Clash Display', sans-serif;
  color:var(--text);
  background:var(--white);
  overflow-x:hidden;
  line-height:1.6;
}

/* ── NAVBAR ── */
nav{
  position:fixed; top:0; left:0; right:0; z-index:999;
  height:70px;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 6%;
  background:rgba(255,255,255,0.96);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
  transition:box-shadow .3s;
}
nav.scrolled{ box-shadow:0 4px 24px rgba(58,79,193,0.10); }
.nav-logo img{ height:52px; width:auto; display:block; }
.nav-links{ display:flex; gap:32px; list-style:none; align-items:center; }
.nav-links a{
  font-size:.9rem; font-weight:500; color:var(--text-mid);
  text-decoration:none; letter-spacing:.01em;
  position:relative; transition:color .2s;
}
.nav-links a::after{
  content:''; position:absolute; bottom:-3px; left:0;
  width:0; height:2px; background:var(--blue); border-radius:2px;
  transition:width .3s;
}
.nav-links a:hover{ color:var(--blue); }
.nav-links a:hover::after{ width:100%; }
.nav-cta{
  background:var(--blue)!important; color:#fff!important;
  padding:9px 22px; border-radius:50px!important;
  font-weight:600!important; transition:background .2s,transform .2s!important;
}
.nav-cta::after{ display:none!important; }
.nav-cta:hover{ background:var(--blue-dark)!important; transform:translateY(-1px); }
.hamburger{
  display:none; flex-direction:column; gap:5px;
  cursor:pointer; padding:6px;
}
.hamburger span{
  display:block; width:24px; height:2px;
  background:var(--text); border-radius:2px; transition:all .3s;
}

/* ── HERO ── */
.hero{
  min-height:100vh;
  background:linear-gradient(140deg, var(--blue-deep) 0%, var(--blue) 55%, var(--blue-light) 100%);
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  text-align:center;
  padding:120px 6% 80px;
  position:relative; overflow:hidden;
}
.hero-orb1{
  position:absolute; top:-120px; right:-80px;
  width:560px; height:560px; border-radius:50%;
  background:radial-gradient(circle, rgba(245,200,0,.18) 0%, transparent 70%);
  pointer-events:none;
  animation:orbFloat 8s ease-in-out infinite;
}
.hero-orb2{
  position:absolute; bottom:-100px; left:-60px;
  width:420px; height:420px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.06) 0%, transparent 70%);
  pointer-events:none;
  animation:orbFloat 10s ease-in-out infinite reverse;
}
@keyframes orbFloat{
  0%,100%{ transform:translateY(0) scale(1); }
  50%{ transform:translateY(-24px) scale(1.05); }
}
.hero-badge{
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(245,200,0,.14); border:1px solid rgba(245,200,0,.45);
  color:var(--yellow); font-size:.75rem; font-weight:700;
  letter-spacing:.12em; text-transform:uppercase;
  padding:7px 18px; border-radius:50px;
  margin-bottom:36px; position:relative; z-index:1;
  animation:fadeUp .8s ease both;
}
.hero-badge-dot{
  width:6px; height:6px; background:var(--yellow);
  border-radius:50%; animation:blink 1.6s infinite;
}
@keyframes blink{ 0%,100%{opacity:1} 50%{opacity:.2} }
.hero-logo{
  width:190px; margin:0 auto 40px;
  position:relative; z-index:1;
  filter:drop-shadow(0 16px 40px rgba(0,0,0,.28));
  animation:fadeUp .9s ease .1s both;
}
.hero h1{
  font-family:'Space Grotesk',sans-serif;
  font-size:clamp(2rem,4.5vw,3.6rem); font-weight:800;
  color:#fff; line-height:1.18; max-width:820px;
  position:relative; z-index:1;
  animation:fadeUp 1s ease .2s both;
}
.hero h1 em{ color:var(--yellow); font-style:normal; }
.hero-sub{
  font-size:clamp(.95rem,1.6vw,1.12rem); color:rgba(255,255,255,.72);
  max-width:580px; line-height:1.78; margin:22px auto 44px;
  position:relative; z-index:1;
  animation:fadeUp 1s ease .35s both;
}
.hero-btns{
  display:flex; gap:14px; flex-wrap:wrap; justify-content:center;
  position:relative; z-index:1;
  animation:fadeUp 1s ease .5s both;
}
.btn-yellow{
  background:var(--yellow); color:var(--blue-deep);
  padding:14px 34px; border-radius:50px;
  font-weight:800; font-size:.97rem; text-decoration:none;
  box-shadow:0 8px 24px rgba(245,200,0,.35);
  transition:all .3s; letter-spacing:.01em;
}
.btn-yellow:hover{ transform:translateY(-3px); box-shadow:0 14px 36px rgba(245,200,0,.5); }
.btn-ghost{
  background:transparent; color:#fff;
  padding:13px 34px; border-radius:50px;
  font-weight:600; font-size:.97rem; text-decoration:none;
  border:2px solid rgba(255,255,255,.38);
  transition:all .3s;
}
.btn-ghost:hover{ background:rgba(255,255,255,.1); border-color:#fff; transform:translateY(-3px); }
.hero-stat-row{
  display:flex; gap:52px; flex-wrap:wrap; justify-content:center;
  margin-top:70px; position:relative; z-index:1;
  animation:fadeUp 1s ease .65s both;
}
.h-stat{ text-align:center; color:#fff; }
.h-stat-num{
  font-family:'Space Grotesk',sans-serif; font-size:2.4rem; font-weight:800;
  color:var(--yellow); display:block; line-height:1;
}
.h-stat-label{
  font-size:.78rem; color:rgba(255,255,255,.6);
  text-transform:uppercase; letter-spacing:.08em; margin-top:5px;
}
.scroll-hint{
  position:absolute; bottom:28px; left:50%; transform:translateX(-50%);
  z-index:2; text-align:center;
}
.scroll-hint a{
  color:rgba(255,255,255,.45); font-size:.72rem;
  letter-spacing:.1em; text-transform:uppercase;
  text-decoration:none; display:flex; flex-direction:column; align-items:center; gap:7px;
}
.scroll-arrow{ animation:arrowBounce 2s infinite; }
@keyframes arrowBounce{ 0%,100%{transform:translateY(0)} 50%{transform:translateY(7px)} }
@keyframes fadeUp{
  from{ opacity:0; transform:translateY(28px); }
  to{ opacity:1; transform:translateY(0); }
}

/* ── SECTION BASE ── */
section{ padding:100px 6%; }
.label{
  font-size:.72rem; font-weight:700; letter-spacing:.14em;
  text-transform:uppercase; color:var(--blue); margin-bottom:10px;
}
.sec-title{
  font-family:'Space Grotesk',sans-serif;
  font-size:clamp(1.7rem,3.2vw,2.7rem); font-weight:800;
  color:var(--text); line-height:1.22;
}
.sec-title em{ color:var(--blue); font-style:normal; }
.sec-sub{
  font-size:1rem; color:var(--text-mid); line-height:1.78;
  max-width:540px; margin-top:14px;
}
.sec-head{ margin-bottom:60px; }
.sec-head.center{ text-align:center; }
.sec-head.center .sec-sub{ margin:14px auto 0; }

/* ── LEGACY ── */
.legacy{ background:var(--off-white); }
.legacy-grid{
  display:grid; grid-template-columns:1fr 1fr;
  gap:72px; align-items:center;
}
.legacy-visual{
  position:relative;
}
.legacy-card-wrap{
  background:linear-gradient(140deg, var(--blue-deep), var(--blue));
  border-radius:24px; padding:52px 40px;
  text-align:center; box-shadow:var(--shadow-lg);
  position:relative; overflow:hidden;
}
.legacy-card-wrap::after{
  content:''; position:absolute; top:-60px; right:-60px;
  width:220px; height:220px;
  background:radial-gradient(circle,rgba(245,200,0,.18),transparent 70%);
  border-radius:50%;
}
.legacy-card-wrap img{
  width:180px; position:relative; z-index:1;
}
.legacy-pill{
  position:absolute; background:#fff; border-radius:14px;
  padding:12px 18px; box-shadow:var(--shadow);
  display:flex; align-items:center; gap:12px;
  font-size:.85rem; font-weight:600; color:var(--text);
  white-space:nowrap;
}
.legacy-pill.p1{ bottom:-18px; left:-28px; }
.legacy-pill.p2{ top:-18px; right:-28px; }
.pill-icon{
  width:34px; height:34px; border-radius:10px;
  display:flex; align-items:center; justify-content:center; font-size:1rem;
  flex-shrink:0;
}
.legacy-text .sec-sub{ max-width:100%; }
.timeline{
  margin-top:36px;
  display:flex; flex-direction:column; gap:0;
  position:relative;
}
.timeline::before{
  content:''; position:absolute; left:20px; top:8px; bottom:8px;
  width:2px; background:linear-gradient(180deg,var(--blue),var(--yellow));
}
.tl-item{
  display:flex; gap:20px; align-items:flex-start;
  padding:18px 0 18px 0;
  position:relative;
}
.tl-dot{
  width:40px; height:40px; flex-shrink:0;
  background:var(--blue); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-family:'Space Grotesk',sans-serif;
  font-size:.72rem; font-weight:800; letter-spacing:.02em;
  border:3px solid #fff; box-shadow:0 0 0 2px var(--blue);
  position:relative; z-index:1;
}
.tl-body h4{
  font-family:'Syne',sans-serif; font-weight:700; font-size:.97rem;
  color:var(--text); margin-bottom:5px;
}
.tl-body p{
  font-size:.87rem; color:var(--text-mid); line-height:1.65;
}
.tl-year{
  font-size:.75rem; font-weight:700; color:var(--blue);
  text-transform:uppercase; letter-spacing:.08em; margin-bottom:3px;
}

/* ── TRUSTED BY ── */
.trusted{ background:#fff; padding:60px 6%; }
.trusted-inner{
  text-align:center;
}
.trusted-inner .label{ margin-bottom:28px; }
.trusted-logos{
  display:flex; align-items:center; justify-content:center; gap:56px; flex-wrap:wrap;
}
.t-logo{
  background:var(--off-white); border:1px solid var(--border);
  border-radius:14px; padding:18px 36px;
  font-family:'Syne',sans-serif; font-size:1.1rem; font-weight:700;
  color:var(--text-mid); letter-spacing:.02em;
  transition:all .3s;
}
.t-logo:hover{ background:var(--blue); color:#fff; transform:translateY(-3px); box-shadow:var(--shadow); }

/* ── SOFTWARE ECOSYSTEM ── */
.ecosystem{ background:var(--off-white); }
.eco-grid{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:26px;
}
.eco-card{
  background:#fff; border-radius:20px; padding:34px 26px;
  border:1px solid var(--border); box-shadow:var(--shadow);
  transition:all .35s; position:relative; overflow:hidden;
  cursor:default;
}
.eco-card::before{
  content:''; position:absolute;
  top:0; left:0; right:0; height:3px;
  background:var(--blue); transform:scaleX(0);
  transform-origin:left; transition:transform .3s;
}
.eco-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-lg); }
.eco-card:hover::before{ transform:scaleX(1); }
.eco-icon{
  width:56px; height:56px; border-radius:15px;
  background:rgba(58,79,193,.08);
  display:flex; align-items:center; justify-content:center;
  font-size:1.6rem; margin-bottom:22px;
  transition:background .3s;
}
.eco-card:hover .eco-icon{ background:var(--blue); }
.eco-card h3{
  font-family:'Syne',sans-serif; font-weight:700;
  font-size:1.05rem; color:var(--text); margin-bottom:10px;
}
.eco-card p{
  font-size:.88rem; color:var(--text-mid); line-height:1.7;
}

/* ── IMPACT ── */
.impact-section{
  background:linear-gradient(140deg,var(--blue-deep),var(--blue));
  color:#fff; position:relative; overflow:hidden;
}
.impact-section::before{
  content:''; position:absolute; top:-100px; right:-100px;
  width:500px; height:500px; border-radius:50%;
  background:radial-gradient(circle,rgba(245,200,0,.12),transparent 70%);
  pointer-events:none;
}
.impact-section .label{ color:var(--yellow); }
.impact-section .sec-title{ color:#fff; }
.impact-section .sec-title em{ color:var(--yellow); }
.impact-grid{
  display:grid; grid-template-columns:1fr 1fr;
  gap:80px; align-items:center;
}
.impact-text .sec-sub{ color:rgba(255,255,255,.68); max-width:100%; }
.impact-highlight{
  margin-top:36px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.18);
  border-left:4px solid var(--yellow);
  border-radius:0 14px 14px 0;
  padding:24px 28px;
  backdrop-filter:blur(6px);
}
.impact-highlight p{
  font-size:1.05rem; color:#fff; line-height:1.7; font-style:italic;
}
.impact-numbers{
  display:grid; grid-template-columns:1fr 1fr; gap:20px;
}
.impact-num-card{
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.16);
  border-radius:18px; padding:28px 22px; text-align:center;
  backdrop-filter:blur(6px); transition:all .3s;
}
.impact-num-card:first-child{
  grid-column:span 2;
  background:rgba(245,200,0,.16); border-color:rgba(245,200,0,.35);
}
.impact-num-card:hover{ background:rgba(255,255,255,.18); transform:translateY(-4px); }
.impact-num{ 
  font-family:'Space Grotesk',sans-serif; font-size:2.4rem; font-weight:800;
  color:var(--yellow); line-height:1;
}
.impact-num-label{
  font-size:.83rem; color:rgba(255,255,255,.68); margin-top:7px;
}

/* ── ABOUT ── */
.about{ background:#fff; }
.about-grid{
  display:grid; grid-template-columns:1fr 1fr;
  gap:72px; align-items:start;
}
.about-text .sec-sub{ max-width:100%; }
.diff-box{
  margin-top:36px;
  background:var(--off-white);
  border-radius:18px; padding:28px 30px;
  border-left:4px solid var(--yellow);
}
.diff-box h4{
  font-family:'Syne',sans-serif; font-weight:700;
  font-size:1rem; color:var(--text); margin-bottom:10px;
}
.diff-box p{
  font-size:.9rem; color:var(--text-mid); line-height:1.72;
}
.legality-card{
  background:var(--off-white);
  border-radius:20px; padding:36px 30px;
  border:1px solid var(--border);
}
.legality-card h4{
  font-family:'Syne',sans-serif; font-weight:800;
  font-size:1rem; color:var(--blue); margin-bottom:20px;
  padding-bottom:12px; border-bottom:2px solid var(--border);
  letter-spacing:.04em; text-transform:uppercase;
}
.legal-rows{ display:flex; flex-direction:column; gap:0; }
.legal-row{
  display:flex; justify-content:space-between; align-items:center;
  padding:13px 0;
  border-bottom:1px solid var(--border);
}
.legal-row:last-child{ border-bottom:none; }
.lr-key{
  font-size:.8rem; font-weight:600; color:var(--text-lt);
  text-transform:uppercase; letter-spacing:.06em;
}
.lr-val{
  font-size:.9rem; font-weight:600; color:var(--text);
  text-align:right;
}
.lr-val.mono{
  font-family:monospace; font-size:.85rem;
  background:rgba(58,79,193,.07); padding:3px 9px;
  border-radius:6px; color:var(--blue);
}

/* ── SERVICES ── */
.services{ background:var(--off-white); }
.srv-grid{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:26px; margin-top:10px;
}
.srv-card{
  background:#fff; border-radius:20px; padding:32px 26px;
  border:1px solid var(--border); box-shadow:var(--shadow);
  transition:all .35s; position:relative; overflow:hidden;
}
.srv-card::after{
  content:''; position:absolute; inset:0;
  background:linear-gradient(140deg,var(--blue),var(--blue-light));
  opacity:0; transition:opacity .35s; border-radius:20px;
  z-index:0;
}
.srv-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-lg); }
.srv-card:hover::after{ opacity:1; }
.srv-card>*{ position:relative; z-index:1; }
.srv-icon{
  width:54px; height:54px; border-radius:14px;
  background:rgba(58,79,193,.09);
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; margin-bottom:20px;
  transition:background .3s;
}
.srv-card:hover .srv-icon{ background:rgba(255,255,255,.2); }
.srv-card h3{
  font-family:'Syne',sans-serif; font-weight:700;
  font-size:1rem; color:var(--text); margin-bottom:10px;
  transition:color .3s;
}
.srv-card:hover h3{ color:#fff; }
.srv-card p{
  font-size:.87rem; color:var(--text-mid); line-height:1.7;
  transition:color .3s;
}
.srv-card:hover p{ color:rgba(255,255,255,.78); }

/* ── PORTFOLIO ── */
.portfolio{ background:#fff; }
.port-track{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:28px; margin-top:10px;
}
.port-card{
  background:var(--off-white); border-radius:20px; padding:34px 28px;
  border:1px solid var(--border); text-align:center;
  transition:all .3s;
}
.port-card:hover{ box-shadow:var(--shadow-lg); transform:translateY(-6px); }
.port-year{
  font-family:'Space Grotesk',sans-serif; font-size:2rem; font-weight:800;
  color:var(--blue); margin-bottom:10px;
}
.port-line{
  width:40px; height:3px; background:var(--yellow);
  border-radius:2px; margin:0 auto 14px;
}
.port-card p{
  font-size:.9rem; color:var(--text-mid); line-height:1.7;
}

/* ── CONTACT ── */
.contact{ background:var(--off-white); }
.contact-wrap{
  display:grid; grid-template-columns:1fr 1.1fr;
  gap:80px; align-items:start;
}
.contact-info .sec-sub{ max-width:100%; }
.c-items{ margin-top:38px; display:flex; flex-direction:column; gap:16px; }
.c-item{
  display:flex; align-items:center; gap:16px;
  padding:18px 20px; background:#fff; border-radius:14px;
  border:1px solid var(--border); transition:all .25s;
}
.c-item:hover{ border-color:var(--blue); transform:translateX(4px); box-shadow:var(--shadow); }
.c-icon{
  width:46px; height:46px; flex-shrink:0;
  background:var(--blue); border-radius:13px;
  display:flex; align-items:center; justify-content:center; font-size:1.2rem;
}
.c-lbl{ font-size:.75rem; color:var(--text-lt); text-transform:uppercase; letter-spacing:.07em; }
.c-val{ font-weight:600; color:var(--text); font-size:.93rem; margin-top:2px; }
.contact-form{
  background:#fff; border-radius:24px; padding:40px;
  box-shadow:var(--shadow);
}
.contact-form h3{
  font-family:'Space Grotesk',sans-serif; font-size:1.2rem; font-weight:700;
  color:var(--text); margin-bottom:28px;
}
.f-row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.f-grp{ margin-bottom:16px; }
.f-grp label{
  display:block; font-size:.82rem; font-weight:600;
  color:var(--text); margin-bottom:7px;
}

.f-grp input, .f-grp textarea, .f-grp select{
  width:100%; padding:12px 15px;
  border:1.5px solid rgba(58,79,193,.15); border-radius:11px;
  font-family:'Inter',sans-serif; font-size:.9rem; color:var(--text);
  background:#fff; outline:none; transition:border-color .2s,box-shadow .2s;
}
.f-grp input:focus,.f-grp textarea:focus,.f-grp select:focus{
  border-color:var(--blue); box-shadow:0 0 0 4px rgba(58,79,193,.08);
}
.f-grp textarea{ resize:vertical; min-height:110px; }
.f-submit{
  width:100%; padding:14px; border:none; border-radius:50px;
  background:var(--blue); color:#fff; cursor:pointer;
  font-family:'Syne',sans-serif; font-size:.97rem; font-weight:700;
  box-shadow:0 8px 24px rgba(58,79,193,.28);
  transition:all .3s;
}
.f-submit:hover{ background:var(--blue-dark); transform:translateY(-2px); box-shadow:0 12px 32px rgba(58,79,193,.38); }

/* ── FOOTER ── */
footer{
  background:var(--dark);
  padding:72px 6% 32px;
}
.ft-grid{
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:48px; padding-bottom:52px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.ft-brand img{ height:97px; width:auto; margin-bottom:25px; display:block; }
.ft-brand p{
  font-size:.88rem; color:rgba(255,255,255,.5); line-height:1.78; max-width:270px;
}
.ft-legal{
  margin-top:18px; display:flex; flex-direction:column; gap:5px;
}
.ft-legal span{
  font-size:.75rem; color:rgba(255,255,255,.35);
  font-family:monospace; letter-spacing:.03em;
}
.ft-social{ display:flex; gap:10px; margin-top:20px; }
.soc-btn{
  width:36px; height:36px; background:rgba(255,255,255,.08);
  border-radius:9px; display:flex; align-items:center; justify-content:center;
  font-size:.9rem; text-decoration:none; color:rgba(255,255,255,.6);
  transition:all .25s;
}
.soc-btn:hover{ background:var(--yellow); color:var(--blue-deep); transform:translateY(-3px); }
.ft-col h5{
  font-family:'Syne',sans-serif; font-weight:700; font-size:.9rem;
  color:#fff; margin-bottom:18px;
}
.ft-col ul{ list-style:none; }
.ft-col li{ margin-bottom:10px; }
.ft-col a{
  font-size:.87rem; color:rgba(255,255,255,.5); text-decoration:none; transition:color .2s;
}
.ft-col a:hover{ color:var(--yellow); }
.ft-bottom{
  padding-top:26px;
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:10px;
}
.ft-bottom p{ font-size:.8rem; color:rgba(255,255,255,.35); }
.ft-bottom a{ color:rgba(255,255,255,.35); text-decoration:none; }
.ft-bottom a:hover{ color:var(--yellow); }
.ft-tagline{
  font-size:.8rem; color:var(--yellow); font-style:italic;
  opacity:.7;
}

/* ── REVEAL ── */
.reveal{
  opacity:0; transform:translateY(28px);
  transition:opacity .7s ease, transform .7s ease;
}
.reveal.visible{ opacity:1; transform:translateY(0); }

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .eco-grid,.srv-grid{ grid-template-columns:repeat(2,1fr); }
  .ft-grid{ grid-template-columns:1fr 1fr; }
}
@media(max-width:768px){
  nav{ padding:0 5%; }
  .nav-links{ display:none; }
  .nav-links.open{
    display:flex; flex-direction:column; gap:0;
    position:fixed; top:70px; left:0; right:0;
    background:#fff; padding:16px 5% 24px;
    box-shadow:0 8px 24px rgba(0,0,0,.1);
  }
  .nav-links.open li{ border-bottom:1px solid var(--border); }
  .nav-links.open a{ padding:12px 0; display:block; }
  .nav-links.open .nav-cta{ margin-top:10px; text-align:center; border:none; }
  .hamburger{ display:flex; }
  .legacy-grid,.about-grid,.contact-wrap,.impact-grid{ grid-template-columns:1fr; gap:40px; }
  .eco-grid,.srv-grid,.port-track{ grid-template-columns:1fr; }
  .impact-numbers{ grid-template-columns:1fr; }
  .impact-num-card:first-child{ grid-column:span 1; }
  .f-row{ grid-template-columns:1fr; }
  .ft-grid{ grid-template-columns:1fr; gap:32px; }
  .hero-stat-row{ gap:28px; }
  .legacy-pill{ display:none; }
  .trusted-logos{ gap:24px; }
}
