/* =============================================================
   Davis County HVAC Pros — Trade Navy + Orange palette
   Static rank-and-rent site, no framework, no font import.
   ============================================================= */

:root {
  --color-primary: #0a3d7a;
  --color-primary-dark: #082c5a;
  --color-primary-light: #1f5fa8;
  --color-accent: #e85a1a;
  --color-accent-dark: #d44e0e;
  --color-text: #1a1a1a;
  --color-text-muted: #444;
  --color-text-light: #666;
  --color-bg: #ffffff;
  --color-bg-alt: #f7fafc;
  --color-bg-hero: #f0f6fc;
  --color-border: #e5e7eb;
  --color-footer-bg: #0a1a2f;
  --color-footer-text: #cbd5e0;
  --color-disclosure-bg: #0a3d7a;
  --color-disclosure-text: #e5edf6;

  --font-sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;

  --text-base: 17px;
  --text-sm: 14px;
  --text-xs: 12px;
  --text-lg: 18px;
  --text-xl: 20px;
  --text-2xl: clamp(24px, 3.5vw, 32px);
  --text-3xl: clamp(28px, 5vw, 42px);

  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-14: 56px;
  --space-16: 64px;

  --container-max: 1200px;
  --container-padding: 20px;

  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;

  --shadow-sm: 0 2px 8px rgba(0,0,0,0.04);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.08);
  --shadow-lg: 0 8px 24px rgba(10,61,122,0.10);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;line-height:1.6}
body{margin:0;font-family:var(--font-sans);font-size:var(--text-base);line-height:1.6;color:var(--color-text);background:var(--color-bg);padding-bottom:80px}
@media(min-width:768px){body{padding-bottom:0}}
img{max-width:100%;height:auto;display:block}
a{color:inherit}

h1,h2,h3,h4{color:var(--color-primary);line-height:1.15;margin:0 0 var(--space-4);font-weight:700}
h1{font-size:var(--text-3xl);font-weight:800}
h2{font-size:var(--text-2xl);line-height:1.25}
h3{font-size:var(--text-xl)}
p{margin:0 0 var(--space-4)}

.container{width:100%;max-width:var(--container-max);margin:0 auto;padding:0 var(--container-padding)}
.section{padding:var(--space-14) 0}
.section-alt{background:var(--color-bg-alt)}

/* === Disclosure band (mandatory lead-share) === */
.disclosure{background:var(--color-disclosure-bg);color:var(--color-disclosure-text);font-size:13px;padding:var(--space-3) 0;text-align:center}
.disclosure p{margin:0 auto;max-width:900px;padding:0 var(--container-padding)}

/* === Header === */
.site-header{position:sticky;top:0;background:var(--color-bg);border-bottom:1px solid var(--color-border);z-index:50}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:var(--space-6)}
.logo{font-weight:800;font-size:var(--text-lg);color:var(--color-primary);text-decoration:none;letter-spacing:-0.01em}
.logo span{color:var(--color-accent)}
.primary-nav{display:none}
@media(min-width:900px){
  .primary-nav{display:flex;gap:var(--space-6)}
  .primary-nav a{text-decoration:none;font-weight:500;color:#333;font-size:15px}
  .primary-nav a:hover{color:var(--color-primary)}
}
.btn-call-header{display:inline-flex;align-items:center;gap:var(--space-2);background:var(--color-accent);color:#fff;padding:10px 16px;border-radius:var(--radius-md);text-decoration:none;font-weight:600;font-size:15px;white-space:nowrap}
.btn-call-header:hover{background:var(--color-accent-dark)}
@media(max-width:480px){.btn-call-header .full-label{display:none}}

/* === Hero === */
.hero{padding:var(--space-10) 0 var(--space-12);background:linear-gradient(180deg,var(--color-bg-hero),var(--color-bg))}
.hero-grid{display:grid;gap:var(--space-8);grid-template-columns:1fr}
@media(min-width:900px){.hero-grid{grid-template-columns:1.1fr 1fr;gap:var(--space-12);align-items:start}}
.hero h1{margin:0 0 var(--space-4)}
.hero-lead{font-size:var(--text-lg);color:#333;margin:0 0 var(--space-6)}
.hero-call-cta{display:inline-flex;align-items:center;gap:var(--space-2);background:var(--color-accent);color:#fff;padding:14px 24px;border-radius:var(--radius-md);text-decoration:none;font-weight:700;font-size:18px;min-height:48px}
.hero-call-cta:hover{background:var(--color-accent-dark)}
.hero-bullets{margin:var(--space-6) 0 0;padding:0;list-style:none;display:grid;gap:var(--space-2);color:var(--color-text-muted);font-size:15px}
.hero-bullets li{padding-left:var(--space-6);position:relative}
.hero-bullets li::before{content:"✓";position:absolute;left:0;color:var(--color-accent);font-weight:700}

/* === Form card (single-screen, urgent-service) === */
.form-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-lg)}
.form-card h2{font-size:20px;margin:0 0 var(--space-2)}
.form-intro{font-size:13px;color:var(--color-text-light);margin:0 0 var(--space-4)}
.form-field{margin-bottom:var(--space-3)}
.form-row{display:grid;gap:var(--space-3);grid-template-columns:1fr}
@media(min-width:480px){.form-row{grid-template-columns:1fr 1fr}}
label{display:block;font-weight:600;margin-bottom:var(--space-2);font-size:13px;color:#333}
input[type=text],input[type=tel],input[type=email],select,textarea{width:100%;padding:11px;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:16px;font-family:inherit;background:var(--color-bg)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary)}
textarea{min-height:72px;resize:vertical}
.btn-submit{display:block;width:100%;padding:14px 24px;border-radius:var(--radius-md);background:var(--color-accent);color:#fff;font-weight:700;font-size:16px;border:none;cursor:pointer;min-height:48px;margin-top:var(--space-2)}
.btn-submit:hover{background:var(--color-accent-dark)}
.form-fine{font-size:11px;color:var(--color-text-light);margin:var(--space-3) 0 0;line-height:1.4}
.honeypot{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* === Sticky mobile call button === */
.btn-sticky-mobile-call{display:flex;align-items:center;justify-content:center;gap:var(--space-2);position:fixed;bottom:var(--space-4);left:var(--space-4);right:var(--space-4);background:var(--color-accent);color:#fff;padding:var(--space-4);border-radius:var(--radius-md);text-decoration:none;font-weight:700;font-size:16px;box-shadow:var(--shadow-md);z-index:40}
@media(min-width:768px){.btn-sticky-mobile-call{display:none}}

/* === Grids / cards === */
.grid{display:grid;gap:var(--space-6);margin-top:var(--space-8)}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-6);box-shadow:var(--shadow-sm)}
.card h3{margin-top:0}
.card a{color:var(--color-accent);font-weight:600;text-decoration:none}
.card a:hover{text-decoration:underline}

/* === FAQ === */
.faq-item{border-bottom:1px solid var(--color-border);padding:var(--space-4) 0}
.faq-item summary{font-weight:600;font-size:17px;cursor:pointer;list-style:none;padding-right:var(--space-6);position:relative;color:var(--color-primary)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";position:absolute;right:0;top:-2px;font-size:24px;color:var(--color-accent);font-weight:700}
.faq-item[open] summary::after{content:"−"}
.faq-item p{margin:var(--space-3) 0 0;color:var(--color-text-muted)}

/* === Area list (multi-column) === */
.area-list{columns:2;max-width:600px;list-style:disc inside;padding:0}
.area-list li{margin-bottom:var(--space-2)}
.area-list a{color:var(--color-primary);text-decoration:none;font-weight:500}
.area-list a:hover{text-decoration:underline}

/* === CTA mini === */
.cta-mini{background:var(--color-primary);color:#fff;padding:var(--space-8);border-radius:var(--radius-md);text-align:center;margin:var(--space-8) auto;max-width:780px}
.cta-mini h3{color:#fff;margin-top:0}
.cta-mini a.btn-cta{display:inline-block;margin-top:var(--space-3);background:var(--color-accent);color:#fff;padding:12px 20px;border-radius:var(--radius-md);text-decoration:none;font-weight:700}
.cta-mini a.btn-cta:hover{background:var(--color-accent-dark)}

/* === Breadcrumbs === */
.breadcrumbs{font-size:14px;color:var(--color-text-light);padding:var(--space-3) 0;background:var(--color-bg-alt);border-bottom:1px solid var(--color-border)}
.breadcrumbs a{color:var(--color-primary);text-decoration:none}
.breadcrumbs a:hover{text-decoration:underline}

/* === Trust strip === */
.trust-strip{display:flex;flex-wrap:wrap;gap:var(--space-3);margin:var(--space-4) 0 0;font-size:14px;color:var(--color-text-muted)}
.trust-strip span{display:inline-flex;align-items:center;gap:6px;background:#e5edf6;color:var(--color-primary);padding:5px 12px;border-radius:999px;font-weight:500}

/* === Prose body === */
.prose{max-width:780px}
.prose p,.prose ul,.prose ol{margin:0 0 var(--space-4)}
.prose ul,.prose ol{padding-left:var(--space-6)}
.prose li{margin-bottom:var(--space-2)}

/* === Footer === */
.site-footer{background:var(--color-footer-bg);color:var(--color-footer-text);padding:var(--space-12) 0 var(--space-6);margin-top:var(--space-16)}
.footer-inner{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-8)}
.site-footer h3,.site-footer h4{color:#fff;margin-top:0}
.site-footer a{color:var(--color-footer-text);text-decoration:none}
.site-footer a:hover{color:#fff}
.footer-nav{display:flex;flex-direction:column;gap:var(--space-2);font-size:15px}
.footer-bottom{padding-top:var(--space-8);margin-top:var(--space-8);border-top:1px solid #1f2d44;text-align:center;color:#888;font-size:13px}

/* === Mobile tweaks === */
@media(max-width:768px){.section{padding:var(--space-10) 0}h2{margin:var(--space-8) 0 var(--space-3)}}

/* === Accessibility === */
:focus-visible{outline:3px solid var(--color-accent);outline-offset:2px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{transition-duration:.01ms!important;animation-duration:.01ms!important}}

/* === Print === */
@media print{.btn-sticky-mobile-call,.site-header,.site-footer{display:none}}
