:root{
  --navy:#0c1b2a;--navy2:#13283a;--blue:#1c78a8;--cyan:#56b8d6;
  --paper:#f3f6f7;--white:#fff;--ink:#14212b;--muted:#65727b;
  --line:#d8e0e4;--max:1180px
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  margin:0;min-width:0;overflow-x:hidden;
  font-family:"DM Sans",Arial,sans-serif;color:var(--ink);
  background:var(--paper);line-height:1.65
}
img,svg{display:block;max-width:100%}
button,input,textarea,select{font:inherit}
.container{width:min(calc(100% - 40px),var(--max));margin-inline:auto}
a{color:inherit}
.skip-link{position:absolute;left:-999px;top:8px;background:#fff;padding:8px;z-index:99}
.skip-link:focus{left:8px}

.site-header{
  position:sticky;top:0;z-index:50;background:rgba(12,27,42,.97);
  border-bottom:1px solid rgba(255,255,255,.08);backdrop-filter:blur(12px)
}
.header-inner{
  min-height:82px;display:flex;align-items:center;justify-content:space-between;gap:24px
}
.brand{
  min-width:0;display:flex;align-items:center;gap:13px;text-decoration:none;color:#fff
}
.brand-symbol{
  flex:0 0 45px;width:45px;height:45px;display:grid;place-items:center;
  border:2px solid var(--cyan);font-family:Manrope;font-weight:800;font-size:18px
}
.brand-copy{min-width:0;display:flex;flex-direction:column;line-height:1.15}
.brand-copy strong{font-family:Manrope;font-size:19px;white-space:nowrap}
.brand-copy small{
  margin-top:5px;color:#9eb0bd;text-transform:uppercase;
  letter-spacing:.13em;font-size:9px;white-space:nowrap
}
.main-nav{display:flex;align-items:center;gap:27px}
.main-nav a{text-decoration:none;color:#dbe4e9;font-size:13px;font-weight:600}
.main-nav a:hover{color:#fff}
.main-nav .phone-link{padding:11px 16px;background:var(--blue);color:#fff}
.menu-toggle{
  display:none;flex:0 0 auto;background:none;border:0;color:#fff;
  padding:8px;cursor:pointer
}
.menu-toggle span{display:block;width:25px;height:2px;margin:5px;background:#fff}
.menu-toggle i{position:absolute;left:-999px}

.hero{
  position:relative;overflow:hidden;background:var(--navy);color:#fff;
  min-height:700px;display:flex;align-items:center
}
.hero:after{
  content:"";position:absolute;right:-15%;top:-20%;width:60%;height:150%;
  background:linear-gradient(145deg,rgba(28,120,168,.25),transparent 65%);
  transform:rotate(8deg)
}
.hero-lines{
  position:absolute;inset:0;opacity:.12;
  background-image:linear-gradient(rgba(255,255,255,.08) 1px,transparent 1px),
  linear-gradient(90deg,rgba(255,255,255,.08) 1px,transparent 1px);
  background-size:52px 52px
}
.hero-grid{
  position:relative;z-index:2;display:grid;
  grid-template-columns:minmax(0,1.06fr) minmax(0,.94fr);
  gap:75px;align-items:center;padding:95px 0
}
.hero-copy,.hero-panel{min-width:0}
.eyebrow{
  margin:0 0 15px;color:var(--blue);text-transform:uppercase;
  font-size:11px;font-weight:800;letter-spacing:.23em
}
.hero h1,.section h2,.contact h2{
  font-family:Manrope,sans-serif;letter-spacing:-.045em;line-height:1.03;
  overflow-wrap:anywhere
}
.hero h1{font-size:clamp(56px,7vw,91px);margin:0 0 28px}
.hero h1 span{color:var(--cyan)}
.hero-lead{max-width:660px;color:#c6d1d8;font-size:19px}
.hero-actions{display:flex;flex-wrap:wrap;gap:13px;margin:35px 0 45px}
.button{
  min-height:52px;padding:0 23px;display:inline-flex;align-items:center;
  justify-content:center;text-align:center;text-decoration:none;font-size:14px;
  font-weight:700;border:1px solid transparent;transition:.2s
}
.button-primary{background:var(--blue);color:#fff}
.button-primary:hover{background:#17678f}
.button-ghost{border-color:#526778;color:#fff}
.button-ghost:hover{background:#fff;color:var(--navy)}
.trust-row{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));
  border-top:1px solid #304557;padding-top:25px;gap:20px
}
.trust-row div{min-width:0;display:flex;flex-direction:column}
.trust-row strong{font-size:13px}
.trust-row span{font-size:11px;color:#8396a4}

.technical-visual{
  position:relative;height:455px;border:1px solid #345064;
  background:linear-gradient(145deg,#13283a,#081521);
  box-shadow:25px 25px 0 rgba(28,120,168,.18);overflow:hidden
}
.technical-visual:before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 55% 45%,rgba(86,184,214,.12),transparent 48%)
}
.technical-visual svg{
  position:absolute;inset:35px 15px 65px;width:calc(100% - 30px);height:calc(100% - 100px)
}
.outline,.detail{fill:none;stroke:#6ac4df;stroke-width:3}
.detail{stroke:#547b91;stroke-width:2}
.wheel{fill:none;stroke:#dceef3;stroke-width:5}
.measure{stroke:#56778b;stroke-width:1}
.scan-line{
  position:absolute;z-index:2;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--cyan),transparent);
  animation:scan 4s linear infinite
}
@keyframes scan{from{top:10%}to{top:85%}}
.panel-label{position:absolute;left:27px;bottom:25px;display:flex;flex-direction:column}
.panel-label span{font-size:10px;color:var(--cyan);letter-spacing:.2em}
.panel-label strong{font-family:Manrope;font-size:19px;margin-top:4px}

.section{padding:115px 0}
.section-head{
  display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);
  gap:90px;align-items:end;margin-bottom:55px
}
.section-head>*{min-width:0}
.section-head h2,.profile h2{font-size:clamp(42px,5vw,65px);margin:0}
.section-head>p{color:var(--muted);font-size:17px}
.service-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}
.service-card{
  min-width:0;padding:35px;background:#fff;border:1px solid var(--line);min-height:500px
}
.service-card.featured{
  background:var(--navy);color:#fff;border-color:var(--navy);
  transform:translateY(-15px);box-shadow:0 25px 55px rgba(12,27,42,.17)
}
.card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:55px}
.card-top>span{font-size:11px;color:#9aa8b0}
.icon{
  flex:0 0 48px;width:48px;height:48px;display:grid;place-items:center;
  background:#eaf4f7;color:var(--blue);font-size:24px
}
.featured .icon{background:#1a394e;color:var(--cyan)}
.service-card h3{font-family:Manrope;font-size:28px;line-height:1.15;margin:0 0 15px}
.service-card p{color:var(--muted);font-size:15px}
.featured p{color:#a9bbc7}
.service-card ul{list-style:none;padding:0;margin:30px 0 0}
.service-card li{border-top:1px solid var(--line);padding:11px 0;font-size:13px;font-weight:600}
.featured li{border-color:#294458}

.profile{background:#fff}
.profile-grid{
  display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);
  gap:100px;align-items:center
}
.profile-grid>*{min-width:0}
.profile-card{
  min-height:490px;padding:48px;background:var(--navy2);color:#fff;
  border-left:8px solid var(--cyan);display:flex;flex-direction:column;
  justify-content:flex-end;box-shadow:22px 22px 0 #e1e8eb
}
.profile-kicker{font-size:10px;color:var(--cyan);letter-spacing:.25em}
.profile-card>strong{
  font-family:Manrope;font-size:42px;line-height:1.08;margin:15px 0 55px;
  overflow-wrap:anywhere
}
.profile-data{
  border-top:1px solid #3a5365;padding-top:22px;display:flex;
  flex-direction:column;gap:8px;color:#a9bbc7;font-size:13px
}
.profile-copy>p:not(.eyebrow){color:var(--muted);font-size:17px}
.profile-tags{display:flex;flex-wrap:wrap;gap:9px;margin-top:30px}
.profile-tags span{padding:9px 13px;background:#edf3f5;font-size:12px;font-weight:700}

.process{background:#e9eef0}
.section-head.compact{grid-template-columns:1fr;margin-bottom:50px}
.steps{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));
  gap:1px;background:#cad4d9;border:1px solid #cad4d9
}
.steps article{min-width:0;background:var(--paper);padding:32px;min-height:240px}
.steps span{
  display:grid;place-items:center;width:37px;height:37px;
  background:var(--blue);color:#fff;font-weight:700
}
.steps h3{font-family:Manrope;margin:27px 0 10px}
.steps p{color:var(--muted);font-size:14px}

.contact{padding:110px 0;background:var(--blue);color:#fff}
.contact-grid{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:90px;align-items:center
}
.contact-grid>*{min-width:0}
.eyebrow.light{color:#fff}
.contact h2{font-size:clamp(48px,5vw,72px);margin:0 0 22px}
.contact-copy>p:last-child{color:#d5eaf3;font-size:18px}
.contact-box{min-width:0;background:#fff;color:var(--ink);padding:45px}
.big-phone{
  display:block;text-decoration:none;font-family:Manrope;
  font-size:clamp(31px,4vw,46px);font-weight:800;letter-spacing:-.04em;
  overflow-wrap:anywhere
}
.mail{display:inline-block;max-width:100%;color:var(--blue);margin:5px 0 28px;text-decoration:none;font-weight:700;overflow-wrap:anywhere}
.contact-box dl{margin:0}
.contact-box dl div{
  display:grid;grid-template-columns:120px minmax(0,1fr);
  border-top:1px solid var(--line);padding:18px 0;gap:18px
}
.contact-box dt{font-weight:700}
.contact-box dd{min-width:0;margin:0;color:var(--muted);overflow-wrap:anywhere}
.contact-actions{display:flex;flex-wrap:wrap;align-items:center;gap:22px;margin-top:25px}
.button-dark{background:var(--navy);color:#fff}
.route{text-decoration:none;font-weight:700;font-size:13px}

.site-footer{background:#08131d;color:#93a1aa;padding:36px 0}
.footer-grid{
  display:grid;grid-template-columns:minmax(0,1fr) auto auto;
  gap:35px;align-items:center;font-size:12px
}
.footer-brand{min-width:0;display:flex;flex-direction:column}
.footer-brand strong{color:#fff;font-family:Manrope;font-size:18px}
.footer-brand span{text-transform:uppercase;letter-spacing:.12em;font-size:9px}
.footer-links{display:flex;flex-wrap:wrap;gap:22px}
.footer-links a{text-decoration:none}

.legal{min-height:70vh;padding:90px 0 120px}
.legal-content{max-width:860px;background:#fff;padding:52px}
.legal h1{font-family:Manrope;font-size:55px;letter-spacing:-.04em;margin:0 0 30px}
.legal h2{font-family:Manrope;margin-top:38px}
.legal p,.legal li{color:var(--muted)}
.back-link{display:inline-block;margin-bottom:25px;color:var(--blue);font-weight:700;text-decoration:none}

@media (max-width:1050px){
  .main-nav{gap:18px}
  .hero-grid{gap:45px}
  .section-head{gap:50px}
  .profile-grid,.contact-grid{gap:60px}
  .service-card{padding:28px}
}

@media (max-width:900px){
  .menu-toggle{display:block}
  .main-nav{
    position:absolute;top:100%;left:0;right:0;display:none;
    flex-direction:column;align-items:stretch;gap:0;
    background:var(--navy);padding:14px 20px 24px;
    border-top:1px solid rgba(255,255,255,.08);
    box-shadow:0 18px 30px rgba(0,0,0,.25)
  }
  .main-nav.open{display:flex}
  .main-nav a{padding:13px 8px;border-bottom:1px solid rgba(255,255,255,.08)}
  .main-nav .phone-link{margin-top:12px;text-align:center;border-bottom:0}
  .hero{min-height:auto}
  .hero-grid{grid-template-columns:1fr;padding:82px 0}
  .hero-panel{display:none}
  .section-head,.profile-grid,.contact-grid{grid-template-columns:1fr}
  .service-grid{grid-template-columns:1fr}
  .service-card{min-height:0}
  .service-card.featured{transform:none}
  .steps{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr;gap:22px}
}

@media (max-width:640px){
  .container{width:min(calc(100% - 28px),var(--max))}
  .header-inner{min-height:70px}
  .brand-symbol{flex-basis:40px;width:40px;height:40px;font-size:16px}
  .brand-copy strong{font-size:17px}
  .brand-copy small{display:none}

  .hero-grid{padding:64px 0 70px}
  .hero h1{font-size:clamp(42px,13vw,58px);line-height:1.02}
  .hero-lead{font-size:16px}
  .hero-actions{flex-direction:column;align-items:stretch;margin:28px 0 34px}
  .button{width:100%}
  .trust-row{grid-template-columns:1fr;gap:14px}
  .trust-row div{padding-bottom:12px;border-bottom:1px solid #263b4d}
  .trust-row div:last-child{border-bottom:0}

  .section{padding:72px 0}
  .section-head{gap:20px;margin-bottom:34px}
  .section-head h2,.profile h2{font-size:clamp(36px,11vw,48px)}
  .section-head>p,.profile-copy>p:not(.eyebrow){font-size:16px}

  .service-card{padding:25px}
  .card-top{margin-bottom:34px}
  .service-card h3{font-size:25px}

  .profile-card{min-height:360px;padding:28px;box-shadow:12px 12px 0 #e1e8eb}
  .profile-card>strong{font-size:clamp(30px,9vw,39px);margin-bottom:35px}

  .steps{grid-template-columns:1fr}
  .steps article{min-height:0;padding:25px}

  .contact{padding:72px 0}
  .contact-grid{gap:35px}
  .contact h2{font-size:clamp(38px,11vw,52px)}
  .contact-copy>p:last-child{font-size:16px}
  .contact-box{padding:25px}
  .big-phone{font-size:clamp(27px,9vw,38px)}
  .contact-box dl div{grid-template-columns:1fr;gap:6px}
  .contact-actions{flex-direction:column;align-items:stretch}
  .route{text-align:center;padding:10px}

  .legal{padding:60px 0 80px}
  .legal-content{padding:26px}
  .legal h1{font-size:clamp(38px,11vw,48px)}
}

@media (max-width:380px){
  .container{width:min(calc(100% - 22px),var(--max))}
  .brand-copy strong{font-size:15px}
  .hero h1{font-size:40px}
  .service-card,.contact-box,.legal-content{padding:21px}
  .profile-card{padding:23px}
}
