/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;color:#2c2c2c;background:#fafaf8;line-height:1.7;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:#1b3a5c;text-decoration:none;transition:color .2s}
a:hover{color:#c9a84c}
ul{list-style:none}
h1,h2,h3,h4{font-weight:700;line-height:1.25;color:#1b2a3d}
h1{font-size:2.25rem}
h2{font-size:1.75rem}
h3{font-size:1.35rem}
p{margin-bottom:1rem}

/* ===== UTILITY ===== */
.container{max-width:1140px;margin:0 auto;padding:0 20px}
.section{padding:60px 0}
.section--gray{background:#f0efeb}
.section--dark{background:#1b2a3d;color:#e8e6e1}
.section--dark h2,.section--dark h3{color:#fff}
.text-center{text-align:center}
.mb-1{margin-bottom:.5rem}
.mb-2{margin-bottom:1rem}
.mb-3{margin-bottom:1.5rem}
.mb-4{margin-bottom:2rem}

/* ===== BUTTONS ===== */
.btn{display:inline-block;padding:13px 30px;border-radius:4px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .25s;border:none;text-align:center}
.btn--primary{background:#1b3a5c;color:#fff}
.btn--primary:hover{background:#14304d;color:#fff}
.btn--outline{background:transparent;color:#1b3a5c;border:2px solid #1b3a5c}
.btn--outline:hover{background:#1b3a5c;color:#fff}
.btn--gold{background:#c9a84c;color:#1b2a3d}
.btn--gold:hover{background:#b8963d;color:#fff}
.btn+.btn{margin-left:12px}

/* ===== HEADER / NAV ===== */
.site-header{background:#fff;border-bottom:1px solid #e0ddd6;position:sticky;top:0;z-index:100}
.site-header .container{display:flex;align-items:center;justify-content:space-between;padding-top:0;padding-bottom:0;min-height:68px}
.logo{font-size:1.15rem;font-weight:700;color:#1b2a3d;line-height:1.2}
.logo span{display:block;font-size:.72rem;font-weight:400;color:#6b6b6b;letter-spacing:.5px;text-transform:uppercase}
.nav-toggle{display:none;background:none;border:none;font-size:1.6rem;cursor:pointer;color:#1b2a3d;padding:6px}
.nav-menu{display:flex;gap:6px}
.nav-menu a{padding:8px 13px;font-size:.88rem;font-weight:500;border-radius:3px;color:#3a3a3a;transition:background .2s,color .2s}
.nav-menu a:hover,.nav-menu a.active{background:#f0efeb;color:#1b3a5c}
.header-cta{display:flex;align-items:center;gap:10px}
.header-cta .phone-link{font-weight:600;font-size:.92rem;color:#1b3a5c}
.header-cta .phone-link:hover{color:#c9a84c}

/* ===== HERO ===== */
.hero{position:relative;background-size:cover;background-position:center;min-height:520px;display:flex;align-items:center;color:#fff}
.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(27,42,61,.82) 0%,rgba(27,58,92,.65) 100%)}
.hero .container{position:relative;z-index:2;max-width:720px}
.hero h1{font-size:2.5rem;margin-bottom:.75rem;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.25)}
.hero p{font-size:1.15rem;margin-bottom:1.5rem;color:#ddd;max-width:560px}
.hero .btn{margin-top:4px}

/* ===== INTRO / ABOUT BLOCK ===== */
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.intro-grid img{border-radius:6px;box-shadow:0 4px 20px rgba(0,0,0,.08)}

/* ===== SERVICES OVERVIEW ===== */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.service-card{background:#fff;border-radius:6px;padding:28px 24px;box-shadow:0 2px 12px rgba(0,0,0,.06);transition:transform .2s,box-shadow .2s}
.service-card:hover{transform:translateY(-4px);box-shadow:0 6px 24px rgba(0,0,0,.1)}
.service-card h3{margin-bottom:.6rem}
.service-card p{font-size:.92rem;color:#555}
.service-card .icon{font-size:2rem;margin-bottom:.75rem;color:#1b3a5c}

/* ===== WHY CHOOSE US ===== */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.why-card{text-align:center;padding:24px 16px}
.why-card .icon{width:56px;height:56px;background:#1b3a5c;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:1.4rem}
.why-card h3{margin-bottom:.5rem;font-size:1.1rem}
.why-card p{font-size:.9rem;color:#555}

/* ===== PROJECTS / GALLERY ===== */
.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.project-card{background:#fff;border-radius:6px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.06)}
.project-card img{width:100%;height:260px;object-fit:cover}
.project-card .card-body{padding:20px 22px}
.project-card h3{margin-bottom:.4rem;font-size:1.1rem}
.project-card .tag{display:inline-block;background:#f0efeb;color:#1b3a5c;font-size:.75rem;padding:3px 10px;border-radius:3px;margin-bottom:.5rem;font-weight:600}
.project-card p{font-size:.88rem;color:#555}

/* ===== SERVICE DETAIL SECTIONS ===== */
.service-detail{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center;padding:40px 0;border-bottom:1px solid #e8e6e1}
.service-detail:last-child{border-bottom:none}
.service-detail.reverse{direction:rtl}
.service-detail.reverse>*{direction:ltr}
.service-detail img{border-radius:6px;width:100%;height:280px;object-fit:cover}
.service-detail h3{margin-bottom:.5rem}
.service-detail p{font-size:.93rem;color:#444}

/* ===== SERVICE AREA ===== */
.area-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.area-card{background:#fff;border-radius:6px;padding:22px 20px;box-shadow:0 2px 8px rgba(0,0,0,.05);text-align:center}
.area-card h3{font-size:1.05rem;margin-bottom:.3rem}
.area-card p{font-size:.85rem;color:#666}

/* ===== CONTACT ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.contact-info h3{margin-bottom:.5rem;font-size:1.1rem}
.contact-info p{font-size:.93rem;color:#444}
.contact-info .info-item{display:flex;gap:12px;margin-bottom:16px;align-items:flex-start}
.contact-info .info-item .icon{flex-shrink:0;width:40px;height:40px;background:#1b3a5c;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem}
.contact-form label{display:block;font-weight:600;font-size:.88rem;margin-bottom:4px;color:#333}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;padding:11px 14px;border:1px solid #d0cec8;border-radius:4px;font-size:.92rem;font-family:inherit;background:#fff;transition:border-color .2s}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:none;border-color:#1b3a5c}
.contact-form textarea{resize:vertical;min-height:120px}
.form-group{margin-bottom:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.map-embed{border-radius:6px;overflow:hidden;margin-top:20px}
.map-embed iframe{width:100%;height:300px;border:0}

/* ===== CTA BANNER ===== */
.cta-banner{background:#1b3a5c;color:#fff;text-align:center;padding:48px 20px}
.cta-banner h2{color:#fff;margin-bottom:.5rem}
.cta-banner p{color:#c8c5bd;margin-bottom:1.25rem;font-size:1.05rem}

/* ===== FOOTER ===== */
.site-footer{background:#141e2b;color:#a0a0a0;padding:48px 0 24px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:36px;margin-bottom:32px}
.site-footer h4{color:#fff;margin-bottom:12px;font-size:1rem}
.site-footer p,.site-footer li{font-size:.88rem;line-height:1.7}
.site-footer a{color:#a0a0a0}
.site-footer a:hover{color:#c9a84c}
.footer-bottom{border-top:1px solid #2a3545;padding-top:20px;text-align:center;font-size:.82rem;color:#6b6b6b}

/* ===== PAGE HEADER (inner pages) ===== */
.page-header{background:#1b2a3d;color:#fff;padding:48px 0 40px;text-align:center}
.page-header h1{color:#fff;margin-bottom:.4rem}
.page-header p{color:#b0b0b0;font-size:1.05rem}
.breadcrumb{font-size:.82rem;color:#8a8a8a;margin-bottom:8px}
.breadcrumb a{color:#8a8a8a}
.breadcrumb a:hover{color:#c9a84c}

/* ===== HOURS TABLE ===== */
.hours-table{width:100%;border-collapse:collapse;margin-top:8px}
.hours-table td{padding:6px 0;font-size:.88rem;border-bottom:1px solid #eee}
.hours-table td:last-child{text-align:right;color:#555}

/* ===== RESPONSIVE ===== */
@media(max-width:991px){
  .services-grid,.why-grid,.area-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .intro-grid,.service-detail,.contact-grid{grid-template-columns:1fr}
  .service-detail.reverse{direction:ltr}
  .hero h1{font-size:2rem}
}
@media(max-width:767px){
  .nav-toggle{display:block}
  .nav-menu{display:none;position:absolute;top:68px;left:0;right:0;background:#fff;flex-direction:column;padding:12px 20px;border-bottom:1px solid #e0ddd6;box-shadow:0 4px 12px rgba(0,0,0,.08)}
  .nav-menu.open{display:flex}
  .header-cta{display:none}
  .services-grid,.why-grid,.projects-grid,.area-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero{min-height:420px}
  .hero h1{font-size:1.65rem}
  .btn+.btn{margin-left:0;margin-top:10px}
  .hero .btn{display:block;width:100%}
  h1{font-size:1.75rem}
  h2{font-size:1.45rem}
  .section{padding:40px 0}
}
