/* =========================================================
   Next Gen Construction LLC — Black | Red | White Brand Theme
   Colors: Black #111111 | Brand Red #CC0000 | White #FFFFFF
   Fonts: Cormorant Garamond (display) + DM Sans (body)
   ========================================================= */
:root{
  --slate:#111111;
  --slate-light:#1a1a1a;
  --gold:#CC0000;
  --gold-light:#E52222;
  --red:#CC0000;
  --red-light:#E52222;
  --ivory:#FFFFFF;
  --ivory-dark:#F2F2F2;
  --stone:#E0E0E0;
  --charcoal:#1C1C1C;
  --mid:#888888;
  --text:#333333;
  --white:#FFFFFF;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;background:var(--ivory);color:var(--text);overflow-x:hidden;}

/* ─── UTILITY ─── */
.container{max-width:1240px;margin:0 auto;padding:0 40px;}
.eyebrow{font-family:'DM Sans',sans-serif;font-size:11px;font-weight:700;letter-spacing:3.5px;text-transform:uppercase;color:var(--red);margin-bottom:14px;}
.display{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:clamp(38px,5vw,72px);line-height:1.05;color:var(--slate);}
.display em{font-style:italic;color:var(--red);}
.body-lg{font-size:17px;line-height:1.85;color:var(--mid);font-weight:400;}
.btn-primary{display:inline-block;background:var(--slate);color:var(--ivory);font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;padding:16px 38px;text-decoration:none;border-radius:2px;transition:background .25s,transform .2s;}
.btn-primary:hover{background:var(--slate-light);transform:translateY(-2px);}
.btn-gold{display:inline-block;background:var(--red);color:#fff;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:16px 38px;text-decoration:none;border-radius:2px;transition:background .25s,transform .2s,box-shadow .25s;}
.btn-gold:hover{background:var(--red-light);transform:translateY(-2px);box-shadow:0 12px 40px rgba(204,0,0,0.35);}
.btn-outline{display:inline-block;border:1.5px solid var(--slate);color:var(--slate);font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;padding:14px 36px;text-decoration:none;border-radius:2px;transition:background .25s,color .25s,transform .2s;}
.btn-outline:hover{background:var(--slate);color:var(--ivory);transform:translateY(-2px);}
.btn-outline-white{display:inline-block;border:1.5px solid rgba(255,255,255,0.4);color:#fff;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;padding:14px 36px;text-decoration:none;border-radius:2px;transition:background .25s,color .25s,border-color .25s;}
.btn-outline-white:hover{background:rgba(255,255,255,0.1);border-color:#fff;}

/* ─── TOP STRIP ─── */
.topstrip{background:var(--slate);padding:10px 0;}
.topstrip-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;}
.topstrip-links{display:flex;gap:28px;align-items:center;}
.topstrip-links a,.topstrip-links span{font-size:12px;color:rgba(255,255,255,0.62);text-decoration:none;display:flex;align-items:center;gap:7px;font-weight:400;transition:color .2s;}
.topstrip-links a:hover{color:var(--red);}
.strip-phone{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:600;color:var(--red);letter-spacing:.5px;text-decoration:none;transition:color .2s;}
.strip-phone:hover{color:var(--red-light);}

/* ─── INSURANCE TAGLINE STRIP ─── */
.ins-strip{background:var(--red);padding:10px 0;text-align:center;}
.ins-strip p{font-size:13px;font-weight:600;color:#fff;letter-spacing:.3px;}
.ins-strip a{color:#fff;text-decoration:underline;margin-left:12px;font-weight:700;}
.ins-strip a:hover{opacity:.85;}

/* ─── NAV ─── */
nav{background:var(--ivory);position:sticky;top:0;z-index:999;border-bottom:1px solid var(--stone);}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:80px;}
.logo{display:flex;align-items:center;gap:12px;text-decoration:none;}
.logo-img{height:48px;width:auto;display:block;flex-shrink:0;}
.logo-name{display:flex;flex-direction:column;line-height:1.1;}
.logo-name strong{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:700;color:var(--slate);letter-spacing:.4px;}
.logo-name span{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--mid);font-weight:500;}
.nav-menu{display:flex;gap:2px;list-style:none;align-items:center;}
.nav-menu > li{position:relative;}
.nav-menu > li > a{font-size:13px;font-weight:500;color:var(--charcoal);text-decoration:none;padding:8px 13px;border-radius:2px;letter-spacing:.3px;transition:color .2s,background .2s;display:flex;align-items:center;gap:4px;white-space:nowrap;}
.nav-menu > li > a:hover,.nav-menu > li > a.active{color:var(--red);background:rgba(204,0,0,0.05);}
.drop-arrow{font-size:9px;opacity:.7;transition:transform .2s;}
.has-dropdown:hover .drop-arrow{transform:rotate(180deg);}
.nav-cta{background:var(--red) !important;color:#fff !important;font-weight:700 !important;letter-spacing:1px !important;padding:10px 22px !important;border-radius:2px;}
.nav-cta:hover{background:var(--red-light) !important;color:#fff !important;}
.dropdown{position:absolute;top:calc(100% + 1px);left:0;background:var(--white);border:1px solid var(--stone);border-top:3px solid var(--red);border-radius:0 0 4px 4px;min-width:215px;display:none;z-index:1000;box-shadow:0 14px 40px rgba(17,17,17,0.12);}
.has-dropdown:hover .dropdown{display:block;}
.dropdown li{list-style:none;}
.dropdown a{display:block;padding:11px 18px;font-size:13px;color:var(--text);border-bottom:1px solid rgba(17,17,17,0.05);text-decoration:none;transition:color .2s,background .2s,padding-left .2s;}
.dropdown a:last-child{border-bottom:none;}
.dropdown a:hover{background:rgba(204,0,0,0.05);color:var(--red);padding-left:24px;}
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:6px;width:36px;}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--slate);border-radius:2px;transition:.3s;}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle.open span:nth-child(2){opacity:0;}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ─── HOME HERO ─── */
.hero{height:100vh;min-height:680px;position:relative;display:flex;align-items:flex-end;overflow:hidden;}
.hero-media{position:absolute;inset:0;}
.hero-media img{width:100%;height:100%;object-fit:cover;}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(105deg,rgba(17,17,17,0.92) 0%,rgba(17,17,17,0.75) 42%,rgba(17,17,17,0.12) 100%);}
.hero-line{position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(to bottom,var(--red),transparent);}
.hero-inner{position:relative;z-index:2;padding-bottom:80px;width:100%;}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:flex-end;}
.hero-badge{display:inline-flex;align-items:center;gap:10px;border:1px solid rgba(204,0,0,0.4);padding:8px 18px;border-radius:1px;margin-bottom:28px;animation:slideRight .8s ease both;}
.hero-badge span{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--red);font-weight:600;}
.hero-badge-dot{width:5px;height:5px;border-radius:50%;background:var(--red);}
.hero h1{font-family:'Cormorant Garamond',serif;font-size:clamp(52px,7vw,100px);font-weight:600;line-height:.95;color:var(--ivory);animation:slideRight .9s ease .08s both;}
.hero h1 em{font-style:italic;color:var(--red);display:block;}
.hero-desc{font-size:16px;color:rgba(255,255,255,0.65);margin-top:24px;max-width:480px;line-height:1.8;animation:slideRight 1s ease .16s both;font-weight:300;}
.hero-actions{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap;animation:slideRight 1.1s ease .24s both;}
.hero-stats-card{background:rgba(255,255,255,0.06);backdrop-filter:blur(16px);border:1px solid rgba(204,0,0,0.2);padding:40px 36px;border-radius:4px;animation:fadeUp 1.2s ease .3s both;}
.hsc-title{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:var(--ivory);margin-bottom:24px;border-bottom:1px solid rgba(204,0,0,0.25);padding-bottom:16px;}
.hsc-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid rgba(255,255,255,0.07);}
.hsc-row:last-of-type{border-bottom:none;}
.hsc-label{font-size:13px;color:rgba(255,255,255,0.55);font-weight:400;}
.hsc-value{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:600;color:var(--red);}
.hsc-cta{margin-top:24px;display:block;text-align:center;background:var(--red);color:#fff;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:14px;border-radius:2px;text-decoration:none;transition:background .2s;}
.hsc-cta:hover{background:var(--red-light);}
.scroll-hint{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;z-index:3;}
.scroll-hint span{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.35);}
.scroll-arrow{width:1px;height:48px;background:linear-gradient(to bottom,rgba(204,0,0,0.5),transparent);animation:scrollPulse 1.8s ease-in-out infinite;}

/* ─── PAGE HERO (subpages) ─── */
.page-hero{height:360px;position:relative;display:flex;align-items:center;overflow:hidden;}
.page-hero-bg{position:absolute;inset:0;}
.page-hero-bg img{width:100%;height:100%;object-fit:cover;}
.page-hero-overlay{position:absolute;inset:0;background:rgba(17,17,17,0.84);}
.page-hero-line{position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(to bottom,var(--red),transparent);}
.page-hero-content{position:relative;z-index:2;}
.page-hero-content .eyebrow{color:var(--red);}
.page-hero-content h1{font-family:'Cormorant Garamond',serif;font-size:clamp(40px,5vw,68px);font-weight:600;color:#fff;line-height:1.05;margin-bottom:16px;}
.page-hero-content h1 em{font-style:italic;color:var(--red);}
.page-hero-content p{font-size:17px;color:rgba(255,255,255,0.62);max-width:620px;line-height:1.75;}

/* ─── PROOF STRIP ─── */
.proof-strip{background:var(--stone);padding:0;}
.proof-inner{display:grid;grid-template-columns:repeat(5,1fr);border-left:1px solid rgba(17,17,17,0.1);}
.proof-cell{padding:28px 20px;text-align:center;border-right:1px solid rgba(17,17,17,0.1);display:flex;flex-direction:column;align-items:center;gap:4px;}
.proof-num{font-family:'Cormorant Garamond',serif;font-size:44px;font-weight:700;color:var(--slate);line-height:1;}
.proof-lbl{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--mid);}
.proof-icon{font-size:22px;margin-bottom:6px;}

/* ─── INSURANCE CALLOUT BANNER ─── */
.ins-callout{background:var(--slate);padding:90px 0;position:relative;overflow:hidden;}
.ins-callout::before{content:'';position:absolute;left:0;top:0;bottom:0;width:6px;background:var(--red);}
.ins-callout-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.ins-callout-left h2{font-family:'Cormorant Garamond',serif;font-size:clamp(30px,4vw,50px);font-weight:600;color:#fff;line-height:1.1;}
.ins-callout-left h2 em{color:var(--red);font-style:italic;}
.ins-callout-left p{font-size:16px;color:rgba(255,255,255,0.62);line-height:1.85;margin-top:18px;}
.ins-callout-actions{margin-top:32px;display:flex;gap:14px;flex-wrap:wrap;}
.ins-steps-list{display:flex;flex-direction:column;gap:18px;}
.ins-step-row{display:flex;gap:16px;align-items:flex-start;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);padding:18px 22px;border-radius:3px;}
.ins-step-num{width:38px;height:38px;background:var(--red);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:17px;font-weight:700;color:#fff;flex-shrink:0;}
.ins-step-row h4{font-size:14px;font-weight:600;color:#fff;margin-bottom:3px;}
.ins-step-row p{font-size:13px;color:rgba(255,255,255,0.52);line-height:1.55;}

/* ─── ABOUT ─── */
.about{background:var(--ivory);padding:120px 0;}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:center;}
.about-visual{position:relative;}
.about-main-img{width:100%;height:580px;object-fit:cover;display:block;border-radius:3px;}
.about-float{position:absolute;bottom:-36px;right:-36px;width:260px;background:var(--slate);padding:32px 28px;border-radius:3px;}
.about-float .num{font-family:'Cormorant Garamond',serif;font-size:64px;font-weight:700;color:var(--red);line-height:1;}
.about-float p{font-size:13px;color:rgba(255,255,255,0.6);margin-top:6px;line-height:1.6;}
.cert-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:32px;}
.cert-badge{background:var(--ivory-dark);border:1px solid var(--stone);padding:8px 16px;border-radius:2px;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--slate);}

/* ─── SERVICES GRID ─── */
.services{background:var(--slate);padding:120px 0;position:relative;overflow:hidden;}
.services::before{content:'';position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1504307651254-35680f356dfd?w=1600&q=80') center/cover no-repeat;opacity:.04;}
.srv-head{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-bottom:72px;align-items:end;}
.srv-head .display{color:var(--ivory);}
.srv-head .display em{color:var(--red);}
.srv-head p{color:rgba(255,255,255,0.5);font-size:16px;line-height:1.8;}
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;}
.srv-card{position:relative;overflow:hidden;background:rgba(255,255,255,0.03);cursor:default;}
.srv-card-img{width:100%;height:320px;object-fit:cover;display:block;transition:transform .6s ease,filter .4s;}
.srv-card:hover .srv-card-img{transform:scale(1.07);filter:brightness(0.7);}
.srv-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(17,17,17,0.95) 0%,rgba(17,17,17,0.3) 55%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:32px 28px;transition:background .3s;}
.srv-card:hover .srv-card-overlay{background:linear-gradient(to top,rgba(17,17,17,0.98) 0%,rgba(17,17,17,0.65) 55%,transparent 100%);}
.srv-tag{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--red);font-weight:700;margin-bottom:8px;}
.srv-card h3{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:600;color:var(--ivory);line-height:1.15;}
.srv-card p{font-size:14px;color:rgba(255,255,255,0.55);line-height:1.7;margin-top:10px;max-height:0;overflow:hidden;transition:max-height .4s ease,opacity .4s;}
.srv-card:hover p{max-height:100px;opacity:1;}
.srv-arrow{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--red);margin-top:16px;text-decoration:none;opacity:0;transform:translateY(8px);transition:opacity .3s,transform .3s;}
.srv-card:hover .srv-arrow{opacity:1;transform:translateY(0);}

/* ─── SERVICE DETAIL (roofing/siding pages) ─── */
.srv-detail-section{padding:100px 0;}
.srv-detail-section:nth-child(even){background:var(--ivory-dark);}
.srv-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.srv-detail-grid.reverse{direction:rtl;}
.srv-detail-grid.reverse > *{direction:ltr;}
.srv-detail-img{width:100%;height:440px;object-fit:cover;border-radius:4px;display:block;box-shadow:0 24px 60px rgba(17,17,17,0.15);}
.srv-detail-copy h2{font-family:'Cormorant Garamond',serif;font-size:clamp(30px,4vw,50px);font-weight:600;color:var(--slate);line-height:1.1;margin-bottom:16px;}
.srv-detail-copy h2 em{font-style:italic;color:var(--red);}
.srv-detail-copy p{font-size:15px;line-height:1.85;color:var(--mid);margin-bottom:14px;}
.srv-bullets{list-style:none;margin:16px 0 26px;}
.srv-bullets li{padding:7px 0;font-size:14px;color:var(--text);display:flex;align-items:center;gap:12px;border-bottom:1px solid rgba(17,17,17,0.05);}
.srv-bullets li:last-child{border-bottom:none;}
.srv-bullets li::before{content:'';width:8px;height:8px;background:var(--red);border-radius:50%;flex-shrink:0;}

/* ─── VIDEO ─── */
.video-sec{background:var(--ivory-dark);padding:120px 0;}
.video-layout{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.video-wrap{position:relative;border-radius:4px;overflow:hidden;box-shadow:0 32px 80px rgba(17,17,17,0.2);}
.video-wrap video,.video-wrap img{width:100%;display:block;border-radius:4px;}
.video-wrap img{height:440px;object-fit:cover;}
.play-ring{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;cursor:pointer;}
.play-ring button{width:80px;height:80px;border-radius:50%;border:2px solid var(--red);background:rgba(255,255,255,0.15);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .25s,transform .25s;color:var(--red);}
.play-ring button:hover{background:var(--red);transform:scale(1.08);}
.play-ring button:hover svg{fill:#fff;}
.play-ring button svg{fill:var(--red);width:28px;height:28px;margin-left:4px;}
.warranty-box{background:var(--slate);color:var(--ivory);padding:36px 32px;border-radius:3px;margin-top:36px;}
.warranty-box h4{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:600;margin-bottom:10px;}
.warranty-box p{font-size:14px;color:rgba(255,255,255,0.55);line-height:1.75;}
.warranty-badges{display:flex;gap:16px;margin-top:20px;flex-wrap:wrap;}
.wb{background:rgba(204,0,0,0.15);border:1px solid rgba(204,0,0,0.3);padding:8px 16px;border-radius:2px;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--red);}

/* ─── GALLERY ─── */
.gallery{background:var(--ivory);padding:120px 0;}
.gal-head{text-align:center;margin-bottom:64px;}
.gal-head .display{font-size:clamp(36px,4.5vw,64px);}
.gal-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:10px;}
.gi{overflow:hidden;border-radius:3px;position:relative;}
.gi img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease,filter .4s;display:block;}
.gi:hover img{transform:scale(1.05);}
.gi-label{position:absolute;bottom:0;left:0;right:0;padding:16px 20px;background:linear-gradient(to top,rgba(17,17,17,0.85),transparent);font-family:'Cormorant Garamond',serif;font-size:15px;font-weight:600;color:var(--ivory);opacity:0;transform:translateY(6px);transition:opacity .3s,transform .3s;}
.gi:hover .gi-label{opacity:1;transform:translateY(0);}
.gi-1{grid-column:1/8;grid-row:1/3;height:480px;}
.gi-2{grid-column:8/13;height:235px;}
.gi-3{grid-column:8/13;height:235px;}
.gi-4{grid-column:1/5;height:280px;}
.gi-5{grid-column:5/9;height:280px;}
.gi-6{grid-column:9/13;height:280px;}
/* Expanded gallery page grid */
.gi-7{grid-column:1/5;height:260px;}
.gi-8{grid-column:5/9;height:260px;}
.gi-9{grid-column:9/13;height:260px;}
.gi-10{grid-column:1/7;height:340px;}
.gi-11{grid-column:7/13;height:340px;}

/* ─── FILTERABLE GALLERY (gallery.html) ─── */
.gallery-filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:46px;}
.f-btn{padding:9px 24px;border-radius:50px;background:transparent;border:1.5px solid rgba(17,17,17,.15);color:var(--slate);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;cursor:pointer;transition:all .2s;}
.f-btn.active,.f-btn:hover{background:var(--red);border-color:var(--red);color:#fff;}
#galGrid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:240px;gap:12px;}
#galGrid .gi{cursor:pointer;transition:opacity .35s ease,transform .4s ease;}
#galGrid .gi.span2{grid-column:span 2;}
#galGrid .gi.tall{grid-row:span 2;}
#galGrid .gi.hidden{opacity:.10;transform:scale(.96);pointer-events:none;}
@media(max-width:900px){#galGrid{grid-template-columns:repeat(2,1fr);grid-auto-rows:200px;}#galGrid .gi.span2{grid-column:span 2;}}
@media(max-width:560px){#galGrid{grid-template-columns:1fr;}#galGrid .gi.span2,#galGrid .gi.tall{grid-column:span 1;grid-row:span 1;}}

/* ─── LIGHTBOX ─── */
.lightbox{position:fixed;inset:0;z-index:9000;background:rgba(17,17,17,.95);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .3s;}
.lightbox.on{opacity:1;visibility:visible;}
.lightbox img{max-width:88vw;max-height:82vh;object-fit:contain;border-radius:6px;}
.lb-close{position:absolute;top:20px;right:20px;width:42px;height:42px;border-radius:50%;background:rgba(0,0,0,.45);border:1.5px solid rgba(255,255,255,.55);box-shadow:0 6px 20px rgba(0,0,0,.4);color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s,transform .2s;z-index:2;}
.lb-close:hover{background:var(--red);border-color:var(--red);transform:scale(1.08);}
.lb-prev,.lb-next{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;background:rgba(0,0,0,.45);border:1.5px solid rgba(255,255,255,.55);box-shadow:0 6px 20px rgba(0,0,0,.4);color:#fff;font-size:1.6rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s,transform .2s;z-index:2;}
.lb-prev{left:22px;}
.lb-next{right:22px;}
.lb-prev:hover,.lb-next:hover{background:var(--red);border-color:var(--red);transform:translateY(-50%) scale(1.08);}
.lb-caption{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);font-family:'Cormorant Garamond',serif;color:#fff;letter-spacing:.5px;font-size:1rem;text-align:center;max-width:80vw;}

/* ─── BEFORE / AFTER ─── */
.before-after{background:var(--ivory-dark);padding:110px 0;}
.ba-head{text-align:center;margin-bottom:54px;}
.ba-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;}
.ba-card{background:var(--ivory);border:1px solid rgba(17,17,17,.10);border-radius:5px;overflow:hidden;box-shadow:0 24px 70px rgba(17,17,17,.08);}
.ba-images{display:grid;grid-template-columns:1fr 1fr;}
.ba-img{position:relative;height:320px;overflow:hidden;}
.ba-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s ease;}
.ba-card:hover .ba-img img{transform:scale(1.04);}
.ba-label{position:absolute;top:14px;left:14px;background:rgba(17,17,17,.88);color:var(--ivory);font-size:10px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;padding:7px 10px;border-radius:2px;}
.ba-label.after{background:var(--red);color:#fff;}
.ba-copy{padding:24px 26px;}
.ba-copy h3{font-family:'Cormorant Garamond',serif;font-size:25px;color:var(--slate);margin-bottom:8px;}
.ba-copy p{font-size:14px;line-height:1.75;color:var(--mid);}

/* ─── WHY US ─── */
.whyus{background:var(--ivory-dark);padding:120px 0;}
.wu-layout{display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:center;}
.wu-img-col{position:relative;}
.wu-main{width:100%;height:520px;object-fit:cover;display:block;border-radius:3px;}
.wu-accent-card{position:absolute;top:-32px;left:-32px;background:var(--red);padding:28px 24px;border-radius:3px;width:180px;box-shadow:0 16px 48px rgba(204,0,0,0.35);}
.wu-accent-card .big{font-family:'Cormorant Garamond',serif;font-size:52px;font-weight:700;color:#fff;line-height:1;}
.wu-accent-card small{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.8);}
.wu-items{display:flex;flex-direction:column;gap:28px;margin-top:36px;}
.wu-item{display:flex;gap:20px;align-items:flex-start;}
.wu-icon-box{width:48px;height:48px;background:rgba(204,0,0,0.10);border:1px solid rgba(204,0,0,0.25);border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.wu-item-text h4{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:var(--slate);margin-bottom:5px;}
.wu-item-text p{font-size:14px;color:var(--mid);line-height:1.75;}

/* ─── TESTIMONIALS ─── */
.testimonials{background:var(--slate);padding:120px 0;}
.test-head{text-align:center;margin-bottom:72px;}
.test-head .display{color:var(--ivory);}
.stars-row{display:flex;justify-content:center;gap:5px;font-size:22px;color:var(--red);margin-top:16px;}
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.test-card{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);padding:40px 32px;border-radius:3px;position:relative;transition:background .3s,border-color .3s;}
.test-card:hover{background:rgba(255,255,255,0.07);border-color:rgba(204,0,0,0.25);}
.tc-quote{font-family:'Cormorant Garamond',serif;font-size:72px;color:rgba(204,0,0,0.15);line-height:1;position:absolute;top:16px;right:24px;font-weight:700;}
.tc-stars{color:var(--red);font-size:14px;letter-spacing:2px;margin-bottom:18px;}
.test-card p{font-family:'Cormorant Garamond',serif;font-size:19px;color:rgba(255,255,255,0.75);line-height:1.65;font-style:italic;}
.tc-author{margin-top:28px;display:flex;align-items:center;gap:14px;border-top:1px solid rgba(255,255,255,0.08);padding-top:20px;}
.tc-av{width:42px;height:42px;border-radius:50%;background:rgba(204,0,0,0.2);border:1px solid var(--red);display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:600;color:var(--red);flex-shrink:0;}
.tc-author strong{display:block;font-size:14px;font-weight:600;color:var(--ivory);}
.tc-author span{font-size:12px;color:rgba(255,255,255,0.35);}

/* ─── PROCESS ─── */
.process{background:var(--ivory);padding:120px 0;}
.proc-head{text-align:center;margin-bottom:72px;}
.proc-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative;}
.proc-steps::after{content:'';position:absolute;top:36px;left:10%;right:10%;height:1px;background:linear-gradient(to right,transparent,var(--red),var(--red),transparent);z-index:0;}
.proc-step{text-align:center;padding:0 20px;position:relative;z-index:1;}
.proc-num{width:72px;height:72px;border-radius:50%;background:var(--ivory);border:2px solid var(--red);display:flex;align-items:center;justify-content:center;margin:0 auto 24px;font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:700;color:var(--slate);}
.proc-step h4{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:var(--slate);margin-bottom:10px;}
.proc-step p{font-size:14px;color:var(--mid);line-height:1.7;}

/* ─── AREAS ─── */
.areas{background:var(--stone);padding:80px 0;}
.areas-inner{display:grid;grid-template-columns:1fr 2fr;gap:80px;align-items:start;}
.areas-tags{display:flex;flex-wrap:wrap;gap:14px;max-width:820px;margin-top:18px;}
.area-chip{background:var(--ivory);border:1px solid rgba(17,17,17,0.12);padding:11px 20px;border-radius:2px;font-size:13px;font-weight:600;color:var(--charcoal);display:inline-block;box-shadow:0 4px 12px rgba(17,17,17,.04);transition:all .2s;cursor:default;}
.area-chip:hover{background:var(--red);color:#fff;border-color:var(--red);transform:translateY(-2px);}

/* ─── CTA BANNER ─── */
.cta-banner{position:relative;overflow:hidden;}
.cta-bg{position:absolute;inset:0;}
.cta-bg img{width:100%;height:100%;object-fit:cover;}
.cta-bg-overlay{position:absolute;inset:0;background:rgba(17,17,17,0.87);}
.cta-inner{position:relative;z-index:2;padding:120px 0;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.cta-text .display{color:var(--ivory);font-size:clamp(38px,5vw,68px);}
.cta-text p{font-size:17px;color:rgba(255,255,255,0.62);line-height:1.8;margin-top:20px;}
.cta-form{background:rgba(255,255,255,0.06);backdrop-filter:blur(16px);border:1px solid rgba(204,0,0,0.2);padding:44px 40px;border-radius:4px;}
.cta-form h3{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:600;color:var(--ivory);margin-bottom:8px;}
.cta-form > p{font-size:14px;color:rgba(255,255,255,0.5);margin-bottom:28px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px;}
.form-field{display:flex;flex-direction:column;gap:5px;margin-bottom:0;}
.form-field label{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.45);}
.form-field input,.form-field select,.form-field textarea{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);border-radius:2px;padding:12px 14px;font-size:14px;color:var(--ivory);font-family:'DM Sans',sans-serif;outline:none;transition:border-color .2s;}
.form-field input::placeholder,.form-field textarea::placeholder{color:rgba(255,255,255,0.25);}
.form-field select option{background:var(--slate);color:var(--ivory);}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--red);}
.form-submit{width:100%;background:var(--red);color:#fff;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:16px;border:none;border-radius:2px;cursor:pointer;margin-top:16px;transition:background .2s;}
.form-submit:hover{background:var(--red-light);}
.phone-display{margin-top:36px;text-align:center;}
.phone-display a{font-family:'Cormorant Garamond',serif;font-size:46px;font-weight:600;color:var(--red);text-decoration:none;letter-spacing:1px;transition:color .2s;}
.phone-display a:hover{color:var(--red-light);}
.phone-display small{display:block;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-bottom:8px;}

/* ─── INSURANCE PAGE ─── */
.ins-page-intro{padding:80px 0;background:var(--ivory);}
.ins-page-tagline{background:var(--red);padding:36px 40px;border-radius:4px;margin-bottom:60px;text-align:center;}
.ins-page-tagline h2{font-family:'Cormorant Garamond',serif;font-size:clamp(24px,3vw,38px);font-weight:600;color:#fff;line-height:1.2;}
.ins-page-tagline p{font-size:15px;color:rgba(255,255,255,0.85);margin-top:10px;}
.ins-page-steps{padding:80px 0;background:var(--ivory-dark);}
.ins-steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:56px;}
.ins-step-card{background:var(--ivory);border:1px solid var(--stone);border-top:4px solid var(--red);padding:36px 28px;border-radius:3px;}
.ins-step-card .snum{font-family:'Cormorant Garamond',serif;font-size:52px;font-weight:700;color:var(--red);line-height:1;margin-bottom:14px;}
.ins-step-card h3{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:600;color:var(--slate);margin-bottom:12px;}
.ins-step-card p{font-size:14px;color:var(--mid);line-height:1.75;}
.ins-benefits-sec{padding:100px 0;background:var(--slate);}
.ins-benefits-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:56px;}
.ins-benefit{display:flex;gap:18px;align-items:flex-start;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);padding:26px 22px;border-radius:3px;transition:border-color .3s;}
.ins-benefit:hover{border-color:rgba(204,0,0,0.3);}
.ins-benefit-icon{font-size:26px;flex-shrink:0;margin-top:2px;}
.ins-benefit h4{font-size:15px;font-weight:600;color:#fff;margin-bottom:6px;}
.ins-benefit p{font-size:13px;color:rgba(255,255,255,0.52);line-height:1.65;}

/* ─── FAQ ─── */
.faq-section{padding:100px 0;background:var(--ivory);}
.faq-list{max-width:800px;margin:56px auto 0;}
.faq-item{border-bottom:1px solid var(--stone);}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:22px 0;cursor:pointer;gap:16px;user-select:none;}
.faq-q h4{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:var(--slate);}
.faq-icon{width:28px;height:28px;border:1.5px solid var(--red);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--red);font-size:18px;flex-shrink:0;transition:transform .25s,background .25s;}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--red);color:#fff;}
.faq-a{font-size:15px;line-height:1.8;color:var(--mid);max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s;}
.faq-item.open .faq-a{max-height:400px;padding-bottom:22px;}

/* ─── ABOUT PAGE ─── */
.about-story{padding:100px 0;background:var(--ivory);}
.about-story-grid{display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:center;}
.story-img{width:100%;height:520px;object-fit:cover;border-radius:4px;display:block;}
.story-stats{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:32px;}
.stat-box{background:var(--ivory-dark);border:1px solid var(--stone);padding:22px 20px;border-radius:3px;text-align:center;}
.stat-box .n{font-family:'Cormorant Garamond',serif;font-size:42px;font-weight:700;color:var(--red);line-height:1;}
.stat-box small{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--mid);}
.certs-section{padding:80px 0;background:var(--slate);}
.certs-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px;margin-top:48px;}
.cert-card{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);padding:28px 20px;border-radius:3px;text-align:center;transition:border-color .3s,background .3s;}
.cert-card:hover{border-color:rgba(204,0,0,0.3);background:rgba(204,0,0,0.06);}
.cert-card .icon{font-size:32px;margin-bottom:12px;}
.cert-card h4{font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#fff;margin-bottom:6px;}
.cert-card p{font-size:12px;color:rgba(255,255,255,0.45);}

/* ─── CONTACT PAGE ─── */
.contact-section{padding:100px 0;background:var(--ivory);}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;}
.contact-info h2{font-family:'Cormorant Garamond',serif;font-size:clamp(30px,4vw,48px);font-weight:600;color:var(--slate);margin-bottom:20px;}
.contact-info h2 em{color:var(--red);font-style:italic;}
.contact-info > p{font-size:16px;color:var(--mid);line-height:1.8;}
.contact-details{margin-top:36px;display:flex;flex-direction:column;gap:22px;}
.cd-item{display:flex;gap:16px;align-items:flex-start;}
.cd-icon{width:46px;height:46px;background:rgba(204,0,0,0.09);border:1px solid rgba(204,0,0,0.2);border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.cd-text strong{display:block;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--slate);margin-bottom:5px;}
.cd-text a,.cd-text span{font-size:15px;color:var(--mid);text-decoration:none;line-height:1.65;transition:color .2s;display:block;}
.cd-text a:hover{color:var(--red);}
.hours-box{margin-top:40px;border:1px solid var(--stone);border-radius:4px;overflow:hidden;}
.hours-box-head{background:var(--slate);padding:14px 20px;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.6);}
.ht-row{display:flex;justify-content:space-between;padding:12px 20px;font-size:13px;border-bottom:1px solid var(--stone);}
.ht-row:last-child{border-bottom:none;}
.ht-row:nth-child(even){background:var(--ivory-dark);}
.ht-day{font-weight:600;color:var(--slate);}
.ht-time{color:var(--mid);}
.contact-form-box{background:var(--ivory-dark);border:1px solid var(--stone);padding:44px 40px;border-radius:4px;}
.contact-form-box h3{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:600;color:var(--slate);margin-bottom:8px;}
.contact-form-box > p{font-size:14px;color:var(--mid);margin-bottom:28px;}
.form-light .form-field label{color:rgba(17,17,17,0.5);font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;}
.form-light .form-field input,
.form-light .form-field select,
.form-light .form-field textarea{background:#fff;border:1px solid var(--stone);color:var(--text);}
.form-light .form-field input::placeholder,
.form-light .form-field textarea::placeholder{color:rgba(17,17,17,0.3);}
.form-light .form-field input:focus,
.form-light .form-field select:focus,
.form-light .form-field textarea:focus{border-color:var(--red);outline:none;}
.form-light .form-field select option{background:#fff;color:var(--text);}
.form-light .form-submit{background:var(--red);color:#fff;}
.form-light .form-submit:hover{background:var(--red-light);}
.form-light .form-field{margin-bottom:0;}

/* ─── FOOTER ─── */
footer{background:#0a0a0a;padding:72px 0 0;}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:60px;padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,0.07);}
.foot-brand .logo{margin-bottom:18px;}
.foot-brand p{font-size:14px;color:rgba(255,255,255,0.38);line-height:1.85;max-width:280px;}
.foot-lic{display:inline-block;background:rgba(204,0,0,0.12);border:1px solid rgba(204,0,0,0.25);padding:5px 13px;border-radius:2px;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(204,0,0,0.75);margin-top:16px;}
.foot-col h4{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;font-weight:700;color:rgba(255,255,255,0.25);margin-bottom:20px;}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:10px;}
.foot-col ul a{font-size:14px;color:rgba(255,255,255,0.46);text-decoration:none;transition:color .2s;display:flex;align-items:center;gap:8px;}
.foot-col ul a::before{content:'—';font-size:10px;color:var(--red);opacity:.6;}
.foot-col ul a:hover{color:var(--ivory);}
.foot-contact-item{display:flex;gap:11px;align-items:flex-start;margin-bottom:14px;}
.fc-ico{color:var(--red);font-size:14px;flex-shrink:0;margin-top:1px;}
.fc-txt a,.fc-txt span{font-size:14px;color:rgba(255,255,255,0.45);text-decoration:none;line-height:1.65;transition:color .2s;}
.fc-txt a:hover{color:var(--ivory);}
.foot-bottom{padding:22px 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;}
.foot-bottom p{font-size:12.5px;color:rgba(255,255,255,0.22);}
.foot-bottom a{color:rgba(204,0,0,0.5);text-decoration:none;transition:color .2s;}
.foot-bottom a:hover{color:var(--red);}

/* ─── FLOATING CALL BUTTON ─── */
.float-call{position:fixed;bottom:28px;right:28px;z-index:998;display:flex;align-items:center;gap:10px;background:var(--red);color:#fff;text-decoration:none;padding:14px 22px;border-radius:50px;box-shadow:0 8px 32px rgba(204,0,0,0.4);font-family:'DM Sans',sans-serif;font-size:14px;font-weight:700;letter-spacing:.5px;transition:background .2s,transform .2s;}
.float-call:hover{background:var(--red-light);transform:scale(1.04);}

/* ─── ANIMATIONS ─── */
@keyframes slideRight{from{opacity:0;transform:translateX(-32px);}to{opacity:1;transform:translateX(0);}}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}
@keyframes scrollPulse{0%,100%{opacity:.6;transform:scaleY(1);}50%{opacity:1;transform:scaleY(1.2);}}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .75s ease,transform .75s ease;}
.reveal.in{opacity:1;transform:none;}

/* ─── RESPONSIVE ─── */
@media(max-width:1100px){
  .hero-grid,.about-grid,.wu-layout,.video-layout,.cta-inner,.foot-grid,
  .ins-callout-grid,.srv-detail-grid,.about-story-grid,.contact-grid{grid-template-columns:1fr;gap:48px;}
  .hero-stats-card{display:none;}
  .srv-grid{grid-template-columns:1fr 1fr;}
  .test-grid{grid-template-columns:1fr 1fr;}
  .proc-steps{grid-template-columns:1fr 1fr;gap:40px;}
  .proc-steps::after{display:none;}
  .gal-grid{grid-template-columns:1fr 1fr;grid-auto-rows:auto;}
  .gi-1,.gi-2,.gi-3,.gi-4,.gi-5,.gi-6,.gi-7,.gi-8,.gi-9,.gi-10,.gi-11{grid-column:span 1;height:220px;}
  .about-float{position:static;margin-top:24px;width:100%;}
  .wu-accent-card{position:static;margin-bottom:24px;}
  .areas-inner{grid-template-columns:1fr;}
  .srv-head{grid-template-columns:1fr;gap:24px;}
  .ba-grid{grid-template-columns:1fr;}
  .ins-steps-grid{grid-template-columns:1fr 1fr;}
  .ins-benefits-grid{grid-template-columns:1fr 1fr;}
  .certs-grid{grid-template-columns:repeat(3,1fr);}
  .srv-detail-grid.reverse{direction:ltr;}
}
@media(max-width:768px){
  .nav-toggle{display:flex;}
  .nav-menu{display:none;position:absolute;top:80px;left:0;right:0;background:var(--white);flex-direction:column;padding:16px;border-top:1px solid var(--stone);box-shadow:0 16px 40px rgba(17,17,17,0.1);gap:0;}
  .nav-menu.open{display:flex;}
  .nav-menu > li > a{padding:12px 14px;border-radius:3px;width:100%;}
  .dropdown{position:static;display:none !important;box-shadow:none;border:none;border-top:none;background:rgba(17,17,17,0.04);border-radius:3px;margin:4px 0;}
  .has-dropdown.open .dropdown{display:block !important;}
  .topstrip-links{display:none;}
  .proof-inner{grid-template-columns:1fr 1fr;border-right:none;}
  .proof-cell:nth-child(2n){border-right:none;}
  .srv-grid,.test-grid{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr 1fr;gap:40px;}
  .container{padding:0 20px;}
  .hero{min-height:640px;height:auto;padding-top:120px;}
  .hero-inner{padding-bottom:70px;}
  .hero-actions{flex-direction:column;align-items:flex-start;}
  .display{font-size:clamp(32px,10vw,48px);}
  .areas-tags{gap:10px;}
  .area-chip{padding:9px 14px;font-size:12px;}
  .ba-images{grid-template-columns:1fr;}
  .ba-img{height:220px;}
  .phone-display a{font-size:32px;}
  .ins-steps-grid{grid-template-columns:1fr;}
  .ins-benefits-grid{grid-template-columns:1fr;}
  .certs-grid{grid-template-columns:1fr 1fr;}
  .story-stats{grid-template-columns:1fr 1fr;}
  .float-call{bottom:20px;right:16px;padding:12px 18px;font-size:13px;}
  .ins-strip p{font-size:12px;}
}
