/*
Theme Name: Gate Services Asap CA
Theme URI: https://gateservicesasapca.com
Description: Professional Gate Repair services theme for Gate Services Asap CA
Author: Gate Services Asap CA
Version: 1.0.0
Text Domain: gate-services-asap-ca-theme
*/

*{margin:0;padding:0;box-sizing:border-box}
:root{
  --primary:#0A3D0A;
  --primary-dark:#002900;
  --secondary:#061806;
  --accent:#FF6B00;
  --white:#fff;
  --dark:#061806;
  --darker:#000900;
  --gray:#8899AA;
  --light-bg:#F0F4F8;
  --card-bg:#f9f9f9;
  --border:#e0e7ef;
  --text-dark:#1a1a2e;
  --text-muted:#555;
  --section-white:#fff;
  --section-light:#F0F4F8;
}
body{font-family:'Inter',sans-serif;color:var(--text-dark);background:#fff;overflow-x:hidden}
a{text-decoration:none;color:inherit}
.container{max-width:1200px;margin:0 auto;padding:0 20px;width:100%}

/* TOP BAR */
.top-bar{background:var(--primary);color:#fff;padding:10px 20px;display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:600;flex-wrap:wrap;gap:8px}
.top-bar a{color:#fff}
.top-bar-right{display:flex;gap:16px;flex-wrap:wrap}

/* HEADER */
header{background:var(--darker);border-bottom:3px solid var(--accent);padding:12px 20px;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:1000;box-shadow:0 2px 20px rgba(0,0,0,0.3)}
.logo-group{display:flex;align-items:center;gap:10px}
.logo-icon{font-size:28px;color:var(--accent)}
.logo-text .name{font-family:'Montserrat',sans-serif;font-weight:900;font-size:20px;letter-spacing:1px;color:#fff}
.logo-text .sub{font-family:'Montserrat',sans-serif;font-weight:700;font-size:10px;color:var(--accent);letter-spacing:3px}
nav{display:flex;gap:20px;align-items:center}
nav a{font-size:14px;font-weight:500;color:#ccd6e0;transition:color .2s}
nav a:hover{color:var(--accent)}
.header-phone{display:flex;align-items:center;gap:8px}
.header-phone .icon{background:var(--accent);color:#fff;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px}
.header-phone .number{font-family:'Montserrat',sans-serif;font-weight:700;font-size:18px;color:var(--accent)}
.menu-toggle{display:none;background:none;border:none;color:var(--accent);font-size:28px;cursor:pointer}

/* HERO */
.hero{padding:80px 20px;text-align:center;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--darker) 0%,var(--primary) 50%,var(--darker) 100%);color:#fff}
.hero::before{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 30% 50%,rgba(255,255,255,0.05) 0%,transparent 50%)}
.hero-badge{display:inline-block;background:rgba(255,255,255,0.15);color:#fff;padding:8px 16px;border-radius:50px;font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:24px;position:relative;border:1px solid rgba(255,255,255,0.3)}
.hero h1{font-family:'Montserrat',sans-serif;font-weight:900;font-size:36px;line-height:1.2;max-width:900px;margin:0 auto 16px;position:relative;color:#fff}
.hero h1 span{color:var(--accent)}
.hero p{font-size:17px;color:rgba(255,255,255,0.82);max-width:700px;margin:0 auto 32px;line-height:1.6;position:relative}
.hero-buttons{display:flex;gap:12px;justify-content:center;position:relative;flex-wrap:wrap}
.btn-primary{background:var(--accent);color:#fff;padding:14px 32px;border-radius:8px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;letter-spacing:1px;transition:transform .2s,box-shadow .2s;display:inline-block;box-shadow:0 4px 15px rgba(0,0,0,0.3)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,0,0,0.4)}
.btn-secondary{background:rgba(255,255,255,0.15);border:2px solid rgba(255,255,255,0.4);color:#fff;padding:14px 32px;border-radius:8px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;letter-spacing:1px;transition:border-color .2s,transform .2s;display:inline-block}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.hero-stats{display:flex;justify-content:center;gap:32px;margin-top:40px;position:relative;flex-wrap:wrap}
.hero-stat{text-align:center}
.hero-stat-number{font-family:'Montserrat',sans-serif;font-weight:900;font-size:28px;color:var(--accent)}
.hero-stat-label{font-size:11px;color:rgba(255,255,255,0.7);letter-spacing:1.5px;text-transform:uppercase;margin-top:4px}

/* TRUST BAR */
.trust-bar{background:var(--primary);padding:20px}
.trust-items{display:flex;justify-content:center;gap:24px;flex-wrap:wrap}
.trust-item{font-size:13px;font-weight:600;letter-spacing:1px;display:flex;align-items:center;gap:6px;color:#fff}

/* SECTIONS */
.section{padding:60px 20px}
.section-white{background:#fff;color:var(--text-dark)}
.section-light{background:var(--section-light);color:var(--text-dark)}
.section-dark{background:var(--darker);color:#fff}
.section-badge{display:inline-block;background:rgba(0,0,0,0.08);color:var(--primary);padding:6px 14px;border-radius:50px;font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;margin-bottom:14px;border:1px solid rgba(0,0,0,0.1)}
.section-title{font-family:'Montserrat',sans-serif;font-weight:900;font-size:30px;margin-bottom:14px;text-align:center}
.section-subtitle{color:var(--text-muted);font-size:15px;margin-bottom:40px;max-width:650px;margin-left:auto;margin-right:auto;text-align:center;line-height:1.6}

/* SERVICES GRID */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1100px;margin:0 auto;padding:0 16px}
.service-card{background:#fff;border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:transform .2s,box-shadow .2s;display:block;box-shadow:0 2px 12px rgba(0,0,0,0.06)}
.service-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,0.12)}
.service-card-content{padding:24px}
.service-card h3{font-family:'Montserrat',sans-serif;font-weight:700;font-size:17px;margin-bottom:8px;color:var(--text-dark)}
.service-card p{font-size:13px;color:var(--text-muted);line-height:1.6;margin-bottom:12px}
.service-icon-box{font-size:40px;padding:20px;text-align:center;background:linear-gradient(135deg,var(--primary),var(--primary-dark))}
.service-link{color:var(--primary);font-weight:600;font-size:13px;display:inline-flex;align-items:center;gap:4px}

/* WHY GRID */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1000px;margin:0 auto;padding:0 16px}
.why-card{text-align:center;padding:24px;background:#fff;border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,0.06);border-top:3px solid var(--primary)}
.why-card .why-icon{font-size:40px;margin-bottom:14px}
.why-card h4{font-family:'Montserrat',sans-serif;font-weight:700;font-size:16px;margin-bottom:8px;color:var(--text-dark)}
.why-card p{font-size:13px;color:var(--text-muted);line-height:1.6}

/* STEPS */
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;max-width:900px;margin:0 auto;text-align:center;padding:0 16px}
.step-number{width:56px;height:56px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Montserrat',sans-serif;font-weight:900;font-size:22px;margin:0 auto 16px;box-shadow:0 4px 15px rgba(0,0,0,0.2)}
.step h3{font-family:'Montserrat',sans-serif;font-weight:700;font-size:18px;margin-bottom:10px;color:var(--text-dark)}
.step p{font-size:13px;color:var(--text-muted);line-height:1.6}

/* TESTIMONIALS */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1100px;margin:0 auto;padding:0 16px}
.testimonial-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:28px;box-shadow:0 2px 12px rgba(0,0,0,0.06);border-left:4px solid var(--primary)}
.testimonial-stars{color:#f59e0b;font-size:16px;margin-bottom:12px;letter-spacing:2px}
.testimonial-text{font-size:14px;color:var(--text-muted);line-height:1.7;margin-bottom:16px;font-style:italic}
.testimonial-author{font-weight:700;color:var(--text-dark);font-size:14px}
.testimonial-location{font-size:12px;color:var(--primary)}

/* FAQ */
.faq-list{max-width:800px;margin:0 auto;padding:0 20px}
.faq-item{border-bottom:1px solid var(--border);padding:20px 0}
.faq-question{font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;color:var(--text-dark);margin-bottom:10px;display:flex;align-items:center;gap:10px}
.faq-question::before{content:'Q';background:var(--primary);color:#fff;width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.faq-answer{color:var(--text-muted);font-size:14px;line-height:1.7;padding-left:36px}

/* EMERGENCY CTA */
.emergency-cta{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 50%,var(--secondary) 100%);padding:60px 20px;text-align:center;color:#fff;position:relative}
.emergency-cta h2{font-family:'Montserrat',sans-serif;font-weight:900;font-size:30px;margin-bottom:14px}
.emergency-cta p{font-size:16px;opacity:0.9;margin-bottom:20px;max-width:600px;margin-left:auto;margin-right:auto}
.emergency-phone{font-family:'Montserrat',sans-serif;font-weight:900;font-size:36px;display:block;margin-bottom:20px}
.emergency-phone a{color:#fff}
.btn-white{background:var(--accent);color:#fff;padding:14px 36px;border-radius:8px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;display:inline-block;box-shadow:0 4px 20px rgba(0,0,0,0.3);transition:transform .2s}
.btn-white:hover{transform:translateY(-2px)}

/* BLOG */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1100px;margin:0 auto;padding:0 16px}
.blog-card{background:#fff;border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 12px rgba(0,0,0,0.06)}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,0.12)}
.blog-card-content{padding:20px}
.blog-card h3{font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;margin-bottom:8px;color:var(--text-dark)}
.blog-card p{font-size:13px;color:var(--text-muted);line-height:1.5;margin-bottom:10px}
.blog-link{color:var(--primary);font-weight:600;font-size:13px}

/* FOOTER */
footer{background:var(--darker);border-top:3px solid var(--primary);padding:50px 20px;color:#fff}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px;max-width:1100px;margin:0 auto;padding:0 16px}
.footer-col h5{font-family:'Montserrat',sans-serif;font-weight:700;font-size:13px;color:var(--accent);letter-spacing:2px;text-transform:uppercase;margin-bottom:14px}
.footer-col p,.footer-col a{font-size:13px;color:var(--gray);line-height:2;display:block}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{text-align:center;padding:16px 20px;border-top:1px solid rgba(255,255,255,0.1);margin-top:32px;font-size:12px;color:#445566}

/* CITY PAGE STYLES */
.city-hero{background:linear-gradient(135deg,var(--secondary) 0%,var(--primary) 50%,var(--secondary) 100%);padding:60px 24px;text-align:center;color:#fff}
.city-badge{display:inline-block;background:rgba(255,255,255,0.15);color:#fff;padding:8px 20px;border-radius:50px;font-size:13px;font-weight:600;letter-spacing:1px;margin-bottom:20px;border:1px solid rgba(255,255,255,0.3)}
.city-hero h1{font-family:'Montserrat',sans-serif;font-weight:900;font-size:34px;margin-bottom:14px;line-height:1.2}
.city-hero-sub{font-size:16px;color:rgba(255,255,255,.75);max-width:650px;margin:0 auto 28px;line-height:1.6}
.city-hero-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:24px}
.city-btn-primary{display:inline-block;background:var(--accent);color:#fff;padding:14px 32px;border-radius:8px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;box-shadow:0 4px 15px rgba(0,0,0,0.3);transition:transform .2s}
.city-btn-primary:hover{transform:translateY(-2px)}
.city-btn-outline{display:inline-block;border:2px solid rgba(255,255,255,.4);color:#fff;padding:12px 28px;border-radius:8px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;transition:border-color .2s}
.city-btn-outline:hover{border-color:var(--accent);color:var(--accent)}
.city-trust{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;font-size:13px;color:rgba(255,255,255,.7);font-weight:500}
.city-stats{background:var(--secondary);padding:28px 24px;display:flex;justify-content:center;gap:48px;flex-wrap:wrap;border-bottom:1px solid rgba(255,255,255,0.1)}
.city-stats div{text-align:center}
.city-stats strong{display:block;font-family:'Montserrat',sans-serif;font-weight:900;font-size:24px;color:var(--accent)}
.city-stats span{font-size:12px;color:var(--gray);text-transform:uppercase;letter-spacing:1px}
.city-bread{background:var(--section-light);padding:14px 24px;font-size:13px;border-bottom:1px solid var(--border)}
.city-bread a{color:var(--primary);font-weight:500}
.city-grid{display:grid;grid-template-columns:1fr 340px;gap:32px;max-width:1200px;margin:0 auto;padding:40px 24px}
.city-article{font-size:16px;line-height:1.8;color:var(--text-muted);margin-bottom:32px}
.city-article p{margin-bottom:16px}
.city-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:28px;margin-bottom:28px;box-shadow:0 2px 12px rgba(0,0,0,0.04)}
.city-card h2{font-family:'Montserrat',sans-serif;font-weight:700;font-size:20px;color:var(--text-dark);margin-bottom:18px}
.city-checklist{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.city-chk{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text-dark)}
.city-chk .ic{color:var(--primary);font-weight:700;font-size:18px}
.city-reasons{display:grid;gap:18px}
.city-reason{display:flex;gap:14px;align-items:flex-start}
.city-ri{font-size:28px;flex-shrink:0}
.city-reason strong{display:block;font-size:15px;color:var(--text-dark);margin-bottom:4px}
.city-reason p{font-size:13px;color:var(--text-muted);line-height:1.5;margin:0}
.city-scta{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border-radius:12px;padding:28px;text-align:center;margin-bottom:20px}
.city-scta h3{font-family:'Montserrat',sans-serif;font-weight:700;font-size:20px;margin-bottom:10px}
.city-scta p{font-size:14px;opacity:.85;margin-bottom:16px}
.city-scta .city-btn-primary{width:100%;text-align:center;padding:14px;font-size:16px;display:block}
.city-sm{font-size:12px;margin-top:10px;opacity:.7}
.city-sm a{color:#fff;text-decoration:underline}
.city-sinfo{background:#fff;border:1px solid var(--border);border-radius:12px;padding:24px;margin-bottom:20px}
.city-sinfo h4{font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;color:var(--text-dark);margin-bottom:14px}
.city-ir{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #f0f0f0;font-size:14px}
.city-ir span{color:var(--text-muted)}
.city-ir strong{color:var(--text-dark)}
.city-faq-item{border-bottom:1px solid var(--border);padding:16px 0}
.city-faq-q{font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;color:var(--text-dark);margin-bottom:8px;display:flex;align-items:center;gap:8px}
.city-faq-q::before{content:'Q';background:var(--primary);color:#fff;width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}
.city-faq-a{color:var(--text-muted);font-size:14px;line-height:1.7;padding-left:32px}
.city-nearby{background:var(--section-light);padding:48px 24px}
.city-nearby h2{font-family:'Montserrat',sans-serif;font-weight:700;font-size:24px;color:var(--text-dark);text-align:center;margin-bottom:24px}
.city-nearby-grid{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:1000px;margin:0 auto}
.city-nearby-grid a{background:#fff;border:1px solid var(--border);border-radius:8px;padding:10px 18px;font-size:13px;color:var(--primary);font-weight:500;transition:border-color .2s,background .2s}
.city-nearby-grid a:hover{border-color:var(--primary);background:var(--light-bg)}
.city-map{max-width:1200px;margin:0 auto;padding:32px 24px}
.city-map iframe{width:100%;height:350px;border:0;border-radius:12px}

/* REVIEWS SECTION */
.reviews-section{background:var(--section-light);padding:60px 24px}

/* ACCORDION (Service Areas) */
.sa-state{border:1px solid var(--border);border-radius:10px;margin-bottom:12px;overflow:hidden}
.sa-state-header{background:#fff;padding:16px 20px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-family:'Montserrat',sans-serif;font-weight:700;font-size:16px;color:var(--text-dark)}
.sa-state-header:hover{background:var(--light-bg)}
.sa-state-body{display:none;padding:16px 20px;background:var(--section-light)}
.sa-state-body.open{display:block}
.sa-cities{display:flex;flex-wrap:wrap;gap:8px}
.sa-cities a{background:#fff;border:1px solid var(--border);border-radius:6px;padding:6px 14px;font-size:13px;color:var(--primary);font-weight:500}
.sa-cities a:hover{border-color:var(--primary);background:var(--light-bg)}

@media(max-width:768px){
  header{padding:10px 16px}
  nav{display:none}
  .menu-toggle{display:block}
  nav.open{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--darker);padding:16px;gap:12px;border-bottom:2px solid var(--accent);z-index:999}
  .header-phone{display:none}
  .hero{padding:40px 16px}
  .hero h1{font-size:26px}
  .hero-buttons{flex-direction:column;align-items:center}
  .btn-primary,.btn-secondary{width:100%;text-align:center}
  .hero-stats{gap:16px}
  .services-grid{grid-template-columns:1fr;gap:16px}
  .why-grid{grid-template-columns:1fr;gap:16px}
  .steps-grid{grid-template-columns:1fr;gap:24px}
  .testimonials-grid{grid-template-columns:1fr;gap:16px}
  .blog-grid{grid-template-columns:1fr;gap:16px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:24px}
  .city-hero h1{font-size:24px}
  .city-grid{grid-template-columns:1fr;gap:24px}
  .city-checklist{grid-template-columns:1fr}
  .city-stats{gap:24px}
  .top-bar{flex-direction:column;text-align:center}
}
@media(max-width:480px){
  .hero h1{font-size:22px}
  .footer-grid{grid-template-columns:1fr}
}
