/* =========================================================
   ALEXANDER CONSTRUCTION, LLC — "FRONT LINE" design system
   Charcoal · single fire-red flare · white-like-lightning
   Oswald (display) / Archivo (body) / Fraunces (quotes)
   ========================================================= */

:root{
  /* ground */
  --ink:#0d0e10;
  --ink-2:#07080a;
  --surface:#16181c;
  --card:#1d2024;
  --card-2:#202329;
  --hairline:#2a2e34;
  --hairline-soft:#23262c;
  /* brand */
  --red:#e01e2b;
  --red-deep:#b3151d;
  --red-ink:#7d0f17;
  --flare:rgba(224,30,43,.16);
  /* text */
  --white:#f4f5f6;
  --body:#b8bcc2;
  --muted:#6f757e;
  /* type */
  --display:'Oswald',Impact,sans-serif;
  --sans:'Archivo','Segoe UI',sans-serif;
  --serif:'Fraunces',Georgia,serif;
  /* metrics */
  --container:1200px;
  --pad:clamp(20px,5vw,64px);
  --radius:4px;
  --ease:cubic-bezier(.2,.7,.2,1);
  --beam:3px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  background:var(--ink);
  color:var(--body);
  font-family:var(--sans);
  font-size:clamp(15px,1.05vw,17px);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--red);color:#fff}

.skip-link{position:absolute;left:-999px;top:0;background:var(--red);color:#fff;padding:10px 16px;z-index:200;font-family:var(--display);text-transform:uppercase;letter-spacing:.06em}
.skip-link:focus{left:8px;top:8px}

.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--pad)}

/* ---------- type primitives ---------- */
.eyebrow{
  font-family:var(--sans);font-weight:600;text-transform:uppercase;
  letter-spacing:.22em;font-size:.74rem;color:var(--red);
  margin:0 0 1rem;display:inline-flex;align-items:center;gap:.5em;
}
.eyebrow--light{color:#fff}
.text-red{color:var(--red)}
.text-white{color:var(--white)}

.section{padding-block:clamp(64px,9vw,124px);position:relative}
.section-head{max-width:760px;margin-bottom:clamp(36px,5vw,64px)}
.section-title{
  font-family:var(--display);font-weight:700;color:var(--white);
  text-transform:uppercase;line-height:.96;letter-spacing:-.01em;
  font-size:clamp(2.1rem,5.4vw,4.1rem);margin:0;
}
.section-lead{margin:1.2rem 0 0;max-width:60ch;color:var(--body);font-size:1.05rem}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{
  --bg:var(--red);
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--display);font-weight:600;text-transform:uppercase;
  letter-spacing:.04em;font-size:.98rem;line-height:1;
  padding:1.02em 1.6em;border:1.5px solid transparent;border-radius:var(--radius);
  cursor:pointer;transition:transform .2s var(--ease),background .2s var(--ease),box-shadow .25s var(--ease),border-color .2s var(--ease);
  position:relative;white-space:nowrap;
}
.btn--red{background:var(--red);color:#fff;box-shadow:0 6px 20px -10px var(--red)}
.btn--red:hover{background:var(--red-deep);transform:translateY(-2px);box-shadow:0 12px 30px -12px var(--red)}
.btn--ghost{background:transparent;color:var(--white);border-color:#3a3f47}
.btn--ghost:hover{border-color:var(--white);background:rgba(255,255,255,.04);transform:translateY(-2px)}
.btn--block{width:100%}
.btn--sm{padding:.8em 1.2em;font-size:.86rem}
.btn--flare{box-shadow:0 0 0 0 var(--flare),0 6px 20px -10px var(--red)}
.btn--flare::after{
  content:"";position:absolute;inset:-2px;border-radius:inherit;z-index:-1;
  box-shadow:0 0 34px 4px var(--flare);opacity:.9;animation:beacon 2.6s var(--ease) infinite;
}
@keyframes beacon{0%,100%{opacity:.35}50%{opacity:1}}

/* =========================================================
   RESPONSE BAR
   ========================================================= */
.responsebar{background:var(--ink-2);border-bottom:1px solid var(--hairline);font-size:.8rem;position:relative;z-index:60}
.responsebar__inner{max-width:var(--container);margin-inline:auto;padding:.5rem var(--pad);display:flex;align-items:center;gap:.9rem}
.responsebar__status{font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:var(--white);display:inline-flex;align-items:center;gap:.5em;white-space:nowrap}
.responsebar__divider{width:1px;height:14px;background:var(--hairline)}
.responsebar__msg{color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.responsebar__phone{margin-left:auto;display:inline-flex;align-items:center;gap:.45em;color:var(--white);font-family:var(--display);font-weight:600;letter-spacing:.04em;white-space:nowrap}
.responsebar__phone:hover{color:var(--red)}
.pulse-dot{width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 0 0 var(--red);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(224,30,43,.6)}70%{box-shadow:0 0 0 7px rgba(224,30,43,0)}100%{box-shadow:0 0 0 0 rgba(224,30,43,0)}}

/* =========================================================
   HEADER / NAV
   ========================================================= */
.site-header{position:sticky;top:0;z-index:50;background:rgba(13,14,16,.72);backdrop-filter:blur(10px);border-bottom:1px solid transparent;transition:background .3s,border-color .3s,box-shadow .3s}
.site-header.is-stuck{background:rgba(10,11,13,.95);border-bottom-color:var(--hairline);box-shadow:0 10px 30px -20px #000}
.site-header__inner{max-width:var(--container);margin-inline:auto;padding:.7rem var(--pad);display:flex;align-items:center;gap:1.5rem}

.brand{display:inline-flex;align-items:center;gap:.7rem}
.brand__mark svg{display:block}
.mark__a{fill:var(--red)}
.mark__hammer{fill:var(--white)}
.brand__type{display:flex;flex-direction:column;line-height:1}
.brand__name{font-family:var(--display);font-weight:700;letter-spacing:.06em;color:var(--white);font-size:1.18rem}
.brand__sub{font-family:var(--sans);font-weight:600;font-size:.6rem;letter-spacing:.34em;color:var(--muted);margin-top:.2em}
.brand__sub i{font-style:normal;color:var(--red)}

.nav{margin-left:auto;display:flex;align-items:center;gap:.35rem}
.nav>a{font-family:var(--display);font-weight:500;text-transform:uppercase;letter-spacing:.04em;font-size:.92rem;color:var(--body);padding:.55em .85em;border-radius:var(--radius);transition:color .2s}
.nav>a:hover{color:var(--white)}
.nav__cta{background:var(--red);color:#fff!important;margin-left:.5rem}
.nav__cta:hover{background:var(--red-deep)}

.nav-toggle{display:none;margin-left:auto;width:44px;height:44px;background:transparent;border:1px solid var(--hairline);border-radius:var(--radius);cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.nav-toggle span{width:20px;height:2px;background:var(--white);transition:transform .25s,opacity .2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;min-height:clamp(560px,92vh,920px);display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;isolation:isolate}
.hero__media{position:absolute;inset:0;z-index:-2}
.hero__photo{
  position:absolute;inset:0;
  background:#000 url('../img/hero-roofer.jpg') center 30%/cover no-repeat;
  filter:grayscale(.35) contrast(1.05) brightness(.62) saturate(.9);
  clip-path:polygon(38% 0,100% 0,100% 100%,22% 100%);
  animation:shutter 1.1s var(--ease) both;
}
@keyframes shutter{from{clip-path:polygon(64% 0,100% 0,100% 100%,52% 100%)}to{clip-path:polygon(38% 0,100% 0,100% 100%,22% 100%)}}
.hero__scrim{
  position:absolute;inset:0;
  background:
    linear-gradient(75deg,var(--ink) 30%,rgba(13,14,16,.55) 52%,rgba(13,14,16,.2) 100%),
    linear-gradient(to top,var(--ink) 4%,transparent 32%),
    linear-gradient(to bottom,rgba(7,8,10,.85),transparent 30%);
}
.hero__sky{position:absolute;inset:0;background:radial-gradient(120% 80% at 78% -10%,rgba(40,52,70,.5),transparent 55%),radial-gradient(80% 60% at 30% 110%,var(--flare),transparent 60%);mix-blend-mode:screen;opacity:.8}
.hero__bolt{position:absolute;top:-2%;left:62%;width:min(34vw,360px);height:80%;opacity:0;z-index:-1;pointer-events:none}
.hero__bolt svg{width:100%;height:100%}
.hero__bolt path{fill:#eaf2ff;filter:drop-shadow(0 0 18px rgba(180,210,255,.9)) drop-shadow(0 0 60px rgba(120,170,255,.6))}
.hero__flash{position:absolute;inset:0;background:#dce8ff;opacity:0;mix-blend-mode:screen;pointer-events:none}

.hero__inner{position:relative;max-width:var(--container);width:100%;margin-inline:auto;padding:0 var(--pad) clamp(56px,8vh,96px)}
.hero__eyebrow{font-family:var(--sans);font-weight:600;text-transform:uppercase;letter-spacing:.34em;font-size:.78rem;color:var(--red);margin:0 0 1.1rem}
.hero__eyebrow span{color:var(--muted);margin:0 .15em}
.hero__title{margin:0;font-family:var(--display);font-weight:700;text-transform:uppercase;color:var(--white);line-height:.92;letter-spacing:-.012em;font-size:clamp(2.9rem,9vw,6.6rem);overflow-wrap:break-word}
.hero__title .line{display:block}
.hero__title .knockout{color:var(--red);text-shadow:0 0 50px rgba(224,30,43,.35)}
.hero__sub{max-width:48ch;margin:1.5rem 0 0;color:#cfd3d8;font-size:clamp(1rem,1.4vw,1.18rem)}
.hero__cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2rem}
.hero__trust{list-style:none;display:flex;flex-wrap:wrap;align-items:center;gap:.55rem 1.4rem;margin:2.2rem 0 0;padding:1.3rem 0 0;border-top:1px solid var(--hairline);font-family:var(--display);font-weight:500;text-transform:uppercase;letter-spacing:.06em;font-size:.82rem;color:var(--body)}
.hero__trust li{position:relative;padding-left:1.4rem}
.hero__trust li::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:8px;height:8px;background:var(--red);clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%)}
.hero__trust-tag{color:var(--white)!important}
.hero__scroll{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);width:26px;height:42px;border:2px solid #3a3f47;border-radius:14px;display:flex;justify-content:center;padding-top:7px;z-index:2}
.hero__scroll span{width:3px;height:8px;background:var(--red);border-radius:2px;animation:scrolldot 1.8s infinite}
@keyframes scrolldot{0%{transform:translateY(0);opacity:1}70%{transform:translateY(14px);opacity:0}100%{opacity:0}}

/* lightning load sequence */
.hero.is-loaded .hero__bolt{animation:bolt 2.6s var(--ease) .35s 1 forwards}
.hero.is-loaded .hero__flash{animation:flash 2.6s var(--ease) .35s 1 forwards}
@keyframes bolt{0%{opacity:0}5%{opacity:1}9%{opacity:.1}12%{opacity:.9}18%{opacity:0}100%{opacity:0}}
@keyframes flash{0%{opacity:0}5%{opacity:.55}10%{opacity:.05}13%{opacity:.42}19%{opacity:0}100%{opacity:0}}

/* =========================================================
   REVEAL / BEAM
   ========================================================= */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .7s var(--ease),transform .7s var(--ease);transition-delay:calc(var(--d,0)*80ms)}
.hero.is-loaded .reveal,.reveal.in{opacity:1;transform:none}

.beam{position:relative;padding-left:clamp(18px,2.4vw,30px)}
.beam::before{content:"";position:absolute;left:0;top:.1em;bottom:.1em;width:var(--beam);background:linear-gradient(var(--red),var(--red-deep));border-radius:2px}

/* =========================================================
   PROMISE BAND + HAZARD
   ========================================================= */
.hazard-edge{position:relative}
.hazard-edge::before{
  content:"";position:absolute;left:0;right:0;top:0;height:6px;
  background:repeating-linear-gradient(45deg,var(--red) 0 16px,var(--ink) 16px 32px);
  opacity:.95;
}
.promise{background:var(--surface);border-block:1px solid var(--hairline)}
.promise__inner{max-width:var(--container);margin-inline:auto;padding:clamp(22px,3.5vw,34px) var(--pad);display:flex;align-items:center;gap:clamp(16px,4vw,40px);flex-wrap:wrap}
.promise__text{margin:0;font-size:clamp(1.05rem,1.8vw,1.4rem);color:var(--body);font-family:var(--sans);max-width:62ch}
.promise__text strong{color:var(--white);font-weight:700}
.promise .btn{margin-left:auto}

/* =========================================================
   SERVICES
   ========================================================= */
.services{background:var(--ink)}
.services__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.6vw,20px)}
.svc-card{
  position:relative;background:var(--card);border:1px solid var(--hairline);border-radius:var(--radius);
  padding:clamp(22px,2.4vw,30px);overflow:visible;
  transition:transform .3s var(--ease),border-color .3s var(--ease),background .3s var(--ease);
}
.svc-card::after{content:"";position:absolute;inset:0;border-radius:inherit;border:1px solid transparent;pointer-events:none;transition:border-color .3s}
.svc-card:hover{transform:translateY(-5px);background:var(--card-2)}
.svc-card:hover::after{border-color:var(--red)}
.svc-card:hover .svc-card__icon{color:var(--red);border-color:var(--red)}
.svc-card--wide{grid-column:span 4}
.svc-card__icon{display:inline-flex;width:54px;height:54px;align-items:center;justify-content:center;border:1px solid var(--hairline);border-radius:var(--radius);color:var(--white);margin-bottom:1.1rem;transition:color .3s,border-color .3s}
.svc-card__icon svg{width:30px;height:30px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.svc-card h3{font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.02em;color:var(--white);font-size:1.35rem;margin:0 0 .5rem}
.svc-card p{margin:0;font-size:.96rem;color:var(--body)}
.svc-card--wide{display:grid;grid-template-columns:auto 1fr;gap:.2rem 1.6rem;align-items:center}
.svc-card--wide .svc-card__icon{grid-row:span 2;width:64px;height:64px;margin:0}
.svc-card--wide h3{margin:0}
.svc-card__badge{
  position:absolute;top:-11px;right:14px;background:var(--red);color:#fff;
  font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.08em;
  font-size:.66rem;padding:.32em .7em;border-radius:2px;transform:rotate(2.5deg);
  box-shadow:0 6px 14px -8px #000;transition:transform .3s var(--ease)
}
.svc-card__badge--blue{background:#1f2c3a;color:#cfe0f0;border:1px solid #32465c}
.svc-card:hover .svc-card__badge{transform:rotate(-2deg) scale(1.04)}

/* =========================================================
   PROCESS
   ========================================================= */
.process{background:var(--surface);border-block:1px solid var(--hairline)}
.process__list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,3vw,40px) clamp(28px,5vw,80px)}
.proc-step{display:flex;gap:clamp(14px,2vw,26px);align-items:flex-start}
.proc-step__num{font-family:var(--display);font-weight:700;font-size:clamp(3rem,6vw,5.2rem);line-height:.8;color:transparent;-webkit-text-stroke:1.4px #3a3f47;letter-spacing:-.03em;flex:none}
.proc-step:hover .proc-step__num{-webkit-text-stroke-color:var(--red);transition:.3s}
.proc-step__body{padding-top:.4rem}
.proc-step h3{font-family:var(--display);font-weight:600;text-transform:uppercase;color:var(--white);font-size:1.3rem;margin:0 0 .4rem;letter-spacing:.01em}
.proc-step p{margin:0;color:var(--body);font-size:.98rem}
.proc-step.beam{padding-left:0}
.proc-step.beam::before{display:none}

/* =========================================================
   CLAIMS
   ========================================================= */
.claims{background:var(--ink)}
.claims__grid{display:grid;grid-template-columns:0.85fr 1fr;gap:clamp(28px,5vw,72px);align-items:center}
.claims__media{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--hairline)}
.claims__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5;filter:grayscale(.2) contrast(1.05) brightness(.85)}
.claims__tag{position:absolute;left:14px;bottom:14px;background:var(--red);color:#fff;font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;padding:.45em .85em;border-radius:2px;box-shadow:0 8px 18px -10px #000}
.claims__copy h2{margin-bottom:.4em}
.claims__copy p{margin:0 0 1rem}
.checklist{list-style:none;margin:1.4rem 0;padding:0;display:grid;gap:.6rem}
.checklist li{position:relative;padding-left:2rem;color:var(--white);font-weight:500;font-size:.98rem}
.checklist li::before{content:"";position:absolute;left:0;top:2px;width:20px;height:20px;border-radius:50%;background:var(--red);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/16px no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/16px no-repeat}

/* =========================================================
   WHY / STATS
   ========================================================= */
.why{background:var(--surface);border-block:1px solid var(--hairline)}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2.5vw,30px)}
.stat{border-left:var(--beam) solid var(--red);padding:.2rem 0 .2rem clamp(14px,1.6vw,22px)}
.stat__num{display:block;font-family:var(--display);font-weight:700;color:var(--white);font-size:clamp(2.6rem,5vw,4rem);line-height:.9;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.stat__label{display:block;margin-top:.5rem;color:var(--body);font-size:.92rem;max-width:22ch}
.why__badges{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:clamp(32px,5vw,52px)}
.why-badge{font-family:var(--display);font-weight:500;text-transform:uppercase;letter-spacing:.08em;font-size:.84rem;color:var(--body);border:1px solid var(--hairline);border-radius:2px;padding:.55em 1em;background:var(--card)}
.why-badge::before{content:"✓ ";color:var(--red);font-weight:700}

/* =========================================================
   PROJECTS GALLERY
   ========================================================= */
.projects{background:var(--ink)}
.projects__filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:clamp(24px,3vw,38px)}
.filter{font-family:var(--display);font-weight:500;text-transform:uppercase;letter-spacing:.06em;font-size:.86rem;color:var(--body);background:transparent;border:1px solid var(--hairline);border-radius:2px;padding:.6em 1.1em;cursor:pointer;transition:.22s}
.filter:hover{color:var(--white);border-color:#3a3f47}
.filter.is-active{background:var(--red);color:#fff;border-color:var(--red)}

.projects__grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(12px,1.4vw,18px);grid-auto-flow:dense}
.proj{
  position:relative;grid-column:span 4;border-radius:var(--radius);overflow:hidden;cursor:pointer;
  border:1px solid var(--hairline);background:var(--card);aspect-ratio:4/3;
  transition:transform .35s var(--ease),border-color .35s var(--ease),box-shadow .35s var(--ease);
}
.proj.span-6{grid-column:span 6}
.proj.tall{aspect-ratio:3/4}
.proj img{width:100%;height:100%;object-fit:cover;filter:grayscale(.85) contrast(1.05) brightness(.78);transition:filter .5s var(--ease),transform .6s var(--ease)}
.proj:hover{transform:translateY(-4px);border-color:var(--red);box-shadow:0 24px 50px -28px #000}
.proj:hover img{filter:grayscale(0) contrast(1.02) brightness(.92);transform:scale(1.05)}
.proj__overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:clamp(14px,1.6vw,20px);background:linear-gradient(to top,rgba(7,8,10,.92) 6%,rgba(7,8,10,.2) 55%,transparent);opacity:.92;transition:opacity .3s}
.proj__type{align-self:flex-start;font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:.66rem;color:#fff;background:var(--red);padding:.28em .6em;border-radius:2px;margin-bottom:.6rem}
.proj__title{font-family:var(--display);font-weight:600;text-transform:uppercase;color:var(--white);font-size:1.12rem;line-height:1.05;margin:0}
.proj__loc{font-size:.82rem;color:var(--body);margin:.25rem 0 0;display:flex;align-items:center;gap:.35em}
.proj__loc::before{content:"";width:6px;height:6px;background:var(--red);clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%)}
.proj__zoom{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:50%;background:rgba(13,14,16,.6);border:1px solid var(--hairline);display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;transform:scale(.8);transition:.3s}
.proj:hover .proj__zoom{opacity:1;transform:scale(1)}
.projects__note{margin-top:clamp(24px,3vw,36px);color:var(--muted);font-size:.95rem}
.projects__note a{color:var(--red);font-weight:600}
.projects__note a:hover{text-decoration:underline}

/* =========================================================
   SERVICE AREA
   ========================================================= */
.area{background:var(--surface);border-block:1px solid var(--hairline)}
.area__grid{display:grid;grid-template-columns:1fr .9fr;gap:clamp(28px,5vw,72px);align-items:center}
.area__list{list-style:none;margin:1.6rem 0;padding:0;display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem 1.4rem}
.area__list li{position:relative;padding-left:1.5rem;color:var(--white);font-family:var(--display);font-weight:500;text-transform:uppercase;letter-spacing:.03em;font-size:.96rem}
.area__list li::before{content:"";position:absolute;left:0;top:.55em;width:9px;height:9px;background:var(--red);clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%)}
.area__hint{color:var(--muted);font-size:.85rem}
.area__hint.center{text-align:center;margin-top:2rem}
.area__hint code{background:var(--card);padding:.1em .4em;border-radius:3px;color:var(--body);font-size:.85em}
.area__media{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--hairline)}
.area__media img{width:100%;aspect-ratio:3/2;object-fit:cover;filter:grayscale(.3) brightness(.8) contrast(1.05)}
.area__call{position:absolute;left:14px;bottom:14px;display:inline-flex;align-items:center;gap:.5em;background:var(--red);color:#fff;font-family:var(--display);font-weight:600;letter-spacing:.04em;padding:.6em 1em;border-radius:2px;box-shadow:0 10px 22px -12px #000}
.area__call:hover{background:var(--red-deep)}

/* =========================================================
   TESTIMONIALS
   ========================================================= */
.testimonials{background:var(--ink)}
.testi__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px)}
.testi{position:relative;background:var(--card);border:1px solid var(--hairline);border-radius:var(--radius);padding:clamp(24px,2.6vw,34px);margin:0;overflow:hidden}
.testi::before{content:"\201C";position:absolute;top:-.35em;right:.15em;font-family:var(--serif);font-style:italic;font-size:9rem;color:var(--red);opacity:.14;line-height:1}
.testi blockquote{margin:0 0 1.4rem;font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(1.1rem,1.5vw,1.32rem);line-height:1.5;color:var(--white)}
.testi figcaption{display:flex;flex-direction:column;gap:.1rem;border-top:1px solid var(--hairline);padding-top:1rem}
.testi figcaption strong{font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--white)}
.testi figcaption span{color:var(--red);font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}

/* =========================================================
   FINAL CTA + TICKET
   ========================================================= */
.cta-final{background:linear-gradient(160deg,var(--surface),var(--ink-2));border-top:1px solid var(--hairline)}
.cta-final__grid{display:grid;grid-template-columns:1fr .85fr;gap:clamp(32px,5vw,72px);align-items:center}
.cta-final__title{font-family:var(--display);font-weight:700;text-transform:uppercase;line-height:.94;color:var(--white);font-size:clamp(2.4rem,5.5vw,4.4rem);margin:0 0 1rem}
.cta-final__lead{max-width:46ch;font-size:1.06rem}
.cta-final__phone{margin:1.8rem 0;display:flex;flex-direction:column;gap:.1rem}
.cta-final__phone span{font-family:var(--display);text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;color:var(--muted)}
.cta-final__phone a{font-family:var(--display);font-weight:700;font-size:clamp(1.8rem,3.5vw,2.6rem);color:var(--white);letter-spacing:.01em}
.cta-final__phone a:hover{color:var(--red)}
.cta-final__tagline{font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:1.1rem;color:var(--body);margin:0}

/* ticket */
.ticket{background:var(--card);border:1px solid var(--hairline);border-radius:6px;box-shadow:0 40px 80px -50px #000;position:relative;overflow:hidden}
.ticket__head{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.4rem;background:var(--red)}
.ticket__title{font-family:var(--display);font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#fff;font-size:1.1rem}
.ticket__badge{font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:.7rem;color:var(--red);background:#fff;padding:.3em .7em;border-radius:2px}
.ticket__perf{height:0;border-bottom:2px dashed var(--hairline);position:relative;background:var(--red)}
.ticket__perf::before,.ticket__perf::after{content:"";position:absolute;top:-9px;width:18px;height:18px;border-radius:50%;background:var(--ink)}
.ticket__perf::before{left:-9px}.ticket__perf::after{right:-9px}
.ticket__body{padding:clamp(18px,2.2vw,26px)}
.field{margin-bottom:.9rem;display:flex;flex-direction:column}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.field label{font-family:var(--display);font-weight:500;text-transform:uppercase;letter-spacing:.08em;font-size:.74rem;color:var(--body);margin-bottom:.4rem}
.field label span{color:var(--muted);text-transform:none;letter-spacing:0}
.field input,.field select,.field textarea{
  background:var(--ink);border:1px solid var(--hairline);border-radius:var(--radius);
  color:var(--white);font-family:var(--sans);font-size:.96rem;padding:.7em .85em;width:100%;
  transition:border-color .2s,box-shadow .2s;resize:vertical;
}
.field input::placeholder,.field textarea::placeholder{color:#5a606a}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px var(--flare)}
.ticket__fineprint{margin:.9rem 0 0;font-size:.8rem;color:var(--muted);text-align:center}
.ticket.is-sent .ticket__body>*:not(.ticket__fineprint){display:none}
.ticket.is-sent .ticket__fineprint{color:var(--white);font-size:1rem}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{background:var(--ink-2);border-top:1px solid var(--hairline);padding-top:clamp(48px,6vw,80px)}
.site-footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:clamp(28px,4vw,56px);padding-bottom:clamp(36px,5vw,60px)}
.site-footer__brand .brand__mark{display:inline-block;margin-bottom:1rem}
.brand__name--lg{font-family:var(--display);font-weight:700;letter-spacing:.05em;color:var(--white);font-size:1.5rem;margin:0}
.brand__name--lg span{display:block;font-size:.78rem;letter-spacing:.22em;color:var(--muted);margin-top:.2em}
.site-footer__tag{font-family:var(--display);font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--red);margin:1rem 0 0}
.site-footer__col h4{font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--white);font-size:.92rem;margin:0 0 1.1rem}
.site-footer__col a{display:block;color:var(--body);font-size:.94rem;padding:.28rem 0;transition:color .2s}
.site-footer__col a:hover{color:var(--red)}
.site-footer__phone{font-family:var(--display)!important;font-weight:700!important;font-size:1.5rem!important;color:var(--white)!important;padding:0!important;margin-bottom:.4rem}
.site-footer__contact p{margin:.2rem 0;font-size:.9rem;color:var(--muted)}
.site-footer__contact .btn{margin-top:1rem}
.site-footer__base{display:flex;flex-wrap:wrap;gap:.6rem 1.5rem;justify-content:space-between;border-top:1px solid var(--hairline);padding-block:1.4rem;font-size:.82rem;color:var(--muted)}

/* =========================================================
   MOBILE STICKY BAR
   ========================================================= */
.mobilebar{position:fixed;left:0;right:0;bottom:0;z-index:55;display:none;gap:1px;background:var(--hairline);box-shadow:0 -10px 30px -20px #000;border-top:1px solid var(--hairline)}
.mobilebar a{flex:1;display:flex;align-items:center;justify-content:center;gap:.5em;padding:1em;font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:.96rem}
.mobilebar__call{background:var(--ink-2);color:#fff}
.mobilebar__quote{background:var(--red);color:#fff}

/* =========================================================
   LIGHTBOX
   ========================================================= */
.lightbox{position:fixed;inset:0;z-index:120;background:rgba(7,8,10,.95);display:none;align-items:center;justify-content:center;padding:clamp(16px,4vw,60px)}
.lightbox.is-open{display:flex}
.lightbox__figure{margin:0;max-width:min(1100px,92vw);max-height:88vh;display:flex;flex-direction:column}
.lightbox__figure img{max-width:100%;max-height:78vh;object-fit:contain;border:1px solid var(--hairline);border-radius:var(--radius)}
.lightbox__figure figcaption{margin-top:1rem;text-align:center;font-family:var(--display);font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:var(--white)}
.lightbox__close{position:absolute;top:18px;right:22px;width:48px;height:48px;background:transparent;border:1px solid var(--hairline);color:#fff;font-size:1.8rem;border-radius:var(--radius);cursor:pointer;line-height:1}
.lightbox__close:hover{border-color:var(--red);color:var(--red)}
.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;background:rgba(13,14,16,.6);border:1px solid var(--hairline);color:#fff;font-size:2rem;border-radius:50%;cursor:pointer;line-height:1}
.lightbox__nav:hover{border-color:var(--red);color:var(--red)}
.lightbox__prev{left:max(16px,3vw)}
.lightbox__next{right:max(16px,3vw)}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1080px){
  .services__grid{grid-template-columns:repeat(2,1fr)}
  .svc-card--wide{grid-column:span 2}
}
@media (max-width:880px){
  .responsebar__msg{display:none}
  /* drop backdrop-filter so it doesn't trap the fixed nav overlay in a containing block */
  .site-header,.site-header.is-stuck{backdrop-filter:none;-webkit-backdrop-filter:none;background:rgba(10,11,13,.96)}
  /* mobile nav = full-screen overlay (robust, always renders clearly) */
  .nav{position:fixed;top:0;left:0;right:0;bottom:0;height:100vh;height:100dvh;width:100%;flex-direction:column;align-items:center;justify-content:center;gap:.3rem;background:var(--ink);padding:5.5rem 1.4rem 2.5rem;z-index:48;opacity:0;visibility:hidden;transform:translateY(-10px);transition:opacity .3s var(--ease),visibility .3s,transform .3s var(--ease)}
  .nav.is-open{opacity:1;visibility:visible;transform:none}
  .nav>a{width:100%;max-width:320px;text-align:center;font-size:1.6rem;padding:.62em 1em;border-bottom:1px solid var(--hairline-soft)}
  .nav__cta{margin-top:1.2rem;border-bottom:none!important;max-width:320px}
  .nav-toggle{display:flex;position:relative;z-index:49}
  .claims__grid,.area__grid,.cta-final__grid{grid-template-columns:1fr}
  .claims__media{max-width:520px}
  .claims__media img{aspect-ratio:16/10}
  .area__grid{direction:ltr}
  .process__list{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .testi__grid{grid-template-columns:1fr}
  .projects__grid .proj,.projects__grid .proj.span-6{grid-column:span 6}
  .mobilebar{display:flex}
  body{padding-bottom:60px}
  .promise .btn{margin-left:0}
  .site-footer__grid{grid-template-columns:1fr 1fr}
  .site-footer__brand{grid-column:1 / -1}
  .site-footer__base{flex-direction:column;align-items:flex-start}
}
@media (max-width:560px){
  .services__grid{grid-template-columns:1fr}
  .svc-card--wide{grid-column:span 1;grid-template-columns:1fr}
  .svc-card--wide .svc-card__icon{grid-row:auto}
  .stats{grid-template-columns:1fr 1fr;gap:1.2rem}
  .area__list{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .projects__grid .proj,.projects__grid .proj.span-6{grid-column:span 12}
  .hero__photo{clip-path:none;opacity:.9}
  .hero__scrim{background:linear-gradient(to top,var(--ink) 10%,rgba(13,14,16,.45) 60%,rgba(13,14,16,.3)),linear-gradient(to bottom,rgba(7,8,10,.7),transparent 40%)}
  .hero__title{font-size:clamp(2.15rem,8.6vw,3rem)}
  .hero__sub{font-size:1rem}
  .responsebar__status{letter-spacing:.08em}
  .site-footer__grid{grid-template-columns:1fr}
  .site-footer__phone{font-size:1.35rem!important}
}

/* =========================================================
   REDUCED MOTION
   ========================================================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .reveal{opacity:1!important;transform:none!important}
  .hero__photo{clip-path:polygon(38% 0,100% 0,100% 100%,22% 100%)}
  .hero__bolt,.hero__flash{display:none}
}
