
:root{
  --navy:#002040;
  --blue:#001040;
  --orange:#B00010;
  --charcoal:#001030;
  --light:#F4F6F8;
  --white:#FFFFFF;
  --max:1180px;
  --radius:10px;
  --shadow:0 8px 24px rgba(0,0,0,.07);
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,Arial,sans-serif;color:var(--charcoal);line-height:1.6;background:var(--white)}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}.narrow{max-width:900px}
.topbar{background:var(--navy);color:#fff;font-size:14px}.topbar .container{display:flex;justify-content:space-between;gap:12px;padding:10px 20px;flex-wrap:wrap}
.header{position:sticky;top:0;background:#fff;border-bottom:1px solid #e8edf2;z-index:50}.header .container{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;gap:20px}
.logo{font-size:28px;font-weight:800;color:var(--navy);letter-spacing:.2px}.logo span{color:var(--orange)}
.nav{display:flex;gap:18px;flex-wrap:wrap}.nav a{font-weight:700;color:var(--navy)}.nav a:hover{color:var(--orange)}
.btn{display:inline-block;background:var(--orange);color:#fff;padding:14px 22px;border-radius:6px;font-weight:800;transition:.2s transform,.2s opacity}.btn:hover{opacity:.92;transform:translateY(-1px)}.btn.secondary{background:var(--navy)}
.hero{background:linear-gradient(rgba(22,58,95,.8),rgba(22,58,95,.8)),linear-gradient(120deg,#2F5D7E,#163A5F);color:#fff;padding:92px 0 84px}.hero h1{font-size:54px;line-height:1.06;margin:0 0 16px;max-width:900px}.hero p{font-size:20px;max-width:760px;margin:0 0 28px}.actions{display:flex;gap:14px;flex-wrap:wrap}
.section{padding:72px 0}.section.alt{background:var(--light)}.section.compact{padding:50px 0}
.h2{font-size:38px;line-height:1.12;margin:0 0 18px;color:var(--navy)}.h3{font-size:24px;color:var(--navy);margin-top:0}.lead{font-size:18px;max-width:820px}
.grid{display:grid;gap:24px}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid #e7ebef;border-radius:var(--radius);padding:26px;box-shadow:var(--shadow)}.card h3{margin-top:0;color:var(--navy)}
.badges{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:-28px}.badge{background:#fff;padding:18px;border-radius:8px;text-align:center;box-shadow:var(--shadow);font-weight:800}
.split{display:grid;grid-template-columns:1.2fr .8fr;gap:30px;align-items:center}.split.equal{grid-template-columns:1fr 1fr}
.cta{background:var(--navy);color:#fff;border-radius:12px;padding:36px}.cta h2{color:#fff;margin-top:0}
.list{padding-left:18px}.list li{margin:8px 0}.checklist{list-style:none;padding-left:0}.checklist li{padding-left:28px;position:relative;margin:12px 0}.checklist li:before{content:'✓';position:absolute;left:0;top:0;color:var(--orange);font-weight:800}
.footer{background:var(--charcoal);color:#fff;padding:50px 0 24px}.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:30px}.footer h4{margin-top:0}.footer a{color:#fff;opacity:.92}.footer a:hover{opacity:1}
.small{font-size:14px;color:#d6dbe1}.page-hero{background:var(--navy);color:#fff;padding:58px 0}.page-hero h1{margin:0;font-size:42px}.breadcrumbs{font-size:14px;opacity:.92;margin-top:10px}
.notice{background:#fff3e8;border-left:4px solid var(--orange);padding:14px 16px;border-radius:6px}.faq .card p{margin-bottom:0}.service-links .card a{font-weight:800;color:var(--navy)}
@media (max-width: 900px){.grid-3,.grid-2,.split,.split.equal,.footer-grid,.badges{grid-template-columns:1fr 1fr}.hero h1{font-size:40px}}
@media (max-width: 640px){.grid-3,.grid-2,.split,.split.equal,.footer-grid,.badges{grid-template-columns:1fr}.hero{padding:72px 0}.hero h1{font-size:34px}.page-hero h1{font-size:32px}.header .container{flex-direction:column;align-items:flex-start}.nav{gap:12px}}

.logo-wrap{display:flex;align-items:center;gap:12px}.logo img{height:52px;width:auto;display:block}.logo-text{font-size:28px;font-weight:800;color:var(--navy);letter-spacing:.2px}.logo-text span{color:var(--orange)}


body{background:linear-gradient(to bottom,#ffffff 0%,#fbfcfd 100%)}
.header{backdrop-filter:saturate(180%) blur(6px)}
.logo img{height:64px;width:auto;display:block;filter:drop-shadow(0 2px 4px rgba(0,0,0,.12))}
.logo-text{display:none}
.hero{background:linear-gradient(rgba(0,0,0,.34),rgba(0,0,0,.34)),linear-gradient(120deg,var(--blue),var(--navy));position:relative;overflow:hidden}
.hero:before{content:'';position:absolute;inset:auto -10% -30% auto;width:420px;height:420px;background:radial-gradient(circle,var(--orange),transparent 62%);opacity:.18}
.badge,.card,.cta{border-radius:14px}
.card{transition:transform .18s ease, box-shadow .18s ease}.card:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(0,0,0,.10)}
.btn{box-shadow:0 10px 22px rgba(0,0,0,.12)}
.btn.secondary{background:transparent;border:2px solid rgba(255,255,255,.7)}
.topbar{background:linear-gradient(90deg,var(--navy),var(--blue))}
.page-hero{background:linear-gradient(135deg,var(--navy),var(--blue))}
.h2{letter-spacing:-.02em}.hero h1,.page-hero h1{letter-spacing:-.03em}
.footer{background:linear-gradient(180deg,#1d232b 0%, #11161c 100%)}
.hero-mark{height:74px;width:auto;filter:drop-shadow(0 6px 16px rgba(0,0,0,.22));margin-bottom:18px}


.hero{background:linear-gradient(rgba(0,0,0,.48),rgba(0,0,0,.48)), url('../img/hero-bg.png') center/cover no-repeat, linear-gradient(120deg,var(--blue),var(--navy));}
.premium-band{background:linear-gradient(90deg,var(--navy),var(--blue));color:#fff}
.showcase{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:stretch}.showcase-image{min-height:360px;border-radius:16px;box-shadow:var(--shadow);background-size:cover;background-position:center}.showcase-stack{display:grid;gap:24px}.showcase-card{min-height:168px;border-radius:16px;box-shadow:var(--shadow);background-size:cover;background-position:center}
.form-card{background:#fff;border:1px solid #e7ebef;border-radius:16px;box-shadow:var(--shadow);padding:28px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-grid .full{grid-column:1/-1}.field label{display:block;font-weight:700;margin-bottom:6px;color:var(--navy)}.field input,.field select,.field textarea{width:100%;padding:14px 14px;border:1px solid #cfd8e3;border-radius:10px;font:inherit;background:#fff}.field textarea{min-height:140px;resize:vertical}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,32,64,.12)}
.note{font-size:14px;color:#5a6470}
.logo img{height:70px}
@media (max-width:900px){.showcase,.form-grid{grid-template-columns:1fr}}


.hero{background:linear-gradient(rgba(0,0,0,.50),rgba(0,0,0,.44)), url('../img/hero-roof-repair.jpg') center/cover no-repeat, linear-gradient(120deg,var(--blue),var(--navy));}
.media-card{overflow:hidden;padding:0}.media-card img{width:100%;height:100%;object-fit:cover;min-height:280px}.service-media{min-height:340px;border-radius:16px;overflow:hidden;box-shadow:var(--shadow)}
.overlay-card{position:relative;color:#fff;min-height:240px;overflow:hidden}.overlay-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.overlay-card .shade{position:absolute;inset:0;background:linear-gradient(rgba(0,0,0,.22),rgba(0,0,0,.55))}.overlay-card .content{position:relative;padding:22px;z-index:2;display:flex;flex-direction:column;justify-content:end;min-height:240px}


.hero .actions{margin-top:10px}
.hero .btn{min-width:220px;text-align:center}
.hero .btn.secondary{background:#fff;border:2px solid #fff;color:var(--navy)}
.hero .btn.secondary:hover{background:rgba(255,255,255,.92)}
.hero-copy{max-width:760px}
.hero-mark{height:88px;width:auto;filter:drop-shadow(0 8px 20px rgba(0,0,0,.28));margin-bottom:22px}


body{font-family:Inter,system-ui,Arial,sans-serif;color:#1b2430}
.hero{padding:118px 0 96px}
.hero-copy{max-width:820px}
.eyebrow{display:inline-block;margin:0 0 18px;padding:8px 12px;border:1px solid rgba(255,255,255,.28);border-radius:999px;color:rgba(255,255,255,.92);font-size:12px;font-weight:800;letter-spacing:.14em}
.hero-mark{height:96px;width:auto;filter:drop-shadow(0 10px 24px rgba(0,0,0,.24));margin:0 0 26px}
.hero h1{font-size:60px;max-width:980px;margin-bottom:18px}
.hero p{font-size:21px;max-width:720px;color:rgba(255,255,255,.92);margin-bottom:34px}
.hero .actions{gap:16px}
.hero .btn{min-width:220px;text-align:center;border-radius:8px;padding:16px 24px;font-size:15px;letter-spacing:.02em}
.hero .btn.secondary{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.36);color:#fff;backdrop-filter:blur(6px)}
.hero .btn.secondary:hover{background:rgba(255,255,255,.14)}
.badges{margin-top:-34px}
.badge{padding:20px 18px;font-size:14px;letter-spacing:.02em}
.h2{font-size:42px}
.card h3{font-size:24px;letter-spacing:-.02em}
.section{padding:84px 0}
.section.compact{padding:58px 0}
.lead{font-size:19px;color:#3b4754}
.premium-band{box-shadow:inset 0 1px 0 rgba(255,255,255,.08)}
.cta{padding:42px;border:1px solid rgba(255,255,255,.08)}
.cta p{color:rgba(255,255,255,.9)}
.notice{background:#fff8f1;border-left-color:var(--accent)}
.footer{padding-top:60px}
@media (max-width:900px){.hero{padding:92px 0 78px}.hero h1{font-size:46px}.hero-mark{height:82px}.h2{font-size:36px}}
@media (max-width:640px){.hero h1{font-size:36px}.hero p{font-size:18px}.hero .btn{min-width:unset;width:100%}.hero-mark{height:68px}.eyebrow{font-size:11px}}


.badges{margin-top:-36px;position:relative;z-index:5}
.badge{background:linear-gradient(135deg,rgba(0,32,64,.96),rgba(0,16,64,.92));color:#fff;border:1px solid rgba(255,255,255,.12);box-shadow:0 12px 30px rgba(0,0,0,.16)}
.service-links .card{background:linear-gradient(135deg,rgba(0,32,64,.96),rgba(0,16,64,.9));color:#fff;border:1px solid rgba(255,255,255,.08);position:relative;overflow:hidden}
.service-links .card:before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,0));pointer-events:none}
.service-links .card h3,.service-links .card a,.service-links .card p{color:#fff}
.service-links .card:hover{box-shadow:0 18px 36px rgba(0,0,0,.18)}


.badges{margin-bottom:18px}
.badge{display:block;text-decoration:none;transition:transform .18s ease, box-shadow .18s ease, opacity .18s ease}
.badge:hover{transform:translateY(-3px);box-shadow:0 16px 34px rgba(0,0,0,.18);opacity:.98}
.premium-band{margin-top:12px}
