/* ==================================================================
   DALLAS COMMERCIAL HVAC — BESPOKE REDESIGN
   Aesthetic: Editorial Industrial — Magazine precision meets
   mechanical authority. Not a template. Not reusable.
   ================================================================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --ink:#0A1928;
  --ink-mid:#112A40;
  --ink-soft:#1C3A54;
  --mint:#34D399;
  --mint-dim:#2AB585;
  --mint-glow:rgba(52,211,153,0.12);
  --mint-glow2:rgba(52,211,153,0.05);
  --chalk:#FFFFFF;
  --bone:#F4F6F5;
  --stone:#E8EDEB;
  --fog:#6B8A80;
  --txt:#1A2E3F;
  --txt-mid:#4A6474;
  --txt-soft:#7A9494;
  --line:#D4DDD8;
  --line-dark:#1E3A4E;
  --r:6px;--r-lg:12px;
  --max:1200px;
  --ease:cubic-bezier(0.4,0,0.2,1);
  --head:'DM Serif Display',Georgia,serif;
  --body:'Manrope',sans-serif;
  --mono:'IBM Plex Mono',monospace;
}

html{scroll-behavior:smooth;scroll-padding-top:80px}
body{font-family:var(--body);color:var(--txt);line-height:1.65;background:var(--chalk);-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:var(--mint-dim);text-decoration:none;transition:color 0.2s var(--ease)}
a:hover{color:var(--mint)}
h1,h2,h3,h4{font-family:var(--head);font-weight:400;color:var(--ink);line-height:1.2;letter-spacing:-0.01em}
h2{font-size:clamp(2rem,4.5vw,3rem);margin-bottom:0.5em}
h3{font-size:clamp(1.15rem,2.2vw,1.5rem)}
p{margin-bottom:1em}
em{font-style:italic}

.hp-container{max-width:var(--max);margin:0 auto;padding:0 28px}

/* --- Atoms --- */
.hp-label{
  font-family:var(--mono);font-size:0.68rem;font-weight:500;
  text-transform:uppercase;letter-spacing:2.5px;
  color:var(--mint-dim);margin-bottom:16px;
}
.hp-eyebrow{
  font-family:var(--mono);font-size:0.72rem;font-weight:500;
  text-transform:uppercase;letter-spacing:2px;
  color:var(--mint);margin-bottom:20px;
  display:flex;align-items:center;gap:12px;
}
.hp-eyebrow::before{content:"";width:32px;height:1px;background:var(--mint)}
.hp-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:15px 30px;font-family:var(--body);font-size:0.88rem;font-weight:700;
  border-radius:var(--r);border:2px solid transparent;
  cursor:pointer;transition:all 0.25s var(--ease);text-decoration:none;white-space:nowrap;
}
.hp-btn-accent{background:var(--mint);color:var(--ink);border-color:var(--mint)}
.hp-btn-accent:hover{background:#4AE8B0;color:var(--ink);transform:translateY(-2px);box-shadow:0 8px 24px rgba(52,211,153,0.25)}
.hp-btn-ghost{background:transparent;color:var(--chalk);border-color:rgba(255,255,255,0.25)}
.hp-btn-ghost:hover{border-color:var(--mint);color:var(--mint)}
.hp-btn-dark{background:var(--ink);color:var(--chalk);border-color:var(--ink)}
.hp-btn-dark:hover{background:var(--ink-mid);transform:translateY(-2px)}
.hp-btn-sm{padding:11px 22px;font-size:0.82rem}

/* ═══════════════════════════════════════════════════════════════
   V2 HOMEPAGE — BESPOKE AGENCY DESIGN
   Conversion-first. Editorial typography. Layered depth.
   ═══════════════════════════════════════════════════════════════ */

.v2-container{max-width:var(--max);margin:0 auto;padding:0 28px}

/* --- V2 Atoms --- */
.v2-section-tag{
  font-family:var(--mono);font-size:0.65rem;font-weight:500;
  text-transform:uppercase;letter-spacing:3px;
  color:var(--mint-dim);margin-bottom:20px;
  display:inline-flex;align-items:center;gap:10px;
}
.v2-section-tag::before{content:"";width:24px;height:1.5px;background:var(--mint);display:inline-block}
.v2-section-tag-light{
  font-family:var(--mono);font-size:0.65rem;font-weight:500;
  text-transform:uppercase;letter-spacing:3px;
  color:var(--mint);margin-bottom:20px;
}

.v2-h2{font-family:var(--head);font-size:clamp(2rem,4.5vw,3.2rem);font-weight:400;color:var(--ink);line-height:1.12;letter-spacing:-0.02em;margin-bottom:0.6em}
.v2-h2 em{color:var(--mint-dim);font-style:italic}
.v2-h2-light{color:var(--chalk) !important}

.v2-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:16px 32px;font-family:var(--body);font-size:0.88rem;font-weight:700;
  border-radius:var(--r);border:2px solid transparent;
  cursor:pointer;transition:all 0.3s var(--ease);text-decoration:none;white-space:nowrap;
}
.v2-btn-lg{padding:18px 40px;font-size:0.95rem}
.v2-btn-primary{background:var(--mint);color:var(--ink);border-color:var(--mint)}
.v2-btn-primary:hover{background:#4AE8B0;color:var(--ink);transform:translateY(-2px);box-shadow:0 12px 32px rgba(52,211,153,0.3)}
.v2-btn-outline{background:transparent;color:var(--chalk);border-color:rgba(255,255,255,0.2)}
.v2-btn-outline:hover{border-color:var(--mint);color:var(--mint)}
.v2-btn-secondary{background:var(--ink);color:var(--chalk);border-color:var(--ink)}
.v2-btn-secondary:hover{background:var(--ink-mid);transform:translateY(-2px)}
.v2-btn-ghost-dark{background:transparent;color:rgba(255,255,255,0.85);border-color:rgba(255,255,255,0.15)}
.v2-btn-ghost-dark:hover{border-color:var(--mint);color:var(--mint)}

/* ═══════════════ HERO ═══════════════ */
.v2-hero{
  background:var(--ink) url('/images/hero-bg.avif') center/cover no-repeat;
  color:var(--chalk);
  padding:clamp(100px,12vw,160px) 0 clamp(80px,10vw,120px);
  position:relative;overflow:hidden;
}
.v2-hero::before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(135deg,rgba(10,25,40,0.96) 0%,rgba(10,25,40,0.88) 40%,rgba(10,25,40,0.82) 70%,rgba(10,25,40,0.92) 100%);
  z-index:0;
}
.v2-hero::after{
  content:"";position:absolute;bottom:-50%;right:-20%;width:800px;height:800px;
  background:radial-gradient(circle,rgba(52,211,153,0.06),transparent 70%);
  pointer-events:none;z-index:0;
}
.v2-hero-inner{
  max-width:var(--max);margin:0 auto;padding:0 28px;
  display:grid;grid-template-columns:1.3fr 0.7fr;gap:80px;align-items:center;
  position:relative;z-index:1;
}
.v2-hero-tag{
  font-family:var(--mono);font-size:0.7rem;font-weight:500;
  text-transform:uppercase;letter-spacing:2.5px;
  color:rgba(255,255,255,0.75);margin-bottom:28px;
  display:flex;align-items:center;gap:10px;
}
.v2-tag-dot{width:6px;height:6px;border-radius:50%;background:var(--mint);animation:v2-pulse 2s infinite}
@keyframes v2-pulse{0%,100%{opacity:1}50%{opacity:0.3}}

.v2-h1{
  font-family:var(--head);font-size:clamp(2.8rem,6vw,4.8rem);
  font-weight:400;line-height:1.06;color:var(--chalk);
  margin-bottom:28px;letter-spacing:-0.02em;
}
.v2-h1 em{color:var(--mint);font-style:italic}
.v2-h1 br{display:block}

.v2-hero-sub{
  font-size:1.08rem;line-height:1.75;color:rgba(255,255,255,0.85);
  max-width:540px;margin-bottom:40px;
}

.v2-hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:48px}

.v2-hero-proof{
  display:flex;align-items:center;gap:20px;flex-wrap:wrap;
  padding-top:28px;border-top:1px solid rgba(255,255,255,0.08);
}
.v2-hp-item{font-size:0.82rem;color:rgba(255,255,255,0.8)}
.v2-hp-item strong{color:var(--mint);font-family:var(--head);font-size:1.1rem;font-style:italic}
.v2-hp-sep{width:1px;height:20px;background:rgba(255,255,255,0.12)}

/* Hero visual cards */
.v2-hero-visual{display:flex;flex-direction:column;gap:16px}
.v2-hero-card{
  background:rgba(255,255,255,0.04);backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,0.08);border-radius:var(--r-lg);
  padding:28px 24px;
  transition:transform 0.3s var(--ease),border-color 0.3s;
}
.v2-hero-card:hover{transform:translateY(-4px);border-color:rgba(52,211,153,0.2)}
.v2-hero-card-main{text-align:center}
.v2-hc-label{font-family:var(--mono);font-size:0.6rem;text-transform:uppercase;letter-spacing:2px;color:rgba(255,255,255,0.88);margin-bottom:12px}
.v2-hc-stat{font-family:var(--head);font-size:3.4rem;color:var(--mint);font-style:italic;line-height:1;margin-bottom:8px}
.v2-hc-sub{font-size:0.78rem;color:rgba(255,255,255,0.75)}

.v2-hero-card-accent{display:flex;align-items:flex-start;gap:14px}
.v2-hc-icon{font-size:1.4rem;flex-shrink:0;margin-top:2px}
.v2-hc-text{font-size:0.82rem;color:rgba(255,255,255,0.8);line-height:1.5}
.v2-hc-text strong{color:var(--chalk)}

/* ═══════════════ ABOUT SNAPSHOT ═══════════════ */
.v2-about-snap{padding:96px 0;background:var(--ink);position:relative;z-index:2;}
.v2-about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.v2-about-text .v2-h2{font-family:'DM Serif Display',serif;font-size:clamp(1.8rem,3vw,2.6rem);color:#fff;margin-bottom:28px;line-height:1.2;}
.v2-about-text p{color:rgba(255,255,255,.78);font-size:1.05rem;line-height:1.75;margin-bottom:20px;}
.v2-about-text p:last-child{margin-bottom:0;}
.v2-about-img{border-radius:16px;overflow:hidden;aspect-ratio:4/3;}
.v2-about-img img{width:100%;height:100%;object-fit:cover;display:block;}
@media(max-width:768px){
  .v2-about-grid{grid-template-columns:1fr;gap:40px;}
  .v2-about-snap{padding:64px 0;}
}

/* ═══════════════ CREDIBILITY BAR ═══════════════ */
.v2-cred-bar{
  background:var(--mint);padding:16px 0;position:relative;z-index:2;
}
.v2-cred-items{
  display:flex;align-items:center;justify-content:center;gap:32px;flex-wrap:wrap;
}
.v2-cred{
  font-family:var(--body);font-size:0.8rem;font-weight:700;color:var(--ink);
  display:flex;align-items:center;gap:6px;
}
.v2-cred-check{font-weight:800;color:var(--ink-mid)}

/* ═══════════════ PROBLEM SECTION ═══════════════ */
.v2-problem{padding:clamp(80px,10vw,120px) 0;background:var(--chalk)}
.v2-problem-layout{
  display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:start;
}
.v2-problem-left .v2-h2{max-width:480px}
.v2-problem-right{display:grid;gap:16px}
.v2-pain-card{
  background:var(--bone);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:28px 32px;
  transition:transform 0.3s var(--ease),box-shadow 0.3s;
}
.v2-pain-card:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(10,25,40,0.06)}
.v2-pain-num{
  font-family:var(--head);font-size:2.2rem;color:var(--ink);font-style:italic;
  line-height:1;margin-bottom:8px;
}
.v2-pain-card p{color:var(--txt-mid);font-size:0.9rem;margin:0;line-height:1.6}
.v2-pain-highlight{
  background:var(--ink);border-color:var(--ink);
}
.v2-pain-highlight .v2-pain-num{color:var(--mint)}
.v2-pain-highlight p{color:rgba(255,255,255,0.85)}

/* ═══════════════ SERVICES MOSAIC ═══════════════ */
.v2-services{background:var(--ink);color:var(--chalk);padding:clamp(80px,10vw,120px) 0}
.v2-svc-header{margin-bottom:56px;max-width:620px}
.v2-svc-mosaic{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border:1px solid rgba(255,255,255,0.08);border-radius:var(--r-lg);overflow:hidden;
}
.v2-svc-card{
  padding:36px 32px;
  border-right:1px solid rgba(255,255,255,0.06);
  border-bottom:1px solid rgba(255,255,255,0.06);
  transition:all 0.35s var(--ease);text-decoration:none;color:inherit;
  display:flex;flex-direction:column;position:relative;
}
.v2-svc-card:nth-child(3n){border-right:none}
.v2-svc-card:nth-child(n+4){border-bottom:none}
.v2-svc-card:hover{background:rgba(52,211,153,0.04)}
.v2-svc-card h3{color:var(--chalk);font-family:var(--head);font-size:1.3rem;margin-bottom:12px;line-height:1.25}
.v2-svc-card p{color:rgba(255,255,255,0.75);font-size:0.85rem;margin-bottom:20px;line-height:1.65;flex:1}
.v2-svc-cta{font-family:var(--mono);font-size:0.72rem;font-weight:500;color:var(--mint);letter-spacing:0.3px;transition:gap 0.2s}
.v2-svc-card:hover .v2-svc-cta{color:#4AE8B0}
.v2-svc-lg{grid-column:1/-1;
  display:grid;grid-template-columns:1fr;grid-template-rows:auto;
  background:rgba(255,255,255,0.02);
  padding:48px 40px;
}
.v2-svc-lg h3{font-size:1.8rem;margin-bottom:16px}
.v2-svc-lg p{max-width:680px;font-size:0.95rem}
.v2-svc-top{margin-bottom:16px}
.v2-svc-badge{
  font-family:var(--mono);font-size:0.6rem;text-transform:uppercase;letter-spacing:2px;
  padding:5px 12px;border-radius:100px;border:1px solid var(--mint);color:var(--mint);
  background:rgba(52,211,153,0.08);
}
.v2-svc-more{text-align:center;margin-top:48px}

/* ═══════════════ TRUST SECTION ═══════════════ */
.v2-proof{padding:clamp(80px,10vw,120px) 0;background:var(--bone)}
.v2-trust-header{text-align:center;margin-bottom:56px}
.v2-trust-header .v2-h2{max-width:560px;margin:0 auto}
.v2-trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:56px}
.v2-trust-card{
  background:var(--chalk);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:36px 28px;text-align:center;
  transition:transform 0.3s var(--ease),box-shadow 0.3s;
}
.v2-trust-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(10,25,40,0.08)}
.v2-trust-icon{font-size:2rem;margin-bottom:16px}
.v2-trust-card h3{font-family:var(--head);font-size:1.1rem;color:var(--txt);margin:0 0 12px;font-style:italic}
.v2-trust-card p{font-size:0.85rem;color:var(--txt-soft);line-height:1.65;margin:0}
.v2-trust-stats{display:flex;justify-content:center;align-items:center;gap:0;background:var(--chalk);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.v2-ts-item{padding:24px 40px;text-align:center;flex:1}
.v2-ts-num{font-family:var(--head);font-size:2rem;color:var(--mint-dim);line-height:1;font-style:italic;margin-bottom:6px}
.v2-ts-label{font-family:var(--mono);font-size:0.7rem;color:var(--txt-soft);letter-spacing:0.3px}
.v2-ts-divider{width:1px;height:48px;background:var(--line)}

/* ═══════════════ INDUSTRIES ═══════════════ */
.v2-industries{background:var(--ink);padding:clamp(60px,8vw,100px) 0}
.v2-ind-header{text-align:center;margin-bottom:56px}
.v2-ind-grid{
  display:grid;grid-template-columns:repeat(6,1fr);gap:0;
  border:1px solid rgba(255,255,255,0.08);border-radius:var(--r-lg);overflow:hidden;
}
.v2-ind-item{
  padding:36px 16px;text-align:center;
  border-right:1px solid rgba(255,255,255,0.06);
  transition:background 0.3s var(--ease);
}
.v2-ind-item:last-child{border-right:none}
.v2-ind-item:hover{background:rgba(52,211,153,0.04)}
.v2-ind-icon{font-size:2rem;margin-bottom:14px;display:block}
.v2-ind-item h3{font-family:var(--body);font-size:0.85rem;font-weight:700;color:var(--chalk);margin-bottom:4px}
.v2-ind-item p{font-size:0.72rem;color:rgba(255,255,255,0.88);line-height:1.4;margin:0}

/* ═══════════════ FAQ ═══════════════ */
.v2-faq{padding:clamp(80px,10vw,120px) 0;background:var(--bone)}
.v2-faq-layout{display:grid;grid-template-columns:0.8fr 1.2fr;gap:80px;align-items:start}
.v2-faq-intro .v2-h2{max-width:400px;font-size:clamp(1.6rem,3vw,2.4rem)}
.v2-faq-intro p{color:var(--txt-mid);max-width:360px}

/* ═══════════════ AREAS ═══════════════ */
.v2-areas{padding:clamp(60px,8vw,100px) 0;background:var(--chalk)}
.v2-areas-header{text-align:center;margin-bottom:48px}

/* ═══════════════ FINAL CTA ═══════════════ */
.v2-final-cta{
  background:var(--ink);padding:clamp(80px,10vw,120px) 0;
  position:relative;overflow:hidden;
}
.v2-final-cta::before{
  content:"";position:absolute;top:-100px;right:-100px;width:500px;height:500px;
  background:radial-gradient(circle,rgba(52,211,153,0.07),transparent 70%);
  pointer-events:none;
}
.v2-fcta-inner{
  display:grid;grid-template-columns:1.2fr 0.8fr;gap:80px;align-items:center;
  position:relative;
}
.v2-fcta-content p{color:rgba(255,255,255,0.8);font-size:1rem;max-width:520px;line-height:1.7}
.v2-fcta-guarantees{display:flex;flex-direction:column;gap:10px;margin-top:28px}
.v2-fcta-g{
  font-size:0.85rem;color:rgba(255,255,255,0.85);
  display:flex;align-items:center;gap:10px;
}
.v2-fcta-g span{color:var(--mint);font-weight:700;font-size:0.9rem}
.v2-fcta-actions{display:flex;flex-direction:column;gap:14px;align-items:flex-start}
.v2-fcta-note{font-size:0.78rem;color:rgba(255,255,255,0.88);margin:8px 0 0;font-style:italic}

/* ═══════════════ V2 RESPONSIVE ═══════════════ */
@media(max-width:1024px){
  .v2-hero-inner{grid-template-columns:1fr;gap:48px}
  .v2-hero-visual{flex-direction:row;flex-wrap:wrap;gap:16px}
  .v2-hero-card{flex:1;min-width:200px}
  .v2-problem-layout{grid-template-columns:1fr;gap:48px}
  .v2-svc-mosaic{grid-template-columns:repeat(2,1fr)}
  .v2-svc-lg{grid-column:1/-1}
  .v2-svc-card:nth-child(2n){border-right:none}
  .v2-trust-grid{grid-template-columns:repeat(2,1fr)}
  .v2-ind-grid{grid-template-columns:repeat(3,1fr)}
  .v2-ind-item:nth-child(3){border-right:none}
  .v2-faq-layout{grid-template-columns:1fr;gap:40px}
  .v2-fcta-inner{grid-template-columns:1fr;gap:40px}
}
@media(max-width:768px){
  .v2-hero{padding:80px 0 60px}
  .v2-hero-visual{display:none}
  .v2-h1{font-size:clamp(2.2rem,8vw,3.2rem)}
  .v2-hero-ctas{flex-direction:column}
  .v2-hero-ctas .v2-btn{width:100%;justify-content:center}
  .v2-hero-proof{flex-direction:column;gap:12px}
  .v2-hp-sep{width:40px;height:1px}
  .v2-cred-items{gap:16px}
  .v2-cred{font-size:0.72rem}
  .v2-svc-mosaic{grid-template-columns:1fr}
  .v2-svc-card{border-right:none !important}
  .v2-svc-lg{padding:32px 24px}
  .v2-svc-lg h3{font-size:1.4rem}
  .v2-ind-grid{grid-template-columns:repeat(2,1fr)}
  .v2-ind-item{border-right:none !important;border-bottom:1px solid rgba(255,255,255,0.06)}
  .v2-trust-grid{grid-template-columns:1fr}
  .v2-trust-stats{flex-direction:column}
  .v2-ts-divider{width:48px;height:1px}
  .v2-ts-item{padding:20px}
  .v2-fcta-actions .v2-btn{width:100%;justify-content:center}
}
@media(max-width:480px){
  .v2-ind-grid{grid-template-columns:1fr}
  .v2-cred-items{flex-direction:column;gap:8px}
}

/* === LEGACY HP CLASSES (kept for any remaining references) === */
.hp-hero,.hp-about,.hp-trust,.hp-services,.hp-faq,.hp-areas,.hp-industries,.hp-proof-section{display:none}


/* --- Shared: FAQ, Form, etc from subpages --- */
.faq-list{max-width:780px}
.faq-item{border-bottom:1px solid var(--line)}
.faq-question{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 0;background:none;border:none;width:100%;
  font-family:var(--head);font-size:1rem;
  color:var(--ink);cursor:pointer;text-align:left;
}
.faq-question::after{content:"+";font-size:1.3rem;font-weight:300;color:var(--mint);flex-shrink:0;transition:transform 0.3s var(--ease)}
.faq-item.active .faq-question::after{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.3s ease}
.faq-answer-inner{padding:0 0 20px;font-size:0.9rem;color:var(--txt-mid);line-height:1.7}

.location-chips{display:flex;flex-wrap:wrap;gap:10px}
.location-chip{
  display:inline-flex;align-items:center;gap:4px;
  padding:8px 18px;background:var(--chalk);border:1px solid var(--line);
  border-radius:100px;font-size:0.82rem;font-weight:600;
  color:var(--txt);transition:all 0.2s var(--ease);text-decoration:none;
}
.location-chip:hover{border-color:var(--mint);color:var(--mint-dim)}
.location-chip::before{content:"\25CF";font-size:0.35rem;color:var(--mint)}

/* Lead Form */
.form-section{background:var(--ink);padding:100px 0;position:relative;overflow:hidden}
.form-section::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 50% 70% at 30% 50%,rgba(52,211,153,0.04),transparent 60%)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;position:relative}
.form-info{color:var(--chalk)}
.form-info h2{color:var(--chalk);font-family:var(--head);font-size:clamp(1.6rem,3vw,2.4rem)}
.form-info p{color:rgba(255,255,255,0.8)}
.form-info-items{margin-top:36px}
.form-info-item{display:flex;align-items:flex-start;gap:14px;margin-bottom:20px;color:rgba(255,255,255,0.85);font-size:0.88rem}
.form-info-icon{flex-shrink:0;width:36px;height:36px;background:var(--mint-glow);border:1px solid rgba(52,211,153,0.2);border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:0.9rem}
.lead-form{background:var(--chalk);border-radius:var(--r-lg);padding:36px}
.lead-form h3{font-family:var(--head);font-size:1.3rem;margin-bottom:20px}
.lead-form .hp-btn{width:100%;justify-content:center;padding:16px}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-family:var(--mono);font-size:0.68rem;font-weight:500;color:var(--txt-mid);margin-bottom:5px;text-transform:uppercase;letter-spacing:1px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:var(--r);font-family:var(--body);font-size:0.88rem;color:var(--txt);transition:border-color 0.2s;background:var(--chalk)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--mint);box-shadow:0 0 0 3px var(--mint-glow)}
.form-group textarea{resize:vertical;min-height:70px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* --- Subpage styles (carried over, adapted to new palette) --- */
.tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:0.68rem;font-weight:500;text-transform:uppercase;letter-spacing:2px;padding:6px 14px;border-radius:100px;border:1px solid var(--mint);color:var(--mint);background:var(--mint-glow2);width:fit-content}
.tag-light{border-color:var(--line);color:var(--txt-mid);background:var(--bone)}
.section{padding:80px 0}
.section-alt{background:var(--bone)}
.section-dark{background:var(--ink);color:var(--chalk)}
.section-dark h2,.section-dark h3{color:var(--chalk)}
.about-banner h2,.about-banner h3{color:var(--chalk) !important}
.cta-block h2{color:var(--chalk) !important}
.form-info h2{color:var(--chalk) !important}
.section-header{max-width:640px;margin-bottom:48px}
.section-header.centered{text-align:center;margin-left:auto;margin-right:auto}
.section-header p{color:var(--txt-mid);font-size:1rem}
.container{max-width:var(--max);margin:0 auto;padding:0 28px}

.cards-grid{display:grid;gap:20px}
.cards-grid-3{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.card{background:var(--chalk);border:1px solid var(--line);border-radius:var(--r-lg);padding:32px 28px;transition:all 0.25s var(--ease)}
.card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(10,25,40,0.08);border-color:var(--mint)}
.card-icon{width:48px;height:48px;background:var(--mint-glow);border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:16px}
.card h3{font-size:1.05rem;margin-bottom:8px}
.card p{font-size:0.88rem;color:var(--txt-mid);margin-bottom:16px}
.card-link{font-family:var(--mono);font-size:0.75rem;font-weight:500;color:var(--mint-dim);display:inline-flex;align-items:center;gap:4px}
.card-link::after{content:"\2192";transition:transform 0.2s}
.card:hover .card-link::after{transform:translateX(4px)}
a.card{text-decoration:none;color:inherit;display:block}
a.card:hover{color:inherit}
.svc-benefit{font-family:var(--mono);font-size:0.65rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--mint-dim);margin-bottom:10px}

.about-banner{background:var(--ink);border-radius:var(--r-lg);display:grid;grid-template-columns:1fr 380px;gap:0;overflow:hidden;position:relative}
.about-banner::before{content:"";position:absolute;bottom:-40px;right:-40px;width:250px;height:250px;border:1px solid rgba(52,211,153,0.08);border-radius:50%;pointer-events:none}
.about-banner-content{padding:56px;position:relative}
.about-banner-img{position:relative;min-height:100%}
.about-banner-placeholder{width:100%;height:100%;background:linear-gradient(135deg,rgba(52,211,153,0.05),rgba(10,25,40,0.3));display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.08);font-size:0.8rem;text-align:center;padding:20px}

.stats-row{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.stat-cell{padding:36px 24px;text-align:center;border-right:1px solid var(--line)}
.stat-cell:last-child{border-right:none}
.stat-num{font-family:var(--head);font-size:clamp(2rem,4vw,2.8rem);color:var(--mint-dim);line-height:1;font-style:italic}
.stat-label{font-size:0.78rem;color:var(--txt-soft);margin-top:8px}

.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.trust-item{padding:24px 16px}
.trust-icon{font-size:1.8rem;margin-bottom:12px}
.trust-item h3{font-size:0.95rem;margin-bottom:6px}
.trust-item p{font-size:0.82rem;color:var(--txt-mid)}

.page-hero{padding:56px 0 64px;background:var(--ink);color:var(--chalk);position:relative;overflow:hidden}
.page-hero-inner{position:relative;max-width:var(--max);margin:0 auto;padding:0 28px}
.page-hero h1{color:var(--chalk);font-family:var(--head);font-size:clamp(2.2rem,5vw,3.4rem);margin-bottom:16px;line-height:1.15;text-shadow:0 2px 12px rgba(0,0,0,0.5)}
.page-hero p{color:rgba(255,255,255,0.78);font-size:1rem;max-width:600px;text-shadow:0 1px 6px rgba(0,0,0,0.4)}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:0.78rem;margin-bottom:16px;color:rgba(255,255,255,0.8)}
.breadcrumb a{color:var(--mint)}
.breadcrumb a:hover{color:var(--mint)}
.breadcrumb span{color:rgba(255,255,255,0.88)}

.content-section{padding:64px 0}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.placeholder-img{border-radius:var(--r-lg);aspect-ratio:4/3;background:linear-gradient(135deg,var(--bone),var(--stone));display:flex;align-items:center;justify-content:center;color:var(--txt-soft);font-size:0.82rem;text-align:center;padding:20px}
.checklist{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:10px}
.checklist li{display:flex;align-items:flex-start;gap:10px;font-size:0.9rem;padding:12px 16px;background:var(--bone);border-radius:var(--r)}
.checklist li::before{content:"\2713";color:var(--mint-dim);font-weight:700;flex-shrink:0}
.related-services{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}

.cta-block{background:var(--ink);border-radius:var(--r-lg);padding:48px 56px;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;position:relative;overflow:hidden}
.cta-block::before{content:"";position:absolute;top:0;right:0;width:300px;height:300px;background:radial-gradient(circle,var(--mint-glow),transparent 70%)}
.cta-block h2{color:var(--chalk);margin:0;position:relative}
.cta-block p{color:rgba(255,255,255,0.8);margin:8px 0 0;position:relative;max-width:480px}
.cta-block .btn-group{display:flex;gap:12px;flex-wrap:wrap;position:relative}

.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px}
.contact-block{display:flex;align-items:flex-start;gap:14px;margin-bottom:16px;padding:16px;background:var(--bone);border-radius:var(--r)}
.contact-block-icon{flex-shrink:0;width:40px;height:40px;background:var(--mint);color:var(--ink);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.9rem}
.contact-block h4{font-family:var(--body);font-weight:700;font-size:0.88rem;margin-bottom:2px}
.contact-block p{font-size:0.82rem;color:var(--txt-mid);margin:0}
.contact-block a{color:var(--mint-dim)}
.map-placeholder{width:100%;height:280px;background:var(--bone);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;color:var(--txt-soft);font-size:0.85rem;margin-top:20px;border:1px solid var(--line)}

.blog-placeholder{text-align:center;padding:80px 20px;background:var(--bone);border-radius:var(--r-lg)}
.legal-content{max-width:780px;margin:0 auto}
.legal-content h2{font-size:1.2rem;margin-top:2em}
.legal-content p,.legal-content li{font-size:0.9rem;color:var(--txt-mid)}
.page-404{text-align:center;padding:120px 20px}
.page-404 h1{font-size:5rem;color:var(--mint);margin-bottom:8px}
.page-404 p{color:var(--txt-mid);margin-bottom:2em}

.industry-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border:1px solid var(--line-dark);border-radius:var(--r-lg);overflow:hidden}
.industry-item{padding:40px 20px;text-align:center;border-right:1px solid var(--line-dark);background:var(--ink);transition:background 0.3s}
.industry-item:last-child{border-right:none}
.industry-item:hover{background:var(--ink-mid)}
.industry-item .ind-icon{font-size:2rem;margin-bottom:12px;display:block}
.industry-item h3{font-family:var(--body);font-size:0.85rem;font-weight:700;color:var(--chalk);margin-bottom:4px}
.industry-item p{font-size:0.72rem;color:rgba(255,255,255,0.75);line-height:1.4}

/* --- Header --- */
.site-header{position:sticky;top:0;z-index:1000;background:rgba(10,25,40,0.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);height:64px;border-bottom:1px solid rgba(255,255,255,0.06)}
.header-inner{max-width:var(--max);margin:0 auto;padding:0 28px;display:flex;align-items:center;justify-content:space-between;height:100%}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-mark{width:36px;height:36px;border:1.5px solid var(--mint);border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:0.75rem;font-weight:500;color:var(--mint);transition:all 0.2s}
.logo:hover .logo-mark{background:var(--mint);color:var(--ink)}
.logo-text{font-family:var(--body);font-weight:700;font-size:0.9rem;color:var(--chalk);line-height:1.15}
.logo-text span{color:var(--mint)}
.main-nav{display:flex;align-items:center;gap:2px}
.main-nav>a,.nav-dropdown>a{padding:8px 12px;font-size:0.82rem;font-weight:600;color:rgba(255,255,255,0.85);border-radius:var(--r);transition:all 0.2s;text-decoration:none}
.main-nav>a:hover,.nav-dropdown>a:hover{color:var(--chalk);background:rgba(255,255,255,0.06)}
.nav-dropdown{position:relative}
.nav-dropdown>a::after{content:"";display:inline-block;width:0;height:0;border-left:3px solid transparent;border-right:3px solid transparent;border-top:3.5px solid currentColor;margin-left:4px;vertical-align:middle;opacity:0.4}
.dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;background:var(--ink);border:1px solid var(--line-dark);border-radius:var(--r-lg);min-width:260px;padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:all 0.2s;z-index:100;box-shadow:0 16px 48px rgba(0,0,0,0.4)}
.nav-dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-menu a{display:block;padding:10px 14px;font-size:0.8rem;color:rgba(255,255,255,0.8);border-radius:var(--r);text-decoration:none}
.dropdown-menu a:hover{color:var(--chalk);background:rgba(255,255,255,0.06)}
.dropdown-divider{border-top:1px solid var(--line-dark);margin:6px 0}
.header-cta{display:flex;align-items:center;gap:12px;flex-shrink:0}
.header-phone{font-family:var(--mono);font-weight:500;font-size:0.82rem;color:var(--chalk);letter-spacing:0.02em}
.mobile-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.mobile-toggle span{display:block;width:20px;height:2px;background:var(--chalk);border-radius:2px;transition:all 0.2s}

/* --- Footer --- */
.site-footer{background:var(--ink);color:rgba(255,255,255,0.88);padding-top:0}
.footer-accent{height:3px;background:var(--mint)}
.footer-top{max-width:var(--max);margin:0 auto;padding:48px 28px 36px;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:28px}
.footer-brand p{font-size:0.8rem;line-height:1.7;margin-bottom:16px}
.footer-brand .logo-text{color:var(--chalk);font-size:1.1rem;margin-bottom:12px}
.footer-brand .logo-text span{color:var(--mint)}
.footer-contact-item{display:flex;align-items:flex-start;gap:8px;font-size:0.78rem;margin-bottom:8px}
.footer-contact-item a{color:rgba(255,255,255,0.88)}
.footer-contact-item a:hover{color:var(--mint)}
.footer-col h4{font-family:var(--mono);font-size:0.65rem;font-weight:500;text-transform:uppercase;letter-spacing:2px;color:var(--mint);opacity:0.85;margin-bottom:14px}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:4px}
.footer-col a{font-size:0.75rem;color:rgba(255,255,255,0.85)}
.footer-col a:hover{color:var(--mint)}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.06);padding:18px 28px;max-width:var(--max);margin:0 auto;display:flex;justify-content:space-between;align-items:center;font-size:0.72rem;flex-wrap:wrap;gap:12px}
.footer-legal-links{display:flex;gap:24px}
.footer-legal-links a{color:rgba(255,255,255,0.8)}
.footer-legal-links a:hover{color:var(--mint)}

/* --- Responsive --- */
@media(max-width:1024px){
  .hp-hero-inner{grid-template-columns:1fr;gap:40px}
  .hp-hero-proof{border-left:none;border-top:1px solid rgba(255,255,255,0.06);flex-direction:row;padding-bottom:40px}
  .hp-proof-card{border-bottom:none;border-right:1px solid rgba(255,255,255,0.06)}
  .hp-proof-card:last-child{border-right:none}
  .hp-testimonials{grid-template-columns:1fr}
  .hp-test-featured{transform:none}
  .hp-value-grid{grid-template-columns:1fr}
  .hp-value-float{position:static;margin-top:20px;display:inline-block}
  .hp-svc-grid{grid-template-columns:repeat(2,1fr)}
  .hp-svc:nth-child(2n){border-right:none}
  .hp-faq-grid{grid-template-columns:1fr}
  .about-banner{grid-template-columns:1fr}
  .about-banner-img{min-height:280px}
  .footer-top{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .stat-cell:nth-child(2){border-right:none}
  .stat-cell:nth-child(1),.stat-cell:nth-child(2){border-bottom:1px solid var(--line)}
  .trust-grid{grid-template-columns:repeat(2,1fr)}
  .industry-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:768px){
  .main-nav,.header-cta .header-phone{display:none}
  .mobile-toggle{display:flex}
  .header-cta .btn{padding:8px 14px;font-size:0.78rem}
  .logo-text{font-size:0.8rem}
  .header-cta{gap:8px}
  .main-nav.open{display:flex;flex-direction:column;position:fixed;top:64px;left:0;right:0;height:calc(100vh - 64px);background:var(--ink);padding:20px 28px;gap:2px;overflow-y:auto;z-index:9999}
  .main-nav.open a{padding:14px 16px;font-size:0.95rem}
  .main-nav.open .dropdown-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;padding-left:16px;min-width:auto;display:none}
  .main-nav.open .nav-dropdown.open .dropdown-menu{display:block}
  .hp-hero{padding:60px 0 0}
  .hp-hero-text{padding-bottom:40px}
  .hp-hero-proof{flex-direction:column}
  .hp-proof-card{border-right:none;border-bottom:1px solid rgba(255,255,255,0.06)}
  .hp-hero-badges{gap:12px}
  .hp-svc-grid{grid-template-columns:1fr}
  .hp-svc{border-right:none !important}
  .hp-industries{gap:12px;padding:16px 20px}
  .section{padding:56px 0}
  .about-grid,.form-grid,.contact-grid{grid-template-columns:1fr;gap:32px}
  .form-row{grid-template-columns:1fr}
  .stats-row{grid-template-columns:1fr}
  .stat-cell{border-right:none !important;border-bottom:1px solid var(--line)}
  .stat-cell:last-child{border-bottom:none}
  .footer-top{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .cta-block{flex-direction:column;text-align:center;padding:36px 24px}
  .trust-grid{grid-template-columns:1fr}
  .about-banner-content{padding:36px 24px}
  .industry-grid{grid-template-columns:1fr 1fr}
  .industry-item{border-right:none !important;border-bottom:1px solid var(--line-dark)}
}
@media(max-width:480px){
  .hp-hero-actions{flex-direction:column}
  .hp-hero-actions .hp-btn{width:100%;justify-content:center}
  .hp-hero-badges{flex-direction:column;align-items:center;gap:8px}
  .hp-badge-sep{display:none}
  .industry-grid{grid-template-columns:1fr}
}
/* === IMAGE OVERRIDES === */
.about-banner-placeholder{
  background:url('/images/technician-service.avif') center/cover no-repeat !important;
  color:transparent !important;
}
.page-hero{
  background:var(--ink) url('/images/dallas-skyline.avif') center/cover no-repeat;
}
.page-hero::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(to right,rgba(10,25,40,0.95),rgba(10,25,40,0.88));
  pointer-events:none;
}
.page-hero-inner{z-index:1}
