/* ============================================================
   PING PRECISION AUTO GLASS — SHARED STYLESHEET
   style.css · All pages link to this file
   ============================================================ */

/* ============================================================
   SELF-HOSTED FONTS — Barlow Condensed + Barlow
   Files live in /fonts/ relative to public_html root
   ============================================================ */

/* barlow-condensed-300 */
@font-face {
  font-family: 'Barlow Condensed';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('fonts/barlow-condensed-v13-latin-300.woff2') format('woff2');
}
/* barlow-condensed-400 */
@font-face {
  font-family: 'Barlow Condensed';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('fonts/barlow-condensed-v13-latin-regular.woff2') format('woff2');
}
/* barlow-condensed-500 */
@font-face {
  font-family: 'Barlow Condensed';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('fonts/barlow-condensed-v13-latin-500.woff2') format('woff2');
}
/* barlow-condensed-600 */
@font-face {
  font-family: 'Barlow Condensed';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('fonts/barlow-condensed-v13-latin-600.woff2') format('woff2');
}
/* barlow-condensed-700 */
@font-face {
  font-family: 'Barlow Condensed';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('fonts/barlow-condensed-v13-latin-700.woff2') format('woff2');
}
/* barlow-condensed-800 */
@font-face {
  font-family: 'Barlow Condensed';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url('fonts/barlow-condensed-v13-latin-800.woff2') format('woff2');
}
/* barlow-condensed-900 */
@font-face {
  font-family: 'Barlow Condensed';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url('fonts/barlow-condensed-v13-latin-900.woff2') format('woff2');
}
/* barlow-300 */
@font-face {
  font-family: 'Barlow';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('fonts/barlow-v13-latin-300.woff2') format('woff2');
}
/* barlow-400 */
@font-face {
  font-family: 'Barlow';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('fonts/barlow-v13-latin-regular.woff2') format('woff2');
}
/* barlow-500 */
@font-face {
  font-family: 'Barlow';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('fonts/barlow-v13-latin-500.woff2') format('woff2');
}
/* barlow-600 */
@font-face {
  font-family: 'Barlow';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('fonts/barlow-v13-latin-600.woff2') format('woff2');
}
/* barlow-condensed-500italic */
@font-face {
  font-family: 'Barlow Condensed';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url('fonts/barlow-condensed-v13-latin-500italic.woff2') format('woff2');
}
/* barlow-condensed-600italic */
@font-face {
  font-family: 'Barlow Condensed';
  font-style: italic;
  font-weight: 600;
  font-display: swap;
  src: url('fonts/barlow-condensed-v13-latin-600italic.woff2') format('woff2');
}
/* barlow-300italic */
@font-face {
  font-family: 'Barlow';
  font-style: italic;
  font-weight: 300;
  font-display: swap;
  src: url('fonts/barlow-v13-latin-300italic.woff2') format('woff2');
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --red:#C41230;--red-dark:#9B0D24;
  --black:#080808;--b2:#101010;--b3:#181818;--b4:#222222;--b5:#2E2E2E;--b6:#3A3A3A;
  --white:#FFFFFF;--off:#F0EEE9;--gray:#9A9A9A;--gl:#B8B8B8;
  --cond:'Barlow Condensed',sans-serif;--body:'Barlow',sans-serif;
  --ease:0.28s cubic-bezier(0.4,0,0.2,1);
}
html{scroll-behavior:smooth;overflow-x:hidden;touch-action:pan-x pan-y}
body{font-family:var(--body);background:var(--black);color:var(--white);overflow-x:hidden;line-height:1.6}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:200;height:80px;display:flex;align-items:center;background:rgba(8,8,8,0.96);backdrop-filter:blur(16px);border-bottom:1px solid rgba(196,18,48,0.45);transition:border-color var(--ease),background var(--ease)}
nav.scrolled{background:rgba(8,8,8,0.99);border-bottom-color:rgba(196,18,48,0.7)}
.nav-inner{width:100%;max-width:1380px;margin:0 auto;padding:0 4vw;display:flex;align-items:center;justify-content:space-between;gap:2rem}
.logo{text-decoration:none;display:flex;align-items:center;gap:12px}
.logo-img{height:82px;width:auto;display:block}
.logo-text{display:flex;flex-direction:column;line-height:1}
.logo-main{font-family:var(--cond);font-size:20px;font-weight:900;letter-spacing:0.06em;text-transform:uppercase;color:var(--white)}
.logo-main span{color:var(--red)}
.logo-sub{font-family:var(--cond);font-size:9px;font-weight:500;letter-spacing:0.28em;text-transform:uppercase;color:var(--gray);margin-top:1px}
.nav-links{display:flex;list-style:none;align-items:center}
.nav-links a{font-family:var(--cond);font-size:13px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--gl);text-decoration:none;padding:8px 12px;transition:color var(--ease)}
.nav-links a:hover{color:var(--white)}
.nav-links a.active{color:var(--white)}
.nav-book{background:var(--red)!important;color:var(--white)!important;padding:8px 20px!important;margin-left:8px;transition:background var(--ease)!important}
.nav-book:hover{background:var(--red-dark)!important}
.mob-btn{display:none;background:none;border:none;cursor:pointer;color:var(--white);padding:4px}
@media(max-width:860px){.mob-btn{display:flex}.nav-links{display:none}}

/* HERO */
.hero{min-height:100vh;position:relative;display:flex;align-items:flex-end;overflow:hidden}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 38%}
.hero-ov{position:absolute;inset:0;background:linear-gradient(108deg,rgba(8,8,8,0.94) 0%,rgba(8,8,8,0.78) 48%,rgba(8,8,8,0.25) 100%)}
.hero-ov2{position:absolute;bottom:0;left:0;right:0;height:45%;background:linear-gradient(to top,var(--black),transparent)}
.hero-content{position:relative;z-index:2;max-width:1380px;width:100%;margin:0 auto;padding:0 4vw 8vh;display:grid;grid-template-columns:1fr auto;align-items:flex-end;gap:3rem}
@keyframes statHint{0%{transform:translateX(0)}25%{transform:translateX(-18px)}50%{transform:translateX(0)}75%{transform:translateX(-10px)}100%{transform:translateX(0)}}
@media(max-width:900px){
  .hero-content{grid-template-columns:1fr}
}
/* MOBILE HERO TRUST BAR */
.hero-trust-bar{display:none}
@media(max-width:900px){
  .hstats{display:none!important}
  .hero-trust-bar{display:grid;grid-template-columns:1fr 1fr;gap:0.5rem;width:100%;margin:0 0 1.75rem}
  .htb-card{display:inline-flex;align-items:center;gap:7px;font-family:var(--cond);font-size:11px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--white);background:rgba(8,8,8,0.65);border:1px solid rgba(255,255,255,0.15);border-left:3px solid var(--red);padding:8px 12px;line-height:1;white-space:nowrap;overflow:hidden}
  .htb-icon{width:11px;height:11px;color:var(--red);flex-shrink:0}
}
.eyebrow-hero{font-family:var(--cond);font-size:12px;font-weight:600;letter-spacing:0.4em;text-transform:uppercase;color:var(--red);display:flex;align-items:center;gap:12px;margin-bottom:1.25rem}
.eyebrow-hero::before{content:'';width:36px;height:2px;background:var(--red);display:inline-block;flex-shrink:0}
h1{font-family:var(--cond);font-size:clamp(62px,8.5vw,118px);font-weight:900;line-height:0.9;text-transform:uppercase;letter-spacing:-0.01em;margin-bottom:1.5rem}
h1 .r{color:var(--red);display:block}
h1 .s{font-size:clamp(18px,2.2vw,30px);font-weight:500;color:rgba(255,255,255,0.45);letter-spacing:0.18em;display:block;margin-top:0.6rem;font-style:italic}
.hero-sub{font-size:16px;font-weight:300;color:rgba(255,255,255,0.58);max-width:500px;line-height:1.78;margin-bottom:2.5rem}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap}
.btn-red{background:var(--red);color:var(--white);font-family:var(--cond);font-size:15px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;padding:15px 36px;text-decoration:none;border:none;transition:all var(--ease);display:inline-block;cursor:pointer}
.btn-red:hover{background:var(--red-dark);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--white);font-family:var(--cond);font-size:15px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;padding:15px 36px;text-decoration:none;border:2px solid rgba(255,255,255,0.22);transition:border-color var(--ease);display:inline-block}
.btn-ghost:hover{border-color:rgba(255,255,255,0.65)}
.hstats{display:flex;flex-direction:column;gap:0.5rem;min-width:220px}
.hstat{display:flex;align-items:center;gap:10px;padding:10px 14px;background:rgba(8,8,8,0.72);border:1px solid var(--b5);border-left:3px solid var(--red);opacity:0;transform:translateX(18px);transition:opacity 0.45s ease,transform 0.45s ease}

.hstat.stat-in{opacity:1;transform:translateX(0)}
.hstat-icon{width:13px;height:13px;color:var(--red);flex-shrink:0}
.hstat-v{font-family:var(--cond);font-size:13px;font-weight:700;color:var(--white);letter-spacing:0.08em;text-transform:uppercase;line-height:1}
.hstat-l{font-family:var(--cond);font-size:9px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--gray);margin-top:2px}

/* LAYOUT SYSTEM */
.sec{padding:6rem 4vw}
.sec-sm{padding:4rem 4vw}
.inn{max-width:1380px;margin:0 auto}
.eyebrow{font-family:var(--cond);font-size:11px;font-weight:700;letter-spacing:0.4em;text-transform:uppercase;color:var(--red);display:flex;align-items:center;gap:10px;margin-bottom:0.75rem}
.eyebrow::before{content:'';width:22px;height:2px;background:var(--red);display:inline-block;flex-shrink:0}
.h2{font-family:var(--cond);font-size:clamp(38px,5vw,66px);font-weight:900;text-transform:uppercase;line-height:0.93;letter-spacing:-0.01em;color:var(--white)}
.h2 em{color:var(--red);font-style:normal}
.body-t{font-size:15px;font-weight:300;color:var(--gl);line-height:1.8}

/* SERVICES */
.svc-bg{background:var(--b2)}
.svc-hdr{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem;gap:2rem;flex-wrap:wrap}
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--b5)}
@media(max-width:1020px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.svc-grid{grid-template-columns:1fr}}
.sc{background:var(--b2);padding:2.25rem;position:relative;overflow:hidden;transition:background var(--ease);display:flex;flex-direction:column;cursor:pointer}
.sc::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--red);opacity:0;transition:opacity 0.32s ease}
.sc:hover{background:var(--b3)}.sc:hover::after{opacity:0.4}
.sc-n{font-family:var(--cond);font-size:10px;font-weight:700;letter-spacing:0.3em;text-transform:uppercase;color:var(--red);margin-bottom:0.55rem}
.sc-t{font-family:var(--cond);font-size:20px;font-weight:800;text-transform:uppercase;color:var(--white);letter-spacing:0.02em;margin-bottom:0.55rem;line-height:1.1}
.sc-d{font-size:13px;font-weight:300;color:var(--gray);line-height:1.68;flex:1;display:none;margin-top:0.75rem}
.sc-d.open{display:block}
.sc-a{font-family:var(--cond);font-size:11px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--red);margin-top:1.1rem}
.sc-expand{font-family:var(--cond);font-size:11px;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;color:var(--gray);margin-top:1rem;transition:color 0.2s ease;user-select:none}
.sc:hover .sc-expand{color:var(--gl)}
.sc-red{background:var(--red)!important;cursor:default}
.sc-red .sc-n{color:rgba(255,255,255,0.6)}.sc-red .sc-t,.sc-red .sc-d{color:var(--white)}.sc-red .sc-d{color:rgba(255,255,255,0.78)}

/* SERVICES OVERVIEW (home page simplified grid) */
.svc-overview-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--b5)}
@media(max-width:1020px){.svc-overview-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.svc-overview-grid{grid-template-columns:1fr}}
.sov{background:var(--b2);padding:2rem;display:flex;flex-direction:column;transition:background var(--ease);text-decoration:none;position:relative;overflow:hidden}
.sov::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--red);opacity:0;transition:opacity 0.3s ease}
.sov:hover{background:var(--b3)}.sov:hover::after{opacity:1}
.sov-n{font-family:var(--cond);font-size:10px;font-weight:700;letter-spacing:0.3em;text-transform:uppercase;color:var(--red);margin-bottom:0.5rem}
.sov-t{font-family:var(--cond);font-size:19px;font-weight:800;text-transform:uppercase;color:var(--white);letter-spacing:0.02em;line-height:1.1;margin-bottom:0.5rem}
.sov-d{font-size:14px;font-weight:300;color:var(--gray);line-height:1.65;flex:1}
.sov-lnk{font-family:var(--cond);font-size:11px;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;color:var(--red);margin-top:1.2rem}
.sov-cta{background:var(--red)!important}
.sov-cta .sov-n{color:rgba(255,255,255,0.65)}
.sov-cta .sov-t{color:var(--white)}
.sov-cta .sov-lnk{color:rgba(255,255,255,0.8)}

/* CRAFTSMAN / ABOUT */
.craft{position:relative;min-height:60vh;display:flex;align-items:center;overflow:hidden}
.craft-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 60%}
@media(min-width:861px){.craft-img{object-position:50% 35%}}
.craft-ov{position:absolute;inset:0;background:linear-gradient(92deg,rgba(8,8,8,0.97) 0%,rgba(8,8,8,0.92) 50%,rgba(8,8,8,0.55) 100%)}
@media(max-width:860px){.craft-ov{background:rgba(8,8,8,0.82)}}
.craft-c{position:relative;z-index:2;max-width:1380px;width:100%;margin:0 auto;padding:5rem 4vw}
.craft-inner{max-width:580px}
.craft-q{border-left:3px solid var(--red);padding:1rem 1.5rem;background:rgba(196,18,48,0.09);margin:1.5rem 0;font-family:var(--cond);font-size:22px;font-weight:600;font-style:italic;color:var(--white);line-height:1.4}
.craft-p{font-size:15px;font-weight:300;color:var(--gl);line-height:1.8;margin-bottom:0.9rem}

/* GALLERY (static photo grid) */
.gal-grid{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:300px 300px;gap:3px}
@media(max-width:760px){.gal-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:220px 220px 280px;gap:3px}.gi{grid-row:unset!important;grid-column:unset!important}.gi.tall{grid-row:unset!important}.gi img{min-height:unset;max-height:unset;height:100%;width:100%;object-fit:cover}.gi-mob-full{grid-column:1/-1!important}.hide-mobile{display:none!important}}
.gi{overflow:hidden;position:relative;background:var(--b3)}
.gi img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.5s ease}
.gi:hover img{transform:scale(1.04)}
.gi.tall{grid-row:span 2}
.gi-lbl{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(8,8,8,0.88),transparent);padding:1rem 1.25rem;font-family:var(--cond);font-size:11px;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--white);opacity:0;transition:opacity 0.28s ease}
.gi:hover .gi-lbl{opacity:1}

/* BEFORE/AFTER */
.ba-bg{background:var(--b3)}
.ba-layout{display:grid;grid-template-columns:55fr 45fr;gap:3rem;align-items:center}
.ba-text{}
@media(max-width:1024px){.ba-layout{display:block}.ba-text{margin-bottom:1.75rem}}
.ba-handle{position:absolute;top:0;bottom:0;left:65%;width:3px;background:var(--red);transform:translateX(-50%);cursor:col-resize;z-index:10;pointer-events:none;box-shadow:0 0 8px rgba(0,0,0,0.5)}
.ba-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;border-radius:50%;background:var(--red);border:3px solid white;display:flex;align-items:center;justify-content:center;gap:2px;box-shadow:0 2px 12px rgba(0,0,0,0.5);pointer-events:none}
.ba-label-before,.ba-label-after{position:absolute;bottom:14px;font-family:var(--cond);font-size:16px;font-weight:800;letter-spacing:0.22em;color:white;background:rgba(0,0,0,0.72);padding:8px 18px;border-radius:3px;pointer-events:none;z-index:9;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);transition:opacity 0.4s ease}
.ba-label-before{left:14px}
.ba-label-after{right:14px}
.ba-slider{position:relative;width:100%;aspect-ratio:4/3;overflow:hidden;cursor:col-resize;user-select:none;-webkit-user-select:none;touch-action:none;border-top:3px solid var(--red);border-radius:4px;background:#111}
.ba-img-before,.ba-img-after{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center center;pointer-events:none;display:block}
.ba-img-after{clip-path:inset(0 35% 0 0);object-position:center center}
@media(max-width:1024px) and (min-width:481px){.ba-slider{aspect-ratio:4/3;max-width:600px;margin-left:auto;margin-right:auto}}
@media(max-width:480px){.ba-slider{aspect-ratio:4/3;max-width:none;margin-left:0;margin-right:0}}

/* PROCESS */
.proc-bg{background:var(--b2)}
.proc-hdr{text-align:center;max-width:620px;margin:0 auto 4rem}
.ps{background:var(--b2);padding:2.5rem 2rem;text-align:center;position:relative;overflow:hidden}
.ps-n{font-family:var(--cond);font-size:78px;font-weight:900;color:var(--red);opacity:0.28;line-height:1;margin-bottom:0.7rem;transition:opacity 0.6s ease,text-shadow 0.6s ease}
.ps-n.ps-active{opacity:0.7;text-shadow:0 0 40px rgba(196,18,48,0.5)}
.ps-t{font-family:var(--cond);font-size:18px;font-weight:800;text-transform:uppercase;color:var(--white);letter-spacing:0.03em;margin-bottom:0.55rem;line-height:1.1}
.ps-d{font-size:14px;font-weight:300;color:var(--gray);line-height:1.65}

/* PROCESS CONNECTOR LINE — desktop only */
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--b5);position:relative}
.proc-line{display:none}

@media(max-width:860px){.proc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:460px){.proc-grid{grid-template-columns:1fr}}

/* CRAFTSMAN CREDENTIAL CHIPS */
.craft-chips{display:flex;gap:0.5rem;flex-wrap:wrap;margin-top:1.25rem;margin-bottom:1.75rem}
.craft-chip{display:inline-flex;align-items:center;gap:7px;font-family:var(--cond);font-size:11px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--white);background:rgba(8,8,8,0.65);border:1px solid rgba(255,255,255,0.15);border-left:3px solid var(--red);padding:8px 14px;line-height:1;white-space:nowrap}
.craft-chip svg{flex-shrink:0;color:var(--red)}

/* WARRANTY */
.war-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
@media(max-width:800px){.war-grid{grid-template-columns:1fr}}
.wi{display:flex;flex-direction:column;gap:1px;margin-top:2rem}
.witem{background:var(--b3);border-left:3px solid var(--red);padding:0.9rem 1.2rem}
.wt{font-family:var(--cond);font-size:15px;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;color:var(--white);margin-bottom:3px}
.wd{font-size:14px;font-weight:300;color:var(--gray);line-height:1.6}
.excl{background:var(--b2);border:1px solid var(--b5);border-top:2px solid var(--red);padding:2rem}
.excl-t{font-family:var(--cond);font-size:17px;font-weight:800;text-transform:uppercase;letter-spacing:0.06em;color:var(--white);margin-bottom:1rem}
.excl-l{list-style:none;display:flex;flex-direction:column;gap:0.5rem}
.excl-l li{font-size:13px;font-weight:300;color:var(--gray);padding-left:1.2rem;position:relative;line-height:1.5}
.excl-l li::before{content:'—';position:absolute;left:0;color:var(--red);font-weight:600}
.post-box{background:var(--b3);border:1px solid var(--b5);padding:2rem;margin-top:1.5rem}
.post-t{font-family:var(--cond);font-size:15px;font-weight:800;text-transform:uppercase;letter-spacing:0.06em;color:var(--white);margin-bottom:0.75rem}
.post-l{list-style:none;display:flex;flex-direction:column;gap:0.5rem}
.post-l li{font-size:13px;font-weight:300;color:var(--gray);padding-left:1.2rem;position:relative;line-height:1.5}
.post-l li::before{content:'✓';position:absolute;left:0;color:var(--red);font-weight:700}
.war-link{font-family:var(--cond);font-size:12px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--red);background:none;border:none;cursor:pointer;margin-top:1.5rem;display:inline-block;text-decoration:underline;padding:0}

/* PICKUP */
.pu-bg{background:var(--b2)}
.pu-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
@media(max-width:800px){.pu-grid{grid-template-columns:1fr}}
.pu-img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:center;display:block;border-top:3px solid var(--red)}
.pu-feats{display:flex;flex-direction:column;gap:1px;margin-top:2rem}
.pf{background:var(--b3);padding:1.2rem 1.5rem;display:flex;gap:1rem;align-items:flex-start}
.pf-ic{width:36px;height:36px;background:var(--red);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pf-t{font-family:var(--cond);font-size:15px;font-weight:700;text-transform:uppercase;letter-spacing:0.05em;color:var(--white);margin-bottom:3px}
.pf-d{font-size:14px;font-weight:300;color:var(--gray);line-height:1.6}
.ins-badge{background:var(--b4);border-left:3px solid var(--red);padding:1rem 1.5rem;font-family:var(--cond);font-size:14px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--white);margin-top:1rem}

/* PARTNERS */
.part-bg{background:var(--b3)}
.part-row{display:flex;align-items:center;justify-content:center;gap:4rem;flex-wrap:wrap;margin-top:3rem;padding-top:2.5rem;border-top:1px solid var(--b5)}
.part{text-align:center}
.part-box{background:var(--b4);border:1px solid var(--b6);padding:1.2rem 2.5rem;min-width:155px;min-height:68px;display:flex;align-items:center;justify-content:center;margin-bottom:0.5rem}
.part-n{font-family:var(--cond);font-size:19px;font-weight:900;text-transform:uppercase;letter-spacing:0.04em;color:var(--white)}
.part-s{font-family:var(--cond);font-size:10px;font-weight:600;letter-spacing:0.25em;text-transform:uppercase;color:var(--gray)}

/* REVIEWS */
.rev-bg{background:var(--b2)}
.rev-hdr{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem;gap:2rem;flex-wrap:wrap}
.rat-n{font-family:var(--cond);font-size:70px;font-weight:900;color:var(--white);line-height:1}
.stars{display:flex;gap:4px;justify-content:flex-end;margin:4px 0}
.star{width:14px;height:14px;background:var(--red);clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%)}
.rat-src{font-size:11px;letter-spacing:0.15em;text-transform:uppercase;color:var(--gray)}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--b5)}
@media(max-width:860px){.rev-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.rev-grid{grid-template-columns:1fr}}
.rc{background:var(--b2);padding:2rem;position:relative}
@keyframes rcGlow{0%,100%{opacity:0.15;text-shadow:0 0 10px rgba(196,18,48,0)}50%{opacity:0.55;text-shadow:0 0 30px rgba(196,18,48,0.85),0 0 60px rgba(196,18,48,0.4)}}
.rc-mark{font-family:var(--cond);font-size:76px;font-weight:900;color:var(--red);line-height:1;margin-bottom:0.2rem;animation:rcGlow 2.8s ease-in-out infinite}
.rc-stars{display:flex;gap:3px;margin-bottom:0.75rem}
.rstar{width:11px;height:11px;background:var(--red);clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%)}
.rc-text{font-size:14px;font-weight:300;color:var(--gl);line-height:1.75;font-style:italic;margin-bottom:1.2rem}
.rc-name{font-family:var(--cond);font-size:15px;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;color:var(--white)}
.rc-src{font-size:11px;letter-spacing:0.15em;text-transform:uppercase;color:var(--red);margin-top:2px}
.rev-cta-w{text-align:center;margin-top:2.5rem}
.rev-cta{display:inline-flex;align-items:center;gap:8px;background:var(--red);color:var(--white);font-family:var(--cond);font-size:13px;font-weight:800;letter-spacing:0.15em;text-transform:uppercase;text-decoration:none;padding:12px 28px;transition:background var(--ease)}
.rev-cta:hover{background:var(--red-dark)}

/* CTA BAND */
.ctaband{background:var(--red);padding:5rem 4vw}
.cta-inn{max-width:1380px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:3rem;flex-wrap:wrap}
.cta-title{font-family:var(--cond);font-size:clamp(30px,4.5vw,58px);font-weight:900;text-transform:uppercase;line-height:0.93;color:var(--white)}
.cta-sub{font-size:15px;font-weight:300;color:rgba(255,255,255,0.72);margin-top:0.6rem}
.btn-white{background:var(--white);color:var(--red);font-family:var(--cond);font-size:15px;font-weight:800;letter-spacing:0.12em;text-transform:uppercase;padding:15px 36px;text-decoration:none;border:2px solid var(--white);transition:all var(--ease);display:inline-block}
.btn-white:hover{background:transparent;color:var(--white)}
.btn-ow{background:transparent;color:var(--white);font-family:var(--cond);font-size:15px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;padding:15px 36px;text-decoration:none;border:2px solid rgba(255,255,255,0.42);transition:border-color var(--ease);display:inline-block}
.btn-ow:hover{border-color:var(--white)}
.cta-btns{display:flex;gap:1rem;flex-wrap:wrap}

/* CONTACT */
.con-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:5rem;margin-top:4rem;align-items:start}
@media(max-width:900px){.con-grid{grid-template-columns:1fr;gap:3rem}}
.cb{padding:1.7rem 0;border-bottom:1px solid var(--b4);display:flex;gap:1.25rem;align-items:flex-start}
.cb:first-of-type{border-top:1px solid var(--b4)}
.cb-ic{width:42px;height:42px;background:var(--red);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.cb-lbl{font-family:var(--cond);font-size:10px;font-weight:700;letter-spacing:0.3em;text-transform:uppercase;color:var(--red);margin-bottom:4px}
.cb-val{font-family:var(--cond);font-size:20px;font-weight:700;color:var(--white);line-height:1.25;text-decoration:none;letter-spacing:0.02em}
a.cb-val:hover{color:var(--red)}
.cb-note{font-size:12px;font-weight:300;color:var(--gray);margin-top:4px;line-height:1.5}
.hrs{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:0.4rem}
.hrl{font-family:var(--cond);font-size:10px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--gl)}
.hrv{font-size:13px;font-weight:300;color:var(--gray);line-height:1.5}
.area-tags{display:flex;flex-wrap:wrap;gap:0.4rem;margin-top:2rem}
.atag{font-family:var(--cond);font-size:12px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--gl);border:1px solid var(--b5);padding:5px 12px}
.soc-row{display:flex;gap:0.75rem;margin-top:1.5rem;flex-wrap:wrap}
.soc-a{display:inline-flex;align-items:center;gap:6px;font-family:var(--cond);font-size:12px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--white);text-decoration:none;border:1px solid var(--b5);padding:8px 14px;transition:border-color var(--ease),color var(--ease)}
.soc-a:hover{border-color:var(--red);color:var(--red)}

/* QUOTE FORM WIZARD */
.qf-wrap{background:var(--b3);border-top:3px solid var(--red);padding:2.5rem}
.qf-title{font-family:var(--cond);font-size:26px;font-weight:900;text-transform:uppercase;color:var(--white);margin-bottom:0.3rem;letter-spacing:0.02em}
.qf-sub{font-size:13px;font-weight:300;color:var(--gray);margin-bottom:2rem}
.qf-progress-wrap{margin-bottom:2rem}
.qf-progress-label{font-family:var(--cond);font-size:11px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--gray);margin-bottom:0.6rem;display:flex;justify-content:space-between}
.qf-progress-label span{color:var(--red)}
.qf-progress-bar{width:100%;height:3px;background:var(--b5);position:relative}
.qf-progress-fill{height:100%;background:var(--red);transition:width 0.4s ease}
.qf-step{display:none}
.qf-step.active{display:block}
.qf-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
@media(max-width:600px){.qf-grid{grid-template-columns:1fr}}
.qf-field{display:flex;flex-direction:column;gap:6px;margin-bottom:0.75rem}
.qf-field.full{grid-column:1/-1}
.qf-label{font-family:var(--cond);font-size:11px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--gl)}
.qf-input,.qf-select,.qf-textarea{background:var(--b4);border:1px solid var(--b6);border-bottom:2px solid var(--b6);color:var(--white);font-family:var(--body);font-size:14px;font-weight:300;padding:12px 14px;width:100%;outline:none;transition:border-color 0.22s ease;-webkit-appearance:none;border-radius:0}
.qf-input:focus,.qf-select:focus,.qf-textarea:focus{border-color:var(--red);border-bottom-color:var(--red)}
.qf-input::placeholder{color:var(--b6)}
.qf-select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23aaa' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.qf-select option{background:var(--b4);color:var(--white)}
.qf-textarea{resize:vertical;min-height:100px}
.qf-warning{display:none;background:rgba(196,18,48,0.1);border-left:3px solid var(--red);padding:0.75rem 1rem;font-size:12px;color:var(--gl);line-height:1.6;margin-top:0.5rem}
.qf-warning.show{display:block}
.qf-hint{display:none;background:var(--b4);border-left:3px solid var(--b6);padding:0.75rem 1rem;font-size:12px;color:var(--gray);line-height:1.6;margin-top:0.75rem}
.qf-hint.show{display:block}
.qf-hint a{color:var(--red)}
.qf-check-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0.5rem;margin-top:0.5rem}
@media(max-width:600px){.qf-check-grid{grid-template-columns:1fr}}
.qf-check{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:300;color:var(--gl);cursor:pointer;padding:10px 12px;background:var(--b4);border:1px solid var(--b6);transition:border-color 0.2s ease,background 0.2s ease}
.qf-check:hover{border-color:var(--red)}
.qf-check input[type="checkbox"]{width:16px;height:16px;accent-color:var(--red);cursor:pointer;flex-shrink:0}
.qf-check:has(input:checked){border-color:var(--red);background:rgba(196,18,48,0.08);color:var(--white)}
.qf-conditional{display:none;margin-top:0.75rem}
.qf-conditional.show{display:block}
.qf-nav{display:flex;gap:1rem;margin-top:1.5rem;flex-wrap:wrap}
.qf-btn-next{background:var(--red);color:var(--white);font-family:var(--cond);font-size:14px;font-weight:800;letter-spacing:0.12em;text-transform:uppercase;padding:14px 32px;border:none;cursor:pointer;transition:background 0.22s ease;flex:1}
.qf-btn-next:hover{background:var(--red-dark)}
.qf-btn-next:disabled{opacity:0.6;cursor:not-allowed}
.qf-btn-back{background:transparent;color:var(--gl);font-family:var(--cond);font-size:14px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;padding:14px 24px;border:1px solid var(--b5);cursor:pointer;transition:border-color 0.22s ease,color 0.22s ease}
.qf-btn-back:hover{border-color:var(--gl);color:var(--white)}
.qf-review-section{margin-bottom:1.25rem;padding-bottom:1.25rem;border-bottom:1px solid var(--b5)}
.qf-review-section:last-child{border-bottom:none}
.qf-review-label{font-family:var(--cond);font-size:10px;font-weight:700;letter-spacing:0.25em;text-transform:uppercase;color:var(--red);margin-bottom:0.5rem;display:flex;justify-content:space-between;align-items:center}
.qf-review-edit{font-size:10px;color:var(--gray);cursor:pointer;text-decoration:underline;text-transform:none;letter-spacing:0;font-weight:400}
.qf-review-edit:hover{color:var(--white)}
.qf-review-val{font-size:13px;color:var(--gl);line-height:1.7}
.qf-success{display:none;background:var(--b4);border-left:3px solid var(--red);padding:2rem;text-align:center}
.qf-success.show{display:block}
.qf-s-title{font-family:var(--cond);font-size:22px;font-weight:900;text-transform:uppercase;color:var(--white);margin-bottom:0.5rem}
.qf-s-sub{font-size:13px;color:var(--gray);line-height:1.7}
.qf-note{font-size:11px;color:var(--gray);margin-top:0.75rem;line-height:1.6}
@keyframes qfShake{0%,100%{transform:translateX(0)}20%{transform:translateX(-6px)}40%{transform:translateX(6px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}
.qf-shake{animation:qfShake 0.4s ease;border-color:var(--red)!important;border-bottom-color:var(--red)!important}
.qf-field-error .qf-label{color:var(--red)}

/* MAP */
.map-bg{background:var(--b2)}
.map-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
@media(max-width:800px){.map-grid{grid-template-columns:1fr}}
.map-frame-wrap{width:100%;position:relative;border-top:3px solid var(--red)}
.map-frame-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:none;filter:grayscale(30%) contrast(1.05)}
@media(min-width:801px){.map-frame-wrap{height:100%;min-height:420px}}
@media(max-width:800px){.map-frame-wrap{padding-bottom:100%}}
.map-addr{font-family:var(--cond);font-size:24px;font-weight:700;color:var(--white);line-height:1.2;margin:1.5rem 0 1rem}
.appt-b{background:var(--red);display:inline-block;font-family:var(--cond);font-size:12px;font-weight:800;letter-spacing:0.22em;text-transform:uppercase;color:var(--white);padding:7px 16px;margin-bottom:1rem}
.map-note{font-size:14px;font-weight:300;color:var(--gray);line-height:1.65}

/* FOOTER */
footer{background:var(--black);border-top:2px solid var(--red);padding:4rem 4vw 2rem}
.fi{max-width:1380px;margin:0 auto}
.ft{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid var(--b4)}
@media(max-width:900px){.ft{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.ft{grid-template-columns:1fr}}
.f-logo{height:52px;width:auto;display:block;margin-bottom:0.6rem}
.f-tagline{font-family:var(--cond);font-size:11px;font-weight:600;letter-spacing:0.3em;text-transform:uppercase;color:var(--red);margin-bottom:1rem}
.f-desc{font-size:14px;font-weight:300;color:var(--gray);line-height:1.7;max-width:280px}
.fcol-t{font-family:var(--cond);font-size:10px;font-weight:700;letter-spacing:0.3em;text-transform:uppercase;color:var(--red);margin-bottom:1.2rem;padding-bottom:0.5rem;border-bottom:1px solid var(--b4)}
.fcol a,.fcol p{display:block;font-size:13px;font-weight:300;color:var(--gray);text-decoration:none;margin-bottom:0.5rem;transition:color var(--ease);line-height:1.5}
.fcol a:hover{color:var(--white)}
.fb{padding-top:2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.f-copy{font-size:12px;color:var(--b6)}
.f-war{font-family:var(--cond);font-size:11px;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--red);display:flex;align-items:center;gap:6px}
.tlink{color:var(--red);text-decoration:underline;cursor:pointer;background:none;border:none;font-family:inherit;font-size:inherit;font-weight:inherit;padding:0}

/* MODALS */
.modal{position:fixed;inset:0;background:rgba(0,0,0,0.9);z-index:500;display:none;align-items:center;justify-content:center;padding:2rem}
.modal.open{display:flex}
.mbox{background:var(--b2);border-top:3px solid var(--red);max-width:680px;width:100%;max-height:82vh;overflow-y:auto;padding:2.5rem;position:relative}
.mclose{position:absolute;top:1rem;right:1rem;background:none;border:1px solid var(--b5);color:var(--gray);font-size:18px;cursor:pointer;padding:4px 10px;transition:border-color var(--ease)}
.mclose:hover{border-color:var(--red);color:var(--white)}
.mtitle{font-family:var(--cond);font-size:26px;font-weight:900;text-transform:uppercase;color:var(--white);margin-bottom:1.5rem;letter-spacing:0.03em}
.msec{margin-bottom:1.5rem}
.msect{font-family:var(--cond);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--red);margin-bottom:0.5rem}
.mbody{font-size:13px;font-weight:300;color:var(--gray);line-height:1.7}
.mbody p{margin-bottom:0.75rem}

/* WORK GALLERY LIVE */
.wg-bg{background:var(--b2)}
.wg-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px;margin-top:3rem}
@media(max-width:860px){.wg-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.wg-grid{grid-template-columns:repeat(2,1fr)}}
.wg-slot{position:relative;aspect-ratio:1;overflow:hidden;background:var(--b3);cursor:pointer}
.wg-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 2.5s ease}
.wg-img.visible{opacity:1}
.wg-overlay{position:absolute;inset:0;background:rgba(8,8,8,0);transition:background 0.3s ease;display:flex;align-items:center;justify-content:center;z-index:2}
.wg-slot:hover .wg-overlay{background:rgba(8,8,8,0.4)}
.wg-icon{opacity:0;transition:opacity 0.3s ease;color:#fff}
.wg-slot:hover .wg-icon{opacity:1}
.wg-lb{position:fixed;inset:0;background:rgba(0,0,0,0.95);z-index:600;display:none;align-items:center;justify-content:center}
.wg-lb.open{display:flex}
.wg-lb-inner{position:relative;max-width:90vw;max-height:90vh;display:flex;align-items:center;justify-content:center}
.wg-lb-img{max-width:90vw;max-height:85vh;object-fit:contain;display:block}
.wg-lb-close{position:fixed;top:1.5rem;right:1.5rem;background:var(--red);border:none;color:#fff;font-size:20px;width:42px;height:42px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;border-radius:0}
.wg-lb-prev,.wg-lb-next{position:fixed;top:50%;transform:translateY(-50%);background:rgba(196,18,48,0.85);border:none;color:#fff;font-size:22px;width:48px;height:64px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:background 0.2s ease}
.wg-lb-prev{left:1rem}.wg-lb-next{right:1rem}
.wg-lb-prev:hover,.wg-lb-next:hover{background:var(--red)}
.wg-lb-counter{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);font-family:var(--cond);font-size:12px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.5)}
.wg-empty{text-align:center;padding:4rem 2rem;color:var(--gray);font-size:14px;grid-column:1/-1}

/* INSURANCE FAQ ITEMS */
.ins-faq-item{padding:1rem 0 1rem 1rem;border-left:2px solid rgba(196,18,48,0.2);transition:border-color var(--ease),background var(--ease),padding-left var(--ease);border-radius:0 2px 2px 0;margin-left:-1px}
.ins-faq-item:hover{border-left-color:var(--red);background:rgba(196,18,48,0.04);padding-left:1.35rem}
.ins-btn-row{display:flex;gap:0.85rem;margin-top:2rem;flex-wrap:wrap;align-items:center}
.btn-ins-faq{background:transparent;color:var(--gl);font-family:var(--cond);font-size:13px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;padding:12px 22px;text-decoration:none;border:1px solid var(--b6);transition:border-color var(--ease),color var(--ease);cursor:pointer;display:inline-flex;align-items:center;gap:8px}
.btn-ins-faq:hover{border-color:rgba(255,255,255,0.45);color:var(--white)}
.btn-ins-quote{background:var(--red);color:var(--white);font-family:var(--cond);font-size:13px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;padding:12px 22px;text-decoration:none;border:none;transition:background var(--ease);cursor:pointer;display:inline-flex;align-items:center;gap:8px}
.btn-ins-quote:hover{background:var(--red-dark)}

/* INSURANCE SECTION */
@media(max-width:860px){.ins-grid{grid-template-columns:1fr !important;gap:3rem !important}}

/* TICKER */
.ticker-wrap{overflow:hidden;width:100%;background:var(--red);padding:13px 0;isolation:isolate}
.ticker-t{display:flex;white-space:nowrap;will-change:transform;backface-visibility:hidden;-webkit-backface-visibility:hidden;animation:ticker-scroll 45s linear infinite}
.ticker-item{font-family:var(--cond);font-size:13px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--white);padding:0 2.5rem;flex-shrink:0}
@keyframes ticker-scroll{0%{transform:translate3d(0,0,0)}100%{transform:translate3d(calc(var(--ticker-width,-50%) * -1),0,0)}}
@media(max-width:860px){.ticker-t{animation-duration:28s}}

/* ANIMATIONS */
.fu{opacity:0;transform:translateY(20px);transition:opacity 0.52s ease,transform 0.52s ease}
.fu.in{opacity:1;transform:translateY(0)}
.fl{opacity:0;transform:translateX(-22px);transition:opacity 0.55s ease,transform 0.55s ease}
.fl.in{opacity:1;transform:translateX(0)}
.fs{opacity:0;transform:scale(0.94);transition:opacity 0.5s ease,transform 0.5s ease}
.fs.in{opacity:1;transform:scale(1)}

/* MOBILE OVERRIDES */
@media(max-width:600px){
  .sec{padding:4rem 1.25rem}.sec-sm{padding:3rem 1.25rem}
  .ctaband{padding:3.5rem 1.25rem}
  .hero{min-height:100svh}
  .hero-content{padding:90px 1.25rem 5vh}
  .craft-c{padding:4rem 1.25rem}
  .rc{padding:1.5rem}
  .sov{padding:1.5rem}
  .ps{padding:1.75rem 1.25rem}
}
@media(max-width:860px){
  .ticker-t{animation-duration:22s}
  .svc-grid,.war-grid,.proc-grid,.pu-grid,.con-grid,.map-grid,.rev-grid{overflow:hidden;max-width:100%}
  iframe{max-width:100%}
  .logo-img{height:56px;width:auto}
  nav{height:76px}
  #partners .inn > div[style*="grid-template-columns:repeat(4"]{grid-template-columns:repeat(2,1fr)!important}
  #social .inn > div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr !important;gap:2rem !important}
}
@media(max-width:520px){
  #partners .inn > div[style*="grid-template-columns:repeat(4"]{grid-template-columns:1fr!important}
}
@media(max-width:600px) and (max-height:700px){
  .hero-content{padding-bottom:2vh}
  .eyebrow-hero{margin-bottom:0.75rem}
  h1{margin-bottom:1rem}
  .hero-sub{margin-bottom:1.75rem}
}
