/* ============================================
   AC & HEATING SERVICE LLC — Main Stylesheet
   Palette: Royal Blue #1A4A8A + Deep Red #C0392B + White
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;600;700;900&family=Open+Sans:wght@400;500;600&display=swap');

/* ---- TOKENS ---- */
:root {
  --blue: #1A4A8A;
  --blue-dark: #0f3166;
  --blue-light: #2a5fa3;
  --red: #C0392B;
  --red-dark: #962d22;
  --red-light: #e04535;
  --white: #ffffff;
  --off-white: #f8f9fc;
  --gray-100: #f1f3f7;
  --gray-200: #e2e6ed;
  --gray-300: #c8cdd7;
  --gray-500: #6b7280;
  --gray-700: #374151;
  --gray-900: #111827;
  --text: #1a1f2e;
  --text-muted: #6b7280;

  --font-display: 'Montserrat', sans-serif;
  --font-body: 'Open Sans', sans-serif;

  --text-xs: clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);
  --text-sm: clamp(0.875rem, 0.8rem + 0.35vw, 1rem);
  --text-base: clamp(1rem, 0.95rem + 0.25vw, 1.125rem);
  --text-lg: clamp(1.125rem, 1rem + 0.75vw, 1.5rem);
  --text-xl: clamp(1.5rem, 1.2rem + 1.25vw, 2.25rem);
  --text-2xl: clamp(2rem, 1.2rem + 2.5vw, 3.5rem);
  --text-hero: clamp(2.5rem, 1rem + 5vw, 4.5rem);

  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;

  --radius-sm: 0.375rem;
  --radius-md: 0.5rem;
  --radius-lg: 0.75rem;
  --radius-xl: 1rem;
  --radius-full: 9999px;

  --shadow-sm: 0 1px 3px rgba(0,0,0,0.08);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.10);
  --shadow-lg: 0 12px 40px rgba(0,0,0,0.14);

  --content-default: 1100px;
  --transition: 200ms cubic-bezier(0.16,1,0.3,1);
}

/* ---- RESET ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:80px;-webkit-font-smoothing:antialiased}
body{min-height:100dvh;font-family:var(--font-body);font-size:var(--text-base);color:var(--text);background:#fff;line-height:1.65}
img,picture,video{display:block;max-width:100%;height:auto}
ul[role=list],ol[role=list]{list-style:none}
input,button,textarea,select{font:inherit;color:inherit}
h1,h2,h3,h4{text-wrap:balance;line-height:1.15;font-family:var(--font-display)}
p,li{text-wrap:pretty;max-width:70ch}
button{cursor:pointer;background:none;border:none}
a{color:inherit;text-decoration:none}

/* ---- UTILITIES ---- */
.container{max-width:var(--content-default);margin-inline:auto;padding-inline:clamp(var(--space-4),5vw,var(--space-10))}
.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:0.75rem 1.75rem;border-radius:var(--radius-full);font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;letter-spacing:0.03em;text-transform:uppercase;transition:transform var(--transition),box-shadow var(--transition),background var(--transition)}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:var(--red-dark)}
.btn-outline{background:transparent;color:#fff;border:2px solid #fff}
.btn-outline:hover{background:#fff;color:var(--blue)}
.btn-blue{background:var(--blue);color:#fff}
.btn-blue:hover{background:var(--blue-dark)}
.section-label{font-size:var(--text-xs);font-weight:700;letter-spacing:0.15em;text-transform:uppercase;color:var(--red);font-family:var(--font-display)}
.section-title{font-size:var(--text-xl);font-weight:900;color:var(--gray-900);margin-top:var(--space-2)}
.section-sub{font-size:var(--text-base);color:var(--text-muted);margin-top:var(--space-3);max-width:60ch}

/* ---- HEADER / NAV ---- */
.header{position:sticky;top:0;z-index:100;background:var(--blue);box-shadow:0 2px 16px rgba(0,0,0,0.2)}
.nav{display:flex;align-items:center;justify-content:space-between;padding-block:var(--space-3)}
.nav-logo{display:flex;align-items:center;gap:var(--space-3)}
.nav-logo img{height:72px;width:72px;object-fit:cover;border-radius:50%;border:3px solid rgba(255,255,255,0.25);box-shadow:0 2px 12px rgba(0,0,0,0.3)}
.nav-links{display:flex;align-items:center;gap:var(--space-8);margin-left:var(--space-6)}
.nav-links a{color:#fff;font-size:var(--text-sm);font-weight:600;font-family:var(--font-display);opacity:0.9;transition:opacity var(--transition)}
.nav-links a:hover{opacity:1}
.nav-cta{display:flex;align-items:center;gap:var(--space-4)}
.nav-phone{color:#fff;font-size:var(--text-sm);font-weight:700;font-family:var(--font-display);display:flex;align-items:center;gap:var(--space-2)}
.nav-phone svg{flex-shrink:0}
.hamburger{display:none;flex-direction:column;gap:5px;padding:var(--space-2);cursor:pointer}
.hamburger span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:transform var(--transition),opacity var(--transition)}

/* ---- TOPBAR ---- */
.topbar{background:var(--blue-dark);padding:var(--space-2) 0;text-align:center}
.topbar p{color:rgba(255,255,255,0.85);font-size:var(--text-xs);font-family:var(--font-display);font-weight:600;letter-spacing:0.05em}
.topbar a{color:var(--red-light);text-decoration:none}

/* ---- HERO ---- */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(105deg, rgba(10,30,80,0.88) 0%, rgba(10,30,80,0.65) 55%, rgba(10,30,80,0.25) 100%)}
.hero-content{position:relative;z-index:1;padding-block:var(--space-24)}
.hero-badge{display:inline-flex;align-items:center;gap:var(--space-2);background:var(--red);color:#fff;padding:0.4rem 1rem;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;letter-spacing:0.1em;text-transform:uppercase;margin-bottom:var(--space-5);font-family:var(--font-display)}
.hero h1{font-size:var(--text-hero);font-weight:900;color:#fff;line-height:1.05;max-width:14ch;margin-bottom:var(--space-5)}
.hero h1 span{color:#f5c842}
.hero p{font-size:var(--text-lg);color:rgba(255,255,255,0.88);max-width:52ch;margin-bottom:var(--space-8)}
.hero-actions{display:flex;flex-wrap:wrap;gap:var(--space-4);align-items:center}
.hero-stats{display:flex;flex-wrap:wrap;gap:var(--space-8);margin-top:var(--space-12)}
.hero-stat strong{display:block;font-size:var(--text-xl);font-weight:900;color:#fff;font-family:var(--font-display)}
.hero-stat span{font-size:var(--text-xs);color:rgba(255,255,255,0.7);text-transform:uppercase;letter-spacing:0.1em;font-weight:600}

/* ---- TRUST BAR ---- */
.trust-bar{background:var(--gray-100);border-bottom:1px solid var(--gray-200);padding:var(--space-5) 0}
.trust-items{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:var(--space-8)}
.trust-item{display:flex;align-items:center;gap:var(--space-3);color:var(--gray-700);font-size:var(--text-sm);font-weight:600}
.trust-item svg{color:var(--red);flex-shrink:0}

/* ---- SERVICES ---- */
.services{padding-block:clamp(var(--space-12),8vw,var(--space-24));background:#fff}
.services-header{text-align:center;margin-bottom:var(--space-12)}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-6)}
.service-card{background:var(--off-white);border:1px solid var(--gray-200);border-radius:var(--radius-xl);overflow:hidden;transition:transform var(--transition),box-shadow var(--transition)}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.service-card-img{height:220px;overflow:hidden;background:var(--gray-200)}
.service-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease}
.service-card:hover .service-card-img img{transform:scale(1.05)}
.service-card-body{padding:var(--space-6)}
.service-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--blue),var(--blue-light));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4)}
.service-icon svg{color:#fff}
.service-card h3{font-size:var(--text-lg);font-weight:800;color:var(--gray-900);margin-bottom:var(--space-2)}
.service-card p{font-size:var(--text-sm);color:var(--text-muted);line-height:1.7}
.service-card-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--gray-200);background:#fff}
.service-link{color:var(--blue);font-size:var(--text-sm);font-weight:700;font-family:var(--font-display);display:inline-flex;align-items:center;gap:var(--space-2);transition:gap var(--transition),color var(--transition)}
.service-link:hover{gap:var(--space-3);color:var(--red)}

/* ---- WHY US ---- */
.why-us{padding-block:clamp(var(--space-12),8vw,var(--space-24));background:linear-gradient(135deg,var(--blue-dark) 0%,var(--blue) 100%)}
.why-us-inner{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-16);align-items:center}
.why-us-text .section-label{color:#f5c842}
.why-us-text .section-title{color:#fff}
.why-us-text .section-sub{color:rgba(255,255,255,0.8)}
.why-features{display:grid;gap:var(--space-5);margin-top:var(--space-8)}
.why-feature{display:flex;gap:var(--space-4);align-items:flex-start}
.why-feature-icon{width:44px;height:44px;background:rgba(255,255,255,0.12);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.why-feature-icon svg{color:#f5c842}
.why-feature h4{color:#fff;font-size:var(--text-base);font-weight:700;margin-bottom:var(--space-1)}
.why-feature p{color:rgba(255,255,255,0.75);font-size:var(--text-sm)}
.why-image{border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg)}
.why-image img{width:100%;height:100%;object-fit:cover}

/* ---- CTA STRIP ---- */
.cta-strip{background:var(--red);padding:clamp(var(--space-10),6vw,var(--space-16)) 0}
.cta-strip-inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-6)}
.cta-strip h2{font-size:var(--text-xl);color:#fff;font-weight:900}
.cta-strip p{color:rgba(255,255,255,0.85);font-size:var(--text-base);margin-top:var(--space-2)}

/* ---- TESTIMONIALS ---- */
.testimonials{padding-block:clamp(var(--space-12),8vw,var(--space-24));background:var(--off-white)}
.testimonials-header{text-align:center;margin-bottom:var(--space-12)}
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-6)}
.testimonial-card{background:#fff;border-radius:var(--radius-xl);padding:var(--space-6);border:1px solid var(--gray-200);box-shadow:var(--shadow-sm)}
.stars{display:flex;gap:2px;margin-bottom:var(--space-4)}
.stars svg{color:#f5c842}
.testimonial-card blockquote{font-size:var(--text-sm);color:var(--gray-700);line-height:1.75;margin-bottom:var(--space-5);font-style:italic}
.testimonial-author{display:flex;align-items:center;gap:var(--space-3)}
.testimonial-avatar{width:44px;height:44px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--blue),var(--blue-light));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:var(--text-sm);font-family:var(--font-display);flex-shrink:0}
.testimonial-author strong{display:block;font-size:var(--text-sm);color:var(--gray-900)}
.testimonial-author span{font-size:var(--text-xs);color:var(--text-muted)}

/* ---- CONTACT ---- */
.contact{padding-block:clamp(var(--space-12),8vw,var(--space-24));background:#fff}
.contact-inner{display:grid;grid-template-columns:1fr 1.2fr;gap:var(--space-12);align-items:start}
.contact-info h2{font-size:var(--text-xl);font-weight:900;color:var(--gray-900);margin-bottom:var(--space-4)}
.contact-info p{font-size:var(--text-base);color:var(--text-muted);margin-bottom:var(--space-8)}
.contact-details{display:grid;gap:var(--space-5)}
.contact-item{display:flex;align-items:flex-start;gap:var(--space-4)}
.contact-item-icon{width:44px;height:44px;background:var(--blue);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-item-icon svg{color:#fff}
.contact-item h4{font-size:var(--text-sm);font-weight:700;color:var(--gray-900);margin-bottom:2px}
.contact-item p,.contact-item a{font-size:var(--text-sm);color:var(--text-muted)}
.contact-item a:hover{color:var(--red)}
.contact-form{background:var(--off-white);border:1px solid var(--gray-200);border-radius:var(--radius-xl);padding:var(--space-8)}
.contact-form h3{font-size:var(--text-lg);font-weight:800;color:var(--gray-900);margin-bottom:var(--space-6)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}
.form-group{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}
.form-group label{font-size:var(--text-sm);font-weight:600;color:var(--gray-700)}
.form-group input,.form-group select,.form-group textarea{padding:0.7rem 1rem;border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--text-sm);background:#fff;transition:border-color var(--transition),box-shadow var(--transition)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,74,138,0.15)}
.form-group textarea{resize:vertical;min-height:120px}
.form-submit{width:100%;padding:0.875rem;background:var(--blue);color:#fff;border-radius:var(--radius-full);font-family:var(--font-display);font-weight:700;font-size:var(--text-sm);text-transform:uppercase;letter-spacing:0.05em;transition:background var(--transition),transform var(--transition)}
.form-submit:hover{background:var(--blue-dark);transform:translateY(-1px)}

/* ---- FOOTER ---- */
.footer{background:var(--gray-900);color:rgba(255,255,255,0.75);padding-top:var(--space-16)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:var(--space-10);padding-bottom:var(--space-12);border-bottom:1px solid rgba(255,255,255,0.08)}
.footer-brand img{height:60px;margin-bottom:var(--space-4)}
.footer-brand p{font-size:var(--text-sm);line-height:1.7;max-width:32ch}
.footer-col h4{font-family:var(--font-display);font-weight:700;color:#fff;font-size:var(--text-sm);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:var(--space-5)}
.footer-col ul{display:grid;gap:var(--space-3)}
.footer-col ul a{font-size:var(--text-sm);color:rgba(255,255,255,0.65);transition:color var(--transition)}
.footer-col ul a:hover{color:#fff}
.footer-bottom{padding-block:var(--space-5);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-3)}
.footer-bottom p{font-size:var(--text-xs);color:rgba(255,255,255,0.45)}
.footer-bottom a{color:var(--red-light);transition:color var(--transition)}
.footer-bottom a:hover{color:#fff}

/* ---- MOBILE NAV ---- */
.mobile-nav{display:none;position:fixed;inset:0;background:var(--blue-dark);z-index:99;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-6)}
.mobile-nav.open{display:flex}
.mobile-nav a{color:#fff;font-size:var(--text-xl);font-weight:700;font-family:var(--font-display)}
.mobile-nav-close{position:absolute;top:var(--space-5);right:var(--space-5);color:#fff;font-size:2rem;background:none;border:none;cursor:pointer}

/* ---- RESPONSIVE ---- */
@media(max-width:900px){
  .why-us-inner{grid-template-columns:1fr}
  .why-image{max-height:300px}
  .contact-inner{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
}
@media(max-width:640px){
  .nav-links{display:none}
  .hamburger{display:flex}
  .hero h1{font-size:clamp(2rem,8vw,3.5rem)}
  .hero p{font-size:var(--text-base)}
  .hero-stats{gap:var(--space-5)}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .cta-strip-inner{flex-direction:column;text-align:center}
  .trust-items{gap:var(--space-5)}
}

/* ---- SUCCESS MESSAGE ---- */
.form-success{display:none;text-align:center;padding:var(--space-8);background:#ecfdf5;border:1px solid #6ee7b7;border-radius:var(--radius-lg)}
.form-success svg{color:#10b981;margin:0 auto var(--space-4)}
.form-success h4{color:#065f46;font-size:var(--text-lg);font-weight:700}
.form-success p{color:#047857;font-size:var(--text-sm)}
