*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Altus logo palette */
  --navy:#0a1733;
  --navy-dark:#05091a;
  --navy-mid:#0f1f42;
  --royal:#1565c0;
  --royal-bright:#2a86e8;
  --sky:#29abe2;
  --steel:#6d8bb5;
  --copper:#b5622a;          /* logo wordmark accent (use sparingly) */
  --copper-bright:#d48248;
  --gold:var(--royal);
  --gold-bright:var(--sky);
  --gold-dim:#0d3a78;
  --white:#ffffff;
  --gray-50:#f5f7fb;
  --gray-100:#edf2f7;
  --gray-200:#dce3ed;
  --gray-400:#6b7a90;
  --gray-600:#3e4a61;
  --text:#0f1a33;
  --sans:'Inter',system-ui,-apple-system,sans-serif;
  --serif:'Inter',system-ui,-apple-system,sans-serif;
  --display:'Inter',system-ui,-apple-system,sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--text);
  background:var(--navy);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
::selection{background:var(--royal);color:var(--white)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* =========== NAV =========== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:14px 32px;
  display:flex;align-items:center;justify-content:space-between;
  transition:all .3s var(--ease);
  background:rgba(10,15,28,.0);
  backdrop-filter:blur(0);
  -webkit-backdrop-filter:blur(0);
}
.nav.scrolled{
  padding:8px 32px;
  background:rgba(10,15,28,.88);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.nav-brand{
  font-family:var(--display);
  font-size:18px;font-weight:800;
  color:var(--white);
  letter-spacing:.25em;
  text-transform:uppercase;
  display:flex;align-items:center;
}
.nav-logo-img{
  height:144px;width:auto;
  transition:all .3s var(--ease);
  filter:drop-shadow(0 4px 20px rgba(0,0,0,.3));
}
.nav.scrolled .nav-logo-img{height:90px}
.nav-brand:hover .nav-logo-img{opacity:.85}
.nav-links{
  display:flex;gap:36px;align-items:center;
  flex-wrap:nowrap;
}
.nav-links a{
  font-size:12px;font-weight:600;
  color:var(--white);
  letter-spacing:.18em;text-transform:uppercase;
  opacity:.65;transition:opacity .3s;
}
.nav-links a:hover{opacity:1}
.nav-links .nav-cta{
  opacity:1;border:1px solid var(--copper-bright);
  color:var(--copper-bright);
  padding:10px 22px;
  transition:all .25s var(--ease);
}
.nav-links .nav-cta:hover{background:var(--copper-bright);color:var(--navy);border-color:var(--copper-bright)}
.lang-toggle{
  background:transparent;
  border:1px solid rgba(255,255,255,.3);
  color:var(--white);
  font-size:11px;font-weight:700;
  letter-spacing:.15em;
  padding:6px 12px;border-radius:20px;
  transition:all .2s;
}
.lang-toggle:hover{border-color:var(--white);background:var(--white);color:var(--navy)}

@media(max-width:900px){
  .nav-links a:not(.nav-cta){display:none}
  .nav-links{gap:10px;flex-shrink:0}
  .nav-links .nav-cta{padding:7px 14px;font-size:11px;letter-spacing:.1em}
  .lang-toggle{display:inline-flex;align-items:center;padding:5px 10px;font-size:10px;flex-shrink:0}
}
@media(max-width:700px){
  .nav{padding:6px 14px;gap:8px}
  .nav.scrolled{padding:6px 14px}
  .nav-logo-img{height:54px}
  .nav.scrolled .nav-logo-img{height:44px}
  .nav-brand{min-width:0;flex-shrink:1;overflow:hidden}
  .nav-links{gap:6px;flex-shrink:0}
  .nav-links .nav-cta{padding:5px 10px;font-size:10px;letter-spacing:.06em;white-space:nowrap}
  .lang-toggle{padding:4px 8px;font-size:10px;white-space:nowrap}
}
@media(max-width:480px){
  .nav{padding:4px 10px;gap:5px}
  .nav.scrolled{padding:4px 10px}
  .nav-logo-img{height:44px}
  .nav.scrolled .nav-logo-img{height:38px}
  .nav-links{gap:4px}
  .nav-links .nav-cta{padding:4px 8px;font-size:9px;letter-spacing:.04em}
  .lang-toggle{padding:3px 6px;font-size:9px;letter-spacing:.04em;border-radius:12px}
}
@media(max-width:360px){
  .nav{padding:3px 8px}
  .nav-logo-img{height:38px}
  .nav-links .nav-cta{padding:3px 6px;font-size:8.5px}
  .lang-toggle{padding:2px 5px;font-size:8.5px}
}

/* =========== HERO =========== */
.hero{
  position:relative;
  height:100vh;height:100dvh;
  min-height:600px;
  display:flex;align-items:center;
  overflow:hidden;
  background:var(--navy);
}

.hero-fluid{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-fluid::before,.hero-fluid::after{
  content:'';position:absolute;border-radius:50%;filter:blur(120px);
  animation:fluid 14s ease-in-out infinite alternate;
}
.hero-fluid::before{
  width:65vw;height:65vw;top:-20%;left:-10%;
  background:radial-gradient(circle,rgba(21,101,192,.28) 0%,rgba(21,101,192,.08) 40%,transparent 70%);
}
.hero-fluid::after{
  width:55vw;height:55vw;bottom:-18%;right:-12%;
  background:radial-gradient(circle,rgba(41,171,226,.22) 0%,rgba(41,171,226,.05) 40%,transparent 70%);
  animation-delay:-5s;animation-name:fluid2;
}
.fluid-mid{
  position:absolute;width:45vw;height:45vw;
  top:28%;left:38%;
  border-radius:50%;filter:blur(100px);
  background:radial-gradient(circle,rgba(41,171,226,.10) 0%,transparent 60%);
  animation:fluid3 18s ease-in-out infinite alternate;
}
@keyframes fluid{
  0%{transform:translate(0,0) scale(1)}
  50%{transform:translate(10vw,8vh) scale(1.15)}
  100%{transform:translate(-5vw,10vh) scale(.9)}
}
@keyframes fluid2{
  0%{transform:translate(0,0) scale(1)}
  50%{transform:translate(-10vw,-6vh) scale(1.1)}
  100%{transform:translate(8vw,-8vh) scale(.85)}
}
@keyframes fluid3{
  0%{transform:translate(0,0) scale(1)}
  33%{transform:translate(-8vw,5vh) scale(1.25)}
  66%{transform:translate(6vw,-8vh) scale(.8)}
  100%{transform:translate(-3vw,3vh) scale(1.08)}
}

/* particles */
.particles{position:absolute;inset:0;z-index:1;overflow:hidden;pointer-events:none}
.particle{position:absolute;border-radius:50%;opacity:0;animation:drift linear infinite}
.particle:nth-child(1){width:6px;height:6px;background:rgba(41,171,226,.55);left:10%;top:80%;animation-duration:14s}
.particle:nth-child(2){width:4px;height:4px;background:rgba(41,171,226,.35);left:25%;top:90%;animation-duration:18s;animation-delay:-3s}
.particle:nth-child(3){width:8px;height:8px;background:rgba(21,101,192,.45);left:40%;top:85%;animation-duration:12s;animation-delay:-6s}
.particle:nth-child(4){width:3px;height:3px;background:rgba(255,255,255,.18);left:55%;top:95%;animation-duration:20s;animation-delay:-2s}
.particle:nth-child(5){width:5px;height:5px;background:rgba(41,171,226,.3);left:70%;top:88%;animation-duration:16s;animation-delay:-8s}
.particle:nth-child(6){width:10px;height:10px;background:rgba(21,101,192,.22);left:85%;top:82%;animation-duration:22s;animation-delay:-5s}
.particle:nth-child(7){width:4px;height:4px;background:rgba(255,255,255,.12);left:15%;top:92%;animation-duration:15s;animation-delay:-10s}
.particle:nth-child(8){width:7px;height:7px;background:rgba(41,171,226,.25);left:60%;top:78%;animation-duration:19s;animation-delay:-7s}
.particle:nth-child(9){width:3px;height:3px;background:rgba(21,101,192,.5);left:35%;top:96%;animation-duration:13s;animation-delay:-1s}
.particle:nth-child(10){width:5px;height:5px;background:rgba(255,255,255,.1);left:80%;top:90%;animation-duration:17s;animation-delay:-4s}
.particle:nth-child(11){width:6px;height:6px;background:rgba(41,171,226,.3);left:48%;top:84%;animation-duration:21s;animation-delay:-9s}
.particle:nth-child(12){width:4px;height:4px;background:rgba(41,171,226,.35);left:5%;top:88%;animation-duration:16s;animation-delay:-11s}
@keyframes drift{
  0%{transform:translateY(0) translateX(0) scale(1);opacity:0}
  10%{opacity:1}
  50%{transform:translateY(-45vh) translateX(20px) scale(1.2);opacity:.7}
  90%{opacity:.3}
  100%{transform:translateY(-100vh) translateX(-10px) scale(.8);opacity:0}
}

.hero-content{
  position:relative;z-index:2;
  width:100%;padding:0 48px;
  display:flex;align-items:flex-end;justify-content:space-between;gap:48px;
  padding-bottom:80px;
}
.hero-left{flex:1;min-width:0}
.hero-right{flex:0 0 320px;display:flex;flex-direction:column;gap:16px;padding-bottom:8px}

.hero-logo{
  width:clamp(260px,32vw,440px);
  height:auto;
  margin-bottom:32px;
  filter:drop-shadow(0 8px 40px rgba(0,0,0,.5)) drop-shadow(0 0 60px rgba(41,171,226,.22));
  animation:heroLogoIn 1.2s var(--ease) both;
}
@keyframes heroLogoIn{
  from{opacity:0;transform:translateY(30px) scale(.95)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.hero-eyebrow{
  font-size:11px;font-weight:700;
  letter-spacing:.35em;text-transform:uppercase;
  color:var(--sky);
  margin-bottom:24px;
  display:inline-block;
  padding:6px 14px;
  border:1px solid rgba(41,171,226,.4);
  border-radius:20px;
  background:rgba(41,171,226,.05);
}

.hero-title{
  font-family:var(--display);
  font-size:clamp(2.75rem,8vw,6.5rem);
  font-weight:800;line-height:.95;
  letter-spacing:-.035em;
  color:var(--white);
  text-transform:uppercase;
  margin-bottom:24px;
}
.hero-title em{
  display:block;
  color:var(--sky);
  font-style:normal;
  text-transform:uppercase;
  font-size:1em;
  font-weight:800;
  letter-spacing:-.02em;
  line-height:.9;
  margin-top:.02em;
}

.hero-sub{
  font-size:clamp(1.1rem,1.8vw,1.4rem);
  color:rgba(255,255,255,.68);
  max-width:560px;
  font-weight:400;
  line-height:1.65;
  letter-spacing:.01em;
}

.hero-stat{
  background:rgba(255,255,255,.04);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.08);
  padding:20px 24px;
  transition:border-color .3s;
}
.hero-stat:hover{border-color:rgba(41,171,226,.45)}
.hero-stat-num{
  font-family:var(--display);
  font-size:36px;font-weight:800;
  color:var(--sky);
  line-height:1;
  letter-spacing:-.02em;
  margin-bottom:6px;
}
.hs-pct{font-size:.6em;color:var(--royal-bright)}
.hero-stat-label{
  font-size:11px;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.5);
}

.hero-scroll{
  position:absolute;right:32px;bottom:40px;z-index:2;
  writing-mode:vertical-rl;
  font-size:10px;letter-spacing:.25em;text-transform:uppercase;
  color:rgba(255,255,255,.3);
  display:flex;align-items:center;gap:12px;
}
.hero-scroll::after{
  content:'';display:block;
  width:1px;height:48px;
  background:rgba(41,171,226,.5);
  animation:scrollLine 2s ease-in-out infinite;
}
@keyframes scrollLine{
  0%,100%{transform:scaleY(1);opacity:.3}
  50%{transform:scaleY(.4);opacity:.9}
}

@media(max-width:900px){
  .hero{min-height:auto;height:auto;padding:120px 0 60px;width:100%}
  .hero-content{flex-direction:column;align-items:stretch;padding:0 20px;gap:24px;padding-bottom:0;width:100%;box-sizing:border-box}
  .hero-left{width:100%;min-width:0;max-width:100%}
  .hero-right{flex:0 0 auto;flex-direction:row;width:100%;gap:8px;padding-bottom:0;box-sizing:border-box}
  .hero-right .hero-stat{flex:1 1 0;padding:12px 10px;min-width:0;box-sizing:border-box}
  .hero-stat-num{font-size:22px;white-space:nowrap}
  .hero-stat-label{font-size:8px;letter-spacing:.12em;white-space:normal;line-height:1.2}
  .hero-scroll{display:none}
  .hero-sub{font-size:1rem;line-height:1.55;max-width:100%}
  .hero-eyebrow{font-size:9.5px;padding:5px 11px;margin-bottom:18px;letter-spacing:.18em;white-space:normal;max-width:100%;line-height:1.3;overflow:hidden;word-break:break-word}
  .hero-title{font-size:clamp(2rem,7.5vw,3.5rem)!important;line-height:.95;word-break:break-word;overflow-wrap:break-word;hyphens:auto;max-width:100%}
  .hero-title em{font-size:.9em;letter-spacing:-.03em}
}
@media(max-width:600px){
  .hero-title{font-size:clamp(1.85rem,7vw,2.75rem)!important}
  .hero-title em{font-size:.88em}
  .hero-eyebrow{font-size:9px;letter-spacing:.16em}
  .hero-right{flex-wrap:wrap;gap:6px}
  .hero-right .hero-stat{flex:1 1 calc(50% - 3px);min-width:0;padding:10px 8px}
  .hero-stat-num{font-size:19px}
  .hero-stat-label{font-size:8px;letter-spacing:.1em;word-break:normal}
}
@media(max-width:480px){
  .hero{padding:100px 0 40px}
  .hero-eyebrow{font-size:8.5px;padding:4px 9px;letter-spacing:.14em}
  .hero-title{font-size:clamp(1.65rem,6.2vw,2.25rem)!important;letter-spacing:-.025em}
  .hero-title em{font-size:.9em;letter-spacing:-.02em}
  .hero-right{flex-wrap:wrap;gap:6px}
  .hero-right .hero-stat{flex:1 1 calc(33.333% - 4px);min-width:0;padding:10px 6px}
  .hero-stat-num{font-size:17px}
  .hero-stat-label{font-size:7.5px;letter-spacing:.08em}
}
@media(max-width:380px){
  .hero-title{font-size:1.55rem!important}
  .hero-title em{font-size:.9em}
  .hero-right .hero-stat{flex:1 1 calc(50% - 3px)}
}

/* =========== MARQUEE =========== */
.marquee{
  background:linear-gradient(90deg,var(--royal) 0%,var(--sky) 100%);
  overflow:hidden;
  padding:14px 0;
  white-space:nowrap;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(0,0,0,.12);
}
.marquee-alt{background:var(--navy-mid);border-color:rgba(255,255,255,.05)}
.marquee-alt .marquee-text{color:rgba(255,255,255,.4)}
.marquee-track{
  display:flex;gap:0;
  animation:marquee 30s linear infinite;
  width:max-content;
}
.marquee-text{
  font-family:var(--display);
  font-size:14px;font-weight:700;
  color:var(--white);
  text-transform:uppercase;
  letter-spacing:.28em;
  padding:0 24px;
}
@media(max-width:600px){
  .marquee{padding:10px 0}
  .marquee-text{font-size:12px;letter-spacing:.2em;padding:0 16px}
}
@keyframes marquee{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* =========== EDITORIAL =========== */
.ed-section{background:var(--white)}
.ed-row{
  display:grid;grid-template-columns:1fr 1fr;
  min-height:70vh;
  border-bottom:1px solid var(--gray-200);
}
.ed-media{position:relative;overflow:hidden;background:var(--navy-mid)}
.ed-photo{
  width:100%;height:100%;
  background-size:cover;background-position:center;
}
.ed-photo-mission{
  background:
    linear-gradient(135deg,rgba(10,15,28,.5) 0%,rgba(21,101,192,.35) 100%),
    repeating-linear-gradient(45deg,rgba(255,255,255,.03) 0 2px,transparent 2px 20px),
    linear-gradient(135deg,#0f2a5c 0%,#0a1733 100%);
  position:relative;
}
.ed-photo-mission::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(circle at 30% 30%,rgba(41,171,226,.3) 0%,transparent 55%),
    radial-gradient(circle at 70% 70%,rgba(21,101,192,.22) 0%,transparent 55%);
}
.ed-photo-mission::after{
  content:'A';position:absolute;
  top:50%;left:50%;transform:translate(-50%,-50%);
  font-family:var(--display);font-size:clamp(12rem,24vw,24rem);
  font-weight:900;
  color:rgba(255,255,255,.06);
  line-height:1;
  letter-spacing:-.05em;
}
.ed-text{
  display:flex;flex-direction:column;justify-content:center;
  padding:64px 56px;
}
.ed-eyebrow{
  font-size:11px;font-weight:700;
  letter-spacing:.35em;text-transform:uppercase;
  color:var(--royal);
  margin-bottom:16px;
}
.ed-heading{
  font-family:var(--display);
  font-size:clamp(2rem,4vw,3.5rem);
  font-weight:800;line-height:1;
  letter-spacing:-.025em;
  margin-bottom:24px;
  color:var(--text);
  text-transform:none;
}
.ed-body{
  font-size:16px;color:var(--gray-600);
  line-height:1.8;font-weight:300;
  margin-bottom:16px;
  max-width:520px;
}
.ed-body strong{color:var(--text);font-weight:600}

@media(max-width:900px){
  .ed-row{grid-template-columns:1fr}
  .ed-media{min-height:40vh;min-height:320px}
  .ed-text{padding:48px 20px}
}
@media(max-width:480px){
  .ed-media{min-height:260px}
  .ed-text{padding:40px 20px}
  .ed-heading{font-size:clamp(1.85rem,8vw,2.5rem)}
  .ed-body{font-size:15px;line-height:1.7}
}

/* =========== SECTION DARK =========== */
.section-dark{
  background:var(--navy);
  color:var(--white);
  padding:120px 48px;
  position:relative;
}
.section-header-dark{
  max-width:1400px;margin:0 auto 80px;
  text-align:left;
}
.section-eyebrow-light{
  display:inline-block;
  font-size:11px;font-weight:700;
  letter-spacing:.35em;text-transform:uppercase;
  color:var(--sky);
  margin-bottom:20px;
  padding:6px 14px;
  border:1px solid rgba(41,171,226,.4);
  border-radius:20px;
  background:rgba(41,171,226,.05);
}
.section-eyebrow{
  display:inline-block;
  font-size:11px;font-weight:700;
  letter-spacing:.35em;text-transform:uppercase;
  color:var(--royal);
  margin-bottom:20px;
  padding:6px 14px;
  border:1px solid rgba(21,101,192,.35);
  border-radius:20px;
  background:rgba(21,101,192,.04);
}
.section-heading-huge{
  font-family:var(--display);
  font-size:clamp(2.75rem,7vw,6rem);
  font-weight:800;line-height:.95;
  letter-spacing:-.03em;
  color:var(--white);
  text-transform:uppercase;
}
.section-heading-huge em{
  color:var(--sky);
  font-style:normal;
  display:inline-block;
  font-weight:800;
}

/* =========== CAPABILITIES GRID =========== */
.caps-grid{
  max-width:1400px;margin:0 auto;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.08);
}
.cap-card{
  background:var(--navy);
  padding:48px 36px;
  transition:background .3s;
  position:relative;
  min-height:260px;
}
.cap-card:hover{background:var(--navy-mid)}
.cap-card-wide{grid-column:span 3;background:linear-gradient(135deg,var(--navy-mid) 0%,var(--navy) 100%);border-left:3px solid var(--royal)}
.cap-num{
  font-family:var(--display);
  font-size:12px;font-weight:700;
  color:var(--sky);
  letter-spacing:.3em;
  margin-bottom:24px;
}
.cap-card h3{
  font-family:var(--display);
  font-size:clamp(1.4rem,2vw,1.8rem);
  font-weight:700;line-height:1.15;
  color:var(--white);
  margin-bottom:16px;
  letter-spacing:-.015em;
}
.cap-card p{
  font-size:15px;color:rgba(255,255,255,.5);
  line-height:1.7;font-weight:300;
}

@media(max-width:900px){
  .caps-grid{grid-template-columns:repeat(2,1fr)}
  .cap-card-wide{grid-column:span 2}
  .section-dark{padding:72px 20px}
  .section-header-dark{margin:0 auto 48px}
}
@media(max-width:600px){
  .caps-grid{grid-template-columns:1fr}
  .cap-card-wide{grid-column:span 1}
  .cap-card{padding:32px 22px;min-height:auto}
  .cap-card h3{font-size:1.4rem}
  .cap-card p{font-size:14px}
  .section-dark{padding:64px 20px}
  .section-heading-huge{font-size:clamp(2.25rem,10vw,3.5rem);line-height:.95}
}
@media(max-width:480px){
  .section-heading-huge{font-size:clamp(2rem,9vw,3rem)}
}

/* =========== STATEMENT / QUALITY =========== */
.statement-section{
  background:var(--white);
  color:var(--text);
  padding:160px 48px;
  text-align:center;
  position:relative;
}
.statement-section::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:60px;height:3px;
  background:linear-gradient(90deg,var(--royal),var(--sky));
}
.statement-inner{max-width:1200px;margin:0 auto}
.statement-heading{
  font-family:var(--display);
  font-size:clamp(2.25rem,6vw,5rem);
  font-weight:800;line-height:1.02;
  letter-spacing:-.03em;
  margin:60px auto 48px;
  max-width:1100px;
  text-transform:uppercase;
}
.statement-heading em{
  color:var(--royal);
  font-style:normal;
  font-weight:800;
  display:inline-block;
  margin:0 .1em;
}
.statement-body{
  max-width:760px;margin:0 auto 64px;
}
.statement-body p{
  font-size:20px;color:var(--gray-600);
  line-height:1.8;font-weight:300;
}

.quality-badges{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  max-width:900px;margin:0 auto;
}
.qb{
  border:1px solid var(--gray-200);
  padding:28px 20px;
  text-align:center;
  transition:all .3s var(--ease);
}
.qb:hover{border-color:var(--royal);transform:translateY(-4px);box-shadow:0 10px 30px rgba(21,101,192,.08)}
.qb-title{background:linear-gradient(135deg,var(--navy) 0%,var(--royal) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.qb-title{
  display:block;
  font-family:var(--display);
  font-size:20px;font-weight:800;
  color:var(--text);
  margin-bottom:6px;
  letter-spacing:-.015em;
}
.qb-sub{
  display:block;
  font-size:11px;font-weight:600;
  letter-spacing:.15em;text-transform:uppercase;
  color:var(--gray-400);
}

@media(max-width:700px){
  .statement-section{padding:80px 20px}
  .quality-badges{grid-template-columns:repeat(2,1fr);gap:16px}
  .qb{padding:22px 16px}
  .qb-title{font-size:19px}
  .qb-sub{font-size:10px;letter-spacing:.1em}
  .statement-body p{font-size:17px;line-height:1.7}
  .statement-heading{font-size:clamp(2.25rem,10vw,3.5rem);line-height:.95}
}
@media(max-width:480px){
  .statement-section{padding:72px 20px}
  .statement-heading{font-size:clamp(2rem,9vw,3rem)}
  .statement-body p{font-size:16px}
}

/* =========== MARKETS =========== */
.markets-grid{
  max-width:1400px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.08);
}
.market-card{
  background:var(--navy);
  padding:48px 36px;
  transition:all .3s;
  position:relative;
  min-height:240px;
}
.market-card:hover{background:var(--navy-mid)}
.market-card::before{
  content:'';position:absolute;
  top:0;left:0;height:3px;
  width:0;
  background:linear-gradient(90deg,var(--royal),var(--sky));
  transition:width .4s var(--ease);
}
.market-card:hover::before{width:100%}
.market-num{
  font-family:var(--display);
  font-size:12px;font-weight:700;
  color:var(--sky);letter-spacing:.3em;
  margin-bottom:24px;
}
.market-card h3{
  font-family:var(--display);
  font-size:clamp(1.3rem,1.9vw,1.65rem);
  font-weight:700;
  color:var(--white);
  margin-bottom:14px;
  letter-spacing:-.015em;
}
.market-card p{
  font-size:14.5px;color:rgba(255,255,255,.5);
  line-height:1.7;font-weight:300;
}

@media(max-width:900px){
  .markets-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .markets-grid{grid-template-columns:1fr}
  .market-card{padding:32px 22px;min-height:auto}
  .market-card h3{font-size:1.35rem}
  .market-card p{font-size:14px}
}

/* =========== CAFTA =========== */
.cafta-section{
  background:linear-gradient(135deg,var(--gray-50) 0%,var(--white) 100%);
  color:var(--text);
  padding:160px 48px;
  position:relative;
}
.cafta-section::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--royal) 0%,var(--sky) 100%);
}
.cafta-inner{max-width:1400px;margin:0 auto}
.cafta-heading{
  font-family:var(--display);
  font-size:clamp(2.25rem,6vw,5rem);
  font-weight:800;line-height:1;
  letter-spacing:-.03em;
  margin-bottom:72px;
  max-width:1200px;
  text-transform:uppercase;
}
.cafta-heading em{
  color:var(--royal);
  font-style:normal;
  font-weight:800;
  display:block;
}
.cafta-body-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:flex-start;
}
.cafta-body-text p{
  font-size:17px;color:var(--gray-600);
  line-height:1.9;font-weight:300;
  margin-bottom:20px;
}
.cafta-body-text strong{color:var(--text);font-weight:600}

.cafta-stats{
  display:flex;flex-direction:column;gap:24px;
}
.cafta-stat{
  background:var(--white);
  border-left:4px solid var(--royal);
  padding:28px 32px;
  box-shadow:0 10px 30px rgba(10,15,28,.06);
}
.cs-big{
  font-family:var(--display);
  font-size:clamp(2.5rem,5vw,4rem);
  font-weight:800;
  color:var(--navy);
  line-height:1;
  letter-spacing:-.02em;
}
.cs-unit{
  font-size:12px;font-weight:700;
  letter-spacing:.25em;text-transform:uppercase;
  color:var(--royal);
  margin:6px 0 4px;
}
.cs-label{
  font-size:14px;color:var(--gray-600);
  letter-spacing:.05em;
}

@media(max-width:900px){
  .cafta-section{padding:80px 20px}
  .cafta-body-grid{grid-template-columns:1fr;gap:40px}
  .cafta-heading{margin-bottom:48px;font-size:clamp(2.25rem,10vw,3.5rem)}
  .cafta-body-text p{font-size:15px;line-height:1.75}
  .cafta-stat{padding:22px 22px}
  .cs-big{font-size:clamp(2rem,8vw,3rem)}
}
@media(max-width:480px){
  .cafta-section{padding:72px 20px}
  .cafta-heading{font-size:clamp(2rem,9vw,3rem)}
}

/* =========== WHY EL SALVADOR =========== */
.why-section{
  background:var(--navy);
  color:var(--white);
  padding:140px 48px;
  position:relative;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.why-section::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--royal) 0%,var(--sky) 100%);
}
.why-inner{max-width:1400px;margin:0 auto}
.why-section .section-heading-huge{
  margin-bottom:32px;
}
.why-lede{
  font-size:clamp(1.05rem,1.4vw,1.3rem);
  color:rgba(255,255,255,.75);
  line-height:1.7;
  max-width:900px;
  margin:0 0 72px;
  font-weight:300;
}
.why-lede strong{color:var(--white);font-weight:600}
.why-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.08);
}
.why-card{
  background:var(--navy);
  padding:44px 32px;
  transition:background .3s var(--ease);
  position:relative;
  min-height:240px;
}
.why-card:hover{background:var(--navy-mid)}
.why-card::before{
  content:'';position:absolute;top:0;left:0;height:2px;width:0;
  background:linear-gradient(90deg,var(--royal),var(--sky));
  transition:width .4s var(--ease);
}
.why-card:hover::before{width:100%}
.why-card-wide{
  grid-column:span 4;
  background:linear-gradient(135deg,var(--navy-mid) 0%,var(--navy) 70%);
  border-left:3px solid var(--royal);
}
/* card 7 spans 2 on desktop so row 2 fills 5,6,7,7 (no empty cell before the wide #8) */
.why-grid > .why-card:nth-child(7){grid-column:span 2}
.why-num{
  font-family:var(--display);
  font-size:12px;font-weight:700;
  color:var(--sky);
  letter-spacing:.3em;
  margin-bottom:22px;
}
.why-card h3{
  font-family:var(--display);
  font-size:clamp(1.2rem,1.6vw,1.5rem);
  font-weight:700;line-height:1.2;
  color:var(--white);
  margin-bottom:14px;
  letter-spacing:-.015em;
}
.why-card p{
  font-size:14.5px;
  color:rgba(255,255,255,.55);
  line-height:1.7;
  font-weight:300;
}
.why-card p strong{color:rgba(255,255,255,.85);font-weight:600}

@media(max-width:1100px){
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .why-card-wide{grid-column:span 2}
  /* card 7 spans both columns at 2-col width so row 4 is 7,7 and row 5 is 8-wide */
  .why-grid > .why-card:nth-child(7){grid-column:span 2}
}
@media(max-width:700px){
  .why-section{padding:80px 20px}
  .why-grid{grid-template-columns:1fr}
  .why-card-wide{grid-column:span 1}
  .why-card{padding:32px 22px;min-height:auto}
  .why-card h3{font-size:1.2rem}
  .why-card p{font-size:14px}
  .why-lede{font-size:1rem;margin-bottom:40px}
}

/* =========== COMPARISON TABLE =========== */
.compare-section{
  background:linear-gradient(180deg,var(--white) 0%,var(--gray-50) 100%);
  color:var(--text);
  padding:140px 48px;
  position:relative;
}
.compare-section::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:80px;height:3px;
  background:linear-gradient(90deg,var(--royal),var(--sky));
}
.compare-inner{max-width:1400px;margin:0 auto}
.compare-heading{
  font-family:var(--display);
  font-size:clamp(2.25rem,5.5vw,4.5rem);
  font-weight:800;line-height:.98;
  letter-spacing:-.03em;
  margin:32px 0 24px;
  max-width:1100px;
  text-transform:uppercase;
}
.compare-heading em{
  color:var(--royal);
  font-style:normal;
  font-weight:800;
  display:block;
}
.compare-lede{
  font-size:clamp(1rem,1.35vw,1.2rem);
  color:var(--gray-600);
  line-height:1.75;
  max-width:900px;
  margin:0 0 56px;
  font-weight:300;
}
.compare-lede strong{color:var(--text);font-weight:600}
.compare-table-wrap{
  overflow-x:auto;
  border:1px solid var(--gray-200);
  background:var(--white);
  box-shadow:0 20px 60px rgba(10,23,51,.06);
}
.compare-table{
  width:100%;
  border-collapse:collapse;
  font-size:14.5px;
  min-width:860px;
}
.compare-table thead th{
  background:var(--navy);
  color:var(--white);
  text-align:left;
  padding:20px 20px;
  font-size:11px;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  border-right:1px solid rgba(255,255,255,.08);
  vertical-align:middle;
  white-space:nowrap;
}
.compare-table thead th:last-child{border-right:none}
.compare-table thead th.th-altus{
  background:linear-gradient(135deg,var(--royal) 0%,var(--sky) 100%);
  color:var(--white);
  letter-spacing:.12em;
}
.compare-table tbody td{
  padding:18px 20px;
  border-bottom:1px solid var(--gray-200);
  border-right:1px solid var(--gray-200);
  vertical-align:top;
  line-height:1.55;
  color:var(--gray-600);
}
.compare-table tbody td:last-child{border-right:none}
.compare-table tbody tr:last-child td{border-bottom:none}
.compare-table tbody tr:nth-child(even) td{background:rgba(21,101,192,.025)}
.compare-table td.cmp-factor{
  font-weight:700;
  color:var(--text);
  letter-spacing:-.005em;
  white-space:nowrap;
  background:var(--gray-50);
}
.compare-table tbody tr:nth-child(even) td.cmp-factor{background:var(--gray-100)}
.compare-table td.cmp-altus{
  color:var(--text);
  background:rgba(41,171,226,.08)!important;
  border-left:3px solid var(--royal);
  font-weight:500;
}
.compare-table td.cmp-altus strong{color:var(--royal);font-weight:700}
.compare-footnote{
  font-size:13px;
  color:var(--gray-400);
  margin-top:24px;
  line-height:1.65;
  max-width:900px;
}

@media(max-width:900px){
  .compare-section{padding:80px 20px}
  .compare-heading{font-size:clamp(2rem,8vw,3rem)}
  .compare-table{font-size:13.5px}
  .compare-table thead th,.compare-table tbody td{padding:14px 14px}
}
@media(max-width:600px){
  .compare-lede{font-size:1rem}
  .compare-table{font-size:13px}
  .compare-table thead th{font-size:10px;letter-spacing:.1em;padding:12px 10px}
  .compare-table tbody td{padding:12px 12px}
}

/* =========== COMPANY =========== */
.company-section{
  background:var(--navy);
  color:var(--white);
  padding:160px 48px;
}
.company-inner{max-width:1400px;margin:0 auto}
.company-heading{
  font-family:var(--display);
  font-size:clamp(2.25rem,6vw,5rem);
  font-weight:800;line-height:1;
  letter-spacing:-.03em;
  margin-bottom:80px;
  max-width:1200px;
  color:var(--white);
  text-transform:uppercase;
}
.company-heading em{
  color:var(--sky);
  font-style:normal;
  font-weight:800;
  display:inline-block;
}

.company-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.08);
}
.comp-stat{
  background:var(--navy);
  padding:48px 32px;
  text-align:left;
  transition:background .3s;
}
.comp-stat:hover{background:var(--navy-mid)}
.comp-num{
  font-family:var(--display);
  font-size:clamp(3rem,5.5vw,5rem);
  font-weight:800;
  color:var(--sky);
  line-height:1;
  letter-spacing:-.02em;
  margin-bottom:12px;
}
.comp-label{
  font-size:14px;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  color:var(--white);
  margin-bottom:10px;
}
.comp-note{
  font-size:13px;
  color:rgba(255,255,255,.4);
  line-height:1.6;font-weight:300;
}

@media(max-width:900px){
  .company-section{padding:80px 20px}
  .company-stats{grid-template-columns:repeat(2,1fr)}
  .company-heading{margin-bottom:48px;font-size:clamp(2.25rem,10vw,3.5rem)}
  .comp-stat{padding:36px 24px}
  .comp-num{font-size:clamp(2.5rem,9vw,4rem)}
  .comp-label{font-size:13px;letter-spacing:.1em}
  .comp-note{font-size:12px}
}
@media(max-width:480px){
  .company-section{padding:72px 20px}
  .company-heading{font-size:clamp(2rem,9vw,3rem)}
  .company-stats{grid-template-columns:1fr}
}

/* =========== CTA / CONTACT =========== */
.cta-section{
  background:linear-gradient(135deg,var(--navy-mid) 0%,var(--royal) 55%,var(--sky) 100%);
  color:var(--white);
  padding:160px 48px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.cta-section::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(
    45deg,
    transparent 0 40px,
    rgba(255,255,255,.04) 40px 41px
  );
}
.cta-inner{max-width:1200px;margin:0 auto;position:relative;z-index:1}
.cta-section .section-eyebrow{
  color:var(--white);
  border-color:rgba(255,255,255,.4);
}
.cta-heading{
  font-family:var(--display);
  font-size:clamp(2.75rem,7vw,6rem);
  font-weight:800;line-height:.95;
  letter-spacing:-.03em;
  color:var(--white);
  text-transform:uppercase;
  margin-bottom:32px;
}
.cta-heading em{
  color:var(--white);
  font-style:normal;
  font-weight:800;
  display:block;
  text-shadow:0 4px 20px rgba(5,9,26,.35);
}
.cta-sub{
  font-size:18px;color:rgba(255,255,255,.82);
  max-width:640px;margin:0 auto 64px;
  line-height:1.7;font-weight:400;
}

.contact-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
  max-width:1000px;margin:0 auto;
}
.contact-card{
  background:rgba(5,9,26,.55);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  padding:32px 24px;
  text-align:left;
  border:1px solid rgba(255,255,255,.18);
  transition:all .3s var(--ease);
  cursor:pointer;
  display:block;
}
.contact-card:not(a):cursor{cursor:default}
a.contact-card:hover{
  background:var(--white);
  color:var(--navy);
  border-color:var(--white);
  transform:translateY(-4px);
}
.cc-label{
  font-size:11px;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--sky);
  margin-bottom:12px;
}
a.contact-card:hover .cc-label{color:var(--royal)}
.cc-value{
  font-family:var(--display);
  font-size:18px;font-weight:700;
  color:var(--white);
  line-height:1.4;
  letter-spacing:-.005em;
}
a.contact-card:hover .cc-value{color:var(--navy)}

@media(max-width:900px){
  .cta-section{padding:80px 20px}
  .contact-grid{grid-template-columns:1fr;gap:12px}
  .cta-heading{font-size:clamp(2.5rem,10vw,4rem);line-height:.95}
  .cta-sub{font-size:16px;line-height:1.65;margin-bottom:40px}
  .contact-card{padding:26px 22px}
  .cc-value{font-size:18px}
}
@media(max-width:480px){
  .cta-section{padding:72px 20px}
  .cta-heading{font-size:clamp(2.25rem,9vw,3.5rem)}
}

/* =========== FOOTER =========== */
footer{
  background:var(--navy-dark);
  color:rgba(255,255,255,.5);
  padding:100px 48px 48px;
  border-top:1px solid rgba(255,255,255,.06);
}
.footer-inner{max-width:1400px;margin:0 auto}
.footer-top{
  display:grid;grid-template-columns:1.5fr 1fr;gap:64px;
  margin-bottom:64px;
  padding-bottom:64px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.footer-brand{
  font-family:var(--display);
  font-size:clamp(2.5rem,4.5vw,4rem);
  font-weight:800;
  color:var(--white);
  line-height:.95;
  letter-spacing:-.03em;
  text-transform:uppercase;
  margin-bottom:24px;
}
.footer-brand em{
  color:var(--sky);
  font-style:normal;
  font-size:.55em;
  display:inline-block;
  letter-spacing:.05em;
  text-transform:uppercase;
  font-weight:700;
}
.footer-logo-img{
  height:160px;width:auto;
  margin-bottom:24px;
  filter:drop-shadow(0 4px 20px rgba(0,0,0,.3));
}
.footer-desc{
  font-size:17px;line-height:1.8;
  max-width:480px;
  font-weight:300;
}
.footer-links{
  display:flex;flex-direction:column;gap:4px;
}
.footer-links a{
  display:block;padding:10px 0;
  font-size:15px;font-weight:500;
  color:rgba(255,255,255,.4);
  border-bottom:1px solid rgba(255,255,255,.06);
  transition:all .2s;
  letter-spacing:.05em;
}
.footer-links a:hover{color:var(--sky);padding-left:8px}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:32px;font-size:13px;
  color:rgba(255,255,255,.35);
}
.footer-legal{max-width:480px;line-height:1.7}

@media(max-width:700px){
  footer{padding:56px 20px 28px}
  .footer-top{grid-template-columns:1fr;gap:36px;margin-bottom:40px;padding-bottom:40px}
  .footer-bottom{flex-direction:column;gap:12px;align-items:flex-start}
  .footer-logo-img{height:110px;margin-bottom:18px}
  .footer-desc{font-size:15px;line-height:1.7}
  .footer-links a{font-size:14px;padding:8px 0}
}

/* =========== REDUCE GPU ON MOBILE =========== */
@media(max-width:768px){
  .particle:nth-child(n+5){display:none}
  .hero-fluid::before{filter:blur(60px)!important}
  .hero-fluid::after{filter:blur(60px)!important}
  .fluid-mid{filter:blur(40px)!important;width:80vw;height:80vw}
}

/* =========== PREVENT HORIZONTAL OVERFLOW =========== */
html,body{overflow-x:hidden;width:100%;max-width:100vw}
.nav{left:0;right:0;box-sizing:border-box;max-width:100vw}
.hero-content,.markets-grid,.caps-grid,.cafta-inner,.company-inner,.cta-inner,.statement-inner{max-width:100%;box-sizing:border-box}
img{max-width:100%;height:auto}
.hero,section{width:100%;max-width:100vw;overflow:hidden;box-sizing:border-box}
.hero-content{width:100%;max-width:100%;box-sizing:border-box}
.hero-left,.hero-right,.hero-sub,.hero-title,.hero-eyebrow{max-width:100%;box-sizing:border-box}
.hero-sub{overflow-wrap:break-word;word-wrap:break-word}
