/* ── BASE ── */
*{margin:0;padding:0;box-sizing:border-box;}
:root{--milk:#FDF7F2;--obsidian:#111111;--flash:#F4CF35;--slate:#F4EEE9;--footer:#0A0A0A;--mid:#1A1A1A;}
html{scroll-behavior:smooth;}
body{background:var(--milk);font-family:'DM Sans',sans-serif;color:var(--obsidian);overflow-x:hidden;}
a{text-decoration:none;color:inherit;}
img{display:block;width:100%;height:100%;object-fit:cover;}

/* ── UTILS ── */
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--flash);}
.eyebrow-line{width:7px;height:7px;background:var(--flash);flex-shrink:0;transform:rotate(45deg);}
.eyebrow.dark{color:var(--obsidian);}
.eyebrow.dark .eyebrow-line{background:var(--obsidian);}
.btn{display:inline-flex;align-items:center;gap:8px;font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:13px;letter-spacing:0.09em;text-transform:uppercase;padding:13px 26px;border-radius:20px 0 20px 20px;border:1.5px solid;cursor:pointer;transition:all 0.18s;white-space:nowrap;position:relative;overflow:hidden;}
.btn-obsidian{background:var(--obsidian);color:var(--milk);border-color:var(--obsidian);}
.btn-obsidian:hover{background:#222;border-color:#222;}
.btn-flash{background:var(--flash);color:var(--obsidian);border-color:var(--flash);}
.btn-flash:hover{background:#e8c228;border-color:#e8c228;}
.btn-outline-light{background:transparent;color:var(--milk);border-color:rgba(253,247,242,0.5);}
.btn-outline-light:hover{border-color:var(--flash);color:var(--flash);}
.btn-outline-dark{background:transparent;color:var(--obsidian);border-color:var(--obsidian);}
.btn-outline-dark:hover{background:var(--obsidian);color:var(--milk);}
.star{width:14px;height:14px;fill:var(--flash);}
.fade-up{opacity:0;transform:translateY(28px);transition:opacity 0.6s ease,transform 0.6s ease;}
.fade-up.visible{opacity:1;transform:translateY(0);}

/* ── LOGO SIZING ── */
.logo-svg{height:26px;width:auto;display:block;}
.logo-footer{height:30px;width:auto;display:block;}
.logo-cta{height:22px;width:auto;display:block;opacity:0.45;margin-bottom:18px;}
.jmark-icon{width:32px;height:auto;display:block;}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;transition:background 0.3s,box-shadow 0.3s;}
nav.scrolled{background:var(--milk);box-shadow:0 1px 0 rgba(17,17,17,0.1);}
.nav-inner{display:flex;align-items:stretch;height:68px;}
.nav-logo{display:flex;align-items:center;padding:0 28px;background:var(--obsidian);flex-shrink:0;text-decoration:none;}
.nav-logo .logo-light{display:none;}
nav.scrolled .nav-logo .logo-svg.logo-white{display:none;}
nav.scrolled .nav-logo .logo-light{display:block;}
.nav-links{display:flex;align-items:stretch;flex:1;}
.nav-item{position:relative;display:flex;align-items:center;}
.nav-link{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:13px;letter-spacing:0.1em;text-transform:uppercase;color:var(--milk);padding:0 18px;height:100%;display:flex;align-items:center;gap:5px;transition:color 0.2s;}
nav.scrolled .nav-link{color:var(--obsidian);}
.nav-link:hover{color:var(--flash)!important;}
.chev{width:10px;height:10px;stroke:currentColor;stroke-width:2;fill:none;transition:transform 0.2s;}
.nav-item:hover .chev{transform:rotate(180deg);}
.dropdown{position:absolute;top:100%;left:0;background:var(--obsidian);min-width:230px;opacity:0;pointer-events:none;transform:translateY(-6px);transition:opacity 0.2s,transform 0.2s;border-top:2px solid var(--flash);z-index:100;}
.nav-item:hover .dropdown{opacity:1;pointer-events:all;transform:translateY(0);}
.dropdown a{display:block;font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:rgba(253,247,242,0.7);padding:14px 20px;border-bottom:1px solid rgba(255,255,255,0.04);transition:color 0.15s,background 0.15s;}
.dropdown a:hover{color:var(--flash);background:rgba(255,255,255,0.04);}
.nav-cta{margin-left:auto;display:flex;align-items:center;padding:0 28px;background:var(--flash);font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:13px;letter-spacing:0.1em;text-transform:uppercase;color:var(--obsidian);cursor:pointer;transition:background 0.2s;border:none;position:relative;overflow:hidden;}
.nav-cta:hover{background:#e8c228;}
.nav-phone{display:flex;align-items:center;gap:10px;padding:0 24px;text-decoration:none;border-left:1px solid rgba(255,255,255,0.1);transition:background 0.2s;flex-shrink:0;}
.nav-phone:hover{background:rgba(255,255,255,0.05);}
nav.scrolled .nav-phone{border-left-color:rgba(17,17,17,0.1);}
nav.scrolled .nav-phone:hover{background:rgba(17,17,17,0.04);}
.nav-phone-icon{width:28px;height:28px;background:rgba(244,207,53,0.15);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
nav.scrolled .nav-phone-icon{background:rgba(17,17,17,0.07);}
.nav-phone-icon svg{width:12px;height:12px;fill:var(--flash);}
nav.scrolled .nav-phone-icon svg{fill:var(--obsidian);}
.nav-phone-label{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,0.4);line-height:1;display:block;}
nav.scrolled .nav-phone-label{color:rgba(17,17,17,0.4);}
.nav-phone-num{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:800;letter-spacing:0.04em;color:var(--milk);line-height:1.2;margin-top:2px;display:block;}
nav.scrolled .nav-phone-num{color:var(--obsidian);}

/* ── FLUID TYPOGRAPHY — scales up on large screens 1280px → 1920px ── */
@media(min-width:1280px){
  .hero h1{font-size:clamp(52px,6.5vw,110px);}
  .hero-sub{font-size:clamp(17px,1.4vw,22px);max-width:clamp(480px,38vw,640px);}
  .section-head h2{font-size:clamp(36px,3.2vw,64px);}
  .why-right h2{font-size:clamp(32px,3.2vw,58px);}
  .area h2{font-size:clamp(32px,3.2vw,56px);}
  .quote-left h2{font-size:clamp(30px,3vw,52px);}
  .cta-banner h2{font-size:clamp(36px,3.5vw,68px);}
  .stat-num{font-size:clamp(34px,3vw,54px);}
  .stat-label{font-size:clamp(14px,0.8vw,13px);}
  .hero-panel-label h3{font-size:clamp(16px,1.4vw,22px);}
  .mat-info h3{font-size:clamp(15px,1.2vw,20px);}
  .p-body h4{font-size:clamp(13px,1vw,16px);}
  .proof-text h4{font-size:clamp(13px,1vw,16px);}
  .nav-link{font-size:clamp(13px,1vw,15px);}
  .btn{font-size:clamp(13px,1vw,15px);padding:clamp(13px,1.1vw,17px) clamp(26px,2vw,36px);}
}

/* ── HERO ── */
.hero{height:100svh;min-height:520px;max-height:900px;position:relative;overflow:hidden;}
.hero-bg{position:absolute;inset:0;}
.hero-bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.04);animation:heroZoom 12s ease-out forwards;}
@keyframes heroZoom{from{transform:scale(1.04);}to{transform:scale(1);}}
.hero-bg-overlay{position:absolute;inset:0;background:linear-gradient(105deg,rgba(0,0,0,0.82) 0%,rgba(0,0,0,0.5) 50%,rgba(0,0,0,0.2) 100%);}
.hero-content{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:0 72px clamp(32px,5vh,80px);max-width:820px;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--flash);margin-bottom:20px;}
.hero-eyebrow span{width:7px;height:7px;background:var(--flash);transform:rotate(45deg);flex-shrink:0;}
.hero h1{font-family:'Montserrat',sans-serif;font-weight:900;font-size:clamp(40px,6vw,80px);letter-spacing:-0.025em;text-transform:uppercase;color:var(--milk);line-height:0.95;margin-bottom:24px;}
.hero h1 em{font-style:normal;color:var(--flash);}
.hero-sub{font-family:'DM Sans',sans-serif;font-size:17px;font-weight:300;color:rgba(253,247,242,0.72);line-height:1.7;max-width:480px;margin-bottom:36px;}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center;}
.hero-right{position:absolute;right:0;top:0;bottom:0;width:35%;display:flex;flex-direction:column;}
.hero-right-panel{flex:1;position:relative;overflow:hidden;border-left:4px solid var(--flash);cursor:pointer;}
.hero-right-panel img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 0.7s ease;}
.hero-right-panel:hover img{transform:scale(1.05);}
.hero-right-panel-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.78) 0%,rgba(0,0,0,0.2) 60%,transparent 100%);}
.hero-panel-label{position:absolute;bottom:0;left:0;right:0;padding:20px 24px;}
.hero-panel-label .eyebrow{margin-bottom:6px;}
.hero-panel-label h3{font-family:'Montserrat',sans-serif;font-weight:900;font-size:16px;text-transform:uppercase;letter-spacing:-0.01em;color:var(--milk);margin-bottom:10px;}
.hero-panel-label a{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:rgba(253,247,242,0.6);border-bottom:1px solid rgba(244,207,53,0.4);padding-bottom:1px;transition:color 0.2s;}
.hero-panel-label a:hover{color:var(--flash);}

/* ── STAT STRIP ── */
.stat-strip{background:var(--obsidian);display:grid;grid-template-columns:repeat(4,1fr);border-top:3px solid var(--flash);}
.stat-item{padding:24px 32px;border-right:1px solid rgba(255,255,255,0.06);}
.stat-item:last-child{border-right:none;}
.stat-num{font-family:'Montserrat',sans-serif;font-weight:900;font-size:34px;letter-spacing:-0.025em;color:var(--flash);line-height:1;}
.stat-label{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.38);margin-top:4px;}

/* ── MATERIALS GRID ── */
.materials{background:var(--milk);padding:96px 0 0;}
.section-head{padding:0 64px 48px;display:flex;align-items:flex-end;justify-content:space-between;gap:32px;}
.section-head h2{font-family:'Montserrat',sans-serif;font-weight:900;font-size:clamp(28px,4vw,48px);letter-spacing:-0.02em;text-transform:uppercase;line-height:1.0;}
.section-head h2.light{color:var(--milk);}
.mat-grid{display:grid;grid-template-columns:repeat(6,1fr);height:480px;}
.mat-card{position:relative;overflow:hidden;cursor:pointer;}
.mat-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 0.65s ease;}
.mat-card:hover img{transform:scale(1.06);}
.mat-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.82) 0%,rgba(0,0,0,0.1) 55%,transparent 100%);transition:background 0.3s;}
.mat-card:hover .mat-overlay{background:linear-gradient(to top,rgba(0,0,0,0.88) 0%,rgba(0,0,0,0.3) 60%,transparent 100%);}
.mat-info{position:absolute;bottom:0;left:0;right:0;padding:18px 16px 20px;}
.mat-tag{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--flash);margin-bottom:5px;}
.mat-info h3{font-family:'Montserrat',sans-serif;font-weight:900;font-size:15px;text-transform:uppercase;letter-spacing:-0.01em;color:var(--milk);line-height:1.1;margin-bottom:8px;}
.mat-link{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:rgba(253,247,242,0.5);opacity:0;transform:translateY(4px);transition:opacity 0.2s,transform 0.2s,color 0.2s;display:inline-flex;align-items:center;gap:5px;}
.mat-card:hover .mat-link{opacity:1;transform:translateY(0);color:var(--flash);}

/* ── ABOUT / WHY US ── */
.why{background:var(--milk);padding:96px 64px;}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;margin-top:48px;}
.why-left img{width:100%;height:480px;object-fit:cover;border-radius:0 0 6px 6px;}
.why-left{position:relative;}
.why-img-badge{position:absolute;bottom:24px;right:-24px;background:var(--flash);padding:20px 24px;}
.why-img-badge .num{font-family:'Montserrat',sans-serif;font-weight:900;font-size:36px;letter-spacing:-0.02em;color:var(--obsidian);line-height:1;}
.why-img-badge .lbl{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--obsidian);opacity:0.65;margin-top:2px;}
.why-right h2{font-family:'Montserrat',sans-serif;font-weight:900;font-size:clamp(28px,3.5vw,44px);letter-spacing:-0.02em;text-transform:uppercase;color:var(--obsidian);line-height:1.05;margin:16px 0 12px;}
.why-right .lead{font-family:'DM Sans',sans-serif;font-size:16px;font-weight:300;color:rgba(17,17,17,0.6);line-height:1.75;margin-bottom:36px;}
.proof-points{display:flex;flex-direction:column;gap:0;}
.proof-item{display:grid;grid-template-columns:48px 1fr;gap:16px;padding:20px 0;border-bottom:1px solid rgba(17,17,17,0.08);align-items:start;}
.proof-item:first-child{border-top:1px solid rgba(17,17,17,0.08);}
.proof-icon{width:40px;height:40px;background:rgba(244,207,53,0.18);border:1px solid rgba(244,207,53,0.4);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.proof-icon svg{width:18px;height:18px;stroke:var(--obsidian);stroke-width:1.5;fill:none;}
.proof-text h4{font-family:'Montserrat',sans-serif;font-weight:800;font-size:13px;text-transform:uppercase;color:var(--obsidian);letter-spacing:0.01em;margin-bottom:4px;}
.proof-text p{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:300;color:rgba(17,17,17,0.55);line-height:1.6;}

/* ── PORTFOLIO ── */
.portfolio{background:var(--slate);padding:96px 0;}
.portfolio .section-head{padding:0 64px 40px;}
.portfolio-filter{display:flex;gap:8px;padding:0 64px 40px;flex-wrap:wrap;}
.filter-btn{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;padding:7px 16px;border:1px solid rgba(17,17,17,0.2);background:transparent;color:rgba(17,17,17,0.5);cursor:pointer;border-radius:2px;transition:all 0.15s;}
.filter-btn.active,.filter-btn:hover{background:var(--flash);color:var(--obsidian);border-color:var(--flash);}
.portfolio-masonry{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:260px 260px;gap:3px;padding:0 0 3px;}
.port-cell{position:relative;overflow:hidden;cursor:pointer;}
.port-cell.tall{grid-row:span 2;}
.port-cell img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 0.6s ease;}
.port-cell:hover img{transform:scale(1.04);}
.port-overlay{position:absolute;inset:0;background:rgba(0,0,0,0);transition:background 0.3s;}
.port-cell:hover .port-overlay{background:rgba(17,17,17,0.3);}
.port-tag{position:absolute;bottom:14px;left:14px;background:rgba(0,0,0,0.6);font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--milk);padding:5px 10px;opacity:0;transition:opacity 0.2s;}
.port-cell:hover .port-tag{opacity:1;}
.portfolio-cta{display:flex;justify-content:center;padding:40px 0 0;}

/* ── BRANDS ── */
.brands{background:var(--slate);padding:48px 64px;}
.brands-inner{display:flex;align-items:center;gap:0;}
.brands-label{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:rgba(17,17,17,0.4);white-space:nowrap;padding-right:40px;border-right:1px solid rgba(17,17,17,0.12);flex-shrink:0;}
.brands-logos{display:flex;align-items:center;gap:40px;padding-left:40px;flex-wrap:wrap;}
.brand-logo-item{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:800;letter-spacing:0.08em;text-transform:uppercase;color:rgba(17,17,17,0.35);transition:color 0.2s;}
.brand-logo-item:hover{color:var(--obsidian);}

/* ── PROCESS ── */
.process{background:var(--milk);padding:96px 64px;}
.process-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;margin-top:48px;}
.process-steps{display:flex;flex-direction:column;}
.p-step{display:grid;grid-template-columns:56px 1fr;gap:20px;padding:24px 0;border-bottom:1px solid rgba(17,17,17,0.07);}
.p-step:first-child{border-top:1px solid rgba(17,17,17,0.07);}
.p-num{font-family:'Montserrat',sans-serif;font-weight:900;font-size:14px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px;}
.p-num.active{background:var(--obsidian);color:var(--flash);}
.p-num.inactive{background:var(--slate);color:rgba(17,17,17,0.3);}
.p-body h4{font-family:'Montserrat',sans-serif;font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:0.02em;margin-bottom:5px;}
.p-body p{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:300;color:rgba(17,17,17,0.55);line-height:1.65;}
.process-image{position:relative;height:520px;border-radius:0 0 6px 6px;overflow:hidden;}
.process-image img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}

/* ── GOOGLE REVIEWS ── */
.reviews{background:var(--milk);padding:96px 64px;}
.reviews-top{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:48px;flex-wrap:wrap;gap:24px;}
.reviews-score{display:flex;align-items:center;gap:18px;}
.score-big{font-family:'Montserrat',sans-serif;font-weight:900;font-size:64px;letter-spacing:-0.03em;color:var(--obsidian);line-height:1;}
.score-meta{display:flex;flex-direction:column;gap:5px;}
.score-stars{display:flex;gap:3px;}
.score-count{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:rgba(17,17,17,0.4);}
.g-badge{display:flex;align-items:center;gap:8px;border:1px solid rgba(17,17,17,0.15);padding:10px 16px;}
.g-badge-text{font-family:'DM Sans',sans-serif;font-size:12px;color:rgba(17,17,17,0.5);}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;}
.r-card{background:rgba(17,17,17,0.04);padding:28px 24px;display:flex;flex-direction:column;gap:14px;}
.r-card.featured{background:var(--obsidian);border-top:none;}
.r-card.featured .r-text,.r-card.featured .r-name{color:var(--milk)!important;}
.r-card.featured .r-ago,.r-card.featured .r-via{color:rgba(253,247,242,0.4)!important;}
.r-card-top{display:flex;align-items:center;justify-content:space-between;}
.r-reviewer{display:flex;align-items:center;gap:10px;}
.r-init{width:36px;height:36px;border-radius:50%;background:var(--obsidian);display:flex;align-items:center;justify-content:center;font-family:'Montserrat',sans-serif;font-weight:900;font-size:12px;color:var(--flash);flex-shrink:0;}
.r-card.featured .r-init{background:var(--flash);color:var(--obsidian);}
.r-name{font-family:'Montserrat',sans-serif;font-weight:800;font-size:12px;text-transform:uppercase;color:var(--obsidian);}
.r-ago{font-family:'DM Sans',sans-serif;font-size:14px;font-weight:300;color:rgba(17,17,17,0.4);}
.r-stars{display:flex;gap:2px;}
.r-star{width:13px;height:13px;fill:var(--flash);}
.r-card.featured .r-star{fill:var(--flash);}
.r-text{font-family:'DM Sans',sans-serif;font-size:16px;font-weight:300;line-height:1.72;color:rgba(17,17,17,0.7);}
.r-via{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:rgba(17,17,17,0.3);}
.reviews-footer{margin-top:28px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;}
.reviews-api-note{font-family:'DM Sans',sans-serif;font-size:12px;color:rgba(17,17,17,0.4);}
.reviews-api-note code{font-family:monospace;font-size:14px;background:rgba(17,17,17,0.07);padding:2px 6px;border-radius:2px;color:var(--obsidian);}

/* ── SERVICE AREA ── */
.area{background:var(--slate);padding:96px 64px;}
.area-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.area h2{font-family:'Montserrat',sans-serif;font-weight:900;font-size:clamp(28px,3.5vw,44px);letter-spacing:-0.02em;text-transform:uppercase;margin:16px 0 12px;}
.area .lead{font-family:'DM Sans',sans-serif;font-size:15px;font-weight:300;color:rgba(17,17,17,0.6);line-height:1.75;margin-bottom:32px;}
.states{display:grid;grid-template-columns:1fr 1fr;gap:2px;margin-bottom:32px;}
.state-card{background:var(--obsidian);padding:20px 22px;}
.state-name{font-family:'Montserrat',sans-serif;font-weight:900;font-size:15px;text-transform:uppercase;color:var(--milk);}
.state-abbr{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-top:3px;}
.state-card.primary .state-name{color:var(--flash);}
.area-cities{display:flex;flex-direction:column;gap:4px;}
.area-cities-label{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:rgba(17,17,17,0.4);margin-bottom:8px;}
.city-links{display:flex;flex-wrap:wrap;gap:6px;}
.city-link{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:rgba(17,17,17,0.5);border:1px solid rgba(17,17,17,0.12);padding:5px 10px;transition:all 0.15s;}
.city-link:hover{background:var(--obsidian);color:var(--flash);border-color:var(--obsidian);}
.area-image{position:relative;height:480px;overflow:hidden;border-radius:0 0 6px 6px;}
.area-image img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}

/* ── INLINE QUOTE FORM ── */
.quote-section{background:var(--obsidian);padding:96px 64px;}
.quote-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:start;margin-top:48px;}
.quote-left h2{font-family:'Montserrat',sans-serif;font-weight:900;font-size:clamp(26px,3.5vw,42px);letter-spacing:-0.02em;text-transform:uppercase;color:var(--milk);line-height:1.05;margin:16px 0 12px;}
.quote-left p{font-family:'DM Sans',sans-serif;font-size:15px;font-weight:300;color:rgba(253,247,242,0.55);line-height:1.75;margin-bottom:32px;}
.contact-facts{display:flex;flex-direction:column;gap:20px;margin-top:32px;}
.cf-item{display:flex;align-items:flex-start;gap:14px;}
.cf-icon{width:36px;height:36px;background:rgba(244,207,53,0.1);border:1px solid rgba(244,207,53,0.2);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.cf-icon svg{width:16px;height:16px;stroke:var(--flash);stroke-width:1.5;fill:none;}
.cf-text{font-family:'DM Sans',sans-serif;font-size:14px;font-weight:400;color:rgba(253,247,242,0.7);line-height:1.5;}
.cf-text strong{display:block;font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-bottom:2px;}
.hours-grid{display:grid;grid-template-columns:1fr 1fr;gap:3px;margin-top:8px;}
.hours-row{background:rgba(255,255,255,0.04);padding:8px 12px;display:flex;justify-content:space-between;}
.hours-day{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:rgba(255,255,255,0.4);}
.hours-time{font-family:'DM Sans',sans-serif;font-size:14px;font-weight:300;color:rgba(255,255,255,0.6);}
.q-form-card{background:var(--milk);padding:36px 32px;border-radius:0 0 6px 6px;}
.q-form-card h3{font-family:'Montserrat',sans-serif;font-weight:900;font-size:18px;text-transform:uppercase;letter-spacing:-0.01em;margin-bottom:4px;}
.q-form-card .sub{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:300;color:rgba(17,17,17,0.5);margin-bottom:24px;}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.fg{display:flex;flex-direction:column;gap:5px;}
.fg.full{grid-column:1/-1;}
.fl{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:rgba(17,17,17,0.4);}
.fi,.fs,.fta{font-family:'DM Sans',sans-serif;font-size:14px;color:var(--obsidian);background:var(--slate);border:1.5px solid transparent;border-radius:3px;padding:14px 13px;outline:none;width:100%;transition:border-color 0.15s,background 0.15s;}
.fi:focus,.fs:focus,.fta:focus{border-color:var(--obsidian);background:white;}
.fs{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23111' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-color:var(--slate);}
.fs:focus{background-color:white;}
.fta{resize:vertical;min-height:88px;line-height:1.55;}
.f-submit{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;background:var(--obsidian);color:var(--milk);border:none;font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:14px;letter-spacing:0.09em;text-transform:uppercase;padding:15px;border-radius:20px 0 20px 20px;cursor:pointer;margin-top:8px;transition:background 0.2s;position:relative;overflow:hidden;}
.f-submit:hover{background:#222;}
.f-submit svg{width:16px;height:16px;stroke:var(--flash);stroke-width:2;fill:none;}
.f-note{font-family:'DM Sans',sans-serif;font-size:14px;font-weight:300;color:rgba(17,17,17,0.4);text-align:center;margin-top:10px;}
.q-success{display:none;flex-direction:column;align-items:center;gap:14px;padding:40px 20px;text-align:center;}
.q-success.show{display:flex;}
.q-success-icon{width:52px;height:52px;background:var(--flash);border-radius:50%;display:flex;align-items:center;justify-content:center;}
.q-success-icon svg{width:24px;height:24px;stroke:var(--obsidian);stroke-width:2.5;fill:none;}
.q-success h4{font-family:'Montserrat',sans-serif;font-weight:900;font-size:16px;text-transform:uppercase;}
.q-success p{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:300;color:rgba(17,17,17,0.55);line-height:1.65;}

/* ── CTA BANNER ── */
.cta-banner{background:var(--flash);padding:80px 64px;display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center;}
.cta-banner h2{font-family:'Montserrat',sans-serif;font-weight:900;font-size:clamp(26px,4vw,52px);letter-spacing:-0.025em;text-transform:uppercase;color:var(--obsidian);line-height:1.0;}
.cta-banner h2 em{font-style:normal;text-decoration:underline;text-underline-offset:5px;text-decoration-thickness:2px;}
.cta-actions{display:flex;flex-direction:column;gap:10px;align-items:flex-end;}

/* ── FOOTER ── */
footer{background:var(--footer);padding:64px 64px 32px;}
.footer-top{display:grid;grid-template-columns:260px 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,0.06);}
.footer-brand{display:flex;flex-direction:column;gap:14px;}
.footer-tagline{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:300;color:rgba(255,255,255,0.35);line-height:1.65;}
.footer-col h4{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,0.25);margin-bottom:16px;}
.footer-col a{display:block;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:300;color:rgba(255,255,255,0.45);padding:3px 0;transition:color 0.15s;}
.footer-col a:hover{color:var(--flash);}
.footer-local h4{margin-top:20px;}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:24px;flex-wrap:wrap;gap:8px;}
.footer-legal{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.18);}

/* ── FLOATING ACTIONS ── */
.fab-cluster{position:fixed;bottom:28px;right:28px;z-index:900;display:flex;flex-direction:column;align-items:flex-end;gap:12px;}
.fab-call{display:flex;align-items:center;gap:10px;background:var(--obsidian);color:var(--milk);padding:12px 18px 12px 14px;border-radius:20px 0 20px 20px;text-decoration:none;box-shadow:0 4px 24px rgba(0,0,0,0.28);transition:background 0.2s,transform 0.15s;}
.fab-call:hover{background:#222;transform:translateY(-2px);}
.fab-pulse{width:20px;height:20px;background:var(--flash);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;}
.fab-pulse::after{content:'';position:absolute;inset:-3px;border-radius:50%;background:var(--flash);opacity:0.3;animation:cring 2s ease-out infinite;}
@keyframes cring{0%{transform:scale(1);opacity:0.3;}100%{transform:scale(2.1);opacity:0;}}
.fab-pulse svg{width:10px;height:10px;fill:var(--obsidian);position:relative;z-index:1;}
.fab-call-inner{display:flex;flex-direction:column;}
.fab-call-lbl{font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:12px;letter-spacing:0.1em;text-transform:uppercase;}
.fab-call-num{font-family:'DM Sans',sans-serif;font-size:14px;font-weight:300;color:rgba(253,247,242,0.5);}
.fab-chat-btn{width:52px;height:52px;border-radius:50%;background:var(--flash);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(244,207,53,0.4);transition:transform 0.2s;}
.fab-chat-btn:hover{transform:scale(1.1);}
.fab-chat-btn svg{width:22px;height:22px;transition:opacity 0.15s;}
.ic-close{display:none;}
.fab-chat-btn.open .ic-chat{display:none;}
.fab-chat-btn.open .ic-close{display:block;}

/* ── QUOTE TAB ── */
.quote-tab{position:fixed;left:0;top:50%;transform:translateY(-50%) rotate(-90deg) translateX(-50%);transform-origin:left center;background:var(--flash);color:var(--obsidian);font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:14px;letter-spacing:0.14em;text-transform:uppercase;padding:8px 16px;border:none;cursor:pointer;z-index:800;border-radius:0 0 5px 5px;box-shadow:2px 0 12px rgba(0,0,0,0.12);}
.quote-tab:hover{background:#e8c228;}
.q-overlay{position:fixed;inset:0;background:rgba(17,17,17,0.55);z-index:850;opacity:0;pointer-events:none;transition:opacity 0.3s;}
.q-overlay.open{opacity:1;pointer-events:all;}
.q-drawer{position:fixed;left:0;top:0;bottom:0;width:400px;background:var(--milk);z-index:851;transform:translateX(-100%);transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);display:flex;flex-direction:column;overflow-y:auto;box-shadow:8px 0 48px rgba(0,0,0,0.2);}
.q-drawer.open{transform:translateX(0);}
.q-head{background:var(--obsidian);padding:32px 28px 24px;border-bottom:3px solid var(--flash);position:relative;flex-shrink:0;}
.q-head .eyebrow{margin-bottom:12px;}
.q-head h3{font-family:'Montserrat',sans-serif;font-weight:900;font-size:22px;text-transform:uppercase;letter-spacing:-0.02em;color:var(--milk);line-height:1.1;}
.q-head p{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:300;color:rgba(253,247,242,0.5);margin-top:8px;line-height:1.6;}
.q-close{position:absolute;top:18px;right:18px;background:rgba(255,255,255,0.09);border:none;width:30px;height:30px;border-radius:50%;cursor:pointer;color:rgba(255,255,255,0.6);font-size:17px;display:flex;align-items:center;justify-content:center;}
.q-close:hover{background:rgba(255,255,255,0.18);}
.q-form-inner{padding:24px 28px;display:flex;flex-direction:column;gap:16px;}
.qd-submit{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;background:var(--obsidian);color:var(--milk);border:none;font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:14px;letter-spacing:0.09em;text-transform:uppercase;padding:14px;border-radius:20px 0 20px 20px;cursor:pointer;margin-top:4px;transition:background 0.2s;position:relative;overflow:hidden;}
.qd-submit:hover{background:#222;}
.qd-submit svg{width:16px;height:16px;stroke:var(--flash);stroke-width:2;fill:none;}
.q-success{display:none;flex-direction:column;align-items:center;gap:14px;padding:40px 28px;text-align:center;}
.q-success.show{display:flex;}
.q-success-icon{width:52px;height:52px;background:var(--flash);border-radius:50%;display:flex;align-items:center;justify-content:center;}
.q-success-icon svg{width:24px;height:24px;stroke:var(--obsidian);stroke-width:2.5;fill:none;}
.q-success h4{font-family:'Montserrat',sans-serif;font-weight:900;font-size:16px;text-transform:uppercase;}
.q-success p{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:300;color:rgba(17,17,17,0.55);line-height:1.65;}

/* ── CHATBOT ── */
.chatbot{position:fixed;bottom:96px;right:28px;width:348px;background:var(--milk);border-radius:16px 0 16px 16px;box-shadow:0 20px 60px rgba(0,0,0,0.22);z-index:899;display:flex;flex-direction:column;overflow:hidden;transform:scale(0.9) translateY(20px);transform-origin:bottom right;opacity:0;pointer-events:none;transition:transform 0.25s ease,opacity 0.25s ease;max-height:500px;}
.chatbot.open{transform:scale(1) translateY(0);opacity:1;pointer-events:all;}
.cb-head{background:var(--obsidian);padding:14px 18px;display:flex;align-items:center;gap:12px;border-bottom:2px solid var(--flash);flex-shrink:0;}
.cb-avatar{width:34px;height:34px;background:var(--flash);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Montserrat',sans-serif;font-weight:900;font-size:13px;color:var(--obsidian);flex-shrink:0;}
.cb-hinfo h4{font-family:'Montserrat',sans-serif;font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:0.03em;color:var(--milk);}
.cb-hinfo p{font-family:'DM Sans',sans-serif;font-size:14px;color:rgba(255,255,255,0.4);font-weight:300;}
.cb-online{width:8px;height:8px;background:#4ade80;border-radius:50%;margin-left:auto;}
.cb-msgs{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;min-height:180px;}
.cb-msg{max-width:88%;display:flex;flex-direction:column;gap:2px;}
.cb-msg.bot{align-self:flex-start;}
.cb-msg.user{align-self:flex-end;}
.cb-bubble{padding:9px 13px;font-family:'DM Sans',sans-serif;font-size:13px;line-height:1.55;}
.cb-msg.bot .cb-bubble{background:var(--slate);color:var(--obsidian);border-radius:0 10px 10px 10px;}
.cb-msg.user .cb-bubble{background:var(--obsidian);color:var(--milk);border-radius:10px 0 10px 10px;}
.cb-time{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:rgba(17,17,17,0.3);padding:0 2px;}
.cb-msg.user .cb-time{text-align:right;}
.cb-qr{display:flex;flex-wrap:wrap;gap:6px;padding:4px 16px 10px;}
.cb-qr button{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:0.07em;text-transform:uppercase;padding:6px 12px;border:1.5px solid rgba(17,17,17,0.2);border-radius:20px 0 20px 20px;background:transparent;cursor:pointer;color:var(--obsidian);transition:all 0.15s;white-space:nowrap;}
.cb-qr button:hover{background:var(--obsidian);color:var(--milk);border-color:var(--obsidian);}
.cb-typing{display:none;padding:4px 16px;}
.cb-typing.show{display:flex;gap:4px;align-items:center;}
.cb-typing span{width:6px;height:6px;border-radius:50%;background:rgba(17,17,17,0.25);animation:blink 1.2s infinite;}
.cb-typing span:nth-child(2){animation-delay:0.2s;}
.cb-typing span:nth-child(3){animation-delay:0.4s;}
@keyframes blink{0%,80%,100%{opacity:0.3;}40%{opacity:1;}}
.cb-input-row{display:flex;gap:8px;padding:10px 14px;border-top:1px solid rgba(17,17,17,0.07);flex-shrink:0;}
.cb-input{flex:1;font-family:'DM Sans',sans-serif;font-size:13px;padding:9px 12px;border:1.5px solid rgba(17,17,17,0.12);border-radius:6px;background:white;color:var(--obsidian);outline:none;}
.cb-input:focus{border-color:var(--obsidian);}
.cb-send{width:36px;height:36px;background:var(--flash);border:none;border-radius:20px 0 20px 20px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.cb-send:hover{background:#e8c228;}
.cb-send svg{width:14px;height:14px;fill:var(--obsidian);}

/* ══════════════════════════════════════════════════════
   RESPONSIVE SYSTEM
   Breakpoints:
   --xs  : 0–479px      (small phones)
   --sm  : 480–767px    (large phones)
   --md  : 768–1023px   (tablets)
   --lg  : 1024–1279px  (small laptops)
   --xl  : 1280–1535px  (desktop) ← base styles above
   --2xl : 1536–1919px  (wide desktop)
   --3xl : 1920px+      (ultra-wide / 4K)
══════════════════════════════════════════════════════ */

/* ─── MOBILE HAMBURGER (hidden on desktop) ─── */
.nav-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;margin-left:8px;flex-shrink:0;}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--milk);border-radius:2px;transition:transform 0.25s ease,opacity 0.25s ease;}
nav.scrolled .nav-hamburger span{background:var(--obsidian);}
.nav-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-hamburger.open span:nth-child(2){opacity:0;}
.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* Mobile slide-down menu */
.mobile-menu{display:none;position:fixed;top:68px;left:0;right:0;background:var(--obsidian);z-index:999;border-top:2px solid var(--flash);overflow-y:auto;max-height:calc(100vh - 68px);transform:translateY(-8px);opacity:0;pointer-events:none;transition:transform 0.28s ease,opacity 0.28s ease;}
.mobile-menu.open{display:block;transform:translateY(0);opacity:1;pointer-events:all;}
.mm-section{border-bottom:1px solid rgba(255,255,255,0.06);}
.mm-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:none;border:none;cursor:pointer;font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--milk);}
.mm-toggle svg{width:10px;height:10px;stroke:currentColor;stroke-width:2;fill:none;transition:transform 0.2s;}
.mm-toggle.active svg{transform:rotate(180deg);}
.mm-sub{display:none;padding:0 24px 12px;}
.mm-sub.open{display:block;}
.mm-sub a{display:block;font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:rgba(253,247,242,0.55);padding:9px 0;border-bottom:1px solid rgba(255,255,255,0.04);}
.mm-sub a:hover{color:var(--flash);}
.mm-cta{padding:20px 24px;display:flex;gap:10px;flex-wrap:wrap;}
.mm-cta .btn{flex:1;justify-content:center;}

/* ══════════════════
   SHORT VIEWPORT HEIGHTS (laptops, landscape)
   Targets screens under 720px tall
══════════════════ */
@media(max-height:720px) and (min-width:768px){
  .hero{min-height:480px;max-height:680px;}
  .hero h1{font-size:clamp(32px,4.5vw,56px);}
  .hero-sub{font-size:14px;margin-bottom:24px;}
  .hero-content{padding:0 64px clamp(24px,4vh,48px);}
  .hero-eyebrow{margin-bottom:12px;}
  .hero-actions{gap:10px;}
  .hero-panel-label{padding:14px 18px;}
  .hero-panel-label h3{font-size:14px;}
}

/* ══════════════════
   ULTRA-WIDE  1920px+
══════════════════ */
@media(min-width:1920px){
  .hero-content{max-width:1000px;padding:0 120px 100px;}
  .hero h1{font-size:96px;}
  .hero-sub{font-size:20px;max-width:600px;}
  .hero-right{width:30%;}
  .section-head,.portfolio .section-head{padding-left:120px;padding-right:120px;}
  .portfolio-filter{padding-left:120px;}
  .mat-grid{height:560px;}
  .portfolio-masonry{grid-template-rows:300px 300px;}
  .why,.process,.area,.quote-section,.reviews{padding-left:120px;padding-right:120px;}
  .brands{padding-left:120px;padding-right:120px;}
  footer{padding-left:120px;padding-right:120px;}
  .footer-top{grid-template-columns:320px 1fr 1fr 1fr;}
  .cta-banner{padding:100px 120px;}
  .stat-item{padding:28px 48px;}
  .stat-num{font-size:42px;}
}

/* ══════════════════
   WIDE  1536–1919px
══════════════════ */
@media(min-width:1536px) and (max-width:1919px){
  .hero-content{padding:0 96px 88px;}
  .section-head,.portfolio .section-head{padding-left:96px;padding-right:96px;}
  .portfolio-filter{padding-left:96px;}
  .mat-grid{height:520px;}
}

/* ══════════════════
   TABLET LANDSCAPE  1024–1279px
══════════════════ */
@media(min-width:1024px) and (max-width:1279px){
  .hero-content{padding:0 48px 64px;max-width:680px;}
  .hero h1{font-size:clamp(36px,5vw,60px);}
  .hero-sub{font-size:15px;}
  .hero-right{width:36%;}
  .section-head,.portfolio .section-head{padding-left:48px;padding-right:48px;}
  .portfolio-filter{padding-left:48px;}
  .mat-grid{grid-template-columns:repeat(3,1fr);height:auto;}
  .mat-card{height:260px;}
  .why,.process,.area,.quote-section,.reviews{padding-left:48px;padding-right:48px;}
  .why-grid{gap:48px;}
  .why-img-badge{right:0;}
  .process-grid{gap:48px;}
  .area-grid{gap:48px;}
  .quote-grid{gap:48px;}
  .brands{padding-left:48px;padding-right:48px;}
  .brands-logos{gap:28px;}
  footer{padding:48px 48px 28px;}
  .footer-top{grid-template-columns:200px 1fr 1fr 1fr;gap:32px;}
  .cta-banner{padding:64px 48px;}
  .reviews{padding-left:48px;padding-right:48px;}
  .reviews-grid{grid-template-columns:repeat(3,1fr);}
}

/* ══════════════════
   TABLET PORTRAIT  768–1023px
══════════════════ */
@media(min-width:768px) and (max-width:1023px){

  /* Nav — hide text links, show hamburger */
  .nav-links,.nav-cta,.nav-phone{display:none;}
  .nav-hamburger{display:flex;}
  .nav-logo{padding:0 20px;}

  /* Hero — stack vertically */
  .hero{height:auto;min-height:100svh;display:block;}
  .hero-content{position:relative;inset:auto;padding:120px 48px 56px;max-width:100%;}
  .hero-right{position:relative;width:100%;height:320px;flex-direction:row;}
  .hero-right-panel{border-left:none;border-top:4px solid var(--flash);}
  .hero-right-panel:first-child{border-top:none;border-right:4px solid var(--flash);}

  /* Stat strip */
  .stat-strip{grid-template-columns:repeat(2,1fr);}
  .stat-item:nth-child(2){border-right:none;}
  .stat-item:nth-child(3){border-top:1px solid rgba(255,255,255,0.06);}
  .stat-item:nth-child(4){border-right:none;border-top:1px solid rgba(255,255,255,0.06);}

  /* Materials */
  .materials{padding:72px 0 0;}
  .section-head{padding-left:40px;padding-right:40px;}
  .portfolio .section-head{padding-left:40px;padding-right:40px;}
  .mat-grid{grid-template-columns:repeat(3,1fr);height:auto;}
  .mat-card{height:240px;}

  /* Why */
  .why{padding:72px 40px;}
  .why-grid{grid-template-columns:1fr;gap:40px;}
  .why-left img{height:360px;}
  .why-img-badge{right:0;bottom:-12px;}

  /* Portfolio */
  .portfolio-filter{padding-left:40px;padding-right:40px;}
  .portfolio-masonry{grid-template-columns:1fr 1fr;grid-template-rows:240px 240px 240px;padding:0 0 3px;}
  .port-cell.tall{grid-row:span 1;grid-column:span 2;}

  /* Brands */
  .brands{padding:40px;}
  .brands-inner{flex-direction:column;align-items:flex-start;gap:20px;}
  .brands-label{border-right:none;border-bottom:1px solid rgba(17,17,17,0.12);padding:0 0 16px;width:100%;}
  .brands-logos{padding-left:0;gap:24px;}

  /* Process */
  .process{padding:72px 40px;}
  .process-grid{grid-template-columns:1fr;gap:40px;}
  .process-image{height:320px;}

  /* Reviews */
  .reviews{padding:72px 40px;}
  .reviews-top{flex-direction:column;align-items:flex-start;gap:16px;}
  .reviews-grid{grid-template-columns:1fr 1fr;gap:3px;}
  .r-card:last-child{grid-column:span 2;}

  /* Service area */
  .area{padding:72px 40px;}
  .area-grid{grid-template-columns:1fr;gap:40px;}
  .area-image{height:320px;}

  /* Quote form */
  .quote-section{padding:72px 40px;}
  .quote-grid{grid-template-columns:1fr;gap:40px;}

  /* CTA banner */
  .cta-banner{padding:64px 40px;grid-template-columns:1fr;gap:28px;}
  .logo-cta{display:none;}
  .cta-actions{align-items:flex-start;flex-direction:row;flex-wrap:wrap;}

  /* Footer */
  footer{padding:48px 40px 24px;}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px;}
  .footer-brand{grid-column:span 2;}

  /* FABs */
  .fab-call-num{display:none;}
  .chatbot{width:320px;}
}

/* ══════════════════
   MOBILE  480–767px
══════════════════ */
@media(min-width:480px) and (max-width:767px){

  /* Nav */
  .nav-links,.nav-cta,.nav-phone{display:none;}
  .nav-hamburger{display:flex;}
  .nav-logo{padding:0 16px;}
  .nav-inner{height:60px;}
  .mobile-menu{top:60px;max-height:calc(100vh - 60px);}

  /* Hero */
  .hero{height:auto;min-height:100svh;display:block;}
  .hero-bg-overlay{background:linear-gradient(160deg,rgba(0,0,0,0.88) 0%,rgba(0,0,0,0.6) 60%,rgba(0,0,0,0.35) 100%);}
  .hero-content{position:relative;inset:auto;padding:96px 28px 48px;max-width:100%;}
  .hero h1{font-size:clamp(32px,8vw,48px);}
  .hero-sub{font-size:14px;max-width:100%;}
  .hero-actions{flex-direction:column;align-items:stretch;}
  .hero-actions .btn{justify-content:center;}
  .hero-right{position:relative;width:100%;height:240px;flex-direction:row;}
  .hero-right-panel{border-left:none;border-right:2px solid var(--flash);}
  .hero-right-panel:last-child{border-right:none;}
  .hero-panel-label h3{font-size:13px;}

  /* Stat strip */
  .stat-strip{grid-template-columns:repeat(2,1fr);}
  .stat-item{padding:18px 20px;}
  .stat-item:nth-child(2){border-right:none;}
  .stat-item:nth-child(3){border-top:1px solid rgba(255,255,255,0.06);}
  .stat-item:nth-child(4){border-right:none;border-top:1px solid rgba(255,255,255,0.06);}
  .stat-num{font-size:26px;}

  /* Section heads */
  .section-head{padding:0 24px 32px;flex-direction:column;align-items:flex-start;gap:16px;}
  .portfolio .section-head{padding:0 24px 28px;}
  .portfolio-filter{padding:0 24px 28px;gap:6px;}

  /* Materials */
  .materials{padding:56px 0 0;}
  .mat-grid{grid-template-columns:repeat(2,1fr);height:auto;}
  .mat-card{height:220px;}
  .mat-link{opacity:1;transform:none;}

  /* Why */
  .why{padding:56px 24px;}
  .why-grid{grid-template-columns:1fr;gap:32px;}
  .why-left img{height:280px;}
  .why-img-badge{right:0;bottom:-12px;}
  .why-right h2{font-size:clamp(24px,6vw,34px);}

  /* Portfolio */
  .portfolio-masonry{grid-template-columns:1fr 1fr;grid-template-rows:180px 180px 180px;padding:0 0 3px;}
  .port-cell.tall{grid-row:span 1;grid-column:span 2;}
  .port-tag{opacity:1;}

  /* Brands */
  .brands{padding:32px 24px;}
  .brands-inner{flex-direction:column;align-items:flex-start;gap:16px;}
  .brands-label{border-right:none;padding:0 0 12px;border-bottom:1px solid rgba(17,17,17,0.12);width:100%;}
  .brands-logos{padding-left:0;gap:20px;}
  .brand-logo-item{font-size:12px;}

  /* Process */
  .process{padding:56px 24px;}
  .process-grid{grid-template-columns:1fr;gap:32px;}
  .process-image{height:260px;}

  /* Reviews */
  .reviews{padding:56px 24px;}
  .reviews-top{flex-direction:column;align-items:flex-start;gap:14px;}
  .score-big{font-size:48px;}
  .reviews-grid{grid-template-columns:1fr;gap:3px;}
  .reviews-footer{flex-direction:column;align-items:stretch;}
  .reviews-footer .btn{text-align:center;justify-content:center;}

  /* Service area */
  .area{padding:56px 24px;}
  .area-grid{grid-template-columns:1fr;gap:32px;}
  .area-image{height:260px;}
  .states{grid-template-columns:1fr 1fr;}

  /* Quote form */
  .quote-section{padding:56px 24px;}
  .quote-grid{grid-template-columns:1fr;gap:32px;}
  .fgrid{grid-template-columns:1fr;}
  .fg.full{grid-column:1;}
  .hours-grid{grid-template-columns:1fr;}

  /* CTA banner */
  .cta-banner{padding:56px 24px;grid-template-columns:1fr;gap:24px;}
  .logo-cta{display:none;}
  .cta-actions{align-items:stretch;}
  .cta-actions .btn{justify-content:center;}

  /* Footer */
  footer{padding:40px 24px 20px;}
  .footer-top{grid-template-columns:1fr 1fr;gap:28px;}
  .footer-brand{grid-column:span 2;}

  /* Floating actions */
  .fab-cluster{bottom:20px;right:16px;gap:10px;}
  .fab-call{padding:10px 14px 10px 12px;}
  .fab-call-num{display:none;}
  .chatbot{width:calc(100vw - 32px);right:16px;bottom:84px;}
  .quote-tab{font-size:9px;padding:7px 12px;}
  .q-drawer{width:100%;}
}

/* ══════════════════
   SMALL MOBILE  0–479px
══════════════════ */
@media(max-width:479px){

  /* Nav */
  .nav-links,.nav-cta,.nav-phone{display:none;}
  .nav-hamburger{display:flex;}
  .nav-logo{padding:0 14px;}
  .nav-inner{height:56px;}
  .mobile-menu{top:56px;max-height:calc(100vh - 56px);}
  .logo-svg,.logo-light{height:20px;}

  /* Hero */
  .hero{height:auto;min-height:100svh;display:block;}
  .hero-bg-overlay{background:rgba(0,0,0,0.72);}
  .hero-content{position:relative;inset:auto;padding:88px 20px 40px;}
  .hero-eyebrow{font-size:14px;}
  .hero h1{font-size:clamp(28px,9vw,40px);line-height:1.0;}
  .hero-sub{font-size:14px;max-width:100%;margin-bottom:24px;}
  .hero-actions{flex-direction:column;align-items:stretch;}
  .hero-actions .btn{justify-content:center;font-size:12px;padding:12px 20px;}
  .hero-right{display:none;} /* On very small screens, drop side panels */

  /* Stat strip */
  .stat-strip{grid-template-columns:1fr 1fr;}
  .stat-item{padding:16px 18px;}
  .stat-item:nth-child(2){border-right:none;}
  .stat-item:nth-child(3){border-top:1px solid rgba(255,255,255,0.06);}
  .stat-item:nth-child(4){border-right:none;border-top:1px solid rgba(255,255,255,0.06);}
  .stat-num{font-size:24px;}
  .stat-label{font-size:14px;}

  /* Section heads */
  .section-head{padding:0 20px 28px;flex-direction:column;align-items:flex-start;gap:14px;}
  .portfolio .section-head{padding:0 20px 24px;}
  .portfolio-filter{padding:0 20px 24px;gap:5px;}
  .filter-btn{font-size:14px;padding:6px 12px;}

  /* Materials — single column */
  .materials{padding:48px 0 0;}
  .mat-grid{grid-template-columns:1fr;height:auto;}
  .mat-card{height:200px;}
  .mat-link{opacity:1;transform:none;}

  /* Why */
  .why{padding:48px 20px;}
  .why-grid{grid-template-columns:1fr;gap:28px;}
  .why-left img{height:240px;}
  .why-img-badge{right:0;bottom:0;padding:14px 16px;}
  .why-img-badge .num{font-size:28px;}
  .proof-item{grid-template-columns:40px 1fr;gap:12px;padding:16px 0;}

  /* Portfolio */
  .portfolio{padding:48px 0;}
  .portfolio-masonry{grid-template-columns:1fr;grid-template-rows:auto;padding:0 0 3px;}
  .port-cell{height:200px;}
  .port-cell.tall{grid-row:span 1;grid-column:span 1;}
  .port-tag{opacity:1;}

  /* Brands */
  .brands{padding:28px 20px;}
  .brands-inner{flex-direction:column;gap:14px;}
  .brands-label{border-right:none;padding:0 0 12px;border-bottom:1px solid rgba(17,17,17,0.12);width:100%;}
  .brands-logos{padding-left:0;gap:16px;}
  .brand-logo-item{font-size:14px;}

  /* Process */
  .process{padding:48px 20px;}
  .process-grid{grid-template-columns:1fr;gap:28px;}
  .process-image{height:220px;}
  .p-step{grid-template-columns:44px 1fr;gap:12px;padding:18px 0;}

  /* Reviews */
  .reviews{padding:48px 20px;}
  .reviews-grid{grid-template-columns:1fr;gap:3px;}
  .score-big{font-size:44px;}
  .reviews-footer{flex-direction:column;align-items:stretch;}
  .reviews-footer .btn{justify-content:center;}

  /* Service area */
  .area{padding:48px 20px;}
  .area-grid{grid-template-columns:1fr;gap:28px;}
  .area-image{height:220px;}
  .states{grid-template-columns:1fr;}

  /* Quote */
  .quote-section{padding:48px 20px;}
  .quote-grid{grid-template-columns:1fr;gap:28px;}
  .fgrid{grid-template-columns:1fr;}
  .fg.full{grid-column:1;}
  .hours-grid{grid-template-columns:1fr;}
  .q-form-card{padding:24px 20px;}

  /* CTA banner */
  .cta-banner{padding:48px 20px;grid-template-columns:1fr;gap:20px;}
  .logo-cta{display:none;}
  .cta-banner h2{font-size:clamp(22px,7vw,36px);}
  .cta-actions{flex-direction:column;align-items:stretch;}
  .cta-actions .btn{justify-content:center;}

  /* Footer */
  footer{padding:36px 20px 16px;}
  .footer-top{grid-template-columns:1fr;gap:28px;}
  .footer-brand{grid-column:auto;}
  .footer-bottom{flex-direction:column;gap:6px;text-align:center;}

  /* Floating actions */
  .fab-cluster{bottom:16px;right:14px;gap:8px;}
  .fab-call-inner{display:none;}
  .fab-call{padding:12px;}
  .chatbot{width:calc(100vw - 28px);right:14px;bottom:80px;max-height:420px;}
  .quote-tab{font-size:9px;padding:6px 10px;}
  .q-drawer{width:100%;}
}

/* ══════════════════
   SAFE AREA (notch phones)
══════════════════ */
@supports(padding:max(0px)){
  .hero-content{padding-bottom:max(80px,env(safe-area-inset-bottom));}
  footer{padding-bottom:max(32px,env(safe-area-inset-bottom));}
  .fab-cluster{bottom:max(16px,env(safe-area-inset-bottom));}
  .quote-tab{bottom:max(50%,env(safe-area-inset-bottom));}
}

/* ══════════════════
   REDUCED MOTION
══════════════════ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:0.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:0.01ms!important;
  }
  .hero-bg img{animation:none;transform:scale(1);}
  .fade-up{opacity:1;transform:none;}
}

/* ══════════════════
   BUTTON ANIMATIONS
══════════════════════════════════════ */

/* Lift + subtle shadow on all buttons */
.btn{
  transition: background 0.2s ease, color 0.2s ease,
              border-color 0.2s ease, transform 0.18s ease,
              box-shadow 0.18s ease;
  position: relative;
  overflow: hidden;
}
.btn:hover{
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.18);
}
.btn:active{
  transform: translateY(0px) scale(0.975);
  box-shadow: none;
  transition-duration: 0.08s;
}

/* Flash Yellow buttons get a stronger gold shadow on hover */
.btn-flash:hover{
  box-shadow: 0 6px 24px rgba(244,207,53,0.38);
}

/* Nav CTA button — lift */
.nav-cta{
  position: relative;
  overflow: hidden;
  transition: background 0.2s ease, box-shadow 0.18s ease, filter 0.08s ease;
}
.nav-cta:hover{
  box-shadow: 0 4px 16px rgba(244,207,53,0.35);
}
.nav-cta:active{
  filter: brightness(0.9);
  box-shadow: none;
  transition-duration: 0.08s;
}

/* Submit buttons inside forms */
.f-submit, .qd-submit{
  position: relative;
  overflow: hidden;
  transition: background 0.2s ease, transform 0.18s ease, box-shadow 0.18s ease;
}
.f-submit:hover, .qd-submit:hover{
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.22);
}
.f-submit:active, .qd-submit:active{
  transform: scale(0.975);
  box-shadow: none;
  transition-duration: 0.08s;
}

/* Quote tab — pulse attention animation after 4s idle */
.quote-tab{
  transition: background 0.2s, transform 0.2s, box-shadow 0.2s;
  animation: tab-breathe 3.5s ease-in-out 4s infinite;
}
@keyframes tab-breathe{
  0%, 100%{ box-shadow: 2px 0 12px rgba(0,0,0,0.12); }
  50%{ box-shadow: 4px 0 20px rgba(244,207,53,0.55), 2px 0 12px rgba(0,0,0,0.12); }
}
.quote-tab:hover{
  animation: none;
  box-shadow: 4px 0 20px rgba(244,207,53,0.5);
}

/* Filter buttons */
.filter-btn{
  transition: background 0.18s ease, color 0.18s ease,
              border-color 0.18s ease, transform 0.15s ease;
}
.filter-btn:hover:not(.active){
  transform: translateY(-1px);
}
.filter-btn:active{
  transform: scale(0.96);
  transition-duration: 0.06s;
}

/* FAB call button */
.fab-call{
  transition: background 0.2s, transform 0.18s ease, box-shadow 0.18s ease;
}
.fab-call:hover{
  box-shadow: 0 8px 24px rgba(0,0,0,0.35);
}

/* FAB chat button */
.fab-chat-btn{
  transition: transform 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}
.fab-chat-btn:hover{
  box-shadow: 0 6px 24px rgba(244,207,53,0.5);
}

/* ══════════════════════════════════════
   PAGE LOAD SEQUENCE
   Hero content staggers in on load
══════════════════════════════════════ */
.hero-eyebrow,
.hero h1,
.hero-sub,
.hero-actions,
.hero-right-panel{
  opacity: 0;
  transform: translateY(20px);
  animation: hero-rise 0.7s ease forwards;
}
.hero-eyebrow   { animation-delay: 0.3s; }
.hero h1        { animation-delay: 0.5s; }
.hero-sub       { animation-delay: 0.65s; }
.hero-actions   { animation-delay: 0.8s; }
.hero-right-panel:nth-child(1){ animation-delay: 0.55s; }
.hero-right-panel:nth-child(2){ animation-delay: 0.7s;  }

@keyframes hero-rise{
  to{ opacity: 1; transform: translateY(0); }
}

/* Stat strip counts animate in when visible */
.stat-num{
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.stat-strip.in-view .stat-num{ opacity: 1; transform: translateY(0); }
.stat-strip.in-view .stat-item:nth-child(1) .stat-num{ transition-delay: 0.0s; }
.stat-strip.in-view .stat-item:nth-child(2) .stat-num{ transition-delay: 0.1s; }
.stat-strip.in-view .stat-item:nth-child(3) .stat-num{ transition-delay: 0.2s; }
.stat-strip.in-view .stat-item:nth-child(4) .stat-num{ transition-delay: 0.3s; }

/* Staggered fade-up for child groups */
.proof-item{
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.why.in-view .proof-item{ opacity: 1; transform: translateY(0); }
.why.in-view .proof-item:nth-child(1){ transition-delay: 0.0s; }
.why.in-view .proof-item:nth-child(2){ transition-delay: 0.12s; }
.why.in-view .proof-item:nth-child(3){ transition-delay: 0.24s; }
.why.in-view .proof-item:nth-child(4){ transition-delay: 0.36s; }

.p-step{
  opacity: 0;
  transform: translateX(-12px);
  transition: opacity 0.45s ease, transform 0.45s ease;
}
.process.in-view .p-step{ opacity: 1; transform: translateX(0); }
.process.in-view .p-step:nth-child(1){ transition-delay: 0.0s; }
.process.in-view .p-step:nth-child(2){ transition-delay: 0.1s; }
.process.in-view .p-step:nth-child(3){ transition-delay: 0.2s; }
.process.in-view .p-step:nth-child(4){ transition-delay: 0.3s; }

.mat-card{
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 0.45s ease, transform 0.45s ease;
}
.materials.in-view .mat-card{ opacity: 1; transform: translateY(0); }
.materials.in-view .mat-card:nth-child(1){ transition-delay: 0.00s; }
.materials.in-view .mat-card:nth-child(2){ transition-delay: 0.07s; }
.materials.in-view .mat-card:nth-child(3){ transition-delay: 0.14s; }
.materials.in-view .mat-card:nth-child(4){ transition-delay: 0.21s; }
.materials.in-view .mat-card:nth-child(5){ transition-delay: 0.28s; }
.materials.in-view .mat-card:nth-child(6){ transition-delay: 0.35s; }

.r-card{
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.reviews.in-view .r-card{ opacity: 1; transform: translateY(0); }
.reviews.in-view .r-card:nth-child(1){ transition-delay: 0.0s; }
.reviews.in-view .r-card:nth-child(2){ transition-delay: 0.12s; }
.reviews.in-view .r-card:nth-child(3){ transition-delay: 0.24s; }

/* Brand logos shimmer in */
.brand-logo-item{
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 0.4s ease, transform 0.4s ease, color 0.2s;
}
.brands.in-view .brand-logo-item{ opacity: 1; transform: translateY(0); }
.brands.in-view .brand-logo-item:nth-child(1){ transition-delay: 0.05s; }
.brands.in-view .brand-logo-item:nth-child(2){ transition-delay: 0.10s; }
.brands.in-view .brand-logo-item:nth-child(3){ transition-delay: 0.15s; }
.brands.in-view .brand-logo-item:nth-child(4){ transition-delay: 0.20s; }
.brands.in-view .brand-logo-item:nth-child(5){ transition-delay: 0.25s; }
.brands.in-view .brand-logo-item:nth-child(6){ transition-delay: 0.30s; }
.brands.in-view .brand-logo-item:nth-child(7){ transition-delay: 0.35s; }

/* Portfolio cells */
.port-cell{
  opacity: 0;
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.port-cell:not(.tall){ transform: translateY(12px); }
.port-cell.tall{ transform: translateX(-12px); }
.portfolio.in-view .port-cell{ opacity: 1; transform: translate(0); }
.portfolio.in-view .port-cell:nth-child(1){ transition-delay: 0.0s; }
.portfolio.in-view .port-cell:nth-child(2){ transition-delay: 0.1s; }
.portfolio.in-view .port-cell:nth-child(3){ transition-delay: 0.18s; }
.portfolio.in-view .port-cell:nth-child(4){ transition-delay: 0.26s; }
.portfolio.in-view .port-cell:nth-child(5){ transition-delay: 0.34s; }

/* ── FORM FOCUS GLOW ── */
.fi:focus, .fs:focus, .fta:focus{
  border-color: var(--obsidian);
  background: white;
  box-shadow: 0 0 0 3px rgba(17,17,17,0.06);
  transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
}
.cb-input:focus{
  box-shadow: 0 0 0 3px rgba(17,17,17,0.06);
}

/* ── LOADING SHIMMER for Google Reviews ── */
.r-card.skeleton{
  pointer-events: none;
  background: rgba(255,255,255,0.04);
}
.skel-line{
  border-radius: 3px;
  background: linear-gradient(90deg,
    rgba(255,255,255,0.05) 25%,
    rgba(255,255,255,0.12) 50%,
    rgba(255,255,255,0.05) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.6s ease-in-out infinite;
}
@keyframes shimmer{
  0%  { background-position: 200% 0; }
  100%{ background-position: -200% 0; }
}

/* ── NAV LINK underline slide ── */
.nav-link{
  position: relative;
}
.nav-link::after{
  content: '';
  position: absolute;
  bottom: 0;
  left: 18px;
  right: 18px;
  height: 2px;
  background: var(--flash);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.22s ease;
}
.nav-link:hover::after{ transform: scaleX(1); }

/* ── DROPDOWN item slide-in ── */
.dropdown a{
  transform: translateX(-4px);
  transition: color 0.15s, background 0.15s, transform 0.15s;
}
.nav-item:hover .dropdown a{ transform: translateX(0); }
.nav-item:hover .dropdown a:nth-child(1){ transition-delay: 0.03s; }
.nav-item:hover .dropdown a:nth-child(2){ transition-delay: 0.06s; }
.nav-item:hover .dropdown a:nth-child(3){ transition-delay: 0.09s; }
.nav-item:hover .dropdown a:nth-child(4){ transition-delay: 0.12s; }
.nav-item:hover .dropdown a:nth-child(5){ transition-delay: 0.15s; }

/* ── PROOF ICON pulse on hover ── */
.proof-item:hover .proof-icon{
  background: rgba(244,207,53,0.2);
  transition: background 0.2s;
}
.proof-icon{
  transition: background 0.2s;
}

/* ── STAT number count-up style (visual, CSS only) ── */
.stat-item{
  transition: background 0.2s;
}
.stat-item:hover{
  background: rgba(255,255,255,0.03);
}