/* Triple A Contracting & Restoration - Stylesheet */
:root{
  --navy:#0f2a47;
  --navy-dark:#0a1f36;
  --blue:#2f6db0;
  --muted-blue:#5a89b8;
  --gray-50:#f6f8fb;
  --gray-100:#eef2f7;
  --gray-200:#dde4ee;
  --gray-500:#6b7785;
  --gray-700:#3a4452;
  --text:#1c2533;
  --white:#ffffff;
  --shadow:0 4px 18px rgba(15,42,71,.08);
  --radius:8px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  font-size:16px;
  line-height:1.6;
  color:var(--text);
  background:var(--white);
}

img{max-width:100%;height:auto;display:block}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}

.container{max-width:1140px;margin:0 auto;padding:0 20px}

h1,h2,h3,h4{color:var(--navy);font-weight:700;line-height:1.25;margin:0 0 .6em}
h1{font-size:2.1rem}
h2{font-size:1.6rem}
h3{font-size:1.2rem}
p{margin:0 0 1em}

/* Top bar */
.topbar{
  background:var(--navy-dark);
  color:#cfd8e3;
  font-size:.86rem;
  padding:8px 0;
}
.topbar .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}
.topbar a{color:#fff}

/* Header / Nav */
.site-header{
  background:#fff;
  border-bottom:1px solid var(--gray-200);
  position:sticky;top:0;z-index:50;
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 0;
}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--navy);font-size:1.05rem}
.brand img{width:34px;height:34px}
.brand span small{display:block;font-weight:500;color:var(--gray-500);font-size:.7rem;letter-spacing:.5px;text-transform:uppercase}
.nav-links{display:flex;gap:6px;align-items:center;list-style:none;margin:0;padding:0}
.nav-links a{
  color:var(--gray-700);
  font-weight:500;
  padding:8px 12px;
  border-radius:6px;
}
.nav-links a:hover{background:var(--gray-100);text-decoration:none;color:var(--navy)}
.nav-links a.active{color:var(--navy)}
.nav-cta{
  background:var(--navy);color:#fff !important;
  padding:9px 16px !important;border-radius:6px;
}
.nav-cta:hover{background:var(--blue) !important}
.menu-toggle{display:none;background:none;border:0;cursor:pointer;padding:6px}
.menu-toggle span{display:block;width:24px;height:2px;background:var(--navy);margin:5px 0;transition:.2s}

/* Buttons */
.btn{
  display:inline-block;
  padding:12px 22px;
  border-radius:6px;
  font-weight:600;
  border:0;
  cursor:pointer;
  transition:.2s;
  font-size:1rem;
}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover{background:var(--blue);text-decoration:none;color:#fff}
.btn-outline{background:transparent;color:#fff;border:2px solid #fff}
.btn-outline:hover{background:#fff;color:var(--navy);text-decoration:none}
.btn-secondary{background:var(--blue);color:#fff}
.btn-secondary:hover{background:var(--navy);color:#fff;text-decoration:none}

/* Hero */
.hero{
  position:relative;
  background:linear-gradient(135deg,rgba(10,31,54,.85),rgba(15,42,71,.7)),url('../images/hero-restoration.jpg') center/cover no-repeat;
  color:#fff;
  padding:80px 0 90px;
}
.hero h1{color:#fff;font-size:2.6rem;max-width:780px}
.hero p.lead{font-size:1.15rem;max-width:680px;color:#e5edf6;margin-bottom:28px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}

/* Page header (inner pages) */
.page-header{
  background:linear-gradient(135deg,var(--navy),var(--navy-dark));
  color:#fff;padding:60px 0 50px;text-align:center;
}
.page-header h1{color:#fff}
.page-header p{color:#cfd8e3;max-width:700px;margin:0 auto}

/* Sections */
section{padding:64px 0}
section.alt{background:var(--gray-50)}
.section-head{text-align:center;max-width:720px;margin:0 auto 40px}
.section-head p{color:var(--gray-500)}

/* Grids */
.grid{display:grid;gap:24px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}

/* Cards */
.card{
  background:#fff;
  border:1px solid var(--gray-200);
  border-radius:var(--radius);
  padding:26px;
  transition:.2s;
}
.card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.card .icon{
  width:48px;height:48px;border-radius:8px;
  background:var(--gray-100);color:var(--navy);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;margin-bottom:14px;
}
.card h3{margin-bottom:8px}
.card p{color:var(--gray-700);margin:0}

/* Service detail blocks */
.service-block{
  display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center;
  padding:30px 0;border-bottom:1px solid var(--gray-200);
}
.service-block:last-child{border-bottom:0}
.service-block.reverse{direction:rtl}
.service-block.reverse > *{direction:ltr}
.service-block img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;height:280px;object-fit:cover}

/* Why us list */
.why-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.why-list li{
  background:#fff;padding:18px 20px;border-left:3px solid var(--blue);
  border-radius:6px;box-shadow:var(--shadow);
}
.why-list strong{display:block;color:var(--navy);margin-bottom:4px}
.why-list span{color:var(--gray-700);font-size:.95rem}

/* Service area */
.area-tags{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:18px}
.area-tags span{
  background:#fff;border:1px solid var(--gray-200);
  padding:8px 16px;border-radius:30px;color:var(--navy);font-weight:500;
}

/* Contact block */
.contact-block{
  background:var(--navy);color:#fff;
  border-radius:var(--radius);padding:40px;text-align:center;
}
.contact-block h2{color:#fff}
.contact-block p{color:#cfd8e3}
.contact-block .ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:18px}

/* Contact page layout */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:40px}
.info-card{
  background:#fff;border:1px solid var(--gray-200);
  border-radius:var(--radius);padding:28px;
}
.info-card h3{margin-bottom:14px}
.info-list{list-style:none;padding:0;margin:0}
.info-list li{padding:10px 0;border-bottom:1px solid var(--gray-100);display:flex;gap:12px}
.info-list li:last-child{border-bottom:0}
.info-list strong{color:var(--navy);min-width:90px;display:inline-block}

/* Form */
.form-group{margin-bottom:16px}
label{display:block;font-weight:500;color:var(--navy);margin-bottom:6px;font-size:.92rem}
input,select,textarea{
  width:100%;padding:11px 13px;border:1px solid var(--gray-200);
  border-radius:6px;font-size:1rem;font-family:inherit;
  transition:.2s;background:#fff;
}
input:focus,select:focus,textarea:focus{
  outline:0;border-color:var(--blue);box-shadow:0 0 0 3px rgba(47,109,176,.15);
}
textarea{min-height:130px;resize:vertical}
.form-msg{padding:12px;border-radius:6px;margin-top:14px;display:none}
.form-msg.success{display:block;background:#e7f5ec;color:#1d6f3f;border:1px solid #b8e0c4}

/* Map */
.map-wrap{
  border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--gray-200);height:380px;
}
.map-wrap iframe{width:100%;height:100%;border:0;display:block}

/* About */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.about-grid img{border-radius:var(--radius);box-shadow:var(--shadow);height:420px;object-fit:cover;width:100%}

/* Footer */
.footer{
  background:var(--navy-dark);color:#cfd8e3;padding:50px 0 20px;font-size:.95rem;
}
.footer h4{color:#fff;font-size:1rem;margin-bottom:14px}
.footer a{color:#cfd8e3}
.footer a:hover{color:#fff}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:30px;padding-bottom:30px;border-bottom:1px solid #1d3554}
.footer-grid ul{list-style:none;padding:0;margin:0}
.footer-grid ul li{padding:4px 0}
.footer-bottom{padding-top:18px;text-align:center;color:#8aa0b8;font-size:.85rem}

/* Responsive */
@media (max-width: 880px){
  h1{font-size:1.7rem}
  .hero{padding:60px 0}
  .hero h1{font-size:2rem}
  .grid-3,.grid-2{grid-template-columns:1fr}
  .service-block{grid-template-columns:1fr}
  .service-block.reverse{direction:ltr}
  .service-block img{height:220px}
  .contact-grid{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr}
  .about-grid img{height:280px}
  .why-list{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .menu-toggle{display:block}
  .nav-links{
    display:none;
    position:absolute;top:100%;left:0;right:0;
    background:#fff;flex-direction:column;align-items:stretch;
    padding:10px 20px 16px;border-bottom:1px solid var(--gray-200);
    box-shadow:var(--shadow);
  }
  .nav-links.open{display:flex}
  .nav-links li{width:100%}
  .nav-links a{display:block;padding:10px 12px}
  .site-header{position:relative}
}
@media (max-width:520px){
  .footer-grid{grid-template-columns:1fr}
  .contact-block{padding:28px 20px}
}
