/* ═══════════════════════════════════════════════════════════════
   Gulf Coast Cooling — HOME PAGE CSS
   index.html specific styles
═══════════════════════════════════════════════════════════════ */

/* ─── HERO ───
   CONTRAST T1: T1 hero is white bg, card on right, minimal.
   T2: orange-accented split, left-editorial, dense badge strip, warmer.
─── */
.hero{
  background:var(--navy);
  padding:var(--sp8) 0 var(--sp7);
  position:relative;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;
  top:-120px;right:-120px;
  width:500px;height:500px;border-radius:50%;
  background:var(--orange);opacity:.04;
  pointer-events:none;z-index:0;
}
.hero-inner{
  max-width:var(--max-w);margin:0 auto;padding:0 var(--sp4);
  display:grid;grid-template-columns:1fr 1fr;
  gap:var(--sp7);align-items:center;
  position:relative;z-index:1;
}
.hero-tag{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'DM Sans',sans-serif;font-size:20px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--orange);margin-bottom:var(--sp3);
  position:relative;z-index:1;
}
.hero-tag-dot{
  width:10px;height:10px;border-radius:50%;
  background:var(--orange);
  box-shadow:0 0 0 3px rgba(249,115,22,.2);
  animation:pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot{
  0%,100%{box-shadow:0 0 0 3px rgba(249,115,22,.2)}
  50%{box-shadow:0 0 0 6px rgba(249,115,22,.08)}
}
.hero h1{
  font-size:clamp(3rem,5.5vw,4.4rem);
  margin-bottom:var(--sp3);
  color:#fff;
}
.hero-sub{
  font-size:1.05rem;line-height:1.8;
  color:rgba(255,255,255,.65);margin-bottom:var(--sp4);
  max-width:480px;
}
.hero-actions{display:flex;gap:var(--sp2);flex-wrap:wrap;margin-bottom:var(--sp4)}
.hero-trust-strip{
  display:flex;flex-direction:column;gap:10px;
}
.hero-trust-item{
  display:flex;align-items:center;gap:10px;
  font-size:0.88rem;font-weight:600;color:rgba(255,255,255,.7);
}
.hero-trust-icon{
  width:28px;height:28px;border-radius:var(--r);
  background:rgba(249,115,22,.15);
  display:flex;align-items:center;justify-content:center;
  color:var(--orange);flex-shrink:0;
}

/* Hero right — photo + floating cards */
.hero-visual{position:relative;padding-left:var(--sp3)}
.hero-photo{
  border-radius:var(--rxl);overflow:hidden;
  box-shadow:var(--sh-lg);
  background:var(--navy);/* placeholder color */
  aspect-ratio:4/5;
  position:relative;
}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-float-card{
  position:absolute;
  background:#fff;border-radius:var(--rl);
  padding:var(--sp2) var(--sp3);
  box-shadow:var(--sh-lg);
  display:flex;align-items:center;gap:var(--sp2);
}
.hero-float-card--tl{top:var(--sp4);left:-var(--sp4)}
.hero-float-card--br{bottom:var(--sp4);right:-var(--sp4)}
.hfc-icon{
  width:38px;height:38px;border-radius:var(--rm);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.hfc-icon--orange{background:var(--orange-soft);color:var(--orange)}
.hfc-icon--green{background:rgba(22,163,74,.1);color:#16A34A}
.hfc-text strong{font-family:'Manrope',sans-serif;font-weight:800;font-size:1.1rem;color:var(--navy);display:block;line-height:1}
.hfc-text span{font-size:0.75rem;color:var(--text-muted)}

/* ─── PROBLEM → SOLUTION ─── */
.problem-section{background:var(--gray-50);padding:var(--sp8) 0}
.problem-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:var(--sp7);align-items:center;
}
.problem-visual-block{
  background:var(--navy);border-radius:var(--rxl);
  padding:var(--sp5);position:relative;overflow:hidden;
}
.problem-visual-block::after{
  content:'';position:absolute;bottom:-60px;right:-60px;
  width:220px;height:220px;border-radius:50%;
  background:var(--orange);opacity:.06;
}
.temp-display{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:7rem;line-height:1;color:var(--orange);
  margin:var(--sp3) 0 var(--sp2);
}
.temp-label{font-size:0.82rem;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.1em}
.temp-sub{font-size:0.9rem;color:rgba(255,255,255,.55);margin-bottom:var(--sp5);line-height:1.6}
.problem-checklist{display:flex;flex-direction:column;gap:var(--sp2);margin-top:var(--sp4)}
.check-item{
  display:flex;align-items:flex-start;gap:var(--sp2);
  font-size:0.95rem;font-weight:600;color:var(--text-mid);line-height:1.4;
}
.check-icon{
  width:22px;height:22px;border-radius:50%;
  background:var(--orange);color:#fff;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;
}

/* ─── HOW IT WORKS — horizontal steps ─── */
.how-section{background:var(--white);padding:var(--sp8) 0}
.steps-row{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:var(--sp4);margin-top:var(--sp6);position:relative;
}
.steps-row::before{
  content:'';position:absolute;
  top:28px;left:calc(25% / 2 + 28px);right:calc(25% / 2 + 28px);
  height:2px;background:var(--border);z-index:0;
}
.step-card{
  display:flex;flex-direction:column;gap:var(--sp2);
  position:relative;z-index:1;
}
.step-num{
  width:56px;height:56px;border-radius:50%;
  background:var(--orange-soft);border:2px solid rgba(249,115,22,.2);
  display:flex;align-items:center;justify-content:center;
  font-family:'Manrope',sans-serif;font-weight:800;font-size:1.1rem;
  color:var(--orange);flex-shrink:0;
  transition:background var(--tb),border-color var(--tb);
  margin-bottom:var(--sp2);
}
.step-card:hover .step-num{background:var(--orange);border-color:var(--orange);color:#fff}
.step-card h3{font-size:1rem;font-weight:700;color:var(--navy)}
.step-card p{font-size:0.88rem;color:var(--text-muted);line-height:1.7}

/* ─── WHY US — left image, right content ─── */
.why-section{background:var(--gray-50);padding:var(--sp8) 0}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp7);align-items:center}
.why-list{display:flex;flex-direction:column;gap:var(--sp4);margin-top:var(--sp5)}
.why-item{display:flex;gap:var(--sp3);align-items:flex-start}
.why-num{
  width:36px;height:36px;border-radius:var(--r);
  background:var(--orange-soft);border:1px solid rgba(249,115,22,.15);
  display:flex;align-items:center;justify-content:center;
  font-family:'Manrope',sans-serif;font-weight:800;font-size:0.82rem;
  color:var(--orange);flex-shrink:0;
}
.why-item-body strong{
  font-family:'Manrope',sans-serif;font-weight:700;font-size:1rem;
  color:var(--navy);display:block;margin-bottom:4px;
}
.why-item-body p{font-size:0.88rem;color:var(--text-muted);line-height:1.65}
.why-stat-cards{
  display:grid;grid-template-columns:1fr 1fr;gap:var(--sp3);
}
.why-stat{
  background:var(--white);border:1.5px solid var(--border);
  border-radius:var(--rl);padding:var(--sp4);
  text-align:center;
  transition:border-color var(--tb),box-shadow var(--tb);
}
.why-stat:hover{border-color:var(--orange);box-shadow:var(--sh-sm)}
.why-stat-num{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:2rem;color:var(--navy);line-height:1;margin-bottom:4px;
}
.why-stat-num span{color:var(--orange)}
.why-stat-label{font-size:0.8rem;color:var(--text-muted);line-height:1.4}
.why-photo-wrap{
  border-radius:var(--rxl);overflow:hidden;
  box-shadow:var(--sh-lg);position:relative;aspect-ratio:4/5;
}
.why-photo-wrap img{width:100%;height:100%;object-fit:cover}
.why-photo-badge{
  position:absolute;bottom:var(--sp4);left:var(--sp4);right:var(--sp4);
  background:rgba(11,31,59,.9);backdrop-filter:blur(8px);
  border-radius:var(--rl);padding:var(--sp3);
  display:flex;align-items:center;gap:var(--sp2);
}
.wpb-icon{
  width:40px;height:40px;border-radius:var(--r);
  background:var(--orange);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.wpb-text strong{font-family:'Manrope',sans-serif;font-weight:700;font-size:0.88rem;color:#fff;display:block}
.wpb-text span{font-size:0.78rem;color:rgba(255,255,255,.5)}

/* ─── HOME REVIEWS PREVIEW ─── */
.reviews-preview{background:var(--white);padding:var(--sp8) 0}
.reviews-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp4);margin-top:var(--sp5)}

/* ─── CONTACT — home page version ─── */
.contact-section{background:var(--gray-50);padding:var(--sp8) 0}
.contact-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:var(--sp5);
  align-items:flex-start;
}
@media(min-width:961px){
  .contact-grid{grid-template-columns:1fr 1fr;gap:var(--sp7)}
}
.contact-form-wrap{width:100%;min-width:0}
.contact-info{min-width:0}
.contact-info .subhead{margin-bottom:var(--sp4)}
.contact-methods{display:flex;flex-direction:column;gap:var(--sp3);margin-bottom:var(--sp5)}
.cm{
  display:flex;align-items:flex-start;gap:var(--sp3);
  padding:var(--sp3);
  background:var(--white);border:1.5px solid var(--border);
  border-radius:var(--rl);
  transition:border-color var(--tb),box-shadow var(--tb);
}
.cm:hover{border-color:var(--orange);box-shadow:var(--sh-sm)}
.cm-icon{
  width:44px;height:44px;border-radius:var(--rm);
  background:var(--orange-soft);color:var(--orange);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.cm-body{display:flex;flex-direction:column;gap:3px}
.cm-label{font-size:0.78rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}
.cm-value{font-family:'Manrope',sans-serif;font-weight:700;font-size:1rem;color:var(--navy)}
.cm-note{font-size:0.82rem;color:var(--text-muted)}

/* ─── FINAL CTA STRIP ─── */
.final-cta{
  background:var(--orange);padding:var(--sp6) 0;
  text-align:center;
}
.final-cta h2{color:#fff;font-size:clamp(1.8rem,3.5vw,2.8rem);margin-bottom:var(--sp2)}
.final-cta p{color:rgba(255,255,255,.8);margin-bottom:var(--sp4);font-size:1rem}

/* ─── RESPONSIVE ─── */
@media(max-width:960px){
  .hero::before{display:none}
  .hero-inner{grid-template-columns:1fr;gap:var(--sp5);padding-top:var(--sp3)}
  .hero-visual{display:none}
  .hero h1{font-size:2.8rem}
  .problem-grid{grid-template-columns:1fr}
  .problem-visual-block{order:-1}
  .how-section .steps-row{grid-template-columns:1fr 1fr;gap:var(--sp4)}
  .steps-row::before{display:none}
  .why-grid{grid-template-columns:1fr}
  .why-photo-wrap{display:none}
  .reviews-grid-3{grid-template-columns:1fr}
  /* Service area: collapse to single column, map placeholder becomes compact strip */
  .service-area-grid{grid-template-columns:1fr !important}
  .service-area-map-ph{
    aspect-ratio:unset !important;
    padding:var(--sp3) var(--sp4) !important;
    flex-direction:row !important;
    gap:var(--sp3) !important;
    justify-content:flex-start !important;
    border-radius:var(--rl) !important;
  }
  .service-area-map-ph svg{width:32px !important;height:32px !important;flex-shrink:0;opacity:.4}
  .service-area-map-ph p{text-align:left !important;margin:0}
}
@media(max-width:600px){
  .hero{padding:var(--sp6) 0}
  .hero h1{font-size:2.4rem}
  .hero-actions{flex-direction:column}
  .hero-actions .btn{width:100%;justify-content:center}
  .how-section .steps-row{grid-template-columns:1fr}
  .why-stat-cards{grid-template-columns:1fr}
  /* Service area location tags: 1 col */
  .sa-tags{grid-template-columns:1fr !important}
}