/*
 * ClearView Cleaning Co. — Main Stylesheet
 * ==========================================
 * File:    css/style.css
 * Project: ClearView Cleaning Co. Website
 * Location: Birmingham, West Midlands, United Kingdom
 *
 * TABLE OF CONTENTS
 * -----------------
 * 1.  CSS Variables (colours, radii, shadows)
 * 2.  Reset & Base
 * 3.  Top Bar
 * 4.  Navigation
 * 5.  Buttons
 * 6.  Hero Section
 * 7.  Trust Bar
 * 8.  Services
 * 9.  Why Us
 * 10. Pricing
 * 11. Testimonials
 * 12. Process Steps
 * 13. Team
 * 14. Coverage
 * 15. FAQ
 * 16. Blog
 * 17. Contact
 * 18. Quote Band
 * 19. Newsletter
 * 20. Footer
 * 21. Portfolio
 * 22. Appointment
 * 23. Mobile Nav
 * 24. Scroll Animations
 * 25. Responsive Breakpoints
 */

:root {
  --sky: #000000;
  --sky-dark: #1a1a1a;
  --sky-light: #F4EBD4;
  --sky-pale: #FAF8F3;
  --charcoal: #0f0f0f;
  --charcoal-2: #1c1c1c;
  --slate: #555555;
  --silver: #999999;
  --smoke: #F8F5F0;
  --white: #ffffff;
  --gold: #D4AF37;
  --emerald: #10a37f;
  --radius: 10px;
  --radius-sm: 8px;
  --radius-lg: 16px;
  --shadow: 0 2px 20px rgba(0,0,0,0.06);
  --shadow-md: 0 8px 40px rgba(0,0,0,0.10);
  --shadow-lg: 0 20px 60px rgba(0,0,0,0.14);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;color:var(--charcoal);background:var(--white);line-height:1.65;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Playfair Display',serif;line-height:1.2;letter-spacing:-0.01em}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 24px}

/* TOP BAR */
.topbar{background:var(--charcoal);color:rgba(255,255,255,0.8);font-size:13px;padding:8px 0}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.topbar a{color:rgba(255,255,255,0.8);transition:.2s}
.topbar a:hover{color:#fff}
.topbar-left,.topbar-right{display:flex;align-items:center;gap:18px}
.badge-verified{background:var(--emerald);color:#fff;font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;letter-spacing:.3px}

/* NAV */
nav{position:sticky;top:0;z-index:999;background:rgba(255,255,255,0.96);backdrop-filter:blur(12px);border-bottom:1px solid #e8eef8;padding:0}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{display:flex;align-items:center;gap:12px;font-family:'Playfair Display',serif}
.logo-icon{width:44px;height:44px;background:linear-gradient(135deg,var(--sky),var(--sky-dark));border-radius:10px;display:flex;align-items:center;justify-content:center}
.logo-icon svg{width:24px;height:24px;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round}
.logo-text{display:flex;flex-direction:column;line-height:1.1}
.logo-main{font-size:17px;font-weight:700;color:var(--charcoal)}
.logo-sub{font-size:11px;color:var(--sky);font-family:'DM Sans',sans-serif;font-weight:500;letter-spacing:.4px}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none}
.nav-links a{padding:8px 14px;font-size:14px;font-weight:500;color:var(--slate);border-radius:8px;transition:.2s}
.nav-links a:hover,.nav-links a.active{color:var(--sky);background:var(--sky-pale)}
.nav-cta{display:flex;align-items:center;gap:10px}
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 24px;border-radius:var(--radius-sm);font-weight:600;font-size:14px;cursor:pointer;transition:all .28s ease;border:none;text-decoration:none;letter-spacing:0.4px}
.btn-primary{background:#000;color:#fff;box-shadow:inset 0 -2px 0 var(--gold),0 4px 20px rgba(0,0,0,0.22)}
.btn-primary:hover{background:var(--gold);color:#000;transform:translateY(-2px);box-shadow:0 8px 28px rgba(212,175,55,0.35)}
.btn-outline{background:transparent;color:var(--charcoal);border:1.5px solid var(--gold)}
.btn-outline:hover{background:var(--gold);color:#fff;border-color:var(--gold)}
.btn-white{background:#fff;color:#000;box-shadow:inset 0 -2px 0 var(--gold),0 4px 16px rgba(0,0,0,0.14)}
.btn-white:hover{background:#f9f5ec;color:#000;box-shadow:inset 0 -2px 0 var(--gold),0 6px 24px rgba(0,0,0,0.20);transform:translateY(-2px)}
.btn-gold{background:var(--gold);color:#fff;border:none;box-shadow:0 4px 18px rgba(212,175,55,0.30)}
.btn-gold:hover{background:#B8942A;color:#fff;transform:translateY(-2px);box-shadow:0 7px 26px rgba(212,175,55,0.42)}
.btn-quote{background:transparent;color:var(--charcoal);border:1.5px solid var(--charcoal);box-shadow:none}
.btn-quote:hover{background:#000;color:#fff;border-color:#000;transform:translateY(-2px)}
.btn-lg{padding:16px 36px;font-size:16px;border-radius:12px}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none}
.hamburger span{width:24px;height:2px;background:var(--charcoal);border-radius:2px;transition:.3s}

/* HERO */
.hero{background:linear-gradient(135deg,#000000 0%,#0a0a0a 50%,#111111 100%);padding:80px 0 60px;position:relative;overflow:hidden;min-height:88vh;display:flex;align-items:center}
.hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.025'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.hero-icons{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:0}
.hicon{position:absolute;color:#D4AF37}
.hicon-spray{width:80px;top:7%;left:2.5%;opacity:.28;transform:rotate(-12deg);animation:float-spray 5.5s ease-in-out infinite}
.hicon-mop{width:50px;bottom:4%;left:5%;opacity:.24;transform:rotate(6deg);animation:float-mop 4.8s ease-in-out infinite 0.9s}
.hicon-bucket{width:96px;bottom:6%;right:2%;opacity:.28;transform:rotate(-8deg);animation:float-bucket 6.3s ease-in-out infinite 1.6s}
.hicon-broom{width:72px;top:5%;right:4%;opacity:.24;transform:rotate(18deg);animation:float-broom 5.1s ease-in-out infinite 0.4s}
.hicon-squeegee{width:110px;top:52%;left:-1%;opacity:.20;transform:rotate(-28deg);animation:float-squeegee 7.2s ease-in-out infinite 2.2s}

/* Hero icon float keyframes — each preserves its unique rotation */
@keyframes float-spray{
  0%,100%{transform:rotate(-12deg) translate(0,0)}
  20%    {transform:rotate(-13deg) translate(5px,-14px)}
  50%    {transform:rotate(-11deg) translate(-6px,-22px)}
  80%    {transform:rotate(-13deg) translate(4px,-10px)}
}
@keyframes float-mop{
  0%,100%{transform:rotate(6deg) translate(0,0)}
  30%    {transform:rotate(7deg) translate(-8px,-18px)}
  65%    {transform:rotate(5deg) translate(7px,-24px)}
}
@keyframes float-bucket{
  0%,100%{transform:rotate(-8deg) translate(0,0)}
  25%    {transform:rotate(-6deg) translate(10px,-13px)}
  55%    {transform:rotate(-9deg) translate(-5px,-20px)}
  80%    {transform:rotate(-7deg) translate(8px,-9px)}
}
@keyframes float-broom{
  0%,100%{transform:rotate(18deg) translate(0,0)}
  35%    {transform:rotate(16deg) translate(-7px,-19px)}
  70%    {transform:rotate(19deg) translate(5px,-12px)}
}
@keyframes float-squeegee{
  0%,100%{transform:rotate(-28deg) translate(0,0)}
  40%    {transform:rotate(-26deg) translate(8px,-17px)}
  75%    {transform:rotate(-29deg) translate(-4px,-11px)}
}
/* Mobile hero review card — hidden on desktop, shown in 768px breakpoint */
.mobile-flowing-reviews{display:none;margin-bottom:20px}
.mob-testi-card{background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);border-radius:14px;padding:16px 18px;backdrop-filter:blur(10px);transition:opacity .4s}
.mob-rating{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.mob-stars{color:var(--gold);font-size:15px;letter-spacing:1px}
.mob-rating-text{font-size:12px;color:rgba(255,255,255,0.65);font-weight:500}
.mob-testi-text{font-size:13px;color:rgba(255,255,255,0.88);line-height:1.65;font-style:italic;margin:0 0 12px}
.mob-testi-author{display:flex;align-items:center;gap:10px}
.mob-testi-avatar{width:32px;height:32px;min-width:32px;background:var(--charcoal-2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff}
.mob-testi-name{font-size:13px;font-weight:600;color:#fff}
.mob-testi-loc{font-size:11px;color:rgba(255,255,255,0.5);margin-top:2px}
/* Floating action buttons — mobile only */
.mobile-fab-container{display:none;position:fixed;bottom:20px;right:16px;flex-direction:column;gap:12px;z-index:1000}
.fab-btn{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,0.25);transition:.2s;text-decoration:none}
.fab-btn svg{width:24px;height:24px}
.fab-call{background:var(--sky);color:#fff}
.fab-call:hover{background:var(--sky-dark);transform:scale(1.08)}
.fab-wa{background:#25d366;color:#fff}
.fab-wa:hover{background:#1da851}
/* Phone ring animation */
@keyframes fab-ring{
  0%,100%{transform:rotate(0) translateY(0)}
  3%{transform:rotate(8deg) translateY(-4px)}
  6%{transform:rotate(-8deg) translateY(-6px)}
  9%{transform:rotate(5deg) translateY(-3px)}
  12%{transform:rotate(0) translateY(0)}
}
.fab-call{animation:fab-ring 4s ease-in-out infinite}
/* Shared deco system for all sections */
.deco-wrap{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:0}
.dico{position:absolute;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2.5}
.dico-w{color:#D4AF37}
.dico-b{color:#D4AF37}

/* Gentle float for section deco icons — uses CSS translate to compose safely with inline transform */
@keyframes float-deco-a{0%,100%{translate:0 0}50%{translate:0 -11px}}
@keyframes float-deco-b{0%,100%{translate:0 0}50%{translate:0 -8px}}
@keyframes float-deco-c{0%,100%{translate:0 0}50%{translate:0 -14px}}
.deco-wrap .dico:nth-child(1){animation:float-deco-a 6s ease-in-out infinite}
.deco-wrap .dico:nth-child(2){animation:float-deco-b 7.5s ease-in-out infinite 1.4s}
.deco-wrap .dico:nth-child(3){animation:float-deco-c 5.8s ease-in-out infinite 2.8s}
.hero-orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}
.hero-orb-1{width:600px;height:600px;background:rgba(198,168,92,0.07);top:-200px;right:-200px}
.hero-orb-2{width:400px;height:400px;background:rgba(198,168,92,0.04);bottom:-100px;left:-100px}
.hero .container{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);border-radius:30px;padding:8px 16px;font-size:13px;color:rgba(255,255,255,0.85);margin-bottom:24px;backdrop-filter:blur(10px)}
.hero-badge span{color:var(--gold)}
.hero h1{font-size:clamp(38px,5vw,64px);color:#fff;margin-bottom:22px;letter-spacing:-1px}
.hero h1 em{color:var(--sky);font-style:normal;display:block}
.hero p{font-size:18px;color:rgba(255,255,255,0.72);margin-bottom:36px;max-width:480px;line-height:1.75}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:32px}
.hero-trust{display:flex;gap:24px;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,0.65)}
.trust-item svg{width:16px;height:16px;flex-shrink:0;color:var(--emerald)}
.hero-visual{position:relative;display:flex;justify-content:center;align-items:center}
.hero-card-stack{position:relative;width:100%}
.hero-main-card{background:rgba(255,255,255,0.07);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.12);border-radius:20px;padding:32px;color:#fff}
.hero-rating{display:flex;align-items:center;gap:10px;margin-bottom:20px}
.stars{display:flex;gap:2px;color:var(--gold)}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px}
.hero-stat{text-align:center;background:rgba(255,255,255,0.06);border-radius:12px;padding:16px 8px}
.hero-stat-num{font-family:'Playfair Display',serif;font-size:28px;font-weight:700;color:#fff;display:block}
.hero-stat-label{font-size:12px;color:rgba(255,255,255,0.55);margin-top:2px}

/* SECTION STYLES */
section{padding:72px 0}
.section-label{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--sky);letter-spacing:.8px;text-transform:uppercase;margin-bottom:12px}
.section-label::before{content:'';width:24px;height:2px;background:var(--sky);border-radius:2px}
h2.section-title{font-size:clamp(28px,4vw,44px);color:var(--charcoal);margin-bottom:16px}
.section-sub{font-size:17px;color:var(--slate);max-width:560px;line-height:1.75}
.text-center{text-align:center}
.text-center .section-label{justify-content:center}
.text-center .section-sub{margin:0 auto}

/* TRUST BAR */
.trust-bar{background:var(--sky-pale);border-top:1px solid #E8DBBF;border-bottom:1px solid #E8DBBF;padding:12px 0}
.trust-bar .container{display:flex;justify-content:center;gap:48px;flex-wrap:wrap;align-items:center}
.trust-item-bar{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500;color:var(--charcoal)}
.trust-item-bar svg{width:20px;height:20px;color:var(--sky)}

/* SERVICES */
.services{background:var(--smoke);position:relative;overflow:hidden}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;margin-top:32px}
.service-card{background:#fff;border-radius:var(--radius-lg);padding:0;border:1px solid #e8eef8;transition:.3s;cursor:pointer;position:relative;overflow:hidden;display:flex;flex-direction:column}
.service-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--gold)}
.svc-image-wrap{position:relative;aspect-ratio:16/10;overflow:hidden;background-color:var(--smoke);background-size:cover;background-position:center;background-repeat:no-repeat;z-index:1;transition:transform .45s ease}
.service-card:hover .svc-image-wrap{transform:scale(1.04)}
.service-card-body{padding:24px 28px 28px;position:relative;z-index:3}
.service-card h3{font-size:20px;margin-bottom:12px;color:var(--charcoal);transition:.3s}
.service-card p{font-size:14px;color:var(--slate);line-height:1.7;margin-bottom:0;transition:.3s}
.svc-link{font-size:14px;font-weight:600;color:var(--sky);display:flex;align-items:center;gap:6px;transition:.3s}
.svc-link::after{content:'→';transition:transform .2s}
.service-card:hover .svc-link::after{transform:translateX(4px)}

/* WHY US */
.why-us{background:#fff}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;margin-top:0}
.why-content{padding:0}
.why-features{display:grid;gap:18px;margin-top:24px}
.feature-item{display:flex;gap:18px;align-items:flex-start}
.feat-icon{width:48px;height:48px;background:var(--sky-pale);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.feat-icon svg{width:22px;height:22px;stroke:var(--sky);fill:none;stroke-width:2;stroke-linecap:round}
.feature-item h4{font-size:16px;font-family:'DM Sans',sans-serif;font-weight:600;color:var(--charcoal);margin-bottom:4px}
.feature-item p{font-size:14px;color:var(--slate);line-height:1.65}
.why-visual{position:relative}
.why-img-wrapper{background:linear-gradient(135deg,var(--charcoal),var(--charcoal-2));border-radius:24px;overflow:hidden;aspect-ratio:4/5;display:flex;align-items:center;justify-content:center;position:relative}
.why-img-bg{position:absolute;inset:0;background:rgba(198,168,92,0.06)}
.why-img-content{text-align:center;padding:40px;position:relative;z-index:1}
.big-number{font-family:'Playfair Display',serif;font-size:80px;font-weight:800;color:#fff;opacity:0.15;line-height:1;position:absolute;top:30px;left:30px}
.cat-logo{font-size:28px;font-weight:800;color:#10a37f}
.cat-text{font-size:12px;color:var(--slate);font-weight:500}
.why-float-card{position:absolute;right:-30px;bottom:40px;background:#fff;border-radius:16px;padding:20px 24px;box-shadow:var(--shadow-lg);width:200px}
.wfc-num{font-family:'Playfair Display',serif;font-size:36px;font-weight:700;color:var(--sky)}
.wfc-label{font-size:13px;color:var(--slate)}
.star-row{display:flex;gap:2px;color:var(--gold);margin-top:4px;font-size:14px}

/* PRICING */
.pricing{background:var(--smoke)}
.pricing-tabs{display:flex;gap:8px;justify-content:center;margin:30px 0 36px;flex-wrap:wrap}
.tab-btn{padding:10px 22px;border-radius:30px;font-size:14px;font-weight:500;color:var(--slate);border:1.5px solid #dde5f5;background:#fff;cursor:pointer;transition:.2s}
.tab-btn.active,.tab-btn:hover{background:var(--sky);color:#fff;border-color:var(--sky)}
.pricing-table{background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid #e8eef8}
.pricing-table table{width:100%;border-collapse:collapse}
.pricing-table th{background:var(--charcoal);color:#fff;padding:16px 24px;text-align:left;font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}
.pricing-table td{padding:16px 24px;font-size:15px;border-bottom:1px solid #f0f4fd}
.pricing-table tr:last-child td{border-bottom:none}
.pricing-table tr:hover td{background:var(--sky-pale)}
.pricing-table .price{font-weight:700;color:var(--sky);font-size:16px}
.pricing-table .tag{display:inline-flex;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600}
.tag-popular{background:#fef3c7;color:#92400e}
.tag-best{background:#d1fae5;color:#065f46}
.pricing-note{text-align:center;margin-top:16px;font-size:14px;color:var(--silver)}
.tab-content{display:none}
.tab-content.active{display:block}

/* TESTIMONIALS */
.testimonials{background:#fff;position:relative;overflow:hidden}
.testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px;margin-top:32px}
.testi-card{background:var(--smoke);border-radius:var(--radius-lg);padding:28px;border:1px solid #e8eef8;transition:.2s}
.testi-card:hover{box-shadow:var(--shadow-md);border-color:#E8DBBF;transform:translateY(-2px)}
.testi-stars{display:flex;gap:3px;color:var(--gold);margin-bottom:16px;font-size:16px}
.testi-text{font-size:15px;color:var(--slate);line-height:1.75;margin-bottom:20px;font-style:italic}
.testi-author{display:flex;align-items:center;gap:12px}
.testi-avatar{width:44px;height:44px;border-radius:50%;background:var(--charcoal);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:15px;font-family:'DM Sans',sans-serif;flex-shrink:0}
.testi-name{font-weight:600;font-size:14px;color:var(--charcoal)}
.testi-loc{font-size:12px;color:var(--silver)}
.testi-platform{font-size:11px;color:var(--emerald);font-weight:600;margin-top:2px}
.reviews-total{text-align:center;margin-top:30px;font-size:15px;color:var(--slate)}
.reviews-total strong{color:var(--charcoal)}

/* PROCESS */
.process{background:var(--charcoal);color:#fff;position:relative;overflow:hidden}
.process::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23ffffff' fill-opacity='0.02'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.process .section-label{color:rgba(255,255,255,0.6)}
.process .section-label::before{background:rgba(255,255,255,0.4)}
.process h2{color:#fff}
.process .section-sub{color:rgba(255,255,255,0.6)}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;margin-top:40px;position:relative}
.process-steps::before{content:'';position:absolute;top:36px;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.15),transparent)}
.process-step{text-align:center;position:relative}
.step-num{width:72px;height:72px;background:rgba(198,168,92,0.12);border:1px solid rgba(198,168,92,0.35);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;font-family:'Playfair Display',serif;font-size:28px;font-weight:700;color:var(--gold);transition:.3s}
.process-step:hover .step-num{background:var(--sky);color:#fff;border-color:var(--sky)}
.process-step h4{font-size:16px;font-family:'DM Sans',sans-serif;font-weight:600;color:#fff;margin-bottom:10px}
.process-step p{font-size:14px;color:rgba(255,255,255,0.55);line-height:1.65}

/* TEAM */
.team-section{background:var(--smoke)}
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:28px;margin-top:40px}
.team-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;border:1px solid #e8eef8;transition:.3s}
.team-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.team-avatar{aspect-ratio:1;background:var(--smoke);position:relative;overflow:hidden}
.team-avatar img{width:100%;height:100%;object-fit:cover;object-position:center 15%;display:block}
.team-info{padding:24px}
.team-info h3{font-size:18px;color:var(--charcoal);margin-bottom:4px}
.team-role{font-size:13px;color:var(--sky);font-weight:600;margin-bottom:12px}
.team-bio{font-size:14px;color:var(--slate);line-height:1.65}

/* COVERAGE */
.coverage{background:#fff}
.coverage-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;margin-top:40px}
.coverage-map{background:#fff;border-radius:24px;border:1px solid #e8eef8;display:flex;flex-direction:column;overflow:hidden;min-height:400px;box-shadow:var(--shadow)}
.map-embed-wrap{position:relative;flex:1;min-height:280px;width:100%;background:var(--smoke)}
.coverage-map-iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.map-caption{padding:18px 20px 20px;display:flex;flex-direction:column;gap:6px;border-top:1px solid #e8eef8;background:#fff}
.map-caption strong{font-size:16px;font-family:'Playfair Display',serif;color:var(--charcoal);font-weight:700}
.map-caption-sub{font-size:13px;color:var(--silver);line-height:1.5}
.map-caption-address{font-size:13px;color:var(--charcoal);font-weight:600;display:inline-flex;align-items:center;gap:6px;margin-top:4px;padding:8px 12px;background:var(--sky-pale);border:1px solid #E8DBBF;border-radius:8px;width:fit-content;max-width:100%}
.map-provider-hint{font-size:11px;color:var(--silver);margin:4px 0 0;line-height:1.45}
.map-provider-hint code{font-size:10px;background:var(--smoke);padding:2px 6px;border-radius:4px}
.map-open-google{font-size:13px;font-weight:600;color:var(--sky);margin-top:8px;width:fit-content}
.map-open-google:hover{color:var(--sky-dark);text-decoration:underline}
.coverage-areas{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:28px 0}
.area-tag{background:var(--sky-pale);border:1px solid #E8DBBF;border-radius:8px;padding:8px 14px;font-size:14px;color:var(--charcoal);font-weight:500;text-align:center}

/* FAQ */
.faq-section{background:var(--smoke);position:relative;overflow:hidden}
.faq-grid{max-width:760px;margin:40px auto 0}
.faq-item{background:#fff;border-radius:var(--radius);margin-bottom:12px;border:1px solid #e8eef8;overflow:hidden}
.faq-q{padding:20px 24px;font-size:16px;font-weight:600;color:var(--charcoal);cursor:pointer;display:flex;justify-content:space-between;align-items:center;user-select:none;transition:.2s}
.faq-q:hover{color:var(--sky)}
.faq-q svg{width:20px;height:20px;stroke:var(--silver);fill:none;stroke-width:2;flex-shrink:0;transition:transform .3s}
.faq-item.open .faq-q svg{transform:rotate(45deg);stroke:var(--sky)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s}
.faq-item.open .faq-a{max-height:600px;padding:0 24px 20px}
.faq-a p{font-size:15px;color:var(--slate);line-height:1.75}

/* BLOG */
.blog-section{background:#fff}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:28px;margin-top:40px}
.blog-card{background:var(--smoke);border-radius:var(--radius-lg);overflow:hidden;border:1px solid #e8eef8;transition:.3s}
.blog-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.blog-img{height:200px;background:linear-gradient(135deg,var(--charcoal),var(--charcoal-2));display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.blog-img-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,0.4))}
.blog-tag{position:absolute;top:16px;left:16px;background:var(--sky);color:#fff;font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px;letter-spacing:.3px;z-index:1}
.blog-img-icon{font-size:64px;opacity:.2}
.blog-content{padding:24px}
.blog-meta{font-size:12px;color:var(--silver);margin-bottom:10px;display:flex;gap:12px}
.blog-card h3{font-size:19px;color:var(--charcoal);margin-bottom:10px;line-height:1.35}
.blog-card p{font-size:14px;color:var(--slate);line-height:1.7;margin-bottom:16px}
.blog-read{font-size:14px;font-weight:600;color:var(--sky);display:flex;align-items:center;gap:6px}

/* CONTACT */
.contact{background:var(--charcoal);color:#fff;position:relative;overflow:hidden}
.contact::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.02'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4z'/%3E%3C/g%3E%3C/svg%3E")}
.contact .container{position:relative;z-index:1}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;margin-top:40px}
.contact-info h3{font-size:22px;margin-bottom:24px;color:#fff}
.contact-details{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}
.cd-item{display:flex;align-items:center;gap:14px;font-size:15px;color:rgba(255,255,255,0.75)}
.cd-icon{width:44px;height:44px;background:rgba(198,168,92,0.15);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cd-icon svg{width:20px;height:20px;stroke:var(--sky);fill:none;stroke-width:2;stroke-linecap:round}
.hours-grid{display:grid;gap:10px}
.hour-row{display:flex;justify-content:space-between;font-size:14px;color:rgba(255,255,255,0.65);padding:8px 0;border-bottom:1px solid rgba(255,255,255,0.08)}
.hour-row span:last-child{color:var(--sky);font-weight:500}
.contact-form{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);border-radius:20px;padding:36px;backdrop-filter:blur(10px)}
.contact-form h3{font-size:20px;color:#fff;margin-bottom:24px;text-align:center}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{margin-bottom:16px}
label.fl{display:block;font-size:11px;color:rgba(255,255,255,0.55);margin-bottom:8px;font-weight:700;text-align:left;text-transform:uppercase;letter-spacing:0.6px}
input.fi,select.fi,textarea.fi{width:100%;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.22);border-radius:10px;padding:13px 16px;font-size:14px;color:#fff;font-family:'DM Sans',sans-serif;transition:all .2s ease;outline:none;box-sizing:border-box}
input.fi::placeholder,textarea.fi::placeholder{color:rgba(255,255,255,0.35)}
input.fi:focus,select.fi:focus,textarea.fi:focus{border-color:var(--gold);background:rgba(212,175,55,0.07);box-shadow:0 0 0 3px rgba(212,175,55,0.12)}
select.fi option{background:var(--charcoal);color:#fff}
textarea.fi{resize:vertical;min-height:120px}
.privacy-note{font-size:12px;color:rgba(255,255,255,0.4);margin-top:12px;text-align:center}

/* QUOTE SECTION */
.quote-band{background:linear-gradient(135deg,#000000,#1a1a1a);padding:64px 0;text-align:center;position:relative;overflow:hidden}
.quote-band::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4z'/%3E%3C/g%3E%3C/svg%3E")}
.quote-band h2{font-size:clamp(26px,4vw,40px);color:#fff;margin-bottom:16px;position:relative;z-index:1}
.quote-band p{font-size:18px;color:rgba(255,255,255,0.8);margin-bottom:24px;position:relative;z-index:1}
.quote-band .btn-white{font-size:16px;padding:16px 40px}

/* NEWSLETTER */
.newsletter{background:var(--sky-pale);border-top:1px solid #E8DBBF;border-bottom:1px solid #E8DBBF;padding:48px 0}
.newsletter .container{display:flex;justify-content:space-between;align-items:center;gap:40px;flex-wrap:wrap}
.nl-text h3{font-size:22px;color:var(--charcoal);margin-bottom:6px}
.nl-text p{font-size:15px;color:var(--slate)}
.nl-form{display:flex;gap:10px;flex-wrap:wrap}
.nl-input{background:#FEFCF8;border:1.5px solid #C8C2B5;border-radius:10px;padding:13px 18px;font-size:14px;font-family:'DM Sans',sans-serif;color:var(--charcoal);width:280px;max-width:100%;outline:none;transition:all .2s ease}
.nl-input:focus{border-color:var(--gold);background:#fff;box-shadow:0 0 0 3px rgba(212,175,55,0.12)}

/* FOOTER */
footer{background:var(--charcoal);color:rgba(255,255,255,0.65);padding:50px 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-brand{display:flex;flex-direction:column;gap:20px}
.footer-desc{font-size:14px;line-height:1.75}
.footer-badges{display:flex;flex-direction:column;gap:10px}
.footer-badge{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:10px;padding:10px 16px;font-size:13px;display:flex;align-items:center;gap:8px}
.footer-badge svg{width:16px;height:16px;stroke:var(--sky);fill:none;stroke-width:2}
footer h4{font-size:14px;font-weight:700;color:#fff;margin-bottom:18px;font-family:'DM Sans',sans-serif;letter-spacing:.3px;text-transform:uppercase}
footer ul{list-style:none;display:flex;flex-direction:column;gap:10px}
footer ul a{font-size:14px;color:rgba(255,255,255,0.55);transition:.2s}
footer ul a:hover{color:#fff;padding-left:4px}
.footer-contact-list{list-style:none;display:flex;flex-direction:column;gap:12px}
.footer-contact-list li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:rgba(255,255,255,0.55)}
.footer-contact-list svg{width:16px;height:16px;stroke:var(--sky);fill:none;stroke-width:2;flex-shrink:0;margin-top:2px}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.08);padding:16px 0;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.footer-bottom-text{font-size:13px}
.footer-bottom-links{display:flex;gap:20px}
.footer-bottom-links a{font-size:13px;color:rgba(255,255,255,0.45);transition:.2s}
.footer-bottom-links a:hover{color:#fff}

/* PORTFOLIO */
.portfolio{background:var(--smoke);position:relative;overflow:hidden}
.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:40px}
.portfolio-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;border:1px solid #e8eef8;transition:.3s}
.portfolio-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.portfolio-before-after{display:grid;grid-template-columns:1fr 1fr;height:160px}
.portfolio-before{background:linear-gradient(135deg,#888,#555);display:flex;align-items:center;justify-content:center;position:relative}
.portfolio-after{background:linear-gradient(135deg,#1a1a1a,#333333);display:flex;align-items:center;justify-content:center;position:relative}
.ba-label{position:absolute;bottom:8px;left:0;right:0;text-align:center;font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:rgba(255,255,255,0.7)}
.portfolio-icon{font-size:40px;opacity:.3}
.portfolio-info{padding:20px}
.portfolio-tag{font-size:11px;font-weight:700;color:var(--sky);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.portfolio-info h3{font-size:16px;color:var(--charcoal);margin-bottom:6px}
.portfolio-info p{font-size:13px;color:var(--slate);line-height:1.6}

/* APPOINTMENT SECTION */
.appointment{background:#fff}
.appointment-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;margin-top:40px}
.packages{display:flex;flex-direction:column;gap:16px}
.package-card{background:var(--smoke);border-radius:var(--radius);padding:20px 24px;border:2px solid transparent;transition:.3s;cursor:pointer}
.package-card:hover,.package-card.selected{border-color:var(--sky);background:var(--sky-pale)}
.package-card h4{font-size:16px;font-weight:600;color:var(--charcoal);margin-bottom:4px}
.package-card .price{font-size:22px;font-weight:700;color:var(--sky);margin-bottom:6px}
.package-card p{font-size:13px;color:var(--slate)}
.package-badge{float:right;background:var(--sky);color:#fff;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px}
.appt-form{background:var(--smoke);border-radius:20px;padding:36px;border:1px solid #e8eef8}
.appt-form h3{font-size:20px;margin-bottom:24px}
.form-group-light label{display:block;font-size:11px;color:var(--charcoal);margin-bottom:8px;font-weight:700;text-transform:uppercase;letter-spacing:0.6px}
.form-group-light input,.form-group-light select,.form-group-light textarea{width:100%;background:#FEFCF8;border:1.5px solid #C8C2B5;border-radius:10px;padding:13px 16px;font-size:14px;color:var(--charcoal);font-family:'DM Sans',sans-serif;outline:none;transition:all .2s ease}
.form-group-light input:focus,.form-group-light select:focus,.form-group-light textarea:focus{border-color:var(--gold);background:#fff;box-shadow:0 0 0 3px rgba(212,175,55,0.12)}
.form-group-light{margin-bottom:14px}
.form-row-light{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* MOBILE NAV */
.mobile-nav{display:none;position:fixed;right:-50vw;top:0;width:50vw;height:100vh;z-index:9999;background:rgba(26,28,46,0.98);flex-direction:column;align-items:center;justify-content:flex-start;gap:8px;padding-top:80px;transition:right .3s ease;overflow-y:auto}
.mobile-nav.open{display:flex;right:0}
.mobile-nav a{font-size:22px;color:#fff;font-weight:600;padding:12px;opacity:.8;transition:.2s;width:100%;text-align:center}
.mobile-nav a:hover{opacity:1;color:var(--sky)}
.close-menu{position:fixed;top:20px;right:20px;background:none;border:none;font-size:32px;color:#fff;cursor:pointer;line-height:1;z-index:10000}

/* SCROLL ANIMATION */
.fade-in{opacity:0;transform:translateY(24px);transition:opacity .6s,transform .6s}
.fade-in.visible{opacity:1;transform:none}

/* SUCCESS MESSAGE */
.form-success{display:none;background:rgba(16,163,127,0.1);border:1px solid var(--emerald);border-radius:10px;padding:16px;color:var(--emerald);text-align:center;font-weight:600;margin-top:12px}

/* FORM VALIDATION */
.field-error{display:none;font-size:12px;color:#ff6b6b;margin-top:6px;font-weight:500;line-height:1.35}
.field-error.is-visible{display:block}
.form-group.has-field-error .fi,.form-group.has-field-error input.fi,.form-group.has-field-error select.fi,.form-group.has-field-error textarea.fi{border-color:#ff6b6b}
.form-group-light.has-field-error input,.form-group-light.has-field-error select,.form-group-light.has-field-error textarea{border-color:#ff6b6b}
.label-req{color:#ff6b6b;font-weight:700;margin-left:2px}

/* RESPONSIVE BREAKPOINTS */
/* Tablet: 1024px and below */
@media(max-width:1024px){
  .container{padding:0 20px}
  .nav-links{gap:2px}
  .nav-links a{padding:8px 12px;font-size:13px}
  .hero{min-height:75vh}
  .hero .container{grid-template-columns:1fr;gap:48px}
  .hero-visual{display:none}
  .hicon-squeegee,.hicon-mop{display:none}
  .hero h1{font-size:42px}
  .hero-badge{font-size:13px}
  .hero-trust{gap:16px}
  .services-grid{grid-template-columns:repeat(2,1fr);gap:20px}
  .service-card-body{padding:20px 22px 24px}
  .service-card h3{font-size:16px}
  .testi-grid{grid-template-columns:repeat(2,1fr);gap:20px}
  .portfolio-grid{grid-template-columns:repeat(2,1fr);gap:20px}
  .team-grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .blog-grid{grid-template-columns:1fr}
  .blog-card{flex-direction:row;gap:24px}
  .blog-img{width:200px;min-height:140px;flex-shrink:0}
  .faq-grid{grid-template-columns:1fr}
  .why-grid,.coverage-grid{grid-template-columns:1fr;gap:40px}
  .appointment-grid{grid-template-columns:1fr;gap:40px}
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .hero-stats{grid-template-columns:repeat(3,1fr);gap:12px}
  section{padding:52px 0}
}

/* Mobile: 768px and below */
@media(max-width:768px){
  html{font-size:15px}
  .container{padding:0 16px}
  .topbar{padding:6px 0;font-size:12px}
  .topbar .container{justify-content:center;flex-direction:column;gap:8px;text-align:center}
  .topbar-left,.topbar-right{display:flex;justify-content:center}
  .topbar-right{display:flex !important;gap:12px;flex-wrap:wrap;font-size:11px}
  
  /* Navigation */
  nav{height:auto;padding:12px 0}
  .nav-inner{height:auto;padding:8px 0;flex-wrap:wrap;justify-content:space-between}
  .logo{gap:8px}
  .logo-icon{width:38px;height:38px}
  .logo-icon svg{width:20px;height:20px}
  .logo-main{font-size:15px}
  .logo-sub{font-size:10px}
  .nav-links{display:none}
  .nav-cta{display:none}
  .hamburger{display:flex}
  .mobile-fab-container{display:flex}
  
  /* Hero */
  section{padding:52px 0}
  .hero{padding:40px 0 30px;min-height:auto}
  .hero h1{font-size:28px;line-height:1.3}
  .hero .container{gap:20px}
  .hero-badge{font-size:12px;padding:6px 12px}
  .hero-content p{font-size:14px}
  .hero-actions{flex-direction:column;width:100%;gap:12px}
  .hero-actions .btn{width:100%;justify-content:center}
  .hero-trust{flex-direction:column;gap:12px}
  .trust-item{gap:8px;font-size:13px}
  .mobile-flowing-reviews{display:block}
  .hero-stats{grid-template-columns:1fr;gap:16px;margin-top:24px}
  .hero-stat-num{font-size:28px}
  .hero-stat-label{font-size:12px}
  
  /* Services */
  .services-grid{grid-template-columns:1fr;gap:16px}
  .service-card h3{font-size:15px;margin-bottom:8px}
  .service-card p{font-size:13px;line-height:1.5}
  
  /* Section Titles */
  .section-label{font-size:11px;letter-spacing:.4px}
  .section-title{font-size:24px;line-height:1.3;margin-bottom:8px}
  .section-sub{font-size:13px;line-height:1.5}
  
  /* Testimonials */
  .testi-grid{grid-template-columns:1fr;gap:16px}
  .testi-card{padding:16px}
  .testi-stars{font-size:14px;margin-bottom:8px}
  .testi-text{font-size:13px;line-height:1.5;margin-bottom:12px}
  .testi-author{gap:8px}
  .testi-avatar{width:36px;height:36px;font-size:13px}
  .testi-name{font-size:13px}
  .testi-loc{font-size:11px}
  .testi-platform{font-size:10px}
  
  /* Portfolio */
  .portfolio-grid{grid-template-columns:1fr;gap:16px}
  .portfolio-before-after{height:120px}
  .portfolio-icon{font-size:32px}
  .portfolio-info{padding:16px}
  .portfolio-tag{font-size:10px}
  .portfolio-info h3{font-size:15px}
  
  /* Team */
  .team-grid{grid-template-columns:1fr;gap:20px}
  .team-card h3{font-size:16px}
  .team-role{font-size:12px;margin-bottom:8px}
  .team-bio{font-size:13px;line-height:1.5}
  
  /* Coverage */
  .coverage-grid{grid-template-columns:1fr;gap:30px}
  .coverage-areas{gap:8px;flex-wrap:wrap}
  .area-tag{font-size:12px;padding:6px 10px}
  .map-embed-wrap{min-height:240px}
  .map-caption{padding:14px 16px 16px}
  
  /* Blog */
  .blog-grid{grid-template-columns:1fr;gap:20px}
  .blog-card{flex-direction:column;gap:0}
  .blog-img{width:100%;height:180px;border-radius:12px 12px 0 0}
  .blog-content{padding:16px}
  .blog-meta{font-size:11px;gap:4px}
  .blog-meta span{display:none}
  .blog-meta span:nth-child(1){display:inline}
  .blog-read{font-size:13px}
  
  /* FAQ */
  .faq-grid{grid-template-columns:1fr}
  .faq-item{margin-bottom:12px}
  .faq-q{font-size:14px;padding:16px;font-weight:600}
  .faq-q svg{width:18px;height:18px}
  .faq-item.open .faq-a{max-height:500px;padding:0 16px 16px}
  .faq-a p{font-size:13px;color:var(--slate);line-height:1.6;margin:0}
  
  /* Contact */
  .contact-grid{grid-template-columns:1fr;gap:30px}
  .contact-info h3,.contact-form h3{font-size:15px;margin-bottom:12px;text-align:center}
  .contact-info{padding:0}
  .contact-form{padding:14px;border-radius:16px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1)}
  .contact-details{gap:12px}
  .cd-item{gap:8px;font-size:13px}
  .cd-icon{width:20px;height:20px}
  .cd-icon svg{width:20px;height:20px}
  .hours-grid{gap:8px}
  .hour-row{font-size:12px;gap:16px;padding:6px 0}
  .form-row,.form-row-light{grid-template-columns:1fr;gap:6px}
  .form-group,.form-group-light{margin-bottom:8px}
  label.fl,.form-group label,.form-group-light label{font-size:11px;margin-bottom:2px;text-align:left}
  .form-group input,.form-group select,.form-group textarea,
  .form-group-light input,.form-group-light select,.form-group-light textarea,
  input.fi,select.fi,textarea.fi{font-size:12px;padding:7px 9px;max-width:100%;box-sizing:border-box}
  .form-group textarea,.form-group-light textarea,textarea.fi{min-height:70px;resize:vertical}
  .btn{padding:10px 16px;font-size:12px;gap:6px;width:100%;justify-content:center}
  .btn-lg{padding:12px 20px;font-size:13px}
  .privacy-note{text-align:center}
  
  /* Appointment */
  .appointment-grid{grid-template-columns:1fr;gap:30px}
  .packages{gap:12px}
  .package-card{padding:16px;margin-bottom:8px}
  .package-card h4{font-size:15px}
  .package-card .price{font-size:18px}
  .package-card p{font-size:12px}
  .appt-form{padding:20px;border-radius:16px}
  .appt-form h3{font-size:16px;margin-bottom:16px}
  
  /* Quote Band */
  #quote{padding:20px 0}
  #quote h2{font-size:20px;margin-bottom:8px}
  #quote p{font-size:13px;margin-bottom:12px}
  
  /* Footer */
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .footer-brand{margin-bottom:16px}
  .footer-brand .logo{margin-bottom:12px}
  .footer-brand .logo-main{font-size:15px}
  .footer-desc{font-size:12px;line-height:1.6;margin-bottom:12px}
  .footer-badge{font-size:11px;gap:6px;flex-direction:column;align-items:flex-start}
  .footer-badge svg{width:16px;height:16px}
  footer h4{font-size:14px;margin-bottom:12px}
  footer a{font-size:12px}
  footer li{gap:8px;margin-bottom:8px}
  .footer-contact-list svg{width:16px;height:16px}
  .footer-bottom-text{font-size:11px}
  .footer-bottom-links{gap:8px;flex-wrap:wrap}
  .footer-bottom-links a{font-size:11px}
}

/* Small Mobile: 480px and below */
@media(max-width:480px){
  .container{padding:0 14px}
  .topbar{padding:4px 0;font-size:11px}
  .topbar-right{font-size:10px;gap:8px}
  
  /* Navigation */
  .logo{gap:6px}
  .logo-icon{width:32px;height:32px}
  .logo-icon svg{width:18px;height:18px}
  .logo-main{font-size:14px}
  .logo-sub{font-size:9px}
  
  /* Hero */
  .hero{padding:30px 0 20px}
  .hero h1{font-size:22px;line-height:1.2}
  .hero-badge{font-size:11px;padding:4px 8px}
  .hero-content p{font-size:13px;line-height:1.5}
  .hero-actions{gap:10px}
  .btn{padding:10px 16px;font-size:12px}
  .hero-stats{display:none}
  
  /* Services Grid */
  .services-grid{grid-template-columns:1fr;gap:12px}
  .service-card-body{padding:16px 18px 20px}
  .service-card h3{font-size:14px}
  .service-card p{font-size:12px}
  
  /* Titles */
  .section-title{font-size:20px}
  .section-sub{font-size:12px}
  
  /* Testimonials */
  .testi-grid{grid-template-columns:1fr}
  .testi-card{padding:12px}
  .testi-text{font-size:12px}
  .testi-avatar{width:32px;height:32px;font-size:11px}
  .testi-name{font-size:12px}
  
  /* Portfolio */
  .portfolio-before-after{height:100px}
  .portfolio-icon{font-size:28px}
  .portfolio-info{padding:12px}
  .portfolio-info h3{font-size:13px}
  
  /* Team */
  .team-grid{grid-template-columns:1fr}
  .team-card h3{font-size:14px}
  
  /* FAQ */
  .faq-q{font-size:13px;padding:10px}
  
  /* Contact */
  .contact-info,.contact-form{padding:0}
  .cd-item{font-size:12px}
  .form-group input,.form-group-light input{font-size:16px;padding:10px 12px;box-sizing:border-box}
  .form-group textarea,.form-group-light textarea{font-size:16px;padding:10px 12px;box-sizing:border-box}
  
  /* Footer */
  .footer-brand .logo{gap:6px}
  .footer-brand .logo-main{font-size:13px}
  .footer-desc{font-size:11px}
  footer h4{font-size:13px}
  footer a{font-size:11px}
  
  /* Mobile Nav */
  .mobile-nav a{font-size:18px;padding:10px}
  .close-menu{font-size:28px;top:16px;right:16px}
  
  /* Spacing */
  section{padding:36px 0}
  .hero .container,.services .container{gap:16px}
}

/* ================================================
   LUXURY THEME — GOLD ACCENT & PRIMARY OVERRIDES
   ================================================ */

/* Section labels — gold accent */
.section-label{color:var(--gold)}
.section-label::before{background:var(--gold)}

/* Logo sub tagline — gold */
.logo-sub{color:var(--gold)}

/* Nav active / hover — gold text on cream */
.nav-links a:hover,.nav-links a.active{color:var(--gold);background:var(--sky-pale)}

/* Mobile nav hover — gold */
.mobile-nav a:hover{color:var(--gold);opacity:1}

/* Hero h1 em highlight — gold on dark hero */
.hero h1 em{color:var(--gold)}

/* Hero trust check icons — gold */
.trust-item svg{color:var(--gold)}

/* Trust bar icons — gold */
.trust-item-bar svg{color:var(--gold)}

/* Service card link — gold */
.svc-link{color:var(--gold)}

/* Feature icon — cream bg, gold icon */
.feat-icon{background:var(--sky-pale)}
.feat-icon svg{stroke:var(--gold)}

/* Why floating card number — gold */
.wfc-num{color:var(--gold)}

/* Pricing price — gold */
.pricing-table .price{color:var(--gold)}

/* Pricing tab active — black with gold underline accent */
.tab-btn.active,.tab-btn:hover{background:#000;color:#fff;border-color:#000;box-shadow:inset 0 -2px 0 var(--gold)}

/* FAQ open toggle icon — gold */
.faq-item.open .faq-q svg{stroke:var(--gold)}
.faq-q:hover{color:var(--gold)}

/* Team role — gold */
.team-role{color:var(--gold)}

/* Testimonials: platform badge, stars — warm */
.testi-platform{color:var(--gold)}

/* Process step hover — gold fill */
.process-step:hover .step-num{background:var(--gold);color:#000;border-color:var(--gold)}

/* Blog tag — black pill */
.blog-tag{background:#000;color:#fff}

/* Blog read link — gold */
.blog-read{color:var(--gold)}

/* Blog second card override — neutral dark bg */
.blog-grid .blog-card:nth-child(2) .blog-img{background:linear-gradient(135deg,#1a1a1a,#2a2a2a) !important}

/* Section deco SVG colour — force all inline-styled dico elements to classic gold */
.deco-wrap .dico{color:#D4AF37 !important}

/* Portfolio tag — gold */
.portfolio-tag{color:var(--gold)}

/* Coverage area tag — warm cream */
.area-tag{background:var(--sky-pale);border-color:#E8DBBF}

/* Map open link — gold */
.map-open-google{color:var(--gold)}

/* Contact hours value — gold */
.hour-row span:last-child{color:var(--gold);font-weight:500}

/* Contact icon — warm gold accent */
.cd-icon{background:rgba(198,168,92,0.12)}
.cd-icon svg{stroke:var(--gold)}

/* Contact form focus state */
.form-group-light input:focus,.form-group-light select:focus,.form-group-light textarea:focus{border-color:var(--gold)}

/* Footer badges & icons — gold */
.footer-badge svg{stroke:var(--gold)}
.footer-contact-list svg{stroke:var(--gold)}

/* Footer links hover — gold */
footer ul a:hover{color:var(--gold);padding-left:4px}

/* FAB call button — black (premium) */
.fab-call{background:#000}
.fab-call:hover{background:#1a1a1a;transform:scale(1.08)}

/* Package card selection — gold border */
.package-card:hover,.package-card.selected{border-color:var(--gold);background:var(--sky-pale)}
.package-card .price{color:var(--gold)}

/* Appointment form focus — gold */
.appt-form .form-group-light input:focus,.appt-form .form-group-light select:focus{border-color:var(--gold)}

/* Inline testimonial avatar override — black instead of hardcoded blue gradient */
#testimonial-avatar{background:var(--charcoal) !important}

/* Social media branded buttons — Follow Us panel */
.social-btn{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;border-radius:50px;font-size:14px;font-weight:600;color:#fff;text-decoration:none;transition:all .2s ease;font-family:'DM Sans',sans-serif;line-height:1}
.social-fb{background:#1877F2}
.social-fb:hover{background:#0d65d9;transform:translateY(-2px);box-shadow:0 4px 14px rgba(24,119,242,0.45)}
.social-ig{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}
.social-ig:hover{filter:brightness(1.12);transform:translateY(-2px);box-shadow:0 4px 14px rgba(220,39,67,0.40)}

/* ================================================
   FINAL POLISH — micro-refinements
   ================================================ */

/* 1. Crisp antialiased text rendering on all platforms */
body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.7}

/* 2. Heading line-height — better for two-line headings */
h1,h2,h3,h4{line-height:1.25}

/* 3. On-brand text selection */
::selection{background:rgba(212,175,55,0.18);color:var(--charcoal)}

/* 4. Nav — subtle depth below the sticky bar */
nav{box-shadow:0 2px 12px rgba(0,0,0,0.05)}

/* 5. Button — normalized transition, refined letter-spacing */
.btn{transition:all .25s ease;letter-spacing:0.3px}

/* 6. Outline button hover — lift consistent with all other buttons */
.btn-outline:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(212,175,55,0.22)}

/* 7. Trust bar — extra breathing room */
.trust-bar{padding:16px 0}

/* 8. Section subtitle — clear vertical gap from title */
.section-sub{margin-top:8px}

/* 9. Hero glass card — depth shadow */
.hero-main-card{box-shadow:0 12px 48px rgba(0,0,0,0.28)}

/* 10. Service card hover — normalize lift to match other cards */
.service-card:hover{transform:translateY(-4px)}

/* 11. Testimonial card — harmonized transition */
.testi-card{transition:.25s ease}

/* 12. Blog card heading — match service card h3 size */
.blog-card h3{font-size:20px}

/* 13. Team card heading — match other card headings */
.team-info h3{font-size:20px}

/* 14. Process step — scale micro-interaction on hover */
.process-step:hover .step-num{transform:scale(1.06)}

/* 15. FAQ open item — shadow gives visual grouping */
.faq-item{transition:box-shadow .25s ease}
.faq-item.open{box-shadow:var(--shadow)}

/* 16. Footer links — translateX instead of padding-left to avoid layout shift */
footer ul a{transition:color .2s ease,transform .2s ease}
footer ul a:hover{padding-left:0;transform:translateX(4px)}

/* 17. Reviews total — align to grid spacing system */
.reviews-total{margin-top:24px}

/* 18. Scroll entrance — subtler upward translate */
.fade-in{transform:translateY(18px)}

/* 19. Package card — harmonized transition */
.package-card{transition:.25s ease}

/* 20. Area tags — subtle hover state */
.area-tag{transition:border-color .2s ease,background .2s ease}
.area-tag:hover{border-color:var(--gold);background:var(--sky-light)}