
:root{
  --navy:#07182b;
  --navy2:#10243d;
  --blue:#16395f;
  --sky:#5aa7dd;
  --gold:#f5a623;
  --gold2:#ffd07a;
  --ink:#142033;
  --muted:#5d6b7b;
  --line:#dce5ef;
  --soft:#f4f8fc;
  --white:#fff;
  --shadow:0 20px 60px rgba(7,24,43,.16);
  --radius:22px;
}
*{box-sizing:border-box}
body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;color:var(--ink);background:#fff;line-height:1.6}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(1180px,92vw);margin:auto}
.topbar{background:var(--navy);color:#d9ebfb;font-size:14px}
.topbar .container{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:8px 0}
.topbar b{color:#fff}
.site-header{position:sticky;top:0;z-index:99;background:rgba(255,255,255,.94);backdrop-filter:blur(12px);box-shadow:0 6px 25px rgba(7,24,43,.08)}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:15px 0}
.brand{display:flex;align-items:center;gap:13px;min-width:max-content}
.brand img{width:54px;height:54px;border-radius:12px}
.brand strong{display:block;color:var(--navy);font-size:21px;line-height:1.05;letter-spacing:.02em}
.brand small{display:block;color:var(--muted);font-size:13px;line-height:1.2;text-transform:uppercase;letter-spacing:.16em;margin-top:4px}
.brand .license{display:block;color:var(--gold);font-size:12px;font-weight:800;letter-spacing:.06em;margin-top:3px}
.nav{display:flex;align-items:center;gap:22px;font-weight:800;font-size:15px}
.nav a:not(.btn):hover{color:var(--blue)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border:0;border-radius:999px;padding:12px 19px;font-weight:900;cursor:pointer;transition:.2s ease;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:linear-gradient(135deg,var(--gold),#ffbd47);color:#07182b;box-shadow:0 14px 35px rgba(245,166,35,.25)}
.btn-blue{background:linear-gradient(135deg,var(--navy2),var(--blue));color:#fff;box-shadow:0 14px 35px rgba(7,24,43,.18)}
.btn-light{background:#fff;color:var(--navy);box-shadow:0 10px 30px rgba(7,24,43,.12)}
.menu-toggle{display:none;border:1px solid var(--line);background:#fff;padding:10px 14px;border-radius:12px;font-weight:900}
.hero{position:relative;color:#fff;isolation:isolate;background:var(--navy);overflow:hidden}
.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,24,43,.94) 0%,rgba(7,24,43,.74) 42%,rgba(7,24,43,.22) 100%);z-index:-1}
.hero .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.hero .container{min-height:690px;display:grid;grid-template-columns:minmax(0,650px) 1fr;align-items:center;padding:82px 0}
.eyebrow{display:inline-flex;align-items:center;gap:10px;color:#ffe0a2;font-weight:900;letter-spacing:.15em;text-transform:uppercase;font-size:13px}
.eyebrow:before{content:"";width:36px;height:3px;background:var(--gold);border-radius:8px}
h1,h2,h3{line-height:1.08;margin:0 0 16px;color:var(--navy)}
.hero h1{font-size:clamp(42px,6vw,76px);color:#fff;letter-spacing:-.055em;margin:12px 0 18px}
.hero p{font-size:20px;color:#dceeff;max-width:630px;margin:0 0 28px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:32px;max-width:660px}
.stat{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:18px;padding:16px;backdrop-filter:blur(8px)}
.stat strong{display:block;font-size:25px;color:#fff;line-height:1}
.stat span{display:block;color:#cfe6fa;font-size:13px;font-weight:800;margin-top:5px}
.license-pill{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:999px;color:#fff;padding:10px 14px;margin-top:18px;font-weight:900}
.section{padding:82px 0}
.section.soft{background:var(--soft)}
.section.dark{background:var(--navy);color:#dceeff}
.section.dark h2,.section.dark h3{color:#fff}
.section-head{max-width:760px;margin:0 auto 36px;text-align:center}
.section-head h2{font-size:clamp(32px,4vw,50px);letter-spacing:-.035em}
.section-head p{font-size:18px;color:var(--muted);margin:0}
.dark .section-head p{color:#bad6ee}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:25px;box-shadow:0 12px 40px rgba(7,24,43,.08);height:100%}
.card h3{font-size:23px}
.card p{color:var(--muted);margin:0 0 15px}
.card .tag{display:inline-flex;background:#fff5df;color:#6e4300;border-radius:999px;padding:7px 10px;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}
.service-card{overflow:hidden;padding:0}
.service-card img{width:100%;height:230px;object-fit:cover}
.service-card .body{padding:24px}
.service-card ul{margin:13px 0 20px;padding-left:18px;color:var(--muted)}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.split.reverse{grid-template-columns:.95fr 1.05fr}
.feature-img{position:relative}
.feature-img img{border-radius:28px;box-shadow:var(--shadow);width:100%;height:520px;object-fit:cover}
.badge-box{position:absolute;left:22px;bottom:22px;background:#fff;border-radius:20px;padding:18px 20px;box-shadow:0 20px 60px rgba(7,24,43,.22);max-width:300px}
.badge-box strong{display:block;color:var(--navy);font-size:21px}
.badge-box span{display:block;color:var(--muted);font-weight:700}
.checklist{list-style:none;margin:20px 0;padding:0;display:grid;gap:11px}
.checklist li{position:relative;padding-left:32px;color:#2c3b4c;font-weight:700}
.checklist li:before{content:"✓";position:absolute;left:0;top:0;width:22px;height:22px;border-radius:50%;background:#eaf7ff;color:#0f5d8c;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:1000}
.page-hero{background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;padding:74px 0 58px;position:relative;overflow:hidden}
.page-hero:after{content:"";position:absolute;right:-160px;top:-180px;width:500px;height:500px;border-radius:50%;background:rgba(245,166,35,.14)}
.page-hero h1{color:#fff;font-size:clamp(38px,5vw,62px);letter-spacing:-.04em}
.page-hero p{max-width:760px;color:#d7ebfb;font-size:19px;margin:0}
.service-row{display:grid;grid-template-columns:390px 1fr;gap:34px;align-items:center;padding:28px;border:1px solid var(--line);border-radius:28px;background:#fff;box-shadow:0 16px 50px rgba(7,24,43,.08);margin-bottom:26px}
.service-row img{width:100%;height:270px;object-fit:cover;border-radius:20px}
.service-row h2{font-size:34px}
.project-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.project-card{position:relative;overflow:hidden;border-radius:26px;box-shadow:var(--shadow);background:#000;min-height:340px}
.project-card img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:.35s}
.project-card:hover img{transform:scale(1.04)}
.project-card:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,24,43,0) 35%,rgba(7,24,43,.92) 100%)}
.project-card .caption{position:absolute;left:22px;right:22px;bottom:20px;z-index:2;color:#fff}
.project-card h3{color:#fff;margin-bottom:5px;font-size:23px}
.project-card p{margin:0;color:#d7ebfb}
.cta{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;border-radius:32px;padding:40px;box-shadow:var(--shadow)}
.cta h2{color:#fff;font-size:clamp(28px,4vw,44px)}
.cta p{color:#cfe6fa;margin:0;font-size:18px}
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:step}
.step{background:#fff;border:1px solid rgba(255,255,255,.14);border-radius:22px;padding:24px;position:relative;box-shadow:0 12px 40px rgba(7,24,43,.08)}
.dark .step{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.16)}
.step:before{counter-increment:step;content:"0" counter(step);display:inline-flex;width:42px;height:42px;border-radius:50%;align-items:center;justify-content:center;background:var(--gold);color:var(--navy);font-weight:1000;margin-bottom:14px}
.step p{color:var(--muted);margin:0}
.dark .step p{color:#bad6ee}
.area-list{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.area-list span{background:#fff;border:1px solid var(--line);padding:14px 16px;border-radius:16px;font-weight:900;color:var(--blue)}
.form-wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:34px;align-items:start}
form{background:#fff;border:1px solid var(--line);border-radius:26px;padding:28px;box-shadow:var(--shadow)}
label{display:block;font-weight:900;margin:0 0 7px;color:var(--navy)}
input,select,textarea{width:100%;border:1px solid #cdd9e5;border-radius:14px;padding:13px 14px;margin-bottom:16px;font:inherit;background:#fff}
textarea{min-height:140px;resize:vertical}
.footer{background:#061320;color:#bed3e6;padding:58px 0 22px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:28px}
.footer h3,.footer h4{color:#fff;margin:0 0 12px}
.footer p{margin:0 0 10px}
.footer a{display:block;color:#bed3e6;margin:7px 0}
.footer a:hover{color:#fff}
.subfooter{border-top:1px solid rgba(255,255,255,.12);margin-top:30px;padding-top:18px;font-size:13px;color:#86a1b8}
.floating-contact{position:fixed;right:18px;bottom:18px;z-index:120;display:flex;flex-direction:column;gap:9px}
.floating-contact a{background:var(--gold);color:var(--navy);padding:11px 14px;border-radius:999px;font-weight:1000;box-shadow:0 12px 30px rgba(7,24,43,.22)}
.floating-contact a:nth-child(2){background:var(--navy);color:#fff}
.notice{background:#fff8e9;border:1px solid #f6d89d;color:#634311;border-radius:18px;padding:16px 18px;font-weight:800}
@media(max-width:980px){
  .nav{display:none;position:absolute;left:4vw;right:4vw;top:86px;background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);padding:18px;flex-direction:column;align-items:flex-start}
  .nav.open{display:flex}
  .menu-toggle{display:block}
  .hero .container{grid-template-columns:1fr;min-height:620px}
  .hero-stats,.grid-3,.grid-4,.process,.project-grid,.area-list,.footer-grid{grid-template-columns:1fr 1fr}
  .split,.split.reverse,.form-wrap,.service-row,.cta{grid-template-columns:1fr}
  .service-row img,.feature-img img{height:330px}
}
@media(max-width:640px){
  .topbar .container{flex-direction:column;align-items:flex-start;gap:3px}
  .hero .container{padding:54px 0;min-height:600px}
  .hero-stats,.grid-3,.grid-4,.process,.project-grid,.area-list,.footer-grid{grid-template-columns:1fr}
  .section{padding:58px 0}
  .brand strong{font-size:18px}
  .brand img{width:48px;height:48px}
  .floating-contact{right:10px;bottom:10px}
  .cta{padding:28px}
}


/* Moving SEO location bar */
.topbar{overflow:hidden;white-space:nowrap}
.topbar .container{display:block;width:100%;max-width:none;padding:0}
.marquee{position:relative;overflow:hidden;padding:9px 0}
.marquee-track{display:flex;align-items:center;gap:30px;width:max-content;animation:marqueeScroll 38s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-group{display:flex;align-items:center;gap:30px;padding-left:30px}
.marquee-link{display:inline-flex;align-items:center;gap:10px;color:#d9ebfb;font-size:14px;font-weight:800}
.marquee-link b{color:#fff}
.marquee-link .dot{width:7px;height:7px;border-radius:50%;background:#f5a623;display:inline-block;flex:none}
.marquee-link:hover{color:#fff;text-decoration:underline}
@keyframes marqueeScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Location pages */
.info-list{display:grid;gap:12px;margin:18px 0 0}
.info-item{background:#fff;border:1px solid var(--line);border-radius:18px;padding:16px 18px;box-shadow:0 10px 30px rgba(7,24,43,.06)}
.info-item strong{display:block;color:var(--navy);margin-bottom:6px}
.location-panels{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.location-panels .card{padding:24px}
.location-panels p{margin:0;color:var(--muted)}
@media(max-width:980px){
  .marquee-link{font-size:13px}
  .location-panels{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .marquee{padding:8px 0}
  .marquee-link{font-size:12px}
  .location-panels{grid-template-columns:1fr}
}
