/*
Theme Name: CovPros Insurance
Theme URI: https://covpros.com
Author: CovPros Insurance
Description: Modern insurance agency theme for Coverage Pros serving Colorado and Arizona.
Version: 1.0
License: GNU General Public License v2 or later
Text Domain: covpros
*/

/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:#f8fafc;color:#1e293b;line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}

/* ===== VARIABLES ===== */
:root{
  --navy:#0f2340;
  --navy-mid:#1e3a5f;
  --navy-light:#1a4a7a;
  --gold:#f59e0b;
  --gold-dark:#d97706;
  --slate:#64748b;
  --slate-dark:#475569;
  --slate-light:#94a3b8;
  --white:#ffffff;
  --bg:#f8fafc;
  --border:#e2e8f0;
  --radius:12px;
  --radius-lg:20px;
  --radius-xl:24px;
  --shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06);
  --shadow-md:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);
  --shadow-xl:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);
}

/* ===== UTILITIES ===== */
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.section{padding:5rem 0}
.section-label{display:inline-flex;align-items:center;gap:.5rem;background:rgba(30,58,95,.1);color:var(--navy-mid);border-radius:9999px;padding:.375rem 1rem;font-size:.875rem;font-weight:600;margin-bottom:1rem}
.section-title{font-size:clamp(1.875rem,4vw,3rem);font-weight:800;color:var(--navy);line-height:1.2;margin-bottom:1rem}
.section-subtitle{color:var(--slate);font-size:1.125rem;max-width:40rem;margin:0 auto}
.text-center{text-align:center}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 2rem;border-radius:var(--radius);font-weight:700;font-size:1rem;transition:all .2s;cursor:pointer;border:2px solid transparent;text-decoration:none}
.btn-primary{background:var(--gold);color:var(--navy);border-color:var(--gold)}
.btn-primary:hover{background:var(--gold-dark);border-color:var(--gold-dark);transform:translateY(-1px);box-shadow:0 10px 25px rgba(245,158,11,.3)}
.btn-secondary{background:transparent;color:var(--white);border-color:rgba(255,255,255,.3)}
.btn-secondary:hover{background:rgba(255,255,255,.1)}
.btn-navy{background:var(--navy-mid);color:var(--white);border-color:var(--navy-mid)}
.btn-navy:hover{background:var(--navy);border-color:var(--navy)}
.badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:700;border:1px solid}

/* ===== NAVBAR ===== */
#site-header{position:fixed;top:0;left:0;right:0;z-index:1000;transition:all .3s;padding:.5rem 0}
#site-header.scrolled{background:rgba(15,35,64,.95);backdrop-filter:blur(12px);box-shadow:0 4px 30px rgba(0,0,0,.3);border-bottom:1px solid rgba(255,255,255,.1)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.nav-logo{display:flex;align-items:center;gap:.75rem}
.nav-logo img{width:44px;height:44px;object-fit:contain;border-radius:8px}
.nav-logo-text{line-height:1.1}
.nav-logo-name{color:var(--white);font-size:1.25rem;font-weight:800;letter-spacing:-.02em}
.nav-logo-name span{color:var(--gold)}
.nav-logo-sub{color:rgba(255,255,255,.5);font-size:.65rem;letter-spacing:.15em;text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:.25rem}
.nav-links a{padding:.5rem 1rem;color:rgba(255,255,255,.8);font-size:.9rem;font-weight:500;border-radius:8px;transition:all .2s}
.nav-links a:hover{color:var(--white);background:rgba(255,255,255,.1)}
.nav-actions{display:flex;align-items:center;gap:1rem}
.nav-phone{display:flex;align-items:center;gap:.5rem;color:rgba(255,255,255,.8);font-size:.9rem;font-weight:500;transition:color .2s}
.nav-phone:hover{color:var(--gold)}
.nav-phone svg{color:var(--gold)}
.nav-cta{background:var(--gold);color:var(--navy)!important;padding:.5rem 1.25rem;border-radius:8px;font-weight:700;font-size:.9rem;transition:all .2s!important}
.nav-cta:hover{background:var(--gold-dark)!important;transform:translateY(-1px)}
.mobile-toggle{display:none;flex-direction:column;gap:5px;padding:.5rem;cursor:pointer}
.mobile-toggle span{width:24px;height:2px;background:var(--white);border-radius:2px;transition:all .3s;display:block}
.mobile-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--navy);z-index:999;padding:5rem 1.5rem 2rem;flex-direction:column;gap:.5rem}
.mobile-menu.open{display:flex}
.mobile-menu a{color:rgba(255,255,255,.8);font-size:1.1rem;font-weight:500;padding:1rem 1.25rem;border-radius:10px;transition:all .2s}
.mobile-menu a:hover{color:var(--white);background:rgba(255,255,255,.1)}
.mobile-menu-footer{margin-top:auto;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1)}
.mobile-close{position:absolute;top:1.25rem;right:1.5rem;background:none;border:none;color:var(--white);font-size:1.5rem;cursor:pointer;padding:.5rem}

/* ===== HERO ===== */
#hero{min-height:100vh;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 50%,var(--navy-light) 100%);display:flex;align-items:center;position:relative;overflow:hidden}
.hero-blob1{position:absolute;top:-10rem;right:-10rem;width:40rem;height:40rem;border-radius:50%;background:rgba(37,99,235,.15);filter:blur(80px);pointer-events:none}
.hero-blob2{position:absolute;bottom:-10rem;left:-10rem;width:35rem;height:35rem;border-radius:50%;background:rgba(245,158,11,.08);filter:blur(80px);pointer-events:none}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:60px 60px;pointer-events:none}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;padding:8rem 0 6rem;position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:.4rem;background:rgba(245,158,11,.2);color:var(--gold);border:1px solid rgba(245,158,11,.3);border-radius:9999px;padding:.4rem 1rem;font-size:.875rem;font-weight:600;margin-bottom:1.5rem}
.hero-title{font-size:clamp(2.25rem,5vw,3.75rem);font-weight:800;color:var(--white);line-height:1.1;letter-spacing:-.03em;margin-bottom:1.5rem}
.hero-title .accent{color:var(--gold)}
.hero-subtitle{color:rgba(255,255,255,.7);font-size:1.125rem;line-height:1.7;max-width:30rem;margin-bottom:2rem}
.hero-ctas{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}
.hero-trust{display:flex;flex-wrap:wrap;gap:1.5rem}
.hero-trust-item{display:flex;align-items:center;gap:.5rem;color:rgba(255,255,255,.6);font-size:.875rem}
.hero-trust-item svg{color:var(--gold)}
.quote-card{background:rgba(255,255,255,.1);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-xl);padding:2rem;box-shadow:0 25px 50px rgba(0,0,0,.3)}
.quote-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}
.quote-card-icon{width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,var(--gold),var(--gold-dark));display:flex;align-items:center;justify-content:center;flex-shrink:0}
.quote-card-title{color:var(--white);font-weight:700;font-size:1.125rem}
.quote-card-sub{color:rgba(255,255,255,.5);font-size:.75rem}
.quote-label{color:rgba(255,255,255,.7);font-size:.875rem;margin-bottom:.75rem}
.quote-types{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:1.5rem}
.quote-type-btn{display:flex;flex-direction:column;align-items:center;gap:.375rem;padding:.75rem .5rem;border-radius:10px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.05);color:rgba(255,255,255,.7);font-size:.75rem;font-weight:600;transition:all .2s;cursor:pointer}
.quote-type-btn:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.3);color:var(--white)}
.quote-type-btn.active{background:var(--gold);border-color:var(--gold);color:var(--navy)}
.quote-type-btn .emoji{font-size:1.375rem}
.quote-submit{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem;background:var(--gold);color:var(--navy);border:none;border-radius:10px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;text-decoration:none}
.quote-submit:hover{background:var(--gold-dark);transform:translateY(-1px);box-shadow:0 10px 25px rgba(245,158,11,.3)}
.quote-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1)}
.quote-stat-val{color:var(--gold);font-weight:800;font-size:1.25rem;text-align:center}
.quote-stat-label{color:rgba(255,255,255,.5);font-size:.7rem;text-align:center;margin-top:.125rem}
.hero-wave{position:absolute;bottom:0;left:0;right:0}

/* ===== STATS BAR ===== */
#stats-bar{background:var(--navy-mid);padding:2.5rem 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.stat-item{text-align:center}
.stat-value{font-size:1.875rem;font-weight:800;color:var(--gold);margin-bottom:.25rem}
.stat-label{color:rgba(255,255,255,.6);font-size:.875rem;font-weight:500}

/* ===== SERVICES ===== */
#services{background:var(--bg)}
.services-header{margin-bottom:3.5rem}
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.service-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;transition:all .3s}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}
.service-card-bar{height:5px}
.service-card-body{padding:1.5rem;display:flex;flex-direction:column;flex:1}
.service-emoji{font-size:2.5rem;margin-bottom:1rem}
.service-tag{font-size:.7rem;font-weight:700;padding:.2rem .6rem;border-radius:9999px;border:1px solid;float:right;margin-top:-3.5rem;position:relative}
.service-name{font-size:1.25rem;font-weight:700;color:var(--navy);margin-bottom:.2rem}
.service-sub{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--slate-light);margin-bottom:.75rem}
.service-desc{color:var(--slate);font-size:.875rem;line-height:1.6;margin-bottom:1.25rem;flex:1}
.service-features{margin-bottom:1.5rem}
.service-features li{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--slate-dark);padding:.25rem 0}
.service-features li::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--gold);flex-shrink:0}
.service-cta{display:flex;align-items:center;justify-content:center;gap:.4rem;width:100%;padding:.7rem 1rem;background:var(--navy-mid);color:var(--white);border-radius:8px;font-weight:600;font-size:.875rem;transition:all .3s;text-decoration:none}
.service-cta:hover{background:var(--gold);color:var(--navy)}

/* ===== QUOTE PLATFORM ===== */
#quote-platform{background:var(--white)}
.qp-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.qp-label{display:inline-flex;align-items:center;gap:.5rem;background:rgba(245,158,11,.1);color:#92400e;border-radius:9999px;padding:.375rem 1rem;font-size:.875rem;font-weight:600;margin-bottom:1rem}
.qp-title{font-size:clamp(1.75rem,3.5vw,2.75rem);font-weight:800;color:var(--navy);margin-bottom:1.25rem;line-height:1.2}
.qp-title span{color:var(--gold)}
.qp-desc{color:var(--slate);font-size:1.05rem;line-height:1.7;margin-bottom:1.5rem}
.qp-list li{display:flex;align-items:flex-start;gap:.75rem;color:var(--slate-dark);margin-bottom:.75rem;font-size:.95rem}
.qp-bullet{width:20px;height:20px;border-radius:50%;background:rgba(245,158,11,.2);flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:.1rem}
.qp-bullet::after{content:'';width:8px;height:8px;border-radius:50%;background:var(--gold)}
.qp-widget{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-xl);padding:2rem;box-shadow:var(--shadow-md)}
.qp-widget-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}
.qp-widget-icon{width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,var(--navy-mid),#2563eb);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.qp-widget-title{font-weight:700;color:var(--navy);font-size:1.1rem}
.qp-widget-sub{color:var(--slate-light);font-size:.75rem}
.qp-options{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.5rem}
.qp-option{display:flex;flex-direction:column;align-items:center;gap:.375rem;padding:.75rem .5rem;border-radius:10px;border:2px solid var(--border);background:var(--white);color:var(--slate-dark);cursor:pointer;transition:all .2s;position:relative}
.qp-option:hover{border-color:rgba(30,58,95,.3);background:rgba(30,58,95,.04)}
.qp-option.active{border-color:var(--gold);background:rgba(245,158,11,.1);color:var(--navy)}
.qp-option.active::after{content:'';position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:50%;background:var(--gold)}
.qp-option-emoji{font-size:1.5rem}
.qp-option-label{font-size:.75rem;font-weight:700}
.qp-option-sub{font-size:.65rem;color:var(--slate-light);font-weight:400}
.qp-submit{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem;background:var(--navy-mid);color:var(--white);border:none;border-radius:10px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s;text-decoration:none}
.qp-submit:hover{background:var(--gold);color:var(--navy)}
.qp-legal{color:var(--slate-light);font-size:.7rem;text-align:center;margin-top:1rem;line-height:1.5}
.qp-legal a{color:var(--navy-mid);text-decoration:underline}

/* ===== WHY US ===== */
#why-us{background:var(--bg)}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:3.5rem}
.why-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border);padding:1.75rem;transition:all .3s}
.why-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-xl)}
.why-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.why-card h3{font-size:1.125rem;font-weight:700;color:var(--navy);margin-bottom:.5rem}
.why-card p{color:var(--slate);font-size:.875rem;line-height:1.6}
.testimonial-block{background:linear-gradient(135deg,var(--navy-mid),var(--navy));border-radius:var(--radius-xl);padding:3.5rem;text-align:center}
.stars{display:flex;justify-content:center;gap:.25rem;margin-bottom:1rem;font-size:1.5rem}
.testimonial-quote{color:var(--white);font-size:clamp(1.1rem,2.5vw,1.5rem);font-style:italic;font-weight:500;max-width:36rem;margin:0 auto 1.5rem;line-height:1.6}
.testimonial-author{color:rgba(255,255,255,.6);font-size:.875rem;font-weight:500}

/* ===== COVERAGE AREAS ===== */
#coverage-areas{background:var(--white)}
.areas-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.area-card{border-radius:var(--radius-xl);border:2px solid var(--border);padding:2rem;position:relative;overflow:hidden;transition:all .3s}
.area-card:hover{box-shadow:var(--shadow-xl);transform:translateY(-2px)}
.area-card-bar{position:absolute;top:0;left:0;right:0;height:5px}
.area-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}
.area-flag{font-size:3rem}
.area-state{font-size:1.5rem;font-weight:800;color:var(--navy)}
.area-desc{color:var(--slate);font-size:.875rem;margin-top:.25rem;line-height:1.5}
.area-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}
.area-tag{font-size:.75rem;font-weight:600;padding:.25rem .75rem;border-radius:9999px}

/* ===== TIPS ===== */
#tips{background:var(--bg)}
.tips-list{display:flex;flex-direction:column;gap:.75rem}
.tip-item{border:2px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color .2s}
.tip-item.open{border-color:var(--navy-mid)}
.tip-header{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;cursor:pointer;transition:background .2s;user-select:none}
.tip-item.open .tip-header{background:var(--navy-mid)}
.tip-num{font-size:.875rem;font-weight:700;font-family:monospace;color:var(--slate-light);flex-shrink:0;width:1.75rem}
.tip-item.open .tip-num{color:var(--gold)}
.tip-info{flex:1}
.tip-title{font-weight:700;font-size:1rem;color:var(--navy)}
.tip-item.open .tip-title{color:var(--white)}
.tip-summary{font-size:.8rem;color:var(--slate);margin-top:.2rem}
.tip-item.open .tip-summary{color:rgba(255,255,255,.6)}
.tip-chevron{font-size:1.25rem;color:var(--slate-light);transition:transform .3s;flex-shrink:0;display:flex;align-items:center;justify-content:center;width:1.5rem}
.tip-item.open .tip-chevron{transform:rotate(180deg);color:var(--gold)}
.tip-body{display:none;padding:1.25rem 1.5rem;background:var(--bg);border-top:1px solid var(--border)}
.tip-item.open .tip-body{display:block}
.tip-body p{color:var(--slate-dark);font-size:.875rem;line-height:1.7}

/* ===== FAQ ===== */
#faq{background:var(--white)}
.faq-list{display:flex;flex-direction:column;gap:.75rem}
.faq-item{border:2px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:var(--white);transition:all .2s}
.faq-item:hover{border-color:var(--border);box-shadow:var(--shadow)}
.faq-item.open{border-color:var(--gold);box-shadow:var(--shadow-md)}
.faq-header{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;cursor:pointer;user-select:none}
.faq-toggle{width:24px;height:24px;border-radius:50%;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.1rem;transition:background .2s;font-size:.875rem}
.faq-item.open .faq-toggle{background:var(--gold);color:var(--white)}
.faq-q{font-size:.95rem;font-weight:600;color:var(--navy);flex:1;line-height:1.4}
.faq-body{display:none;padding:.75rem 1.25rem 1.25rem 3.75rem}
.faq-item.open .faq-body{display:block}
.faq-body p{color:var(--slate);font-size:.875rem;line-height:1.7}

/* ===== CTA BANNER ===== */
#cta-banner{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 50%,var(--navy-light) 100%);padding:5rem 0;position:relative;overflow:hidden}
.cta-blob1{position:absolute;top:-5rem;right:-5rem;width:20rem;height:20rem;border-radius:50%;background:rgba(245,158,11,.1);filter:blur(60px);pointer-events:none}
.cta-blob2{position:absolute;bottom:-5rem;left:-5rem;width:20rem;height:20rem;border-radius:50%;background:rgba(37,99,235,.15);filter:blur(60px);pointer-events:none}
.cta-inner{position:relative;z-index:1;text-align:center}
.cta-title{font-size:clamp(1.875rem,4vw,3rem);font-weight:800;color:var(--white);margin-bottom:1rem;line-height:1.2}
.cta-subtitle{color:rgba(255,255,255,.7);font-size:1.125rem;max-width:36rem;margin:0 auto 2rem;line-height:1.6}
.cta-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:1.5rem}
.cta-fine{color:rgba(255,255,255,.4);font-size:.8rem}

/* ===== FOOTER ===== */
#site-footer{background:#0a1929;color:var(--white)}
.footer-main{padding:4rem 0;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2.5rem}
.footer-brand-logo{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem}
.footer-brand-logo img{width:40px;height:40px;object-fit:contain;border-radius:8px}
.footer-brand-name{color:var(--white);font-size:1.25rem;font-weight:800}
.footer-brand-name span{color:var(--gold)}
.footer-desc{color:rgba(255,255,255,.5);font-size:.875rem;line-height:1.7;margin-bottom:1.5rem}
.footer-contact-item{display:flex;align-items:flex-start;gap:.625rem;color:rgba(255,255,255,.6);font-size:.875rem;margin-bottom:.75rem;transition:color .2s}
.footer-contact-item:hover{color:var(--gold)}
.footer-contact-item svg{color:var(--gold);flex-shrink:0;margin-top:.125rem}
.footer-col-title{color:var(--white);font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:1.25rem}
.footer-links li{margin-bottom:.625rem}
.footer-links a{color:rgba(255,255,255,.5);font-size:.875rem;transition:color .2s;display:flex;align-items:center;gap:.375rem}
.footer-links a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:1.5rem 0;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.footer-copy{color:rgba(255,255,255,.3);font-size:.75rem}
.footer-bottom-links{display:flex;gap:1.5rem}
.footer-bottom-links a{color:rgba(255,255,255,.3);font-size:.75rem;transition:color .2s}
.footer-bottom-links a:hover{color:rgba(255,255,255,.6)}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .footer-main{grid-template-columns:1fr 1fr;gap:2rem}
}
@media(max-width:768px){
  .nav-links,.nav-actions{display:none}
  .mobile-toggle{display:flex}
  .hero-inner{grid-template-columns:1fr;gap:3rem;padding:7rem 0 4rem}
  .hero-ctas{flex-direction:column}
  .hero-ctas .btn{text-align:center;justify-content:center}
  .qp-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .areas-grid{grid-template-columns:1fr}
  .services-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .footer-main{grid-template-columns:1fr}
}
@media(max-width:480px){
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .quote-types{grid-template-columns:repeat(3,1fr)}
  .qp-options{grid-template-columns:repeat(2,1fr)}
  .cta-buttons{flex-direction:column;align-items:center}
}

/* ══ Scroll-reveal animation ══ */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .55s ease, transform .55s ease;
}
.reveal.visible {
  opacity: 1;
  transform: none;
}

/* ══ Iframe quote platform ══ */
.iframe-wrap {
  display: flex;
  justify-content: center;
  overflow-x: auto;          /* scroll on small screens */
  -webkit-overflow-scrolling: touch;
  border-radius: 12px;
}
.iframe-wrap iframe {
  min-width: 320px;
}
/* hide old qp-grid two-column layout if any remnant */
.qp-grid { display: block; }
