/* ================================================
EA Spotless Rides — Global Stylesheet
easpotlessrides.com
================================================ */

/* ===== VARIABLES ===== */
:root{--gold:#D4A017;--gold-light:#F0C040;--black:#0a0a0a;--dark:#111111;--dark2:#1a1a1a;--dark3:#222222;--gray:#888;--white:#ffffff;--font-display:'Barlow Condensed',sans-serif;--font-body:'Barlow',sans-serif;}

/* ===== RESET ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body{background:var(--black);color:var(--white);font-family:var(--font-body);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}

/* ===== NAV ===== */
nav{position:sticky;top:0;z-index:100;background:rgba(10,10,10,0.96);border-bottom:1px solid var(--dark3);padding:0
1.5rem;display:flex;align-items:center;justify-content:space-between;height:64px;backdrop-filter:blur(8px);}
.nav-logo{display:flex;align-items:center;}
.nav-logo img{height:36px;width:auto;display:block;}
.nav-links{display:flex;gap:1.5rem;font-size:14px;font-weight:500;color:var(--gray);}
.nav-links a:hover{color:var(--white);}
.nav-links a.active{color:var(--white);}
.nav-cta{background:var(--gold);color:var(--black);font-family:var(--font-display);font-weight:700;font-size:14px;letter-spacing:.05em;text-transform:uppercase;padding:9px
20px;border-radius:4px;}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;}
.hamburger span{width:22px;height:2px;background:var(--white);border-radius:2px;}
.mobile-menu{display:none;position:fixed;top:64px;left:0;right:0;background:var(--dark);border-bottom:1px solid
var(--dark3);z-index:99;flex-direction:column;padding:1rem 1.5rem 1.5rem;}
.mobile-menu a{padding:.75rem 0;border-bottom:1px solid var(--dark3);font-size:16px;color:var(--gray);}
.mobile-menu.open{display:flex;}

/* ===== NAV DROPDOWN ===== */
.nav-dropdown{position:relative;}
.nav-dropdown>a{display:flex;align-items:center;gap:4px;}
.nav-dropdown>a::after{content:'▾';font-size:10px;margin-top:1px;}
.dropdown-menu{display:none;position:absolute;top:100%;left:0;background:var(--dark2);border:1px solid
var(--dark3);border-radius:6px;min-width:180px;padding:.5rem 0;z-index:200;box-shadow:0 8px 24px
rgba(0,0,0,.5);margin-top:0;}
.dropdown-menu::before{content:'';position:absolute;top:-10px;left:0;right:0;height:10px;}
.nav-dropdown:hover .dropdown-menu{display:block;}
.dropdown-menu a{display:block;padding:.6rem 1rem;font-size:13px;color:var(--gray);white-space:nowrap;transition:color
.15s,background .15s;}
.dropdown-menu a:hover{color:var(--white);background:var(--dark3);}

/* ===== LAYOUT ===== */
section{padding:3.5rem 1.5rem;}
.container{max-width:960px;margin:0 auto;}

/* ===== TYPOGRAPHY ===== */
.section-label{font-family:var(--font-display);font-size:12px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:.75rem;}
.section-title{font-family:var(--font-display);font-weight:800;font-size:clamp(30px,5vw,46px);text-transform:uppercase;line-height:1;margin-bottom:1rem;}
.section-sub{color:#aaa;font-size:16px;max-width:580px;line-height:1.7;}

/* ===== BUTTONS ===== */
.btn-primary{background:var(--gold);color:var(--black);font-family:var(--font-display);font-weight:700;font-size:16px;letter-spacing:.06em;text-transform:uppercase;padding:14px
28px;border-radius:4px;transition:background .2s;display:inline-block;}
.btn-primary:hover{background:var(--gold-light);}
.btn-secondary{border:1px solid
rgba(255,255,255,.2);color:var(--white);font-family:var(--font-display);font-weight:600;font-size:16px;letter-spacing:.06em;text-transform:uppercase;padding:14px
28px;border-radius:4px;display:inline-block;transition:border-color .2s,color
.2s;}.btn-secondary:hover{border-color:var(--gold);}
.btn-dark{background:var(--black);color:var(--white);font-family:var(--font-display);font-weight:700;font-size:17px;letter-spacing:.06em;text-transform:uppercase;padding:16px
36px;border-radius:4px;display:inline-block;transition:background .2s;}
.btn-dark:hover{background:var(--dark2);}

/* ===== HERO BASE ===== */
.hero{ position:relative; display:flex; align-items:center; padding:6rem 1.5rem 4rem; overflow:hidden; background-size:cover; background-position:center; background-repeat:no-repeat; }
.hero::before{ content:''; position:absolute; inset:0; background:linear-gradient( rgba(0,0,0,.65), rgba(0,0,0,.80) ); z-index:0; pointer-events:none; }
.hero-content{ position:relative; z-index:1; max-width:960px; margin:0 auto; width:100%; }
.booking-hero { position: relative; display: flex; align-items: center; padding: 5rem 1.5rem 3rem; overflow: hidden; background-size: cover; background-position: center; background-repeat: no-repeat; min-height: 360px; }
.booking-hero::before { content: ''; position: absolute; inset: 0; background: linear-gradient(rgba(0,0,0,.55), rgba(0,0,0,.65)); z-index: 0; pointer-events: none; }
.booking-hero .hero-content { position: relative; z-index: 1; }
.hero-badge{ display:inline-block; background:rgba(212,160,23,.15); border:1px solid rgba(212,160,23,.4); color:var(--gold); font-family:var(--font-display); font-size:13px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; padding:6px 14px; border-radius:2px; margin-bottom:1.5rem; }
.hero h1{ font-family:var(--font-display); font-weight:800; font-size:clamp(48px,8vw,88px); line-height:.95; text-transform:uppercase; margin-bottom:1.5rem; }
.hero h1 em{ font-style:normal; color:var(--gold); display:block; }
.hero-sub{ font-size:17px; color:#ddd; max-width:500px; margin-bottom:2.5rem; line-height:1.7; }
.hero-actions{ display:flex; gap:1rem; flex-wrap:wrap; }
.hero-stats{ display:flex; gap:2.5rem; margin-top:3rem; padding-top:2rem; border-top:1px solid rgba(255,255,255,.15); flex-wrap:wrap; }
.stat-num{ font-family:var(--font-display); font-weight:800; font-size:30px; color:var(--gold); line-height:1; }
.stat-label{ font-size:13px; color:var(--gray); margin-top:3px; }

/* ===== HERO BACKGROUNDS ===== */
.hero-index{ background-image:url('./hero-bg.jpg'); min-height:580px; }
.hero-detailing{ background-image:url("https://images.unsplash.com/photo-1520340356584-f9917d1eea6f?fm=jpg&q=80&w=1600&fit=crop"); min-height:460px; }
.hero-tint{ background-image:url("https://images.unsplash.com/photo-1690022676526-2762ac826843?fm=jpg&q=80&w=1600&fit=crop"); min-height:520px; }
.hero-pressure-washing{ background-image:url("https://images.unsplash.com/photo-1623625434531-d130448273c1?fm=jpg&q=80&w=1600&fit=crop"); min-height:460px; }
.hero-ceramic{ background-image:url("https://images.unsplash.com/photo-1711513503795-05712fef15cd?fm=jpg&q=80&w=1600&fit=crop"); min-height:420px; }
.hero-boat-rv{ background-image:url("https://images.unsplash.com/photo-1684849843504-7919ac9ede9c?fm=jpg&q=80&w=1600&fit=crop"); min-height:420px; }
.hero-golf-cart{ background-image:url("https://images.unsplash.com/photo-1699135801906-ad078d7a6e76?fm=jpg&q=80&w=1600&fit=crop"); min-height:420px; }
.hero-program{ background-image:url("https://images.unsplash.com/photo-1449965408869-eaa3f722e40d?fm=jpg&q=80&w=1600&fit=crop"); min-height:460px; }
.hero-city{ background-image:url("https://images.unsplash.com/photo-1526726538690-5cbf956ae2fd?w=1600&q=85"); min-height:380px; }
.hero-service-area{ background-image:url("https://images.unsplash.com/photo-1449965408869-eaa3f722e40d?fm=jpg&q=80&w=1600&fit=crop"); min-height:360px; }
.hero-faq{ background-image:url("https://images.unsplash.com/photo-1520340356584-f9917d1eea6f?fm=jpg&q=80&w=1600&fit=crop"); min-height:360px; }

/* City pages use relative path from /cities/ folder */
.cities .hero-index,
.hero-index-city{ background-image:url("https://images.unsplash.com/photo-1614972973290-3b2f6f6cab49?fm=jpg&q=80&w=1600&fit=crop"); min-height:580px; }

/* ===== SERVICES GRID (homepage) ===== */
.services-section{background:var(--black);}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;margin-top:2.5rem;}
.service-card{background:var(--dark2);border:1px solid var(--dark3);border-radius:8px;padding:2rem
1.5rem;transition:border-color .2s,transform .15s;}
.service-card:hover{border-color:rgba(212,160,23,.4);transform:translateY(-2px);}
.service-cat{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem;}
.service-name{font-family:var(--font-display);font-weight:800;font-size:22px;text-transform:uppercase;margin-bottom:.75rem;}
.service-desc{font-size:14px;color:#999;line-height:1.6;margin-bottom:1.5rem;}
.service-link{font-family:var(--font-display);font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.06em;color:var(--gold);}
.service-link:hover{color:var(--gold-light);}

/* ===== CITY PAGE LAYOUTS ===== */
.service-section{background:var(--black);padding:3.5rem 1.5rem;}
.service-block{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;}
.service-visual{background:var(--dark2);border:1px solid var(--dark3);border-radius:8px;padding:2rem
1.5rem;position:relative;overflow:hidden;}
.service-visual-title{font-family:var(--font-display);font-weight:800;font-size:52px;text-transform:uppercase;color:rgba(212,158,23,0.8);line-height:1;margin-bottom:1rem;}
.reverse{direction:rtl;}
.reverse>*{direction:ltr;}
.areas-inner{max-width:960px;margin:0 auto;}
.current{color:var(--white);font-weight:600;}
.gold{color:var(--gold);}

/* ===== SPEC ROWS (city + tint pages) ===== */
.spec-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid
var(--dark3);font-size:14px;}
.spec-row:last-child{border-bottom:none;}
.spec-key{color:var(--gray);}
.spec-val{font-weight:600;color:var(--white);}
.spec-val.gold{color:var(--gold);}

/* ===== INCLUDES LIST ===== */
.includes-list{list-style:none;display:flex;flex-direction:column;gap:.6rem;margin-top:1.5rem;}
.includes-list li{font-size:14px;color:#ccc;display:flex;align-items:flex-start;gap:8px;line-height:1.5;}
.includes-list li::before{content:'';width:16px;height:16px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%23D4A017' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M3 8l3.5 3.5L13 4'/%3E%3C/svg%3E") center/contain no-repeat;flex-shrink:0;margin-top:1px;}

/* ===== TRUST BAR ===== */
.trust-bar{background:var(--dark2);border-top:1px solid var(--dark3);padding:1.25rem
1.5rem;display:flex;flex-wrap:wrap;justify-content:center;gap:2rem;}
.trust-item{display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#ccc;}
.trust-item
svg{width:18px;height:18px;stroke:var(--gold);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}

/* ===== CTA STRIP ===== */
.cta-strip{background:var(--gold);padding:4rem 1.5rem;text-align:center;}
.cta-strip
h2{font-family:var(--font-display);font-weight:800;font-size:clamp(28px,5vw,48px);text-transform:uppercase;color:var(--black);margin-bottom:.75rem;line-height:1;}
.cta-strip p{color:rgba(0,0,0,.65);font-size:16px;margin-bottom:2rem;}
.cta-contact{margin-top:1.25rem;font-size:15px;color:rgba(0,0,0,.6);}
.cta-contact a{color:var(--black);font-weight:600;}

/* ===== FOOTER ===== */
footer{background:var(--black);border-top:1px solid var(--dark3);padding:3rem 1.5rem 2rem;}
.footer-inner{max-width:960px;margin:0 auto;}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;margin-bottom:2rem;}
.footer-logo{margin-bottom:.75rem;}
.footer-logo img{height:52px;width:auto;}
.footer-tagline{font-size:14px;color:var(--gray);margin-top:.5rem;}
.footer-col{display:flex;flex-direction:column;}
.footer-col
h4{font-family:var(--font-display);font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.08em;color:var(--gold);margin-bottom:1rem;}
.footer-col a{display:block;font-size:14px;color:var(--gray);margin-bottom:.5rem;transition:color .2s;}
.footer-col a:hover{color:var(--white);}
.footer-bottom{padding-top:1.5rem;border-top:1px solid
var(--dark3);display:flex;justify-content:space-between;font-size:13px;color:var(--gray);flex-wrap:wrap;gap:.5rem;}
.footer-social{display:flex;gap:.75rem;margin-top:1rem;}
.footer-social
a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--dark2);border:1px solid
var(--dark3);border-radius:6px;color:var(--gray);font-size:14px;font-weight:700;transition:all .2s;}
.footer-social a:hover{border-color:var(--gold);color:var(--gold);}

/* ===== DETAILING PAGE ===== */
.packages-section{background:var(--black);padding:3.5rem 1.5rem;}
.packages-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;margin-top:2rem;}
.pkg-card{background:var(--dark2);border:1px solid var(--dark3);border-radius:8px;padding:2rem
1.5rem;transition:border-color .2s,transform .15s;position:relative;}
.pkg-card:hover{border-color:rgba(212,160,23,.4);transform:translateY(-2px);}
.pkg-card.featured{border-color:var(--gold);}
.featured-tag,.pkg-featured-tag{position:absolute;top:-1px;right:1.5rem;background:var(--gold);color:var(--black);font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px
10px;border-radius:0 0 4px 4px;}
.pkg-name{font-family:var(--font-display);font-weight:800;font-size:22px;text-transform:uppercase;margin-bottom:.5rem;}
.pkg-desc{font-size:14px;color:#999;line-height:1.6;margin-bottom:1.5rem;}
.pkg-price{font-family:var(--font-display);font-weight:800;font-size:36px;color:var(--gold);line-height:1;margin-bottom:.25rem;}
.pkg-price sup{font-size:18px;vertical-align:top;margin-top:5px;}
.pkg-from{font-size:13px;color:var(--gray);margin-bottom:1.25rem;}
.pkg-includes,.price-includes{list-style:none;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.75rem;}
.pkg-includes li,.price-includes li{font-size:14px;color:#ccc;display:flex;align-items:center;gap:8px;}
.pkg-includes li::before,.price-includes
li::before{content:'';width:16px;height:16px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%23D4A017' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M3 8l3.5 3.5L13 4'/%3E%3C/svg%3E") center/contain no-repeat; flex-shrink:0;}
.pkg-cta,.price-cta{display:block;text-align:center;background:transparent;border:1px solid
rgba(255,255,255,.15);color:var(--white);font-family:var(--font-display);font-weight:700;font-size:15px;letter-spacing:.06em;text-transform:uppercase;padding:12px;border-radius:4px;transition:all
.2s;}
.pkg-card.featured .pkg-cta,.price-card.featured
.price-cta{background:var(--gold);border-color:var(--gold);color:var(--black);}
.pkg-cta:hover,.price-cta:hover{background:var(--gold);border-color:var(--gold);color:var(--black);}
.pkg-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;margin-top:2rem;}
.addons-section{background:var(--dark);padding:3.5rem 1.5rem;}
.addons-grid,.addon-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1px;border:1px solid
var(--dark3);border-radius:8px;overflow:hidden;}
.addon-card{background:var(--dark2);padding:1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;}
.addon-name{font-weight:600;font-size:15px;}
.addon-sub{font-size:13px;color:var(--gray);margin-top:2px;}
.addon-tag,.addon-price{font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--gold);white-space:nowrap;}
.how-section{background:var(--black);padding:3.5rem 1.5rem;}
.how-steps{display:flex;flex-direction:column;gap:1px;margin-top:2rem;}
.how-step{background:var(--dark2);padding:1.5rem;display:flex;align-items:flex-start;gap:1.25rem;}
.how-num{font-family:var(--font-display);font-weight:800;font-size:28px;color:#D4A017;line-height:1;min-width:36px;}
.how-step:hover .how-num{color:var(--gold);transition:color .2s;}
.how-title{font-weight:600;font-size:16px;margin-bottom:.25rem;}
.how-desc{font-size:14px;color:#999;line-height:1.6;}

/* ===== TINT PAGE ===== */
.benefits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1px;margin-top:2.5rem;border:1px
solid var(--dark3);border-radius:8px;overflow:hidden;}
.benefit-card{background:var(--dark2);padding:2rem 1.5rem;transition:background .2s;}
.benefit-card:hover{background:var(--dark3);}
.benefit-icon{width:44px;height:44px;background:rgba(212,160,23,.1);border-radius:6px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;}
.benefit-icon
svg{width:22px;height:22px;stroke:var(--gold);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;}
.benefit-title{font-family:var(--font-display);font-weight:700;font-size:18px;text-transform:uppercase;margin-bottom:.5rem;}
.benefit-desc{font-size:14px;color:#999;line-height:1.6;}
.film-section{background:var(--black);padding:3.5rem 1.5rem;}
.film-card{background:var(--dark2);border:1px solid
var(--dark3);border-radius:8px;padding:2.5rem;display:grid;grid-template-columns:1fr
1fr;gap:3rem;align-items:center;margin-top:2rem;}
.film-badge{display:inline-block;background:rgba(212,160,23,.15);border:1px solid
rgba(212,160,23,.35);color:var(--gold);font-family:var(--font-display);font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:5px
12px;border-radius:2px;margin-bottom:1rem;}
.film-name{font-family:var(--font-display);font-weight:800;font-size:36px;text-transform:uppercase;line-height:1;margin-bottom:1rem;}
.film-name span{color:var(--gold);}
.film-desc{color:#aaa;font-size:15px;line-height:1.7;margin-bottom:1.5rem;}
.film-specs{display:flex;flex-direction:column;gap:.75rem;}
.pricing-section{background:var(--dark);padding:3.5rem 1.5rem;}
.pricing-note{display:inline-flex;align-items:center;gap:8px;background:rgba(212,160,23,.08);border:1px solid
rgba(212,160,23,.25);color:#bbb;font-size:13px;padding:8px 14px;border-radius:4px;margin-top:1rem;margin-bottom:2rem;}
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;}
.price-card{background:var(--dark2);border:1px solid var(--dark3);border-radius:8px;padding:2rem
1.5rem;transition:border-color .2s,transform .15s;position:relative;}
.price-card:hover{border-color:rgba(212,160,23,.4);transform:translateY(-2px);}
.price-card.featured{border-color:var(--gold);}
.price-vehicle{font-family:var(--font-display);font-weight:800;font-size:22px;text-transform:uppercase;margin-bottom:.25rem;}
.price-examples{font-size:13px;color:var(--gray);margin-bottom:1.5rem;}
.price-amount{font-family:var(--font-display);font-weight:800;font-size:42px;color:var(--gold);line-height:1;margin-bottom:.25rem;}
.price-amount sup{font-size:22px;vertical-align:top;margin-top:6px;}
.price-starting{font-size:13px;color:var(--gray);margin-bottom:1.5rem;}
.law-section{background:var(--black);padding:3.5rem 1.5rem;}
.law-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-top:2rem;}
.law-card{background:var(--dark2);border:1px solid var(--dark3);border-radius:8px;padding:1.5rem;}
.law-window{font-family:var(--font-display);font-weight:700;font-size:16px;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem;}
.law-rule{font-size:14px;color:#bbb;line-height:1.5;}
.law-note{margin-top:2rem;padding:1.25rem 1.5rem;background:rgba(212,160,23,.06);border-left:3px solid
var(--gold);border-radius:0 4px 4px 0;font-size:14px;color:#bbb;}
.law-note strong{color:var(--white);}
.mobile-section{background:var(--dark);padding:3.5rem 1.5rem;}
.why-list{display:flex;flex-direction:column;gap:1px;margin-top:2rem;}
.why-item{background:var(--dark2);padding:1.5rem;display:flex;align-items:flex-start;gap:1.25rem;}
.why-num{font-family:var(--font-display);font-weight:800;font-size:28px;color:#D4A017;line-height:1;min-width:36px;}
.why-item:hover .why-num{color:var(--gold);transition:color .2s;}
.why-title{font-weight:600;font-size:16px;margin-bottom:.25rem;}
.why-desc{font-size:14px;color:#999;line-height:1.6;}

/* ===== PROGRAM PAGE ===== */
.membership-inner{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start;margin-top:2.5rem;}
.plan-card{background:var(--dark2);border:1px solid var(--dark3);border-radius:8px;padding:2rem;transition:border-color
.2s;}
.plan-card.featured{border-color:var(--gold);}
.plan-name{font-family:var(--font-display);font-weight:800;font-size:24px;text-transform:uppercase;margin-bottom:.5rem;}
.plan-price{font-family:var(--font-display);font-weight:800;font-size:42px;color:var(--gold);line-height:1;}
.plan-period{font-size:14px;color:var(--gray);margin-bottom:1.5rem;}
.plan-features{list-style:none;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.75rem;}
.plan-features li{font-size:14px;color:#ccc;display:flex;align-items:center;gap:8px;}
.plan-cta{display:block;text-align:center;font-family:var(--font-display);font-weight:700;font-size:15px;letter-spacing:.06em;text-transform:uppercase;padding:12px;border-radius:4px;transition:all
.2s;border:1px solid rgba(255,255,255,.15);color:var(--white);}
.plan-card.featured .plan-cta{background:var(--gold);border-color:var(--gold);color:var(--black);}

/* ===== SERVICE AREA PAGE ===== */
.cities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.5rem;margin-top:1.5rem;}
.city-link{background:var(--dark2);border:1px solid var(--dark3);border-radius:6px;padding:.75rem
1rem;font-size:14px;color:var(--gray);transition:all .2s;text-align:center;display:block;}
.city-link:hover{border-color:var(--gold);color:var(--white);}

/* ===== FAQ PAGE ===== */
.faq-group{margin-bottom:2.5rem;}
.faq-group-title{font-family:var(--font-display);font-weight:700;font-size:18px;text-transform:uppercase;color:var(--gold);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px
solid var(--dark3);}
.faq-item{border-bottom:1px solid var(--dark3);padding:1.25rem 0;}
.faq-q{font-weight:600;font-size:15px;margin-bottom:.5rem;color:var(--white);}
.faq-a{font-size:14px;color:#999;line-height:1.7;}

/* ===== BOOKING PAGES ===== */
.booking-hero{position:relative;display:flex;align-items:center;padding:5rem 1.5rem
3rem;min-height:280px;background-size:cover;background-position:center;}
.booking-layout{display:grid;grid-template-columns:1fr 1.8fr;gap:3rem;align-items:start;max-width:1200px;margin:0
auto;padding:4rem 1.5rem;}
.booking-info{position:sticky;top:84px;}
.booking-form-wrap{background:var(--dark2);border:1px solid var(--dark3);border-radius:8px;padding:2rem 2.5rem;}
.booking-form-wrap
h3{font-family:var(--font-display);font-weight:800;font-size:22px;text-transform:uppercase;margin-bottom:1.5rem;}
.price-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid
var(--dark3);font-size:14px;}
.price-row:last-child{border-bottom:none;}
.price-label{color:var(--gray);}
.price-val{font-weight:600;color:var(--white);}
.price-val.gold{color:var(--gold);}
.include-list{list-style:none;display:flex;flex-direction:column;gap:.5rem;margin:1.5rem 0;}
.include-list li{font-size:14px;color:#ccc;display:flex;align-items:center;gap:8px;}
.include-list li::before{content:'';width:16px;height:16px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%23D4A017' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M3 8l3.5 3.5L13 4'/%3E%3C/svg%3E") center/contain no-repeat;flex-shrink:0;}

/* ===== CONFIRMATION PAGE ===== */
.confirm-hero{text-align:center;padding:6rem 1.5rem 5rem;background-size:cover;background-position:center;}
.confirm-icon{width:80px;height:80px;background:rgba(212,160,23,.1);border:2px solid
var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 2rem;}
.confirm-badge{display:inline-block;background:rgba(212,160,23,.15);border:1px solid
rgba(212,160,23,.4);color:var(--gold);font-family:var(--font-display);font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:6px
14px;border-radius:2px;margin-bottom:1.5rem;}
.confirm-title{font-family:var(--font-display);font-weight:800;font-size:clamp(42px,7vw,80px);text-transform:uppercase;line-height:.95;margin-bottom:1.5rem;}
.confirm-title em{font-style:normal;color:var(--gold);display:block;}
.confirm-sub{font-size:18px;color:#aaa;max-width:520px;margin:0 auto 3rem;line-height:1.7;}
.upsell-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:2rem;}
.upsell-card{background:var(--dark2);border:1px solid
var(--dark3);border-radius:8px;padding:1.75rem;transition:border-color .2s,transform .15s;}
.upsell-card:hover{border-color:rgba(212,160,23,.4);transform:translateY(-2px);}
.upsell-name{font-family:var(--font-display);font-weight:800;font-size:18px;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem;}
.upsell-desc{font-size:14px;color:#999;line-height:1.5;margin-bottom:1rem;}
.upsell-link{font-family:var(--font-display);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--white);}
.upsell-link:hover{color:var(--gold);}
.social-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:1.5rem;}
.social-btn{display:flex;align-items:center;gap:10px;padding:12px 24px;border:1px solid
var(--dark3);border-radius:6px;font-family:var(--font-display);font-weight:700;font-size:15px;text-transform:uppercase;letter-spacing:.04em;color:var(--gray);transition:all
.2s;}
.social-btn:hover{border-color:var(--gold);color:var(--white);}

/* ===== RESPONSIVE ===== */
@media(max-width:768px){
.nav-links{display:none;}
.hamburger{display:flex;}
.hero{padding:4rem 1rem 3rem;}
section{padding:3rem 1rem;}
.service-block{grid-template-columns:1fr;}
.reverse{direction:ltr;}
.film-card{grid-template-columns:1fr;gap:2rem;}
.footer-top{grid-template-columns:1fr;gap:2rem;}
.footer-bottom{flex-direction:column;text-align:center;}
.trust-bar{gap:1.25rem;}
.hero-stats{gap:1.5rem;}
.membership-inner{grid-template-columns:1fr;}
}
@media(max-width:900px){
.booking-layout{grid-template-columns:1fr;gap:2rem;padding:2rem 1rem;}
.booking-info{position:static;}
.booking-form-wrap{padding:1.5rem;}
}

/* ===== INDEX PAGE SPECIFIC ===== */
.why-section{background:var(--dark);}
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1px;margin-top:2.5rem;border:1px
solid var(--dark3);border-radius:8px;overflow:hidden;}
.why-card{background:var(--dark2);padding:2rem 1.5rem;transition:background .2s;}
.why-card:hover{background:var(--dark3);}
.why-icon{width:48px;height:48px;background:rgba(212,160,23,.1);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;}
.why-icon
svg{width:24px;height:24px;stroke:var(--gold);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;}
.membership-strip{background:var(--dark);padding:4rem 1.5rem;}
.membership-strip .membership-inner{max-width:960px;margin:0 auto;display:grid;grid-template-columns:1fr
1fr;gap:3rem;align-items:center;}
.membership-tag{display:inline-block;background:rgba(212,160,23,.15);border:1px solid
rgba(212,160,23,.4);color:var(--gold);font-family:var(--font-display);font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:5px
12px;border-radius:2px;margin-bottom:1rem;}
.membership-title{font-family:var(--font-display);font-weight:800;font-size:clamp(28px,4vw,42px);text-transform:uppercase;line-height:1;margin-bottom:1rem;}
.membership-desc{color:#aaa;font-size:15px;line-height:1.7;margin-bottom:1.5rem;}
.membership-strip .perks-list{list-style:none;display:flex;flex-direction:column;gap:.75rem;margin:0;}
.membership-strip .perk-item{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:#ccc;line-height:1.5;}
.membership-strip
.perk-check{width:20px;height:20px;background:var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;}
.membership-strip .perk-check
svg{width:12px;height:12px;stroke:var(--black);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.areas-section{background:var(--black);padding:3.5rem 1.5rem;}
.areas-wrap{max-width:960px;margin:0 auto;}
.areas-grid{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem;}
.area-pill{background:var(--dark2);border:1px solid var(--dark3);border-radius:20px;padding:.4rem
.9rem;font-size:13px;color:var(--gray);transition:all .2s;display:inline-block;}
.area-pill:hover{border-color:var(--gold);color:var(--white);}
@media(max-width:768px){.membership-strip{padding:3rem 1rem;}.membership-strip
.membership-inner{grid-template-columns:1fr;gap:2rem;}}

/* ===== PRESSURE WASHING PAGE ===== */
.note-section{background:var(--black);padding:2rem 1.5rem;}
.note-inner{max-width:960px;margin:0 auto;background:rgba(212,160,23,.06);border-left:3px solid
var(--gold);border-radius:0 4px 4px 0;padding:1.5rem;}
.note-title{font-family:var(--font-display);font-weight:700;font-size:16px;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem;}
.note-text{font-size:14px;color:#bbb;line-height:1.6;}
.svc-icon{width:48px;height:48px;background:rgba(212,160,23,.1);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;}
.svc-icon
svg{width:24px;height:24px;stroke:var(--gold);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;}
.svc-name{font-family:var(--font-display);font-weight:800;font-size:22px;text-transform:uppercase;margin-bottom:.5rem;}
.svc-desc{font-size:14px;color:#999;line-height:1.6;}

/* ===== PROGRAM PAGE ===== */
.perks-section{background:var(--dark);padding:3.5rem 1.5rem;}
.perks-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-top:2.5rem;}
.perk-card{background:var(--dark2);border:1px solid var(--dark3);border-radius:8px;padding:2rem
1.5rem;transition:border-color .2s,transform .15s;}
.perk-card:hover{border-color:rgba(212,160,23,.4);transform:translateY(-2px);}
.perk-icon{width:44px;height:44px;background:#D4A017;border-radius:6px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;}
.perk-title{font-family:var(--font-display);font-weight:700;font-size:18px;text-transform:uppercase;margin-bottom:.5rem;}
.perk-desc{font-size:14px;color:#999;line-height:1.6;}
.who-section{background:var(--black);padding:3.5rem 1.5rem;}
.who-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1px;border:1px solid
var(--dark3);border-radius:8px;overflow:hidden;margin-top:2.5rem;}
.who-card{background:var(--dark2);padding:2rem 1.5rem;transition:background .2s;}
.who-card:hover{background:var(--dark3);}
.who-num{font-family:var(--font-display);font-weight:800;font-size:36px;color:rgba(212,160,23,.15);line-height:1;margin-bottom:.75rem;}
.who-card:hover .who-num{color:var(--gold);transition:color .2s;}
.who-text{font-size:14px;color:#999;line-height:1.6;}
.pkg-tagline{font-size:13px;color:var(--gold);font-weight:600;margin-bottom:.5rem;}
.pkg-target{font-size:13px;color:var(--gray);margin-bottom:1.5rem;}
.pkg-features{list-style:none;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.75rem;}
.packages-note{margin-top:1.5rem;padding:1rem 1.25rem;background:rgba(212,160,23,.06);border-left:3px solid
var(--gold);border-radius:0 4px 4px 0;font-size:14px;color:#bbb;}
.req-note{background:var(--dark);padding:3.5rem 1.5rem;}
.req-inner{max-width:960px;margin:0 auto;background:rgba(212,160,23,.06);border-left:3px solid
var(--gold);border-radius:0 4px 4px 0;padding:1.5rem;}
.req-title{font-family:var(--font-display);font-weight:700;font-size:16px;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem;}
.req-text{font-size:14px;color:#bbb;line-height:1.6;}
.req-icon{color:var(--gold);}

/* ===== SERVICE AREA PAGE ===== */
.how-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-top:2rem;}
.how-card{background:var(--dark2);border:1px solid var(--dark3);border-radius:8px;padding:1.5rem;}
.travel-inner{max-width:960px;margin:0 auto;}
.travel-note{background:rgba(212,160,23,.06);border-left:3px solid var(--gold);border-radius:0 4px 4px
0;padding:1.5rem;margin-top:2rem;}
.travel-title{font-family:var(--font-display);font-weight:700;font-size:16px;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem;}
.travel-text{font-size:14px;color:#bbb;line-height:1.6;}

/* ===== FAQ PAGE ===== */
.faq-section{background:var(--black);padding:3.5rem 1.5rem;}
.container-wide{max-width:960px;margin:0 auto;}
.faq-arrow{color:var(--gold);font-size:18px;transition:transform .2s;}
.faq-a-inner{font-size:14px;color:#999;line-height:1.7;padding-top:.5rem;}
.contact-strip{background:var(--gold);padding:3rem 1.5rem;text-align:center;}
.contact-inner{max-width:960px;margin:0 auto;}
.contact-card{background:rgba(0,0,0,.15);border-radius:8px;padding:1.5rem
2rem;display:inline-flex;align-items:center;gap:1rem;margin:.5rem;}
.contact-icon
svg{width:24px;height:24px;stroke:var(--black);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.contact-label{font-size:13px;color:rgba(0,0,0,.7);font-weight:600;text-transform:uppercase;letter-spacing:.05em;}
.contact-val{font-family:var(--font-display);font-weight:800;font-size:22px;color:var(--black);}

/* ===== CITY HERO LOGO ===== */
.hero-logo{width:min(280px,60vw);filter:drop-shadow(0 4px 24px rgba(0,0,0,0.7));}
.contact-icon{display:flex;align-items:center;justify-content:center;}
.contact-icon svg{width:24px;height:24px;stroke:var(--black);fill:none;stroke-width:2;}

/* ===== BOOKING CONFIRMATION PAGE ===== */
.next-steps{background:var(--dark);padding:3.5rem 1.5rem;}
.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1px;border:1px solid
var(--dark3);border-radius:8px;overflow:hidden;margin-top:2.5rem;}
.step-card{background:var(--dark2);padding:2rem 1.5rem;}
.step-num{font-family:var(--font-display);font-weight:800;font-size:42px;color:rgba(212,160,23,.2);line-height:1;margin-bottom:.75rem;}
.step-title{font-family:var(--font-display);font-weight:700;font-size:18px;text-transform:uppercase;margin-bottom:.5rem;}
.step-desc{font-size:14px;color:#999;line-height:1.6;}
.upsell-section{background:var(--black);padding:3.5rem 1.5rem;}
.social-section{background:var(--dark);padding:3rem 1.5rem;text-align:center;}

/* ================================================
POST-SPLIT FIXES
Keeps shared layout stable after moving CSS files.
================================================ */
nav{ -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px); }
.nav-dropdown:hover .dropdown-menu,
.nav-dropdown:focus-within .dropdown-menu{ display:block; }

/* Hero overlays should come from .hero::before only. */
.hero-detailing{background-image:url("https://images.unsplash.com/photo-1520340356584-f9917d1eea6f?fm=jpg&q=80&w=1600&fit=crop");}
.hero-tint{background-image:url("https://images.unsplash.com/photo-1690022676526-2762ac826843?fm=jpg&q=80&w=1600&fit=crop");}
.hero-pressure-washing{background-image:url("https://images.unsplash.com/photo-1623625434531-d130448273c1?fm=jpg&q=80&w=1600&fit=crop");}
.hero-ceramic{background-image:url("https://images.unsplash.com/photo-1711513503795-05712fef15cd?fm=jpg&q=80&w=1600&fit=crop");}
.hero-boat-rv{background-image:url("https://images.unsplash.com/photo-1684849843504-7919ac9ede9c?fm=jpg&q=80&w=1600&fit=crop");}
.hero-golf-cart{background-image:url("https://images.unsplash.com/photo-1699135801906-ad078d7a6e76?fm=jpg&q=80&w=1600&fit=crop");}
.hero-program{background-image:url("https://images.unsplash.com/photo-1449965408869-eaa3f722e40d?fm=jpg&q=80&w=1600&fit=crop");}
.hero-city{background-image:url("https://images.unsplash.com/photo-1526726538690-5cbf956ae2fd?w=1600&q=85");}
.hero-service-area{background-image:url("https://images.unsplash.com/photo-1449965408869-eaa3f722e40d?fm=jpg&q=80&w=1600&fit=crop");}
.hero-faq{background-image:url("https://images.unsplash.com/photo-1520340356584-f9917d1eea6f?fm=jpg&q=80&w=1600&fit=crop");}

/* Root pages use ./hero-bg.jpg; city pages override this in city-pages.css. */
.hero-index{background-image:url('../hero-bg.jpg');}
.service-block{ align-items:start; }

/* Membership strip fix: scoped to index/home strip so it does not fight program-page grids. */
.membership-strip{ background:var(--dark); padding:4rem 1.5rem; }
.membership-strip .membership-inner{ max-width:960px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:center; }
.membership-strip .membership-tag{ display:inline-block; background:rgba(212,160,23,.15); border:1px solid rgba(212,160,23,.4); color:var(--gold); font-family:var(--font-display); font-size:12px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; padding:5px 12px; border-radius:2px; margin-bottom:1rem; }
.membership-strip .membership-title{ font-family:var(--font-display); font-weight:800; font-size:clamp(28px,4vw,42px); text-transform:uppercase; line-height:1; margin-bottom:1rem; }
.membership-strip .membership-desc{ color:#aaa; font-size:15px; line-height:1.7; margin-bottom:1.5rem; }
.membership-strip .perks-list{ display:flex; flex-direction:column; gap:.75rem; margin-bottom:2rem; list-style:none; }
.membership-strip .perk-item{ display:flex; align-items:center; gap:10px; font-size:14px; color:#ccc; line-height:1.5; }
.membership-strip .perk-check{ width:20px; height:20px; background:rgba(212,160,23,.1); border:1px solid rgba(212,160,23,.35); border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.membership-strip .perk-check svg{ width:12px; height:12px; stroke:var(--gold); fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }

/* FAQ accordion button reset/fix. Prevents browser default button styling and giant arrows. */
.faq-section{ background:var(--black); padding:3.5rem 1.5rem; }
.faq-item{ border-bottom:1px solid var(--dark3); padding:0; }
.faq-q{ appearance:none; -webkit-appearance:none; width:100%; background:transparent; border:0; color:var(--white); font-family:var(--font-body); font-weight:600; font-size:15px; line-height:1.4; text-align:left; cursor:pointer; padding:1.25rem 0; display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.faq-q:hover{ color:var(--gold); }
.faq-arrow{ width:18px; height:18px; min-width:18px; flex:0 0 18px; stroke:var(--gold); fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; transition:transform .2s ease; }
.faq-a{ display:none; padding:0 0 1.5rem; }
.faq-item.open .faq-a{ display:block; }
.faq-item.open .faq-arrow{ transform:rotate(180deg); }
.faq-a-inner{ color:#999; font-size:14px; line-height:1.7; max-width:760px; }

@media(max-width:768px){ .membership-strip{ padding:3rem 1rem; } 
.membership-strip .membership-inner{ grid-template-columns:1fr; gap:2rem; } }
