/* ─── EZ TV MOUNTING — LIGHT BLUE THEME ─── */
@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@400;600;700;800;900&family=Mulish:wght@300;400;500;600;700&display=swap');

:root {
  --bg:       #ffffff;
  --bg2:      #f0f7ff;
  --bg3:      #e3f0fd;
  --navy:     #0a1f3c;
  --navy2:    #f0f7ff;
  --navy3:    #e3f0fd;
  --blue:     #1a6fd4;
  --blue2:    #2484e8;
  --blue3:    #4da3f5;
  --blue4:    #daeeff;
  --blue5:    #eef6ff;
  --white:    #ffffff;
  --off:      #e8f2fc;
  --muted:    #5a789e;
  --dim:      #8aaccc;
  --border:   rgba(26,111,212,0.13);
  --border2:  rgba(26,111,212,0.28);
  --card:     #ffffff;
  --green:    #0ea84f;
  --shadow:   0 2px 20px rgba(26,111,212,0.08);
  --shadow2:  0 8px 40px rgba(26,111,212,0.15);
  --r:        8px;
  --font-head:'Barlow Condensed', sans-serif;
  --font-body:'Mulish', sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-font-smoothing:antialiased}
body{font-family:var(--font-body);background:var(--bg);color:var(--navy);overflow-x:hidden;line-height:1.6}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

/* ─── TOPBAR ─── */
.topbar{background:var(--blue);padding:9px 0;text-align:center;font-size:13px;font-weight:600;letter-spacing:.5px;color:#fff}
.topbar a{color:#fff;margin:0 16px;font-weight:700}
.topbar a:hover{text-decoration:underline}
.topbar-sep{opacity:.5;margin:0 4px}

/* ─── NAV ─── */
nav{position:sticky;top:0;z-index:900;background:rgba(255,255,255,.97);backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.nav-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:68px}
.nav-logo{font-family:var(--font-head);font-size:26px;font-weight:900;letter-spacing:1px;color:var(--navy);display:flex;align-items:center;gap:10px;cursor:pointer;text-decoration:none}
.logo-icon{width:36px;height:36px;background:var(--blue);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0} .nav-logo img{height:38px;width:auto;display:block}
.nav-logo span{color:var(--blue2)}
.nav-links{display:flex;align-items:center;gap:2px;list-style:none}
.nav-links a{color:var(--muted);font-size:12.5px;font-weight:600;letter-spacing:.7px;text-transform:uppercase;padding:7px 12px;border-radius:6px;transition:all .2s;white-space:nowrap}
.nav-links a:hover,.nav-links a.active{color:var(--blue);background:var(--blue5)}
.nav-cta{background:var(--blue)!important;color:#fff!important;padding:9px 20px!important;border-radius:30px!important;font-size:13px!important}
.nav-cta:hover{background:var(--blue2)!important;box-shadow:0 6px 20px rgba(26,111,212,.3)!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none;-webkit-appearance:none;appearance:none;-webkit-tap-highlight-color:rgba(0,0,0,0);touch-action:manipulation}
.hamburger span{width:24px;height:2px;background:var(--navy);border-radius:2px;transition:all .3s;display:block}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mobile-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:800;background:var(--bg);flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:40px 20px;-webkit-overflow-scrolling:touch}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:26px;font-weight:700;font-family:var(--font-head);letter-spacing:2px;color:var(--navy);padding:8px 0;border-bottom:1px solid var(--border);width:100%;text-align:center}
.mobile-menu a:hover{color:var(--blue)}
.mobile-close{position:absolute;top:20px;right:24px;font-size:32px;cursor:pointer;color:var(--muted);background:none;border:none;line-height:1}

/* ─── HELPERS ─── */
.wrap{max-width:1200px;margin:0 auto;padding:0 32px}
.section{padding:80px 0}
.section-sm{padding:56px 0}
.label{display:inline-block;font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--blue);margin-bottom:14px;background:var(--blue4);border:1px solid var(--border2);padding:4px 14px;border-radius:100px}
.h1{font-family:var(--font-head);font-weight:900;font-size:clamp(48px,7vw,88px);line-height:.95;letter-spacing:1px;color:var(--navy)}
.h2{font-family:var(--font-head);font-weight:800;font-size:clamp(34px,5vw,60px);line-height:1;letter-spacing:.5px;color:var(--navy)}
.h3{font-family:var(--font-head);font-weight:700;font-size:clamp(20px,3vw,28px);line-height:1.1;color:var(--navy)}
.text-blue{color:var(--blue2)}
.text-muted{color:var(--muted)}
.text-center{text-align:center}
.lead{font-size:17px;color:var(--muted);line-height:1.75;max-width:600px}
.stars{color:#f59e0b;letter-spacing:2px;font-size:16px}
.divider{border:none;border-top:1px solid var(--border);margin:0}

/* ─── BUTTONS ─── */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:14px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;padding:14px 28px;border-radius:var(--r);transition:all .2s;cursor:pointer;border:2px solid transparent;white-space:nowrap}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue2);transform:translateY(-1px);box-shadow:0 8px 24px rgba(26,111,212,.35)}
.btn-outline{border-color:var(--border2);color:var(--blue);background:transparent}
.btn-outline:hover{border-color:var(--blue);background:var(--blue5)}
.btn-white{background:#fff;color:var(--blue)}
.btn-white:hover{background:var(--blue5)}
.btn-lg{padding:17px 36px;font-size:15px}
.btn-phone{background:var(--green);color:#fff}
.btn-phone:hover{background:#0b9442;transform:translateY(-1px);box-shadow:0 8px 24px rgba(14,168,79,.35)}
.btn-sm{padding:9px 18px;font-size:12px}

/* ─── CARDS ─── */
.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:32px;transition:all .3s;box-shadow:var(--shadow)}
.card:hover{border-color:var(--border2);transform:translateY(-3px);box-shadow:var(--shadow2)}
.card-icon{font-size:36px;margin-bottom:16px}
.card-title{font-family:var(--font-head);font-size:22px;font-weight:700;margin-bottom:10px;letter-spacing:.3px;color:var(--navy)}
.card-text{color:var(--muted);font-size:14px;line-height:1.7}

/* ─── STATS BAR ─── */
.stats-bar{background:var(--blue);padding:32px 0}
.stats-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat-box{text-align:center}
.stat-num{font-family:var(--font-head);font-size:52px;font-weight:900;color:#fff;line-height:1}
.stat-label{font-size:13px;color:rgba(255,255,255,.65);margin-top:4px;text-transform:uppercase;letter-spacing:.8px;font-weight:600}

/* ─── TRUST BAR ─── */
.trust-bar{background:var(--bg);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:18px 0}
.trust-bar-inner{max-width:1200px;margin:0 auto;padding:0 32px;display:flex;justify-content:space-around;align-items:center;flex-wrap:wrap;gap:16px}
.trust-item{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:600;color:var(--navy)}
.trust-item-icon{font-size:20px;flex-shrink:0}
.trust-item-text strong{display:block;font-size:14px;color:var(--navy)}
.trust-item-text span{font-size:12px;color:var(--muted);font-weight:400}

/* ─── HERO ─── */
.hero{min-height:92vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:60px;position:relative;overflow:hidden;padding:80px 0;background:var(--bg2)}
.hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,#daeeff 0%,#f0f7ff 50%,#fff 100%)}
.hero-glow{position:absolute;top:-10%;right:-5%;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(36,132,232,.1) 0%,transparent 70%);pointer-events:none}
.hero-grid{position:absolute;inset:0;opacity:.035;background-image:linear-gradient(var(--blue) 1px,transparent 1px),linear-gradient(90deg,var(--blue) 1px,transparent 1px);background-size:50px 50px}
.hero-left{position:relative;z-index:2;padding:0 32px}
.hero-eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:24px;flex-wrap:wrap}
.live-dot{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--green);font-family:var(--font-body)}
.live-dot::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--green);animation:blink 1.4s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.hero-title{margin-bottom:20px}
.hero-title .line1{display:block;color:var(--navy)}
.hero-title .line2{display:block;color:var(--blue2)}
.hero-title .line3{display:block;-webkit-text-stroke:2px var(--blue3);color:transparent}
.hero-sub{font-size:17px;color:var(--muted);line-height:1.75;max-width:480px;margin-bottom:36px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}
.hero-proof{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.hero-proof-text{font-size:13px;color:var(--muted);line-height:1.45}
.hero-proof-text strong{color:var(--navy)}
.hero-right{position:relative;z-index:2;padding:0 32px 0 0;grid-row:1/3;grid-column:2}
.hero-left{grid-column:1;grid-row:1}
.hero-sub-block{grid-column:1;grid-row:2;position:relative;z-index:2;padding:0 32px}
.hero-card{background:var(--white);border:1px solid var(--border2);border-radius:16px;padding:36px;box-shadow:var(--shadow2)}
.hero-card-title{font-family:var(--font-head);font-size:22px;font-weight:800;margin-bottom:24px;color:var(--navy);letter-spacing:.3px}
.trust-row{display:flex;align-items:flex-start;gap:14px;padding:14px 0;border-bottom:1px solid var(--border)}
.trust-row:last-of-type{border:none}
.trust-icon-box{width:44px;height:44px;border-radius:10px;flex-shrink:0;background:var(--blue5);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:20px}
.trust-row-text strong{display:block;font-size:14px;font-weight:700;color:var(--navy)}
.trust-row-text span{font-size:12px;color:var(--muted)}
.hero-phone{display:block;width:100%;margin-top:24px;background:var(--green);color:#fff;text-align:center;padding:18px;border-radius:var(--r);font-family:var(--font-head);font-size:24px;font-weight:900;letter-spacing:2px;transition:all .2s}
.hero-phone:hover{background:#0b9442;transform:translateY(-2px);box-shadow:0 8px 24px rgba(14,168,79,.3)}

/* ─── PAGE HERO ─── */
.page-hero{background:var(--bg2);padding:56px 0 48px;border-bottom:1px solid var(--border);text-align:center}
.page-hero .h2{margin-bottom:14px}
.page-hero p{color:var(--muted);font-size:17px;max-width:560px;margin:0 auto}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--dim);justify-content:center;margin-bottom:20px;flex-wrap:wrap}
.breadcrumb a{color:var(--muted);transition:color .2s}
.breadcrumb a:hover{color:var(--blue)}
.breadcrumb-sep{opacity:.4}

/* ─── SERVICES PAGE ─── */
.services-full{display:flex;flex-direction:column;gap:80px;margin-top:64px}
.service-block{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.service-block.reverse{direction:rtl}
.service-block.reverse>*{direction:ltr}
.service-visual{background:var(--bg3);border:1px solid var(--border2);border-radius:14px;min-height:280px;display:flex;align-items:center;justify-content:center;font-size:90px;position:relative;overflow:hidden;box-shadow:var(--shadow)}
.service-visual::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(26,111,212,.08) 0%,transparent 70%)}
.service-number{font-family:var(--font-head);font-size:72px;font-weight:900;color:rgba(26,111,212,.1);line-height:1;margin-bottom:-8px}
.service-title{font-family:var(--font-head);font-size:36px;font-weight:800;margin-bottom:16px;color:var(--navy)}
.service-desc{color:var(--muted);font-size:15px;line-height:1.75;margin-bottom:20px}
.service-bullets{list-style:none;display:flex;flex-direction:column;gap:10px}
.service-bullets li{display:flex;align-items:flex-start;gap:10px;font-size:14px;font-weight:600;color:var(--navy)}
.service-bullets li::before{content:'✓';color:var(--blue2);font-size:16px;font-weight:900;flex-shrink:0;margin-top:1px}
.service-price-note{margin-top:24px;background:var(--blue5);border:1px solid var(--border2);border-radius:8px;padding:14px 18px;font-size:14px;color:var(--blue);font-weight:600}
.service-price-note a{color:inherit;text-decoration:underline}

/* ─── SERVICES GRID (home/areas) ─── */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:52px}

/* ─── HOW IT WORKS ─── */
.how-section{background:var(--bg2)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative;margin-top:56px}
.steps::before{content:'';position:absolute;top:28px;left:12%;right:12%;height:2px;background:linear-gradient(90deg,transparent,var(--blue3),transparent);z-index:0}
.step{text-align:center;padding:0 16px;position:relative;z-index:1}
.step-circle{width:56px;height:56px;border-radius:50%;border:2px solid var(--blue3);background:var(--white);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-family:var(--font-head);font-size:22px;font-weight:900;color:var(--blue);box-shadow:0 4px 16px rgba(26,111,212,.15)}
.step-title{font-family:var(--font-head);font-size:18px;font-weight:700;margin-bottom:8px;color:var(--navy)}
.step-desc{color:var(--muted);font-size:13px;line-height:1.6}

/* ─── PRICING ─── */
.price-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-top:48px}
.price-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:28px 16px;text-align:center;transition:all .3s;position:relative;box-shadow:var(--shadow)}
.price-card:hover{border-color:var(--border2);transform:translateY(-4px);box-shadow:var(--shadow2)}
.price-card.popular{border-color:var(--blue);background:var(--blue5)}
.popular-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--blue);color:#fff;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:4px 12px;border-radius:100px;white-space:nowrap}
.price-size{font-size:12px;color:var(--muted);font-weight:600;letter-spacing:.5px;margin-bottom:10px}
.price-amt{font-family:var(--font-head);font-size:52px;font-weight:900;line-height:1;color:var(--navy)}
.price-amt sup{font-size:20px;vertical-align:super}
.price-from{font-size:11px;color:var(--dim);margin-top:4px;margin-bottom:16px}
.price-divider{border:none;border-top:1px solid var(--border);margin:16px 0}
.price-feat{font-size:12px;color:var(--muted);padding:4px 0;display:flex;align-items:center;justify-content:center;gap:6px}
.price-feat::before{content:'✓';color:var(--blue);font-weight:900}
.addons-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:24px}
.mobile-only-addon{display:none!important}
.addon-row{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:16px 20px;display:flex;justify-content:space-between;align-items:center;transition:all .2s;box-shadow:var(--shadow);gap:12px}
.addon-row:hover{border-color:var(--border2);transform:translateY(-2px)}
.addon-name{font-size:14px;font-weight:600;color:var(--navy)}
.addon-price{color:var(--blue);font-weight:700;font-size:15px;white-space:nowrap}
.note-box{background:var(--blue5);border:1px solid var(--border2);border-radius:10px;padding:22px 28px;margin-top:28px;color:var(--muted);font-size:14px;line-height:1.7}
.note-box strong{color:var(--navy)}
.addons-header{font-family:var(--font-head);font-size:36px;font-weight:800;margin-bottom:8px;color:var(--navy)}
.addons-sub{color:var(--muted);font-size:15px;margin-bottom:24px}
.compare-table{width:100%;border-collapse:collapse;margin-top:48px}
.compare-table th{background:var(--bg3);padding:16px 20px;text-align:left;font-size:13px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border)}
.compare-table td{padding:16px 20px;border-bottom:1px solid var(--border);font-size:14px;font-weight:500;color:var(--navy)}
.compare-table tr:last-child td{border:none}
.compare-table tr:hover td{background:var(--bg2)}
.check{color:#16a34a;font-size:18px}
.cross{color:var(--dim);font-size:18px}
.pay-methods{display:flex;gap:12px;flex-wrap:wrap;margin-top:32px}
.pay-chip{background:var(--white);border:1px solid var(--border);padding:10px 20px;border-radius:6px;font-size:13px;font-weight:600;color:var(--navy);box-shadow:var(--shadow)}

/* ─── REVIEWS ─── */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:52px}
.review-section{background:var(--bg2)}
.review-card{display:flex;flex-direction:column;gap:14px}
.review-quote{color:var(--muted);font-size:14px;line-height:1.75;font-style:italic;flex:1}
.review-author{font-weight:700;font-size:14px;color:var(--navy)}
.review-meta{font-size:11px;color:var(--dim)}

/* ─── GUARANTEE ─── */
.guarantee-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:48px}
.guarantee-item{text-align:center;padding:32px 20px;background:var(--white);border:1px solid var(--border);border-radius:12px;transition:all .3s;box-shadow:var(--shadow)}
.guarantee-item:hover{border-color:var(--border2);transform:translateY(-3px);box-shadow:var(--shadow2)}
.guarantee-icon{font-size:38px;margin-bottom:16px}
.guarantee-title{font-family:var(--font-head);font-size:20px;font-weight:800;margin-bottom:8px;color:var(--navy)}
.guarantee-desc{font-size:13px;color:var(--muted);line-height:1.6}

/* ─── AREAS ─── */
.areas-section{background:var(--bg2)}
.areas-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:40px}
.area-chip{background:var(--white);border:1px solid var(--border);padding:14px 16px;border-radius:8px;text-align:center;font-size:14px;font-weight:600;transition:all .2s;color:var(--navy);box-shadow:var(--shadow);display:block}
.area-chip:hover{border-color:var(--blue);color:var(--blue);background:var(--blue5);transform:translateY(-2px)}
.area-chip .city-name-chip{font-family:var(--font-head);font-size:18px;font-weight:800;display:block;margin-bottom:3px}
.area-chip .city-sub-chip{font-size:11px;color:var(--muted);font-weight:500}

/* ─── CTA BAND ─── */
.cta-band{background:linear-gradient(135deg,var(--blue) 0%,#1558b0 100%);padding:64px 0;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 100% at 50% 0%,rgba(255,255,255,.1) 0%,transparent 70%)}
.cta-band .wrap{position:relative}
.cta-band .h2{color:#fff;margin-bottom:14px}
.cta-band p{color:rgba(255,255,255,.8);font-size:17px;margin-bottom:32px}
.cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ─── FAQ ─── */
.faq-list{display:flex;flex-direction:column;gap:8px;margin-top:48px}
.faq-item{background:var(--white);border:1px solid var(--border);border-radius:10px;overflow:hidden;box-shadow:var(--shadow)}
.faq-q{padding:20px 24px;font-weight:700;font-size:15px;color:var(--navy);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;user-select:none;transition:color .2s;width:100%;text-align:left;background:none;border:none;font-family:var(--font-body)}
.faq-q:hover{color:var(--blue)}
.faq-toggle{width:28px;height:28px;flex-shrink:0;border:2px solid var(--border2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--blue);transition:transform .3s;font-weight:300;line-height:1}
.faq-item.open .faq-toggle{transform:rotate(45deg);background:var(--blue5)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .3s;padding:0 24px;color:var(--muted);font-size:14px;line-height:1.75}
.faq-item.open .faq-a{max-height:300px;padding:0 24px 22px}
.faq-section-title{font-family:var(--font-head);font-size:26px;font-weight:800;color:var(--blue);margin:48px 0 16px;letter-spacing:.3px}
.faq-section-title:first-child{margin-top:0}

/* ─── BLOG ─── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:52px}
.blog-card{background:var(--white);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:all .3s;box-shadow:var(--shadow);display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow2);border-color:var(--border2)}
.blog-thumb{aspect-ratio:16/9;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:56px;border-bottom:1px solid var(--border);position:relative;overflow:hidden}
.blog-body{padding:24px;flex:1;display:flex;flex-direction:column}
.blog-tag{font-size:11px;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}
.blog-card h3{font-family:var(--font-head);font-size:20px;font-weight:800;color:var(--navy);line-height:1.2;margin-bottom:10px;letter-spacing:.2px}
.blog-card p{font-size:14px;color:var(--muted);line-height:1.6;flex:1}
.blog-meta{font-size:12px;color:var(--dim);margin-top:14px;display:flex;gap:12px;align-items:center}
.blog-read{display:inline-flex;align-items:center;gap:5px;margin-top:16px;font-size:13px;font-weight:700;color:var(--blue)}
.blog-read:hover{gap:8px}

/* ─── CONTACT ─── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.contact-form-card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:40px;box-shadow:var(--shadow2)}
.form-title{font-family:var(--font-head);font-size:30px;font-weight:800;margin-bottom:8px;color:var(--navy)}
.form-sub{color:var(--muted);font-size:14px;margin-bottom:32px}
.form-group{margin-bottom:20px}
.form-label{display:block;font-size:13px;font-weight:700;margin-bottom:8px;color:var(--navy);letter-spacing:.3px}
.form-input,.form-select,.form-textarea{width:100%;background:var(--bg2);border:1.5px solid var(--border);border-radius:8px;padding:13px 16px;color:var(--navy);font-family:var(--font-body);font-size:14px;transition:border-color .2s,box-shadow .2s;outline:none;-webkit-appearance:none}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,111,212,.1)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--dim)}
.form-textarea{min-height:120px;resize:vertical}
.form-select option{background:var(--bg)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-submit{width:100%;padding:16px;background:var(--blue);color:#fff;border:none;border-radius:30px;font-family:var(--font-body);font-size:15px;font-weight:700;letter-spacing:.8px;cursor:pointer;transition:all .2s;text-transform:uppercase}
.form-submit:hover{background:var(--blue2);transform:translateY(-1px);box-shadow:0 8px 24px rgba(26,111,212,.35)}
.form-note{text-align:center;font-size:12px;color:var(--dim);margin-top:12px}
.contact-info{display:flex;flex-direction:column;gap:20px}
.contact-card{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:24px 28px;display:flex;gap:18px;align-items:flex-start;transition:border-color .2s;box-shadow:var(--shadow)}
.contact-card:hover{border-color:var(--border2)}
.contact-card-icon{font-size:30px;flex-shrink:0}
.contact-card-label{font-size:12px;color:var(--muted);font-weight:600;letter-spacing:1px;text-transform:uppercase;margin-bottom:6px}
.contact-card-value{font-size:20px;font-family:var(--font-head);font-weight:800;color:var(--navy)}
.contact-card-value a{color:inherit;transition:color .2s}
.contact-card-value a:hover{color:var(--blue2)}
.contact-card-note{font-size:13px;color:var(--muted);margin-top:4px}
.avail-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(14,168,79,.1);border:1px solid rgba(14,168,79,.3);color:var(--green);padding:4px 12px;border-radius:100px;font-size:12px;font-weight:700;margin-top:8px}
.avail-badge::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--green);animation:blink 1.4s infinite}
.hours-row{display:flex;justify-content:space-between;font-size:13px;padding:4px 0}
.hours-row .day{color:var(--muted)}
.hours-row .time{font-weight:700;color:var(--navy)}

/* ─── GALLERY ─── */
.gallery-filter{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:48px}
.filter-btn{padding:9px 20px;border-radius:100px;font-size:13px;font-weight:700;cursor:pointer;border:1.5px solid var(--border);color:var(--muted);background:transparent;transition:all .2s;letter-spacing:.5px}
.filter-btn:hover,.filter-btn.active{border-color:var(--blue);color:var(--blue);background:var(--blue5)}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gallery-item{border-radius:12px;overflow:hidden;position:relative;background:var(--bg3);border:1px solid var(--border);aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;transition:all .3s;cursor:pointer;box-shadow:var(--shadow)}
.gallery-item:hover{transform:scale(1.02);border-color:var(--border2);box-shadow:var(--shadow2)}
.gallery-item.large{grid-column:span 2;aspect-ratio:16/9}
.gallery-emoji{font-size:64px}
.gallery-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,31,60,.9) 0%,transparent 50%);opacity:0;transition:opacity .3s;display:flex;align-items:flex-end;padding:20px}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-label{font-size:13px;font-weight:700;color:#fff}
.gallery-tag{font-size:11px;color:var(--blue3);margin-top:2px}
.upload-cta{background:var(--bg2);border:2px dashed var(--border2);border-radius:14px;padding:56px 32px;text-align:center;margin-top:48px}
.upload-cta h3{font-family:var(--font-head);font-size:28px;margin-bottom:12px;color:var(--navy)}
.upload-cta p{color:var(--muted);font-size:15px;margin-bottom:24px}

/* ─── ABOUT ─── */
.about-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about-photo-box{background:var(--bg3);border:1px solid var(--border2);border-radius:16px;min-height:380px;display:flex;align-items:center;justify-content:center;font-size:90px;position:relative;overflow:hidden;box-shadow:var(--shadow2)}
.about-photo-box::before{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--blue),var(--blue2))}
.about-photo-caption{position:absolute;bottom:20px;left:20px;right:20px;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:10px;padding:14px 18px}
.about-photo-name{font-family:var(--font-head);font-size:22px;font-weight:800;color:var(--navy)}
.about-photo-title{font-size:13px;color:var(--blue2);font-weight:600;margin-top:2px}
.about-stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:24px}
.about-stat{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:18px;text-align:center;box-shadow:var(--shadow)}
.about-stat-num{font-family:var(--font-head);font-size:38px;font-weight:900;color:var(--blue2);line-height:1}
.about-stat-label{font-size:12px;color:var(--muted);margin-top:4px;text-transform:uppercase;letter-spacing:.8px}
.credential-list{display:flex;flex-direction:column;gap:10px;margin-top:24px}
.credential-item{display:flex;align-items:flex-start;gap:14px;padding:14px;background:var(--white);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow)}
.cred-icon{font-size:22px;flex-shrink:0}
.cred-text strong{display:block;font-size:14px;font-weight:700;color:var(--navy)}
.cred-text span{font-size:13px;color:var(--muted)}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:48px}
.value-card{text-align:center;padding:32px 20px;background:var(--white);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);transition:all .3s}
.value-card:hover{border-color:var(--border2);transform:translateY(-3px);box-shadow:var(--shadow2)}
.value-icon{font-size:40px;margin-bottom:14px}
.value-title{font-family:var(--font-head);font-size:22px;font-weight:800;margin-bottom:8px;color:var(--navy)}
.value-desc{font-size:13px;color:var(--muted);line-height:1.6}

/* ─── CITY/AREA PAGES ─── */
.city-hero{padding:64px 0 52px;background:var(--bg2);border-bottom:1px solid var(--border);text-align:center}
.city-hero .h1{font-size:clamp(36px,6vw,68px);margin-bottom:14px}
.city-hero .lead{margin:0 auto 28px;max-width:580px}
.city-hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.city-services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:48px}
.city-faq-wrap{max-width:780px;margin:0 auto}
.city-trust{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:40px}
.city-trust-item{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:20px;text-align:center;box-shadow:var(--shadow)}
.city-trust-icon{font-size:28px;margin-bottom:8px}
.city-trust-title{font-family:var(--font-head);font-size:17px;font-weight:800;color:var(--navy);margin-bottom:4px}
.city-trust-desc{font-size:12px;color:var(--muted)}

/* ─── FOOTER ─── */
footer{background:var(--navy);padding:64px 0 28px;border-top:1px solid rgba(255,255,255,.06)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-logo{font-family:var(--font-head);font-size:26px;font-weight:900;margin-bottom:14px;color:#fff;display:flex;align-items:center;gap:8px}
.footer-logo span{color:var(--blue3)}
.footer-logo .logo-icon{width:30px;height:30px;font-size:14px}
.footer-desc{color:rgba(255,255,255,.45);font-size:13px;line-height:1.7;max-width:260px;margin-bottom:20px}
.footer-contact a{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.45);font-size:13px;margin-bottom:8px;transition:color .2s}
.footer-contact a:hover{color:var(--blue3)}
.footer-col h4{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--blue3);font-weight:700;margin-bottom:18px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col li a{color:rgba(255,255,255,.4);font-size:13px;transition:color .2s}
.footer-col li a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:24px;display:flex;justify-content:space-between;align-items:center;color:rgba(255,255,255,.3);font-size:12px;flex-wrap:wrap;gap:8px}
.footer-bottom a{color:rgba(255,255,255,.4);transition:color .2s}
.footer-bottom a:hover{color:var(--blue3)}

/* ─── ANIMATIONS ─── */
.anim{opacity:0;transform:translateY(24px);transition:opacity .55s ease,transform .55s ease}
.anim.visible{opacity:1;transform:translateY(0)}

/* ═══════════ RESPONSIVE ═══════════ */

/* Home page photo strip */
.home-photo-strip{gap:6px}
.home-photo-strip-desktop{display:grid;grid-template-columns:1fr 1fr 1fr}
.home-photo-strip-mobile{display:none}
.home-photo-item{border-radius:12px;overflow:hidden;height:260px;box-shadow:var(--shadow)}

/* ─────────────────────────────────────────────
   RESPONSIVE STYLES — one clean file, one block
   ───────────────────────────────────────────── */


/* Footer accordion button — hidden on desktop */
.footer-acc-btn{display:none}
.footer-acc-arrow{display:inline-block;transition:transform .25s}
.footer-acc-btn.open .footer-acc-arrow{transform:rotate(180deg)}
.footer-acc-list{display:block}/* always visible on desktop */

/* Guarantee items */
.guarantee-icon{font-size:36px;margin-bottom:12px}
.guarantee-title{font-family:var(--font-head);font-size:20px;font-weight:800;color:var(--navy);margin-bottom:8px}
.guarantee-desc{font-size:14px;color:var(--muted);line-height:1.6}

/* ── 1100px ── */
@media(max-width:1100px){
  .price-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero{min-height:auto;padding:56px 0 40px}
  .hero-left{grid-column:1;grid-row:1;padding:0 32px}
  .hero-sub-block{grid-column:1;grid-row:2;padding:0 32px}
  .services-full .service-block,.services-full .service-block.reverse{grid-template-columns:1fr;direction:ltr}
  .service-visual{min-height:200px}
  .about-hero-grid{grid-template-columns:1fr;gap:40px}
}

/* Hide hero photo on tablet only — mobile shows it */
@media(min-width:681px) and (max-width:1100px){
  .hero-right{display:none}
}

/* ── 900px ── */
@media(max-width:900px){
  .wrap{padding:0 20px}
  .section{padding:60px 0}
  .stats-inner{grid-template-columns:repeat(2,1fr);gap:20px}
  .services-grid,.city-services-grid{grid-template-columns:repeat(2,1fr)}
  .reviews-grid{grid-template-columns:1fr 1fr}
  .guarantee-row{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr);gap:32px}
  .steps::before{display:none}
  .areas-grid{grid-template-columns:repeat(3,1fr)}
  .addons-grid{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-item.large{grid-column:span 1;aspect-ratio:4/3}
  .values-grid{grid-template-columns:repeat(2,1fr)}
  .city-trust{grid-template-columns:repeat(2,1fr)}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .price-grid{grid-template-columns:repeat(2,1fr)}
}

/* ── 680px MOBILE ── */
@media(max-width:680px){

  /* All .anim elements visible immediately — no JS needed */
  .anim{opacity:1!important;transform:none!important;transition:none!important}

  /* Nav fixed on mobile */
  nav{position:fixed!important;top:0;left:0;right:0;z-index:9999!important;height:60px;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;background:rgba(255,255,255,1)!important}
  body{padding-top:60px}
  .nav-inner{padding:0 16px;height:60px}
  .nav-logo{font-size:20px}
  .nav-links{display:none}
  /* Hamburger - large tap target, above everything */
  .hamburger{
    display:flex!important;
    position:static!important;
    z-index:auto!important;
    padding:12px!important;
    margin:0!important;
    min-width:44px!important;
    min-height:44px!important;
    -webkit-tap-highlight-color:rgba(0,0,0,0)!important;
    -webkit-touch-callout:none!important;
    touch-action:manipulation!important;
    cursor:pointer!important;
    pointer-events:auto!important;
    background:none!important;
    border:none!important;
    outline:none!important;
    -webkit-appearance:none!important;
    appearance:none!important;
    user-select:none!important;
    -webkit-user-select:none!important;
  }
  /* Mobile menu */
  .mobile-menu{z-index:99998!important}

  /* Hero — title → photo → description → buttons */
  /* Hero mobile: title(row1) → photo(row2) → sub+buttons(row3) */
  .hero{
    display:flex!important;
    flex-direction:column!important;
    padding:0!important;
    min-height:auto!important;
    gap:0!important;
  }
  .hero > *{width:100%}
  .hero-eyebrow{display:none!important}
  /* Row 1: title */
  .hero-left{
    padding:12px 18px 8px!important;
    grid-row:unset!important;grid-column:unset!important;
    order:1;
    text-align:left!important;
  }
  .hero-left .h1,.hero-title{
    text-align:left!important;
    padding-left:0!important;
  }
  .hero-title{margin-bottom:0;font-size:clamp(36px,10vw,54px)}
  /* Row 2: photo */
  .hero-right{
    display:block!important;
    order:2;
    padding:0!important;
    margin:0!important;
    width:100vw!important;
    position:relative;
    left:0;right:0;
    grid-row:unset!important;grid-column:unset!important;
  }
  .hero-right > div{
    border-radius:0!important;
    box-shadow:none!important;
    margin:0!important;
    width:100%!important;
  }
  .hero-right img{
    height:240px!important;
    width:100%!important;
    border-radius:0!important;
    object-fit:cover;
    object-position:center 15%;
    display:block!important;
    margin:0!important;
  }
  /* Row 3: sub text + buttons + stars */
  .hero-sub-block{
    order:3;
    padding:16px 18px 20px!important;
    grid-row:unset!important;grid-column:unset!important;
  }
  .hero-sub{font-size:15px;margin-bottom:18px;max-width:100%}
  .hero-actions{flex-direction:column;gap:10px;margin-bottom:16px}
  .hero-actions .btn{width:100%;justify-content:center;padding:15px;font-size:15px}
  .hero-proof{gap:10px;margin-bottom:0}

  /* Stats 2x2 grid */
  .stats-bar{padding:0}
  .stats-inner{grid-template-columns:1fr 1fr;gap:0}
  .stat-box{padding:18px 12px;border-right:1px solid rgba(255,255,255,.2);border-bottom:1px solid rgba(255,255,255,.2)}
  .stat-box:nth-child(2n){border-right:none}
  .stat-box:nth-child(3),.stat-box:nth-child(4){border-bottom:none}
  .stat-num{font-size:38px}

  /* Trust bar — clean 2-col grid */
  .trust-bar{padding:0}
  .trust-bar-inner{display:grid!important;grid-template-columns:1fr 1fr;gap:0;padding:0;flex-wrap:unset}
  .trust-item{padding:12px 12px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);align-items:flex-start;width:auto}
  .trust-item:nth-child(2n){border-right:none}
  .trust-item:nth-last-child(-n+1){border-bottom:none}
  .trust-item-icon{font-size:20px;margin-top:2px}
  .trust-item-text strong{font-size:12px;display:block}
  .trust-item-text span{display:block;font-size:11px;color:var(--muted);font-weight:400}

  /* Typography */
  .h2{font-size:clamp(26px,8vw,40px)}
  .lead{font-size:15px}

  /* Sections */
  .section{padding:40px 0}
  .wrap{padding:0 18px}

  /* Services — stacks, animations off */
  .services-grid,.city-services-grid{grid-template-columns:1fr}
  .card{padding:20px 16px}

  /* Services full page — title → photo → description */
  .service-block,.service-block.reverse{
    display:flex!important;flex-direction:column!important;
    direction:ltr!important;gap:0!important
  }
  .service-content{display:contents!important}
  .service-number{order:1;padding:16px 18px 2px}
  .service-title{order:2;padding:0 18px 10px;font-size:22px!important;margin-bottom:0!important}
  .service-visual{order:3!important;min-height:210px!important;border-radius:0!important;width:100%}
  .service-desc{order:4;padding:12px 18px 0;display:block}
  .service-bullets{order:5;padding:0 18px;margin-top:8px}
  .service-price-note{order:6;padding:8px 18px 20px;display:block}

  /* Steps */
  .steps{grid-template-columns:1fr;gap:0}
  .step{display:flex;flex-direction:row;align-items:flex-start;gap:14px;padding:16px 0;border-bottom:1px solid var(--border);text-align:left}
  .step:last-child{border-bottom:none}
  .step-circle{margin:0;flex-shrink:0;width:44px;height:44px;font-size:18px}
  .step-title{font-size:16px;margin-bottom:3px}
  .step-desc{font-size:13px}

  /* Pricing */
  .price-grid{grid-template-columns:1fr 1fr;gap:8px}
  .price-card{padding:16px 10px}
  .price-amt{font-size:36px}
  .addons-grid{grid-template-columns:1fr}
  .compare-table{font-size:12px}
  .compare-table th,.compare-table td{padding:10px 8px}

  /* Reviews */
  .reviews-grid{grid-template-columns:1fr}
  .review-card{padding:18px 14px}

  /* Guarantee */
  .guarantee-row{grid-template-columns:1fr 1fr;gap:10px}
  .guarantee-item{padding:18px 12px;text-align:center}
  .guarantee-icon{font-size:26px;margin-bottom:8px}
  .guarantee-title{font-size:15px}
  .guarantee-desc{font-size:11px}

  /* Areas */
  .areas-grid{grid-template-columns:1fr 1fr;gap:8px}
  .area-chip{padding:12px 10px}
  .city-name-chip{font-size:14px}

  /* CTA band */
  .cta-actions{flex-direction:column;align-items:stretch;gap:10px}
  .cta-actions .btn{width:100%;justify-content:center;padding:15px}

  /* Blog card thumbs hidden — show only card body */
  .blog-card-thumb{display:none!important}
  .blog-grid{grid-template-columns:1fr}

  /* Footer — accordion on mobile */
  .footer-grid{grid-template-columns:1fr;gap:0}
  .footer-col{border-bottom:1px solid rgba(255,255,255,.12);padding:0}
  .footer-col:last-child{border-bottom:none}
  .footer-col-h{display:none!important}
  .footer-acc-btn{
    display:flex!important;
    width:100%;background:none;border:none;border:0;
    color:rgba(255,255,255,.9);
    font-family:var(--font-head);font-size:16px;font-weight:700;
    letter-spacing:.5px;text-transform:uppercase;
    padding:14px 0;text-align:left;cursor:pointer;
    justify-content:space-between;align-items:center;
    -webkit-tap-highlight-color:transparent;touch-action:manipulation;
  }
  .footer-acc-list{
    display:block;max-height:0;overflow:hidden;
    transition:max-height .3s ease;
  }
  .footer-acc-list.open{max-height:400px}
  .footer-bottom{flex-direction:column;gap:6px;text-align:center;font-size:11px}
  .footer-contact a{font-size:13px}

  /* Forms — 16px prevents iOS zoom */
  .form-row{grid-template-columns:1fr}
  .form-input,.form-select,.form-textarea{font-size:16px!important}
  .form-submit{width:100%;padding:15px}

  /* Contact */
  .contact-grid{grid-template-columns:1fr}
  .contact-card{padding:16px 14px}

  /* Gallery */
  .gallery-grid{grid-template-columns:1fr}
  .gallery-item.large{grid-column:span 1;aspect-ratio:4/3}

  /* Misc */
  .values-grid{grid-template-columns:1fr}
  .about-stats-row{grid-template-columns:repeat(3,1fr)}
  .faq-q{font-size:14px;padding:14px 16px}
  .city-trust{grid-template-columns:1fr 1fr}
  .city-hero-actions{flex-direction:column;align-items:stretch;gap:10px}
  .city-hero-actions .btn{width:100%;justify-content:center}
  .page-hero{padding:32px 0 24px}
  .about-hero-grid{grid-template-columns:1fr;gap:32px}


  /* Home page photo strip: show mobile strip, hide desktop strip */
  .home-photo-strip-desktop{display:none!important}
  .home-photo-strip-mobile{display:grid!important;grid-template-columns:1fr 1fr;gap:6px}
  /* Any TV Size trust item hidden on mobile */
  .hide-mobile-trust{display:none!important}
  /* About page: show 100% satisfaction on mobile */
  .about-stat-satisfaction{display:block!important}
  /* City area pages: fix layout on mobile */
  .city-two-col{grid-template-columns:1fr!important;gap:32px!important}
  .city-trust{grid-template-columns:1fr 1fr!important;gap:10px!important}
  .city-trust-item{padding:14px!important}
  .city-trust-icon{font-size:22px!important;margin-bottom:6px!important}
  .city-trust-title{font-size:15px!important}
  .city-hero{padding:32px 0 24px!important}
  .city-hero .h1{font-size:clamp(30px,8vw,44px)!important}
  .city-services-grid{grid-template-columns:1fr!important}
  .about-stats-row{grid-template-columns:repeat(2,1fr)!important}
  /* Plastic channel concealment — mobile only */
    /* Plastic channel concealment — mobile only */
    /* Plastic channel — mobile only */
  .mobile-only-addon{display:flex!important}
  /* Hide scroll-to-top */
  #scroll-top{display:none!important}

  /* Sticky mobile CTA bar */
  .mobile-sticky-cta{display:flex!important}
}

@media(max-width:400px){
  .areas-grid{grid-template-columns:1fr 1fr}
  .price-grid{grid-template-columns:1fr}
  .about-stats-row{grid-template-columns:1fr}
  .guarantee-row{grid-template-columns:1fr}
}

/* ── Sticky mobile call bar (always visible) ── */
.mobile-sticky-cta{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:9990;
  background:transparent;border:none;
  padding:10px 16px;padding-bottom:calc(10px + env(safe-area-inset-bottom));
  gap:10px;box-shadow:none;pointer-events:none;
}
.mobile-sticky-cta a{pointer-events:auto}
.mobile-sticky-cta a{
  flex:1;display:flex;align-items:center;justify-content:center;
  gap:7px;padding:13px 8px;border-radius:10px;
  font-family:var(--font-body);font-size:14px;font-weight:700;
  letter-spacing:.3px;text-decoration:none;white-space:nowrap;
  -webkit-tap-highlight-color:transparent;touch-action:manipulation;
  box-shadow:0 2px 12px rgba(0,0,0,.25);
}
.mobile-sticky-cta .cta-call{background:#0ea84f;color:#fff}
.mobile-sticky-cta .cta-quote{background:#1a6fd4;color:#fff}


/* ── Page-specific styles (moved from inline <style> blocks) ── */

.filter-bar{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:36px}
.filter-btn{padding:8px 18px;border-radius:100px;font-size:13px;font-weight:700;cursor:pointer;border:1.5px solid var(--border);color:var(--muted);background:transparent;transition:all .2s;font-family:var(--font-body)}
.filter-btn:hover,.filter-btn.active{border-color:var(--blue);color:var(--blue);background:var(--blue5)}

/* Uniform grid — all portrait, all same aspect ratio, zero gaps */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}
.gi{
  border-radius:12px;
  overflow:hidden;
  position:relative;
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  background:var(--bg3);
  aspect-ratio:3/4;  /* all same box size — portrait */
}
.gi img{
  width:100%;
  height:100%;
  object-fit:cover;   /* fills box, crops edges — NO GAPS */
  object-position:center top;
  display:block;
  transition:transform .4s ease;
}
.gi:hover img{transform:scale(1.04)}
.gi:hover{box-shadow:var(--shadow2);border-color:var(--border2)}
.ov{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(10,31,60,.88) 0%,transparent 55%);
  opacity:0;transition:opacity .3s;
  display:flex;align-items:flex-end;padding:16px;
}
.gi:hover .ov{opacity:1}
.ov-title{color:#fff;font-size:13px;font-weight:700;display:block;margin-bottom:3px}
.ov-tag{color:var(--blue3);font-size:11px}

@media(max-width:900px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.gallery-grid{grid-template-columns:repeat(2,1fr);gap:8px}}

.blog-grid-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.blog-card-link{text-decoration:none;display:flex;flex-direction:column;background:var(--white);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--shadow);transition:all .3s}
.blog-card-link:hover{transform:translateY(-4px);box-shadow:var(--shadow2);border-color:var(--border2)}
.blog-card-thumb{height:160px;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border);font-family:var(--font-head);font-size:18px;font-weight:800;letter-spacing:.5px;color:var(--blue)}
.blog-card-body{padding:24px;flex:1;display:flex;flex-direction:column}
.blog-card-tag{font-size:11px;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}
.blog-card-title{font-family:var(--font-head);font-size:20px;font-weight:800;color:var(--navy);line-height:1.25;margin-bottom:10px;letter-spacing:.2px}
.blog-card-desc{font-size:14px;color:var(--muted);line-height:1.65;flex:1}
.blog-card-meta{font-size:12px;color:var(--dim);margin-top:14px;display:flex;justify-content:space-between;align-items:center}
.blog-card-read{font-size:13px;font-weight:700;color:var(--blue);margin-top:16px;display:inline-flex;align-items:center;gap:5px}
.blog-card-link:hover .blog-card-read{gap:8px}
.faq-max{max-width:820px;margin:0 auto}
.faq-section-title{font-family:var(--font-head);font-size:26px;font-weight:800;color:var(--blue);margin:52px 0 16px;letter-spacing:.3px}
.faq-section-title:first-child{margin-top:0}
/* Thumb background colors per category */
.thumb-fireplace{background:linear-gradient(135deg,#fff5f0,#ffe8e0)}
.thumb-wire{background:linear-gradient(135deg,#f0f7ff,#daeeff)}
.thumb-height{background:linear-gradient(135deg,#f0fff4,#dcfce7)}
.thumb-mounts{background:linear-gradient(135deg,#fdf4ff,#ede9fe)}
.thumb-diy{background:linear-gradient(135deg,#fffbeb,#fef3c7)}
.thumb-walls{background:linear-gradient(135deg,#f0f9ff,#e0f2fe)}
@media(max-width:900px){.blog-grid-cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.blog-grid-cards{grid-template-columns:1fr}}

.about-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about-photo-box{background:var(--bg3);border:1px solid var(--border2);border-radius:16px;min-height:400px;display:flex;align-items:center;justify-content:center;font-size:100px;position:relative;overflow:hidden;box-shadow:var(--shadow2)}
.about-photo-box::before{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--blue),var(--blue2))}
.about-photo-caption{position:absolute;bottom:20px;left:20px;right:20px;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:10px;padding:14px 18px}
.about-photo-name{font-family:var(--font-head);font-size:22px;font-weight:800;color:var(--navy)}
.about-photo-title{font-size:13px;color:var(--blue2);font-weight:600;margin-top:2px}
.about-stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:24px}
.about-stat{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:18px;text-align:center;box-shadow:var(--shadow)}
.about-stat-num{font-family:var(--font-head);font-size:38px;font-weight:900;color:var(--blue2);line-height:1}
.about-stat-label{font-size:12px;color:var(--muted);margin-top:4px;text-transform:uppercase;letter-spacing:.8px}
.credential-list{display:flex;flex-direction:column;gap:10px;margin-top:24px}
.credential-item{display:flex;align-items:flex-start;gap:14px;padding:14px;background:var(--white);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow)}
.cred-icon{font-size:22px;flex-shrink:0}
.cred-text strong{display:block;font-size:14px;font-weight:700;color:var(--navy)}
.cred-text span{font-size:13px;color:var(--muted)}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:48px}
.value-card{text-align:center;padding:32px 20px;background:var(--white);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);transition:all .3s}
.value-card:hover{border-color:var(--border2);transform:translateY(-3px);box-shadow:var(--shadow2)}
.value-icon{font-size:40px;margin-bottom:14px}
.value-title{font-family:var(--font-head);font-size:22px;font-weight:800;margin-bottom:8px;color:var(--navy)}
.value-desc{font-size:13px;color:var(--muted);line-height:1.6}
@media(max-width:900px){.about-hero-grid{grid-template-columns:1fr;gap:40px}.values-grid{grid-template-columns:repeat(2,1fr)}.about-stats-row{grid-template-columns:repeat(3,1fr)}}
@media(max-width:580px){.values-grid{grid-template-columns:1fr}.about-stats-row{grid-template-columns:1fr 1fr}}

.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.contact-form-card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:40px;box-shadow:var(--shadow2)}
.form-title{font-family:var(--font-head);font-size:30px;font-weight:800;margin-bottom:8px;color:var(--navy)}
.form-sub{color:var(--muted);font-size:14px;margin-bottom:32px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.contact-info{display:flex;flex-direction:column;gap:16px}
.contact-card{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:22px 26px;display:flex;gap:16px;align-items:flex-start;transition:border-color .2s;box-shadow:var(--shadow)}
.contact-card:hover{border-color:var(--border2)}
.contact-card-icon{font-size:28px;flex-shrink:0}
.contact-card-label{font-size:11px;color:var(--muted);font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:5px}
.contact-card-value{font-size:19px;font-family:var(--font-head);font-weight:800;color:var(--navy)}
.contact-card-value a{color:inherit;transition:color .2s}
.contact-card-value a:hover{color:var(--blue2)}
.contact-card-note{font-size:13px;color:var(--muted);margin-top:3px}
.avail-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(14,168,79,.1);border:1px solid rgba(14,168,79,.3);color:var(--green);padding:4px 12px;border-radius:100px;font-size:12px;font-weight:700;margin-top:8px}
.avail-badge::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--green);animation:blink 1.4s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.hours-row{display:flex;justify-content:space-between;font-size:13px;padding:4px 0}
.hours-row .day{color:var(--muted)}
.hours-row .time{font-weight:700;color:var(--navy)}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr;gap:36px}.form-row{grid-template-columns:1fr}}

.note-box{background:var(--blue5);border:1px solid var(--border2);border-radius:10px;padding:22px 28px;margin-top:28px;color:var(--muted);font-size:14px;line-height:1.7}
.note-box strong{color:var(--navy)}
.addons-header{font-family:var(--font-head);font-size:34px;font-weight:800;margin-bottom:8px;color:var(--navy)}
.addons-sub{color:var(--muted);font-size:15px;margin-bottom:24px}
.compare-table{width:100%;border-collapse:collapse;margin-top:48px;border-radius:12px;overflow:hidden}
.compare-table th{background:var(--bg3);padding:16px 20px;text-align:left;font-size:13px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border)}
.compare-table td{padding:15px 20px;border-bottom:1px solid var(--border);font-size:14px;font-weight:500;color:var(--navy)}
.compare-table tr:last-child td{border:none}
.compare-table tr:hover td{background:var(--bg2)}
.check{color:#16a34a;font-size:18px}
.cross{color:var(--dim);font-size:18px}
.pay-methods{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px;justify-content:center}
.pay-chip{background:var(--white);border:1px solid var(--border);padding:10px 20px;border-radius:6px;font-size:13px;font-weight:600;color:var(--navy);box-shadow:var(--shadow)}
@media(max-width:680px){
  .compare-table{font-size:12px}
  .compare-table th,.compare-table td{padding:10px 10px}
  .addons-grid{grid-template-columns:1fr!important}
}

.services-full{display:flex;flex-direction:column;gap:80px;margin-top:64px}
.service-block{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.service-block.reverse{direction:rtl}
.service-block.reverse>*{direction:ltr}
.service-visual{background:var(--bg3);border:1px solid var(--border2);border-radius:14px;min-height:280px;display:flex;align-items:center;justify-content:center;font-size:90px;position:relative;overflow:hidden;box-shadow:var(--shadow)}
.service-visual::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(26,111,212,.08) 0%,transparent 70%)}
.service-number{font-family:var(--font-head);font-size:72px;font-weight:900;color:rgba(26,111,212,.1);line-height:1;margin-bottom:-8px}
.service-title{font-family:var(--font-head);font-size:36px;font-weight:800;margin-bottom:16px;color:var(--navy)}
.service-desc{color:var(--muted);font-size:15px;line-height:1.75;margin-bottom:20px}
.service-bullets{list-style:none;display:flex;flex-direction:column;gap:10px}
.service-bullets li{display:flex;align-items:flex-start;gap:10px;font-size:14px;font-weight:600;color:var(--navy)}
.service-bullets li::before{content:'✓';color:var(--blue2);font-size:16px;font-weight:900;flex-shrink:0;margin-top:1px}
.service-price-note{margin-top:24px;background:var(--blue5);border:1px solid var(--border2);border-radius:8px;padding:14px 18px;font-size:14px;color:var(--blue);font-weight:600}
.service-price-note a{color:inherit;text-decoration:underline}
@media(max-width:900px){
  .service-block,.service-block.reverse{grid-template-columns:1fr;direction:ltr;gap:32px}
  .service-visual{min-height:180px;font-size:64px}
  .services-full{gap:56px;margin-top:40px}
}

.areas-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.city-page-card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:32px;transition:all .3s;box-shadow:var(--shadow);display:block;text-decoration:none}
.city-page-card:hover{border-color:var(--border2);transform:translateY(-4px);box-shadow:var(--shadow2)}
.city-page-card .city-icon{font-size:40px;margin-bottom:14px}
.city-page-card h2{font-family:var(--font-head);font-size:26px;font-weight:800;color:var(--navy);margin-bottom:8px;letter-spacing:.3px}
.city-page-card p{font-size:14px;color:var(--muted);line-height:1.6;margin-bottom:16px}
.city-page-card .city-link{font-size:13px;font-weight:700;color:var(--blue);display:inline-flex;align-items:center;gap:5px}
@media(max-width:900px){.areas-card-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.areas-card-grid{grid-template-columns:1fr}}

.city-hero{padding:72px 0 56px;background:var(--bg2);border-bottom:1px solid var(--border);text-align:center}
.city-hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:28px}
.city-body{font-size:16px;color:var(--muted);line-height:1.8}
.city-body p{margin-bottom:16px}
.city-trust{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:40px}
.city-trust-item{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:20px;text-align:center;box-shadow:var(--shadow)}
.city-trust-icon{font-size:28px;margin-bottom:8px}
.city-trust-title{font-family:var(--font-head);font-size:17px;font-weight:800;color:var(--navy);margin-bottom:4px}
.city-trust-desc{font-size:12px;color:var(--muted)}
@media(max-width:680px){
  .city-trust{grid-template-columns:1fr 1fr}
  .city-hero-actions{flex-direction:column;align-items:center}
  .city-hero-actions .btn{width:100%;justify-content:center}
}
