/* ===========================================================
   Current Installations — shared site styles
   Brand: Navy #013A58 · Amber #FFA307 · Montserrat / Inter
   =========================================================== */
:root{
  --navy:#013A58;
  --navy-d:#012E45;
  --amber:#FFA307;
  --amber-d:#E8920A;
  --ink:#1A1F24;
  --grey:#5C6770;
  --light:#F1F4F6;
  --line:#E1E6EA;
  --radius:12px;
  --shadow:0 10px 30px rgba(1,58,88,.10);
  --shadow-sm:0 2px 10px rgba(1,58,88,.07);
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;color:var(--ink);background:#fff;line-height:1.65;-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4,h5,.font-d{font-family:'Montserrat',sans-serif;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
.wrap{max-width:1140px;margin:0 auto;padding:0 28px;}
.narrow{max-width:820px;}
.eyebrow{font-family:'Montserrat',sans-serif;font-weight:800;letter-spacing:.16em;text-transform:uppercase;font-size:12px;color:var(--amber);}

.btn{display:inline-flex;align-items:center;gap:9px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;padding:14px 24px;border-radius:8px;transition:.18s;cursor:pointer;border:2px solid transparent;}
.btn-amber{background:var(--amber);color:var(--navy);}
.btn-amber:hover{background:var(--amber-d);transform:translateY(-1px);}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.45);}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08);}
.btn-navy{background:var(--navy);color:#fff;}
.btn-navy:hover{background:var(--navy-d);}
.btn-lg{font-size:16px;padding:16px 30px;}

/* ---- direction banner ---- */

/* ---- header ---- */
header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line);}
.nav{display:flex;align-items:center;justify-content:space-between;height:92px;position:relative;}
.nav .logo img{height:62px;width:auto;}
.nav ul{display:flex;gap:26px;list-style:none;}
.nav ul a{font-family:'Montserrat',sans-serif;font-weight:600;font-size:14.5px;color:var(--navy);}
.nav ul a:hover,.nav ul a.active{color:var(--amber);}
.nav-right{display:flex;align-items:center;gap:18px;}
.phone{font-family:'Montserrat',sans-serif;font-weight:800;font-size:17px;color:var(--navy);display:flex;align-items:center;gap:8px;}
.phone .ico{color:var(--amber);}
.navtoggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;}
.navtoggle span{display:block;width:26px;height:3px;background:var(--navy);border-radius:2px;}
@media(max-width:900px){
  .nav ul{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;gap:0;border-bottom:1px solid var(--line);box-shadow:var(--shadow);padding:6px 0;}
  .nav ul.show{display:flex;}
  .nav ul li{width:100%;}
  .nav ul a{display:block;padding:14px 28px;font-size:16px;}
  .navtoggle{display:flex;order:3;}
  .nav-right .btn{display:none;}
  .phone-text{display:none;}
}

/* ---- home hero ---- */
.hero{position:relative;color:#fff;background:linear-gradient(110deg,rgba(1,46,69,.94) 0%,rgba(1,58,88,.82) 55%,rgba(1,58,88,.55) 100%),url('current-installations-team.webp') center 20%/cover;}
.hero .wrap{padding-top:92px;padding-bottom:96px;}
.hero-inner{max-width:660px;}
.hero h1{font-weight:900;font-size:52px;line-height:1.06;letter-spacing:-.02em;margin:16px 0 18px;}
.hero h1 .hl{color:var(--amber);}
.hero .sub{font-size:19px;color:#D4E0E8;margin-bottom:30px;max-width:34em;}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:28px;}
.hero-trust{display:flex;gap:22px;flex-wrap:wrap;font-size:13.5px;color:#AFC4D2;font-weight:500;}
.hero-trust span{display:flex;align-items:center;gap:7px;}
.hero-trust .dot{color:var(--amber);font-size:16px;line-height:0;}
@media(max-width:640px){.hero h1{font-size:36px;}.hero .sub{font-size:17px;}}

/* ---- interior page hero ---- */
.pagehero{position:relative;color:#fff;background:linear-gradient(120deg,var(--navy-d),var(--navy));}
.pagehero .wrap{padding:62px 0 58px;}
.pagehero .crumb{font-family:'Montserrat',sans-serif;font-size:12px;letter-spacing:.04em;color:#8DA4B2;margin-bottom:14px;}
.pagehero .crumb a:hover{color:#fff;}
.pagehero h1{font-weight:900;font-size:44px;line-height:1.08;letter-spacing:-.02em;margin:0 0 16px;max-width:20ch;}
.pagehero p{font-size:18px;color:#C9D6DE;max-width:56ch;}
@media(max-width:640px){.pagehero h1{font-size:32px;}}

/* ---- trust strip ---- */
.strip{background:var(--navy-d);color:#fff;}
.strip .wrap{display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px 24px;padding:18px 28px;}
.strip .item{display:flex;align-items:center;gap:10px;font-family:'Montserrat',sans-serif;font-weight:600;font-size:13.5px;color:#D4E0E8;}
.strip .item b{color:#fff;}
.strip .ck{color:var(--amber);font-weight:900;}

/* ---- sections ---- */
section{padding:84px 0;}
.alt{background:var(--light);}
.sec-head{max-width:680px;margin-bottom:44px;}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center;}
h2{font-weight:800;font-size:36px;color:var(--navy);letter-spacing:-.01em;line-height:1.12;margin:10px 0 12px;}
.sec-head p{font-size:17px;color:var(--grey);}
.lede{font-size:18px;color:var(--ink);max-width:62ch;margin-bottom:18px;}
.prose p{font-size:16px;color:var(--ink);max-width:64ch;margin-bottom:16px;}
.prose h3{font-size:20px;color:var(--navy);margin:30px 0 10px;}

/* ---- cards (who we help) ---- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.scard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px;box-shadow:var(--shadow-sm);transition:.2s;position:relative;overflow:hidden;display:flex;flex-direction:column;}
.scard:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.scard .ic{width:46px;height:46px;border-radius:10px;background:rgba(255,163,7,.14);display:flex;align-items:center;justify-content:center;margin-bottom:16px;}
.scard .ic svg{width:24px;height:24px;stroke:var(--amber);}
.scard h4{font-size:17px;color:var(--navy);margin-bottom:7px;font-weight:800;}
.scard p{font-size:14px;color:var(--grey);margin-bottom:14px;flex:1;}
.scard .more{font-family:'Montserrat',sans-serif;font-weight:700;font-size:13px;color:var(--navy);display:inline-flex;align-items:center;gap:6px;}
.scard .more .ar{color:var(--amber);transition:.2s;}
.scard:hover .more .ar{transform:translateX(3px);}
.scard.flag::before{content:"Priority";position:absolute;top:14px;right:-30px;background:var(--amber);color:var(--navy);font-family:'Montserrat',sans-serif;font-weight:800;font-size:10px;letter-spacing:.08em;text-transform:uppercase;padding:4px 34px;transform:rotate(45deg);}
@media(max-width:980px){.cards{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.cards{grid-template-columns:1fr;}}

/* ---- split (text + image) ---- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;}
.split.rev .col-img{order:-1;}
.feat-img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);position:relative;aspect-ratio:4/3.2;background-size:cover;background-position:center;}
.why-img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);position:relative;aspect-ratio:4/3.2;background:linear-gradient(180deg,rgba(1,58,88,.15),rgba(1,58,88,.55)),url('https://images.unsplash.com/photo-1682345262055-8f95f3c513ea?auto=format&fit=crop&w=1000&q=75') center/cover;}
.why-img .badge,.feat-img .badge{position:absolute;left:22px;bottom:22px;background:#fff;border-radius:10px;padding:14px 18px;box-shadow:var(--shadow);}
.badge .big{font-family:'Montserrat',sans-serif;font-weight:900;font-size:30px;color:var(--navy);line-height:1;}
.badge .lbl{font-size:12px;color:var(--grey);font-weight:600;}
.pillar{display:flex;gap:16px;margin-bottom:24px;}
.pillar .num{flex:none;width:40px;height:40px;border-radius:9px;background:var(--navy);color:var(--amber);font-family:'Montserrat',sans-serif;font-weight:900;display:flex;align-items:center;justify-content:center;font-size:16px;}
.pillar h4{font-size:18px;color:var(--navy);margin-bottom:4px;}
.pillar p{font-size:15px;color:var(--grey);}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:34px;}.split.rev .col-img{order:0;}}

/* ---- service checklist ---- */
.svc{display:grid;grid-template-columns:1fr 1fr;gap:20px 30px;}
.svc .it{display:flex;gap:14px;}
.svc .it .ck{flex:none;width:30px;height:30px;border-radius:8px;background:rgba(255,163,7,.14);color:var(--amber);font-weight:900;display:flex;align-items:center;justify-content:center;font-size:15px;}
.svc .it h4{font-size:16px;color:var(--navy);margin-bottom:3px;}
.svc .it p{font-size:14px;color:var(--grey);}
@media(max-width:640px){.svc{grid-template-columns:1fr;}}

/* ---- highlight / price box ---- */
.box{background:#fff;border:1px solid var(--line);border-left:4px solid var(--amber);border-radius:0 var(--radius) var(--radius) 0;padding:28px 30px;box-shadow:var(--shadow-sm);}
.box h3{font-size:19px;color:var(--navy);margin-bottom:14px;}
.ticks{list-style:none;display:grid;gap:11px;}
.ticks li{display:flex;gap:11px;font-size:15px;color:var(--ink);}
.ticks li .t{color:var(--amber);font-weight:800;flex:none;}

/* ---- gallery ---- */
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.gal figure{border-radius:var(--radius);overflow:hidden;position:relative;aspect-ratio:4/3;box-shadow:var(--shadow-sm);}
.gal img{width:100%;height:100%;object-fit:cover;transition:.4s;}
.gal figure:hover img{transform:scale(1.05);}
.gal figcaption{position:absolute;left:0;right:0;bottom:0;padding:30px 16px 14px;color:#fff;font-family:'Montserrat',sans-serif;font-weight:700;font-size:13.5px;background:linear-gradient(transparent,rgba(1,46,69,.88));}
@media(max-width:820px){.gal{grid-template-columns:1fr 1fr;}}
@media(max-width:480px){.gal{grid-template-columns:1fr;}}

/* ---- service areas ---- */
.areas{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px;}
.areas span{background:#fff;border:1px solid var(--line);border-radius:30px;padding:9px 18px;font-family:'Montserrat',sans-serif;font-weight:600;font-size:13.5px;color:var(--navy);}
.areas span.hub{background:var(--navy);color:#fff;}
.maparea{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);}
.maparea iframe{display:block;width:100%;height:380px;border:0;}

/* ---- FAQ accordion ---- */
.faq details{border:1px solid var(--line);border-radius:10px;margin-bottom:12px;background:#fff;box-shadow:var(--shadow-sm);}
.faq summary{cursor:pointer;padding:18px 22px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:16px;color:var(--navy);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+";color:var(--amber);font-size:24px;font-weight:700;line-height:1;}
.faq details[open] summary::after{content:"\2013";}
.faq .ans{padding:0 22px 20px;color:var(--grey);font-size:15px;max-width:70ch;}

/* ---- contact ---- */
.contact-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:48px;align-items:start;}
.form .field{margin-bottom:16px;}
.form label{display:block;font-family:'Montserrat',sans-serif;font-weight:600;font-size:13px;color:var(--navy);margin-bottom:6px;}
.form input,.form textarea,.form select{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:8px;font-family:'Inter',sans-serif;font-size:15px;background:#fff;color:var(--ink);}
.form textarea{min-height:130px;resize:vertical;}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(255,163,7,.15);}
.form .hp{position:absolute;left:-9999px;}
.cinfo{background:var(--light);border-radius:var(--radius);padding:28px;}
.cinfo h3{font-size:18px;color:var(--navy);margin-bottom:18px;}
.cinfo .row{display:flex;gap:13px;margin-bottom:18px;align-items:flex-start;}
.cinfo .row .ic{flex:none;color:var(--amber);font-size:18px;width:22px;text-align:center;}
.cinfo .row b{font-family:'Montserrat',sans-serif;color:var(--navy);font-size:14px;display:block;}
.cinfo .row span{font-size:14px;color:var(--grey);}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr;gap:30px;}}

/* ---- final CTA ---- */
.cta{background:var(--navy);color:#fff;}
.cta .wrap{display:grid;grid-template-columns:1.2fr .8fr;gap:50px;align-items:center;}
.cta h2{color:#fff;font-size:34px;}
.cta p{color:#C9D6DE;font-size:17px;margin-bottom:26px;}
.cta-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center;}
.cta-phone{font-family:'Montserrat',sans-serif;font-weight:800;font-size:22px;color:#fff;display:flex;align-items:center;gap:10px;}
.cta-phone .ico{color:var(--amber);}
.cta-quote{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius);padding:26px;}
.cta-quote h4{font-family:'Montserrat',sans-serif;color:#fff;font-size:15px;letter-spacing:.04em;text-transform:uppercase;margin-bottom:16px;}
.cta-quote ul{list-style:none;display:grid;gap:13px;}
.cta-quote li{display:flex;gap:11px;color:#E4EDF2;font-size:14.5px;}
.cta-quote li .t{color:var(--amber);font-weight:800;}
@media(max-width:820px){.cta .wrap{grid-template-columns:1fr;gap:30px;}}

/* ---- footer ---- */
footer{background:var(--navy-d);color:#9FB4C1;padding:60px 0 30px;font-size:14px;}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:36px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.1);}
footer h5{font-family:'Montserrat',sans-serif;color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px;}
footer a{color:#9FB4C1;display:block;margin-bottom:9px;}
footer a:hover{color:var(--amber);}
.foot-logo img{height:58px;width:auto;margin-bottom:16px;background:#fff;padding:10px 16px;border-radius:8px;}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;padding-top:22px;font-size:12.5px;color:#7C93A2;}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:480px){.foot-grid{grid-template-columns:1fr;}}

/* ---- sticky mobile call ---- */
.mcall{display:none;}
@media(max-width:900px){
  .mcall{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:60;}
  .mcall a{flex:1;display:flex;align-items:center;justify-content:center;gap:9px;padding:15px;font-family:'Montserrat',sans-serif;font-weight:800;font-size:15px;}
  .mcall .call{background:var(--amber);color:var(--navy);}
  .mcall .quote{background:var(--navy);color:#fff;}
  body{padding-bottom:54px;}
}

/* ===== Cookie consent banner ===== */
.cookiebar{position:fixed;left:16px;right:16px;bottom:16px;z-index:80;max-width:760px;margin:0 auto;background:var(--navy-d);color:#EAF1F6;border-radius:var(--radius);box-shadow:0 12px 40px rgba(1,30,45,.45);padding:16px 18px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;}
.cookiebar p{font-size:13.5px;line-height:1.5;margin:0;flex:1;min-width:230px;}
.cookiebar a{color:var(--amber);font-weight:600;}
.cookiebar-actions{display:flex;gap:10px;flex:none;}
.cookiebar .btn{padding:9px 18px;font-size:13.5px;}
.cookiebar .btn-ghost{background:transparent;color:#EAF1F6;border:1px solid rgba(255,255,255,.35);}
.cookiebar .btn-ghost:hover{background:rgba(255,255,255,.08);}
@media(max-width:820px){
  .cookiebar{left:10px;right:10px;bottom:64px;padding:14px;}
  .cookiebar-actions{width:100%;}
  .cookiebar .btn{flex:1;}
}

/* ===== 404 ===== */
.err{text-align:center;padding:90px 0;}
.err .code{font-family:'Montserrat',sans-serif;font-weight:900;font-size:84px;color:var(--amber);line-height:1;}

.areas a{text-decoration:none;display:inline-flex;}
.areas a span{transition:.18s;}
.areas a:hover span{background:var(--navy);color:#fff;border-color:var(--navy);}
