/* ===== ACS — Action Chutes Services ===== */
:root{
  --ink:        #0A0F1C;
  --ink-2:      #1C2433;
  --steel:      #2A3340;
  --paper:      #FBFCFE;
  --paper-2:    #F1F4F7;
  --line:       #DDE3EA;
  --line-dk:    #1f2734;
  --muted:      #5b6776;
  --muted-2:    #8b95a5;
  --red:        #B50E11;
  --red-dk:     #8E0A0D;
  --blue:       #002658;
  --blue-2:     #003D8F;
  --navy:       #002658;
  --ok:         #1f8a5b;

  --radius:     4px;
  --radius-lg:  8px;

  --font-display: "Archivo", "Archivo Narrow", system-ui, sans-serif;
  --font-body:    "Archivo", system-ui, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, monospace;

  --container: 1280px;
}

*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; background:var(--paper); color:var(--ink); }
html{ scroll-behavior:smooth; }
body{
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; }
button:disabled{ cursor:not-allowed; opacity:.72; }
h1,h2,h3,h4{ font-family:var(--font-display); margin:0; letter-spacing:-0.02em; }
p{ margin:0; }
::selection{ background:var(--red); color:var(--paper); }

.container{
  width:100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 28px;
}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding: 12px 18px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.02em;
  border-radius: var(--radius);
  border: 1.5px solid transparent;
  white-space: nowrap;
  transition: transform .15s ease, background .15s ease, border-color .15s ease, color .15s ease;
  text-transform: uppercase;
}
.btn:active{ transform: translateY(1px); }
.btn-red{
  position: relative;
  overflow: hidden;
}
.btn-red::after{
  content:"";
  position:absolute;
  inset:-40% auto -40% -70%;
  width:55%;
  transform: skewX(-18deg);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.28), transparent);
  transition: left .45s ease;
}
.btn-red:hover::after{ left:120%; }
.btn-lg{ padding: 16px 22px; font-size: 14px; }
.btn-red{ background:var(--red); color:#fff; border-color:var(--red); box-shadow: 0 1px 0 rgba(0,0,0,.04), inset 0 -2px 0 rgba(0,0,0,.18); }
.btn-red:hover{ background:var(--red-dk); border-color:var(--red-dk); }
.btn-dark{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.btn-dark:hover{ background:#000; }
.btn-ghost{ background:transparent; color:var(--ink); border-color: rgba(10,15,28,.18); }
.btn-ghost:hover{ border-color: var(--ink); }

/* ============ TOP UTILITY BAR ============ */
.util-bar{
  background: var(--ink);
  color: #cfd5df;
  font-family: var(--font-mono);
  font-size: 12px;
}
.util-inner{
  max-width: var(--container);
  margin:0 auto;
  padding: 8px 28px;
  display:flex; justify-content:space-between; align-items:center; gap:16px;
}
.util-left{ display:flex; align-items:center; gap:10px; }
.util-left strong{ color:#fff; font-weight:600; letter-spacing:.04em; text-transform:uppercase; }
.util-sep{ color:#4a5566; }
.util-link{ color:#cfd5df; }
.util-link:hover{ color:#fff; }
.pulse{
  width:8px; height:8px; border-radius:50%;
  background: var(--red);
  box-shadow: 0 0 0 0 rgba(181,14,17,.7);
  animation: pulse 1.8s infinite;
}
@keyframes pulse{
  0%{ box-shadow:0 0 0 0 rgba(181,14,17,.7); }
  70%{ box-shadow:0 0 0 8px rgba(181,14,17,0); }
  100%{ box-shadow:0 0 0 0 rgba(181,14,17,0); }
}

/* ============ HEADER ============ */
.site-header{
  position: sticky; top:0; z-index: 40;
  background: rgba(245,244,238,.92);
  backdrop-filter: saturate(1.2) blur(8px);
  -webkit-backdrop-filter: saturate(1.2) blur(8px);
  border-bottom: 1px solid var(--line);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  height: 76px;
}
.brand{ display:flex; align-items:center; gap:12px; }
.brand-badge{ width:48px; height:48px; }
.brand-badge.sm{ width:44px; height:44px; }
.badge-text-top{ font-family: var(--font-mono); font-weight:700; font-size:7.2px; letter-spacing:.18em; }
.badge-text-bot{ font-family: var(--font-mono); font-weight:700; font-size:7px; letter-spacing:.32em; }
.badge-mono{ font-family: var(--font-display); font-weight:900; font-size:21px; letter-spacing:.02em; }
.brand-word{ display:flex; flex-direction:column; line-height:1.05; }
.brand-acs{ font-family:var(--font-display); font-weight:900; font-size:18px; letter-spacing:.02em; color:var(--ink); }
.brand-full{ font-family:var(--font-mono); font-size:11px; color:var(--muted); letter-spacing:.06em; text-transform:uppercase; }

.site-nav{ display:flex; gap:28px; }
.site-nav a{
  font-family:var(--font-display); font-weight:600; font-size:14px;
  color:var(--ink); position:relative; padding:6px 0;
}
.site-nav a:hover::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px; height:2px; background:var(--red);
}
.header-cta{ display:flex; gap:10px; align-items:center; }

/* ============ HERO ============ */
.hero{
  position:relative;
  background:
    radial-gradient(1200px 480px at 80% -10%, rgba(27,58,139,.07), transparent 60%),
    var(--paper);
  border-bottom: 1px solid var(--line);
  overflow: hidden;
}
.hero::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background-image:
    linear-gradient(to right, rgba(10,15,28,.05) 1px, transparent 1px);
  background-size: 80px 100%;
  mask-image: linear-gradient(to bottom, transparent, #000 30%, #000 70%, transparent);
}
.hero-grid{
  display:grid; grid-template-columns: 1.15fr 1fr; gap: 64px;
  padding: 88px 28px 72px;
  position:relative;
}
.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing:.18em; text-transform:uppercase;
  color: var(--steel);
  margin-bottom: 22px;
}
.eyebrow-bar{ width:32px; height:2px; background:var(--red); display:inline-block; }

.hero-title{
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(44px, 6.4vw, 92px);
  line-height: 0.95;
  letter-spacing: -0.035em;
  color: var(--ink);
  animation: heroFadeUp .9s cubic-bezier(.16,1,.3,1) both;
}
.title-accent{
  font-style: italic;
  font-family: var(--font-display);
  font-weight: 800;
  color: var(--red);
}
.hero-sub{
  margin-top: 24px;
  max-width: 560px;
  font-size: 18px;
  color: var(--steel);
  line-height: 1.55;
  animation: heroFadeUp .9s cubic-bezier(.16,1,.3,1) .12s both;
}
.hero-cta{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top: 32px;
  animation: heroFadeUp .9s cubic-bezier(.16,1,.3,1) .22s both;
}

.hero-stats{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:0;
  margin: 56px 0 0; padding-top: 24px;
  border-top: 1px solid var(--line);
  animation: heroFadeUp .9s cubic-bezier(.16,1,.3,1) .32s both;
}
.hero-stats > div{
  padding-right: 20px;
  border-right: 1px solid var(--line);
}
.hero-stats > div:last-child{ border-right:0; }
.hero-stats dt{
  font-family: var(--font-mono); font-size: 11px; letter-spacing:.18em;
  text-transform:uppercase; color: var(--muted);
}
.hero-stats dd{
  margin: 6px 0 0; font-family: var(--font-display); font-weight: 700;
  font-size: 20px; letter-spacing:-.01em; color: var(--ink);
}

/* hero art */
.hero-art{ position:relative; min-height: 420px; display:flex; align-items:stretch; }
.art-frame{
  flex: 1;
  position:relative;
  background: var(--ink);
  border-radius: var(--radius-lg);
  padding: 14px;
  display:grid;
  grid-template-rows: 1fr;
  box-shadow:
    0 30px 60px -30px rgba(10,15,28,.5),
    inset 0 0 0 1px rgba(255,255,255,.06);
  animation: artFloat 7s ease-in-out infinite;
}
.art-tag{
  position:absolute; z-index:2;
  font-family: var(--font-mono); font-size: 11px; letter-spacing:.18em; text-transform:uppercase;
  background: var(--paper); color: var(--ink);
  padding: 6px 10px; border-radius: 2px;
  display:inline-flex; align-items:center; gap:6px;
}
.art-tag-tl{ top: -10px; left: 18px; }
.art-tag-br{ bottom: 18px; right: -10px; background: var(--red); color:#fff; }
.art-tag .dot{ width:6px; height:6px; border-radius:50%; background:#1f8a5b; box-shadow:0 0 0 3px rgba(31,138,91,.25); }

.art-photo{
  position:relative;
  background: #11182a;
  border-radius: 4px;
  overflow:hidden;
  min-height: 360px;
  display:flex; align-items:stretch; justify-content:center;
}
.job-photo{
  background:
    radial-gradient(circle at 28% 72%, rgba(181,14,17,.18), transparent 18rem),
    linear-gradient(135deg, #293647, #111827 64%, #070b12);
}
.placeholder-photo{
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.02) 0 12px, rgba(255,255,255,.04) 12px 13px),
    linear-gradient(180deg, #1a2236, #0c1322);
}
.ph-mark{
  position:absolute; top:14px; left:14px;
  font-family: var(--font-mono); font-size:10px; letter-spacing:.2em;
  color: rgba(255,255,255,.55); text-transform:uppercase;
  background: rgba(255,255,255,.06);
  border: 1px dashed rgba(255,255,255,.2);
  padding: 4px 8px;
}
.art-shaft{ width:100%; height:100%; }
.art-job{
  width:100%;
  height:100%;
  min-height:360px;
}
.real-hero-photo{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  filter:saturate(.95) contrast(1.04);
}
.job-photo::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(10,15,28,.08), rgba(10,15,28,.34)),
    linear-gradient(90deg, rgba(10,15,28,.12), transparent 44%, rgba(10,15,28,.28));
  pointer-events:none;
}
.job-photo .ph-mark{ z-index:2; }
.job-photo .art-job{ display:none; }
.art-chute-stack{ animation: shaftGlow 4.5s ease-in-out infinite; }
.art-tech{ transform-origin: 160px 300px; animation: techWork 3.8s ease-in-out infinite; }
.spark-group{ animation: sparkBlink 1.4s steps(2, end) infinite; }
.art-pipes{ animation: pipePulse 5s ease-in-out infinite; }
/* marquee */
.marquee{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background: var(--paper-2);
  overflow:hidden;
  position:relative;
}
.marquee::before, .marquee::after{
  content:""; position:absolute; top:0; bottom:0; width:80px; z-index:2; pointer-events:none;
}
.marquee::before{ left:0; background:linear-gradient(to right, var(--paper-2), transparent); }
.marquee::after{ right:0; background:linear-gradient(to left, var(--paper-2), transparent); }
.marquee-track{
  display:flex; gap: 56px; padding: 14px 0;
  white-space: nowrap;
  animation: marquee 40s linear infinite;
  font-family: var(--font-mono); font-size: 13px;
  letter-spacing: .14em; color: var(--ink);
}
.marquee-track span{ display:inline-flex; }
@keyframes marquee{
  from{ transform: translateX(0); }
  to{ transform: translateX(-50%); }
}
@keyframes artFloat{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(-8px); }
}
@keyframes shaftGlow{
  0%,100%{ opacity:1; }
  50%{ opacity:.92; }
}
@keyframes techWork{
  0%,100%{ transform: rotate(0deg) translateY(0); }
  50%{ transform: rotate(-1.4deg) translateY(3px); }
}
@keyframes sparkBlink{
  0%,45%{ opacity:0; transform: scale(.8); }
  46%,100%{ opacity:1; transform: scale(1); }
}
@keyframes pipePulse{
  0%,100%{ opacity:.65; }
  50%{ opacity:1; }
}

/* ============ FOOTER ============ */
.site-footer{
  background: var(--ink);
  color: #cfd5df;
  padding: 72px 0 24px;
  margin-top: 80px;
}
.footer-grid{
  display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 48px;
  padding-bottom: 56px;
  border-bottom: 1px solid #1f2734;
}
.foot-brand .brand{ margin-bottom: 16px; }
.foot-blurb{ color:#9aa3b2; font-size:14px; max-width: 380px; }
.foot-col{ display:flex; flex-direction:column; gap:8px; }
.foot-col h4{
  font-family: var(--font-mono); font-size: 11px; letter-spacing:.18em; text-transform:uppercase;
  color: #7c8699; margin-bottom: 6px;
}
.foot-col a, .foot-col span{ color: #d8dde6; font-size: 15px; }
.foot-col a:hover{ color:#fff; }
.foot-fine{
  display:flex; justify-content:space-between; padding-top: 20px;
  font-family: var(--font-mono); font-size: 11px; letter-spacing:.14em; text-transform:uppercase;
  color:#5b6776;
}

/* ============ MOBILE STICKY ============ */
.mobile-cta{
  display:none;
  position:fixed; bottom: 12px; left: 12px; right: 12px; z-index: 60;
  gap:8px;
  background: rgba(245,244,238,.92);
  backdrop-filter: blur(10px);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px;
  box-shadow: 0 12px 30px -10px rgba(10,15,28,.35);
}
.mobile-cta .btn{ flex:1; justify-content:center; padding: 14px 12px; }

/* ============ SECTIONS COMMON ============ */
.section{ padding: 96px 0; }
.section-head{ max-width: 760px; margin-bottom: 56px; }
.section-head.row{
  display:grid; grid-template-columns: 1fr 1fr; gap: 48px;
  max-width: none; align-items:end;
}
.section-title{
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(36px, 4.4vw, 64px);
  line-height: 1.0;
  letter-spacing: -0.03em;
  color: var(--ink);
}
.section-title.light{ color: var(--paper); }
.section-sub{
  margin-top: 20px;
  font-size: 17px;
  color: var(--steel);
  max-width: 640px;
  text-wrap: pretty;
}
.aside-sub{ margin-top: 0; align-self:end; max-width: 460px; padding-bottom: 6px; }
.eyebrow-light{ color: rgba(245,244,238,.7); }

/* ============ SERVICES ============ */
.services{ background: var(--paper); }
.svc-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--ink); border-left: 1px solid var(--ink); }
.svc{
  position:relative;
  overflow:hidden;
  min-height: 340px;
  padding: 36px 32px 32px;
  border-right: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  background: var(--paper);
  transition: background .2s ease, color .2s ease, transform .2s ease;
}
.svc > *:not(.svc-visual){ position:relative; z-index:2; }
.svc-visual{
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  opacity:.34;
  transform: scale(1.02);
  transition: opacity .25s ease, transform .35s ease;
}
.svc-visual::before,
.svc-visual::after{
  content:"";
  position:absolute;
  display:block;
}
.svc:hover .svc-visual{
  opacity:.48;
  transform: scale(1.06) translateY(-3px);
}
.svc-chute .svc-visual{
  background:
    linear-gradient(90deg, transparent 0 44%, rgba(0,38,88,.12) 44% 77%, transparent 77%),
    repeating-linear-gradient(0deg, transparent 0 48px, rgba(0,38,88,.18) 49px 50px);
}
.svc-chute .svc-visual::before{
  right:32px;
  bottom:20px;
  width:118px;
  height:250px;
  border:4px solid rgba(0,38,88,.72);
  background:linear-gradient(90deg, #6f7f90, #edf2f5 52%, #718192);
  box-shadow: 0 18px 36px rgba(0,38,88,.18);
}
.svc-chute .svc-visual::after{
  right:54px;
  bottom:78px;
  width:76px;
  height:48px;
  border:5px solid rgba(181,14,17,.78);
  background:#182337;
}
.svc-accent .svc-visual{
  opacity:.42;
  background:
    radial-gradient(circle at 74% 32%, rgba(255,255,255,.16), transparent 9rem),
    linear-gradient(145deg, rgba(245,244,238,.12), transparent 46%);
}
.svc-accent .svc-visual::before{
  right:24px;
  bottom:26px;
  width:210px;
  height:132px;
  border:5px solid rgba(245,244,238,.42);
  background:#1c2433;
  clip-path: polygon(0 24%, 88% 24%, 100% 42%, 100% 86%, 0 86%);
  box-shadow: inset -44px 0 0 rgba(255,255,255,.08);
}
.svc-accent .svc-visual::after{
  right:74px;
  bottom:92px;
  width:76px;
  height:44px;
  border:3px solid rgba(181,14,17,.95);
  border-radius:999px;
  box-shadow: 82px -28px 0 -12px rgba(245,244,238,.35), -58px 26px 0 -16px rgba(245,244,238,.35);
}
.svc-door .svc-visual{
  background:
    linear-gradient(90deg, rgba(0,38,88,.08) 0 35%, transparent 35%),
    repeating-linear-gradient(90deg, transparent 0 34px, rgba(10,15,28,.08) 35px 36px);
}
.svc-door .svc-visual::before{
  right:28px;
  bottom:24px;
  width:172px;
  height:208px;
  border:5px solid rgba(0,38,88,.62);
  background:linear-gradient(135deg, #dfe8ef, #91a3b3);
  box-shadow: inset -18px 0 0 rgba(10,15,28,.12), 0 16px 32px rgba(10,15,28,.14);
}
.svc-door .svc-visual::after{
  right:64px;
  bottom:98px;
  width:100px;
  height:58px;
  border:4px solid rgba(181,14,17,.8);
  background:rgba(10,15,28,.9);
}
.svc-maintenance .svc-visual{
  background:
    linear-gradient(135deg, rgba(0,38,88,.08), transparent 52%),
    repeating-linear-gradient(0deg, transparent 0 44px, rgba(10,15,28,.08) 45px 46px);
}
.svc-maintenance .svc-visual::before{
  right:28px;
  bottom:34px;
  width:172px;
  height:124px;
  border:4px solid rgba(0,38,88,.52);
  background:
    linear-gradient(#f5f4ee 0 22%, transparent 22%),
    repeating-linear-gradient(0deg, rgba(0,38,88,.18) 0 2px, transparent 2px 24px),
    #e7ebed;
  box-shadow: 0 16px 30px rgba(10,15,28,.12);
}
.svc-maintenance .svc-visual::after{
  right:146px;
  bottom:154px;
  width:62px;
  height:62px;
  border-radius:50%;
  border:8px solid rgba(181,14,17,.76);
  border-right-color:transparent;
  transform: rotate(-28deg);
}
.svc-cleaning .svc-visual{
  background:
    radial-gradient(circle at 82% 70%, rgba(0,38,88,.18), transparent 8rem),
    linear-gradient(90deg, rgba(0,38,88,.08), transparent 55%);
}
.svc-cleaning .svc-visual::before{
  right:48px;
  bottom:28px;
  width:104px;
  height:232px;
  border:4px solid rgba(0,38,88,.58);
  background:
    linear-gradient(180deg, rgba(255,255,255,.24), transparent 28%),
    linear-gradient(90deg, #8597a9, #eef3f5 52%, #6e7e90);
}
.svc-cleaning .svc-visual::after{
  right:154px;
  bottom:86px;
  width:90px;
  height:26px;
  border-radius:999px;
  background:rgba(181,14,17,.78);
  box-shadow: 18px -36px 0 -7px rgba(0,38,88,.35), -10px -66px 0 -9px rgba(0,38,88,.25), 40px -92px 0 -11px rgba(181,14,17,.45);
}
.svc-emergency .svc-visual{
  opacity:.28;
  background:
    radial-gradient(circle at 76% 35%, rgba(255,255,255,.35), transparent 9rem),
    repeating-linear-gradient(135deg, rgba(255,255,255,.08) 0 8px, transparent 8px 18px);
}
.svc-emergency .svc-visual::before{
  right:28px;
  bottom:34px;
  width:178px;
  height:88px;
  border:4px solid rgba(255,255,255,.66);
  background:#0a0f1c;
  clip-path: polygon(0 30%, 74% 30%, 86% 48%, 100% 48%, 100% 84%, 0 84%);
}
.svc-emergency .svc-visual::after{
  right:58px;
  bottom:28px;
  width:30px;
  height:30px;
  border-radius:50%;
  background:#f5f4ee;
  box-shadow: -96px 0 0 #f5f4ee, -48px -74px 0 -8px #f5f4ee;
}

.svc .svc-visual{
  background-size:cover;
  background-position:center;
  opacity:.6;
  filter:saturate(.95) contrast(1.08);
}
.svc .svc-visual::before,
.svc .svc-visual::after{ display:none; }
.svc-chute .svc-visual{ background-image:url("public/assets/photos/hero-chute-repair.png"); }
.svc-accent .svc-visual{ background-image:url("public/assets/photos/compactor-repair.png"); opacity:.5; }
.svc-door .svc-visual{ background-image:url("public/assets/photos/hopper-door-repair.png"); }
.svc-maintenance .svc-visual{ background-image:url("public/assets/photos/preventive-maintenance.png"); }
.svc-cleaning .svc-visual{ background-image:url("public/assets/photos/chute-cleaning.png"); }
.svc-emergency .svc-visual{ background-image:url("public/assets/photos/emergency-repair.png"); opacity:.48; }
.svc::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(245,244,238,.9) 0 42%, rgba(245,244,238,.46)),
    linear-gradient(180deg, rgba(245,244,238,.42), rgba(245,244,238,.82));
}
.svc-accent::before{
  background:
    linear-gradient(90deg, rgba(0,38,88,.94) 0 44%, rgba(0,38,88,.52)),
    linear-gradient(180deg, rgba(0,38,88,.44), rgba(0,38,88,.88));
}
.svc-emergency::before{
  background:
    linear-gradient(90deg, rgba(181,14,17,.94) 0 44%, rgba(181,14,17,.52)),
    linear-gradient(180deg, rgba(181,14,17,.44), rgba(181,14,17,.88));
}
.svc-num{
  font-family: var(--font-mono); font-size: 12px; letter-spacing: .2em;
  color: var(--muted); margin-bottom: 36px;
}
.svc h3{
  font-family: var(--font-display); font-weight: 800; font-size: 26px;
  letter-spacing:-.02em; color: var(--ink); margin-bottom: 12px;
}
.svc p{ color: var(--steel); font-size: 15px; line-height: 1.55; }
.svc-list{
  list-style:none; padding:0; margin: 24px 0 0;
  display:flex; flex-wrap:wrap; gap: 6px;
}
.svc-list li{
  font-family: var(--font-mono); font-size: 11px; letter-spacing:.12em; text-transform:uppercase;
  padding: 5px 9px; border: 1px solid var(--line);
  color: var(--steel);
}
.svc:hover{ background: var(--paper-2); }
.svc-accent{ background: var(--navy); color: var(--paper); }
.svc-accent:hover{ background: var(--navy); }
.svc-accent .svc-num{ color: rgba(245,244,238,.55); }
.svc-accent h3{ color: var(--paper); }
.svc-accent p{ color: rgba(245,244,238,.78); }
.svc-accent .svc-list li{ border-color: rgba(245,244,238,.25); color: rgba(245,244,238,.85); }
.svc-emergency{ background: var(--red); color:#fff; }
.svc-emergency:hover{ background: var(--red); }
.svc-emergency .svc-num{ color: rgba(255,255,255,.7); }
.svc-emergency h3, .svc-emergency p{ color:#fff; }
.svc-emergency p{ color: rgba(255,255,255,.92); }
.svc-emergency .svc-list li{ border-color: rgba(255,255,255,.45); color:#fff; }

/* ============ EMERGENCY ============ */
.emergency{
  background: var(--ink);
  color: var(--paper);
  padding: 96px 0;
  position: relative;
  overflow: hidden;
}
.emergency::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(800px 320px at 90% 10%, rgba(181,14,17,.18), transparent 60%),
    repeating-linear-gradient(45deg, transparent 0 18px, rgba(255,255,255,.018) 18px 19px);
  pointer-events:none;
}
.emergency-grid{ position:relative; display:grid; grid-template-columns: 1.2fr 1fr; gap: 64px; align-items:center; }
.emergency-sub{ font-size: 17px; color: rgba(245,244,238,.78); max-width: 560px; margin-top: 20px; }
.emergency-cta{ display:flex; gap: 12px; flex-wrap:wrap; margin-top: 32px; }
.btn-outline-light{ background: transparent; color: var(--paper); border-color: rgba(245,244,238,.4); }
.btn-outline-light:hover{ border-color: var(--paper); background: rgba(245,244,238,.06); }
.emergency-stamps{
  display:grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  margin-top: 48px; padding-top: 24px; border-top: 1px solid rgba(245,244,238,.15);
}
.emergency-stamps > div{
  border-right: 1px solid rgba(245,244,238,.15);
  padding-right: 20px;
}
.emergency-stamps > div:last-child{ border-right:0; }
.stamp-num{
  display:block;
  font-family: var(--font-display); font-weight: 900;
  font-size: 32px; letter-spacing: -.02em; color: var(--paper);
}
.stamp-lbl{
  display:block; margin-top: 6px;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .16em;
  text-transform: uppercase; color: rgba(245,244,238,.55);
}

.emergency-card{
  background: var(--ink-2);
  border: 1px solid rgba(245,244,238,.1);
  border-radius: var(--radius-lg);
  padding: 22px;
  font-family: var(--font-mono);
  color: #d8dde6;
  box-shadow: 0 30px 60px -30px rgba(0,0,0,.6), inset 0 0 0 1px rgba(255,255,255,.02);
}
.card-header{
  display:flex; align-items:center; gap: 10px;
  padding-bottom: 14px; margin-bottom: 14px;
  border-bottom: 1px dashed rgba(245,244,238,.18);
  font-size: 11px; letter-spacing:.18em; text-transform:uppercase;
}
.card-dot{ width:8px; height:8px; border-radius:50%; background:#5cd29c; box-shadow:0 0 0 3px rgba(92,210,156,.18); animation: pulse 2s infinite; }
.card-label{ color:#fff; flex: 1; }
.card-time{ color: rgba(245,244,238,.55); }
.card-row{
  display:grid; grid-template-columns: 70px 1fr; gap: 14px;
  padding: 8px 0; font-size: 13px;
  border-bottom: 1px dashed rgba(245,244,238,.1);
}
.card-row:last-of-type{ border-bottom: 0; }
.card-row .k{ color:#7c8699; font-size: 11px; letter-spacing:.16em; text-transform:uppercase; padding-top: 2px; }
.card-row .v{ color:#fff; }
.card-row .v.eta{ color: #ffd07a; }
.thumb{
  display:inline-block; width: 36px; height: 36px;
  background: linear-gradient(135deg, #1a2236, #0c1322);
  border: 1px solid rgba(245,244,238,.2);
  margin-right: 4px; vertical-align: middle;
  background-image:
    repeating-linear-gradient(135deg, rgba(255,255,255,.04) 0 6px, rgba(255,255,255,.08) 6px 7px);
}
.card-foot{
  display:flex; align-items:center; justify-content:space-between;
  margin-top: 14px; padding-top: 14px;
  border-top: 1px dashed rgba(245,244,238,.18);
}
.status-pill{
  background: var(--red); color:#fff;
  padding: 6px 10px; font-size: 11px; letter-spacing:.18em;
}
.card-job{ color: rgba(245,244,238,.55); font-size: 11px; letter-spacing:.18em; text-transform:uppercase; }

/* ============ WHY ============ */
.why{ background: var(--paper-2); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.why-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--ink); }
.why-item{
  padding: 32px 28px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--paper);
}
.why-item:nth-child(3n){ border-right: 0; }
.why-num{
  display:inline-block;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .2em;
  color: var(--red); margin-bottom: 18px;
}
.why-item h4{ font-family: var(--font-display); font-weight: 800; font-size: 20px; letter-spacing: -.01em; margin-bottom: 8px; }
.why-item p{ color: var(--steel); font-size: 14.5px; line-height: 1.55; }

/* ============ AREAS ============ */
.areas{ background: var(--paper); }
.areas-grid{
  display:grid;
  grid-template-columns: 1.1fr 1fr;
  column-gap: 64px;
  row-gap: 40px;
  align-items: start;
}
.areas-copy{ grid-column: 1; grid-row: 1; }
.areas-cols{
  grid-column: 1;
  grid-row: 2;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  padding-top: 28px;
  border-top: 1px solid var(--line);
}
.areas-cols h4{
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .2em;
  text-transform: uppercase; color: var(--red);
  margin-bottom: 14px;
}
.areas-cols ul{ list-style: none; margin: 0; padding: 0; display:flex; flex-direction:column; gap: 6px; }
.areas-cols li{ font-size: 15px; color: var(--ink); }
.areas-map{
  grid-column: 2;
  grid-row: 1 / span 2;
  background:
    radial-gradient(circle at 20% 10%, rgba(255,255,255,.82), transparent 15rem),
    linear-gradient(145deg, #f1efe6, #e0ded3);
  border: 1px solid rgba(10,15,28,.12);
  border-radius: var(--radius-lg);
  padding: 18px;
  position: sticky; top: 96px;
  perspective: 900px;
  box-shadow:
    0 28px 70px -44px rgba(10,15,28,.55),
    inset 0 1px 0 rgba(255,255,255,.5);
  overflow:hidden;
  transform-style: preserve-3d;
  transition:
    transform .35s cubic-bezier(.16,1,.3,1),
    box-shadow .35s ease,
    border-color .35s ease;
}
.areas-map::before{
  content:"";
  position:absolute;
  inset: 0;
  border-radius: inherit;
  background:
    linear-gradient(90deg, rgba(10,15,28,.04) 1px, transparent 1px),
    linear-gradient(0deg, rgba(10,15,28,.04) 1px, transparent 1px);
  background-size: 26px 26px;
  pointer-events:none;
}
.areas-map::after{
  content:"";
  position:absolute;
  inset: 18px;
  border:1px solid rgba(0,38,88,.16);
  border-radius:8px;
  pointer-events:none;
}
.minimal-map{
  position:relative;
  z-index:1;
  width: 100%;
  height: auto;
  border-radius: 6px;
  filter:
    drop-shadow(0 20px 18px rgba(10,15,28,.18))
    drop-shadow(0 3px 0 rgba(255,255,255,.55));
  transform: rotateX(7deg) rotateZ(-.6deg);
  transform-origin:center;
  animation: mapHover 8s ease-in-out infinite;
  transition:
    transform .35s cubic-bezier(.16,1,.3,1),
    filter .35s ease;
  will-change: transform;
}
.areas-map:hover{
  transform: perspective(900px) rotateX(2.5deg) rotateY(-4deg) translateY(-6px);
  border-color: rgba(0,61,143,.32);
  box-shadow:
    0 38px 86px -42px rgba(10,15,28,.62),
    inset 0 1px 0 rgba(255,255,255,.68);
}
.areas-map:hover .minimal-map{
  transform: rotateX(13deg) rotateZ(-1.5deg) translateY(-8px) scale(1.025);
  filter:
    drop-shadow(0 30px 24px rgba(10,15,28,.24))
    drop-shadow(0 4px 0 rgba(255,255,255,.68));
}
.areas-map:hover .state-top,
.areas-map:hover .long-island{
  transform: translateY(-5px);
}
.areas-map:hover .state-depth{
  transform: translateY(28px);
}
.areas-map:hover .route-line,
.areas-map:hover .route-pulse{
  stroke-width:6;
}
.map-water{ opacity:.96; }
.state-depth{
  transform: translateY(22px);
  opacity:.9;
  transition: transform .35s cubic-bezier(.16,1,.3,1);
}
.ny-depth{ fill:#9fb7ce; }
.ct-depth{ fill:#d2a0a4; }
.state-top{
  stroke-width:2.4;
  stroke-linejoin:round;
  transition: transform .35s cubic-bezier(.16,1,.3,1);
}
.ny-top{
  fill:url(#nyTop);
  stroke:#003d8f;
}
.ct-top{
  fill:url(#ctTop);
  stroke:#b50e11;
}
.long-island{
  fill:#e5f1fb;
  stroke:#003d8f;
  stroke-width:2;
  stroke-linejoin:round;
  transition: transform .35s cubic-bezier(.16,1,.3,1);
}
.route{
  fill:none;
  stroke-linecap:round;
  transition: stroke-width .25s ease;
}
.route-shadow{
  stroke:rgba(10,15,28,.22);
  stroke-width:12;
  transform:translateY(7px);
}
.route-line{
  stroke:#fff;
  stroke-width:8;
}
.route-pulse{
  stroke:#b50e11;
  stroke-width:4;
  stroke-dasharray:18 16;
  animation: routeMove 1.8s linear infinite;
}
.map-label text:first-child{
  font-family:var(--font-display);
  font-weight:900;
  font-size:24px;
  letter-spacing:4px;
}
.map-label text:last-child{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:2px;
  opacity:.62;
}
.ny-label text{ fill:#002658; text-anchor:middle; }
.ct-label text{ fill:#b50e11; text-anchor:middle; }
.pin text{
  font-family:var(--font-mono);
  font-size:12px;
  fill:#0a0f1c;
  font-weight:700;
}
.pin-dot{
  fill:#b50e11;
  stroke:#fff;
  stroke-width:3;
  filter: drop-shadow(0 7px 5px rgba(10,15,28,.26));
}
.pin-ring{
  fill:rgba(181,14,17,.14);
  stroke:rgba(181,14,17,.28);
  stroke-width:2;
  animation: mapPinPulse 2.3s ease-in-out infinite;
}
.pin-stamford .pin-dot,
.pin-newhaven .pin-dot,
.pin-hartford .pin-dot{
  fill:#002658;
}
.map-legend rect{
  fill:#d5e8fa;
  stroke:#003d8f;
}
.map-legend .legend-ct{
  fill:#ffdfe0;
  stroke:#b50e11;
}
.map-legend text{
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:2px;
  fill:#002658;
}
.map-legend .legend-route{
  fill:#b50e11;
}
@keyframes mapHover{
  0%,100%{ transform: rotateX(7deg) rotateZ(-.6deg) translateY(0); }
  50%{ transform: rotateX(9deg) rotateZ(.35deg) translateY(-5px); }
}
@keyframes mapPinPulse{
  0%,100%{ r:20; opacity:1; }
  50%{ r:27; opacity:.5; }
}
@keyframes routeMove{
  to{ stroke-dashoffset:-34; }
}

/* ============ PROJECTS ============ */
.projects{ background: var(--paper-2); border-top: 1px solid var(--line); }
.proj-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: 240px;
  gap: 16px;
}
.proj{ margin: 0; display:flex; flex-direction: column; }
.proj-lg{ grid-column: span 2; grid-row: span 2; }
.proj-img{
  position: relative;
  flex: 1;
  background: var(--ink);
  border-radius: var(--radius);
  overflow: hidden;
  display:flex; align-items:center; justify-content:center;
}
.proj-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  filter:saturate(.95) contrast(1.04);
  transition: transform .45s ease;
}
.proj:hover .proj-img img{ transform: scale(1.045); }
.proj-img::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(10,15,28,.26));
  pointer-events:none;
}
.proj-img.placeholder-photo{
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.02) 0 12px, rgba(255,255,255,.05) 12px 13px),
    linear-gradient(180deg, #1a2236, #0c1322);
}
.proj-img .ph-mark{
  position: relative; top: auto; left: auto;
}
.proj-tag{
  position:absolute; top: 12px; right: 12px;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .18em; text-transform:uppercase;
  background: var(--red); color: #fff; padding: 5px 9px;
}
.proj figcaption{
  display:flex; flex-direction:column; gap: 2px;
  padding: 12px 2px 0;
}
.proj figcaption strong{ font-family: var(--font-display); font-weight: 700; font-size: 17px; }
.proj figcaption span{ font-family: var(--font-mono); font-size: 11px; letter-spacing:.1em; color: var(--muted); text-transform: uppercase; }

/* ============ REQUEST FORM ============ */
.request{
  background: var(--navy);
  color: var(--paper);
  padding: 96px 0;
  position: relative;
  overflow: hidden;
}
.request::before{
  content:""; position:absolute; inset:0;
  background-image: linear-gradient(to right, rgba(245,244,238,.04) 1px, transparent 1px);
  background-size: 80px 100%;
  mask-image: linear-gradient(to bottom, transparent, #000 20%, #000 80%, transparent);
  pointer-events:none;
}
.request-grid{ display:grid; grid-template-columns: 1fr 1.2fr; gap: 64px; position:relative; }
.request-sub{ margin-top: 20px; color: rgba(245,244,238,.8); font-size: 17px; }
.request-sub a{ color: #ffd07a; border-bottom: 1px solid rgba(255,208,122,.4); }
.request-bullets{
  list-style: none; margin: 32px 0 0; padding: 0;
  display: grid; gap: 10px;
}
.request-bullets li{
  display:flex; align-items:center; gap: 12px;
  font-size: 15px; color: rgba(245,244,238,.92);
}
.request-bullets li span{
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--red); flex: 0 0 auto;
}
.request-contact{
  margin-top: 36px; padding-top: 24px;
  border-top: 1px solid rgba(245,244,238,.15);
  display: flex; gap: 16px; align-items:center;
  font-family: var(--font-mono); font-size: 13px; letter-spacing: .12em; text-transform: uppercase;
  color: rgba(245,244,238,.7);
}
.request-contact a{ color: #fff; border-bottom: 1px solid rgba(255,255,255,.3); padding-bottom:2px; }

.request-form{
  background: var(--paper);
  color: var(--ink);
  padding: 32px;
  border-radius: var(--radius-lg);
  box-shadow: 0 30px 60px -30px rgba(0,0,0,.5);
}
.hp-field{
  position:absolute;
  left:-10000px;
  width:1px;
  height:1px;
  opacity:0;
  pointer-events:none;
}
.request-form.is-loading{ opacity:.9; }
.form-error{
  margin-top:12px;
  padding:12px 14px;
  border:1px solid rgba(181,14,17,.3);
  border-radius:var(--radius);
  background:rgba(181,14,17,.08);
  color:var(--red-dk);
  font-family:var(--font-mono);
  font-size:12px;
}
.form-fields{ display:grid; gap: 16px; }
.form-row.two{ display:grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.request-form label{ display:flex; flex-direction:column; gap: 6px; font-size: 14px; }
.request-form label > span{
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--muted);
}
.request-form input[type=text],
.request-form input[type=tel],
.request-form input[type=email],
.request-form select,
.request-form textarea{
  font: inherit; font-family: var(--font-body); font-size: 15px;
  padding: 12px 14px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  color: var(--ink);
  outline: none;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.request-form input:focus,
.request-form select:focus,
.request-form textarea:focus{
  border-color: var(--navy);
  box-shadow: 0 0 0 3px rgba(0,38,88,.12);
}
.request-form textarea{ resize: vertical; }
.upload{ position: relative; }
.upload input[type=file]{ position: absolute; inset:0; opacity: 0; cursor: pointer; }
.upload-face{
  display:flex; align-items: center; gap: 12px;
  padding: 16px; border: 1.5px dashed var(--line);
  border-radius: var(--radius);
  color: var(--steel); font-size: 14px;
  transition: border-color .15s ease, background .15s ease;
}
.upload:hover .upload-face{ border-color: var(--navy); background: rgba(0,38,88,.03); }
.upload-face strong{ color: var(--ink); font-weight: 700; }
.form-submit{ justify-content:center; margin-top: 4px; }
.form-fine{
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .1em;
  text-transform: uppercase; color: var(--muted);
  text-align: center;
}
.form-success{ text-align:center; padding: 32px 12px; }
.success-mark{
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--ok); color: #fff;
  display:flex; align-items:center; justify-content:center;
  font-size: 28px; font-weight: 700; margin: 0 auto 16px;
}
.form-success h3{ font-size: 22px; margin-bottom: 8px; }
.form-success p{ color: var(--steel); }
.form-success a{ color: var(--red); }

/* ============ FAQ ============ */
.faq{ background: var(--paper); }
.faq-grid{ display:grid; grid-template-columns: 1fr 1.4fr; gap: 64px; align-items: start; }
.faq-head{ position: static; }
.faq-head .section-sub a{ color: var(--red); border-bottom: 1px solid rgba(181,14,17,.3); }
.faq-list{ display:flex; flex-direction:column; }
.faq-list details{
  border-top: 1px solid var(--line);
  padding: 20px 0;
}
.faq-list details:last-child{ border-bottom: 1px solid var(--line); }
.faq-list summary{
  display:flex; justify-content:space-between; align-items:center; gap: 16px;
  list-style: none; cursor:pointer;
  font-family: var(--font-display); font-weight: 700;
  font-size: 19px; letter-spacing: -.01em; color: var(--ink);
}
.faq-list summary::-webkit-details-marker{ display: none; }
.faq-list .chev{
  width: 24px; height: 24px; flex: 0 0 auto;
  position: relative;
}
.faq-list .chev::before, .faq-list .chev::after{
  content:""; position:absolute; top: 50%; left: 50%;
  width: 12px; height: 2px; background: var(--ink);
  transform: translate(-50%, -50%);
  transition: transform .25s ease;
}
.faq-list .chev::after{ transform: translate(-50%, -50%) rotate(90deg); }
.faq-list details[open] .chev::after{ transform: translate(-50%, -50%) rotate(0deg); }
.faq-list details p{
  margin-top: 12px; padding-right: 40px;
  color: var(--steel); font-size: 15px; line-height: 1.65; max-width: 680px;
}
.faq-list details p a{ color: var(--red); border-bottom: 1px solid rgba(181,14,17,.3); }

/* ============ RESPONSIVE ============ */
@media (max-width: 1080px){
  .site-nav{ display:none; }
  .svc-grid{ grid-template-columns: repeat(2, 1fr); }
  .why-grid{ grid-template-columns: repeat(2, 1fr); }
  .why-item:nth-child(3n){ border-right: 1px solid var(--line); }
  .why-item:nth-child(2n){ border-right: 0; }
  .areas-grid, .request-grid, .faq-grid, .emergency-grid{ grid-template-columns: 1fr; gap: 48px; }
  .areas-copy, .areas-map, .areas-cols{ grid-column: auto; grid-row: auto; }
  .areas-map, .faq-head{ position: static; }
  .section-head.row{ grid-template-columns: 1fr; gap: 16px; }
  .aside-sub{ padding-bottom: 0; }
  .proj-grid{ grid-template-columns: repeat(2, 1fr); }
  .proj-lg{ grid-column: span 2; grid-row: span 1; }
}
@media (max-width: 900px){
  .util-right .util-link:first-child, .util-right .util-sep{ display:none; }
  .hero-grid{ grid-template-columns: 1fr; gap: 32px; padding: 32px 22px 48px; }
  .hero-art{ order:-1; min-height: auto; }
  .art-frame{
    min-height: clamp(260px, 62vw, 420px);
    animation:none;
    border-radius: 0;
    margin: 0 -22px;
    box-shadow:
      0 22px 44px -28px rgba(10,15,28,.55),
      inset 0 0 0 1px rgba(255,255,255,.06);
  }
  .art-photo{ min-height: clamp(232px, 58vw, 390px); }
  .real-hero-photo{ object-position: 58% 48%; }
  .art-tag-tl{ top:12px; left:14px; }
  .art-job{ min-height:300px; }
  .hero-stats{ grid-template-columns: repeat(2, 1fr); row-gap: 16px; }
  .hero-stats > div:nth-child(2){ border-right:0; }
  .footer-grid{ grid-template-columns: 1fr 1fr; gap: 32px; }
  .foot-fine{ flex-direction:column; gap:6px; }
  .header-cta .btn-ghost{ display:none; }
  .mobile-cta{ display:flex; }
  body{ padding-bottom: 80px; }
  .svc-grid{ grid-template-columns: 1fr; }
  .svc{ min-height: 300px; }
  .svc-visual{ opacity:.46; }
  .why-grid{ grid-template-columns: 1fr; }
  .why-item{ border-right: 0 !important; }
  .areas-grid{ gap: 32px; }
  .areas-cols{ grid-template-columns: 1fr; }
  .form-row.two{ grid-template-columns: 1fr; }
  .proj-grid{ grid-template-columns: 1fr; grid-auto-rows: 220px; }
  .proj-lg{ grid-column: span 1; }
  .section{ padding: 64px 0; }
  .emergency, .request{ padding: 64px 0; }
  .areas-map{ padding:16px; }
  .areas-map::after{ inset:16px; }
  .minimal-map{ transform:none; animation:none; }
  .map-label text:first-child{ font-size:20px; }
  .map-label text:last-child,
  .map-legend text,
  .pin text{ font-size:10px; }
}
@media (max-width: 540px){
  .util-left span:last-child{ display:none; }
  .hero-grid{ padding: 0 24px 44px; gap: 30px; }
  .hero-art{ margin: 0 -24px; }
  .art-frame{
    min-height: 268px;
    margin: 0;
    padding: 10px;
    border-radius: 0;
  }
  .art-photo{ min-height: 248px; border-radius: 3px; }
  .job-photo::after{
    background:
      linear-gradient(180deg, rgba(10,15,28,.04), rgba(10,15,28,.22)),
      linear-gradient(90deg, rgba(10,15,28,.06), transparent 54%, rgba(10,15,28,.2));
  }
  .hero-copy{ padding-top: 4px; }
  .hero-title{ font-size: clamp(40px, 11vw, 64px); }
  .header-cta .btn-red{ padding: 10px 12px; font-size:12px; }
  .svc{
    padding: 30px 24px 28px;
    min-height: 320px;
  }
  .svc-chute .svc-visual::before,
  .svc-door .svc-visual::before,
  .svc-cleaning .svc-visual::before{
    right:12px;
    opacity:.8;
  }
}

/* ============ MOTION ============ */
.motion-ready .reveal-item{
  opacity:0;
  transform: translateY(22px);
  transition:
    opacity .75s ease,
    transform .75s cubic-bezier(.16,1,.3,1);
}
.motion-ready .reveal-item.is-visible{
  opacity:1;
  transform: translateY(0);
}
.motion-ready .svc.reveal-item:nth-child(2),
.motion-ready .why-item.reveal-item:nth-child(2),
.motion-ready .proj.reveal-item:nth-child(2){ transition-delay:.06s; }
.motion-ready .svc.reveal-item:nth-child(3),
.motion-ready .why-item.reveal-item:nth-child(3),
.motion-ready .proj.reveal-item:nth-child(3){ transition-delay:.12s; }
.motion-ready .svc.reveal-item:nth-child(4),
.motion-ready .why-item.reveal-item:nth-child(4),
.motion-ready .proj.reveal-item:nth-child(4){ transition-delay:.18s; }
.motion-ready .svc.reveal-item:nth-child(5),
.motion-ready .why-item.reveal-item:nth-child(5),
.motion-ready .proj.reveal-item:nth-child(5){ transition-delay:.24s; }
.motion-ready .svc.reveal-item:nth-child(6),
.motion-ready .why-item.reveal-item:nth-child(6),
.motion-ready .proj.reveal-item:nth-child(6){ transition-delay:.3s; }

@media (prefers-reduced-motion: reduce){
  *,
  *::before,
  *::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    scroll-behavior:auto !important;
    transition-duration:.01ms !important;
  }
  .motion-ready .reveal-item{
    opacity:1;
    transform:none;
  }
}

@keyframes heroFadeUp{
  from{
    opacity:0;
    transform: translateY(20px);
  }
  to{
    opacity:1;
    transform: translateY(0);
  }
}
