/**
 * Theme Name:        Tangipahoa Sand & Gravel
 * Theme URI:         https://tangipahoasandandgravel.com
 * Author:            PME LLC
 * Author URI:        https://pme-llc.com
 * Description:       Custom theme for Tangipahoa Sand & Gravel. Ironclad Ironwood design system. 69 pages.
 * Version:           1.0.0
 * Requires at least: 6.0
 * Tested up to:      6.9
 * 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:       tangipahoa-theme
 */

/* WordPress normalization */
@media screen and (min-width:783px){body.admin-bar .nav{top:32px}}
@media screen and (max-width:782px){body.admin-bar .nav{top:46px}}
.wp-block-image,.wp-block-paragraph,.wp-block-heading,.wp-block-list,.wp-block-group{margin:0!important;padding:0!important}
.entry-content{padding:0!important;max-width:none!important}
.wp-img-auto-sizes-contain{contain-intrinsic-size:auto none!important}
html,body{font-size:16px}
input,select,textarea,button{font-family:inherit;font-size:inherit;box-sizing:border-box}
input[type="number"]{-moz-appearance:textfield}
input[type="number"]::-webkit-inner-spin-button,input[type="number"]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
input,select,textarea{font-size:max(16px,1rem)}

/* ============================================================
   TANGIPAHOA SAND & GRAVEL - SHARED STYLESHEET
   Ironclad Ironwood Design System
   All 70 pages link to this file. Zero embedded CSS.
   ============================================================ */

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--bg:#1a1f26;--accent:#5BAA3C;--accent-rgb:91,170,60;--blue:#1F4E8C;--blue-rgb:31,78,140;--cta-text:#fff;--card-bg:rgba(91,170,60,.06);--card-border:rgba(91,170,60,.14);--icon-bg:rgba(91,170,60,.14);--text-body:rgba(255,255,255,.72);--text-muted:rgba(255,255,255,.45)}
html{scroll-behavior:smooth;scroll-padding-top:110px}
body{font-family:'Source Sans 3',sans-serif;background:var(--bg);color:#fff;overflow-x:hidden}
.dot-grid{background-color:var(--bg)}

/* UTILITIES */
.ico{display:inline-flex;align-items:center;justify-content:center;color:var(--accent)}
.ico svg{stroke:currentColor;fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}
.ac{color:var(--accent)}
.si{max-width:1600px;margin:0 auto;padding:0 48px}
.eyebrow{font-size:17px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:20px;display:block}
.stag{font-size:16px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:10px;display:block}
.stit{font-family:'Oswald',sans-serif;font-size:clamp(32px,3.8vw,56px);font-weight:700;line-height:1;text-transform:uppercase;margin-bottom:18px;cursor:default;transition:color .22s,transform .22s,text-shadow .22s;display:block}
.stit:hover{color:var(--accent);transform:translateX(6px) scale(1.02);text-shadow:0 0 32px rgba(var(--accent-rgb),.35)}
.stit:hover .ac{color:#fff}
.ssub{font-size:21px;color:var(--text-body);line-height:1.45;max-width:700px;margin-bottom:40px;transition:color .28s,transform .28s;cursor:default}
.ssub:hover{color:#fff;transform:translateX(4px)}
.clip-bottom{clip-path:polygon(0 0,100% 0,100% calc(100% - 48px),0 100%);padding-bottom:96px!important}
.clip-top{clip-path:polygon(0 48px,100% 0,100% 100%,0 100%);padding-top:96px!important;margin-top:-48px}

/* REVEAL ANIMATIONS */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .55s ease,transform .55s ease;will-change:opacity,transform}
.reveal.visible{opacity:1;transform:none}
.stagger-1{transition-delay:.06s}
.stagger-2{transition-delay:.12s}
.stagger-3{transition-delay:.18s}
.stagger-4{transition-delay:.24s}
.stagger-5{transition-delay:.30s}
.stagger-6{transition-delay:.36s}

/* TICKER */
.ticker{background:#162038;border-bottom:1px solid rgba(var(--blue-rgb),.45);overflow:hidden;height:36px;display:flex;align-items:center;position:fixed;top:0;left:0;right:0;z-index:1001}
.ticker-track{display:flex;gap:48px;white-space:nowrap;justify-content:center;flex-wrap:nowrap;overflow:hidden}
@keyframes ticker-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.ticker-item{font-family:'Oswald',sans-serif;font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:8px;flex-shrink:0}
.ticker-item .tw{color:#fff}
.ticker-dot{width:5px;height:5px;border-radius:50%;background:#fff;opacity:.85}

/* NAV */
.nav{position:fixed;top:36px;left:0;right:0;z-index:1000;padding:0 120px;height:64px;display:flex;align-items:center;justify-content:space-between;background:transparent;box-shadow:none;transition:background .3s,box-shadow .3s}
.nav.scrolled{background:rgba(28,31,36,.92);box-shadow:0 1px 0 rgba(255,255,255,.08)}
.nav-logo{font-family:'Oswald',sans-serif;font-weight:700;font-size:22px;letter-spacing:.08em;text-transform:uppercase;color:#fff;text-decoration:none;line-height:1.1}
.nav-logo span{color:var(--accent);display:block;font-size:16px}
.nav-links{display:flex;align-items:center;gap:20px;list-style:none}
.nav-links a{font-size:14px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.6);text-decoration:none;transition:color .2s}
.nav-links a:hover{color:#fff}
.nav-links a.active{color:var(--accent)}
.nav-cta{background:var(--blue)!important;color:var(--cta-text)!important;padding:7px 16px;border-radius:5px;font-family:'Oswald',sans-serif!important;font-size:14px!important}
.nav-ph{font-family:'Oswald',sans-serif!important;font-size:16px!important;font-weight:700!important;color:#fff!important}
.nav-dd{position:relative}
.nav-dd .dd-menu{display:none;position:absolute;top:100%;left:-12px;background:rgba(20,20,20,.95);border:1px solid rgba(var(--accent-rgb),.2);border-radius:8px;padding:8px 0;min-width:200px;z-index:1100;box-shadow:0 16px 48px rgba(0,0,0,.5)}
.nav-dd:hover .dd-menu,.nav-dd:focus-within .dd-menu{display:block}
.dd-menu a{display:block;padding:7px 18px;font-size:14px;letter-spacing:.06em}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;z-index:1100}
.hamburger span{width:24px;height:2px;background:#fff;transition:transform .3s,opacity .3s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mobile-drawer{position:fixed;top:0;right:-320px;width:300px;height:100vh;background:rgba(20,20,20,.98);z-index:1050;transition:right .3s;padding:80px 24px 24px;overflow-y:auto;border-left:1px solid rgba(var(--blue-rgb),.2)}
.mobile-drawer.open{right:0}
.mobile-drawer a{display:block;padding:12px 0;font-family:'Oswald',sans-serif;font-size:16px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.7);text-decoration:none;border-bottom:1px solid rgba(255,255,255,.06);transition:color .2s,padding-left .2s}
.mobile-drawer a:hover{color:var(--accent);padding-left:8px}
.mobile-drawer .dd-label{font-size:10px;letter-spacing:.2em;color:var(--text-muted);margin-top:16px;margin-bottom:4px}
.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:1040;display:none}
.drawer-overlay.open{display:block}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--blue);color:var(--cta-text);font-family:'Oswald',sans-serif;font-size:15px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:14px 26px;border-radius:6px;border:none;cursor:pointer;text-decoration:none;transition:transform .18s,box-shadow .18s,filter .18s;position:relative;overflow:hidden}
.btn::after{content:'';position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.18) 50%,transparent 70%);transform:translateX(-100%);transition:transform .45s}
.btn:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(var(--blue-rgb),.55);filter:brightness(1.15)}
.btn:hover::after{transform:translateX(100%)}
.btn-o{display:inline-flex;align-items:center;gap:8px;background:transparent;color:#fff;font-family:'Oswald',sans-serif;font-size:15px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:13px 26px;border-radius:6px;border:1px solid rgba(255,255,255,.22);cursor:pointer;text-decoration:none;transition:border-color .25s,color .25s,box-shadow .25s,transform .18s}
.btn-o:hover{border-color:rgba(255,255,255,.5);color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.22)}
.btn-sm{font-size:14px;padding:10px 18px}

/* HERO */
.sa-hero{padding:174px 0 80px;position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:url('https://images.pexels.com/photos/13224687/pexels-photo-13224687.jpeg?w=1600') center 40%/cover fixed;opacity:.32;z-index:0}
.sa-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 25% 55%,transparent 30%,rgba(0,0,0,.5) 100%);pointer-events:none;z-index:1}
.hero-wrap{display:grid;grid-template-columns:1fr 420px;gap:52px;align-items:end;max-width:1600px;margin:0 auto;padding:0 48px;position:relative;z-index:2}
.sa-hero h1{font-family:'Oswald',sans-serif;font-size:clamp(56px,7.5vw,96px);font-weight:700;line-height:.92;text-transform:uppercase;margin-bottom:20px;cursor:default;transition:color .22s,transform .22s,text-shadow .22s}
.sa-hero h1:hover{color:var(--accent);transform:scale(1.025);text-shadow:0 0 48px rgba(var(--accent-rgb),.3)}
.sa-hero h1:hover em{color:#fff}
.sa-hero h1 em{font-style:normal;color:var(--accent)}
.hero-loc{font-family:'Oswald',sans-serif;font-size:20px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:14px}
.hero-sub{font-size:24px;color:var(--text-body);line-height:1.5;margin-bottom:36px;max-width:620px;transition:color .28s;cursor:default}
.hero-sub:hover{color:#fff}
.hero-btns{display:flex;gap:16px;flex-wrap:wrap}
.hero-btns .btn,.hero-btns .btn-o{font-size:17px;padding:16px 32px}
.sa-hero .eyebrow{font-size:19px;letter-spacing:.18em}
.hero-card{background:rgba(0,0,0,.62);border:1px solid rgba(var(--accent-rgb),.22);border-radius:16px;padding:28px 24px;box-shadow:0 24px 64px rgba(0,0,0,.6)}
.hc-top{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.hc-pulse{width:8px;height:8px;border-radius:50%;background:#4caf50;box-shadow:0 0 8px #4caf50;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hc-pulse-text{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:#4caf50}
.hc-title{font-family:'Oswald',sans-serif;font-size:20px;font-weight:700;text-transform:uppercase;margin-bottom:4px}
.hc-body{font-size:14px;color:var(--text-muted);margin-bottom:8px;line-height:1.4}
.hc-link{font-family:'Oswald',sans-serif;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);text-decoration:none;transition:color .2s}
.hc-link:hover{color:#fff}
.hc-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:20px;padding-top:18px;border-top:1px solid rgba(255,255,255,.07)}
.hc-stat{text-align:center}
.hc-stat-val{font-family:'Oswald',sans-serif;font-size:18px;font-weight:700;color:var(--accent);display:block;transition:transform .2s}
.hc-stat:hover .hc-stat-val{transform:scale(1.15);color:#fff}
.hc-stat-lbl{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);transition:color .2s}
.hc-stat:hover .hc-stat-lbl{color:#fff}

/* BADGE ROW */
.brow{background:rgba(0,0,0,.22);border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06)}
.binner{max-width:1400px;margin:0 auto;padding:0 48px;display:flex;align-items:stretch;justify-content:space-between}
.bi{display:flex;align-items:center;gap:10px;padding:18px 20px;font-size:15px;font-weight:600;color:rgba(255,255,255,.65);white-space:nowrap;letter-spacing:.03em;cursor:default;border-radius:6px;flex:1;justify-content:center;transition:color .2s,background .2s}
.bi:hover{color:#fff;background:rgba(var(--accent-rgb),.07)}
.bi-val{font-family:'Oswald',sans-serif;font-size:22px;font-weight:700;color:var(--accent);margin-right:4px;transition:transform .2s}
.bi:hover .bi-val{transform:scale(1.15)}
.bdiv{width:1px;height:32px;background:rgba(255,255,255,.08);flex-shrink:0;align-self:center}

/* SPLIT SECTIONS */
.split-sec{padding:96px 0}
.split-sec.alt-bg{background:rgba(0,0,0,.13)}
.split-inner{display:grid;grid-template-columns:2fr 3fr;gap:52px;align-items:center}
.split-inner.reverse{direction:rtl}
.split-inner.reverse>*{direction:ltr}
.split-body{font-size:19px;color:var(--text-body);line-height:1.5;margin-bottom:14px;transition:color .28s,transform .28s;cursor:default}
.split-body:hover{color:#fff;transform:translateX(4px)}
.split-body a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.split-bullets{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px}
.sb{display:flex;align-items:flex-start;gap:14px;cursor:default;transition:transform .2s}
.sb:hover{transform:translateX(4px)}
.sb-icon{display:none!important}
.sb strong{display:block;font-family:'Oswald',sans-serif;font-size:17px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:#fff;margin-bottom:3px;transition:color .2s}
.sb:hover strong{color:var(--accent)}
.sb span{font-size:18px;color:var(--text-body);line-height:1.45;transition:color .2s}
.sb:hover span{color:rgba(255,255,255,.95)}
.split-img{position:relative;border-radius:12px;overflow:hidden;aspect-ratio:4/3;box-shadow:0 24px 64px rgba(0,0,0,.45);transition:box-shadow .35s,border-color .35s;border:1px solid transparent}
.split-img:hover{box-shadow:0 28px 72px rgba(0,0,0,.6),0 0 0 1px rgba(var(--accent-rgb),.35);border-color:rgba(var(--accent-rgb),.35)}
.split-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s}
.split-img:hover img{transform:scale(1.06)}
.split-img-overlay{position:absolute;inset:0;background:linear-gradient(160deg,transparent 40%,rgba(0,0,0,.55));pointer-events:none}
.split-img-tag{position:absolute;bottom:16px;left:16px;display:inline-flex;align-items:center;gap:7px;background:rgba(0,0,0,.65);border:1px solid rgba(255,255,255,.12);border-radius:6px;padding:8px 13px;font-size:13px;font-family:'Oswald',sans-serif;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#fff;transition:background .25s,border-color .25s}
.split-img:hover .split-img-tag{background:rgba(var(--accent-rgb),.18);border-color:rgba(var(--accent-rgb),.4)}
.split-link{display:inline-flex;align-items:center;gap:6px;font-family:'Oswald',sans-serif;font-size:15px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);text-decoration:none;margin-top:12px;transition:color .2s,gap .2s}
.split-link:hover{color:#fff;gap:10px}

/* CARD GRID */
.card-sec{padding:88px 0}
.card-sec.alt-bg{background:rgba(0,0,0,.13)}
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px}
.card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;padding:28px 24px;transition:border-color .25s,transform .25s,background .2s,box-shadow .25s;position:relative;overflow:hidden;box-shadow:0 4px 18px rgba(0,0,0,.28)}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.card:hover{border-color:rgba(var(--accent-rgb),.3);transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.38),0 0 20px rgba(var(--accent-rgb),.1)}
.card:hover::before{transform:scaleX(1)}
.card-top{display:flex;align-items:center;gap:20px;margin-bottom:14px}
.card-top h3{margin-bottom:0}
.card-icon{display:none!important}
.card h3{font-family:'Oswald',sans-serif;font-size:22px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;margin-bottom:8px;transition:color .2s}
.card:hover h3{color:var(--accent)}
.card p{font-size:18px;color:var(--text-body);line-height:1.45;transition:color .2s}
.card:hover p{color:rgba(255,255,255,.9)}
.card-img{height:280px;border-radius:12px 12px 0 0;overflow:hidden;margin:-28px -24px 16px -24px;width:calc(100% + 48px);position:relative}
.card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
.card:hover .card-img img{transform:scale(1.06)}
.card-img::after{display:none}
.card-body{}
.card-link{font-family:'Oswald',sans-serif;font-size:14px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);text-decoration:none;display:inline-flex;align-items:center;gap:6px;margin-top:14px;transition:color .2s,gap .2s}
.card-link:hover{color:#fff;gap:10px}
.pills{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px;margin-bottom:8px}
.pill{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:4px;padding:6px 12px;font-size:14px;color:rgba(255,255,255,.6);transition:background .15s,border-color .15s,color .15s;text-decoration:none;cursor:pointer}
.pill:hover{background:rgba(var(--accent-rgb),.15);border-color:rgba(var(--accent-rgb),.35);color:var(--accent)}
.card-btns{display:flex;gap:8px;margin-top:14px}

/* DEV CARD ACTIVE STATES */
.dev-card.dev-active{border-color:rgba(var(--accent-rgb),.3);transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.38),0 0 20px rgba(var(--accent-rgb),.1)}
.dev-card.dev-active::before{transform:scaleX(1)}
.dev-card.dev-active h3{color:var(--accent)}
.dev-card.dev-active p{color:rgba(255,255,255,.9)}
.dev-grid:hover .dev-active:not(:hover){border-color:var(--card-border);transform:none;box-shadow:0 4px 18px rgba(0,0,0,.28)}
.dev-grid:hover .dev-active:not(:hover)::before{transform:scaleX(0)}
.dev-grid:hover .dev-active:not(:hover) h3{color:#fff}
.dev-grid:hover .dev-active:not(:hover) p{color:var(--text-body)}

/* GENERIC CARD ACTIVE STATE */
.card.active{border-color:rgba(var(--accent-rgb),.3);transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.38),0 0 20px rgba(var(--accent-rgb),.1)}
.card.active::before{transform:scaleX(1)}
.card.active h3{color:var(--accent)}
.card.active p{color:rgba(255,255,255,.9)}
.card-grid:hover .card.active:not(:hover){border-color:var(--card-border);transform:none;box-shadow:0 4px 18px rgba(0,0,0,.28)}
.card-grid:hover .card.active:not(:hover)::before{transform:scaleX(0)}
.card-grid:hover .card.active:not(:hover) h3{color:#fff}
.card-grid:hover .card.active:not(:hover) p{color:var(--text-body)}

/* INDUSTRY LIST */
.ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.ind-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:10px;padding:18px 16px;transition:border-color .25s,transform .25s,background .2s,box-shadow .25s;position:relative;overflow:hidden;cursor:default;display:flex;flex-direction:column}
.ind-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.ind-card:hover{border-color:rgba(var(--accent-rgb),.3);transform:translateY(-4px);background:rgba(var(--accent-rgb),.06);box-shadow:0 16px 48px rgba(0,0,0,.38),0 0 20px rgba(var(--accent-rgb),.1)}
.ind-card:hover::before{transform:scaleX(1)}
.ind-card-top{display:flex;align-items:center;gap:18px;margin-bottom:10px}
.ind-icon{display:none!important}
.ind-card-top strong{font-family:'Oswald',sans-serif;font-size:18px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:#fff;transition:color .2s;white-space:nowrap}
.ind-card:hover .ind-card-top strong{color:var(--accent)}
.ind-desc{font-size:17px;color:var(--text-body);line-height:1.4;transition:color .2s;display:block}
.ind-card:hover .ind-desc{color:rgba(255,255,255,.9)}
.ind-card.ind-active{border-color:rgba(var(--accent-rgb),.3);transform:translateY(-4px);background:rgba(var(--accent-rgb),.06);box-shadow:0 16px 48px rgba(0,0,0,.38),0 0 20px rgba(var(--accent-rgb),.1)}
.ind-card.ind-active::before{transform:scaleX(1)}
.ind-card.ind-active .ind-card-top strong{color:var(--accent)}
.ind-card.ind-active .ind-desc{color:rgba(255,255,255,.9)}
.ind-grid:hover .ind-active:not(:hover){border-color:var(--card-border);transform:none;background:var(--card-bg);box-shadow:none}
.ind-grid:hover .ind-active:not(:hover)::before{transform:scaleX(0)}
.ind-grid:hover .ind-active:not(:hover) .ind-card-top strong{color:#fff}
.ind-grid:hover .ind-active:not(:hover) .ind-desc{color:var(--text-body)}

/* GALLERY */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:40px}
.gallery-card{border-radius:12px;overflow:hidden;position:relative;aspect-ratio:4/3;border:1px solid rgba(var(--accent-rgb),.14);box-shadow:0 8px 32px rgba(0,0,0,.4);transition:transform .22s,box-shadow .22s,border-color .22s}
.gallery-card:hover{transform:translateY(-5px) scale(1.02);box-shadow:0 20px 56px rgba(0,0,0,.55),0 0 24px rgba(var(--accent-rgb),.15);border-color:rgba(var(--accent-rgb),.35)}
.gallery-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.gallery-card:hover img{transform:scale(1.06)}
.gallery-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 50%);display:flex;flex-direction:column;justify-content:flex-end;padding:16px}
.gallery-tag{font-family:'Oswald',sans-serif;font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}
.gallery-loc{font-size:14px;color:rgba(255,255,255,.6)}

/* CALCULATOR */
.calc-card{background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:40px 36px;width:100%;max-width:1100px;transition:border-color .3s,box-shadow .3s;box-shadow:0 8px 32px rgba(0,0,0,.35);display:grid;grid-template-columns:1fr 320px;gap:36px}
.calc-card:hover{border-color:rgba(var(--accent-rgb),.35);box-shadow:0 0 32px rgba(var(--accent-rgb),.1),0 20px 60px rgba(0,0,0,.4)}
.calc-form{}
.calc-card h3{font-family:'Oswald',sans-serif;font-size:36px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;text-align:center}
.calc-card h3 span{color:var(--accent)}
.calc-sub{font-size:18px;color:var(--text-muted);margin-bottom:22px;border-bottom:1px solid rgba(255,255,255,.07);padding-bottom:16px}
.calc-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:12px}
.calc-row.full{grid-template-columns:1fr}
.calc-toggle{display:flex;gap:0;margin-bottom:16px;border-radius:6px;overflow:hidden;border:1px solid rgba(255,255,255,.1)}
.calc-toggle button{flex:1;padding:14px;font-family:'Oswald',sans-serif;font-size:16px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;background:transparent;color:rgba(255,255,255,.5);border:none;cursor:pointer;transition:background .2s,color .2s}
.calc-toggle button.active{background:var(--blue);color:var(--cta-text)}
.calc-result{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:32px 24px;background:rgba(var(--accent-rgb),.06);border:1px solid rgba(var(--accent-rgb),.2);border-radius:12px;gap:24px;min-height:100%}
.cr-item{text-align:center}
.cr-val{font-family:'Oswald',sans-serif;font-size:56px;font-weight:700;color:var(--accent);display:block;transition:transform .2s}
.cr-item:hover .cr-val{transform:scale(1.08)}
.cr-lbl{font-size:14px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);margin-top:4px}
.cr-divider{width:60px;height:1px;background:rgba(var(--accent-rgb),.3)}
.calc-card .btn{font-size:18px;padding:16px 28px}

/* TIMELINE STEPS */
.tl-steps{display:flex;align-items:flex-start;gap:0;position:relative;counter-reset:step}
.tl-steps::before{content:'';position:absolute;top:48px;left:48px;right:48px;height:4px;background:rgba(var(--accent-rgb),.2);z-index:0}
.tl-step{flex:1;text-align:center;position:relative;z-index:1;padding:0 20px;cursor:default;opacity:0;transform:translateY(30px);transition:opacity .5s ease,transform .5s ease}
.tl-step.visible{opacity:1;transform:none}
.tl-step-circle{width:96px;height:96px;border-radius:50%;background:var(--bg);border:4px solid var(--blue);display:flex;align-items:center;justify-content:center;margin:0 auto 24px;font-family:'Oswald',sans-serif;font-size:44px;font-weight:700;color:var(--blue);transition:background .25s,color .25s,transform .25s,box-shadow .25s}
.tl-step:hover .tl-step-circle{background:var(--blue);color:#fff;transform:scale(1.1);box-shadow:0 8px 32px rgba(var(--blue-rgb),.4)}
.tl-step.tl-active .tl-step-circle{background:var(--blue);color:#fff;transform:scale(1.1);box-shadow:0 8px 32px rgba(var(--blue-rgb),.4)}
.tl-step.tl-active .tl-step-heading{color:var(--accent)}
.tl-step.tl-active .tl-step-desc{color:rgba(255,255,255,.9)}
.tl-steps:hover .tl-active:not(:hover) .tl-step-circle{background:var(--bg);color:var(--accent);transform:none;box-shadow:none}
.tl-steps:hover .tl-active:not(:hover) .tl-step-heading{color:#fff}
.tl-steps:hover .tl-active:not(:hover) .tl-step-desc{color:var(--text-body)}
.tl-step-heading{font-family:'Oswald',sans-serif;font-size:22px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;color:#fff;transition:color .2s}
.tl-step:hover .tl-step-heading{color:var(--accent)}
.tl-step-desc{font-size:17px;color:var(--text-body);line-height:1.5;max-width:200px;margin:0 auto;transition:color .2s}
.tl-step:hover .tl-step-desc{color:rgba(255,255,255,.9)}

/* OLD STEPS (product/category pages) */
.steps{display:flex;flex-direction:column;gap:0;margin-top:32px}
.step{display:flex;align-items:flex-start;gap:20px;padding:24px 0;border-bottom:1px solid rgba(255,255,255,.07);cursor:default;transition:background .2s,padding-left .2s;border-radius:8px}
.step:last-child{border-bottom:none}
.step:hover{background:rgba(var(--accent-rgb),.05);padding-left:12px}
.step-num{font-family:'Oswald',sans-serif;font-size:40px;font-weight:700;color:rgba(var(--accent-rgb),.25);line-height:1;flex-shrink:0;width:52px;text-align:right;transition:color .25s,transform .25s}
.step:hover .step-num{color:var(--accent);transform:scale(1.1)}
.step-info strong{font-family:'Oswald',sans-serif;font-size:17px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:#fff;display:block;margin-bottom:5px;transition:color .2s}
.step:hover .step-info strong{color:var(--accent)}
.step-info span{font-size:17px;color:var(--text-body);line-height:1.45;transition:color .2s}
.step:hover .step-info span{color:rgba(255,255,255,.9)}

/* STEPS GRID (product pages - compact) */
.steps-grid{display:flex;flex-direction:column;gap:0;margin-top:24px}
.step-item{display:flex;align-items:flex-start;gap:12px;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.06);cursor:default;transition:background .2s,padding-left .2s;border-radius:6px}
.step-item:last-child{border-bottom:none}
.step-item:hover{background:rgba(var(--accent-rgb),.04);padding-left:10px}
.step-num{font-family:'Oswald',sans-serif;font-size:52px;font-weight:700;color:var(--accent);line-height:1;flex-shrink:0;width:48px;text-align:center;transition:color .25s,transform .2s}
.step-item:hover .step-num{color:#fff;transform:scale(1.1)}
.step-item h3{font-family:'Oswald',sans-serif;font-size:20px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:#fff;margin-bottom:4px;transition:color .2s}
.step-item:hover h3{color:var(--accent)}
.step-item p{font-size:17px;color:var(--text-body);line-height:1.45;transition:color .2s}
.step-item:hover p{color:rgba(255,255,255,.9)}

/* CITY CHIPS */
.city-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:32px}
.city-chip{background:var(--card-bg);border:1px solid var(--card-border);border-radius:10px;padding:18px 16px;text-decoration:none;transition:border-color .2s,transform .2s,background .2s,box-shadow .2s;display:block;text-align:center}
.city-chip:hover{border-color:rgba(var(--accent-rgb),.4);transform:translateY(-3px);background:rgba(var(--accent-rgb),.08);box-shadow:0 12px 32px rgba(0,0,0,.3)}
.city-chip strong{font-family:'Oswald',sans-serif;font-size:22px;font-weight:700;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:4px;transition:color .2s}
.city-chip:hover strong{color:#fff}
.city-chip span{font-size:15px;color:var(--text-muted);transition:color .2s;display:block}
.city-chip:hover span{color:rgba(255,255,255,.7)}

/* REVIEWS */
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px}
.review-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;padding:26px 24px;transition:transform .22s,box-shadow .22s,border-color .22s;position:relative}
.review-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.3),0 0 20px rgba(var(--accent-rgb),.08);border-color:rgba(var(--accent-rgb),.3)}
.review-card.featured{border-color:rgba(var(--accent-rgb),.35);background:rgba(var(--accent-rgb),.08)}
.review-stars{display:flex;gap:3px;margin-bottom:14px;transition:transform .2s,filter .2s}
.review-card:hover .review-stars{transform:scale(1.08);filter:drop-shadow(0 0 6px rgba(var(--accent-rgb),.6))}
.review-star{color:var(--accent);font-size:16px}
.review-quote{font-size:17px;line-height:1.55;color:var(--text-body);margin-bottom:18px;font-style:italic;transition:color .2s,transform .2s}
.review-card:hover .review-quote{color:rgba(255,255,255,.88);transform:translateX(3px)}
.review-meta{display:flex;align-items:center;gap:10px;border-top:1px solid rgba(255,255,255,.06);padding-top:14px}
.review-avatar{width:36px;height:36px;border-radius:50%;background:rgba(var(--accent-rgb),.14);border:1px solid rgba(var(--accent-rgb),.22);display:flex;align-items:center;justify-content:center;font-family:'Oswald',sans-serif;font-size:14px;font-weight:700;color:var(--accent);flex-shrink:0;transition:background .2s,border-color .2s,box-shadow .2s}
.review-card:hover .review-avatar{background:rgba(var(--accent-rgb),.28);border-color:var(--accent);box-shadow:0 0 12px rgba(var(--accent-rgb),.35)}
.review-name{font-family:'Oswald',sans-serif;font-size:15px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#fff;transition:color .2s}
.review-card:hover .review-name{color:var(--accent)}
.review-city{font-size:14px;color:var(--text-muted)}
.review-badge{position:absolute;top:16px;right:16px;font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);background:rgba(var(--accent-rgb),.1);border:1px solid rgba(var(--accent-rgb),.2);border-radius:4px;padding:3px 8px;transition:background .2s,border-color .2s}
.review-card:hover .review-badge{background:rgba(var(--accent-rgb),.2);border-color:rgba(var(--accent-rgb),.45)}

/* FAQ ACCORDION */
.faqgd{display:grid;grid-template-columns:1fr 1fr;gap:12px 28px;margin-top:40px}
.fi{border:1px solid rgba(255,255,255,.07);border-radius:8px;overflow:hidden;background:rgba(0,0,0,.18);transition:border-color .2s,background .2s,box-shadow .2s}
.fi:hover{background:rgba(0,0,0,.28);border-color:rgba(255,255,255,.12)}
.fi.open{border-color:rgba(var(--blue-rgb),.35);background:rgba(var(--blue-rgb),.05);box-shadow:0 0 0 1px rgba(var(--blue-rgb),.1),inset 3px 0 0 var(--blue)}
.fq{padding:18px 20px;font-family:'Oswald',sans-serif;font-size:20px;font-weight:600;letter-spacing:.02em;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px;user-select:none;transition:color .2s}
.fq:hover{color:var(--accent)}
.ft{width:22px;height:22px;border-radius:50%;background:var(--icon-bg);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s,transform .3s}
.fi.open .ft{background:var(--blue);transform:rotate(45deg)}
.fi.open .fq{color:var(--accent)}
.fa{max-height:0;overflow:hidden;transition:max-height .35s ease}
.fi.open .fa{max-height:800px}
.fa p{padding:0 20px 18px;font-size:18px;color:var(--text-body);line-height:1.5;transition:color .2s,transform .2s;cursor:default}
.fa p:hover{color:rgba(255,255,255,.9);transform:translateX(3px)}
.fa a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}

/* STAT ROW */
.stat-row{display:flex;gap:24px;margin:24px 0;flex-wrap:wrap}
.stat-item{text-align:center;flex:1;min-width:100px;padding:16px;background:rgba(var(--accent-rgb),.06);border:1px solid rgba(var(--accent-rgb),.15);border-radius:8px;transition:transform .2s,border-color .2s,box-shadow .2s;cursor:default}
.stat-item:hover{transform:translateY(-3px);border-color:rgba(var(--accent-rgb),.4);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.stat-val{font-family:'Oswald',sans-serif;font-size:28px;font-weight:700;color:var(--accent);display:block;transition:transform .2s}
.stat-item:hover .stat-val{transform:scale(1.1)}
.stat-lbl{font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}

/* FORM */
.form-card{background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:32px 28px;transition:border-color .3s,box-shadow .3s,transform .25s;box-shadow:0 8px 32px rgba(0,0,0,.35)}
.form-card:hover{border-color:rgba(var(--accent-rgb),.35);box-shadow:0 0 32px rgba(var(--accent-rgb),.1),0 20px 60px rgba(0,0,0,.4);transform:translateY(-3px)}
.form-card h3{font-family:'Oswald',sans-serif;font-size:22px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}
.form-card h3 span{color:var(--accent)}
.form-card .fsub{font-size:14px;color:var(--text-muted);margin-bottom:20px;line-height:1.4;border-bottom:1px solid rgba(255,255,255,.07);padding-bottom:16px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.frow.full{grid-template-columns:1fr}
.fgroup{display:flex;flex-direction:column;gap:5px}
.fgroup label{font-size:14px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.45);transition:color .2s}
.fgroup:hover label{color:var(--accent)}
.fgroup input,.fgroup select,.fgroup textarea{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:16px 18px;font-family:'Source Sans 3',sans-serif;font-size:18px;color:#fff;outline:none;transition:border-color .2s,box-shadow .2s,background .2s;width:100%}
.fgroup input:hover,.fgroup select:hover,.fgroup textarea:hover{border-color:rgba(var(--accent-rgb),.4);background:rgba(255,255,255,.07)}
.fgroup input:focus,.fgroup select:focus,.fgroup textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.15)}
.fgroup input::placeholder,.fgroup textarea::placeholder{color:rgba(255,255,255,.25)}
.fgroup select{appearance:none;cursor:pointer;color:rgba(255,255,255,.7)}
.fgroup select option{background:#1a1a1a;color:#fff}
.fgroup textarea{resize:vertical;min-height:100px}
.form-submit{width:100%;margin-top:8px;justify-content:center;font-size:15px;padding:15px 26px;border-radius:6px}
.form-note{font-size:13px;color:var(--text-muted);text-align:center;margin-top:10px;line-height:1.4}
.form-success{text-align:center;padding:40px 20px}
.form-success h3{font-family:'Oswald',sans-serif;font-size:28px;font-weight:700;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.form-success p{font-size:18px;color:var(--text-body);line-height:1.5}
.form-error{font-size:14px;color:#e74c3c;text-align:center;margin-top:10px}

/* INTENT TABS */
.intent-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:20px}
.intent-tab{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:14px 12px;font-family:'Oswald',sans-serif;font-size:15px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:rgba(255,255,255,.55);text-align:center;cursor:pointer;transition:background .2s,border-color .2s,color .2s,transform .18s}
.intent-tab:hover{border-color:rgba(var(--accent-rgb),.4);color:#fff;background:rgba(var(--accent-rgb),.08);transform:translateY(-2px)}
.intent-tab.active{background:var(--blue);border-color:var(--blue);color:#fff}

/* SPEC TABLE */
.spec-table{width:100%;border-collapse:collapse;margin-top:20px}
.spec-table th,.spec-table td{padding:14px 18px;text-align:left;border-bottom:1px solid rgba(255,255,255,.07);transition:background .2s}
.spec-table th{font-family:'Oswald',sans-serif;font-size:15px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);background:rgba(var(--accent-rgb),.06)}
.spec-table td{font-size:17px;color:var(--text-body)}
.spec-table tr:hover td{background:rgba(var(--accent-rgb),.04);color:rgba(255,255,255,.9)}

/* BREADCRUMB */
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-muted);margin-bottom:12px;flex-wrap:wrap}
.breadcrumb a{color:var(--text-muted);text-decoration:none;transition:color .2s}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb span{color:rgba(255,255,255,.3)}

/* PRODUCT HERO (smaller variant for inner pages) */
.prod-hero{padding:140px 0 60px;position:relative}
.prod-hero .hero-bg{opacity:.22}
.prod-hero h1{font-family:'Oswald',sans-serif;font-size:clamp(40px,5.5vw,72px);font-weight:700;line-height:.95;text-transform:uppercase;margin-bottom:12px;cursor:default;transition:color .22s,transform .22s,text-shadow .22s}
.prod-hero h1:hover{color:var(--accent);transform:scale(1.025);text-shadow:0 0 48px rgba(var(--accent-rgb),.3)}
.prod-hero h1 em{font-style:normal;color:var(--accent)}
.prod-hero h1:hover em{color:#fff}

/* PRODUCT HERO GRID */
.prod-grid{display:grid;grid-template-columns:1fr 420px;gap:52px;align-items:start}
.prod-eyebrow{font-size:16px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.prod-eyebrow .pulse-dot{width:8px;height:8px;border-radius:50%;background:#4caf50;box-shadow:0 0 8px #4caf50;animation:pulse 2s infinite}
.prod-h1{font-family:'Oswald',sans-serif;font-size:clamp(40px,5vw,64px);font-weight:700;line-height:.95;text-transform:uppercase;margin-bottom:8px;cursor:default;transition:color .22s,transform .22s,text-shadow .22s}
.prod-h1:hover{color:var(--accent);transform:scale(1.02);text-shadow:0 0 40px rgba(var(--accent-rgb),.3)}
.prod-h1 em{font-style:normal;color:var(--accent)}
.prod-h1:hover em{color:#fff}
.prod-loc{font-family:'Oswald',sans-serif;font-size:24px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:16px}
.prod-desc{font-size:20px;color:var(--text-body);line-height:1.55;margin-bottom:28px;transition:color .28s;cursor:default}
.prod-desc:hover{color:#fff}
.prod-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 40%;background-attachment:fixed;opacity:.3;z-index:0}
.prod-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(28,31,36,.8) 30%,rgba(28,31,36,.5) 100%);z-index:1;pointer-events:none}
.prod-hero .si{position:relative;z-index:2;max-width:1400px}

/* ORDER CARD */
.order-card{background:rgba(0,0,0,.55);border:1px solid rgba(var(--blue-rgb),.22);border-radius:16px;padding:28px 24px;box-shadow:0 24px 64px rgba(0,0,0,.6);position:sticky;top:110px;align-self:start}
.qty-toggle{display:flex;gap:0;margin:12px 0 16px;border-radius:6px;overflow:hidden;border:1px solid rgba(255,255,255,.1)}
.qty-toggle button{flex:1;padding:10px;font-family:'Oswald',sans-serif;font-size:14px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;background:transparent;color:rgba(255,255,255,.5);border:none;cursor:pointer;transition:background .2s,color .2s}
.qty-toggle button.active{background:var(--blue);color:#fff}
.oc-title{font-family:'Oswald',sans-serif;font-size:22px;font-weight:700;text-transform:uppercase;margin-bottom:12px}
.oc-title span{color:var(--accent)}
.oc-sub{font-size:16px;color:var(--text-muted);margin-bottom:18px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.07)}
.oc-label{font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);margin-bottom:8px}
.qty-pills{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.qty-pill{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:10px 18px;font-family:'Oswald',sans-serif;font-size:15px;font-weight:600;color:rgba(255,255,255,.7);cursor:pointer;transition:all .2s;text-align:center;flex:1;min-width:60px}
.qty-pill:hover,.qty-pill.active{background:rgba(var(--accent-rgb),.15);border-color:rgba(var(--accent-rgb),.5);color:#fff;box-shadow:0 0 12px rgba(var(--accent-rgb),.2)}
.qty-input{width:100%;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:11px 14px;font-family:'Source Sans 3',sans-serif;font-size:16px;color:#fff;outline:none;margin-bottom:20px;transition:border-color .2s}
.qty-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.15)}
.trust-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
.trust-item{display:flex;align-items:center;gap:8px;font-size:14px;color:rgba(255,255,255,.6);transition:color .2s}
.trust-item:hover{color:#fff}
.trust-item .ico{width:14px;height:14px;flex-shrink:0;transition:transform .2s}
.trust-item:hover .ico{transform:scale(1.25)}
.oc-phone{display:block;text-align:center;font-family:'Oswald',sans-serif;font-size:16px;font-weight:700;color:#fff;text-decoration:none;margin-top:12px;transition:color .2s}
.oc-phone:hover{color:var(--accent)}

/* USES GRID */
.uses-grid{display:flex;gap:16px;margin-top:36px}.uses-grid .use-card{flex:1;min-width:0}
.use-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:10px;padding:22px 18px;transition:border-color .25s,transform .25s,background .2s,box-shadow .25s;cursor:default;position:relative;overflow:hidden}
.use-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.use-card:hover{border-color:rgba(var(--accent-rgb),.3);transform:translateY(-4px);background:rgba(var(--accent-rgb),.06);box-shadow:0 16px 48px rgba(0,0,0,.38),0 0 20px rgba(var(--accent-rgb),.1)}
.use-card:hover::before{transform:scaleX(1)}
.use-card-top{display:flex;align-items:center;gap:16px;margin-bottom:10px}
.use-icon{width:40px;height:40px;min-width:40px;border-radius:9px;background:var(--icon-bg);border:1px solid var(--card-border);display:flex;align-items:center;justify-content:center;transition:background .25s,border-color .25s,box-shadow .25s,transform .25s}
.use-card:hover .use-icon{background:rgba(var(--accent-rgb),.22);border-color:rgba(var(--accent-rgb),.45);box-shadow:0 0 14px rgba(var(--accent-rgb),.3);transform:scale(1.18)}
.use-card-top strong{font-family:'Oswald',sans-serif;font-size:17px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;transition:color .2s}
.use-card:hover .use-card-top strong{color:var(--accent)}
.use-desc{font-size:16px;color:var(--text-body);line-height:1.45;transition:color .2s}
.use-card:hover .use-desc{color:rgba(255,255,255,.9)}

/* SPECS LAYOUT */
.specs-layout{display:grid;grid-template-columns:1fr 320px;gap:36px;align-items:start}
.specs-table{width:100%;border-collapse:collapse}
.specs-table th{font-family:'Oswald',sans-serif;font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);text-align:left;padding:12px 16px;border-bottom:2px solid rgba(var(--accent-rgb),.3)}
.specs-table td{padding:12px 16px;font-size:17px;color:var(--text-body);border-bottom:1px solid rgba(255,255,255,.06);transition:color .2s,background .2s}
.specs-table tr:hover{background:rgba(var(--accent-rgb),.06)}
.specs-table tr:hover td{color:rgba(255,255,255,.9)}
.specs-table td:first-child{font-family:'Oswald',sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:#fff}
.quick-facts{background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:24px 20px;position:sticky;top:120px}
.qf-title{font-family:'Oswald',sans-serif;font-size:18px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:16px;color:var(--accent)}
.qf-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.06);font-size:15px}
.qf-label{color:var(--text-muted)}
.qf-val{color:#fff;font-weight:600}

/* RELATED PRODUCTS GRID */
.related-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:32px}
.rel-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:10px;overflow:hidden;text-decoration:none;color:#fff;transition:border-color .25s,transform .25s,box-shadow .25s;display:block}
.rel-card:hover{border-color:rgba(var(--accent-rgb),.35);transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.38)}
.rel-card-img{width:100%;height:140px;object-fit:cover;display:block;transition:transform .5s}
.rel-card:hover .rel-card-img{transform:scale(1.06)}
.rel-card-body{padding:14px 12px}
.rel-card-body strong{font-family:'Oswald',sans-serif;font-size:16px;font-weight:700;text-transform:uppercase;display:block;margin-bottom:4px;transition:color .2s}
.rel-card:hover .rel-card-body strong{color:var(--accent)}
.rel-card-body span{font-size:14px;color:var(--text-muted);line-height:1.3;display:block}

/* FAQ LAYOUT (no sidebar) */
.faq-layout{display:block}
.faq-sidebar{display:none}

/* BENEFITS LIST */
.benefits-list{display:flex;flex-direction:column;gap:6px;margin:14px 0}
.benefit{display:flex;align-items:center;gap:8px;font-size:15px;color:var(--text-body);transition:color .2s}
.benefit:hover{color:#fff}
.benefit .ico{color:var(--accent);flex-shrink:0}

/* CALC CALL LINK */
.calc-call{display:block;text-align:center;font-family:'Oswald',sans-serif;font-size:16px;font-weight:700;color:#fff;text-decoration:none;margin-top:10px;transition:color .2s}
.calc-call:hover{color:var(--accent)}

/* CALC LAYOUT (centered) */
.calc-layout{display:flex;flex-direction:column;align-items:center;text-align:center;gap:36px}

@media(max-width:1100px){.prod-grid{grid-template-columns:1fr 380px;gap:36px}.specs-layout{grid-template-columns:1fr}}
@media(max-width:900px){.prod-grid{grid-template-columns:1fr;gap:32px}.order-card{position:relative;top:0}.uses-grid{flex-wrap:wrap}.uses-grid .use-card{flex:1 1 calc(50% - 8px);min-width:calc(50% - 8px)}.prod-hero-bg{background-attachment:scroll}.specs-layout{grid-template-columns:1fr}.calc-layout{text-align:left}.related-grid{grid-template-columns:repeat(2,1fr)}.split-inner{grid-template-columns:1fr}}
@media(max-width:600px){.uses-grid .use-card{flex:1 1 calc(50% - 8px);min-width:calc(50% - 8px)}.related-grid{grid-template-columns:repeat(2,1fr)}}

/* PRODUCT IMAGE BADGES */
.prod-img-badges{position:absolute;bottom:16px;left:16px;display:flex;gap:10px;align-items:center;z-index:2}
.prod-img-tag{display:inline-flex;align-items:center;gap:7px;background:rgba(0,0,0,.65);border:1px solid rgba(255,255,255,.12);border-radius:6px;padding:8px 14px;font-size:14px;font-family:'Oswald',sans-serif;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#fff;transition:background .25s,border-color .25s}
.prod-img-wrap:hover .prod-img-tag{background:rgba(var(--accent-rgb),.18);border-color:rgba(var(--accent-rgb),.4)}
.prod-avail-tag{background:rgba(var(--blue-rgb),.25);border-color:rgba(var(--blue-rgb),.35)}
.prod-img-wrap:hover .prod-avail-tag{background:rgba(var(--blue-rgb),.35);border-color:rgba(var(--blue-rgb),.5)}
.pulse-dot-sm{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px var(--accent);animation:pulse 2s infinite}
.prod-img-wrap{position:relative;border-radius:12px;overflow:hidden;aspect-ratio:3/2;box-shadow:0 24px 64px rgba(0,0,0,.45)}
.prod-img-wrap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s}
.prod-img-wrap:hover img{transform:scale(1.04)}
.prod-img-overlay{position:absolute;inset:0;background:linear-gradient(160deg,transparent 40%,rgba(0,0,0,.6));pointer-events:none}
@media(max-width:600px){.prod-img-badges{gap:6px;flex-wrap:wrap}.prod-img-tag{font-size:12px;padding:6px 10px}}

/* CATEGORY PAGE HERO */
.hero-sec{padding:160px 0 72px;position:relative;overflow:hidden}
.hero-sec .hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 40%;background-attachment:fixed;opacity:.6;z-index:0}
.hero-sec::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(28,31,36,.65) 30%,rgba(28,31,36,.3) 100%);z-index:1;pointer-events:none}
.hero-inner{max-width:1400px;margin:0 auto;padding:0 48px;position:relative;z-index:2}
.hero-sec h1{font-family:'Oswald',sans-serif;font-size:clamp(48px,6vw,80px);font-weight:700;line-height:.95;text-transform:uppercase;margin-bottom:16px;cursor:default;transition:color .22s,transform .22s,text-shadow .22s}
.hero-sec h1:hover{color:var(--accent);transform:scale(1.025);text-shadow:0 0 48px rgba(var(--accent-rgb),.3)}
.hero-sec h1:hover em{color:#fff}
.hero-sec h1 em{font-style:normal;color:var(--accent)}
.hero-line{display:block}

/* BADGE ROW */
.badge-row{display:flex;gap:16px;flex-wrap:wrap;margin-top:24px}
.badge-item{display:flex;align-items:center;gap:10px;padding:12px 18px;background:rgba(var(--accent-rgb),.06);border:1px solid rgba(var(--accent-rgb),.18);border-radius:8px;transition:transform .2s,border-color .2s,box-shadow .2s;cursor:default}
.badge-item:hover{transform:translateY(-2px);border-color:rgba(var(--accent-rgb),.45);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.badge-val{font-family:'Oswald',sans-serif;font-size:20px;font-weight:700;color:var(--accent);transition:transform .2s}
.badge-item:hover .badge-val{transform:scale(1.12)}
.badge-lbl{font-size:15px;color:rgba(255,255,255,.65)}
.badge-item .ico{transition:transform .2s}
.badge-item:hover .ico{transform:scale(1.25)}

/* CHOOSE GRID (category product selector) */
.choose-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:20px;margin-top:40px}
.choose-item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;cursor:pointer;transition:transform .2s;padding:28px 20px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;position:relative;overflow:hidden;height:100%;text-decoration:none;color:#fff}
.choose-item::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.choose-item:hover{transform:translateY(-4px);border-color:rgba(var(--accent-rgb),.3);box-shadow:0 16px 48px rgba(0,0,0,.38),0 0 20px rgba(var(--accent-rgb),.1)}
.choose-item:hover::before{transform:scaleX(1)}
.choose-item.choose-active{border-color:rgba(var(--accent-rgb),.3);transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.38),0 0 20px rgba(var(--accent-rgb),.1)}
.choose-item.choose-active::before{transform:scaleX(1)}
.choose-img{width:100%;aspect-ratio:4/3;border-radius:8px;overflow:hidden;margin-bottom:4px}
.choose-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
.choose-item:hover .choose-img img{transform:scale(1.08)}
.choose-banner{width:100%;max-height:380px;border-radius:12px;overflow:hidden;border:1px solid rgba(var(--accent-rgb),.14)}
.choose-banner img{width:100%;max-height:380px;object-fit:cover;display:block}
.choose-item strong{display:block;font-family:'Oswald',sans-serif;font-size:18px;white-space:nowrap;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:#fff;margin-bottom:8px;transition:color .2s}
.choose-item:hover strong{color:var(--accent)}
.choose-item.choose-active strong{color:var(--accent)}
.choose-item span{font-size:16px;color:var(--text-body);line-height:1.45;transition:color .2s;display:block}
.choose-item:hover span{color:rgba(255,255,255,.92)}
.choose-link{font-family:'Oswald',sans-serif;font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-top:auto;transition:color .2s}
.choose-item:hover .choose-link{color:#fff}

/* SPEC ACCORDION (category pages) */
.dv-accordion{display:flex;flex-direction:column;gap:12px}
.dv-acc-panel{border:1px solid rgba(var(--accent-rgb),.14);border-radius:10px;overflow:hidden;transition:border-color .25s}
.dv-acc-panel:hover{border-color:rgba(var(--accent-rgb),.35)}
.dv-acc-panel.open{border-color:rgba(var(--accent-rgb),.45)}
.dv-acc-trigger{width:100%;background:rgba(var(--accent-rgb),.06);border:none;color:#fff;padding:20px 24px;display:flex;align-items:center;gap:16px;cursor:pointer;transition:background .2s}
.dv-acc-trigger:hover{background:rgba(var(--accent-rgb),.1)}
svg.dv-acc-icon{width:24px;min-width:24px;height:24px;stroke:var(--accent);fill:none;stroke-width:1.75;flex-shrink:0;transition:transform .25s}
.dv-acc-trigger:hover svg.dv-acc-icon{transform:scale(1.2)}
.dv-acc-trigger-text{flex:1;text-align:left}
.dv-acc-trigger-text h3{font-family:'Oswald',sans-serif;font-size:22px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}
.dv-acc-trigger-text p{font-size:17px;color:var(--text-muted);margin:0}
.dv-acc-arrow{width:24px;min-width:24px;height:24px;stroke:var(--text-muted);fill:none;stroke-width:2;transition:transform .3s,stroke .3s;flex-shrink:0}
.dv-acc-panel.open .dv-acc-arrow{transform:rotate(180deg);stroke:var(--accent)}
.dv-acc-body{max-height:0;overflow:hidden;transition:max-height .4s ease}
.dv-acc-panel.open .dv-acc-body{max-height:600px}
.dv-acc-body-inner{padding:20px 24px}
.dv-spec-table{width:100%;border-collapse:collapse}
.dv-spec-table th{font-family:'Oswald',sans-serif;font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);text-align:left;padding:10px 14px;border-bottom:2px solid rgba(var(--accent-rgb),.3)}
.dv-spec-table td{padding:10px 14px;font-size:17px;color:var(--text-body);border-bottom:1px solid rgba(255,255,255,.06)}
.dv-spec-table tr:hover td{color:rgba(255,255,255,.9);background:rgba(var(--accent-rgb),.04)}
.dv-spec-table td:first-child{font-family:'Oswald',sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:#fff}

/* CATEGORY RELATED GRID */
.rel-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:40px}

/* CATEGORY CALCULATOR */
.calc-inner{display:flex;gap:36px;align-items:flex-start}
.calc-cta{display:flex;flex-direction:column;gap:12px;margin-top:20px}

/* FAQ SECTION */
.faq-sec{padding:80px 0}

/* CATEGORY RESPONSIVE */
@media(max-width:1100px){.choose-grid{grid-template-columns:repeat(3,1fr)}.rel-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:900px){.hero-inner{padding:0 20px}.hero-sec{padding:130px 0 56px}.hero-sec h1{font-size:clamp(36px,8vw,56px)}.choose-grid{grid-template-columns:repeat(2,1fr)}.choose-img{aspect-ratio:16/9}.rel-grid{grid-template-columns:repeat(2,1fr)}.calc-inner{flex-direction:column;text-align:center}.hero-sec .hero-bg{background-attachment:scroll}.badge-row{justify-content:center}}
@media(max-width:600px){.choose-grid{grid-template-columns:1fr}.rel-grid{grid-template-columns:1fr}.badge-row{flex-direction:column;align-items:stretch}}

/* FOOTER CTA */
.fcta{padding:80px 48px;text-align:center;position:relative;overflow:hidden}
.fcta-bg{position:absolute;inset:0;background:url('https://images.pexels.com/photos/1579356/pexels-photo-1579356.jpeg?w=1600') center 50%/cover fixed;opacity:.22;z-index:0}
.fcta::before{content:'';position:absolute;inset:0;background:var(--fcta-overlay,rgba(0,0,0,.55));z-index:1;pointer-events:none}
.fcta>*{position:relative;z-index:2}
.fcta h2{font-family:'Oswald',sans-serif;font-size:clamp(32px,4vw,56px);font-weight:700;text-transform:uppercase;margin-bottom:16px;cursor:default;transition:color .22s,transform .22s,text-shadow .22s}
.fcta h2:hover{color:var(--accent);transform:scale(1.03);text-shadow:0 0 40px rgba(var(--accent-rgb),.4)}
.fcta h2:hover .ac{color:#fff}
.fcta p{font-size:21px;color:var(--text-body);margin-bottom:36px;max-width:560px;margin-left:auto;margin-right:auto;line-height:1.45}
.fcta-btns{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;margin-bottom:24px}
.fcta-badges{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
.fcta-badge{font-size:14px;font-weight:600;color:rgba(255,255,255,.6);display:flex;align-items:center;gap:6px;transition:color .2s}
.fcta-badge:hover{color:#fff}
.fcta-badge .ico{width:14px;height:14px;transition:transform .2s}
.fcta-badge:hover .ico{transform:scale(1.2)}

/* FOOTER */
footer{background:rgba(0,0,0,.28);border-top:1px solid rgba(255,255,255,.07);padding:52px 0 28px}
.fti{max-width:1600px;margin:0 auto;padding:0 48px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.flogo{font-family:'Oswald',sans-serif;font-weight:700;font-size:20px;letter-spacing:.08em;text-transform:uppercase;display:block;margin-bottom:12px}
.flogo span{color:var(--accent)}
.fdesc{max-width:280px;font-size:17px;color:var(--text-muted);line-height:1.5}
.fcol h4{font-family:'Oswald',sans-serif;font-size:17px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:14px}
.fcol ul{list-style:none}
.fcol a{font-size:18px;color:rgba(255,255,255,.55);display:block;margin-bottom:7px;transition:color .2s,padding-left .2s;text-decoration:none}
.fcol a:hover{color:#fff;padding-left:4px}
.fbot{max-width:1600px;margin:0 auto;padding:20px 48px 0;border-top:1px solid rgba(255,255,255,.07);display:flex;justify-content:space-between;align-items:center}
.fbot p{font-size:16px;color:var(--text-muted)}
.fbot a{color:var(--text-muted);text-decoration:none;transition:color .2s}
.fbot a:hover{color:var(--accent)}

/* MOBILE CTA BAR */
.mobile-cta-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:1000;background:rgba(20,20,20,.95);border-top:1px solid rgba(var(--blue-rgb),.3);padding:10px 16px;gap:10px}
.mobile-cta-bar a{flex:1;text-align:center;font-size:13px;padding:12px 8px}

/* CONTRACTOR FORM */
.contractor-benefits{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin:32px 0}
.cb-item{background:var(--card-bg);border:1px solid var(--card-border);border-radius:10px;padding:20px;transition:border-color .2s,transform .2s,box-shadow .2s;cursor:default}
.cb-item:hover{border-color:rgba(var(--accent-rgb),.35);transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,.3)}
.cb-item strong{font-family:'Oswald',sans-serif;font-size:17px;font-weight:600;text-transform:uppercase;color:#fff;display:block;margin-bottom:6px;transition:color .2s}
.cb-item:hover strong{color:var(--accent)}
.cb-item span{font-size:17px;color:var(--text-body);line-height:1.4}

/* LEGAL PAGES */
.legal-content{max-width:900px;margin:0 auto;padding:40px 0}
.legal-content h2{font-family:'Oswald',sans-serif;font-size:28px;font-weight:700;text-transform:uppercase;margin:40px 0 16px;color:#fff;transition:color .2s}
.legal-content h2:hover{color:var(--accent)}
.legal-content h3{font-family:'Oswald',sans-serif;font-size:20px;font-weight:600;text-transform:uppercase;margin:24px 0 12px;color:rgba(255,255,255,.85)}
.legal-content p{font-size:17px;color:var(--text-body);line-height:1.6;margin-bottom:16px}
.legal-content ul{margin:12px 0 20px 24px;color:var(--text-body)}
.legal-content li{font-size:17px;line-height:1.6;margin-bottom:8px}
.legal-content a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}

/* RESPONSIVE */
@media(max-width:1100px){
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .city-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:900px){
  .nav{padding:0 20px}
  .nav-links{display:none}
  .hamburger{display:flex}
  .si{padding:0 20px}
  .hero-wrap{grid-template-columns:1fr;gap:32px;padding:0 20px}
  .split-inner{grid-template-columns:1fr;gap:40px}
  .split-inner.reverse{direction:ltr}
  .split-bullets{grid-template-columns:1fr}
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .review-grid{grid-template-columns:1fr}
  .calc-card{grid-template-columns:1fr}
  .calc-row{grid-template-columns:1fr}
  .faqgd{grid-template-columns:1fr}
  .frow{grid-template-columns:1fr}
  .stat-row{flex-direction:column}
  .ind-grid{grid-template-columns:repeat(2,1fr)}
  .contractor-benefits{grid-template-columns:1fr}
  .fti{grid-template-columns:1fr 1fr;gap:16px;padding:0 20px;justify-items:center}
  .fti>div:first-child{grid-column:1/-1;text-align:center;margin-bottom:32px}
  .fti>div:first-child .fdesc{margin:0 auto}
  .fti>div:last-child{grid-column:1/-1;text-align:center;margin-top:16px}
  .binner{overflow-x:auto;gap:0;padding:0 16px}
  .mobile-cta-bar{display:flex;justify-content:center}
  .mobile-cta-bar a{font-size:16px;padding:14px 12px;font-family:'Oswald',sans-serif;font-weight:600;letter-spacing:.06em;text-transform:uppercase;text-align:center;justify-content:center}
  footer{padding-bottom:10px}
  .fbot{padding:12px 20px 0}
  .hero-btns{flex-direction:column}
  .hero-btns .btn,.hero-btns .btn-o{width:100%;justify-content:center}
  .tl-steps{flex-direction:column;align-items:center;gap:40px;padding:0}
  .tl-steps::before{display:none}
  .tl-step{text-align:center;display:flex;flex-direction:column;align-items:center;padding:0}
  .tl-step-circle{margin:0 auto 16px;width:80px;height:80px;font-size:36px}
  .tl-step-text{text-align:center}
  .tl-step-desc{max-width:320px;margin:0 auto}
  .sa-hero{padding:120px 0 60px}
  .sa-hero h1{font-size:clamp(36px,8vw,56px)}
  .prod-hero{padding:110px 0 48px}
  .hero-bg{background-attachment:scroll}
  .fcta-bg{background-attachment:scroll}
  body{padding-bottom:80px}
  .card-sec .stag,.card-sec .stit,.card-sec .ssub{text-align:center}
  .card-sec .ssub{margin-left:auto;margin-right:auto}
  .split-inner>div:last-child{order:-1}
  .step-item{gap:10px}
  .step-num{font-size:32px;width:32px}
}

@media(max-width:600px){
  .fti{grid-template-columns:1fr 1fr}
  .fti>div:first-child{grid-column:1/-1;text-align:center}
  .fti>div:first-child .fdesc{margin:0 auto}
  .fti>div:last-child{grid-column:1/-1;text-align:center}
  .gallery-grid{grid-template-columns:1fr}
  .city-grid{grid-template-columns:repeat(2,1fr)}
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .ind-grid{grid-template-columns:1fr}
  .fbot{flex-direction:column;gap:8px;text-align:center}
  .intent-tabs{grid-template-columns:1fr}
}

/* NOSCRIPT FALLBACK */
noscript .reveal{opacity:1!important;transform:none!important}
