/*
Theme Name: APLA Construction v2
Theme URI: https://aplaconstruction.com
Author: APLA Construction
Description: High-end editorial design for APLA Construction
Version: 2.0
Text Domain: apla-construction-v2
*/

/* =====================================================================
   TOKENS
   ===================================================================== */
@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Mono:wght@400;500&family=DM+Sans:ital,wght@0,300;0,400;0,500;1,300&display=swap');

:root {
  --ink:        #0E0E0C;
  --ink-70:     rgba(14,14,12,0.70);
  --ink-50:     rgba(14,14,12,0.50);
  --ink-30:     rgba(14,14,12,0.30);
  --ink-12:     rgba(14,14,12,0.12);
  --bone:       #F2EEE6;
  --bone-soft:  #EDE9E1;
  --paper:      #F7F4EF;
  --clay:       #B5481F;
  --hi-vis:     #F5C400;
  --eucalyptus: #5C6B5A;

  --font-display: 'DM Serif Display', Georgia, serif;
  --font-mono:    'DM Mono', 'Courier New', monospace;
  --font-body:    'DM Sans', system-ui, sans-serif;

  --dur-fast: 180ms;
  --dur-med:  320ms;
  --dur-slow: 560ms;
  --ease-default: cubic-bezier(0.25, 0.1, 0.25, 1);
}

/* =====================================================================
   RESET
   ===================================================================== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { background: var(--bone); color: var(--ink); font-family: var(--font-body); overflow-x: hidden; }
img { max-width: 100%; height: auto; display: block; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; }
button { cursor: pointer; font-family: inherit; }

/* =====================================================================
   LAYOUT
   ===================================================================== */
.container { max-width: 1440px; margin: 0 auto; padding: 0 80px; }
.section { padding: 160px 0; }
.section--tight { padding: 96px 0; }
.section--ink { background: var(--ink); color: var(--bone); }
.section--paper { background: var(--paper); }

/* =====================================================================
   TYPOGRAPHY UTILITIES
   ===================================================================== */
.eyebrow {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--clay);
}
.eyebrow--bone { color: var(--hi-vis); }
.eyebrow--muted { color: var(--ink-50); }

.section-head { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: end; margin-bottom: 80px; }
.section-head__no { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-50); }
.section-head__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(40px, 6vw, 96px);
  line-height: 0.95;
  letter-spacing: -0.025em;
  margin: 16px 0 0;
}
.section-head__title em { font-style: italic; color: var(--clay); }
.section-head__lede { font-family: var(--font-body); font-size: 17px; line-height: 1.55; color: var(--ink-70); max-width: 50ch; }
.section--ink .section-head__no { color: rgba(242,238,230,0.6); }
.section--ink .section-head__lede { color: rgba(242,238,230,0.75); }

/* =====================================================================
   BUTTONS
   ===================================================================== */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.10em; text-transform: uppercase;
  padding: 14px 22px; border: 1px solid transparent; border-radius: 0;
  transition: background var(--dur-fast) var(--ease-default), color var(--dur-fast) var(--ease-default), border-color var(--dur-fast) var(--ease-default);
}
.btn--accent { background: var(--hi-vis); color: var(--ink); border-color: var(--hi-vis); }
.btn--accent:hover { background: var(--bone); border-color: var(--bone); }
.btn--ghost { background: transparent; color: var(--bone); border-color: rgba(242,238,230,0.4); }
.btn--ghost:hover { background: rgba(242,238,230,0.1); }
.btn--ink { background: var(--ink); color: var(--bone); border-color: var(--ink); }
.btn--ink:hover { background: transparent; color: var(--ink); }

/* =====================================================================
   REVEAL ON SCROLL
   ===================================================================== */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity 700ms var(--ease-default), transform 700ms var(--ease-default); }
.reveal.in { opacity: 1; transform: translateY(0); }
.reveal--d1 { transition-delay: 80ms; }
.reveal--d2 { transition-delay: 160ms; }
.reveal--d3 { transition-delay: 240ms; }
.reveal--d4 { transition-delay: 320ms; }

/* =====================================================================
   NAV
   ===================================================================== */
#site-header {
  position: fixed; top: 0; left: 0; right: 0;
  width: 100%;
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 48px;
  background: rgba(14,14,12,0.15);
  color: var(--bone);
  backdrop-filter: blur(0px);
  z-index: 100;
  transition: background var(--dur-med) var(--ease-default), backdrop-filter var(--dur-med) var(--ease-default), padding var(--dur-med) var(--ease-default);
  border-bottom: 1px solid transparent;
}
#site-header.is-stuck {
  background: rgba(14,14,12,0.95);
  backdrop-filter: blur(16px);
  border-bottom-color: rgba(242,238,230,0.08);
  padding: 10px 48px;
}
.nav__left { display: flex; align-items: center; gap: 32px; }
.nav__brand { display: flex; align-items: center; text-decoration: none; }
.nav__logo {
  height: 54px; width: auto; display: block;
  transition: height var(--dur-med) var(--ease-default);
  object-fit: contain;
}
#site-header.is-stuck .nav__logo { height: 42px; }
.nav__links { display: flex; gap: 22px; }
.nav__links a { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.10em; text-transform: uppercase; color: rgba(242,238,230,0.8); transition: color var(--dur-fast) var(--ease-default); }
.nav__links a:hover { color: var(--hi-vis); }
.nav__cta {
  font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.10em; text-transform: uppercase;
  padding: 11px 18px; background: var(--hi-vis); color: var(--ink); border: 0; border-radius: 999px;
  display: inline-flex; align-items: center; gap: 8px;
  transition: background var(--dur-fast) var(--ease-default);
}
.nav__cta:hover { background: var(--bone); }

.nav-toggle { display: none; flex-direction: column; gap: 5px; background: none; border: none; padding: 4px; }
.nav-toggle span { display: block; width: 22px; height: 2px; background: var(--bone); border-radius: 1px; }

/* =====================================================================
   HERO
   ===================================================================== */
.hero {
  position: relative; height: 100vh; min-height: 720px; overflow: hidden;
  background: var(--ink); color: var(--bone);
}
.hero__bg {
  position: absolute; inset: -10% -2% -2% -2%;
  background-size: cover; background-position: center;
  background-image: url('https://images.unsplash.com/photo-1600596542815-ffad4c1539a9?auto=format&fit=crop&w=2400&q=80');
  filter: brightness(0.52) saturate(0.8);
  will-change: transform;
}
.hero__bg::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(14,14,12,0.4) 0%, rgba(14,14,12,0.1) 40%, rgba(14,14,12,0.88) 100%);
}
.hero__topmeta {
  position: absolute; top: 76px; right: 80px;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(242,238,230,0.65); z-index: 2;
}
.hero__content {
  position: relative; z-index: 2; height: 100%;
  max-width: 1440px; margin: 0 auto; padding: 0 80px;
  display: flex; flex-direction: column; justify-content: flex-end; padding-bottom: 96px;
}
.hero__eyebrow { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--hi-vis); margin-bottom: 16px; display: none; }
.hero__title {
  font-family: var(--font-display);
  font-size: clamp(56px, 10vw, 144px);
  line-height: 0.92; letter-spacing: -0.03em;
  color: var(--bone); max-width: 14ch;
  font-weight: 400;
}
.hero__title em { font-style: italic; color: var(--hi-vis); }
.hero__sub { margin-top: 28px; font-family: var(--font-body); font-size: 18px; line-height: 1.5; color: rgba(242,238,230,0.82); max-width: 56ch; }
.hero__row { margin-top: 36px; display: flex; align-items: center; gap: 24px; flex-wrap: wrap; }
.hero__scroll {
  position: absolute; bottom: 28px; left: 80px; right: 80px;
  display: flex; justify-content: space-between; align-items: flex-end;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(242,238,230,0.65); z-index: 2;
}
.hero__scroll-line { width: 2px; height: 56px; background: var(--hi-vis); animation: scrollPulse 2200ms ease-in-out infinite; }
@keyframes scrollPulse {
  0%   { transform: scaleY(0.2); transform-origin: top; }
  50%  { transform: scaleY(1);   transform-origin: top; }
  50.01% { transform-origin: bottom; }
  100% { transform: scaleY(0.2); transform-origin: bottom; }
}

/* =====================================================================
   STATS
   ===================================================================== */
.stats { background: var(--ink); color: var(--bone); padding: 96px 0; }
.stats__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; }
.stat { padding-top: 14px; border-top: 2px solid rgba(242,238,230,0.2); }
.stat__num {
  font-family: var(--font-display);
  font-size: clamp(52px, 7vw, 88px);
  font-weight: 400; line-height: 1; letter-spacing: -0.04em;
  color: var(--bone);
}
.stat__num em { font-style: normal; color: var(--hi-vis); }
.stat__lbl { margin-top: 10px; font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.10em; text-transform: uppercase; opacity: 0.6; }

/* =====================================================================
   SERVICES GRID (12 services)
   ===================================================================== */
.svc12 { background: var(--bone); }
.svc12__grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  border-top: 2px solid var(--ink); border-left: 1px solid var(--ink-12);
}
.svc12__cell {
  position: relative; padding: 28px 22px 24px; min-height: 190px;
  border-right: 1px solid var(--ink-12); border-bottom: 1px solid var(--ink-12);
  display: flex; flex-direction: column; justify-content: space-between;
  cursor: pointer; text-decoration: none; color: var(--ink); overflow: hidden;
  transition: background var(--dur-med) var(--ease-default), color var(--dur-med) var(--ease-default);
}
.svc12__cell:hover { background: var(--ink); color: var(--bone); }
.svc12__cell:hover .svc12__no { color: var(--hi-vis); }
.svc12__cell:hover .svc12__more { color: var(--hi-vis); }
.svc12__no { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.10em; color: var(--ink-50); transition: color var(--dur-med) var(--ease-default); }
.svc12__name { font-family: var(--font-display); font-size: 22px; font-weight: 400; letter-spacing: -0.01em; line-height: 1.05; margin-top: 6px; }
.svc12__more { margin-top: auto; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.10em; text-transform: uppercase; transition: color var(--dur-med) var(--ease-default); padding-top: 12px; }

/* =====================================================================
   PROCESS (sticky)
   ===================================================================== */
.process { background: var(--ink); color: var(--bone); position: relative; }
.process__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; padding: 160px 80px; max-width: 1440px; margin: 0 auto; }
.process__sticky { position: sticky; top: 120px; height: max-content; }
.process__pretitle { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--hi-vis); }
.process__title { font-family: var(--font-display); font-size: clamp(48px, 6vw, 88px); line-height: 0.95; letter-spacing: -0.025em; margin: 16px 0 24px; font-weight: 400; }
.process__title em { font-style: italic; color: var(--hi-vis); }
.process__desc { font-family: var(--font-body); font-size: 16px; line-height: 1.55; color: rgba(242,238,230,0.7); max-width: 44ch; }
.process__progress { margin-top: 32px; display: flex; gap: 8px; }
.process__progress span { flex: 1; height: 3px; background: rgba(242,238,230,0.15); transition: background var(--dur-med) var(--ease-default); }
.process__progress span.active { background: var(--hi-vis); }
.process__steps { display: flex; flex-direction: column; gap: 96px; padding: 8px 0; }
.process__step { padding-bottom: 24px; border-bottom: 1px solid rgba(242,238,230,0.15); transition: opacity var(--dur-slow) var(--ease-default), border-color var(--dur-slow) var(--ease-default); opacity: 0.4; }
.process__step.active { opacity: 1; border-bottom-color: var(--hi-vis); }
.process__step-no { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.18em; color: var(--hi-vis); margin-bottom: 12px; }
.process__step-name { font-family: var(--font-display); font-size: 34px; letter-spacing: -0.02em; margin: 0 0 12px; font-weight: 400; }
.process__step-body { font-family: var(--font-body); font-size: 16px; line-height: 1.55; color: rgba(242,238,230,0.72); max-width: 48ch; }

/* =====================================================================
   HORIZONTAL GALLERY
   ===================================================================== */
.hgallery { background: var(--bone); position: relative; }
.hgallery__sticky { position: sticky; top: 0; height: 100vh; overflow: hidden; display: flex; align-items: center; }
.hgallery__track { display: flex; gap: 32px; padding: 0 80px; will-change: transform; align-items: center; height: 100%; }
.hgallery__intro { flex-shrink: 0; width: 460px; padding-right: 32px; }
.hgallery__intro .eyebrow { margin-bottom: 16px; display: block; }
.hgallery__intro h2 { font-family: var(--font-display); font-size: clamp(56px, 8vw, 88px); line-height: 0.95; letter-spacing: -0.03em; margin-bottom: 16px; font-weight: 400; }
.hgallery__intro h2 em { font-style: italic; color: var(--clay); }
.hgallery__intro p { font-family: var(--font-body); font-size: 16px; line-height: 1.55; color: var(--ink-70); max-width: 40ch; }
.hgallery__card { flex-shrink: 0; width: 520px; height: 70vh; max-height: 640px; display: flex; flex-direction: column; gap: 12px; }
.hgallery__photo { flex: 1; background-size: cover; background-position: center; transition: transform var(--dur-slow) var(--ease-default); overflow: hidden; }
.hgallery__card:hover .hgallery__photo { transform: scale(1.02); }
.hgallery__meta { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--ink); }
.hgallery__name { font-family: var(--font-display); font-size: 20px; letter-spacing: -0.01em; color: var(--ink); text-transform: none; font-weight: 400; }
.hgallery__tags { color: var(--ink-50); font-size: 10px; }
.hgallery__progress { position: absolute; left: 80px; right: 80px; bottom: 32px; display: flex; align-items: center; gap: 16px; font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--ink-70); pointer-events: none; }
.hgallery__progress-bar { flex: 1; height: 2px; background: var(--ink-12); position: relative; }
.hgallery__progress-bar::after { content: ""; position: absolute; inset: 0 auto 0 0; width: var(--p, 0%); background: var(--ink); transition: width 80ms linear; }

/* =====================================================================
   BEFORE / AFTER
   ===================================================================== */
.ba { background: var(--bone); }
.ba__frame { position: relative; height: 70vh; min-height: 520px; max-height: 760px; overflow: hidden; user-select: none; cursor: ew-resize; }
.ba__img { position: absolute; inset: 0; background-size: cover; background-position: center; }
.ba__after { clip-path: inset(0 0 0 var(--split, 50%)); }
.ba__handle { position: absolute; top: 0; bottom: 0; left: var(--split, 50%); width: 2px; background: var(--hi-vis); transform: translateX(-1px); pointer-events: none; }
.ba__handle::before { content: ""; position: absolute; left: 50%; transform: translateX(-50%); width: 56px; height: 56px; border-radius: 999px; background: var(--hi-vis); top: 50%; margin-top: -28px; }
.ba__handle::after { content: ""; position: absolute; left: 50%; transform: translateX(-50%); width: 16px; height: 16px; border-radius: 999px; background: var(--ink); top: 50%; margin-top: -8px; }
.ba__label { position: absolute; top: 32px; font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.18em; text-transform: uppercase; padding: 6px 12px; background: var(--ink); color: var(--bone); }
.ba__label--before { left: 32px; }
.ba__label--after { right: 32px; }

/* =====================================================================
   MARQUEE
   ===================================================================== */
.marquee { background: var(--bone-soft); border-top: 1px solid var(--ink-12); border-bottom: 1px solid var(--ink-12); padding: 28px 0; overflow: hidden; }
.marquee__track { display: flex; gap: 64px; animation: marqueeScroll 36s linear infinite; white-space: nowrap; }
.marquee__item { font-family: var(--font-display); font-size: 28px; letter-spacing: -0.02em; color: var(--ink); display: inline-flex; align-items: center; gap: 24px; font-weight: 400; }
.marquee__item::after { content: "—"; color: var(--ink-30); }
@keyframes marqueeScroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

/* =====================================================================
   TESTIMONIAL
   ===================================================================== */
.quote-slab { background: var(--paper); padding: 160px 0; }
.quote { font-family: var(--font-display); font-size: clamp(32px, 4.5vw, 60px); line-height: 1.08; letter-spacing: -0.02em; color: var(--ink); max-width: 24ch; font-weight: 400; }
.quote__attribution { display: flex; gap: 14px; align-items: center; margin-top: 40px; }
.quote__avatar { width: 52px; height: 52px; border-radius: 999px; background: var(--ink); }
.quote__name { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--ink); }
.quote__role { font-family: var(--font-mono); font-size: 12px; color: var(--ink-50); margin-top: 2px; }

/* =====================================================================
   CTA / FOOTER
   ===================================================================== */
.footer { background: var(--ink); color: var(--bone); padding: 120px 0 32px; }
.footer__grid { display: grid; grid-template-columns: 1.2fr 1fr 0.6fr; gap: 64px; padding-bottom: 80px; border-bottom: 1px solid rgba(242,238,230,0.12); }
.footer__cta-title { font-family: var(--font-display); font-size: clamp(44px, 5.5vw, 80px); line-height: 0.95; letter-spacing: -0.025em; margin: 0 0 24px; max-width: 14ch; font-weight: 400; }
.footer__cta-title em { font-style: italic; color: var(--hi-vis); }
.footer__meta { margin-top: 40px; display: flex; flex-direction: column; gap: 6px; font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(242,238,230,0.55); }

.footer__form { display: grid; grid-template-columns: 1fr 1fr; gap: 16px 20px; }
.field { display: flex; flex-direction: column; gap: 6px; }
.field--wide { grid-column: 1 / -1; }
.field label { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.10em; text-transform: uppercase; color: rgba(242,238,230,0.55); }
.field input, .field select, .field textarea {
  background: transparent; border: 0; border-bottom: 1px solid rgba(242,238,230,0.22);
  color: var(--bone); font-family: var(--font-body); font-size: 15px; padding: 8px 0;
  outline: none; border-radius: 0; width: 100%;
}
.field input:focus, .field select:focus, .field textarea:focus { border-color: var(--hi-vis); }
.field select option { color: var(--ink); background: var(--bone); }
.footer__submit {
  grid-column: 1 / -1; background: var(--hi-vis); color: var(--ink);
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.10em; text-transform: uppercase;
  padding: 16px 22px; border: 0; display: inline-flex; align-items: center; justify-content: space-between;
  transition: background var(--dur-fast) var(--ease-default);
  width: 100%;
}
.footer__submit:hover { background: var(--bone); }

.footer__col h5 { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.10em; text-transform: uppercase; color: rgba(242,238,230,0.55); margin: 0 0 18px; font-weight: 500; }
.footer__col ul { display: flex; flex-direction: column; gap: 10px; font-family: var(--font-body); font-size: 15px; }
.footer__col a { transition: color var(--dur-fast) var(--ease-default); color: rgba(242,238,230,0.75); }
.footer__col a:hover { color: var(--hi-vis); }
.footer__bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 32px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.10em; text-transform: uppercase; color: rgba(242,238,230,0.45); }
.footer__wm { font-family: var(--font-display); font-size: 180px; line-height: 0.85; letter-spacing: -0.04em; color: rgba(242,238,230,0.035); margin-top: 80px; padding: 0 80px; user-select: none; }

/* =====================================================================
   TOAST
   ===================================================================== */
.toast { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(20px); background: var(--ink); color: var(--bone); padding: 14px 22px; font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.10em; text-transform: uppercase; opacity: 0; transition: all var(--dur-med) var(--ease-default); border: 1px solid var(--hi-vis); z-index: 200; pointer-events: none; }
.toast.in { opacity: 1; transform: translateX(-50%) translateY(0); }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width: 960px) {
  .container { padding: 0 24px; }
  .section { padding: 96px 0; }
  #site-header { width: 100%; padding: 12px 20px; top: 0; left: 0; transform: none; }
  .nav__links { display: none; }
  .nav-toggle { display: flex; }
  .nav__links.open { display: flex; flex-direction: column; position: fixed; top: 70px; left: 8px; right: 8px; background: rgba(14,14,12,0.96); padding: 24px; gap: 16px; border: 1px solid rgba(242,238,230,0.1); backdrop-filter: blur(12px); }
  .nav__links.open a { font-size: 14px; padding: 8px 0; border-bottom: 1px solid rgba(242,238,230,0.08); }

  .hero__topmeta { top: 68px; right: 24px; font-size: 9px; }
  .hero__content { padding: 0 24px 64px; }
  .hero__sub { font-size: 16px; }
  .hero__scroll { left: 24px; right: 24px; }

  .stats__grid { grid-template-columns: 1fr 1fr; gap: 28px 24px; }
  .section-head { grid-template-columns: 1fr; gap: 16px; margin-bottom: 48px; }
  .svc12__grid { grid-template-columns: 1fr 1fr; }
  .process__inner { grid-template-columns: 1fr; padding: 96px 24px; }
  .process__sticky { position: relative; top: auto; }
  .hgallery__track { padding: 0 24px; }
  .hgallery__intro { width: 78vw; }
  .hgallery__card { width: 78vw; }
  .hgallery__progress { left: 24px; right: 24px; }
  .ba__frame { height: 56vh; min-height: 360px; }
  .footer__grid { grid-template-columns: 1fr; gap: 56px; }
  .footer__form { grid-template-columns: 1fr; }
  .footer__wm { font-size: 80px; padding: 0 24px; }
  .footer__bottom { flex-direction: column; gap: 12px; align-items: flex-start; }
}
@media (max-width: 520px) {
  .svc12__grid { grid-template-columns: 1fr; }
  .stats__grid { grid-template-columns: 1fr; }
}

/* =====================================================================
   SERVICE AREA MAP
   ===================================================================== */
.area { background: #0E0E0C !important; color: #F2EEE6; padding: 160px 0 120px; }
.area__head { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: end; margin-bottom: 64px; }
.area__title { font-family: var(--font-display); font-size: clamp(40px, 6vw, 88px); line-height: 0.95; letter-spacing: -0.025em; margin: 16px 0 0; font-weight: 400; }
.area__title em { font-style: italic; color: var(--hi-vis); }
.area__lede { font-family: var(--font-body); font-size: 17px; line-height: 1.55; color: rgba(242,238,230,0.72); max-width: 50ch; }
.area__layout { display: grid; grid-template-columns: 1.6fr 1fr; gap: 48px; align-items: start; }
.area__map-wrap {
  position: relative; aspect-ratio: 4/3;
  border: 1px solid rgba(242,238,230,0.12);
  background: #0a0a08;
  background-image: linear-gradient(rgba(242,238,230,0.04) 1px, transparent 1px), linear-gradient(90deg, rgba(242,238,230,0.04) 1px, transparent 1px);
  background-size: 32px 32px;
}
.area__map { width: 100%; height: 100%; display: block; }

/* City paths */
.area__city { fill: rgba(242,238,230,0.05); stroke: rgba(242,238,230,0.35); stroke-width: 0.8; transition: fill 180ms ease, stroke 180ms ease; cursor: pointer; }
.area__city:hover, .area__city.is-active { fill: rgba(245,196,0,0.18); stroke: var(--hi-vis); stroke-width: 1.5; }
.area__city.has-built { fill: rgba(181,72,31,0.18); }
.area__city.has-built:hover, .area__city.has-built.is-active { fill: rgba(245,196,0,0.22); }

/* Backdrop (rest of county) */
.area__backdrop path { fill: rgba(242,238,230,0.02); stroke: rgba(242,238,230,0.08); stroke-width: 0.5; pointer-events: none; }

/* Labels */
.area__city-label { fill: rgba(242,238,230,0.45); font-family: var(--font-mono); font-size: 8px; letter-spacing: 0.06em; text-transform: uppercase; pointer-events: none; transition: fill 180ms ease; }
.area__city-label.is-active { fill: var(--hi-vis); }

/* HQ pin */
.area__pin { fill: var(--hi-vis); stroke: var(--ink); stroke-width: 2; }
.area__hq-label { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.10em; text-transform: uppercase; fill: var(--hi-vis); }

/* Chrome */
.area__chrome-tx { font-family: var(--font-mono); font-size: 9px; fill: rgba(242,238,230,0.5); letter-spacing: 0.08em; }

/* Readout panel */
.area__readout {
  padding: 28px;
  background: rgba(242,238,230,0.04) !important;
  border: 1px solid rgba(242,238,230,0.10);
  display: flex; flex-direction: column; gap: 20px;
  min-height: 380px;
  color: #F2EEE6;
}
.area__readout-status { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--hi-vis); }
.area__readout-name { font-family: var(--font-display); font-size: 38px; letter-spacing: -0.02em; line-height: 1; font-weight: 400; }
.area__readout-meta { display: flex; flex-direction: column; gap: 0; font-family: var(--font-mono); font-size: 12px; }
.area__readout-meta div { display: flex; justify-content: space-between; padding: 10px 0; border-bottom: 1px solid rgba(242,238,230,0.08); color: rgba(242,238,230,0.65); }
.area__readout-meta div span:last-child { color: var(--bone); }
.area__readout-blurb { font-family: var(--font-body); font-size: 14px; line-height: 1.6; color: rgba(242,238,230,0.72); flex: 1; }
.area__readout .btn { margin-top: auto; text-decoration: none; }

/* Legend */
.area__legend { display: flex; gap: 22px; margin-top: 24px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(242,238,230,0.5); flex-wrap: wrap; }
.area__legend-swatch { display: inline-block; width: 13px; height: 13px; vertical-align: -2px; margin-right: 7px; border: 1px solid rgba(242,238,230,0.3); }
.area__legend-swatch--built { background: rgba(181,72,31,0.5); }
.area__legend-swatch--active { background: rgba(245,196,0,0.45); border-color: var(--hi-vis); }

@media (max-width: 960px) {
  .area { padding: 96px 0; }
  .area__head { grid-template-columns: 1fr; }
  .area__layout { grid-template-columns: 1fr; }
  .area__readout { min-height: 0; }
  .area__readout-name { font-size: 28px; }
}

/* =====================================================================
   SERVICE DETAIL PAGE
   ===================================================================== */
.svc-hero {
  background: var(--ink); color: var(--bone);
  padding: 180px 0 96px; position: relative; overflow: hidden;
  min-height: 70vh; display: flex; align-items: flex-end;
}
.svc-hero__bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  opacity: 0.35; filter: saturate(0.7);
}
.svc-hero__bg::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(14,14,12,0.4) 0%, rgba(14,14,12,0.96) 100%);
}
.svc-hero__inner { position: relative; z-index: 2; width: 100%; }
.svc-hero__crumb {
  font-family: var(--font-mono); font-size: 11.5px;
  letter-spacing: 0.10em; text-transform: uppercase; color: var(--hi-vis);
  margin-bottom: 20px; display: block;
}
.svc-hero__crumb a { color: var(--hi-vis); transition: color var(--dur-fast) var(--ease-default); }
.svc-hero__crumb a:hover { color: var(--bone); }
.svc-hero__title {
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(56px, 9vw, 128px); line-height: 0.92;
  letter-spacing: -0.03em; margin: 0 0 24px; max-width: 16ch;
  color: var(--bone);
}
.svc-hero__sub {
  font-family: var(--font-body); font-size: 18px; line-height: 1.5;
  color: rgba(242,238,230,0.82); max-width: 60ch;
}
.svc-hero__meta {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 32px; margin-top: 64px; padding-top: 32px;
  border-top: 1px solid rgba(242,238,230,0.15);
}
.svc-hero__meta-item { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; }
.svc-hero__meta-item span { display: block; }
.svc-hero__meta-item span:first-child { color: rgba(242,238,230,0.5); margin-bottom: 8px; font-size: 11px; }
.svc-hero__meta-item span:last-child { color: var(--hi-vis); font-size: 13px; }

.svc-body { background: var(--bone); padding: 120px 0; }
.svc-body__grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; }
.svc-body__lhs h2 { font-family: var(--font-display); font-weight: 400; font-size: 48px; line-height: 0.95; letter-spacing: -0.025em; margin: 14px 0 18px; }
.svc-body__lhs p { font-family: var(--font-body); font-size: 16px; line-height: 1.6; color: var(--ink-70); margin-bottom: 14px; }
.svc-body__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; }
.svc-body__list li { padding: 20px 0; border-bottom: 1px solid var(--ink-12); display: flex; gap: 24px; align-items: baseline; }
.svc-body__list li:last-child { border-bottom: 0; }
.svc-body__list .n { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.10em; color: var(--clay); flex-shrink: 0; width: 32px; }
.svc-body__list .ttl { font-family: var(--font-display); font-size: 20px; font-weight: 400; letter-spacing: -0.01em; flex-shrink: 0; width: 30%; }
.svc-body__list .desc { font-family: var(--font-body); font-size: 14px; line-height: 1.55; color: var(--ink-70); }

.svc-related { background: var(--paper); padding: 96px 0; }
.svc-related h3 { font-family: var(--font-display); font-size: 32px; font-weight: 400; letter-spacing: -0.01em; margin: 0 0 36px; }
.svc-related__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.svc-related__card {
  display: block; padding: 22px 20px; border: 1px solid var(--ink-12);
  background: var(--bone); text-decoration: none; color: var(--ink);
  transition: background var(--dur-fast) var(--ease-default), color var(--dur-fast) var(--ease-default);
}
.svc-related__card:hover { background: var(--ink); color: var(--bone); }
.svc-related__card .n { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.10em; opacity: 0.5; margin-bottom: 8px; }
.svc-related__card .nm { font-family: var(--font-display); font-size: 18px; font-weight: 400; letter-spacing: -0.01em; }

@media (max-width: 960px) {
  .svc-hero { padding: 140px 0 64px; }
  .svc-hero__meta { grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 40px; }
  .svc-body__grid { grid-template-columns: 1fr; gap: 40px; }
  .svc-body__lhs h2 { font-size: 36px; }
  .svc-body__list li { flex-direction: column; gap: 6px; }
  .svc-body__list .ttl, .svc-body__list .n { width: auto; }
  .svc-related__grid { grid-template-columns: 1fr 1fr; }
}
