/*
Theme Name:  Cooksville Lumber
Theme URI:   https://cooksvillelumber.com/
Author:      Cooksville Lumber Ltd.
Author URI:  https://cooksvillelumber.com/
Description: Official WordPress theme for Cooksville Lumber Ltd. — family-owned lumber yard in Mississauga, Ontario since 1965. Converted from static site, design and CSS preserved exactly as-is.
Version:     1.0.0
Requires at least: 5.8
Tested up to: 6.5
Requires PHP: 7.4
License:     GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: cooksville-lumber
Tags:        custom-logo, custom-menu, featured-images, threaded-comments
*/

/* ── Reset & Base ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f8f6f2;--fg:#1a2e1a;
  --card:#fff;--card-fg:#1a2e1a;
  --primary:hsl(150,35%,25%);--primary-fg:#f8f6f2;
  --secondary:hsl(25,40%,35%);--secondary-fg:#f8f6f2;
  --muted:#ebe8e2;--muted-fg:hsl(150,10%,40%);
  --accent:hsl(35,55%,50%);--accent-fg:hsl(150,25%,10%);
  --border:#dbd7cf;--input:#dbd7cf;--ring:hsl(150,35%,25%);
  --bark:hsl(20,30%,20%);
  --gradient-hero:linear-gradient(135deg,hsla(150,35%,20%,.92),hsla(25,40%,30%,.85));
  --gradient-cta:linear-gradient(135deg,hsl(150,35%,25%),hsl(150,25%,35%));
  --gradient-warm:linear-gradient(135deg,hsl(25,40%,35%),hsl(35,55%,50%));
  --shadow-card:0 4px 20px -4px hsla(150,35%,25%,.1);
  --shadow-elevated:0 10px 40px -10px hsla(150,35%,25%,.15);
  --radius:.5rem;
  --font-heading:'Merriweather',Georgia,serif;
  --font-body:'Source Sans 3',system-ui,sans-serif;
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--fg);font-family:var(--font-body);-webkit-font-smoothing:antialiased;line-height:1.6}
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);line-height:1.25}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
ul{list-style:none}
.container{    padding-left: 1rem;
    padding-right: 1rem;}


.logo-text {
    display: flex;
    flex-direction: column;
}

.legal-box {
    border-radius: .5rem;
        font-size: 1rem;
    line-height: 1.25rem;
        padding: 1.25rem;
}
.legal-box p{
        margin-bottom: 3px !important;
}

.custom-logo-link img{
    max-width: 200px;
}

@media(min-width:1440px){
.container{max-width:1400px;margin:0 auto;padding:0 1rem}
}

/* @media(min-width:640px){.container{padding:0 2rem}} */

/* ── Icons ── */
.icon{display:inline-block;vertical-align:middle;width:1em;height:1em;flex-shrink:0}
.icon-xs{width:.875rem;height:.875rem}
.icon-sm{width:1rem;height:1rem}
.icon-md{width:1.5rem;height:1.5rem}
.icon-lg{width:2rem;height:2rem}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.5rem;border-radius:var(--radius);font-family:var(--font-body);font-weight:600;font-size: 1rem;cursor:pointer;border:none;transition:all .2s}
.btn-hero{background:var(--gradient-cta);color:var(--primary-fg);padding:.75rem 2rem;font-size:1rem}
.btn-hero:hover{opacity:.9;transform:translateY(-1px)}
.btn-outline{border:1px solid var(--border);background:transparent;color:var(--fg)}
.btn-outline:hover{background:var(--muted)}
.btn-outline-light{border:1px solid rgba(255,255,255,.3);background:transparent;color:var(--primary-fg)}
.btn-outline-light:hover{background:rgba(255,255,255,.1)}
.btn-default{background:var(--primary);color:var(--primary-fg)}
.btn-default:hover{opacity:.9}
.btn-sm{padding:.375rem 1rem;font-size: .900rem}
.btn-lg{padding:.75rem 2rem;font-size:1rem}

/* ── Top Bar ── */
.top-bar{background:var(--primary);color:var(--primary-fg)}
.top-bar-inner{display:flex;align-items:center;justify-content:space-between;padding-top:.5rem; padding-bottom:.5rem;font-size: 1rem;flex-wrap:wrap}
.top-bar-left,.top-bar-right{display:flex;align-items:center;gap:1rem}
.top-bar-link{display:flex;align-items:center;gap:.375rem;transition:color .2s}
.top-bar-link:hover{color:var(--accent)}
.top-bar-hours{display:flex;align-items:center;gap:.375rem}
.top-bar-social{display:flex;align-items:center;gap:.5rem}
.top-bar-social a{transition:color .2s}
.top-bar-social a:hover{color:var(--accent)}

/* ── Main Nav ── */
.site-header{position:sticky;top:0;z-index:50}
.main-nav{background:var(--card);box-shadow:var(--shadow-card)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding-top:.75rem; padding-bottom:.75rem}
.logo-link{display:flex;align-items:center;gap:.75rem}
.logo-name{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--primary);line-height:1.2;     margin-bottom: 5px;}
.logo-sub{font-size:.800rem;color:var(--muted-fg);letter-spacing:.35em;text-transform:uppercase;line-height:1}
.nav-desktop{display:none}
@media(min-width:1024px){.nav-desktop{display:flex;align-items:center}}
.nav-menu{display:flex;align-items:center;gap:.25rem}
.nav-menu > li{position:relative}
.nav-link{text-transform: uppercase;display:flex;align-items:center;gap:.25rem;padding:.5rem 1rem;font-size:1rem;font-weight:500;color:var(--fg);border-radius:var(--radius);transition:all .2s;background:none;border:none;cursor:pointer;font-family:var(--font-body)}
.nav-link:hover{color:var(--primary);background:var(--muted)}
.nav-contractor{color:var(--secondary);font-weight:600}
.nav-actions{display:none;align-items:center;gap:.75rem}
@media(min-width:1024px){.nav-actions{display:flex}}
.nav-location{display:flex;align-items:center;gap:.375rem;font-size: 1rem;color:var(--muted-fg);transition:color .2s}
.nav-location:hover{color:var(--primary)}
/* Dropdown */
.has-dropdown{position:relative}
.sub-menu{display:none;position:absolute;top:100%;left:0;margin-top:.25rem;width:15rem;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-elevated);padding:.5rem 0;z-index:50}
.has-dropdown.open .sub-menu{display:block}
.has-dropdown.open .dropdown-toggle .icon{transform:rotate(180deg)}
.sub-menu li{display:block}
.sub-menu li a{display:block;padding:.625rem 1rem;font-size: 1rem;color:var(--fg);transition:all .2s; text-transform: uppercase;}
.sub-menu li a:hover{color:var(--primary);background:var(--muted)}
/* Mobile */
.mobile-toggle{display:flex;align-items:center;justify-content:center;padding:.5rem;background:none;border:none;color:var(--fg);cursor:pointer}
@media(min-width:1024px){.mobile-toggle{display:none}}
.mobile-menu{border-top:1px solid var(--border);background:var(--card);padding:1rem}
.mobile-menu[hidden]{display:none}
.mobile-nav-list > li > a,.mobile-nav-list > li > button{display:flex;width:100%;align-items:center;justify-content:space-between;padding:.75rem 0;font-weight:500;color:var(--fg);border-bottom:1px solid rgba(0,0,0,.05);background:none;border-left:none;border-right:none;border-top:none;cursor:pointer;font-family:var(--font-body);font-size:1rem;text-align:left}
.mobile-nav-list > li > a:hover,.mobile-nav-list > li > button:hover{color:var(--primary)}
.mobile-sub-menu{padding-left:1rem}
.mobile-sub-menu[hidden]{display:none}
.mobile-sub-menu li{display:block}
.mobile-sub-menu li a{display:block;padding:.5rem 0;font-size: 1rem;color:var(--muted-fg);transition:color .2s}
.mobile-sub-menu li a:hover{color:var(--primary)}
.mobile-cta{width:100%;margin-top:1rem}
.mobile-has-dropdown.open .mobile-dropdown-toggle .icon{transform:rotate(180deg)}

/* ── Hero ── */
.hero{
    position:relative;
    /*min-height:85vh;*/
    display:flex;
    align-items:center;
    overflow:hidden;
    padding: 25px 0px;
    
}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:var(--gradient-hero)}
.hero-content{position:relative;z-index:10;max-width:48rem}
.hero-badge{display:inline-block;padding:.375rem 1rem;border-radius:9999px;background:hsla(35,55%,50%,.2);color:var(--accent);font-size: 1rem;font-weight:600;margin-bottom:1.5rem;backdrop-filter:blur(4px);border:1px solid hsla(35,55%,50%,.3)}
.hero h1{font-size:2.25rem;font-weight:700;color:var(--primary-fg);line-height:1.15;margin-bottom:1.5rem}
.hero h1 .accent{color:var(--accent)}
@media(min-width:768px){.hero h1{font-size:3rem}}
@media(min-width:1024px){.hero h1{font-size:3.75rem}}
.hero-desc{font-size:1.125rem;color:rgba(248,246,242,.85);margin-bottom:2rem;max-width:42rem;line-height:1.7}
@media(min-width:768px){.hero-desc{font-size:1.25rem}}
.hero-buttons{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}
.hero-buttons .btn{padding:.75rem 2rem;font-size:1rem}
.hero-highlights{display:flex;flex-wrap:wrap;gap:1.5rem}
@media(min-width:768px){.hero-highlights{gap:2.5rem}}
.hero-highlight{display:flex;align-items:center;gap:.5rem;color:rgba(248,246,242,.8);font-size: 1rem;font-weight:500}
.hero-highlight .icon{color:var(--accent)}
.hero-fade{position:absolute;bottom:0;left:0;right:0;height:6rem;background:linear-gradient(to top, #00000029, transparent)}

/* ── Sections ── */
.section{padding:5rem 0}
.section-head{text-align:center;margin-bottom:3.5rem}
.section-badge{display:inline-block;font-size: 1rem;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.75rem}
.section-head h2{font-size:1.875rem;font-weight:700;color:var(--fg);margin-bottom:1rem}
@media(min-width:768px){.section-head h2{font-size:2.25rem}}
.section-head p{font-size:1.125rem;color:var(--muted-fg);max-width:42rem;margin:0 auto}
.bg-muted{background:var(--muted)}
.bg-primary{background:var(--primary);color:var(--primary-fg)}
.bg-secondary{background:var(--secondary);color:var(--secondary-fg)}
.text-center{text-align:center}

/* ── Promos ── */
.promos{padding:5rem 0;background:hsla(25,40%,35%,.05);overflow:hidden}
.promo-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:2.5rem}
@media(min-width:640px){.promo-header{flex-direction:row;align-items:center;justify-content:space-between}}
.promo-header-left .badge-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}
.promo-header-left .badge-row .icon{color:var(--accent)}
.promo-header-left .badge-text{font-size: 1rem;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.1em}
.promo-nav{display:flex;align-items:center;gap:.5rem}
.promo-nav button{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:9999px;border:1px solid var(--border);background:transparent;cursor:pointer;color:var(--fg);transition:background .2s}
.promo-nav button:hover{background:var(--muted)}
.promo-counter{font-size: 1rem;color:var(--muted-fg);font-weight:500;padding:0 .5rem}
.promo-card{background:var(--card);border-radius:.75rem;overflow:hidden;box-shadow:var(--shadow-elevated)}
.promo-card-inner{display:grid;grid-template-columns:1fr}
@media(min-width:1024px){.promo-card-inner{grid-template-columns:1fr 1fr}}
.promo-image{position:relative;height:16rem;min-height:20rem}
@media(min-width:1024px){.promo-image{height:auto}}
.promo-image img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.promo-image .badge-abs{position:absolute;top:1rem;left:1rem}
.promo-image .badge-pill{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:9999px;background:var(--accent);color:var(--accent-fg);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.promo-image .highlight-abs{position:absolute;bottom:1rem;left:1rem}
.promo-image .highlight-pill{display:inline-block;padding:.5rem 1rem;border-radius:var(--radius);background:hsla(150,35%,25%,.9);color:var(--primary-fg);font-family:var(--font-heading);font-weight:700;font-size:1.125rem;backdrop-filter:blur(4px)}
.promo-body{padding:2rem}
@media(min-width:1024px){.promo-body{padding:2.5rem}}
.promo-body .promo-cat{font-size: 1rem;font-weight:600;color:var(--secondary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem}
.promo-body h3{font-size:1.5rem;font-weight:700;color:var(--fg);margin-bottom:.5rem}
@media(min-width:1024px){.promo-body h3{font-size:1.875rem}}
.promo-body .promo-subtitle{font-size:1.125rem;color:var(--muted-fg);font-weight:500;margin-bottom:1rem}
.promo-body .promo-desc{color:var(--muted-fg);line-height:1.7;margin-bottom:1.5rem}
.promo-body .promo-valid{display:flex;align-items:center;gap:.5rem;font-size: 1rem;color:var(--muted-fg);margin-bottom:1.5rem}
.promo-body .promo-actions{display:flex;flex-wrap:wrap;gap:.75rem}
.promo-thumbs{display:grid;grid-template-columns:1fr;gap:1rem;margin-top:1.5rem}
@media(min-width:768px){.promo-thumbs{grid-template-columns:repeat(3,1fr)}}
.promo-thumb{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--card);cursor:pointer;transition:all .2s;text-align:left}
.promo-thumb.active{background:hsla(150,35%,25%,.05);border-color:var(--primary);box-shadow:var(--shadow-card)}
.promo-thumb img{width:4rem;height:4rem;border-radius:.375rem;object-fit:cover;flex-shrink:0}
.promo-thumb .thumb-badge{font-size:.75rem;font-weight:600;color:var(--accent)}
.promo-thumb h4{font-size: 1rem;font-weight:700;color:var(--fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.promo-thumb .thumb-sub{font-size:.900rem;color:var(--muted-fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.promo-fb{margin-top:2rem;text-align:center}
.promo-fb p{font-size: 1rem;color:var(--muted-fg);margin-bottom:.75rem}

/* ── Categories Grid ── */
.categories-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:768px){.categories-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.categories-grid{grid-template-columns:repeat(3,1fr)}}
.cat-card{background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);transition:all .3s}
.cat-card:hover{box-shadow:var(--shadow-elevated);transform:translateY(-4px)}
.cat-card a{display:block}
.cat-card-img{position:relative;height:13rem;overflow:hidden}
.cat-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease-out}
.cat-card:hover .cat-card-img img{transform:scale(1.1)}
.cat-card-img .overlay{position:absolute;inset:0;background:linear-gradient(to top,hsla(20,30%,20%,.7),hsla(20,30%,20%,.2),transparent)}
.cat-card:hover .cat-card-img .overlay{background:linear-gradient(to top,hsla(20,30%,20%,.8),hsla(20,30%,20%,.2),transparent)}
.cat-card-img h3{position:absolute;bottom:1rem;left:1rem;font-size:1.25rem;font-weight:700;color:var(--primary-fg);text-shadow:0 2px 8px rgba(0,0,0,.3)}
.cat-card-body{padding:1.25rem}
.cat-card-body p{color:var(--muted-fg);font-size: 1rem;line-height:1.7;margin-bottom:1rem}
.cat-card-body .btn-row{display:flex;gap:.5rem}

/* ── Why Choose Us ── */
.features-grid-3{display:grid;grid-template-columns:1fr;gap:2rem}
@media(min-width:768px){.features-grid-3{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.features-grid-3{grid-template-columns:repeat(3,1fr)}}
.feature-box{background:var(--card);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow-card);transition:all .3s}
.feature-box:hover{box-shadow:var(--shadow-elevated);transform:translateY(-6px)}
.feature-box .icon-wrap{width:3rem;height:3rem;border-radius:var(--radius);background:var(--gradient-cta);display:flex;align-items:center;justify-content:center;margin-bottom:1rem;color:var(--primary-fg);transition:transform .3s}
.feature-box:hover .icon-wrap{transform:scale(1.1)}
.feature-box h3{font-size:1.125rem;font-weight:700;color:var(--fg);margin-bottom:.5rem}
.feature-box p{color:var(--muted-fg);font-size: 1rem;line-height:1.7}

/* ── Reviews ── */
.reviews-stars{display:flex;align-items:center;justify-content:center;gap:.25rem;margin-bottom:1rem}
.reviews-stars .icon{color:var(--accent)}
.review-cards{display:grid;grid-template-columns:1fr;gap:1.5rem;max-width:65rem;margin:0 auto 2.5rem}
@media(min-width:768px){.review-cards{grid-template-columns:repeat(3,1fr)}}
.review-card{background:var(--card);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow-card);position:relative;transition:all .3s}
.review-card:hover{box-shadow:var(--shadow-elevated);transform:translateY(-4px)}
.review-card .quote-mark{position:absolute;top:.75rem;right:1rem;font-size:3rem;font-family:var(--font-heading);color:hsla(150,35%,25%,.07);line-height:1;user-select:none}
.review-card .card-stars{display:flex;gap:.125rem;margin-bottom:.75rem}
.review-card .card-stars .icon{color:var(--accent);width:.875rem;height:.875rem}
.review-card .card-text{font-size: 1rem;color:var(--fg);line-height:1.7;margin-bottom:1rem;font-style:italic}
.review-card .card-author{display:flex;align-items:center;gap:.5rem}
.review-card .card-author .avatar{width:2rem;height:2rem;border-radius:9999px;background:var(--gradient-cta);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:var(--primary-fg)}
.review-card .card-author span{font-size: 1rem;font-weight:500}

/* ── Services Dark Section ── */
.services-section{background:var(--primary);color:var(--primary-fg);padding:5rem 0;position:relative;overflow:hidden}
.services-grid{display:grid;grid-template-columns:1fr;gap:1.25rem}
@media(min-width:768px){.services-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.services-grid{grid-template-columns:repeat(3,1fr)}}
.service-card{background:rgba(255,255,255,.1);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius);padding:1.25rem;transition:all .3s}
.service-card:hover{background:rgba(255,255,255,.15);transform:translateY(-4px)}
.service-card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:.75rem}
.service-card-icon{width:2.5rem;height:2.5rem;border-radius:var(--radius);background:hsla(35,55%,50%,.2);display:flex;align-items:center;justify-content:center;color:var(--accent);transition:background .3s}
.service-card:hover .service-card-icon{background:hsla(35,55%,50%,.3)}
.service-card-arrow{color:rgba(255,255,255,.3);transition:all .3s}
.service-card:hover .service-card-arrow{color:var(--accent);transform:translateX(4px)}
.service-card h3{font-size:1.125rem;font-weight:700;margin-bottom:.375rem}
.service-card p{color:rgba(248,246,242,.75);font-size: 1rem;line-height:1.7;margin-bottom:.75rem}

/* ── About ── */
.about-grid{display:grid;grid-template-columns:1fr;gap:3rem;align-items:center}
@media(min-width:1024px){.about-grid{grid-template-columns:1fr 1fr}}
.about-text .about-badge{font-size: 1rem;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.1em}
.about-text h2{font-size:1.875rem;font-weight:700;color:var(--fg);margin:.5rem 0 1.5rem}
@media(min-width:768px){.about-text h2{font-size:2.25rem}}
.about-text p{color:var(--muted-fg);line-height:1.7;margin-bottom:1rem}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.stat-box{background:var(--muted);border-radius:var(--radius);padding:1.5rem;text-align:center;cursor:default;transition:transform .2s}
.stat-box:hover{transform:scale(1.03)}
.stat-box .stat-num{font-size:1.875rem;font-family:var(--font-heading);font-weight:700;color:var(--primary);margin-bottom:.25rem;transition:color .3s}
.stat-box:hover .stat-num{color:var(--accent)}
.stat-box .stat-label{font-size: 1rem;color:var(--muted-fg)}
.hours-box{background:hsla(25,40%,35%,.1);border:1px solid hsla(25,40%,35%,.2);border-radius:var(--radius);padding:1.5rem;margin-top:1.5rem}
.hours-box h3{font-family:var(--font-heading);font-weight:700;color:var(--fg);margin-bottom:.75rem}
.hours-box .hours-row{display:flex;justify-content:space-between;font-size: 1rem;color:var(--muted-fg);padding:.25rem 0}
.hours-box .hours-row span:last-child{font-weight:600;color:var(--fg)}

/* ── Contact ── */
.contact-grid{display:grid;grid-template-columns:1fr;gap:2rem}
@media(min-width:1024px){.contact-grid{grid-template-columns:2fr 3fr}}
.contact-info-card{background:var(--card);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow-card)}
.contact-info-card h3{font-family:var(--font-heading);font-weight:700;font-size:1.125rem;margin-bottom:1rem}
.contact-info-card .info-item{display:flex;align-items:flex-start;gap:.75rem;color:var(--muted-fg);margin-bottom:1rem;transition:color .2s}
.contact-info-card .info-item:hover{color:var(--primary)}
.contact-info-card .info-item .icon{color:var(--primary);margin-top:.125rem}
.contact-info-card .info-item strong{color:var(--fg);display:block}
.map-embed{background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);margin-top:1.5rem}
.map-embed iframe{    width: 100%;
    height: 309px;
    border: 0;
    display: block}

/* ── Forms ── */
.contact-form,.sidebar-form form{display:flex;flex-direction:column;gap:1.25rem}
.sidebar-form{background:var(--card);border-radius:var(--radius);padding:1.5rem 2rem;box-shadow:var(--shadow-card);position:sticky;top:8rem}
.sidebar-form h3{font-family:var(--font-heading);font-weight:700;font-size:1.25rem;color:var(--fg)}
.form-sub{font-size: 1rem;color:var(--muted-fg)}
.form-row label{display:block;font-size: 1rem;font-weight:500;color:var(--fg);margin-bottom:.25rem}
.form-row input[type="text"],.form-row input[type="email"],.form-row input[type="tel"],.form-row textarea,.form-row select{width:100%;border:1px solid var(--input);border-radius:var(--radius);background:var(--bg);padding:.625rem .75rem;font-size: 1rem;color:var(--fg);font-family:var(--font-body);transition:box-shadow .2s}
.form-row input:focus,.form-row textarea:focus,.form-row select:focus{outline:none;box-shadow:0 0 0 2px var(--ring)}
.form-row textarea{resize:vertical}
.form-cols{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:768px){.form-cols{grid-template-columns:1fr 1fr}}
.radio-group{display:flex;gap:1rem}
.radio-group label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size: 1rem}
.consent{display:flex;align-items:flex-start;gap:.5rem}
.consent input{margin-top:.25rem;accent-color:var(--primary);width:1rem;height:1rem;flex-shrink:0}
.consent label{font-size:.900rem;color:var(--muted-fg);line-height:1.5}
.consent a{color:var(--primary);text-decoration:underline}

/* ── Service Inner Pages ── */
.service-hero{background:var(--primary);color:var(--primary-fg);padding:4rem 0 6rem}
@media(min-width:768px){.service-hero{padding:6rem 0 8rem}}
.service-hero-inner{max-width:48rem}
.service-badge{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}
.service-badge .icon{color:var(--accent)}
.service-badge span{color:var(--accent);font-weight:500;text-transform:uppercase;letter-spacing:.1em;font-size: 1rem}
.service-hero h1{font-size:1.875rem;font-weight:700;margin-bottom:1.5rem}
@media(min-width:768px){.service-hero h1{font-size:3rem}}
.service-hero p{font-size:1.125rem;color:rgba(248,246,242,.8)}
.service-content{padding:4rem 0 5rem}
@media(min-width:768px){.service-content{padding:5rem 0}}
.service-grid{display:grid;grid-template-columns:1fr;gap:3rem}
@media(min-width:1024px){.service-grid{grid-template-columns:3fr 2fr}}
.service-main .content-block{margin-bottom:3rem}
.content-block h2{font-size:1.5rem;font-weight:700;color:var(--fg);margin-bottom:1rem}
@media(min-width:768px){.content-block h2{font-size:1.875rem}}
.content-block p{color:var(--muted-fg);line-height:1.7}
.features-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-top:1.5rem}
@media(min-width:640px){.features-grid{grid-template-columns:1fr 1fr}}
.feature-card{display:flex;align-items:flex-start;gap:.75rem;background:var(--muted);border-radius:var(--radius);padding:1rem}
.feature-card .feature-icon{color:var(--primary);margin-top:.125rem;flex-shrink:0}
.feature-card span{font-size: 1rem;font-weight:500;color:var(--fg)}

/* ── Category Pages ── */
.category-hero{position:relative;height:45vh;min-height:300px;display:flex;align-items:flex-end;overflow:hidden;background-size:cover;background-position:center}
.category-hero-overlay{position:absolute;inset:0;background:var(--gradient-hero)}
.category-hero-content{position:relative;z-index:10;padding-bottom:2.5rem}
.back-link{display:inline-flex;align-items:center;gap:.25rem;font-size: 1rem;color:rgba(248,246,242,.7);margin-bottom:.75rem;transition:color .2s}
.back-link:hover{color:var(--accent)}
.category-hero h1{font-size:1.875rem;font-weight:700;color:var(--primary-fg)}
@media(min-width:768px){.category-hero h1{font-size:3rem}}
.category-location{color:rgba(248,246,242,.7);font-size: 1rem;display:flex;align-items:center;gap:.5rem;margin-top:.5rem}
.content-narrow{max-width:65rem;margin:0 auto}
.content-narrow h2{
 margin-bottom: 1.5rem;   
}
.intro-text{font-size:1.125rem;color:var(--muted-fg);line-height:1.7;margin-bottom:2.5rem}
.features-grid-2col{display:grid;grid-template-columns:1fr;gap:.75rem}
@media(min-width:640px){.features-grid-2col{grid-template-columns:1fr 1fr}}
.product-feature{display:flex;align-items:flex-start;gap:.75rem;background:var(--muted);border-radius:var(--radius);padding:.75rem 1rem}
.product-feature .icon{color:var(--primary);flex-shrink:0;margin-top:.125rem}
.product-feature span{font-size: 1rem;color:var(--fg)}
.mt-lg{margin-top:3rem}

/* ── CTA Banner ── */
.cta-banner{background:var(--primary);color:var(--primary-fg);padding:4rem 0}
.cta-banner h2{font-size:1.5rem;font-weight:700;margin-bottom:1rem}
@media(min-width:768px){.cta-banner h2{font-size:1.875rem}}
.cta-banner p{color:rgba(248,246,242,.8);margin-bottom:1.5rem;max-width:50rem;margin-left:auto;margin-right:auto}
.cta-buttons{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem}
.related-grid{display:grid;grid-template-columns:1fr;gap:1rem;max-width:48rem;margin:1.5rem auto 0}
@media(min-width:768px){.related-grid{grid-template-columns:repeat(3,1fr)}}
.related-card{background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);transition:all .3s}
.related-card:hover{box-shadow:var(--shadow-elevated)}
.related-card .related-img{height:8rem;overflow:hidden}
.related-card .related-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.related-card:hover .related-img img{transform:scale(1.05)}
.related-card .related-name{padding:1rem}
.related-card h3{font-size:1rem;font-weight:700;color:var(--fg);display:flex;align-items:center;gap:.25rem;transition:color .2s}
.related-card:hover h3{color:var(--primary)}

/* ── Legal Pages ── */
.legal-page{padding:4rem 0}
.legal-page .breadcrumb{font-size: 1rem;color:var(--muted-fg);margin-bottom:2rem;display:flex;align-items:center;gap:.5rem}
.legal-page .breadcrumb a{transition:color .2s}
.legal-page .breadcrumb a:hover{color:var(--primary)}
.legal-page h1{font-size:1.875rem;font-weight:700;color:var(--fg);margin-bottom:.5rem}
@media(min-width:768px){.legal-page h1{font-size:2.25rem}}
.legal-page .date{font-size: 1rem;color:var(--muted-fg);margin-bottom:2.5rem}
.legal-content section{margin-bottom:2rem}
.legal-content h2{font-size:1.25rem;font-weight:700;color:var(--fg);margin-bottom:.75rem}
.legal-content p{color:rgba(26,46,26,.9);line-height:1.7;margin-bottom:.75rem}
.legal-content ul{list-style:disc;padding-left:1.5rem;margin-bottom:.75rem}
.legal-content li{color:rgba(26,46,26,.9);line-height:1.7;margin-bottom:.375rem}
.legal-content li strong{color:var(--fg)}
.legal-content a{color:var(--primary);text-decoration:underline}
.legal-content a:hover{opacity:.8}
.legal-content .info-box{background:var(--muted);border-radius:var(--radius);padding:1.25rem;margin-top:.75rem;font-size: 1rem}
.legal-content .info-box p{margin-bottom:.25rem}
.legal-content .info-box .bold{font-weight:600;color:var(--fg)}

/* ── Contractor Page ── */
.contractor-hero{position:relative;min-height:60vh;display:flex;align-items:center;overflow:hidden;background-size:cover;background-position:center}
.contractor-hero-overlay{position:absolute;inset:0;background:var(--gradient-hero)}
.contractor-hero-content{position:relative;z-index:10;max-width:48rem;padding-top:5rem; padding-bottom:5rem;}
.contractor-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem 1rem;border-radius:9999px;background:hsla(35,55%,50%,.2);color:var(--accent);font-size: 1rem;font-weight:600;margin-bottom:1.5rem;backdrop-filter:blur(4px);border:1px solid hsla(35,55%,50%,.3)}
.contractor-hero h1{font-size:2.25rem;font-weight:700;color:var(--primary-fg);line-height:1.15;margin-bottom:1.5rem}
@media(min-width:768px){.contractor-hero h1{font-size:3rem}}
@media(min-width:1024px){.contractor-hero h1{font-size:3.75rem}}
.contractor-hero h1 .accent{color:var(--accent)}
.contractor-hero p{font-size:1.125rem;color:rgba(248,246,242,.85);margin-bottom:2rem;max-width:42rem;line-height:1.7}
.benefits-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:768px){.benefits-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.benefits-grid{grid-template-columns:repeat(3,1fr)}}
.benefit-card{background:var(--card);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow-card);transition:box-shadow .3s}
.benefit-card:hover{box-shadow:var(--shadow-elevated)}
.benefit-card .icon-wrap{width:3rem;height:3rem;border-radius:var(--radius);background:var(--gradient-cta);display:flex;align-items:center;justify-content:center;margin-bottom:1rem;color:var(--primary-fg)}
.benefit-card h3{font-size:1.125rem;font-weight:700;color:var(--fg);margin-bottom:.5rem}
.benefit-card p{color:var(--muted-fg);font-size: 1rem;line-height:1.7}
.trade-products-grid{display:grid;grid-template-columns:1fr;gap:.75rem}
@media(min-width:640px){.trade-products-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.trade-products-grid{grid-template-columns:repeat(3,1fr)}}
.trade-product{display:flex;align-items:center;gap:.75rem;background:rgba(255,255,255,.1);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:.75rem 1rem}
.trade-product .icon{color:var(--accent);flex-shrink:0}
.trade-product span{font-size: 1rem;font-weight:500}
.steps-grid{display:grid;grid-template-columns:1fr;gap:2rem;max-width:56rem;margin:0 auto}
@media(min-width:768px){.steps-grid{grid-template-columns:repeat(3,1fr)}}
.step-item{text-align:center}
.step-num{width:3.5rem;height:3.5rem;border-radius:9999px;background:var(--gradient-cta);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-size:1.25rem;font-family:var(--font-heading);font-weight:700;color:var(--primary-fg)}
.step-item h3{font-size:1.25rem;font-weight:700;color:var(--fg);margin-bottom:.5rem}
.step-item p{color:var(--muted-fg);font-size: 1rem;line-height:1.7}
.app-form{background:var(--card);border-radius:.75rem;padding:2rem 2.5rem;box-shadow:var(--shadow-elevated);max-width:48rem;margin:0 auto}
.app-form h3{font-family:var(--font-heading);font-weight:700;font-size:1.125rem;color:var(--fg);display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}
.app-form h3 .icon{color:var(--primary)}
.form-section{margin-bottom:2rem}

/* ── Footer ── */
.site-footer{background:var(--primary);color:var(--primary-fg);position:relative}
.back-to-top{position:absolute;top:-1.25rem;right:2rem;width:2.5rem;height:2.5rem;border-radius:9999px;background:var(--accent);color:var(--accent-fg);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-elevated);border:none;cursor:pointer;transition:transform .2s}
.back-to-top:hover{transform:scale(1.1)}
.footer-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;padding-top:4rem; padding-bottom:4rem;}
@media(min-width:768px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.footer-grid{grid-template-columns:1fr 1fr 1fr 1fr}}
.footer-logo{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;margin-bottom:.5rem;transition:color .2s}
.footer-logo:hover{color:var(--accent)}
.footer-est{font-size: 1rem;font-weight:500;color:var(--accent);margin-bottom:1rem}
.footer-desc{font-size: 1rem;color:rgba(248,246,242,.7);line-height:1.7}
.footer-social{display:flex;gap:.75rem;margin-top:1rem}
.footer-social a{width:2.25rem;height:2.25rem;border-radius:9999px;background:rgba(248,246,242,.1);display:flex;align-items:center;justify-content:center;transition:all .2s}
.footer-social a:hover{background:var(--accent);transform:scale(1.1)}
.footer-col h4{font-family:var(--font-heading);font-weight:700;font-size: 1rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem}
.footer-col ul{display:flex;flex-direction:column;gap:.5rem}
.footer-col li a{font-size: 1rem;color:rgba(248,246,242,.7);transition:all .2s;display:inline-block}
.footer-col li a:hover{color:var(--accent);transform:translateX(4px)}
.footer-contact li a{display:flex;align-items:flex-start;gap:.5rem}
.footer-hours{margin-top:1rem;font-size: 1rem;color:rgba(248,246,242,.7)}
.footer-hours .hours-title{font-weight:600;color:rgba(248,246,242,.9)}
.footer-bottom{border-top:1px solid rgba(248,246,242,.15);padding-top:2rem; padding-bottom:2rem;}
.footer-seo{font-size:.900rem;color:rgba(248,246,242,.5);line-height:1.7;margin-bottom:1rem}
.footer-legal{display:flex;flex-direction:column;gap:1rem;font-size:.900rem;color:rgba(248,246,242,.4)}
@media(min-width:768px){.footer-legal{flex-direction:row;justify-content:space-between;align-items:center}}
.footer-legal-links{display:flex;align-items:center;gap:1rem}
.footer-legal-links a{transition:color .2s}
.footer-legal-links a:hover{color:var(--accent)}
.footer-credit{text-align:center;margin-top:1.5rem;font-size:.900rem;color:rgba(248,246,242,.3)}
.footer-credit a{text-decoration:underline;transition:color .2s}
.footer-credit a:hover{color:var(--accent)}

/* ── WordPress Core ── */
.wp-caption{max-width:100%}
.wp-caption-text{font-size: 1rem;color:var(--muted-fg);text-align:center;margin-top:.5rem}
.alignleft{float:left;margin:0 1.5rem 1rem 0}
.alignright{float:right;margin:0 0 1rem 1.5rem}
.aligncenter{display:block;margin:1rem auto}
.screen-reader-text{clip:rect(1px,1px,1px,1px);height:1px;overflow:hidden;position:absolute;width:1px;word-wrap:normal}
.screen-reader-text:focus{background:var(--card);clip:auto;color:var(--fg);display:block;font-size: 1rem;font-weight:700;height:auto;left:5px;padding:1rem 1.5rem;position:fixed;text-decoration:none;top:5px;width:auto;z-index:9999}
.page-numbers,.nav-links{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:2.5rem 0;flex-wrap:wrap}
a.page-numbers,span.page-numbers,.nav-previous a,.nav-next a{display:inline-flex;align-items:center;justify-content:center;min-width:2.5rem;height:2.5rem;padding:0 .75rem;border-radius:var(--radius);font-size: 1rem;font-weight:500;color:var(--fg);background:var(--card);border:1px solid var(--border);transition:all .2s}
a.page-numbers:hover,.nav-previous a:hover,.nav-next a:hover{background:var(--primary);color:var(--primary-fg);border-color:var(--primary)}
.page-numbers.current{background:var(--primary);color:var(--primary-fg);border-color:var(--primary)}
.page-numbers.dots{border:none;background:transparent}

/* ── Blog / Archive ── */
.blog-grid{display:grid;grid-template-columns:1fr;gap:2rem}
@media(min-width:768px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.blog-grid{grid-template-columns:repeat(3,1fr)}}
.post-card{background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);transition:all .3s}
.post-card:hover{box-shadow:var(--shadow-elevated);transform:translateY(-4px)}
.post-card-img{height:12rem;overflow:hidden;background:var(--muted)}
.post-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.post-card:hover .post-card-img img{transform:scale(1.05)}
.post-card-body{padding:1.25rem}
.post-card-meta{display:flex;align-items:center;gap:.75rem;font-size:.75rem;color:var(--muted-fg);margin-bottom:.75rem}
.post-card-meta .cat-label{background:var(--gradient-cta);color:var(--primary-fg);padding:.125rem .5rem;border-radius:9999px;font-weight:600;font-size:.6875rem}
.post-card h2{font-size:1.125rem;font-weight:700;color:var(--fg);margin-bottom:.5rem;line-height:1.3}
.post-card h2 a{transition:color .2s}
.post-card h2 a:hover{color:var(--primary)}
.post-card p{color:var(--muted-fg);font-size: 1rem;line-height:1.7;margin-bottom:1rem}
.post-card .read-more{font-size: 1rem;font-weight:600;color:var(--primary);display:inline-flex;align-items:center;gap:.25rem;transition:gap .2s}
.post-card .read-more:hover{gap:.5rem}
.single-post-hero{background:var(--primary);color:var(--primary-fg);padding:4rem 0 3rem}
.single-post-meta{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;font-size: 1rem;color:rgba(248,246,242,.7);margin-bottom:1rem}
.single-post-meta .cat-label{background:var(--accent);color:var(--accent-fg);padding:.25rem .75rem;border-radius:9999px;font-weight:600;font-size:.75rem}
.single-post-content{max-width:48rem;margin:0 auto;padding:4rem 1rem}
.single-post-content h2,.single-post-content h3{font-family:var(--font-heading);color:var(--fg);margin:2rem 0 1rem}
.single-post-content p{color:var(--muted-fg);line-height:1.8;margin-bottom:1.25rem}
.single-post-content ul,.single-post-content ol{padding-left:1.5rem;margin-bottom:1.25rem;color:var(--muted-fg);line-height:1.8}
.single-post-content blockquote{border-left:4px solid var(--accent);padding:.75rem 1.25rem;margin:1.5rem 0;background:var(--muted);border-radius:0 var(--radius) var(--radius) 0}
.single-post-content img{border-radius:var(--radius);margin:1.5rem 0}
.post-nav{display:grid;grid-template-columns:1fr 1fr;gap:1rem;max-width:48rem;margin:3rem auto;padding:0 1rem}
.post-nav-item{background:var(--card);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow-card);transition:all .3s}
.post-nav-item:hover{box-shadow:var(--shadow-elevated)}
.post-nav-item span{display:block;font-size:.75rem;color:var(--muted-fg);margin-bottom:.25rem}
.post-nav-item a{font-weight:700;color:var(--fg);line-height:1.3;display:block;transition:color .2s}
.post-nav-item a:hover{color:var(--primary)}
.search-form{display:flex;gap:.5rem;max-width:32rem;margin:0 auto}
.search-form input{flex:1;padding:.625rem .75rem;border:1px solid var(--border);border-radius:var(--radius);font-size: 1rem;background:var(--bg);color:var(--fg)}
.search-form input:focus{outline:none;box-shadow:0 0 0 2px var(--ring)}
.search-form button{padding:.625rem 1.25rem;background:var(--primary);color:var(--primary-fg);border:none;border-radius:var(--radius);cursor:pointer;font-weight:600;transition:opacity .2s}
.search-form button:hover{opacity:.9}

/* ── Responsive helpers ── */
.hide-mobile{display:none}@media(min-width:640px){.hide-mobile{display:inline-flex}}
.hide-tablet{display:none}@media(min-width:768px){.hide-tablet{display:inline-flex}}
.hide-xl{display:none}@media(min-width:1280px){.hide-xl{display:inline}}
@media(min-width:1024px){.hide-desktop{display:none}}

/* ── Animations ── */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
