/* =========================================================
   Reliable Construction & Home Improvement — Brand stylesheet
   Blue / Gold / White · Veteran owned · Licensed & Insured
   ========================================================= */

:root{
  /* Brand */
  --blue:        #1857C4;
  --blue-600:    #1450B8;
  --blue-700:    #103F94;
  --navy:        #0A2750;
  --navy-900:    #071B3A;
  --gold:        #F6C513;
  --gold-600:    #E3B100;
  --gold-soft:   #FFF4CC;
  --wa:          #25D366;
  --wa-600:      #1FB457;

  /* Neutrals */
  --ink:    #0E1726;
  --body:   #33415A;
  --muted:  #6A7790;
  --paper:  #FFFFFF;
  --mist:   #F4F6FB;
  --mist-2: #EAEFF7;
  --line:   #E0E6F0;
  --line-2: #CBD5E6;

  /* Type */
  --f-display: "Archivo", system-ui, sans-serif;
  --f-body:    "Manrope", system-ui, sans-serif;
  --f-mono:    "Space Mono", ui-monospace, monospace;

  /* Geometry */
  --r-sm: 8px;
  --r:    14px;
  --r-lg: 22px;
  --shadow: 0 18px 50px -24px rgba(10,39,80,.45);
  --shadow-sm: 0 8px 22px -14px rgba(10,39,80,.40);
  --maxw: 1200px;
  --gutter: clamp(20px, 5vw, 64px);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--f-body);
  color:var(--body);
  background:var(--paper);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

h1,h2,h3,h4{font-family:var(--f-display);color:var(--ink);margin:0;line-height:1.02;letter-spacing:-.02em;font-weight:800}
p{margin:0}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(64px,8vw,112px)}
.center{text-align:center}

/* Eyebrow / overline */
.eyebrow{
  font-family:var(--f-mono);
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  font-weight:700;color:var(--blue);
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow.on-dark{color:var(--gold)}
.eyebrow::before{content:"";width:26px;height:2px;background:currentColor;display:inline-block}

.kicker{
  font-family:var(--f-mono);font-size:12.5px;letter-spacing:.2em;
  text-transform:uppercase;font-weight:700;color:var(--muted);
}

/* Headings scale */
.h-xxl{font-size:clamp(2.6rem,6.5vw,5.2rem)}
.h-xl{font-size:clamp(2.1rem,4.6vw,3.5rem)}
.h-lg{font-size:clamp(1.7rem,3vw,2.5rem)}
.lead{font-size:clamp(1.05rem,1.5vw,1.28rem);color:var(--body);line-height:1.55}
.text-gold{color:var(--gold)}
.text-blue{color:var(--blue)}

/* ============ Buttons ============ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 26px;border-radius:var(--r-sm);
  font-family:var(--f-display);font-weight:700;font-size:1rem;letter-spacing:-.01em;
  border:2px solid transparent;transition:background .18s,color .18s,border-color .18s,transform .18s;
  line-height:1;white-space:nowrap;
}
.btn svg{width:19px;height:19px}
.btn-wa{background:var(--wa);color:#fff}
.btn-wa:hover{background:var(--wa-600)}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold:hover{background:var(--gold-600)}
.btn-blue{background:var(--blue);color:#fff}
.btn-blue:hover{background:var(--blue-700)}
.btn-outline{border-color:var(--line-2);color:var(--ink);background:#fff}
.btn-outline:hover{border-color:var(--blue);color:var(--blue)}
.btn-ghost-light{border-color:rgba(255,255,255,.45);color:#fff}
.btn-ghost-light:hover{background:rgba(255,255,255,.12);border-color:#fff}

/* ============ Header ============ */
.topbar{
  background:var(--navy-900);color:rgba(255,255,255,.85);
  font-size:13px;
}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:40px;flex-wrap:wrap}
.topbar a{color:rgba(255,255,255,.85)}
.topbar a:hover{color:var(--gold)}
.topbar .lic{font-family:var(--f-mono);letter-spacing:.04em;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.topbar .lic .dot{width:6px;height:6px;border-radius:50%;background:var(--gold)}
.topbar .util{display:flex;align-items:center;gap:18px}

.site-header{
  position:sticky;top:0;z-index:60;background:var(--blue);
  color:#fff;box-shadow:0 6px 24px -16px rgba(0,0,0,.6);
}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:84px}
.brand{display:flex;align-items:center;gap:14px}
.brand img{height:54px;width:auto}
.brand .veteran{
  display:flex;flex-direction:column;line-height:1.05;
  border-left:1px solid rgba(255,255,255,.28);padding-left:14px;
}
.brand .veteran b{font-family:var(--f-display);font-weight:800;font-size:14px;letter-spacing:.02em;color:#fff}
.brand .veteran span{font-family:var(--f-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold)}

.nav{display:flex;align-items:center;gap:34px}
.nav a{
  font-family:var(--f-display);font-weight:700;font-size:14.5px;letter-spacing:.02em;
  text-transform:uppercase;color:#fff;padding:6px 0;position:relative;
}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:3px;background:var(--gold);transition:right .22s}
.nav a:hover::after,.nav a.active::after{right:0}
.nav a.active{color:var(--gold)}

.header-actions{display:flex;align-items:center;gap:14px}
.lang-toggle{
  display:inline-flex;border:1.5px solid rgba(255,255,255,.4);border-radius:999px;overflow:hidden;
  font-family:var(--f-mono);font-size:12px;font-weight:700;
}
.lang-toggle button{
  background:transparent;color:rgba(255,255,255,.75);border:0;padding:7px 13px;letter-spacing:.05em;
}
.lang-toggle button.on{background:var(--gold);color:var(--navy)}

.menu-btn{display:none;background:transparent;border:0;color:#fff;padding:6px}
.menu-btn svg{width:30px;height:30px}

/* Mobile drawer */
.drawer{
  position:fixed;inset:0;z-index:90;display:none;
}
.drawer.open{display:block}
.drawer .scrim{position:absolute;inset:0;background:rgba(7,27,58,.55);backdrop-filter:blur(2px)}
.drawer .panel{
  position:absolute;right:0;top:0;bottom:0;width:min(86vw,340px);
  background:var(--navy);padding:24px;display:flex;flex-direction:column;gap:6px;
  box-shadow:-20px 0 60px -20px rgba(0,0,0,.6);
}
.drawer .panel a{
  font-family:var(--f-display);font-weight:700;text-transform:uppercase;color:#fff;
  padding:15px 10px;border-bottom:1px solid rgba(255,255,255,.1);letter-spacing:.02em;
}
.drawer .panel a:hover,.drawer .panel a.active{color:var(--gold)}
.drawer .x{align-self:flex-end;background:transparent;border:0;color:#fff;font-size:30px;line-height:1;margin-bottom:8px}

/* ============ Hero ============ */
.hero{position:relative;color:#fff;overflow:hidden;background:var(--navy)}
.hero .bg{position:absolute;inset:0}
.hero-slides{position:absolute;inset:0;overflow:hidden}
.hero-slides .slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;will-change:opacity,transform;animation:heroFade 32s linear infinite, heroZoom 32s ease-in-out infinite}
.hero-slides .slide:nth-child(1){animation-delay:0s,0s}
.hero-slides .slide:nth-child(2){animation-delay:-8s,-8s}
.hero-slides .slide:nth-child(3){animation-delay:-16s,-16s}
.hero-slides .slide:nth-child(4){animation-delay:-24s,-24s}
@keyframes heroFade{0%{opacity:0}4%{opacity:1}22%{opacity:1}26%{opacity:0}100%{opacity:0}}
@keyframes heroZoom{0%{transform:scale(1.04)}100%{transform:scale(1.2)}}
@media (prefers-reduced-motion:reduce){.hero-slides .slide{animation:none;opacity:0}.hero-slides .slide:nth-child(1){opacity:1}}
.hero .bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(115deg,rgba(7,27,58,.93) 0%,rgba(7,27,58,.78) 38%,rgba(7,27,58,.35) 100%);
}
.hero .wrap{position:relative;z-index:2;padding-block:clamp(72px,11vw,150px)}
.hero-inner{max-width:760px}
.hero h1{font-size:clamp(2.9rem,7vw,5.6rem);color:#fff;font-weight:800;text-transform:uppercase}
.hero h1 .gold{color:var(--gold);display:block}
.hero .lead{color:rgba(255,255,255,.86);margin-top:22px;max-width:560px}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.hero-trust{display:flex;gap:30px;flex-wrap:wrap;margin-top:46px}
.hero-trust .item{display:flex;align-items:center;gap:11px;font-size:14px;color:rgba(255,255,255,.9)}
.hero-trust .item svg{width:22px;height:22px;color:var(--gold);flex:none}
.hero-trust b{font-family:var(--f-display);color:#fff}

/* ============ Marquee strip ============ */
.strip{background:var(--gold);color:var(--navy);overflow:hidden}
.strip .track{display:flex;gap:48px;white-space:nowrap;padding:15px 0;animation:scroll 32s linear infinite;width:max-content}
.strip .track span{font-family:var(--f-display);font-weight:800;text-transform:uppercase;letter-spacing:.02em;font-size:15px;display:flex;align-items:center;gap:48px}
.strip .track span::after{content:"◆";color:var(--blue);font-size:11px}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ============ Section header ============ */
.sec-head{max-width:720px}
.sec-head.center{margin-inline:auto}
.sec-head h2{margin-top:14px}
.sec-head p{margin-top:16px;color:var(--muted);font-size:1.1rem}

/* ============ Services grid ============ */
.grid{display:grid;gap:22px}
.grid.g3{grid-template-columns:repeat(3,1fr)}
.grid.g2{grid-template-columns:repeat(2,1fr)}
.grid.g4{grid-template-columns:repeat(4,1fr)}

.svc{
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:30px;transition:transform .2s,box-shadow .2s,border-color .2s;
  position:relative;overflow:hidden;
}
.svc::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--blue);transform:scaleY(0);transform-origin:top;transition:transform .25s}
.svc:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line-2)}
.svc:hover::before{transform:scaleY(1)}
.svc .ico{
  width:56px;height:56px;border-radius:12px;display:grid;place-items:center;
  background:var(--blue);color:#fff;margin-bottom:20px;
}
.svc .ico svg{width:28px;height:28px}
.svc h3{font-size:1.32rem;margin-bottom:10px}
.svc p{color:var(--muted);font-size:.97rem}
.svc.feature{background:var(--navy);border-color:var(--navy)}
.svc.feature h3{color:#fff}
.svc.feature p{color:rgba(255,255,255,.72)}
.svc.feature .ico{background:var(--gold);color:var(--navy)}
.svc.feature::before{background:var(--gold)}

/* ============ Split showcase ============ */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:center}
.split.rev{direction:rtl}
.split.rev>*{direction:ltr}
.split .media{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow)}
.split .media img{width:100%;height:100%;object-fit:cover;aspect-ratio:5/4}
.split .media .tag{
  position:absolute;left:20px;bottom:20px;background:var(--gold);color:var(--navy);
  font-family:var(--f-display);font-weight:800;padding:12px 18px;border-radius:10px;font-size:14px;
  text-transform:uppercase;letter-spacing:.02em;box-shadow:var(--shadow-sm);
}
.check{list-style:none;padding:0;margin:26px 0 0;display:grid;gap:14px}
.check li{display:flex;gap:13px;align-items:flex-start;font-weight:600;color:var(--ink)}
.check li svg{width:23px;height:23px;color:var(--blue);flex:none;margin-top:1px}

/* ============ Stats ============ */
.stats{background:var(--navy);color:#fff}
.stats .grid{gap:0}
.stat{padding:18px 26px;text-align:center;border-right:1px solid rgba(255,255,255,.12)}
.stat:last-child{border-right:0}
.stat .num{font-family:var(--f-display);font-weight:800;font-size:clamp(2.6rem,5vw,3.8rem);color:var(--gold);line-height:1}
.stat .lbl{font-family:var(--f-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-top:10px}

/* ============ Gallery ============ */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;grid-auto-rows:210px;grid-auto-flow:dense}
.gallery a{overflow:hidden;border-radius:var(--r-sm);position:relative;background:var(--mist-2);cursor:pointer}
.gallery a img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gallery a:hover img{transform:scale(1.06)}
.gallery a::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(7,27,58,.35));opacity:0;transition:opacity .25s}
.gallery a:hover::after{opacity:1}
.gallery a.tall{grid-row:span 2}
.gallery a.wide{grid-column:span 2}

.lightbox{position:fixed;inset:0;z-index:100;background:rgba(7,27,58,.92);display:none;align-items:center;justify-content:center;padding:30px}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:var(--r-sm);box-shadow:0 30px 80px -20px #000}
.lightbox .close{position:absolute;top:24px;right:30px;color:#fff;font-size:42px;background:transparent;border:0;line-height:1}
.lightbox .nav-x{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:0;color:#fff;width:54px;height:54px;border-radius:50%;font-size:26px;display:grid;place-items:center}
.lightbox .prev{left:24px}.lightbox .next{right:24px}

/* ============ Areas ============ */
.area{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.area .map{height:180px;background:var(--mist-2);position:relative;border-bottom:1px solid var(--line)}
.area .map iframe{width:100%;height:100%;border:0;filter:grayscale(.2)}
.area .body{padding:22px 24px}
.area .body h3{font-size:1.2rem;display:flex;align-items:center;gap:10px}
.area .body h3 svg{width:20px;height:20px;color:var(--blue)}
.area .body p{color:var(--muted);font-size:.95rem;margin-top:8px}

/* ============ CTA band ============ */
.cta-band{background:var(--blue);color:#fff;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:
  repeating-linear-gradient(45deg,rgba(255,255,255,.05) 0 2px,transparent 2px 22px)}
.cta-band .wrap{position:relative;display:flex;align-items:center;justify-content:space-between;gap:36px;flex-wrap:wrap;padding-block:clamp(44px,6vw,72px)}
.cta-band h2{color:#fff;font-size:clamp(1.9rem,4vw,3rem);text-transform:uppercase}
.cta-band p{color:rgba(255,255,255,.85);margin-top:12px;max-width:520px}

/* ============ Footer ============ */
.footer{background:var(--navy-900);color:rgba(255,255,255,.74);padding-top:64px}
.footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer h4{color:#fff;font-size:13px;font-family:var(--f-mono);letter-spacing:.18em;text-transform:uppercase;margin-bottom:20px;font-weight:700}
.footer .brand-f img{height:50px;margin-bottom:18px}
.footer p{font-size:14.5px;line-height:1.7}
.footer ul{list-style:none;padding:0;margin:0;display:grid;gap:11px}
.footer ul a{font-size:14.5px}
.footer ul a:hover{color:var(--gold)}
.footer .lic-badge{display:inline-flex;align-items:center;gap:10px;margin-top:18px;font-family:var(--f-mono);font-size:12px;letter-spacing:.05em;color:var(--gold);border:1px solid rgba(246,197,19,.4);padding:8px 12px;border-radius:8px}
.footer .socials{display:flex;gap:12px;margin-top:18px}
.footer .socials a{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.08);display:grid;place-items:center;color:#fff;transition:background .2s}
.footer .socials a:hover{background:var(--blue)}
.footer .socials svg{width:19px;height:19px}
.footer .contact-row{display:flex;align-items:center;gap:11px;font-size:14.5px;margin-bottom:13px}
.footer .contact-row svg{width:18px;height:18px;color:var(--gold);flex:none}
.footer .bottom{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;padding:24px 0;font-size:13px;color:rgba(255,255,255,.5)}

/* Floating WhatsApp */
.fab{position:fixed;right:22px;bottom:22px;z-index:80;width:60px;height:60px;border-radius:50%;background:var(--wa);display:grid;place-items:center;box-shadow:0 12px 30px -8px rgba(37,211,102,.6);transition:transform .2s}
.fab:hover{transform:scale(1.07)}
.fab svg{width:32px;height:32px;color:#fff}
.fab::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid var(--wa);animation:ping 2.4s ease-out infinite}
@keyframes ping{0%{transform:scale(1);opacity:.7}80%,100%{transform:scale(1.5);opacity:0}}

/* ============ Page banner (subpages) ============ */
.banner{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.banner .bg{position:absolute;inset:0;opacity:.28}
.banner .bg img{width:100%;height:100%;object-fit:cover}
.banner .wrap{position:relative;z-index:2;padding-block:clamp(56px,8vw,96px)}
.banner h1{color:#fff;font-size:clamp(2.3rem,5vw,3.8rem);text-transform:uppercase}
.banner .crumb{font-family:var(--f-mono);font-size:12.5px;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.banner p{color:rgba(255,255,255,.82);margin-top:16px;max-width:600px}

/* ============ Accordion (about) ============ */
.acc{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#fff}
.acc .item{border-bottom:1px solid var(--line)}
.acc .item:last-child{border-bottom:0}
.acc .q{width:100%;text-align:left;background:#fff;border:0;padding:22px 24px;display:flex;justify-content:space-between;align-items:center;gap:16px;font-family:var(--f-display);font-weight:700;font-size:1.1rem;color:var(--ink)}
.acc .q svg{width:22px;height:22px;color:var(--blue);transition:transform .25s;flex:none}
.acc .item.open .q svg{transform:rotate(45deg)}
.acc .a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.acc .a p{padding:0 24px 22px;color:var(--muted)}

/* ============ Contact form ============ */
.form{display:grid;gap:18px}
.field label{display:block;font-family:var(--f-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-weight:700}
.field input,.field textarea{
  width:100%;padding:14px 16px;border:1.5px solid var(--line-2);border-radius:var(--r-sm);
  font-family:var(--f-body);font-size:1rem;color:var(--ink);background:#fff;transition:border-color .18s,box-shadow .18s;
}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 3px rgba(24,87,196,.15)}
.field textarea{min-height:140px;resize:vertical}
.info-card{background:var(--navy);color:#fff;border-radius:var(--r-lg);padding:34px;display:grid;gap:22px;align-content:start}
.info-card h3{color:#fff}
.info-card .row{display:flex;gap:14px;align-items:flex-start}
.info-card .row svg{width:22px;height:22px;color:var(--gold);flex:none;margin-top:2px}
.info-card .row b{display:block;color:#fff;font-family:var(--f-display)}
.info-card .row span{font-size:14.5px;color:rgba(255,255,255,.78)}
.info-card a{color:rgba(255,255,255,.78)}
.info-card a:hover{color:var(--gold)}

/* Lang visibility */
[data-lang-es]{display:none}
html[lang="es"] [data-lang-en]{display:none}
html[lang="es"] [data-lang-es]{display:revert}

/* ============ Responsive ============ */
@media (max-width:1024px){
  .nav,.header-actions .desktop-cta{display:none}
  .menu-btn{display:block}
  .footer .cols{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  body{font-size:16px}
  .grid.g3,.grid.g4,.grid.g2{grid-template-columns:1fr}
  .stats .grid{grid-template-columns:1fr 1fr}
  .stat{border-right:0;border-bottom:1px solid rgba(255,255,255,.12);padding-block:26px}
  .split{grid-template-columns:1fr}
  .split.rev{direction:ltr}
  .cta-band .wrap{flex-direction:column;align-items:flex-start}
  .footer .cols{grid-template-columns:1fr}
  .topbar .util{display:none}
  .brand .veteran{display:none}
  .hero-trust{gap:18px}
}
