:root{
  --navy:#081a2d;
  --navy2:#10243c;
  --green:#36b23a;
  --green-dark:#28952c;
  --cyan:#2ea3f2;
  --text:#10243c;
  --muted:#546578;
  --off:#f3f4f6;
  --card:#12253d;
  --white:#ffffff;
  --shadow:0 22px 60px rgba(6,19,35,.18);
  --shadow-soft:0 16px 40px rgba(7,24,41,.10);
  --radius:22px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:linear-gradient(180deg,#fbfbfc 0%,#f0f2f5 100%);
}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{width:min(1240px,calc(100% - 32px));margin:0 auto}
.topbar{
  background:linear-gradient(90deg,#07172a 0%,#0d2240 52%,#07172a 100%);
  color:#fff;
  position:relative;
  z-index:20;
}
.topbar .container{
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  padding:14px 0;
}
.topbar-links{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.topbar-links a{font-weight:700;color:#fff}
.topbar-actions{display:flex;align-items:center;gap:12px}
.top-call-btn,.top-quote-btn,.btn,.card-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  border-radius:4px;font-weight:800;transition:.2s ease;
}
.top-call-btn,.btn-primary{background:var(--green);color:#fff;box-shadow:var(--shadow-soft)}
.top-call-btn:hover,.btn-primary:hover{background:var(--green-dark)}
.top-quote-btn,.btn-secondary{background:#f1f0ec;color:#20364d;border:1px solid rgba(16,36,60,.12)}
.top-call-btn,.top-quote-btn{padding:14px 22px}
.site-header{
  position:absolute;left:0;right:0;top:68px;z-index:15;
}
.site-header .container{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
  padding:26px 0;
}

.brand{
  display:flex;
  align-items:center;
  flex:0 0 auto;
  overflow:visible;
}
.brand img{
  display:block;
  height:190px;
  width:auto;
  max-width:none;
  filter:drop-shadow(0 10px 24px rgba(0,0,0,.18));
}

.nav{display:flex;align-items:center;gap:28px;color:#fff;font-weight:700}
.nav a{opacity:.95}
.nav a:hover{opacity:1}
.mobile-bar{display:none}
.hero{
  position:relative;
  min-height:760px;
  color:#fff;
  background:
    linear-gradient(90deg,rgba(4,12,24,.82) 0%,rgba(4,12,24,.66) 34%,rgba(4,12,24,.36) 64%,rgba(4,12,24,.48) 100%),
    url('hero-bg.jpg') center/cover no-repeat;
  overflow:hidden;
}
.hero::after{
  content:"";
  position:absolute;inset:auto 0 0 0;height:160px;
  background:linear-gradient(180deg,rgba(255,255,255,0),rgba(255,255,255,.92));
}
.hero-inner{
  position:relative;z-index:2;
  padding:170px 0 230px;
}
.hero-copy{max-width:700px}
.kicker{
  display:inline-block;margin-bottom:18px;padding-bottom:8px;
  border-bottom:4px solid var(--green);letter-spacing:.12em;text-transform:uppercase;
  font-size:20px;font-weight:800;color:#dce9f8;
}
.hero h1{
  font-size:clamp(46px,6.3vw,78px);
  line-height:.98;letter-spacing:-.04em;margin:0 0 20px;
  max-width:840px;
}
.hero p{
  font-size:clamp(20px,2.2vw,31px);line-height:1.5;color:#edf2f8;
  max-width:900px;margin:0 0 34px;
}
.hero-actions{display:flex;gap:18px;flex-wrap:wrap}
.btn{padding:22px 34px;font-size:20px}
.hero-note{margin-top:16px;color:#d6deea;font-size:17px}
.offer-wrap{position:relative;z-index:3;margin-top:-86px}
.offer-box{
  background:linear-gradient(180deg,rgba(255,255,255,.97),rgba(246,247,249,.96));
  border:1px solid rgba(16,36,60,.08);
  box-shadow:0 20px 55px rgba(7,24,41,.16);
  border-radius:0;padding:0;overflow:hidden;
}
.offer-grid{display:grid;grid-template-columns:1.35fr .65fr}
.offer-copy{padding:34px 40px}
.offer-kicker{font-size:68px;line-height:.92;font-weight:900;color:#195f1f;letter-spacing:-.04em}
.offer-kicker span{color:#112945}
.offer-copy p{font-size:28px;line-height:1.45;margin:14px 0 0;color:#23384e}
.offer-actions{display:grid;grid-template-rows:1fr 1fr}
.offer-actions a{
  display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:900;
}
.offer-actions .offer-call{background:var(--green);color:#fff}
.offer-actions .offer-quote{background:#efeee9;color:#17304a;border-top:1px solid rgba(16,36,60,.08)}
.section-light{position:relative;background:linear-gradient(180deg,#f6f7f8 0%,#f1f3f6 100%)}
.texture::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.32;
  background-image:radial-gradient(rgba(255,255,255,.85) 0.8px, transparent 0.8px);
  background-size:12px 12px;
  mix-blend-mode:soft-light;
}
.section-pad{padding:74px 0}
.section-title{font-size:clamp(34px,4vw,60px);line-height:1.03;letter-spacing:-.04em;text-align:center;color:#10243c;margin:0 0 42px}
.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.trust-item{
  background:transparent;border:none;padding:8px 8px 0;
  display:grid;grid-template-columns:84px 1fr;gap:18px;align-items:start;
}
.trust-icon{
  width:68px;height:68px;border-radius:18px;background:linear-gradient(180deg,#12345c,#0a2240);
  color:#fff;display:grid;place-items:center;font-size:28px;box-shadow:var(--shadow-soft)
}
.trust-item h3{margin:0 0 8px;font-size:32px;line-height:1.05;color:#10243c;letter-spacing:-.03em}
.trust-item p{margin:0;color:#495d72;font-size:20px;line-height:1.55}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.service-card{
  position:relative;min-height:420px;overflow:hidden;color:#fff;
  box-shadow:var(--shadow);background:#0d213a;
}
.service-card .bg{
  position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.02)
}
.service-card::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(8,26,45,.08) 0%,rgba(8,26,45,.18) 28%,rgba(8,26,45,.94) 100%);
}
.service-card .content{position:relative;z-index:1;display:flex;flex-direction:column;justify-content:flex-end;min-height:420px;padding:28px}
.service-card h3{margin:0 0 10px;font-size:34px;line-height:1.05;letter-spacing:-.03em}
.service-card p{margin:0 0 22px;color:#e7edf4;font-size:22px;line-height:1.5}
.card-btn{
  padding:14px 22px;border:1px solid rgba(255,255,255,.45);color:#fff;
  width:max-content;font-size:18px;background:rgba(255,255,255,.02)
}
.card-btn:hover{background:rgba(255,255,255,.10)}
.service-bar{padding:34px 0;background:#0f233c;color:#fff}
.service-bar .container{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.service-bar h3{margin:0;font-size:34px;letter-spacing:-.03em}
.service-bar p{margin:8px 0 0;color:#d8e1eb;font-size:19px}
.service-bar .actions{display:flex;gap:14px;flex-wrap:wrap}
.dark-section{background:linear-gradient(180deg,#08192d 0%,#0d2340 100%);color:#fff;position:relative;overflow:hidden}
.dark-section::before{content:"";position:absolute;inset:0;opacity:.14;background:url('uniform-mockup.jpg') right -140px top 40px / 540px auto no-repeat}
.dark-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:start}
.dark-panel{padding:30px 0}
.dark-panel h2{font-size:clamp(34px,4vw,58px);line-height:1.02;letter-spacing:-.04em;margin:0 0 18px}
.dark-panel p{color:#d9e2ee;font-size:21px;line-height:1.65;margin:0 0 24px;max-width:760px}
.dark-list{display:grid;gap:18px}
.dark-list .item{display:grid;grid-template-columns:54px 1fr;gap:16px;align-items:start}
.dark-list .icon{width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.10);display:grid;place-items:center;font-size:24px}
.dark-list h4{margin:0 0 6px;font-size:24px}
.dark-list span{display:block;color:#ced8e5;font-size:18px;line-height:1.5}
.form-card{
  position:relative;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(244,245,247,.98));
  border:1px solid rgba(16,36,60,.08);padding:28px;box-shadow:var(--shadow);color:#10243c
}
.form-card h3{margin:0 0 10px;font-size:40px;line-height:1.04;letter-spacing:-.03em}
.form-card p{margin:0 0 20px;color:#4a5d72;font-size:18px;line-height:1.6}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid .full{grid-column:1/-1}
input,select,textarea{
  width:100%;padding:17px 16px;border:1px solid rgba(16,36,60,.15);border-radius:0;
  background:#fff;color:#10243c;font:inherit;font-size:16px;outline:none
}
input:focus,select:focus,textarea:focus{border-color:#2ea3f2;box-shadow:0 0 0 3px rgba(46,163,242,.12)}
textarea{min-height:148px;resize:vertical}
.form-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:6px}
.form-actions .btn{padding:18px 28px;font-size:18px}
.form-status{display:none;padding:16px 18px;margin:0 0 16px;border-left:5px solid #36b23a;background:#eef8ef;color:#113219;font-weight:700}
.form-status.error{border-left-color:#c0392b;background:#fff1ef;color:#6d1f16}
.footer{background:#08192d;color:#fff;padding:24px 0 34px}
.footer .container{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.footer-links{display:flex;gap:20px;align-items:center;flex-wrap:wrap;color:#dce4ef}
.footer-links a:hover{color:#fff}
.footer-copy{color:#dce4ef}
@media (max-width:1100px){
  .offer-grid,.dark-grid{grid-template-columns:1fr}
  .services-grid,.trust-grid{grid-template-columns:1fr 1fr}
  .offer-actions{grid-template-columns:1fr 1fr;grid-template-rows:none}
}
@media (max-width:820px){
  .topbar .container,.site-header .container,.service-bar .container,.footer .container{display:block}
  .topbar-links,.topbar-actions{margin-top:12px}
  .site-header{top:104px}
  .nav{display:none}
  .brand img{height:80px}
  .mobile-bar{display:block}
  .hero{min-height:auto}
  .hero-inner{padding:168px 0 180px}
  .hero h1{font-size:clamp(38px,12vw,58px)}
  .hero p{font-size:20px}
  .hero-actions,.form-actions{display:grid;grid-template-columns:1fr}
  .btn{width:100%;padding:18px 22px;font-size:18px}
  .offer-wrap{margin-top:-70px}
  .offer-copy{padding:26px}
  .offer-kicker{font-size:46px}
  .offer-copy p{font-size:20px}
  .trust-grid,.services-grid,.form-grid{grid-template-columns:1fr}
  .service-card,.service-card .content{min-height:360px}
  .section-pad{padding:62px 0}
}


.sub-hero{
  position:relative;
  min-height:700px;
  color:#fff;
  background:
    linear-gradient(90deg,rgba(4,12,24,.84) 0%,rgba(4,12,24,.68) 34%,rgba(4,12,24,.42) 66%,rgba(4,12,24,.56) 100%),
    var(--hero-image) center/cover no-repeat;
  overflow:hidden;
}
.sub-hero::after{
  content:"";
  position:absolute;inset:auto 0 0 0;height:160px;
  background:linear-gradient(180deg,rgba(255,255,255,0),rgba(255,255,255,.92));
}
.sub-hero-inner{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.05fr .95fr;gap:30px;align-items:end;
  padding:170px 0 220px;
}
.hero-side-panel{
  background:rgba(9,22,39,.74);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:var(--shadow);
  backdrop-filter:blur(8px);
  padding:30px;
}
.hero-side-panel h3{
  margin:0 0 16px;
  font-size:40px;line-height:1.04;letter-spacing:-.04em;
}
.side-copy{
  margin:0 0 18px;
  color:#eef3f9;font-size:22px;line-height:1.6;
}
.hero-bullets,.bullet-stack{display:grid;gap:14px}
.hero-bullets div,.bullet-stack div{
  display:grid;grid-template-columns:28px 1fr;gap:12px;align-items:start;
  color:#eef3f9;font-size:20px;line-height:1.55;
}
.check{
  width:28px;height:28px;border-radius:50%;
  display:grid;place-items:center;
  background:rgba(54,178,58,.24);color:#fff;font-weight:900;
  margin-top:2px;
}
.section-intro{
  max-width:900px;margin:0 auto 36px;
  text-align:center;color:#526173;font-size:22px;line-height:1.65;
}
.showcase-grid{
  display:grid;grid-template-columns:.95fr 1.05fr;gap:28px;align-items:stretch;
}
.showcase-photo{
  position:relative;overflow:hidden;min-height:520px;
  background:#0d213a;box-shadow:var(--shadow);
}
.showcase-photo img{
  width:100%;height:100%;object-fit:cover;
}
.showcase-photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(8,26,45,.04) 0%,rgba(8,26,45,.12) 30%,rgba(8,26,45,.34) 100%);
}
.showcase-copy{
  background:#fff;border:1px solid rgba(16,36,60,.08);
  box-shadow:var(--shadow-soft);padding:32px;
}
.eyebrow{
  display:inline-block;margin-bottom:12px;padding-bottom:8px;
  border-bottom:4px solid var(--green);letter-spacing:.10em;text-transform:uppercase;
  color:#10243c;font-size:17px;font-weight:900;
}
.showcase-copy h2{
  margin:0 0 12px;font-size:clamp(36px,4.6vw,58px);line-height:1.03;letter-spacing:-.04em;
}
.showcase-copy p{
  margin:0 0 18px;color:#526173;font-size:21px;line-height:1.65;
}
.inline-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.area-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.area-card{
  display:block;background:#fff;border:1px solid rgba(16,36,60,.10);box-shadow:var(--shadow-soft);
  padding:24px;min-height:210px;transition:.2s ease;
}
.area-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.area-card h3{
  margin:0 0 10px;font-size:30px;line-height:1.05;letter-spacing:-.03em;color:#10243c;
}
.area-card p{
  margin:0 0 20px;color:#5a697a;font-size:19px;line-height:1.6;
}
.area-card span{
  color:var(--green-dark);font-size:16px;font-weight:900;letter-spacing:.04em;
}
.cluster-title{
  margin:0 0 10px;font-size:clamp(34px,4vw,52px);line-height:1.03;letter-spacing:-.04em;color:#10243c;
}
.cluster-intro{
  max-width:860px;margin:0 0 28px;color:#546578;font-size:22px;line-height:1.6;
}
@media (max-width:1100px){
  .sub-hero-inner,.showcase-grid,.area-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:820px){
  .sub-hero{min-height:auto}
  .sub-hero-inner,.showcase-grid,.area-grid{grid-template-columns:1fr}
  .sub-hero-inner{padding:168px 0 180px}
  .hero-side-panel,.showcase-copy{padding:22px}
  .hero-side-panel h3{font-size:30px}
  .hero-bullets div,.bullet-stack div,.showcase-copy p,.side-copy,.section-intro,.cluster-intro{font-size:18px}
  .showcase-photo{min-height:320px}
  .area-card h3{font-size:25px}
}


/* Gallery */
.gallery-preview-grid,
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.gallery-item{
  position:relative;
  overflow:hidden;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  box-shadow:0 20px 40px rgba(0,0,0,.22);
}
.gallery-item img{
  width:100%;
  height:100%;
  min-height:260px;
  object-fit:cover;
  display:block;
  transition:transform .35s ease;
}
.gallery-item:hover img{transform:scale(1.04)}
.gallery-caption{
  position:absolute;
  left:0; right:0; bottom:0;
  padding:16px 18px;
  background:linear-gradient(180deg, rgba(4,11,22,0), rgba(4,11,22,.88));
  color:#fff;
  font-weight:700;
}
.gallery-hero{
  padding:80px 0 40px;
}
@media (max-width: 960px){
  .gallery-preview-grid,
  .gallery-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 640px){
  .gallery-preview-grid,
  .gallery-grid{grid-template-columns:1fr}
}

/* === Emergency gallery overlay fix === */
/* Hide rogue filename / open-image bars injected by gallery widgets */
.gallery-grid [class*="caption"],
.gallery-grid [class*="Caption"],
.gallery-grid [class*="overlay"],
.gallery-grid [class*="Overlay"],
.gallery-grid [class*="meta"],
.gallery-grid [class*="Meta"],
.gallery-grid [class*="filename"],
.gallery-grid [class*="file-name"],
.gallery-grid [class*="title"],
.gallery-grid [class*="Title"],
.gallery-preview-grid [class*="caption"],
.gallery-preview-grid [class*="Caption"],
.gallery-preview-grid [class*="overlay"],
.gallery-preview-grid [class*="Overlay"],
.gallery-preview-grid [class*="meta"],
.gallery-preview-grid [class*="Meta"],
.gallery-preview-grid [class*="filename"],
.gallery-preview-grid [class*="file-name"],
.gallery-preview-grid [class*="title"],
.gallery-preview-grid [class*="Title"]{
  display:none !important;
}

/* Keep any accidental bars clipped inside each tile */
.gallery-item,
.gallery-item a,
.gallery-item picture,
.gallery-item figure{
  position:relative;
  overflow:hidden;
}

.gallery-item > div,
.gallery-item > span,
.gallery-item > figcaption,
.gallery-item a > div,
.gallery-item a > span,
.gallery-item a > figcaption{
  max-width:100%;
}

/* Kill common full-width injected bars on gallery pages */
body .gallery-grid ~ div[style*="position: fixed"],
body .gallery-preview-grid ~ div[style*="position: fixed"],
body div[style*="background: rgb(0, 0, 0)"],
body div[style*="background-color: rgb(0, 0, 0)"]{
  display:none !important;
}
