/*
Theme Name: All State Gate Co.
Theme URI: https://allstategateco.com
Description: Professional gate repair services theme for All State Gate Co.
Author: All State Gate Co.
Version: 1.0.0
Text Domain: all-state-gate-co
*/

*{margin:0;padding:0;box-sizing:border-box}
:root{--navy:#0B3D2E;--blue:#28A745;--blue-dark:#1a7a30;--blue-light:#e8f5e9;--orange:#FFC107;--dark:#0B3D2E;--darker:#071f17;--white:#fff;--gray:#8899AA;--light-bg:#F0F4F8;--card-bg:#0d2e1e;--border:#1a4d2e;--section-white:#fff;--section-light:#F0F4F8;--text-dark:#1a1a2e;--text-muted:#555}
body{font-family:'Inter',sans-serif;color:var(--white);background:var(--dark);overflow-x:hidden}
a{text-decoration:none;color:inherit}
.container{max-width:1200px;margin:0 auto;padding:0 20px;width:100%}
.top-bar{background:var(--blue);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{background:var(--darker);border-bottom:2px solid var(--blue);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-bolt{font-size:28px;color:var(--orange)}
.logo-text .name{font-family:'Montserrat',sans-serif;font-weight:900;font-size:22px;letter-spacing:2px;color:#fff}
.logo-text .sub{font-family:'Montserrat',sans-serif;font-weight:700;font-size:10px;color:var(--orange);letter-spacing:4px}
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(--orange)}
.header-phone{display:flex;align-items:center;gap:8px}
.header-phone .icon{background:var(--orange);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(--orange)}
.menu-toggle{display:none;background:none;border:none;color:var(--orange);font-size:28px;cursor:pointer}
.hero{padding:80px 20px;text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 30% 50%,rgba(0,82,204,0.15) 0%,transparent 50%)}
.hero-badge{display:inline-block;background:rgba(0,82,204,0.3);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(0,82,204,0.5)}
.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(--orange)}
.hero p{font-size:17px;color:#b0bec5;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(--orange);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(255,107,0,0.4)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(255,107,0,0.5)}
.btn-secondary{background:var(--blue);color:#fff;padding:14px 32px;border-radius:8px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;letter-spacing:1px;border:none;transition:background .2s,transform .2s;display:inline-block;box-shadow:0 4px 15px rgba(0,82,204,0.3)}
.btn-secondary:hover{background:var(--blue-dark);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(--orange)}
.hero-stat-label{font-size:11px;color:#b0bec5;letter-spacing:1.5px;text-transform:uppercase;margin-top:4px}
.trust-bar{background:var(--blue);padding:20px;box-shadow:0 4px 20px rgba(0,82,204,0.3)}
.trust-items{display:flex;justify-content:center;gap:24px;flex-wrap:wrap;padding:0 16px}
.trust-item{font-size:13px;font-weight:600;letter-spacing:1px;display:flex;align-items:center;gap:6px;color:#fff}
.section{padding:60px 20px}
.section-white{background:var(--section-white);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,82,204,0.1);color:var(--blue);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,82,204,0.2)}
.section-title{font-family:'Montserrat',sans-serif;font-weight:900;font-size:30px;margin-bottom:14px;text-align:center;color:var(--text-dark)}
.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}
.section-dark .section-subtitle{color:var(--gray)}
.section-dark .section-badge{background:rgba(0,82,204,0.3);color:#6ea8fe;border-color:rgba(0,82,204,0.4)}
.section-dark .section-title{color:#fff}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;max-width:1100px;margin:0 auto;padding:0 16px}
.about-text h2{font-family:'Montserrat',sans-serif;font-weight:900;font-size:28px;margin-bottom:16px;color:var(--blue)}
.about-text p{font-size:15px;line-height:1.7;color:var(--text-muted);margin-bottom:14px}
.about-features{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:20px}
.about-feature{font-size:14px;font-weight:500;color:var(--text-dark);display:flex;align-items:center;gap:8px}
.about-feature .check{color:var(--blue);font-weight:700;font-size:16px}
.about-image img{width:100%;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,0.15)}
.brands-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;max-width:1000px;margin:0 auto;padding:0 16px}
.brand-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:24px 16px;text-align:center;transition:border-color .2s,transform .2s,box-shadow .2s;box-shadow:0 2px 8px rgba(0,0,0,0.04)}
.brand-card:hover{border-color:var(--blue);transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,82,204,0.12)}
.brand-card .brand-icon{font-size:32px;margin-bottom:10px;color:var(--blue)}
.brand-card .brand-name{font-family:'Montserrat',sans-serif;font-weight:700;font-size:14px;color:var(--text-dark)}
.brand-card .brand-models{font-size:11px;color:var(--text-muted);margin-top:4px}
.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 #e0e7ef;border-radius:12px;overflow:hidden;transition:transform .2s,box-shadow .2s;cursor:pointer;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,82,204,0.12)}
.service-card .service-img{height:180px;overflow:hidden;position:relative}
.service-card .service-img::after{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:var(--blue)}
.service-card .service-img img{width:100%;height:100%;object-fit:cover}
.service-card-content{padding:20px}
.service-card h3{font-family:'Montserrat',sans-serif;font-weight:700;font-size:16px;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-link{color:var(--blue);font-weight:600;font-size:13px;display:inline-flex;align-items:center;gap:4px}
.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(--blue)}
.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-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(--blue);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,82,204,0.3)}
.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-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 #e0e7ef;border-radius:12px;padding:28px;box-shadow:0 2px 12px rgba(0,0,0,0.06);border-left:4px solid var(--blue)}
.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(--blue)}
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border-bottom:1px solid #e0e7ef;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(--blue);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{background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 50%,var(--navy) 100%);padding:60px 20px;text-align:center;color:#fff;position:relative;overflow:hidden}
.emergency-cta::before{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 50% 50%,rgba(255,107,0,0.1) 0%,transparent 60%)}
.emergency-cta h2{font-family:'Montserrat',sans-serif;font-weight:900;font-size:30px;margin-bottom:14px;position:relative}
.emergency-cta p{font-size:16px;opacity:0.9;margin-bottom:20px;max-width:600px;margin-left:auto;margin-right:auto;position:relative}
.emergency-phone{font-family:'Montserrat',sans-serif;font-weight:900;font-size:36px;display:block;margin-bottom:20px;position:relative}
.emergency-phone a{color:#fff}
.btn-white{background:var(--orange);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(255,107,0,0.4);position:relative;transition:transform .2s}
.btn-white:hover{transform:translateY(-2px)}
.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 #e0e7ef;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,82,204,0.12)}
.blog-thumb{height:160px;overflow:hidden}
.blog-thumb img{width:100%;height:100%;object-fit:cover}
.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(--blue);font-weight:600;font-size:13px}
footer{background:var(--darker);border-top:2px solid var(--blue);padding:50px 20px}
.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(--orange);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(--orange)}
.footer-bottom{text-align:center;padding:16px 20px;border-top:1px solid var(--border);margin-top:32px;font-size:12px;color:#445566}

/* ===== CITY PAGE STYLES ===== */
.city-hero{background:linear-gradient(135deg,var(--navy) 0%,var(--blue) 50%,var(--navy) 100%);padding:60px 24px;text-align:center;color:#fff}
.city-badge{display:inline-block;background:rgba(255,107,0,0.2);color:var(--orange);padding:8px 20px;border-radius:50px;font-size:13px;font-weight:600;letter-spacing:1px;margin-bottom:20px;border:1px solid rgba(255,107,0,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-orange{display:inline-block;background:var(--orange);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(255,107,0,0.4);transition:transform .2s}
.city-btn-orange:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(255,107,0,0.5)}
.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(--orange);color:var(--orange)}
.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(--darker);padding:28px 24px;display:flex;justify-content:center;gap:48px;flex-wrap:wrap;border-bottom:1px solid var(--border)}
.city-stats div{text-align:center}
.city-stats strong{display:block;font-family:'Montserrat',sans-serif;font-weight:900;font-size:24px;color:var(--orange)}
.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 #e0e7ef}
.city-bread a{color:var(--blue);font-weight:500}
.city-bread span{color:var(--text-muted)}
.city-grid{display:grid;grid-template-columns:1fr 340px;gap:32px;max-width:1200px;margin:0 auto;padding:40px 24px}
.city-main{}
.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 #e0e7ef;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(--blue);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-sidebar{}
.city-scta{background:linear-gradient(135deg,var(--blue),var(--blue-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-orange{width:100%;text-align:center;padding:14px;font-size:16px}
.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 #e0e7ef;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{max-width:100%;margin:0}
.city-faq-item{border-bottom:1px solid #e0e7ef;padding:16px 0}
.city-faq-q{font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;color:var(--text-dark);margin-bottom:8px;cursor:pointer;display:flex;align-items:center;gap:8px}
.city-faq-q::before{content:'Q';background:var(--blue);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 #e0e7ef;border-radius:8px;padding:10px 18px;font-size:13px;color:var(--blue);font-weight:500;transition:border-color .2s,background .2s}
.city-nearby-grid a:hover{border-color:var(--blue);background:var(--blue-light)}
.city-map{max-width:1200px;margin:0 auto;padding:32px 24px}
.city-map iframe{width:100%;height:350px;border:0;border-radius:12px}

@media(max-width:768px){
  .top-bar{flex-direction:column;text-align:center;padding:8px 12px;font-size:12px}
  .top-bar-right{justify-content:center;gap:10px;font-size:11px}
  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(--orange);z-index:999}
  .header-phone{display:none}
  .logo-text .name{font-size:18px}
  .logo-text .sub{font-size:8px;letter-spacing:3px}
  .logo-bolt{font-size:24px}
  .hero{padding:40px 16px}
  .hero h1{font-size:26px}
  .hero p{font-size:15px}
  .hero-buttons{flex-direction:column;align-items:center}
  .btn-primary,.btn-secondary{width:100%;text-align:center;padding:14px 20px;font-size:14px}
  .hero-stats{gap:16px}
  .hero-stat-number{font-size:22px}
  .hero-stat-label{font-size:10px}
  .trust-items{gap:8px;justify-content:center;padding:0 12px}
  .trust-item{font-size:11px;white-space:nowrap}
  .section{padding:40px 16px}
  .section-title{font-size:24px}
  .section-subtitle{font-size:14px;margin-bottom:28px}
  .about-grid{grid-template-columns:1fr;gap:24px}
  .about-text h2{font-size:24px}
  .about-features{grid-template-columns:1fr}
  .brands-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .brand-card{padding:18px 12px}
  .services-grid{grid-template-columns:1fr;gap:16px}
  .service-card .service-img{height:200px}
  .why-grid{grid-template-columns:1fr;gap:16px}
  .steps-grid{grid-template-columns:1fr;gap:24px}
  .testimonials-grid{grid-template-columns:1fr;gap:16px}
  .emergency-cta{padding:40px 16px}
  .emergency-cta h2{font-size:24px}
  .emergency-phone{font-size:28px}
  .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}
}
@media(max-width:480px){
  .hero h1{font-size:22px}
  .hero-stats{flex-direction:row;flex-wrap:wrap;gap:12px}
  .hero-stat{min-width:80px}
  .brands-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
}

/* ===== CONTACT FORM 7 STYLES ===== */
.wpcf7 { max-width: 100%; }
.asap-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.asap-form-full { grid-template-columns: 1fr; }
.asap-form-field label { display: block; font-size: 13px; font-weight: 600; color: #333; margin-bottom: 6px; letter-spacing: 0.5px; }
.asap-form-field input[type="text"],
.asap-form-field input[type="tel"],
.asap-form-field input[type="email"],
.asap-form-field select,
.asap-form-field textarea {
  width: 100%; padding: 14px 16px; border: 1px solid #d0d7de; border-radius: 8px;
  font-size: 15px; font-family: "Inter", sans-serif; color: #333; background: #fff;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.asap-form-field input:focus,
.asap-form-field select:focus,
.asap-form-field textarea:focus { border-color: var(--blue); box-shadow: 0 0 0 3px rgba(0,82,204,0.1); outline: none; }
.asap-form-field textarea { min-height: 120px; resize: vertical; }
.asap-form-field select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 width=%2712%27 height=%278%27 viewBox=%270 0 12 8%27%3E%3Cpath d=%27M1 1l5 5 5-5%27 stroke=%27%23666%27 stroke-width=%272%27 fill=%27none%27/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 40px; }
.wpcf7-submit {
  background: var(--orange); color: #fff; padding: 16px 40px; border: none; border-radius: 8px;
  font-family: "Montserrat", sans-serif; font-weight: 700; font-size: 16px; letter-spacing: 1px;
  cursor: pointer; transition: transform 0.2s, box-shadow 0.2s;
  box-shadow: 0 4px 15px rgba(255,107,0,0.4); width: 100%;
}
.wpcf7-submit:hover { transform: translateY(-2px); box-shadow: 0 8px 30px rgba(255,107,0,0.5); }
.wpcf7 .wpcf7-response-output { border-radius: 8px !important; padding: 14px 18px !important; font-size: 14px; margin-top: 16px; }
.wpcf7 .wpcf7-not-valid-tip { font-size: 12px; color: #e53e3e; margin-top: 4px; }
.wpcf7 .wpcf7-not-valid { border-color: #e53e3e !important; }
.wpcf7-spinner { display: none !important; }

/* Homepage contact form section */
.contact-form-section { background: var(--section-light); padding: 60px 20px; }
.contact-form-wrapper { max-width: 700px; margin: 0 auto; background: #fff; border-radius: 16px; padding: 40px; box-shadow: 0 4px 24px rgba(0,0,0,0.08); border: 1px solid #e0e7ef; }
.contact-form-wrapper h3 { font-family: "Montserrat", sans-serif; font-weight: 800; font-size: 22px; color: var(--text-dark); margin-bottom: 6px; }
.contact-form-wrapper .form-sub { font-size: 14px; color: var(--text-muted); margin-bottom: 28px; }

@media (max-width: 600px) {
  .asap-form-row { grid-template-columns: 1fr; }
  .contact-form-wrapper { padding: 24px 18px; }
}

/* Fix dark text on dark background */
.wpcf7 .wpcf7-response-output {
    color: #ffffff !important;
    border-color: #ff6b00 !important;
    background: rgba(0,0,0,0.5) !important;
}
.wpcf7 .wpcf7-response-output.wpcf7-mail-sent-ng {
    color: #ff6b6b !important;
    border-color: #ff4444 !important;
    background: rgba(255,0,0,0.1) !important;
}
.wpcf7 .wpcf7-response-output.wpcf7-mail-sent-ok {
    color: #4ade80 !important;
    border-color: #22c55e !important;
    background: rgba(0,255,0,0.1) !important;
}
.wpcf7 label, .wpcf7 .wpcf7-form p {
    color: #ffffff !important;
}

/* Fix Contact Us page colors */
.contact-page h1, .page-title, .entry-title {
    color: #ffffff !important;
    font-size: 2.5rem !important;
    font-weight: 700 !important;
}
.wpcf7 input[type=text], .wpcf7 input[type=tel], .wpcf7 input[type=email], .wpcf7 textarea, .wpcf7 select {
    background: rgba(255,255,255,0.1) !important;
    border: 1px solid rgba(255,255,255,0.3) !important;
    color: #ffffff !important;
    padding: 12px 16px !important;
    border-radius: 8px !important;
    font-size: 16px !important;
}
.wpcf7 input::placeholder, .wpcf7 textarea::placeholder {
    color: rgba(255,255,255,0.5) !important;
}
.wpcf7 label {
    color: #ffffff !important;
    font-weight: 600 !important;
    margin-bottom: 6px !important;
    display: block !important;
}
.wpcf7-submit {
    background: #ff6b00 !important;
    color: #ffffff !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    padding: 16px 40px !important;
    border: none !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    width: 100% !important;
    text-transform: uppercase !important;
}
.wpcf7-submit:hover {
    background: #ff8c33 !important;
}
.wpcf7 select {
    appearance: auto !important;
    -webkit-appearance: auto !important;
}
.wpcf7 select option {
    background: #1a1a2e !important;
    color: #ffffff !important;
}
