:root{
  --bg: #ffffff;
  --ink: #0a0a0a;
  --ink-2: #6b6b6b;
  --line: #e5e5e5;
  --accent: #d8042a;
  --max: 1440px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{
  background:var(--bg);color:var(--ink);
  font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  -webkit-font-smoothing:antialiased;
  transition:background-color 1.2s cubic-bezier(.4,0,.5,1), color 1.2s cubic-bezier(.4,0,.5,1);
  overflow-x:hidden;
}
img,iframe,video{max-width:100%}
body.is-dark{background:#0a0a0a;color:#fff}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* ── Top bar (fixed, light translucent) ─────────────── */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  padding:14px 48px;color:var(--ink);
  background:rgba(255,255,255,.78);
  backdrop-filter:saturate(160%) blur(18px);
  -webkit-backdrop-filter:saturate(160%) blur(18px);
  border-bottom:1px solid rgba(0,0,0,.06);
}
.top-left{display:flex;align-items:center;justify-self:start}
.logo{justify-self:center;display:block;line-height:0}
.logo img{height:26px;width:auto;display:block}
.top-right{display:flex;align-items:center;gap:24px;font-size:14px;justify-self:end}
.phone{color:var(--ink-2)}

/* Menu trigger */
.menu-btn{
  display:inline-flex;align-items:center;gap:12px;
  background:transparent;border:0;color:inherit;cursor:pointer;
  font:inherit;font-size:13px;letter-spacing:.08em;
  text-transform:uppercase;font-weight:500;padding:6px 0;
}
.menu-btn__lines{display:flex;flex-direction:column;gap:5px}
.menu-btn__lines span{display:block;width:22px;height:1.5px;background:currentColor}

/* Full overlay menu (dark) */
.menu-overlay{
  position:fixed;inset:0;background:#0a0a0a;color:#fff;z-index:100;
  padding:32px 48px;
  display:flex;flex-direction:column;
  opacity:0;visibility:hidden;
  transition:opacity .35s ease, visibility .35s;
}
.menu-overlay.is-open{opacity:1;visibility:visible}
.menu-overlay__bar{display:flex;justify-content:space-between;align-items:center}
.menu-overlay__logo{display:inline-block;line-height:0}
.menu-overlay__logo .brand-mask{
  display:block;width:120px;height:52px;
  background:linear-gradient(to bottom, #fff 0%, #fff 55%, var(--accent) 55%, var(--accent) 100%);
  -webkit-mask:url(logo-stack.png) center/contain no-repeat;
  mask:url(logo-stack.png) center/contain no-repeat;
}
.menu-overlay__close{
  background:transparent;border:0;color:#fff;cursor:pointer;
  font:inherit;font-size:13px;letter-spacing:.08em;
  text-transform:uppercase;font-weight:500;padding:6px 0;
}
.menu-overlay nav{
  flex:1;display:flex;flex-direction:column;justify-content:center;
  gap:8px;max-width:var(--max);margin:0 auto;width:100%;
}
.menu-overlay nav a{
  display:inline-block;align-self:flex-start;
  font-size:clamp(40px,7vw,96px);font-weight:300;line-height:1.05;
  letter-spacing:-.02em;color:#fff;padding:8px 0;
  transition:opacity .2s, transform .25s, color .2s;
}
.menu-overlay nav a:hover{opacity:.8;transform:translateX(6px);color:var(--accent)}
.menu-overlay__foot{
  display:flex;justify-content:space-between;align-items:center;
  color:#9a9a9a;font-size:13px;letter-spacing:.04em;flex-wrap:wrap;gap:16px;
  padding-top:24px;border-top:1px solid rgba(255,255,255,.1);
}
.menu-overlay__foot a{color:#9a9a9a;transition:color .2s}
.menu-overlay__foot a:hover{color:#fff}

.btn{
  display:inline-block;padding:12px 22px;border:1px solid currentColor;
  font-size:13px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;
  transition:background .2s,color .2s;cursor:pointer;background:transparent;color:inherit;
}
.btn--light{color:#fff;border-color:#fff}
.btn--light:hover{background:#fff;color:#0a0a0a}
.btn--dark{color:#0a0a0a;border-color:#0a0a0a}
.btn--dark:hover{background:#0a0a0a;color:#fff}
.btn--solid{background:#0a0a0a;color:#fff;border-color:#0a0a0a}
.btn--solid:hover{background:transparent;color:#0a0a0a}

/* ── Hero (home) ──────────────────────────────────────── */
.hero{
  position:relative;height:100vh;min-height:720px;width:100%;overflow:hidden;
  background:#0a0a0a url('/media/hero-poster.jpg') center/cover no-repeat;
  color:#fff;display:flex;flex-direction:column;justify-content:flex-end;
  padding:0 48px 80px;
}
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero::after{
  content:'';position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,0) 35%,rgba(0,0,0,.55) 100%);
}
.hero__inner{position:relative;z-index:2}
@media (prefers-reduced-motion: reduce){ .hero__video{display:none} }

/* Form submission status + honeypot */
.form-status{margin-top:14px;font-size:14px;font-weight:500;line-height:1.45;min-height:1.1em}
.form-status.is-ok{color:#1a7f37}
.form-status.is-err{color:var(--accent)}
.form-hp{position:absolute!important;left:-9999px!important;height:0;overflow:hidden}
.hero__eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;opacity:.85;margin-bottom:24px}
.hero__title{font-size:clamp(56px,8vw,128px);font-weight:300;line-height:.95;letter-spacing:-.02em;max-width:14ch;margin-bottom:28px}
.hero__sub{font-size:18px;font-weight:300;line-height:1.5;max-width:46ch;opacity:.9;margin-bottom:40px}
.hero__cta{display:flex;gap:16px;flex-wrap:wrap}
.hero__rating{display:inline-flex;align-items:center;gap:14px;margin-top:32px;color:#fff;font-size:14px;text-decoration:none}
.hero__stars{display:inline-flex;gap:2px;color:#ffb400;font-size:18px;letter-spacing:.04em}
.hero__rating-score{font-size:15px;font-weight:500;color:#fff}
.hero__rating-meta{padding-left:14px;border-left:1px solid rgba(255,255,255,.22);font-size:13px;color:rgba(255,255,255,.75);letter-spacing:.01em}
.hero__rating:hover .hero__rating-meta{color:#fff}

/* ── Page hero (subpages) ─────────────────────────────── */
.page-hero{
  padding:160px 48px 72px;border-bottom:1px solid var(--line);
}
.page-hero__inner{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:end;
}
.page-hero__eyebrow{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-2);font-weight:500;margin-bottom:18px;
}
.page-hero__title{
  font-size:clamp(48px,7vw,112px);font-weight:300;line-height:1.0;letter-spacing:-.02em;color:var(--ink);
}
.page-hero__sub{font-size:17px;line-height:1.6;color:var(--ink-2);font-weight:300;max-width:46ch}

/* ── Brand banner strip (dark island) ───────────────── */
.banner{padding:30px 0;background:#0a0a0a;color:#fff;overflow:hidden}
.banner__viewport{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
/* iOS-safe strip: white-space:nowrap + inline-block can't wrap/stack the way
   a max-content flex row does on Safari. min-width guards the loop math. */
.banner__track{white-space:nowrap;width:-webkit-max-content;width:max-content;min-width:-webkit-max-content;min-width:max-content;will-change:transform;animation:logoScroll 36s linear infinite}
@media (hover:hover){ .banner:hover .banner__track{animation-play-state:paused} }
@keyframes logoScroll{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
.banner__inner{max-width:var(--max);margin:0 auto;display:flex;align-items:center;justify-content:center;gap:56px;flex-wrap:wrap}
.banner__label{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.55);font-weight:500;padding-right:28px;border-right:1px solid rgba(255,255,255,.15)}
.banner__track img{display:inline-block;vertical-align:middle;margin:0 32px;width:auto;object-fit:contain;opacity:.8;filter:brightness(0) invert(1);transition:opacity .25s}
.banner__track img:hover{opacity:1}
/* optically balanced so each logo reads the same visual size */
.banner__track img.logo--ceramicpro{height:26px}
.banner__track img.logo--suntek{height:28px}
.banner__track img.logo--stek{height:26px}
.banner__track img.logo--3m{height:40px}
.banner__track img.logo--avery{height:33px}
.banner__track img.logo--carfax{height:34px;filter:none}
@media (prefers-reduced-motion:reduce){
  .banner__viewport{-webkit-mask-image:none;mask-image:none}
  .banner__track{animation:none;white-space:normal;text-align:center;width:auto;min-width:0;max-width:var(--max);margin:0 auto;padding:0 24px}
  .banner__track img{margin:12px 24px}
  .banner__track img.dupe{display:none}
}

/* ── Journey (dark) section ─────────────────────────── */
.journey{background:transparent;color:#fff;padding:140px 48px 56px}
.journey__inner{max-width:var(--max);margin:0 auto}
.journey__head{margin-bottom:48px}
.journey__eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 16px 8px 14px;border-radius:999px;
  background:rgba(216,4,42,.12);border:1px solid rgba(216,4,42,.45);
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:#ff4d6a;font-weight:600;margin-bottom:24px;
}
.journey__eyebrow::before{
  content:'';display:inline-block;width:7px;height:7px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 0 4px rgba(216,4,42,.18);
}
.journey__title{font-size:clamp(28px,4.6vw,72px);font-weight:300;line-height:1.0;letter-spacing:-.02em;white-space:nowrap}
.journey__lead{font-size:17px;line-height:1.6;color:#bdbdbd;font-weight:300;max-width:60ch;margin-top:24px}
.jrows{display:flex;flex-direction:column;gap:30px;margin-top:24px}
.jrow{display:flex;gap:30px;height:clamp(420px, 46vw, 680px)}
.tile{
  position:relative;flex:1 1 0;min-width:0;height:100%;
  border-radius:32px;overflow:hidden;background:#111;
  isolation:isolate;cursor:pointer;
  transition:flex-grow .6s cubic-bezier(0,0,.2,1);
}
.tile:hover{flex-grow:1.25}
.tile__media{position:absolute;inset:0;background:#1a1a1a center/cover no-repeat;transition:transform .8s cubic-bezier(.2,.7,.2,1);z-index:0}
.tile:hover .tile__media{transform:scale(1.04)}
.tile__gradient{position:absolute;left:0;right:0;bottom:0;height:65%;background:linear-gradient(180deg,rgba(0,0,0,0) 0%,rgba(0,0,0,.55) 55%,rgba(0,0,0,.9) 100%);z-index:1;pointer-events:none}
.tile__overlay{position:absolute;inset:0;z-index:3;text-indent:-9999px;overflow:hidden}
.tile__content{pointer-events:none}
.tile__cta{pointer-events:auto}
.tile__cta a{position:relative;z-index:4}
.tile__signature{position:absolute;top:28px;left:28px;z-index:2;font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;color:#fff;opacity:.85}
.tile__content{position:absolute;left:32px;right:32px;bottom:30px;z-index:2;color:#fff}
.tile__title{font-size:clamp(28px,2.6vw,40px);font-weight:300;line-height:1.05;letter-spacing:-.015em;margin-bottom:8px}
.tile__desc{font-size:14px;line-height:1.5;color:#d4d4d4;font-weight:300;margin-bottom:10px;max-width:42ch}
.tile__price{font-size:13px;color:#fff;margin-bottom:22px;font-weight:400}
.tile__price strong{font-weight:500}
.tile__cta{display:flex;gap:18px;flex-wrap:wrap;align-items:center}
.tile__cta a{font-size:12px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:#fff;border-bottom:1px solid #fff;padding-bottom:3px;transition:opacity .2s}
.tile__cta a.is-ghost{color:#cfcfcf;border-bottom-color:rgba(255,255,255,.35)}
.tile__cta a:hover{opacity:.7}
.tile__cta a.is-ghost:hover{color:#fff;border-bottom-color:#fff}
.price-note{color:#6b6b6b;font-size:11px;margin-top:24px;letter-spacing:.02em}

/* ── Why Ultra Autoworks ────────────────────────────── */
.why{background:transparent;color:var(--ink);padding:80px 48px 64px}
.why__inner{max-width:var(--max);margin:0 auto}
.why__head{display:grid;grid-template-columns:1fr 1fr;gap:64px;margin-bottom:80px;align-items:end}
.why__eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);font-weight:500;margin-bottom:20px}
.why__title{font-size:clamp(36px,5vw,72px);font-weight:300;line-height:1.0;letter-spacing:-.02em}
.why__lead{font-size:17px;line-height:1.6;color:var(--ink-2);font-weight:300;max-width:46ch}
.why__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line);padding-top:56px}
.why__grid > article{padding:0 32px;border-left:1px solid var(--line);transition:transform .35s cubic-bezier(.2,.7,.2,1)}
.why__grid > article:first-child{border-left:0;padding-left:0}
.why__grid > article:last-child{padding-right:0}
.why__grid > article:hover{transform:translateY(-4px)}
.why__num{font-size:clamp(56px,6vw,88px);font-weight:300;color:#d8d8d8;letter-spacing:-.03em;line-height:1;margin-bottom:28px;font-variant-numeric:tabular-nums;transition:color .35s}
.why__grid > article:hover .why__num{color:var(--accent)}
.why__item-title{font-size:22px;font-weight:500;letter-spacing:-.005em;line-height:1.2;margin-bottom:14px;color:var(--ink)}
.why__item-desc{font-size:14px;line-height:1.55;color:var(--ink-2);font-weight:400}

.why__quote-link{display:block;text-decoration:none;color:inherit}
.why__quote{margin-top:64px;padding-top:48px;border-top:1px solid var(--line);display:grid;grid-template-columns:auto 1fr;gap:40px;align-items:start}
.why__quote-arrow{display:inline-block;transition:transform .25s}
.why__quote-meta{transition:color .25s}
.why__quote-meta::before{transition:background .25s}
.why__quote-link:hover .why__quote-meta{color:var(--accent)}
.why__quote-link:hover .why__quote-meta::before{background:var(--accent)}
.why__quote-link:hover .why__quote-arrow{transform:translate(3px,-3px)}
.why__quote-mark{font-size:140px;line-height:.7;font-weight:300;color:var(--accent);font-family:Georgia,'Times New Roman',serif}
.why__quote-body{max-width:64ch}
.why__quote-text{font-size:clamp(22px,2.4vw,30px);font-weight:300;line-height:1.35;letter-spacing:-.01em;color:var(--ink)}
.why__quote-meta{display:flex;align-items:center;gap:14px;margin-top:24px;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2);font-weight:500}
.why__quote-meta::before{content:'';display:inline-block;width:32px;height:1px;background:var(--ink-2)}
.why__quote-stars{color:#ffb400;font-size:14px;letter-spacing:.05em}

/* ── Find Us section ───────────────────────────────── */
.find{background:transparent;color:var(--ink);padding:80px 48px 120px}
.find__inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.find__eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);font-weight:500;margin-bottom:20px}
.find__title{font-size:clamp(36px,5vw,72px);font-weight:300;line-height:1.0;letter-spacing:-.02em;margin-bottom:24px}
.find__desc{font-size:16px;line-height:1.6;color:var(--ink-2);font-weight:300;max-width:42ch;margin-bottom:36px}
.find__meta{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;padding-top:32px;border-top:1px solid var(--line)}
.find__col{display:flex;flex-direction:column;gap:24px}
.find__meta h5{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);font-weight:500;margin-bottom:8px}
.find__meta p, .find__meta a{font-size:15px;line-height:1.5;color:var(--ink);font-weight:400}
.find__meta a:hover{opacity:.6}
.find__dir{display:inline-block;margin-top:10px;font-size:13px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;border-bottom:1px solid var(--ink);padding-bottom:3px}
.hours{display:flex;flex-direction:column;gap:6px}
.hours li{display:flex;justify-content:space-between;align-items:baseline;font-size:15px;color:var(--ink);font-weight:400;list-style:none;padding:4px 0;border-bottom:1px solid var(--line)}
.hours li:last-child{border-bottom:0}
.hours li.is-today{color:var(--ink);font-weight:500}
.hours .day{color:var(--ink-2);font-weight:500;letter-spacing:.04em;text-transform:uppercase;font-size:12px;min-width:54px}
.hours li.is-today .day{color:var(--ink)}
.hours .time{font-variant-numeric:tabular-nums}
.hours .closed{color:var(--ink-2);font-style:normal}
.find__media{position:relative;aspect-ratio:4/3;background:#eee;overflow:hidden;border-radius:4px}
.find__media iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:saturate(.9)}

/* ── Footer ─────────────────────────────────────────── */
.footer{background:#0a0a0a;color:#9a9a9a;padding:48px 48px 36px;border-top:1px solid #1a1a1a}
.footer__inner{max-width:var(--max);margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap}
.footer__brand{line-height:0}
.footer__brand img{height:22px;width:auto;filter:brightness(0) invert(1);opacity:.9}
.footer__copy{font-size:12px;color:#6b6b6b;letter-spacing:.02em}
.footer__socials{display:flex;gap:20px}
.footer__socials a{font-size:12px;color:#9a9a9a;letter-spacing:.04em;transition:color .2s}
.footer__socials a:hover{color:#fff}

/* ─────────────────────────────────────────────────────── */
/* GALLERY page                                             */
/* ─────────────────────────────────────────────────────── */
.gallery{padding:64px 48px 120px;max-width:var(--max);margin:0 auto}
.gallery__filters{display:flex;gap:8px;margin-bottom:40px;flex-wrap:wrap}
.gallery__chip{
  padding:9px 18px;border:1px solid var(--line);border-radius:999px;
  font-size:13px;background:transparent;cursor:pointer;color:var(--ink-2);
  font:inherit;letter-spacing:.02em;
  transition:background .2s, color .2s, border-color .2s;
}
.gallery__chip:hover{border-color:var(--ink);color:var(--ink)}
.gallery__chip.is-active{background:var(--ink);color:#fff;border-color:var(--ink)}
.gallery__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;grid-auto-flow:dense}
.gallery__item{
  position:relative;aspect-ratio:1/1;background:#eee center/cover no-repeat;
  overflow:hidden;cursor:pointer;border-radius:6px;
}
.gallery__item--wide{grid-column:span 2}
.gallery__item--tall{grid-row:span 2;aspect-ratio:1/2}
.gallery__item::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 60%,rgba(0,0,0,.55) 100%);opacity:0;transition:opacity .35s;z-index:1}
.gallery__item:hover::after{opacity:1}
.gallery__item-media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;background:#1a1a1a;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.gallery__item:hover .gallery__item-media{transform:scale(1.05)}
.gallery__caption{position:absolute;left:20px;bottom:18px;color:#fff;font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;opacity:0;transform:translateY(8px);transition:opacity .35s, transform .35s;z-index:2}
.gallery__item:hover .gallery__caption{opacity:1;transform:translateY(0)}
.gallery__item.is-hidden{display:none}

/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;background:rgba(8,8,8,.93);padding:24px}
.lightbox.is-open{display:flex}
.lightbox__stage{margin:0;max-width:92vw;display:flex;flex-direction:column;align-items:center;gap:16px}
.lightbox__img{max-width:92vw;max-height:80vh;object-fit:contain;border-radius:4px;box-shadow:0 24px 70px rgba(0,0,0,.55);background:#1a1a1a}
.lightbox__caption{color:#fff;font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;text-align:center}
.lightbox__btn{position:absolute;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.28);color:#fff;cursor:pointer;border-radius:50%;width:48px;height:48px;font-size:26px;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s}
.lightbox__btn:hover{background:rgba(255,255,255,.2);border-color:#fff}
.lightbox__close{top:20px;right:20px;font-size:30px}
.lightbox__prev{left:20px;top:50%;transform:translateY(-50%)}
.lightbox__next{right:20px;top:50%;transform:translateY(-50%)}
@media (max-width:700px){
  .lightbox__img{max-height:72vh}
  .lightbox__btn{width:40px;height:40px;font-size:22px}
  .lightbox__prev{left:8px}
  .lightbox__next{right:8px}
  .lightbox__close{top:10px;right:10px}
}

/* Featured work / gallery teaser (homepage) */
.work{background:transparent;color:var(--ink);padding:56px 48px 120px;max-width:var(--max);margin:0 auto}
.work__head{display:flex;justify-content:space-between;align-items:flex-end;gap:48px;margin-bottom:44px;flex-wrap:wrap}
.work__eyebrow{display:inline-flex;align-items:center;gap:10px;padding:8px 16px 8px 14px;border-radius:999px;background:rgba(216,4,42,.1);border:1px solid rgba(216,4,42,.4);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:20px}
.work__eyebrow::before{content:'';display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(216,4,42,.18)}
.work__title{font-size:clamp(28px,4.2vw,60px);font-weight:300;line-height:1.0;letter-spacing:-.02em;color:var(--ink)}
.work__lead{font-size:17px;line-height:1.6;color:var(--ink-2);font-weight:300;max-width:46ch}
.work__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.work__item{position:relative;aspect-ratio:4/3;overflow:hidden;border-radius:6px;background:#1a1a1a;display:block;cursor:pointer}
.work__item::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 55%,rgba(0,0,0,.5) 100%);opacity:0;transition:opacity .35s;z-index:1}
.work__item:hover::after{opacity:1}
.work__media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.work__item:hover .work__media{transform:scale(1.06)}
.work__foot{margin-top:44px;display:flex;justify-content:center}
@media (max-width:760px){
  .work{padding:32px 20px 80px}
  .work__head{margin-bottom:28px;gap:18px}
  .work__grid{grid-template-columns:1fr 1fr;gap:10px}
  .work__title{font-size:30px}
  .work__lead{font-size:15px}
}

/* ─────────────────────────────────────────────────────── */
/* ABOUT page                                               */
/* ─────────────────────────────────────────────────────── */
.story{padding:96px 48px;max-width:var(--max);margin:0 auto}
.story__inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.story__eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);font-weight:500;margin-bottom:18px}
.story__title{font-size:clamp(36px,4.5vw,64px);font-weight:300;line-height:1.05;letter-spacing:-.02em;margin-bottom:28px;color:var(--ink)}
.story__text p{font-size:16px;line-height:1.7;color:var(--ink-2);font-weight:300;margin-bottom:18px}
.story__text p:last-child{margin-bottom:0}
.story__media{aspect-ratio:4/5;background:#eee center/cover no-repeat;border-radius:8px}

.stats{padding:80px 48px;background:#0a0a0a;color:#fff}
.stats__inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.stat__num{font-size:clamp(48px,5vw,80px);font-weight:300;letter-spacing:-.02em;line-height:1;margin-bottom:12px;color:#fff}
.stat__num em{font-style:normal;color:var(--accent);font-weight:500}
.stat__label{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:#9a9a9a;font-weight:500}

/* ── Elite Dealer highlight ─────────────────────────── */
.elite{
  padding:96px 48px;background:#0a0a0a;color:#fff;position:relative;
}
.elite__inner{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1fr 1.4fr;gap:64px;align-items:center;
}
.elite__media{
  display:flex;flex-direction:column;align-items:flex-start;gap:32px;
  padding:48px 40px;border:1px solid rgba(255,255,255,.12);
  border-radius:16px;background:rgba(255,255,255,.02);
}
.elite__badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:7px 14px 7px 12px;border-radius:999px;
  background:rgba(216,4,42,.15);border:1px solid rgba(216,4,42,.5);
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:#ff4d6a;font-weight:600;
}
.elite__badge::before{
  content:'';display:inline-block;width:6px;height:6px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 0 4px rgba(216,4,42,.18);
}
.elite__logo{
  max-height:48px;width:auto;
  filter:brightness(4) contrast(0);opacity:.95;
}
.elite__credentials{
  display:flex;gap:32px;font-size:12px;letter-spacing:.06em;
  color:#9a9a9a;text-transform:uppercase;font-weight:500;flex-wrap:wrap;
}
.elite__credentials li{list-style:none;display:flex;align-items:center;gap:8px}
.elite__credentials li::before{content:'✓';color:var(--accent);font-weight:700}
.elite__eyebrow{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:#9a9a9a;font-weight:500;margin-bottom:18px;
}
.elite__title{
  font-size:clamp(36px,5vw,72px);font-weight:300;line-height:1.0;
  letter-spacing:-.02em;margin-bottom:24px;
}
.elite__title em{font-style:normal;color:var(--accent);font-weight:400}
.elite__text{
  font-size:17px;line-height:1.65;color:#bdbdbd;font-weight:300;
  max-width:54ch;margin-bottom:32px;
}
.elite__cta{
  display:inline-flex;align-items:center;gap:10px;
  font-size:13px;font-weight:500;letter-spacing:.06em;
  text-transform:uppercase;color:#fff;border-bottom:1px solid #fff;
  padding-bottom:4px;transition:opacity .2s;
}
.elite__cta:hover{opacity:.7}

/* ── Testimonials (Yelp-sourced) ────────────────────── */
.testi{padding:96px 48px;max-width:var(--max);margin:0 auto}
.testi__head{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:56px;gap:32px;flex-wrap:wrap;
}
.testi__lead{max-width:42ch}
.testi__eyebrow{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-2);font-weight:500;margin-bottom:18px;
}
.testi__title{
  font-size:clamp(36px,4.5vw,64px);font-weight:300;line-height:1.05;
  letter-spacing:-.02em;color:var(--ink);
}
.testi__meta{font-size:13px;color:var(--ink-2);line-height:1.5;text-align:right}
.testi__meta strong{display:block;color:var(--ink);font-weight:500;font-size:24px;margin-bottom:4px}
.testi__meta-stars{color:#ffb400;letter-spacing:.05em}
.testi__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:32px;
  border-top:1px solid var(--line);padding-top:48px;
}
.testi__card{
  display:flex;flex-direction:column;gap:18px;
}
.testi__stars{color:#ffb400;font-size:15px;letter-spacing:.05em}
.testi__quote{
  font-size:16px;line-height:1.6;color:var(--ink);font-weight:300;
  flex:1;
}
.testi__author{
  display:flex;justify-content:space-between;align-items:baseline;
  padding-top:18px;border-top:1px solid var(--line);
  font-size:13px;color:var(--ink-2);font-weight:500;letter-spacing:.04em;
}
.testi__author strong{color:var(--ink);font-weight:500}
.testi__foot{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:48px;gap:24px;flex-wrap:wrap;
}
.testi__foot a{
  font-size:13px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;
  color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:3px;
}
.testi__sync{font-size:12px;color:var(--ink-2);letter-spacing:.04em}
.testi__sync code{
  background:rgba(216,4,42,.08);color:var(--accent);
  padding:2px 8px;border-radius:4px;font-family:inherit;font-weight:500;
}

.process{padding:96px 48px;max-width:var(--max);margin:0 auto}
.process__head{margin-bottom:64px;max-width:42ch}
.process__steps{display:grid;grid-template-columns:repeat(4,1fr);gap:48px;border-top:1px solid var(--line);padding-top:56px}
.process__step{display:flex;flex-direction:column}
.process__num{font-size:13px;font-weight:600;color:var(--accent);margin-bottom:24px;letter-spacing:.14em}
.process__step h3{font-size:22px;font-weight:500;letter-spacing:-.005em;margin-bottom:12px;color:var(--ink)}
.process__step p{font-size:14px;line-height:1.55;color:var(--ink-2);font-weight:400}

/* ─────────────────────────────────────────────────────── */
/* BLOG page                                                */
/* ─────────────────────────────────────────────────────── */
.blog{padding:64px 48px 120px;max-width:var(--max);margin:0 auto}
.blog__featured{display:grid;grid-template-columns:1.3fr 1fr;gap:64px;align-items:center;margin-bottom:96px;padding-bottom:96px;border-bottom:1px solid var(--line)}
.blog__featured-img{aspect-ratio:4/3;background:#eee center/cover no-repeat;border-radius:8px;transition:transform .35s}
.blog__featured:hover .blog__featured-img{transform:translateY(-4px)}
.blog__featured-cat{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:16px}
.blog__featured-title{font-size:clamp(28px,3vw,44px);font-weight:400;letter-spacing:-.015em;line-height:1.15;margin-bottom:20px;color:var(--ink)}
.blog__featured-title:hover{color:var(--accent)}
.blog__featured-excerpt{font-size:16px;line-height:1.6;color:var(--ink-2);margin-bottom:24px;font-weight:300}
.blog__featured-meta{font-size:12px;color:var(--ink-2);letter-spacing:.06em;text-transform:uppercase;font-weight:500;display:flex;gap:14px;align-items:center}
.blog__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px}
.blog__post{cursor:pointer;display:flex;flex-direction:column}
.blog__post-img{aspect-ratio:4/3;background:#eee center/cover no-repeat;margin-bottom:24px;border-radius:6px;overflow:hidden;transition:transform .35s}
.blog__post:hover .blog__post-img{transform:translateY(-4px)}
.blog__post-meta{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2);margin-bottom:14px;font-weight:500;display:flex;gap:12px}
.blog__post-meta .blog__cat{color:var(--accent);font-weight:600}
.blog__post-title{font-size:22px;font-weight:500;letter-spacing:-.005em;line-height:1.25;margin-bottom:10px;color:var(--ink);transition:color .2s}
.blog__post:hover .blog__post-title{color:var(--accent)}
.blog__post-excerpt{font-size:14px;color:var(--ink-2);line-height:1.55;font-weight:300}

/* ─────────────────────────────────────────────────────── */
/* FAQ page                                                 */
/* ─────────────────────────────────────────────────────── */
.faq{padding:64px 48px 120px;max-width:880px;margin:0 auto}
.faq__group{margin-bottom:64px}
.faq__group:last-child{margin-bottom:0}
.faq__group-title{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);font-weight:600;margin-bottom:24px;
  padding-bottom:18px;border-bottom:1px solid var(--line);
}
.faq__item{border-bottom:1px solid var(--line)}
.faq__item summary{
  list-style:none;cursor:pointer;
  padding:24px 56px 24px 0;position:relative;
  font-size:clamp(17px,1.5vw,20px);font-weight:500;letter-spacing:-.005em;
  color:var(--ink);line-height:1.4;transition:color .2s;
}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{
  content:'+';position:absolute;right:0;top:50%;transform:translateY(-50%);
  font-size:24px;font-weight:300;color:var(--ink-2);transition:transform .3s, color .2s;
}
.faq__item[open] summary::after{transform:translateY(-50%) rotate(45deg);color:var(--accent)}
.faq__item summary:hover{color:var(--accent)}
.faq__item-body{padding:0 56px 28px 0;font-size:16px;line-height:1.65;color:var(--ink-2);font-weight:300}

/* ─────────────────────────────────────────────────────── */
/* CAREERS page                                             */
/* ─────────────────────────────────────────────────────── */
.careers{padding:64px 48px 96px;max-width:var(--max);margin:0 auto}
.careers__intro{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;margin-bottom:80px}
.careers__intro h2{font-size:clamp(28px,3vw,44px);font-weight:300;line-height:1.05;letter-spacing:-.02em;margin-bottom:24px}
.careers__intro p{font-size:17px;line-height:1.65;color:var(--ink-2);font-weight:300}
.careers__benefits{display:flex;flex-direction:column;gap:18px}
.careers__benefits li{
  list-style:none;font-size:15px;color:var(--ink);line-height:1.5;
  padding-left:32px;position:relative;
}
.careers__benefits li::before{
  content:'';position:absolute;left:0;top:.6em;width:18px;height:1px;background:var(--accent);
}
.jobs__list{display:grid;grid-template-columns:1fr;gap:0;border-top:1px solid var(--line)}
.job{
  display:grid;grid-template-columns:1fr 2fr auto;gap:32px;align-items:center;
  padding:32px 0;border-bottom:1px solid var(--line);
  transition:padding-left .35s ease;
}
.job:hover{padding-left:12px}
.job__title{font-size:clamp(20px,2vw,28px);font-weight:500;letter-spacing:-.005em;color:var(--ink)}
.job__desc{font-size:15px;line-height:1.55;color:var(--ink-2);font-weight:300}
.job__meta{display:flex;flex-direction:column;gap:6px;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2);font-weight:500;text-align:right}
.job__meta strong{color:var(--ink);font-weight:600}
.job__apply{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 22px;background:var(--ink);color:#fff;border:0;
  font:inherit;font-size:12px;letter-spacing:.06em;text-transform:uppercase;font-weight:500;
  text-decoration:none;transition:background .2s;
}
.job__apply:hover{background:var(--accent)}

/* ── Job Application form ───────────────────────────── */
.apply{padding:96px 48px;background:#0a0a0a;color:#fff;scroll-margin-top:80px}
.apply__inner{max-width:880px;margin:0 auto}
.apply__head{margin-bottom:48px;max-width:60ch}
.apply__eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:#9a9a9a;font-weight:500;margin-bottom:18px}
.apply__title{font-size:clamp(32px,4vw,56px);font-weight:300;line-height:1.05;letter-spacing:-.02em;margin-bottom:24px}
.apply__intro{font-size:17px;line-height:1.65;color:#bdbdbd;font-weight:300}
.apply__intro a{color:#fff;border-bottom:1px solid #fff;transition:opacity .2s}
.apply__intro a:hover{opacity:.7}
.apply__form{display:flex;flex-direction:column;gap:24px}
.apply__row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.apply__field{display:flex;flex-direction:column}
.apply__field label{
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:#9a9a9a;font-weight:500;margin-bottom:10px;
}
.apply__field label .req{color:var(--accent)}
.apply__field input,
.apply__field select,
.apply__field textarea{
  border:0;border-bottom:1px solid #2a2a2a;
  padding:10px 0 12px;font:inherit;font-size:16px;background:transparent;
  outline:none;color:#fff;transition:border-color .2s;border-radius:0;
}
.apply__field input::placeholder,
.apply__field textarea::placeholder{color:#666}
.apply__field input:focus,
.apply__field select:focus,
.apply__field textarea:focus{border-bottom-color:#fff}
.apply__field select{background:transparent;color:#fff;cursor:pointer}
.apply__field select option{background:#0a0a0a;color:#fff}
.apply__field input[type=file]{padding:14px 0 16px;color:#cfcfcf;font-size:14px}
.apply__field input[type=file]::file-selector-button{
  background:transparent;color:#fff;border:1px solid #444;padding:8px 14px;
  font:inherit;font-size:12px;letter-spacing:.06em;text-transform:uppercase;
  font-weight:500;cursor:pointer;margin-right:14px;border-radius:0;
  transition:border-color .2s,background .2s,color .2s;
}
.apply__field input[type=file]::file-selector-button:hover{background:#fff;color:#0a0a0a;border-color:#fff}
.apply__hint{font-size:12px;color:#6b6b6b;margin-top:14px}
.apply__submit{
  margin-top:8px;align-self:flex-start;
  padding:14px 32px;background:#fff;color:#0a0a0a;border:0;
  font:inherit;font-size:13px;letter-spacing:.06em;text-transform:uppercase;
  font-weight:500;cursor:pointer;transition:background .2s,color .2s;
}
.apply__submit:hover{background:var(--accent);color:#fff}

/* ─────────────────────────────────────────────────────── */
/* SERVICE DETAIL pages                                     */
/* ─────────────────────────────────────────────────────── */
.svc-hero{
  position:relative;height:80vh;min-height:560px;width:100%;
  color:#fff;display:flex;flex-direction:column;justify-content:flex-end;
  padding:0 48px 80px;
  background:#0a0a0a center/cover no-repeat;
}
.svc-hero::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.45) 0%,rgba(0,0,0,.1) 35%,rgba(0,0,0,.8) 100%);
  pointer-events:none;
}
.svc-hero > *{position:relative;z-index:1}
.svc-hero__eyebrow{font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:500;opacity:.85;margin-bottom:24px;color:#fff}
.svc-hero__title{font-size:clamp(48px,7vw,112px);font-weight:300;line-height:1.0;letter-spacing:-.02em;max-width:14ch;margin-bottom:24px;color:#fff}
.svc-hero__sub{font-size:18px;line-height:1.55;color:rgba(255,255,255,.85);max-width:52ch;font-weight:300;margin-bottom:32px}
.svc-hero__price{
  display:inline-flex;align-items:center;gap:14px;font-size:14px;color:#fff;
}
.svc-hero__price strong{font-size:24px;font-weight:500}
.svc-hero__price-meta{padding-left:14px;border-left:1px solid rgba(255,255,255,.25);color:rgba(255,255,255,.7);font-size:13px}

.svc-intro{padding:96px 48px;max-width:var(--max);margin:0 auto}
.svc-intro__inner{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:start}
.svc-intro__eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);font-weight:500;margin-bottom:18px}
.svc-intro__title{font-size:clamp(28px,3vw,44px);font-weight:300;line-height:1.1;letter-spacing:-.015em;color:var(--ink)}
.svc-intro__body p{font-size:17px;line-height:1.7;color:var(--ink-2);margin-bottom:18px;font-weight:300}
.svc-intro__body p:last-child{margin-bottom:0}

.svc-features{padding:80px 48px;max-width:var(--max);margin:0 auto}
.svc-features__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line);padding-top:56px}
.svc-features__grid > div{padding:0 32px;border-left:1px solid var(--line)}
.svc-features__grid > div:first-child{border-left:0;padding-left:0}
.svc-features__grid > div:last-child{padding-right:0}
.svc-features__icon{font-size:24px;color:var(--accent);margin-bottom:24px;font-weight:300}
.svc-features__grid h3{font-size:20px;font-weight:500;letter-spacing:-.005em;margin-bottom:12px;color:var(--ink)}
.svc-features__grid p{font-size:14px;line-height:1.55;color:var(--ink-2);font-weight:400}

/* Embedded video */
.svc-video{padding:0 48px 24px;max-width:var(--max);margin:0 auto}
.svc-video__inner{max-width:960px;margin:0 auto}
.svc-video__frame{
  position:relative;aspect-ratio:16/9;background:#000;
  border-radius:12px;overflow:hidden;cursor:pointer;
  box-shadow:0 24px 60px rgba(0,0,0,.18);
}
.svc-video__frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.svc-video__poster{
  position:absolute;inset:0;background:#000 center/cover no-repeat;
  display:flex;align-items:center;justify-content:center;
  transition:filter .3s;border:0;padding:0;cursor:pointer;width:100%;
}
.svc-video__poster:hover{filter:brightness(.92)}
.svc-video__play{
  position:relative;z-index:1;width:84px;height:84px;border-radius:50%;
  background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 32px rgba(0,0,0,.45);
  transition:transform .3s;
}
.svc-video__poster:hover .svc-video__play{transform:scale(1.07)}
.svc-video__play svg{width:30px;height:30px;fill:#fff;margin-left:4px}
.svc-video__caption{
  display:flex;justify-content:center;align-items:center;gap:14px;
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-2);font-weight:500;margin-top:18px;
}
.svc-video__caption a{color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:2px;transition:opacity .2s}
.svc-video__caption a:hover{opacity:.6}

/* Credentials row (badge pills) */
.svc-creds{padding:0 48px;max-width:var(--max);margin:0 auto 64px}
.svc-creds__list{
  display:flex;flex-wrap:wrap;gap:10px;
  padding-top:32px;border-top:1px solid var(--line);
}
.svc-creds__list li{
  list-style:none;display:inline-flex;align-items:center;gap:8px;
  padding:9px 16px;border:1px solid var(--line);border-radius:999px;
  font-size:13px;font-weight:500;color:var(--ink);letter-spacing:.01em;
}
.svc-creds__list li::before{content:'✓';color:var(--accent);font-weight:700}

/* Deep dive — alternating image + text */
.svc-deep{padding:80px 48px;max-width:var(--max);margin:0 auto}
.svc-deep__inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.svc-deep--reverse .svc-deep__media{order:2}
.svc-deep__media{aspect-ratio:4/3;background:#eee center/cover no-repeat;border-radius:8px}
.svc-deep__eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);font-weight:500;margin-bottom:18px}
.svc-deep__title{font-size:clamp(28px,3vw,44px);font-weight:300;line-height:1.1;letter-spacing:-.015em;margin-bottom:18px;color:var(--ink)}
.svc-deep__body p{font-size:16px;line-height:1.7;color:var(--ink-2);margin-bottom:14px;font-weight:300}
.svc-deep__body p:last-child{margin-bottom:0}

/* Bullets section (benefits) */
.svc-bullets{padding:80px 48px;max-width:var(--max);margin:0 auto}
.svc-bullets__head{margin-bottom:48px;max-width:38ch}
.svc-bullets__eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);font-weight:500;margin-bottom:18px}
.svc-bullets__title{font-size:clamp(28px,3.5vw,52px);font-weight:300;line-height:1.05;letter-spacing:-.02em;color:var(--ink)}
.svc-bullets__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px 64px;border-top:1px solid var(--line);padding-top:48px}
.svc-bullets__grid li{
  list-style:none;display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:start;
  padding:18px 0;border-bottom:1px solid var(--line);
}
.svc-bullets__grid li:last-child,.svc-bullets__grid li:nth-last-child(2){border-bottom:0}
.svc-bullets__num{
  font-size:14px;font-weight:600;color:var(--accent);letter-spacing:.04em;
  font-variant-numeric:tabular-nums;line-height:1.5;
}
.svc-bullets__text{font-size:17px;line-height:1.5;color:var(--ink);font-weight:400}

/* Service offerings checklist */
.svc-offers{padding:80px 48px;background:#0a0a0a;color:#fff}
.svc-offers__inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 2fr;gap:64px;align-items:start}
.svc-offers__title{font-size:clamp(28px,3.5vw,48px);font-weight:300;line-height:1.05;letter-spacing:-.02em;color:#fff}
.svc-offers__list{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 32px}
.svc-offers__list li{
  list-style:none;font-size:16px;color:#cfcfcf;padding:14px 0;
  border-bottom:1px solid #1c1c1c;display:flex;align-items:center;gap:14px;
}
.svc-offers__list li::before{content:'→';color:var(--accent);font-weight:500}

/* Inline FAQ on service pages */
.svc-faq{padding:80px 48px 32px;max-width:880px;margin:0 auto}
.svc-faq__head{margin-bottom:32px}
.svc-faq__eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);font-weight:500;margin-bottom:18px}
.svc-faq__title{font-size:clamp(28px,3.5vw,48px);font-weight:300;line-height:1.05;letter-spacing:-.02em;color:var(--ink)}

.svc-cta{padding:96px 48px;background:#0a0a0a;color:#fff;text-align:center}
.svc-cta__inner{max-width:680px;margin:0 auto}
.svc-cta h2{font-size:clamp(32px,4vw,56px);font-weight:300;letter-spacing:-.02em;line-height:1.05;margin-bottom:18px}
.svc-cta p{font-size:16px;line-height:1.6;color:#bdbdbd;font-weight:300;margin-bottom:32px}
.svc-cta__buttons{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ── Menu overlay sub-nav ───────────────────────────── */
.menu-overlay nav .menu-sub{
  display:flex;flex-wrap:wrap;gap:14px 24px;
  margin:6px 0 18px 0;padding-left:4px;
}
.menu-overlay nav .menu-sub a{
  font-size:14px;font-weight:400;letter-spacing:.02em;line-height:1.4;
  color:#9a9a9a;padding:4px 0;transform:none;
}
.menu-overlay nav .menu-sub a:hover{color:#fff;transform:none}
.menu-overlay nav .menu-sub a::before{content:'·';margin-right:10px;color:#444}
.menu-overlay nav .menu-sub a:first-child::before{display:none}

/* ─────────────────────────────────────────────────────── */
/* BLOG ARTICLE pages                                       */
/* ─────────────────────────────────────────────────────── */
.article-hero{
  padding:120px 48px 48px;border-bottom:1px solid var(--line);
}
.article-hero__inner{max-width:760px;margin:0 auto}
.article-hero__eyebrow{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);font-weight:600;margin-bottom:20px;
}
.article-hero__title{
  font-size:clamp(36px,5vw,72px);font-weight:300;line-height:1.05;
  letter-spacing:-.02em;color:var(--ink);margin-bottom:28px;
}
.article-hero__meta{
  display:flex;gap:18px;font-size:13px;color:var(--ink-2);
  letter-spacing:.04em;text-transform:uppercase;font-weight:500;flex-wrap:wrap;
}
.article-hero__meta span{display:inline-flex;align-items:center;gap:8px}
.article-hero__meta .sep{color:#ccc}

.article{
  padding:48px 48px 96px;max-width:720px;margin:0 auto;
}
.article__cover{
  aspect-ratio:16/9;background:#eee center/cover no-repeat;
  border-radius:8px;margin-bottom:56px;
}
.article__body{
  font-size:17px;line-height:1.75;color:var(--ink);font-weight:400;
}
.article__lead{
  font-size:20px;line-height:1.6;color:var(--ink);font-weight:400;
  margin-bottom:32px;
}
.article__body p{margin-bottom:22px}
.article__body p:last-child{margin-bottom:0}
.article__body h2,
.article__body h3{
  font-size:clamp(22px,2.5vw,30px);font-weight:500;
  letter-spacing:-.01em;line-height:1.2;
  margin-top:56px;margin-bottom:18px;color:var(--ink);
}
.article__body h2:first-child,
.article__body h3:first-child{margin-top:0}
.article__body ul,
.article__body ol{margin:0 0 24px 22px;padding-left:0}
.article__body li{margin-bottom:8px;list-style:disc;padding-left:6px;color:var(--ink-2)}
.article__body a{color:var(--accent);border-bottom:1px solid var(--accent)}
.article__body a:hover{opacity:.7}
.article__body strong{font-weight:600;color:var(--ink)}

.article__nav{
  max-width:720px;margin:0 auto;padding:32px 48px 96px;
  display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;
  border-top:1px solid var(--line);
}
.article__nav a{
  font-size:13px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;
  color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:3px;
  transition:opacity .2s;
}
.article__nav a:hover{opacity:.6}
.article__nav .article__nav-next{text-align:right}

/* ─────────────────────────────────────────────────────── */
/* CONTACT page                                             */
/* ─────────────────────────────────────────────────────── */
.contact{padding:80px 48px 120px;max-width:var(--max);margin:0 auto}
.contact__grid{display:grid;grid-template-columns:1.2fr 1fr;gap:96px;align-items:start}
.contact__form{display:flex;flex-direction:column;gap:28px}
.contact__row{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.contact__field{display:flex;flex-direction:column}
.contact__field label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);font-weight:500;margin-bottom:10px}
.contact__field input,
.contact__field select,
.contact__field textarea{
  border:0;border-bottom:1px solid var(--line);
  padding:10px 0 12px;font:inherit;font-size:16px;background:transparent;
  outline:none;color:var(--ink);transition:border-color .2s;
  border-radius:0;
}
.contact__field input:focus,
.contact__field select:focus,
.contact__field textarea:focus{border-bottom-color:var(--ink)}
.contact__field textarea{min-height:120px;resize:vertical}
.contact__submit{
  margin-top:12px;align-self:flex-start;
  padding:14px 32px;background:var(--ink);color:#fff;border:0;
  font:inherit;font-size:13px;letter-spacing:.06em;text-transform:uppercase;
  font-weight:500;cursor:pointer;transition:background .2s, color .2s;
}
.contact__submit:hover{background:var(--accent)}
.contact__aside{display:flex;flex-direction:column;gap:32px;padding-top:8px}
.contact__aside h5{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);font-weight:500;margin-bottom:10px}
.contact__aside p, .contact__aside a{font-size:15px;line-height:1.5;color:var(--ink)}
.contact__aside a:hover{opacity:.6}
.contact__map{margin-top:24px;position:relative;aspect-ratio:4/3;border-radius:4px;overflow:hidden;background:#eee}
.contact__map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:saturate(.9)}

/* ─────────────────────────────────────────────────────── */
/* CHAT WIDGET (floating)                                   */
/* ─────────────────────────────────────────────────────── */
.chat-fab{
  position:fixed;right:24px;bottom:24px;z-index:60;
  width:56px;height:56px;border-radius:50%;
  background:var(--accent);color:#fff;border:0;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 24px rgba(0,0,0,.22);
  transition:transform .25s ease, box-shadow .25s ease;
  font:inherit;
}
.chat-fab:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(0,0,0,.3)}
.chat-fab svg{width:24px;height:24px;fill:#fff}
.chat-fab__dot{
  position:absolute;top:6px;right:6px;width:10px;height:10px;border-radius:50%;
  background:#22c55e;border:2px solid var(--accent);
}
.chat-panel{
  position:fixed;right:24px;bottom:96px;z-index:60;
  width:360px;max-width:calc(100vw - 48px);
  background:#fff;color:var(--ink);
  border-radius:16px;overflow:hidden;
  box-shadow:0 24px 60px rgba(0,0,0,.22);
  transform:translateY(12px) scale(.96);opacity:0;visibility:hidden;
  transform-origin:bottom right;
  transition:transform .25s cubic-bezier(.2,.7,.2,1), opacity .2s, visibility .2s;
}
.chat-panel.is-open{transform:translateY(0) scale(1);opacity:1;visibility:visible}
.chat-panel__head{
  background:#0a0a0a;color:#fff;padding:20px 22px;display:flex;justify-content:space-between;align-items:center;
}
.chat-panel__title{font-size:15px;font-weight:500;letter-spacing:-.005em}
.chat-panel__title small{display:block;font-size:12px;color:#9a9a9a;font-weight:400;margin-top:2px;letter-spacing:.02em}
.chat-panel__close{background:transparent;border:0;color:#9a9a9a;font:inherit;cursor:pointer;font-size:20px;line-height:1;padding:4px}
.chat-panel__close:hover{color:#fff}
.chat-panel__body{padding:18px 22px 22px}
.chat-panel__intro{font-size:14px;color:var(--ink-2);line-height:1.5;margin-bottom:16px}
.chat-actions{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.chat-actions a{
  flex:1;min-width:90px;text-align:center;
  padding:10px 8px;border:1px solid var(--line);border-radius:8px;
  font-size:12px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;
  color:var(--ink);transition:background .2s,color .2s,border-color .2s;
}
.chat-actions a:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.chat-form{display:flex;flex-direction:column;gap:10px}
.chat-form input,.chat-form textarea{
  width:100%;border:1px solid var(--line);border-radius:8px;
  padding:11px 12px;font:inherit;font-size:14px;background:#fafafa;
  outline:none;color:var(--ink);transition:border-color .2s,background .2s;
}
.chat-form input:focus,.chat-form textarea:focus{border-color:var(--ink);background:#fff}
.chat-form textarea{min-height:80px;resize:vertical;font-family:inherit}
.chat-form button{
  margin-top:4px;padding:11px 16px;border:0;border-radius:8px;
  background:var(--ink);color:#fff;font:inherit;font-size:13px;font-weight:500;
  letter-spacing:.04em;text-transform:uppercase;cursor:pointer;
  transition:background .2s;
}
.chat-form button:hover{background:var(--accent)}
.chat-panel__foot{
  padding:10px 22px 14px;font-size:11px;color:var(--ink-2);
  text-align:center;border-top:1px solid var(--line);
}

@media (max-width: 900px){
  .chat-fab{right:16px;bottom:16px;width:52px;height:52px}
  .chat-panel{right:12px;left:12px;width:auto;bottom:84px;max-width:none}
}

/* ─────────────────────────────────────────────────────── */
/* RESPONSIVE                                               */
/* ─────────────────────────────────────────────────────── */
@media (max-width: 900px){
  .topbar{padding:12px 16px;gap:8px}
  .phone{display:none}
  .menu-btn span:not(:first-child){display:none}
  .menu-btn{padding:6px 4px;gap:0}
  .logo img{height:18px}
  .top-right{gap:10px;font-size:12px}
  .top-right .btn{padding:9px 12px;font-size:11px;letter-spacing:.04em}
  .menu-overlay{padding:20px}
  .menu-overlay__bar{align-items:center}
  .menu-overlay__logo .brand-mask{width:84px;height:36px}
  .menu-overlay nav a{font-size:38px;padding:4px 0}
  .menu-overlay nav .menu-sub{gap:8px 14px;margin:2px 0 12px 0}
  .menu-overlay nav .menu-sub a{font-size:13px}
  .hero{padding:96px 20px 48px;min-height:560px}
  .hero__title{margin-bottom:20px}
  .hero__sub{font-size:16px;margin-bottom:28px}
  .hero__cta .btn{padding:10px 16px;font-size:12px}
  .hero__rating{margin-top:24px;flex-wrap:wrap;gap:10px}
  .hero__rating-meta{padding-left:10px}
  .page-hero{padding:104px 20px 48px}
  .page-hero__inner{grid-template-columns:1fr;gap:20px}
  .banner{padding:22px 0}
  .banner__track{animation-duration:26s}
  .banner__track img{margin:0 22px}
  .banner__track img.logo--ceramicpro{height:22px}
  .banner__track img.logo--suntek{height:23px}
  .banner__track img.logo--stek{height:21px}
  .banner__track img.logo--3m{height:33px}
  .banner__track img.logo--avery{height:26px}
  .banner__track img.logo--carfax{height:27px}
  .grid{grid-template-columns:1fr;gap:24px}
  .journey{padding:64px 20px 48px}
  .journey__title{font-size:32px;white-space:normal}
  .journey__lead{font-size:15px;margin-top:18px}
  .jrows{gap:16px;margin-top:18px}
  .jrow{flex-direction:column;height:auto;gap:16px;width:100%}
  .tile{
    flex:0 0 auto;width:100%;height:auto;
    aspect-ratio:4/3;border-radius:20px;transition:none;
  }
  .tile:hover{flex-grow:0}
  .tile:hover .tile__media{transform:none}
  .tile__content{left:18px;right:18px;bottom:18px}
  .tile__signature{top:16px;left:18px}
  .tile__title{font-size:24px}
  .tile__desc{font-size:13px}
  .tile__cta{gap:14px}
  .why{padding:64px 20px 48px}
  .why__head{grid-template-columns:1fr;gap:18px;margin-bottom:36px}
  .why__grid{grid-template-columns:1fr 1fr;gap:28px 18px;padding-top:28px}
  .why__grid > article{padding:0;border-left:0;border-top:1px solid var(--line);padding-top:20px;transition:none}
  .why__grid > article:nth-child(-n+2){border-top:0;padding-top:0}
  .why__grid > article:hover{transform:none}
  .why__num{font-size:40px;margin-bottom:14px}
  .why__item-title{font-size:18px;margin-bottom:10px}
  .why__quote{grid-template-columns:1fr;gap:14px;margin-top:48px;padding-top:32px}
  .why__quote-mark{font-size:64px;line-height:.5}
  .find{padding:48px 20px 64px}
  .find__inner{grid-template-columns:1fr;gap:32px}
  .find__meta{grid-template-columns:1fr;gap:28px;padding-top:24px}
  .footer{padding:32px 20px 24px}
  .footer__inner{flex-direction:column;align-items:flex-start;gap:18px;text-align:left}
  .footer__socials{flex-wrap:wrap;gap:14px}

  .gallery{padding:40px 20px 80px}
  .gallery__grid{grid-template-columns:1fr 1fr;gap:10px}
  .gallery__item--wide{grid-column:auto}
  .gallery__item--tall{grid-row:auto;aspect-ratio:1/1}

  .story{padding:64px 20px}
  .story__inner{grid-template-columns:1fr;gap:40px}
  .stats{padding:48px 20px}
  .stats__inner{grid-template-columns:1fr 1fr;gap:24px}
  .process{padding:64px 20px}
  .process__steps{grid-template-columns:1fr 1fr;gap:32px 24px;padding-top:32px}
  .elite{padding:64px 20px}
  .elite__inner{grid-template-columns:1fr;gap:40px}
  .elite__media{padding:32px 24px}
  .testi{padding:64px 20px}
  .testi__head{flex-direction:column;align-items:flex-start;margin-bottom:32px}
  .testi__meta{text-align:left}
  .testi__grid{grid-template-columns:1fr;gap:40px;padding-top:32px}

  .blog{padding:40px 20px 80px}
  .blog__featured{grid-template-columns:1fr;gap:24px;margin-bottom:64px;padding-bottom:64px}
  .blog__grid{grid-template-columns:1fr;gap:40px}

  .article-hero{padding:96px 20px 32px}
  .article{padding:32px 20px 64px}
  .article__cover{margin-bottom:36px}
  .article__nav{padding:24px 20px 64px}

  .contact{padding:48px 20px 80px}
  .contact__grid{grid-template-columns:1fr;gap:48px}
  .contact__row{grid-template-columns:1fr;gap:24px}

  .faq{padding:40px 20px 80px}
  .faq__item summary{padding-right:40px;font-size:17px}
  .faq__item-body{padding-right:40px}

  .careers{padding:40px 20px 80px}
  .careers__intro{grid-template-columns:1fr;gap:32px;margin-bottom:48px}
  .job{grid-template-columns:1fr;gap:14px;padding:24px 0}
  .job:hover{padding-left:0}
  .job__meta{text-align:left;flex-direction:row;align-items:center;gap:16px}
  .job__apply{align-self:flex-start}

  .apply{padding:64px 20px}
  .apply__head{margin-bottom:32px}
  .apply__row{grid-template-columns:1fr;gap:20px}

  .svc-hero{padding:0 20px 60px;min-height:480px;height:auto;padding-top:160px}
  .svc-intro{padding:64px 20px}
  .svc-intro__inner{grid-template-columns:1fr;gap:32px}
  .svc-features{padding:48px 20px}
  .svc-features__grid{grid-template-columns:1fr 1fr;gap:32px 24px;padding-top:32px}
  .svc-features__grid > div{padding:0;border-left:0;border-top:1px solid var(--line);padding-top:24px}
  .svc-features__grid > div:nth-child(-n+2){border-top:0;padding-top:0}
  .svc-cta{padding:64px 20px}
  .svc-video{padding:0 20px 16px}
  .svc-video__frame{border-radius:10px}
  .svc-creds{padding:0 20px;margin-bottom:48px}
  .svc-creds__list{padding-top:24px}
  .svc-deep{padding:48px 20px}
  .svc-deep__inner{grid-template-columns:1fr;gap:32px}
  .svc-deep--reverse .svc-deep__media{order:0}
  .svc-bullets{padding:48px 20px}
  .svc-bullets__grid{grid-template-columns:1fr;gap:0;padding-top:24px}
  .svc-bullets__grid li:nth-last-child(2){border-bottom:1px solid var(--line)}
  .svc-bullets__grid li:last-child{border-bottom:0}
  .svc-offers{padding:48px 20px}
  .svc-offers__inner{grid-template-columns:1fr;gap:32px}
  .svc-offers__list{grid-template-columns:1fr;gap:0}
  .svc-faq{padding:48px 20px 16px}
}

.footer__legal{display:flex;gap:20px;flex-basis:100%;justify-content:center;flex-wrap:wrap;margin-top:24px;padding-top:20px;border-top:1px solid #1a1a1a}
.footer__legal a{font-size:12px;color:#6b6b6b;letter-spacing:.04em;transition:color .2s}
.footer__legal a:hover{color:#fff}
