/* ============================================================
   GARAGE FORCE WEST MICHIGAN — Funnel Page
   Industrial premium: Deep charcoal + burnt orange (#E85D04)
   ============================================================ */

:root {
  /* Fonts */
  --font-display: 'Barlow Condensed', Impact, sans-serif;
  --font-body: 'Inter', system-ui, -apple-system, sans-serif;

  /* Colors */
  --dark:        #111010;
  --dark-2:      #1A1815;
  --dark-3:      #242220;
  --dark-4:      #2E2B28;
  --dark-border: rgba(255,255,255,0.08);

  --orange:      #E85D04;
  --orange-h:    #C94E00;
  --orange-dim:  rgba(232,93,4,0.15);
  --orange-glow: rgba(232,93,4,0.08);

  --bg:          #F4F3F0;
  --bg-2:        #FFFFFF;
  --surface:     #FFFFFF;
  --border:      #DDD9D4;

  --text:        #1A1815;
  --text-m:      #5E5C58;
  --text-f:      #A8A5A0;

  --star:        #F59E0B;
  --success:     #2E7D32;

  /* Spacing */
  --s1:.25rem; --s2:.5rem; --s3:.75rem; --s4:1rem;
  --s5:1.25rem; --s6:1.5rem; --s8:2rem; --s10:2.5rem;
  --s12:3rem; --s16:4rem; --s20:5rem; --s24:6rem;

  --r-sm:.375rem; --r-md:.5rem; --r-lg:.875rem; --r-xl:1.25rem; --r-full:9999px;

  --max-w: 1180px;
  --t: 180ms cubic-bezier(0.16,1,0.3,1);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { -webkit-font-smoothing:antialiased; scroll-behavior:smooth; scroll-padding-top:72px; }
body { font-family:var(--font-body); font-size:1rem; color:var(--text); background:var(--bg); line-height:1.6; }
img,svg { display:block; max-width:100%; }
a,button,input,select { font:inherit; color:inherit; transition:all var(--t); }
button { cursor:pointer; background:none; border:none; }
h1,h2,h3 { text-wrap:balance; }

.container {
  width:100%; max-width:var(--max-w);
  margin-inline:auto;
  padding-inline:clamp(var(--s5),5vw,var(--s12));
}

/* ─── HEADER ─── */
.site-header {
  position:sticky; top:0; z-index:200;
  background:var(--dark-2);
  border-bottom:1px solid var(--dark-border);
}
.header-inner {
  max-width:var(--max-w); margin-inline:auto;
  padding:var(--s4) clamp(var(--s5),5vw,var(--s12));
  display:flex; align-items:center; justify-content:space-between; gap:var(--s4);
}
.logo { display:flex; align-items:center; gap:var(--s3); text-decoration:none; }
.logo-text {
  font-family:var(--font-display); font-size:1.25rem; font-weight:700;
  color:#fff; text-transform:uppercase; letter-spacing:.03em; line-height:1.1;
}
.logo-region { display:block; font-size:.7rem; font-weight:400; color:rgba(255,255,255,.35); letter-spacing:.06em; }
.header-phone {
  display:flex; align-items:center; gap:var(--s2);
  font-size:.875rem; font-weight:700; color:var(--orange);
  text-decoration:none; padding:var(--s2) var(--s4);
  border:1.5px solid var(--orange); border-radius:var(--r-full);
  white-space:nowrap;
}
.header-phone:hover { background:var(--orange); color:#fff; }

/* ─── BUTTONS ─── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:var(--s2);
  padding:var(--s4) var(--s8); font-size:.9rem; font-weight:700;
  border-radius:var(--r-md); text-decoration:none; cursor:pointer;
  border:2px solid transparent; white-space:nowrap; letter-spacing:.01em;
}
.btn-primary { background:var(--orange); color:#fff; border-color:var(--orange); }
.btn-primary:hover { background:var(--orange-h); border-color:var(--orange-h); }
.btn-ghost { background:transparent; color:#fff; border-color:rgba(255,255,255,.3); }
.btn-ghost:hover { background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.6); }
.btn-white { background:#fff; color:var(--orange); border-color:#fff; font-weight:800; }
.btn-white:hover { background:rgba(255,255,255,.92); }
.btn-outline-white { background:transparent; color:#fff; border-color:rgba(255,255,255,.45); }
.btn-outline-white:hover { background:rgba(255,255,255,.1); }
.btn-full { width:100%; padding-block:var(--s5); font-size:1rem; }

/* ─── HERO ─── */
.hero {
  background:var(--dark-2);
  display:grid; grid-template-columns:1fr 1fr;
  align-items:center; gap:var(--s12);
  padding:clamp(var(--s12),6vw,var(--s20)) clamp(var(--s5),5vw,var(--s12));
  max-width:var(--max-w); margin-inline:auto;
  min-height:calc(100vh - 62px);
  position:relative;
}
.hero-glow {
  position:fixed; inset:0; pointer-events:none; z-index:0;
  background:radial-gradient(ellipse 70% 60% at 15% 55%, rgba(232,93,4,0.1) 0%, transparent 65%);
}
.hero-content, .hero-form-col { position:relative; z-index:1; }

.hero-badge {
  display:inline-block;
  background:rgba(232,93,4,.15); color:#FF8A3D;
  font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em;
  padding:var(--s2) var(--s4); border-radius:var(--r-full);
  border:1px solid rgba(232,93,4,.3); margin-bottom:var(--s6);
}
.hero-headline {
  font-family:var(--font-display); font-weight:900;
  font-size:clamp(3.2rem, 4.5vw + 1.5rem, 7rem);
  color:#fff; line-height:.96; letter-spacing:-.01em;
  text-transform:uppercase; margin-bottom:var(--s6);
}
.accent { color:var(--orange); }
.hero-sub {
  font-size:clamp(1rem,1.2vw,.1rem + 1.2vw + .8rem, 1.15rem);
  font-size:1.05rem;
  color:rgba(255,255,255,.62); line-height:1.65; max-width:46ch; margin-bottom:var(--s8);
}
.hero-ctas { display:flex; flex-wrap:wrap; gap:var(--s4); margin-bottom:var(--s8); }
.hero-trust {
  display:flex; flex-wrap:wrap; gap:var(--s2) var(--s3);
  padding-top:var(--s6); border-top:1px solid rgba(255,255,255,.08);
}
.trust-pill {
  display:inline-flex; align-items:center; gap:6px;
  font-size:.75rem; font-weight:600; color:rgba(255,255,255,.5);
  padding:5px 10px; border-radius:var(--r-full);
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.04);
}
.trust-pill svg { color:var(--orange); flex-shrink:0; }

/* FORM CARD */
.form-card {
  background:var(--surface); border-radius:var(--r-xl);
  padding:clamp(var(--s6),4vw,var(--s10));
  box-shadow:0 12px 60px rgba(0,0,0,.35), 0 0 0 1px rgba(255,255,255,.04);
  border:1px solid var(--border);
}
.form-tag {
  display:inline-block; background:var(--orange); color:#fff;
  font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em;
  padding:3px var(--s3); border-radius:var(--r-sm); margin-bottom:var(--s3);
}
.form-title {
  font-family:var(--font-display); font-size:1.9rem; font-weight:800;
  text-transform:uppercase; color:var(--text); margin-bottom:var(--s2);
}
.form-sub { font-size:.875rem; color:var(--text-m); margin-bottom:var(--s5); line-height:1.5; }
.est-form { display:flex; flex-direction:column; gap:var(--s4); }
.fg { display:flex; flex-direction:column; gap:6px; }
.fg-row { display:grid; grid-template-columns:1fr 1fr; gap:var(--s4); }
label { font-size:.825rem; font-weight:600; color:var(--text); }
input, select {
  width:100%; padding:10px var(--s4);
  border:1.5px solid var(--border); border-radius:var(--r-md);
  font-size:.9rem; background:var(--surface); color:var(--text);
}
input:focus, select:focus {
  outline:none; border-color:var(--orange);
  box-shadow:0 0 0 3px rgba(232,93,4,.12);
}
input::placeholder { color:var(--text-f); }
.form-note { font-size:.75rem; color:var(--text-f); text-align:center; line-height:1.5; }

/* ─── STATS BAR ─── */
.stats-bar { background:var(--dark); padding:clamp(var(--s8),4vw,var(--s12)) 0; }
.stats-grid {
  display:grid; grid-template-columns:repeat(5,1fr);
  gap:var(--s6); text-align:center;
}
.stat { display:flex; flex-direction:column; gap:4px; }
.stat-num {
  font-family:var(--font-display);
  font-size:clamp(1.8rem,2.5vw + .5rem,3rem);
  font-weight:900; color:var(--orange); line-height:1; text-transform:uppercase;
}
.stat-label { font-size:.72rem; color:rgba(255,255,255,.4); text-transform:uppercase; letter-spacing:.06em; font-weight:500; }

/* ─── SECTIONS ─── */
.section { padding:clamp(var(--s12),7vw,var(--s24)) 0; }
.eyebrow {
  font-size:.72rem; font-weight:700; text-transform:uppercase;
  letter-spacing:.12em; color:var(--orange); margin-bottom:var(--s3);
}
.eyebrow-light { color:#FF8A3D; }
.section-title {
  font-family:var(--font-display);
  font-size:clamp(2rem,2.5vw + 1rem,3.5rem);
  font-weight:900; text-transform:uppercase; color:var(--text);
  line-height:1; margin-bottom:var(--s4);
}
.section-title-light { color:#fff; }
.section-intro { font-size:1rem; color:var(--text-m); max-width:60ch; line-height:1.65; margin-bottom:var(--s10); }
.section-intro-light { color:rgba(255,255,255,.5); }
.body-text { font-size:1rem; color:var(--text-m); line-height:1.7; max-width:55ch; }

/* ─── CYCLOSPHARTIC SECTION ─── */
.cyclosphartic-section { background:var(--bg-2); }
.two-col { display:grid; grid-template-columns:1fr 1fr; gap:clamp(var(--s10),6vw,var(--s20)); align-items:center; }
.feature-list { display:flex; flex-direction:column; gap:var(--s5); margin-top:var(--s8); }
.feat { display:flex; align-items:flex-start; gap:var(--s4); }
.feat-icon {
  width:32px; height:32px; flex-shrink:0; border-radius:50%;
  background:var(--orange-dim); display:flex; align-items:center; justify-content:center;
  color:var(--orange); margin-top:2px;
}
.feat-title { font-size:.95rem; font-weight:700; color:var(--text); margin-bottom:2px; }
.feat-desc { font-size:.85rem; color:var(--text-m); line-height:1.55; }

/* WARRANTY CARD */
.warranty-card {
  background:var(--dark-2); border-radius:var(--r-xl);
  padding:var(--s8); border:1px solid var(--dark-border);
  box-shadow:0 8px 40px rgba(0,0,0,.25);
  display:flex; flex-direction:column; gap:var(--s5);
  position:relative; overflow:hidden;
}
.warranty-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--orange);
}
.wc-badge {
  display:inline-block; background:var(--orange); color:#fff;
  font-size:.65rem; font-weight:800; text-transform:uppercase; letter-spacing:.1em;
  padding:3px 10px; border-radius:var(--r-full); align-self:flex-start;
}
.wc-title { font-family:var(--font-display); font-size:2.2rem; font-weight:900; color:#fff; text-transform:uppercase; line-height:1; }
.wc-sub { font-size:.8rem; color:rgba(255,255,255,.4); text-transform:uppercase; letter-spacing:.1em; margin-top:-var(--s2); }
.wc-divider { height:1px; background:var(--dark-border); }
.wc-stat { display:flex; align-items:baseline; gap:var(--s3); }
.wc-big { font-family:var(--font-display); font-size:3.5rem; font-weight:900; color:var(--orange); line-height:1; }
.wc-desc { font-size:.85rem; color:rgba(255,255,255,.5); }
.wc-warranty-label { font-size:.7rem; color:rgba(255,255,255,.3); text-transform:uppercase; letter-spacing:.1em; margin-bottom:var(--s2); }
.wc-warranty-value { font-family:var(--font-display); font-size:2.8rem; font-weight:900; color:#fff; text-transform:uppercase; line-height:1; margin-bottom:var(--s2); }
.wc-warranty-note { font-size:.8rem; color:rgba(255,255,255,.4); font-style:italic; }
.wc-exclusive-note { font-size:.8rem; color:rgba(255,255,255,.35); line-height:1.5; }
.wc-exclusive-note strong { color:rgba(255,255,255,.6); }

/* ─── COMPARE ─── */
.compare-section { background:var(--bg); }
.compare-grid { display:grid; grid-template-columns:1fr 1fr; gap:var(--s6); }
.compare-card {
  border-radius:var(--r-lg); padding:var(--s8);
  border:1.5px solid var(--border);
}
.compare-us {
  background:var(--dark-2); border-color:var(--orange);
  position:relative; overflow:hidden;
}
.compare-us::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--orange); }
.compare-them { background:#fff; }
.compare-header {
  display:flex; align-items:center; gap:var(--s3);
  margin-bottom:var(--s6); padding-bottom:var(--s4);
  border-bottom:1px solid var(--dark-border);
}
.compare-them .compare-header { border-bottom-color:var(--border); }
.compare-logo-sm { flex-shrink:0; }
.compare-name { font-family:var(--font-display); font-size:1.2rem; font-weight:800; text-transform:uppercase; color:#fff; }
.compare-them-name { color:var(--text-m); }
.compare-list { list-style:none; display:flex; flex-direction:column; gap:var(--s4); }
.compare-list li { display:flex; align-items:flex-start; gap:var(--s3); font-size:.9rem; line-height:1.4; }
.compare-us .compare-list li { color:rgba(255,255,255,.8); }
.compare-them .compare-list li { color:var(--text-m); }
.pro span { color:var(--orange); font-weight:800; flex-shrink:0; }
.con span { color:var(--text-f); font-weight:800; flex-shrink:0; }

/* ─── FINISHES ─── */
.finishes-section { background:var(--dark-2); }
.finishes-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:var(--s4); }
.finish-card {
  border-radius:var(--r-lg); overflow:hidden;
  background:var(--dark-3); border:1px solid rgba(255,255,255,.06);
  transition:transform var(--t), box-shadow var(--t);
}
.finish-card:hover { transform:translateY(-5px); box-shadow:0 16px 40px rgba(0,0,0,.4); }
.finish-swatch { height:130px; width:100%; }
.swatch-fullchip {
  background:
    radial-gradient(circle at 20% 30%, #888 2px, transparent 2px),
    radial-gradient(circle at 60% 70%, #aaa 1.5px, transparent 1.5px),
    radial-gradient(circle at 80% 20%, #666 2px, transparent 2px),
    radial-gradient(circle at 40% 80%, #999 1px, transparent 1px),
    #5a5a58;
  background-size: 20px 20px, 15px 15px, 25px 25px, 18px 18px, auto;
}
.swatch-metallic { background:linear-gradient(135deg,#7a6347 0%,#c4a870 25%,#5c4a33 50%,#d4b895 75%,#7a6347 100%); }
.swatch-medici { background:linear-gradient(160deg,#3d3a38 0%,#605852 35%,#302e2c 65%,#524d49 100%); }
.swatch-quartz { background:radial-gradient(circle at 30% 40%,#c8b89a 0%,#a89878 40%,#8b7a62 100%); }
.swatch-solid { background:linear-gradient(135deg,#35312e,#2a2724); }
.finish-info {
  display:flex; align-items:center; justify-content:space-between;
  gap:var(--s2); padding:var(--s4) var(--s4) var(--s2);
}
.finish-name { font-family:var(--font-display); font-size:1rem; font-weight:700; text-transform:uppercase; color:#fff; letter-spacing:.03em; }
.finish-badge {
  font-size:.65rem; font-weight:700; text-transform:uppercase; letter-spacing:.06em;
  color:var(--orange); background:rgba(232,93,4,.15);
  padding:2px 8px; border-radius:var(--r-full); border:1px solid rgba(232,93,4,.25);
  white-space:nowrap;
}
.finish-desc { font-size:.78rem; color:rgba(255,255,255,.38); padding:0 var(--s4) var(--s5); line-height:1.55; }

/* ─── SURFACES ─── */
.surfaces-section { background:var(--bg-2); }
.surfaces-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:var(--s4); }
.surface-card {
  background:var(--bg); border:1.5px solid var(--border);
  border-radius:var(--r-lg); padding:var(--s6) var(--s5);
  text-align:center; transition:box-shadow var(--t), border-color var(--t);
}
.surface-card:hover { border-color:var(--orange); box-shadow:0 4px 20px rgba(232,93,4,.1); }
.surface-icon { font-size:2rem; margin-bottom:var(--s3); }
.surface-name { font-family:var(--font-display); font-size:1rem; font-weight:800; text-transform:uppercase; color:var(--text); margin-bottom:var(--s2); }
.surface-desc { font-size:.8rem; color:var(--text-m); line-height:1.55; }

/* ─── REVIEWS ─── */
.reviews-section { background:var(--bg); }
.rating-row { display:flex; align-items:center; gap:var(--s3); margin-bottom:var(--s10); }
.stars-lg { font-size:1.6rem; color:var(--star); letter-spacing:2px; line-height:1; }
.rating-num { font-family:var(--font-display); font-size:2.5rem; font-weight:900; color:var(--text); line-height:1; }
.rating-label { font-size:.875rem; color:var(--text-m); }
.reviews-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s5); }
.review-card {
  background:var(--surface); border-radius:var(--r-lg);
  padding:var(--s6); border:1px solid var(--border);
  display:flex; flex-direction:column; gap:var(--s4);
  box-shadow:0 1px 4px rgba(0,0,0,.06);
  transition:box-shadow var(--t), transform var(--t);
}
.review-card:hover { box-shadow:0 6px 24px rgba(0,0,0,.1); transform:translateY(-2px); }
.review-stars { font-size:1rem; color:var(--star); letter-spacing:2px; }
.review-text { font-size:.875rem; color:var(--text-m); line-height:1.7; flex:1; font-style:italic; }
.reviewer {
  display:flex; align-items:center; gap:var(--s3);
  padding-top:var(--s4); border-top:1px solid var(--border);
}
.av {
  width:36px; height:36px; border-radius:50%;
  background:var(--orange); color:#fff;
  font-size:.7rem; font-weight:800; display:flex; align-items:center; justify-content:center;
  flex-shrink:0; letter-spacing:.04em;
}
.rv-name { font-size:.875rem; font-weight:700; color:var(--text); line-height:1.2; }
.rv-loc { font-size:.75rem; color:var(--text-m); }

/* ─── SERVICE AREA ─── */
.area-section { background:var(--bg-2); }
.area-grid { display:grid; grid-template-columns:1fr 1fr; gap:var(--s8); }
.area-block { display:flex; flex-direction:column; gap:var(--s4); }
.area-title { font-family:var(--font-display); font-size:1.1rem; font-weight:700; text-transform:uppercase; color:var(--text); letter-spacing:.03em; }
.area-tags { display:flex; flex-wrap:wrap; gap:var(--s2); }
.tag {
  font-size:.8rem; font-weight:500; padding:5px 12px;
  border-radius:var(--r-full); border:1px solid var(--border);
  background:var(--bg); color:var(--text-m);
}
.tag-primary { background:var(--orange-dim); border-color:rgba(232,93,4,.3); color:var(--orange); font-weight:600; }

/* ─── BOTTOM CTA ─── */
.cta-section { background:var(--orange); padding:clamp(var(--s12),6vw,var(--s20)) 0; }
.cta-inner {
  display:flex; align-items:center; justify-content:space-between;
  gap:var(--s8); flex-wrap:wrap;
}
.cta-badge {
  display:inline-block; background:rgba(255,255,255,.18); color:#fff;
  font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em;
  padding:3px 12px; border-radius:var(--r-full); margin-bottom:var(--s3);
  border:1px solid rgba(255,255,255,.25);
}
.cta-title { font-family:var(--font-display); font-size:clamp(1.8rem,2.5vw + .5rem,3rem); font-weight:900; color:#fff; text-transform:uppercase; line-height:1; margin-bottom:var(--s3); }
.cta-body { font-size:1rem; color:rgba(255,255,255,.75); }
.cta-actions { display:flex; gap:var(--s4); flex-wrap:wrap; flex-shrink:0; }

/* ─── FOOTER ─── */
.site-footer { background:var(--dark); padding:var(--s8) 0; border-top:1px solid rgba(255,255,255,.05); }
.footer-row { display:flex; align-items:center; justify-content:space-between; gap:var(--s6); flex-wrap:wrap; margin-bottom:var(--s4); }
.footer-brand { display:flex; align-items:center; gap:var(--s3); font-size:.9rem; font-weight:600; color:rgba(255,255,255,.55); }
.footer-contact { display:flex; align-items:center; gap:var(--s3); }
.footer-phone, .footer-email { font-size:.875rem; color:rgba(255,255,255,.4); text-decoration:none; }
.footer-phone:hover, .footer-email:hover { color:var(--orange); }
.footer-sep { color:rgba(255,255,255,.2); }
.footer-legal { font-size:.72rem; color:rgba(255,255,255,.2); line-height:1.6; }

/* ─── MOBILE STICKY CTA ─── */
.mobile-cta {
  display:none;
  position:fixed; bottom:0; left:0; right:0; z-index:300;
  background:var(--dark-2); border-top:1px solid rgba(255,255,255,.1);
  padding:var(--s3) var(--s4);
  gap:var(--s3);
}
.mobile-cta-call {
  flex:1; display:flex; align-items:center; justify-content:center; gap:var(--s2);
  padding:var(--s4); background:var(--dark-4); color:#fff;
  border-radius:var(--r-md); font-weight:700; font-size:.9rem; text-decoration:none;
  border:1.5px solid rgba(255,255,255,.15);
}
.mobile-cta-form {
  flex:1.5; display:flex; align-items:center; justify-content:center;
  padding:var(--s4); background:var(--orange); color:#fff;
  border-radius:var(--r-md); font-weight:800; font-size:.9rem; text-decoration:none;
}
.mobile-cta-call:hover { background:var(--dark-3); }
.mobile-cta-form:hover { background:var(--orange-h); }

/* ─── RESPONSIVE ─── */
@media (max-width:1100px) {
  .finishes-grid { grid-template-columns:repeat(3,1fr); }
  .surfaces-grid { grid-template-columns:repeat(3,1fr); }
  .stats-grid { grid-template-columns:repeat(3,1fr); }
}
@media (max-width:900px) {
  .hero { grid-template-columns:1fr; min-height:auto; gap:var(--s8); padding-top:var(--s10); }
  .hero-glow { display:none; }
  .two-col { grid-template-columns:1fr; }
  .compare-grid { grid-template-columns:1fr; }
  .area-grid { grid-template-columns:1fr; }
  .cta-inner { flex-direction:column; text-align:center; }
  .cta-actions { justify-content:center; }
}
@media (max-width:680px) {
  .reviews-grid { grid-template-columns:1fr; }
  .finishes-grid { grid-template-columns:repeat(2,1fr); }
  .surfaces-grid { grid-template-columns:repeat(2,1fr); }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .fg-row { grid-template-columns:1fr; }
  .hero-ctas .btn { flex:1; min-width:0; }
  .footer-row { flex-direction:column; text-align:center; }
  .mobile-cta { display:flex; }
  body { padding-bottom:80px; }
  .hero-headline { font-size:clamp(2.8rem,12vw,4.5rem); }
}
@media (max-width:420px) {
  .finishes-grid, .surfaces-grid { grid-template-columns:1fr; }
  .stats-grid { grid-template-columns:1fr 1fr; }
}
