/* === RESET === */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{display:block;max-width:100%;height:auto}
button{border:none;background:none;cursor:pointer;font:inherit}
address{font-style:normal}

/* === VARIABLES === */
:root{
  --navy-darkest:#0D1B2A;
  --navy-dark:#1B2A4A;
  --navy-mid:#243B6A;
  --blue-accent:#4A90D9;
  --cream-light:#FAF8F4;
  --gold:#D4A843;
  --gold-light:#E8C97A;
  --green:#22C55E;
  --green-glow:#4ADE80;
  --text-light:#C8D4E6;
  --text-muted:#8899B0;
  --header-bg:#F5F5F5;
  --header-text:#1B2A4A;
  --header-text-muted:#4A5568;
  --border-dark:rgba(255,255,255,0.08);
  --border-light:rgba(255,255,255,0.12);
  --header-border:rgba(0,0,0,0.08);
}

body{
  font-family:'DM Sans',sans-serif;
  background:var(--cream-light);
  color:#333;
  min-height:100vh;
  display:flex;
  flex-direction:column;
}

/* === TOP BAR (dark navy, no address) === */
.top-bar{background:var(--navy-darkest);border-bottom:1px solid var(--border-dark)}
.top-bar-inner{max-width:1280px;margin:0 auto;padding:8px 24px;display:flex;justify-content:space-between;align-items:center}
.top-bar-left{display:flex;align-items:center;gap:24px}
.top-bar-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted)}
.top-bar-item svg{width:14px;height:14px;fill:var(--blue-accent);flex-shrink:0}
.top-bar-right{display:flex;align-items:center;gap:16px}
.top-bar-right a{color:var(--text-muted);font-size:13px;transition:color .2s}
.top-bar-right a:hover{color:#fff}
.top-bar-divider{width:1px;height:14px;background:var(--border-light)}

/* === HEADER (light grey) === */
.main-header{
  background:var(--header-bg);
  position:sticky;
  top:0;
  z-index:1000;
  box-shadow:0 2px 12px rgba(0,0,0,.08);
  border-bottom:1px solid var(--header-border);
}
.header-inner{
  max-width:1280px;
  margin:0 auto;
  padding:12px 32px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  min-height:80px;
}
.logo-link{display:flex;align-items:center;flex-shrink:0}
.logo-link img{width:200px;height:auto;object-fit:contain}

/* === NAV (dark text on light bg) === */
.main-nav{display:flex;align-items:center;gap:4px}
.nav-item{position:relative}
.nav-link{
  display:inline-flex;align-items:center;gap:4px;padding:8px 14px;
  color:var(--header-text);font-family:'Outfit',sans-serif;
  font-size:14.5px;font-weight:500;letter-spacing:.02em;
  border-radius:6px;transition:all .2s;white-space:nowrap;
}
.nav-link:hover{color:var(--navy-darkest);background:rgba(0,0,0,.06)}
.nav-link svg{width:12px;height:12px;fill:currentColor;transition:transform .2s}
.nav-item:hover .nav-link svg{transform:rotate(180deg)}

/* === DROPDOWN (stays dark) === */
.dropdown{
  position:absolute;top:calc(100% + 8px);left:0;min-width:270px;
  background:var(--navy-darkest);border:1px solid var(--border-light);
  border-radius:10px;padding:8px;opacity:0;visibility:hidden;
  transform:translateY(-8px);transition:all .25s ease;
  box-shadow:0 16px 48px rgba(0,0,0,.4);z-index:100;
}
.nav-item:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown a{display:block;padding:10px 14px;color:var(--text-light);font-size:14px;border-radius:6px;transition:all .15s}
.dropdown a:hover{background:rgba(74,144,217,.12);color:#fff;padding-left:18px}
.dropdown-divider{height:1px;background:var(--border-dark);margin:6px 8px}

/* === PHONE CTA (dark text) === */
.header-cta{display:flex;align-items:center;gap:16px}
.header-phone{display:flex;align-items:center;gap:12px;margin-left:16px;flex-shrink:0}
.phone-indicator{
  position:relative;display:flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:50%;
  background:rgba(34,197,94,.1);border:1.5px solid rgba(34,197,94,.25);
}
.phone-indicator svg{width:18px;height:18px;fill:var(--green)}
.pulse-dot{position:absolute;top:2px;right:2px;width:10px;height:10px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green)}
.pulse-dot::before{content:'';position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--green-glow);animation:pulse-ring 2s ease-out infinite}
.pulse-dot::after{content:'';position:absolute;inset:0;border-radius:50%;background:var(--green);animation:pulse-glow 2s ease-out infinite}
@keyframes pulse-ring{0%{transform:scale(1);opacity:.8}70%{transform:scale(2.2);opacity:0}100%{transform:scale(2.2);opacity:0}}
@keyframes pulse-glow{0%{box-shadow:0 0 4px var(--green),0 0 8px var(--green)}50%{box-shadow:0 0 8px var(--green),0 0 20px rgba(34,197,94,.4)}100%{box-shadow:0 0 4px var(--green),0 0 8px var(--green)}}
.phone-text{display:flex;flex-direction:column}
.phone-label{font-family:'Outfit',sans-serif;font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:#16a34a;font-weight:600;line-height:1}
.phone-number{font-family:'Outfit',sans-serif;font-size:18px;font-weight:700;color:var(--navy-dark);letter-spacing:.03em;line-height:1.3;transition:color .2s}
.phone-number:hover{color:var(--green)}

/* === FREE ESTIMATE BTN === */
.btn-estimate{
  display:inline-flex;align-items:center;gap:8px;padding:10px 20px;
  background:linear-gradient(135deg,var(--gold),var(--gold-light));
  color:var(--navy-darkest);font-family:'Outfit',sans-serif;font-size:13.5px;
  font-weight:700;text-transform:uppercase;letter-spacing:.08em;border-radius:6px;
  transition:all .25s;box-shadow:0 2px 8px rgba(212,168,67,.3);
}
.btn-estimate:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(212,168,67,.4);background:linear-gradient(135deg,var(--gold-light),var(--gold))}
.btn-estimate svg{width:14px;height:14px;fill:var(--navy-darkest)}

/* === MOBILE TOGGLE (dark bars on light bg) === */
.mobile-toggle{display:none;flex-direction:column;gap:5px;padding:8px}
.mobile-toggle span{display:block;width:24px;height:2.5px;background:var(--navy-dark);border-radius:2px;transition:all .3s}

/* === DEMO CONTENT === */
.demo-content{flex:1;display:flex;align-items:center;justify-content:center;padding:80px 24px;text-align:center}
.demo-content p{font-size:16px;color:#999;font-style:italic}

/* === FOOTER === */
.site-footer{background:var(--navy-dark);color:var(--text-light);position:relative;overflow:hidden}
.site-footer::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue-accent),var(--gold),var(--blue-accent))}
.footer-main{max-width:1280px;margin:0 auto;padding:56px 24px 40px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px}
.footer-brand{display:flex;flex-direction:column;gap:20px}
.footer-logo img{width:220px;height:auto;opacity:.95}
.footer-tagline{font-size:14.5px;color:var(--text-muted);line-height:1.7;max-width:300px}
.footer-phone-cta{display:flex;align-items:center;gap:12px;margin-top:4px;padding:14px 18px;background:rgba(255,255,255,.04);border:1px solid var(--border-light);border-radius:12px;transition:background .2s}
.footer-phone-cta:hover{background:rgba(255,255,255,.07)}
.footer-phone-icon{width:36px;height:36px;border-radius:50%;background:rgba(34,197,94,.12);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.footer-phone-icon svg{width:16px;height:16px;fill:var(--green)}
.footer-phone-text span{font-size:12px;color:var(--text-muted);letter-spacing:.04em}
.footer-phone-text a{display:block;font-family:'Outfit',sans-serif;font-size:18px;font-weight:700;color:#fff;letter-spacing:.02em;transition:color .2s}
.footer-phone-text a:hover{color:var(--green-glow)}
.footer-section h4{font-family:'Outfit',sans-serif;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--gold);margin-bottom:20px;position:relative;padding-bottom:12px}
.footer-section h4::after{content:'';position:absolute;bottom:0;left:0;width:28px;height:2px;background:var(--gold);border-radius:1px}
.footer-links{display:flex;flex-direction:column;gap:10px}
.footer-links a{color:var(--text-muted);font-size:14px;transition:all .2s;display:inline-block}
.footer-links a:hover{color:#fff;transform:translateX(4px)}
.footer-address{color:var(--text-muted);font-size:14px;line-height:1.8}
.footer-address strong{color:var(--text-light)}
.footer-address a{color:var(--text-light);transition:color .2s}
.footer-address a:hover{color:#fff}
.footer-hours{margin-top:16px;padding:12px 16px;background:rgba(255,255,255,.03);border-radius:8px;border:1px solid var(--border-dark)}
.footer-hours-row{display:flex;justify-content:space-between;font-size:13px;color:var(--text-muted);padding:3px 0}
.footer-hours-row.active{color:var(--green-glow);font-weight:600}
.footer-bottom{border-top:1px solid var(--border-dark);max-width:1280px;margin:0 auto;padding:20px 24px;display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--text-muted)}
.footer-bottom-links{display:flex;gap:24px}
.footer-bottom-links a{color:var(--text-muted);transition:color .2s}
.footer-bottom-links a:hover{color:#fff}

/* === MOBILE MENU === */
.mobile-menu{display:none;position:fixed;inset:0;z-index:9999;background:var(--navy-darkest);overflow-y:auto}
.mobile-menu.active{display:block;animation:slideIn .3s ease}
@keyframes slideIn{from{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}
.mobile-menu-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border-dark)}
.mobile-menu-header img{width:180px;height:auto}
.mobile-close{padding:8px}
.mobile-close svg{width:24px;height:24px;fill:#fff}
.mobile-phone-bar{display:flex;align-items:center;gap:12px;padding:16px 24px;background:rgba(34,197,94,.06);border-bottom:1px solid var(--border-dark)}
.mobile-phone-icon{width:40px;height:40px;border-radius:50%;background:rgba(34,197,94,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mobile-phone-icon svg{width:16px;height:16px;fill:var(--green)}
.mobile-phone-label{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--green-glow);font-weight:600;font-family:'Outfit',sans-serif}
.mobile-phone-number{font-family:'Outfit',sans-serif;font-size:20px;font-weight:700;color:#fff}
.mobile-menu a{display:block;padding:14px 24px;color:var(--text-light);font-size:16px;border-bottom:1px solid var(--border-dark);transition:all .15s}
.mobile-menu a:hover{background:rgba(74,144,217,.1);color:#fff}
.mobile-section-title{padding:14px 24px 8px;font-family:'Outfit',sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--gold);border-bottom:none}
.mobile-section-title:hover{background:transparent}

/* === RESPONSIVE === */
/* === STICKY MOBILE CALL BAR === */
.mobile-call-bar{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:998;
  background:#2563EB;padding:12px 20px;
  box-shadow:0 -4px 16px rgba(0,0,0,.2);
  transform:translateY(100%);transition:transform .3s ease;
}
.mobile-call-bar.visible{transform:translateY(0)}
.mobile-call-bar a{
  display:flex;align-items:center;justify-content:center;gap:10px;
  color:#fff;font-family:'Outfit',sans-serif;font-size:16px;font-weight:700;
  letter-spacing:.04em;text-transform:uppercase;
}
.mobile-call-bar a svg{width:20px;height:20px;fill:#fff}

@media(max-width:1024px){
  .main-nav,.btn-estimate{display:none}
  .mobile-toggle{display:flex}
  .header-inner{min-height:70px;padding:10px 24px}
  .logo-link img{width:225px}
  .footer-main{grid-template-columns:1fr 1fr;gap:36px}
  .mobile-call-bar{display:block}
}
@media(max-width:768px){
  .top-bar-left{display:none}
  .top-bar-inner{justify-content:center}
  .phone-text{display:none}
  .header-phone{margin-left:8px}
  .logo-link img{width:200px}
  .footer-main{grid-template-columns:1fr;gap:32px;padding:40px 24px 32px}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center;padding-bottom:72px}
}
@media(max-width:480px){
  .logo-link img{width:175px}
}

/* HERO COLORS - Change these to update all page heroes at once */
/*:root {
  --hero-start: #13171A;
  --hero-mid: #13171A;
  --hero-end: #13171A;
}
.hp-hero, .page-hero, .br-hero {
  background: linear-gradient(135deg, var(--hero-start) 0%, var(--hero-mid) 50%, var(--hero-end) 100%) !important;
}
