*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
:root{
  --gold:#D4A017;
  --gold2:#F0C040;
  --gold-dark:#A07800;
  --black:#0A0A0A;
  --dark:#111111;
  --dark2:#1A1A1A;
  --dark3:#222222;
  --dark4:#2A2A2A;
  --mid:#3A3A3A;
  --steel:#4A4A4A;
  --muted:#888888;
  --light:#CCCCCC;
  --white:#FFFFFF;
  --red:#CC2200;
  --red2:#E03318;
  --green:#2A7A3A;
  --r:4px;
  --rl:8px;
}
body{font-family:'Roboto',sans-serif;background:var(--dark);color:var(--light);overflow-x:hidden;line-height:1.6}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.container--wide{max-width:1400px;margin:0 auto;padding:0 20px}

/* ---- BUTTONS ---- */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:'Oswald',sans-serif;font-weight:600;font-size:0.95rem;letter-spacing:0.08em;text-transform:uppercase;border:none;border-radius:var(--r);cursor:pointer;transition:all .2s ease;text-decoration:none;white-space:nowrap;line-height:1}
.btn-gold{background:linear-gradient(135deg,var(--gold2),var(--gold));color:var(--black);padding:15px 28px}
.btn-gold:hover{background:linear-gradient(135deg,#FFD060,var(--gold2));transform:translateY(-2px);box-shadow:0 6px 20px rgba(212,160,23,0.5)}
.btn-outline{background:transparent;color:var(--white);padding:14px 26px;border:2px solid rgba(255,255,255,0.3)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold)}
.btn-dark{background:var(--dark2);color:var(--white);padding:14px 26px;border:1px solid var(--mid)}
.btn-dark:hover{border-color:var(--gold);color:var(--gold)}
.btn-red{background:var(--red2);color:var(--white);padding:15px 28px}
.btn-red:hover{background:#FF4422;transform:translateY(-2px);box-shadow:0 6px 20px rgba(200,50,20,0.4)}
.btn--lg{font-size:1.05rem;padding:18px 36px}
.btn--sm{font-size:0.8rem;padding:10px 18px}
.btn svg{width:18px;height:18px;flex-shrink:0}

/* ---- TOPBAR ---- */
.topbar{background:var(--gold);padding:9px 0}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:6px}
.topbar-msg{font-family:'Oswald',sans-serif;font-size:0.78rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--black)}
.topbar-contact{display:flex;align-items:center;gap:20px}
.topbar-contact a{font-family:'Oswald',sans-serif;font-size:0.78rem;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--black);display:flex;align-items:center;gap:6px}
.topbar-contact a:hover{text-decoration:underline}

/* ---- NAVBAR ---- */
.navbar{position:sticky;top:0;z-index:1000;background:rgba(10,10,10,0.97);backdrop-filter:blur(14px);border-bottom:2px solid var(--gold)}
.nav-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:78px;padding:0 20px}
.nav-logo img{height:58px;width:auto}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-links a{font-family:'Oswald',sans-serif;font-weight:500;font-size:0.85rem;letter-spacing:0.07em;text-transform:uppercase;color:var(--light);padding:8px 13px;border-radius:var(--r);transition:color .2s,background .2s}
.nav-links a:hover{color:var(--gold);background:rgba(212,160,23,0.08)}
.nav-cta{display:flex;align-items:center;gap:10px}
.nav-phone{font-family:'Oswald',sans-serif;font-weight:700;font-size:1.05rem;color:var(--white);letter-spacing:0.04em}
.nav-phone-label{font-size:0.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.1em;font-family:'Oswald',sans-serif;display:block;line-height:1}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.hamburger span{display:block;width:24px;height:2px;background:var(--white);border-radius:2px;transition:all .3s}
.mobile-menu{display:none;flex-direction:column;background:var(--dark2);border-top:2px solid var(--gold);padding:16px 20px 20px;gap:2px}
.mobile-menu a{font-family:'Oswald',sans-serif;font-weight:500;font-size:1rem;letter-spacing:0.07em;text-transform:uppercase;color:var(--light);padding:10px 14px;border-radius:var(--r);display:block}
.mobile-menu a:hover{background:rgba(212,160,23,0.1);color:var(--gold)}
.mobile-menu.open{display:flex}
@media(max-width:960px){.nav-links{display:none}.hamburger{display:flex}}
@media(max-width:620px){.nav-phone{display:none}.nav-cta .btn{display:none}}

/* ---- STICKY MOBILE BAR ---- */
.sticky-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:9999;background:var(--black);border-top:2px solid var(--gold);padding:10px 14px;gap:10px}
.sticky-bar a{flex:1;text-align:center;font-family:'Oswald',sans-serif;font-weight:600;font-size:0.88rem;letter-spacing:0.07em;text-transform:uppercase;padding:12px 8px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;gap:6px}
.sb-call{background:var(--red2);color:var(--white)}
.sb-estimate{background:linear-gradient(135deg,var(--gold2),var(--gold));color:var(--black)}
@media(max-width:768px){.sticky-bar{display:flex};body{padding-bottom:70px}}
@media(max-width:760px){.roofing-split-grid{grid-template-columns:1fr!important}}

/* ---- HERO ---- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:var(--black)}
.hero-bg{position:absolute;inset:0;background:
  linear-gradient(160deg,rgba(10,10,10,0.97) 0%,rgba(10,10,10,0.82) 45%,rgba(10,10,10,0.55) 100%);
  z-index:1}
.hero-img{position:absolute;inset:0;background:url('https://images.leadconnectorhq.com/image/f_webp/q_80/r_1200/u_https://assets.cdn.filesafe.space/lqiVDebNkepppMgzu9ub/media/69d9547801157e64b3d1d5a3.png') center/cover no-repeat;z-index:0}
.hero-pattern{position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 40px,rgba(212,160,23,0.015) 40px,rgba(212,160,23,0.015) 41px);z-index:1;pointer-events:none}
.hero-content{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:0 20px;width:100%}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(212,160,23,0.12);border:1px solid rgba(212,160,23,0.4);border-radius:20px;padding:6px 16px;margin-bottom:22px}
.hero-eyebrow span{font-family:'Oswald',sans-serif;font-size:0.72rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold)}
.hero-eyebrow-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);flex-shrink:0;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}
.hero-h1{font-family:'Bebas Neue',sans-serif;font-size:clamp(3.2rem,8.5vw,7.2rem);line-height:0.92;color:var(--white);letter-spacing:0.01em;margin-bottom:10px}
.hero-h1 em{color:var(--gold);font-style:normal;display:block}
.hero-tagline{font-family:'Oswald',sans-serif;font-size:clamp(1rem,2.2vw,1.35rem);font-weight:400;letter-spacing:0.08em;text-transform:uppercase;color:var(--muted);margin-bottom:28px}
.hero-tagline strong{color:var(--gold2);font-weight:600}
.hero-desc{font-size:1.05rem;color:rgba(204,204,204,0.8);max-width:560px;margin-bottom:36px;line-height:1.7}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:48px}
.hero-trust-strip{display:flex;flex-wrap:wrap;align-items:center;gap:24px}
.trust-item{display:flex;align-items:center;gap:10px}
.trust-icon{width:38px;height:38px;border-radius:50%;background:rgba(212,160,23,0.15);border:1px solid rgba(212,160,23,0.3);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.trust-icon svg{width:18px;height:18px;fill:var(--gold)}
.trust-text{font-family:'Oswald',sans-serif;font-size:0.82rem;font-weight:500;letter-spacing:0.06em;text-transform:uppercase;color:var(--light);line-height:1.2}
.trust-text span{display:block;font-size:0.68rem;color:var(--muted);font-weight:400}
.hero-scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:6px;opacity:.5}
.hero-scroll span{font-family:'Oswald',sans-serif;font-size:0.65rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--light)}
.scroll-arrow{width:20px;height:20px;border-right:2px solid var(--gold);border-bottom:2px solid var(--gold);transform:rotate(45deg);animation:scrolldown 1.6s infinite}
@keyframes scrolldown{0%,100%{transform:rotate(45deg) translateY(0)}50%{transform:rotate(45deg) translateY(5px)}}
@media(max-width:640px){.hero-h1{font-size:3.4rem}.hero-actions{flex-direction:column}.hero-actions .btn{justify-content:center}.hero-desc{font-size:0.95rem}}

/* ---- STATS BAR ---- */
.stats-bar{background:linear-gradient(90deg,var(--gold-dark),var(--gold),var(--gold2),var(--gold),var(--gold-dark));padding:2px 0}
.stats-bar-inner{background:var(--dark2);margin:2px 0}
.stats-inner{display:grid;grid-template-columns:repeat(4,1fr);max-width:1200px;margin:0 auto}
.stat-item{padding:22px 20px;text-align:center;border-right:1px solid var(--dark4)}
.stat-item:last-child{border-right:none}
.stat-num{font-family:'Bebas Neue',sans-serif;font-size:2.6rem;color:var(--gold);line-height:1}
.stat-label{font-family:'Oswald',sans-serif;font-size:0.72rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);margin-top:4px}
@media(max-width:640px){.stats-inner{grid-template-columns:repeat(2,1fr)}.stat-item:nth-child(2){border-right:none}.stat-item:nth-child(3){border-right:1px solid var(--dark4)}}

/* ---- SECTION BASICS ---- */
section{padding:90px 0}
.section-tag{display:inline-flex;align-items:center;gap:8px;font-family:'Oswald',sans-serif;font-size:0.72rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.section-tag::before{content:'';width:28px;height:2px;background:var(--gold)}
.section-h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.4rem,5vw,4rem);line-height:0.95;color:var(--white);letter-spacing:0.02em;margin-bottom:14px}
.section-h2 em{color:var(--gold);font-style:normal}
.section-sub{font-size:1rem;color:var(--muted);max-width:560px;line-height:1.7}
.section-head-center{text-align:center}
.section-head-center .section-tag{justify-content:center}
.section-head-center .section-sub{margin:0 auto}

/* ---- TRUST PILLARS ---- */
.trust-section{background:var(--dark2)}
.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:52px}
.pillar{background:var(--dark3);padding:40px 32px;position:relative;overflow:hidden;transition:background .25s}
.pillar::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold2))}
.pillar:hover{background:var(--dark4)}
.pillar-num{font-family:'Bebas Neue',sans-serif;font-size:4rem;color:rgba(212,160,23,0.08);position:absolute;top:16px;right:24px;line-height:1}
.pillar-icon{width:50px;height:50px;background:rgba(212,160,23,0.12);border-radius:var(--r);display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.pillar-icon svg{width:24px;height:24px;fill:var(--gold)}
.pillar-title{font-family:'Oswald',sans-serif;font-size:1.2rem;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--white);margin-bottom:10px}
.pillar-text{font-size:0.9rem;color:var(--muted);line-height:1.7}
@media(max-width:900px){.pillars-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.pillars-grid{grid-template-columns:1fr}}

/* ---- SERVICES ---- */
.services-section{background:var(--dark)}
.services-intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;margin-bottom:64px}
.services-badge-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.services-badge{font-family:'Oswald',sans-serif;font-size:0.8rem;font-weight:500;letter-spacing:0.07em;text-transform:uppercase;color:var(--gold);border:1px solid rgba(212,160,23,0.3);padding:6px 14px;border-radius:20px;background:rgba(212,160,23,0.06)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.service-card{background:var(--dark2);padding:36px 28px;position:relative;overflow:hidden;transition:all .25s;cursor:pointer}
.service-card:hover{background:var(--dark3);transform:translateY(-3px)}
.service-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:0;transition:opacity .25s}
.service-card:hover::after{opacity:1}
.service-card-icon{width:54px;height:54px;background:rgba(212,160,23,0.1);border:1px solid rgba(212,160,23,0.2);border-radius:var(--r);display:flex;align-items:center;justify-content:center;margin-bottom:20px;transition:background .25s}
.service-card:hover .service-card-icon{background:rgba(212,160,23,0.2)}
.service-card-icon svg{width:26px;height:26px;fill:var(--gold)}
.service-card-title{font-family:'Oswald',sans-serif;font-size:1.1rem;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--white);margin-bottom:10px}
.service-card-text{font-size:0.88rem;color:var(--muted);line-height:1.65;margin-bottom:20px}
.service-card-link{font-family:'Oswald',sans-serif;font-size:0.78rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:6px}
.service-card-link svg{width:14px;height:14px;fill:var(--gold)}
@media(max-width:900px){.services-intro-grid{grid-template-columns:1fr}.services-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.services-grid{grid-template-columns:1fr}}

/* ---- STORM DAMAGE BANNER ---- */
.storm-banner{background:var(--red);background:linear-gradient(135deg,#8B0000,var(--red2),#CC3300);padding:60px 0;position:relative;overflow:hidden}
.storm-banner::before{content:'⚡';position:absolute;right:5%;top:50%;transform:translateY(-50%);font-size:18rem;opacity:0.04;line-height:1}
.storm-inner{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.storm-text h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(2rem,4vw,3.4rem);color:var(--white);letter-spacing:0.04em;line-height:1}
.storm-text p{font-size:1rem;color:rgba(255,255,255,0.8);margin-top:8px;max-width:520px}
.storm-cta{display:flex;gap:14px;flex-wrap:wrap}

/* ---- OC WIDGETS SECTION ---- */
.oc-section{background:var(--dark2)}
.oc-cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:48px}
.oc-card{background:var(--dark3);border:1px solid var(--dark4);border-radius:var(--rl);padding:28px 22px;text-align:center;transition:all .25s;cursor:pointer}
.oc-card:hover{border-color:rgba(212,160,23,0.4);background:var(--dark4);transform:translateY(-3px)}
.oc-card-icon{width:56px;height:56px;margin:0 auto 16px;background:rgba(212,160,23,0.1);border-radius:50%;display:flex;align-items:center;justify-content:center}
.oc-card-icon svg{width:28px;height:28px;fill:var(--gold)}
.oc-card-title{font-family:'Oswald',sans-serif;font-size:0.95rem;font-weight:600;letter-spacing:0.07em;text-transform:uppercase;color:var(--white);margin-bottom:8px}
.oc-card-text{font-size:0.82rem;color:var(--muted);line-height:1.6;margin-bottom:16px}
.oc-card-link{font-family:'Oswald',sans-serif;font-size:0.75rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--gold)}
.oc-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(212,160,23,0.08);border:1px solid rgba(212,160,23,0.25);border-radius:20px;padding:8px 20px;margin-bottom:28px}
.oc-badge img{height:20px;width:auto;filter:brightness(1.3)}
.oc-badge span{font-family:'Oswald',sans-serif;font-size:0.78rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--gold)}
@media(max-width:900px){.oc-cards-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.oc-cards-grid{grid-template-columns:1fr}}

/* ---- PROCESS SECTION ---- */
.process-section{background:var(--dark)}
.process-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin-top:56px;position:relative}
.process-steps::before{content:'';position:absolute;top:40px;left:10%;right:10%;height:2px;background:linear-gradient(90deg,transparent,var(--gold),var(--gold2),var(--gold),transparent);z-index:0}
.process-step{text-align:center;padding:0 12px;position:relative;z-index:1}
.step-circle{width:80px;height:80px;border-radius:50%;background:var(--dark3);border:2px solid rgba(212,160,23,0.3);margin:0 auto 20px;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:1.8rem;color:var(--gold);transition:all .3s}
.process-step:hover .step-circle{background:rgba(212,160,23,0.15);border-color:var(--gold)}
.step-title{font-family:'Oswald',sans-serif;font-size:0.9rem;font-weight:600;letter-spacing:0.07em;text-transform:uppercase;color:var(--white);margin-bottom:8px}
.step-text{font-size:0.8rem;color:var(--muted);line-height:1.6}
@media(max-width:900px){.process-steps{grid-template-columns:1fr 1fr;gap:32px}.process-steps::before{display:none}.process-step:last-child{grid-column:1/-1;max-width:240px;margin:0 auto}}
@media(max-width:480px){.process-steps{grid-template-columns:1fr}}

/* ---- GALLERY ---- */
.gallery-section{background:var(--dark2)}
.gallery-tabs{display:flex;gap:2px;margin-top:40px;margin-bottom:32px;flex-wrap:wrap}
.gallery-tab{font-family:'Oswald',sans-serif;font-size:0.82rem;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;padding:10px 20px;border:1px solid var(--dark4);border-radius:var(--r);cursor:pointer;transition:all .2s;color:var(--muted);background:var(--dark3)}
.gallery-tab.active,.gallery-tab:hover{background:rgba(212,160,23,0.12);border-color:rgba(212,160,23,0.4);color:var(--gold)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px}
.gallery-item{aspect-ratio:1;overflow:hidden;position:relative;cursor:pointer;background:var(--dark4)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.gallery-item:hover img{transform:scale(1.06)}
.gallery-item-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.7),transparent);opacity:0;transition:opacity .3s;display:flex;align-items:flex-end;padding:14px}
.gallery-item:hover .gallery-item-overlay{opacity:1}
.gallery-item-label{font-family:'Oswald',sans-serif;font-size:0.8rem;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--white)}
.gallery-placeholder{background:var(--dark4);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;aspect-ratio:1}
.gallery-placeholder svg{width:32px;height:32px;fill:var(--dark)}
.gallery-placeholder span{font-family:'Oswald',sans-serif;font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--steel)}
@media(max-width:768px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}

/* ---- REVIEWS ---- */
.reviews-section{background:var(--dark)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:52px}
.review-card{background:var(--dark2);border:1px solid var(--dark4);border-radius:var(--rl);padding:28px;transition:border-color .25s}
.review-card:hover{border-color:rgba(212,160,23,0.3)}
.review-stars{display:flex;gap:3px;margin-bottom:14px}
.star{width:16px;height:16px;fill:var(--gold)}
.review-text{font-size:0.9rem;color:var(--light);line-height:1.7;margin-bottom:18px;font-style:italic}
.review-author{display:flex;align-items:center;gap:12px;border-top:1px solid var(--dark4);padding-top:14px}
.review-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));display:flex;align-items:center;justify-content:center;font-family:'Oswald',sans-serif;font-size:1rem;font-weight:700;color:var(--black);flex-shrink:0}
.review-name{font-family:'Oswald',sans-serif;font-size:0.9rem;font-weight:600;letter-spacing:0.05em;color:var(--white)}
.review-location{font-size:0.75rem;color:var(--muted)}
.review-platform{margin-left:auto;font-family:'Oswald',sans-serif;font-size:0.68rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted)}
@media(max-width:900px){.reviews-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.reviews-grid{grid-template-columns:1fr}}

/* ---- LOCATIONS ---- */
.locations-section{background:var(--dark2)}
.locations-grid{display:flex;flex-wrap:wrap;gap:10px;margin-top:40px}
.location-chip{font-family:'Oswald',sans-serif;font-size:0.82rem;font-weight:500;letter-spacing:0.07em;text-transform:uppercase;color:var(--light);border:1px solid var(--dark4);padding:9px 18px;border-radius:20px;background:var(--dark3);transition:all .2s;display:flex;align-items:center;gap:7px}
.location-chip:hover{border-color:var(--gold);color:var(--gold);background:rgba(212,160,23,0.07)}
.location-chip::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--gold);flex-shrink:0}

/* ---- ESTIMATE SECTION ---- */
.estimate-section{background:var(--dark);position:relative;overflow:hidden}
.estimate-section::before{content:'';position:absolute;top:-80px;right:-80px;width:500px;height:500px;border-radius:50%;background:rgba(212,160,23,0.04);pointer-events:none}
.estimate-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.estimate-form-wrap{background:var(--dark2);border:1px solid var(--dark4);border-radius:var(--rl);padding:40px;border-top:3px solid var(--gold)}
.estimate-form-title{font-family:'Bebas Neue',sans-serif;font-size:2.2rem;color:var(--white);letter-spacing:0.04em;margin-bottom:6px}
.estimate-form-sub{font-size:0.88rem;color:var(--muted);margin-bottom:28px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-family:'Oswald',sans-serif;font-size:0.78rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
.form-group input,.form-group select,.form-group textarea{width:100%;background:var(--dark3);border:1px solid var(--mid);border-radius:var(--r);padding:12px 14px;font-size:0.92rem;color:var(--white);font-family:'Roboto',sans-serif;transition:border .2s;outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold)}
.form-group select{appearance:none;cursor:pointer}
.form-group textarea{resize:vertical;min-height:90px}
.form-submit-row{margin-top:6px}
.form-privacy{font-size:0.75rem;color:var(--muted);margin-top:10px;line-height:1.5}
.estimate-info{padding-top:8px}
.estimate-info-title{font-family:'Bebas Neue',sans-serif;font-size:2.6rem;color:var(--white);letter-spacing:0.04em;line-height:1;margin-bottom:18px}
.estimate-info-title em{color:var(--gold);font-style:normal;display:block}
.estimate-info-text{font-size:0.95rem;color:var(--muted);line-height:1.75;margin-bottom:28px}
.estimate-features{display:flex;flex-direction:column;gap:14px;margin-bottom:32px}
.estimate-feature{display:flex;align-items:flex-start;gap:14px}
.ef-icon{width:36px;height:36px;border-radius:var(--r);background:rgba(212,160,23,0.12);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.ef-icon svg{width:18px;height:18px;fill:var(--gold)}
.ef-text strong{display:block;font-family:'Oswald',sans-serif;font-size:0.9rem;font-weight:600;letter-spacing:0.05em;color:var(--white);margin-bottom:2px}
.ef-text span{font-size:0.83rem;color:var(--muted)}
.estimate-contact-row{display:flex;gap:14px;flex-wrap:wrap}
.contact-box{flex:1;min-width:180px;background:var(--dark2);border:1px solid var(--dark4);border-radius:var(--r);padding:18px;text-align:center}
.contact-box-label{font-family:'Oswald',sans-serif;font-size:0.7rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.contact-box-value{font-family:'Oswald',sans-serif;font-size:1.05rem;font-weight:600;color:var(--gold)}
@media(max-width:900px){.estimate-grid{grid-template-columns:1fr}.estimate-info{order:-1}.form-row{grid-template-columns:1fr}}

/* ---- FAQ ---- */
.faq-section{background:var(--dark2)}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;margin-top:52px}
.faq-item{background:var(--dark3);border-left:3px solid transparent;padding:28px 30px;transition:border-color .25s,background .25s;cursor:pointer}
.faq-item:hover,.faq-item.open{border-left-color:var(--gold);background:var(--dark4)}
.faq-q{font-family:'Oswald',sans-serif;font-size:1rem;font-weight:600;letter-spacing:0.04em;color:var(--white);display:flex;align-items:flex-start;justify-content:space-between;gap:14px;user-select:none}
.faq-arrow{width:20px;height:20px;flex-shrink:0;fill:var(--gold);transition:transform .3s;margin-top:2px}
.faq-item.open .faq-arrow{transform:rotate(180deg)}
.faq-a{font-size:0.88rem;color:var(--muted);line-height:1.7;max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s}
.faq-item.open .faq-a{max-height:300px;padding-top:14px}
@media(max-width:768px){.faq-grid{grid-template-columns:1fr}}

/* ---- FOOTER ---- */
footer{background:var(--black);border-top:2px solid rgba(212,160,23,0.2)}
.footer-top{padding:70px 0 50px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:48px}
.footer-brand img{height:60px;width:auto;margin-bottom:18px}
.footer-brand p{font-size:0.88rem;color:var(--muted);line-height:1.7;margin-bottom:20px}
.footer-social{display:flex;gap:10px}
.social-btn{width:38px;height:38px;border-radius:var(--r);background:var(--dark3);border:1px solid var(--dark4);display:flex;align-items:center;justify-content:center;transition:all .2s}
.social-btn:hover{background:rgba(212,160,23,0.15);border-color:rgba(212,160,23,0.4)}
.social-btn svg{width:18px;height:18px;fill:var(--muted)}
.social-btn:hover svg{fill:var(--gold)}
.footer-col-title{font-family:'Oswald',sans-serif;font-size:0.85rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--white);margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid var(--dark4)}
.footer-links{display:flex;flex-direction:column;gap:8px}
.footer-links a{font-size:0.85rem;color:var(--muted);transition:color .2s;display:flex;align-items:center;gap:6px}
.footer-links a::before{content:'›';color:var(--gold);flex-shrink:0}
.footer-links a:hover{color:var(--gold)}
.footer-contact-list{display:flex;flex-direction:column;gap:14px}
.footer-contact-item{display:flex;align-items:flex-start;gap:12px}
.fc-icon{width:34px;height:34px;border-radius:var(--r);background:rgba(212,160,23,0.1);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fc-icon svg{width:16px;height:16px;fill:var(--gold)}
.fc-text strong{display:block;font-family:'Oswald',sans-serif;font-size:0.78rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);margin-bottom:2px}
.fc-text span{font-size:0.88rem;color:var(--light)}
.fc-text a{color:var(--gold)}
.footer-bottom{border-top:1px solid var(--dark3);padding:20px 0}
.footer-bottom-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.footer-copy{font-size:0.8rem;color:var(--muted)}
.footer-bottom-links{display:flex;gap:20px}
.footer-bottom-links a{font-size:0.78rem;color:var(--muted);transition:color .2s}
.footer-bottom-links a:hover{color:var(--gold)}
.footer-locations-grid{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.footer-loc{font-size:0.75rem;color:var(--steel);transition:color .2s}
.footer-loc:hover{color:var(--gold)}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}}

/* ---- UTILITY SECTIONS ---- */
.section-divider{height:2px;background:linear-gradient(90deg,transparent,rgba(212,160,23,0.3),transparent)}
.gold-bar{height:3px;background:linear-gradient(90deg,var(--gold-dark),var(--gold),var(--gold2),var(--gold),var(--gold-dark))}

/* ---- BEFORE/AFTER STRIP ---- */
.ba-strip{display:grid;grid-template-columns:1fr 1fr;gap:2px;margin-top:40px}
.ba-item{position:relative;overflow:hidden;aspect-ratio:16/9;background:var(--dark4)}
.ba-item img{width:100%;height:100%;object-fit:cover}
.ba-label{position:absolute;top:14px;left:14px;font-family:'Oswald',sans-serif;font-size:0.78rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;padding:5px 12px;border-radius:2px}
.ba-label.before{background:rgba(0,0,0,0.75);color:var(--light)}
.ba-label.after{background:var(--gold);color:var(--black)}
@media(max-width:560px){.ba-strip{grid-template-columns:1fr}}

/* ---- OC VISUALIZER TEASER ---- */
.oc-teaser{background:linear-gradient(135deg,var(--dark3),var(--dark2));border:1px solid rgba(212,160,23,0.2);border-radius:var(--rl);padding:52px 48px;margin-top:56px;display:flex;align-items:center;gap:40px;flex-wrap:wrap}
.oc-teaser-icon{width:80px;height:80px;background:rgba(212,160,23,0.1);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.oc-teaser-icon svg{width:38px;height:38px;fill:var(--gold)}
.oc-teaser-text h3{font-family:'Bebas Neue',sans-serif;font-size:2rem;color:var(--white);letter-spacing:0.04em;margin-bottom:8px}
.oc-teaser-text p{font-size:0.92rem;color:var(--muted);max-width:480px;line-height:1.7}
.oc-teaser-actions{margin-left:auto;display:flex;gap:12px;flex-wrap:wrap}
@media(max-width:768px){.oc-teaser{padding:36px 28px}.oc-teaser-actions{margin-left:0;width:100%}}

/* ---- AWARDS / BADGES ---- */
.badges-row{display:flex;align-items:center;gap:28px;flex-wrap:wrap;padding:30px 0;border-top:1px solid var(--dark4);border-bottom:1px solid var(--dark4);margin-top:52px}
.badge-item{display:flex;align-items:center;gap:12px}
.badge-item svg{width:36px;height:36px;fill:var(--gold)}
.badge-item-text{font-family:'Oswald',sans-serif;font-size:0.78rem;font-weight:600;letter-spacing:0.07em;text-transform:uppercase;color:var(--light);line-height:1.3}
.badge-item-text span{display:block;font-size:0.65rem;color:var(--muted);font-weight:400}