/*
Theme Name: Heating Cooling Pros Legacy
Theme URI: https://ohiolaw.org/
Author: ChatGPT
Author URI: https://openai.com/
Description: A modern HVAC WordPress theme for HeatingCoolingPros.com / Otto A. Trzos Co., Inc. featuring third-generation family business messaging, phone-first CTAs, quote capture, services, products, air quality, resources, careers and contact sections.
Version: 1.5.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GPLv2 or later
Text Domain: hcp-legacy
*/

:root{
  --hcp-blue:#1f5e5a;
  --hcp-blue-2:#2f6f6b;
  --hcp-sky:#efe6d6;
  --hcp-orange:#a55a2a;
  --hcp-gold:#c79a52;
  --hcp-ink:#2a2926;
  --hcp-muted:#6d6255;
  --hcp-light:#f7f1e7;
  --hcp-white:#fffdf8;
  --hcp-border:#ddd1bd;
  --hcp-shadow:0 18px 45px rgba(13,57,84,.14);
  --hcp-radius:24px;
  --hcp-radius-sm:14px;
  --hcp-max:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Georgia, "Times New Roman", serif;
  color:var(--hcp-ink);
  background:var(--hcp-light);
  line-height:1.6;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block;height:auto}
.hcp-image-stack img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:26px;box-shadow:var(--hcp-shadow)}
.hcp-card-media img,.hcp-product img{width:100%;height:100%;object-fit:cover}
.hcp-product img{aspect-ratio:4/3;border-bottom:1px solid var(--hcp-border)}

button,input,select,textarea{font:inherit}

.hcp-container{width:min(var(--hcp-max), calc(100% - 36px));margin:0 auto}
.hcp-eyebrow{letter-spacing:.12em;text-transform:uppercase;font-weight:800;color:var(--hcp-orange);font-size:.78rem;margin:0 0 10px}
.hcp-section{padding:84px 0}
.hcp-section--soft{background:linear-gradient(180deg,#fff 0%,var(--hcp-light) 100%)}
.hcp-section-title{font-size:clamp(2rem,4vw,3.4rem);line-height:1.05;margin:0 0 18px;color:var(--hcp-blue);letter-spacing:-.04em}
.hcp-section-lead{font-size:1.08rem;color:var(--hcp-muted);max-width:760px;margin:0 0 28px}
.hcp-btn-row{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.hcp-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border-radius:999px;padding:13px 22px;font-weight:800;transition:transform .2s ease, box-shadow .2s ease, background .2s ease;border:2px solid transparent;line-height:1.1;white-space:nowrap;cursor:pointer}
.hcp-btn:hover{transform:translateY(-2px)}
.hcp-btn--primary{background:var(--hcp-orange);color:#fff;box-shadow:0 12px 28px rgba(242,107,33,.28)}
.hcp-btn--primary:hover{background:#da5c18}
.hcp-btn--secondary{background:#fff;color:var(--hcp-blue);border-color:var(--hcp-border);box-shadow:0 10px 25px rgba(12,48,73,.08)}
.hcp-btn--dark{background:var(--hcp-blue);color:#fff}
.hcp-btn--ghost{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.36)}

.hcp-topbar{background:#2a2926;color:#f9f3e8;font-size:.95rem;border-bottom:1px solid rgba(255,255,255,.08)}
.hcp-topbar .hcp-container{display:flex;justify-content:space-between;gap:18px;align-items:center;padding:9px 0;flex-wrap:wrap}
.hcp-topbar strong{color:#fff}.hcp-topbar a{text-decoration:underline;text-underline-offset:3px}
.hcp-header{position:sticky;top:0;z-index:50;background:rgba(255,253,248,.96);backdrop-filter:saturate(180%) blur(18px);border-bottom:1px solid var(--hcp-border)}
.hcp-header-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:82px}
.hcp-logo{display:flex;align-items:center;min-width:180px}
.hcp-logo img{width:auto;height:78px;max-width:300px;flex:0 0 auto;object-fit:contain;background:transparent;mix-blend-mode:multiply}
.hcp-menu{display:flex;align-items:center;gap:22px;list-style:none;margin:0;padding:0;font-size:.96rem;font-weight:750;color:#233d4d}
.hcp-menu a:hover{color:var(--hcp-orange)}
.hcp-header-actions{display:flex;align-items:center;gap:12px}.hcp-phone-pill{display:inline-flex;align-items:center;gap:8px;background:var(--hcp-sky);color:var(--hcp-blue);font-weight:900;border-radius:999px;padding:10px 14px;border:1px solid #c7e4f2}
.hcp-mobile-toggle{display:none;border:0;background:var(--hcp-blue);color:#fff;border-radius:12px;padding:10px 13px;font-weight:800}

.hcp-hero{position:relative;overflow:hidden;background:radial-gradient(circle at 10% 20%,rgba(199,154,82,.14) 0%,transparent 36%),linear-gradient(135deg,#fbf6ed 0%,#f2eadc 48%,#fffaf2 100%)}
.hcp-hero:before{content:"";position:absolute;right:-160px;top:-220px;width:520px;height:520px;border-radius:50%;background:rgba(165,90,42,.10)}
.hcp-hero:after{content:"";position:absolute;left:-140px;bottom:-160px;width:380px;height:380px;border-radius:50%;background:rgba(31,94,90,.10)}
.hcp-hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1.02fr) minmax(360px,.98fr);align-items:center;gap:46px;padding:82px 0 66px}
.hcp-hero h1{font-size:clamp(2.65rem,6vw,5.55rem);line-height:.95;letter-spacing:-.07em;margin:0 0 20px;color:var(--hcp-blue)}
.hcp-hero p{font-size:1.17rem;color:#415869;max-width:650px;margin:0 0 28px}.hcp-hero strong{color:var(--hcp-blue)}
.hcp-hero-card{background:#fffdf8;border-radius:32px;box-shadow:var(--hcp-shadow);padding:16px;position:relative;transform:rotate(-1deg);border:1px solid rgba(42,41,38,.08)}
.hcp-hero-card img{border-radius:24px;aspect-ratio:4/3;object-fit:cover;object-position:center}.hcp-hero-card img[src*="hero-1940s-contractor"]{filter:grayscale(1)}
.hcp-hero-badge{position:absolute;left:-20px;bottom:28px;background:var(--hcp-blue);color:#fff;border-radius:20px;padding:18px 22px;box-shadow:0 18px 30px rgba(16,36,51,.23);min-width:260px;max-width:none}
.hcp-hero-badge span{display:block;font-size:.78rem;opacity:.82;text-transform:uppercase;letter-spacing:.1em;font-weight:800}.hcp-hero-badge strong{display:block;font-size:1.7rem;color:#fff;line-height:1.05;margin-top:4px;white-space:nowrap}
.hcp-trust-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:42px}.hcp-trust-card{background:#fff;border:1px solid var(--hcp-border);border-radius:18px;padding:16px;box-shadow:0 8px 22px rgba(18,61,90,.06)}.hcp-trust-card b{display:block;color:var(--hcp-blue);font-size:1.35rem;line-height:1}.hcp-trust-card span{display:block;color:var(--hcp-muted);font-size:.91rem;margin-top:6px}

.hcp-anchor-card{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:-34px;position:relative;z-index:4}.hcp-anchor-item{background:#fff;border-radius:20px;padding:24px;border:1px solid var(--hcp-border);box-shadow:var(--hcp-shadow)}.hcp-anchor-icon{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;background:var(--hcp-sky);font-size:1.5rem;margin-bottom:12px}.hcp-anchor-item h3{font-size:1.2rem;line-height:1.15;margin:0 0 8px;color:var(--hcp-blue)}.hcp-anchor-item p{margin:0;color:var(--hcp-muted);font-size:.98rem}

.hcp-split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}.hcp-image-stack{position:relative}.hcp-image-stack img{border-radius:var(--hcp-radius);box-shadow:var(--hcp-shadow);aspect-ratio:4/3;object-fit:cover}.hcp-floating-note{position:absolute;right:-18px;bottom:-26px;background:#fff;border-radius:20px;padding:22px;box-shadow:var(--hcp-shadow);border:1px solid var(--hcp-border);max-width:285px}.hcp-floating-note strong{display:block;color:var(--hcp-blue);font-size:1.3rem}.hcp-floating-note span{color:var(--hcp-muted);font-size:.94rem}
.hcp-feature-list{display:grid;gap:14px;margin-top:24px}.hcp-feature{display:flex;gap:12px;background:#fff;border:1px solid var(--hcp-border);padding:14px;border-radius:16px;box-shadow:0 6px 20px rgba(18,61,90,.06)}.hcp-feature-mark{width:28px;height:28px;background:var(--hcp-orange);color:#fff;border-radius:50%;display:grid;place-items:center;font-weight:900;flex:0 0 auto}.hcp-feature h4{margin:0;color:var(--hcp-blue);font-size:1.02rem}.hcp-feature p{margin:3px 0 0;color:var(--hcp-muted);font-size:.94rem}

.hcp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.hcp-card{background:#fff;border:1px solid var(--hcp-border);border-radius:var(--hcp-radius);overflow:hidden;box-shadow:0 10px 32px rgba(13,57,84,.08);display:flex;flex-direction:column}.hcp-card-media{height:190px;background:#f3f8fb;display:grid;place-items:center;overflow:hidden}.hcp-card-media img{height:100%;width:100%;object-fit:cover}.hcp-card-media--product img{object-fit:contain;padding:20px;background:#fff}.hcp-card-body{padding:24px;flex:1}.hcp-card h3{margin:0 0 9px;color:var(--hcp-blue);font-size:1.32rem;line-height:1.16}.hcp-card p{margin:0;color:var(--hcp-muted)}.hcp-card .hcp-card-link{margin-top:16px;color:var(--hcp-orange);font-weight:900;display:inline-flex;align-items:center;gap:6px}

.hcp-band{background:linear-gradient(135deg,var(--hcp-blue) 0%,#0f587f 100%);color:#fff;border-radius:32px;padding:44px;position:relative;overflow:hidden}.hcp-band:after{content:"";position:absolute;right:-80px;top:-100px;width:320px;height:320px;border:36px solid rgba(255,255,255,.08);border-radius:50%}.hcp-band-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:26px;align-items:center;position:relative;z-index:1}.hcp-band h2{font-size:clamp(2rem,4vw,3.4rem);line-height:1;margin:0 0 12px;letter-spacing:-.04em}.hcp-band p{font-size:1.08rem;margin:0;color:rgba(255,255,255,.82)}.hcp-band-actions{display:flex;gap:12px;justify-content:flex-end;flex-wrap:wrap}

.hcp-products{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.hcp-product{background:#fff;border-radius:20px;border:1px solid var(--hcp-border);padding:16px;text-align:center;box-shadow:0 8px 22px rgba(18,61,90,.05)}.hcp-product img{height:120px;width:100%;object-fit:contain;margin-bottom:12px}.hcp-product h3{font-size:1rem;margin:0 0 6px;color:var(--hcp-blue)}.hcp-product p{font-size:.9rem;color:var(--hcp-muted);margin:0}

.hcp-timeline{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.hcp-step{background:#fff;border:1px solid var(--hcp-border);border-radius:22px;padding:24px;position:relative}.hcp-step span{display:grid;place-items:center;width:40px;height:40px;border-radius:50%;background:var(--hcp-blue);color:#fff;font-weight:900;margin-bottom:14px}.hcp-step h3{margin:0 0 8px;color:var(--hcp-blue)}.hcp-step p{margin:0;color:var(--hcp-muted);font-size:.95rem}

.hcp-form-wrap{display:grid;grid-template-columns:.86fr 1.14fr;gap:34px;align-items:start}.hcp-contact-card{background:var(--hcp-blue);color:#fff;border-radius:30px;padding:34px;box-shadow:var(--hcp-shadow);position:sticky;top:105px}.hcp-contact-card h2{font-size:2.3rem;line-height:1;margin:0 0 14px}.hcp-contact-card p{color:rgba(255,255,255,.8);margin:0 0 22px}.hcp-contact-card a.hcp-big-phone{font-size:2rem;font-weight:950;letter-spacing:-.04em;display:block;margin-bottom:14px}.hcp-contact-card .small{font-size:.95rem;color:rgba(255,255,255,.75)}
.hcp-quote-form{background:#fff;border:1px solid var(--hcp-border);border-radius:30px;padding:30px;box-shadow:var(--hcp-shadow)}.hcp-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.hcp-field{display:flex;flex-direction:column;gap:7px}.hcp-field--full{grid-column:1/-1}.hcp-field label{font-weight:850;color:var(--hcp-blue);font-size:.92rem}.hcp-field input,.hcp-field select,.hcp-field textarea{border:1px solid #cfe0e8;border-radius:14px;padding:13px 14px;background:#fbfdfe;color:var(--hcp-ink);outline:none}.hcp-field input:focus,.hcp-field select:focus,.hcp-field textarea:focus{border-color:var(--hcp-orange);box-shadow:0 0 0 4px rgba(242,107,33,.13)}.hcp-field textarea{min-height:120px;resize:vertical}.hcp-form-note{font-size:.86rem;color:var(--hcp-muted);margin:14px 0 0}.hcp-alert{padding:14px 16px;border-radius:14px;margin-bottom:16px;font-weight:750}.hcp-alert--success{background:#eaf9f1;color:#116038;border:1px solid #bcebcf}.hcp-alert--error{background:#fff0ee;color:#9e2d1a;border:1px solid #ffd0c5}

.hcp-footer{background:#081f31;color:#fff;padding:54px 0 24px}.hcp-footer-grid{display:grid;grid-template-columns:1.2fr repeat(3,.7fr);gap:28px}.hcp-footer h3{margin:0 0 12px;color:#fff}.hcp-footer p,.hcp-footer li{color:rgba(255,255,255,.72);margin:0}.hcp-footer ul{list-style:none;padding:0;margin:0;display:grid;gap:7px}.hcp-footer a:hover{color:#fff;text-decoration:underline;text-underline-offset:3px}.hcp-footer-bottom{border-top:1px solid rgba(255,255,255,.14);margin-top:34px;padding-top:20px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;color:rgba(255,255,255,.64);font-size:.9rem}

.hcp-page{padding:70px 0}.hcp-page article{max-width:860px;margin:0 auto}.hcp-page h1{color:var(--hcp-blue);font-size:clamp(2.2rem,4vw,3.5rem);line-height:1.02;letter-spacing:-.04em}.hcp-page-content{font-size:1.08rem;color:#334b5b}.screen-reader-text{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

@media (max-width:980px){
  .hcp-menu{display:none;position:absolute;left:18px;right:18px;top:82px;background:#fff;box-shadow:var(--hcp-shadow);border:1px solid var(--hcp-border);border-radius:18px;padding:18px;flex-direction:column;align-items:flex-start;gap:13px}.hcp-menu.is-open{display:flex}.hcp-mobile-toggle{display:inline-flex}.hcp-header-actions .hcp-btn{display:none}.hcp-hero-grid,.hcp-split,.hcp-band-grid,.hcp-form-wrap,.hcp-footer-grid{grid-template-columns:1fr}.hcp-hero-grid{padding:54px 0}.hcp-trust-row,.hcp-anchor-card,.hcp-grid,.hcp-timeline{grid-template-columns:repeat(2,1fr)}.hcp-products{grid-template-columns:repeat(3,1fr)}.hcp-band-actions{justify-content:flex-start}.hcp-contact-card{position:relative;top:0}.hcp-hero-card{transform:none}.hcp-hero-badge{left:20px;bottom:20px}
}
@media (max-width:640px){
  .hcp-topbar .hcp-container{justify-content:center;text-align:center}.hcp-logo{min-width:0}.hcp-logo img{height:62px;max-width:220px}.hcp-phone-pill{font-size:.9rem}.hcp-hero h1{font-size:3rem}.hcp-trust-row,.hcp-anchor-card,.hcp-grid,.hcp-products,.hcp-timeline,.hcp-form-grid{grid-template-columns:1fr}.hcp-section{padding:58px 0}.hcp-band{padding:28px;border-radius:24px}.hcp-contact-card a.hcp-big-phone{font-size:1.6rem}.hcp-quote-form{padding:20px}.hcp-footer-bottom{display:block}.hcp-products{gap:12px}
}

/* Mobile header phone cleanup */
@media (max-width:640px){
  .hcp-topbar{font-size:.9rem}
  .hcp-topbar .hcp-container{display:block;padding:8px 0;text-align:center}
  .hcp-topbar .hcp-container > div:first-child{display:none}
  .hcp-topbar .hcp-container > div:last-child{font-size:0}
  .hcp-topbar .hcp-container > div:last-child a{font-size:1rem;font-weight:900;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;color:#fff;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);border-radius:999px;padding:7px 14px;white-space:nowrap}
  .hcp-topbar .hcp-container > div:last-child a:before{content:"Call "}

  .hcp-header-inner{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px 10px;min-height:auto;padding:10px 0;align-items:center}
  .hcp-logo{grid-column:1;min-width:0;max-width:100%}
  .hcp-logo img{height:56px;max-width:190px;width:auto;object-fit:contain}
  .hcp-nav{grid-column:1 / -1;grid-row:3}
  .hcp-header-actions{display:contents}
  .hcp-mobile-toggle{grid-column:2;grid-row:1;justify-self:end;padding:9px 12px;border-radius:10px}
  .hcp-phone-pill{grid-column:1 / -1;grid-row:2;justify-self:stretch;display:flex;align-items:center;justify-content:center;background:#2a2926;color:#fff;border-color:#2a2926;border-radius:14px;padding:11px 14px;font-size:1.05rem;font-weight:950;letter-spacing:.02em;line-height:1;white-space:nowrap;box-shadow:0 8px 18px rgba(42,41,38,.16)}
  .hcp-menu{top:132px;left:18px;right:18px;background:#fffdf8}
}
