/* ============================================================
   PIEDMONT PROPERTY INTELLIGENCE — shared styles
   Aesthetic: ground-control / instrument readout, warmed with
   a heritage brass signal accent (brand) in place of amber.
   A warm ember tone is reserved for literal heat/anomaly
   callouts inside the scan visualization only — distinct from
   brand chrome, the same way the dashboard uses terracotta for
   "Action" status apart from the brass brand accent.
   Type: Space Grotesk (display) / IBM Plex Sans (body) /
         IBM Plex Mono (telemetry + data). Logo wordmark uses
         Georgia (serif) inline, independent of site body type.
   ============================================================ */

:root{
  /* surfaces — ink navy, not neutral black */
  --bg:        #0c1220;
  --bg-2:      #121a2c;
  --surface:   #161f33;
  --surface-2: #1c2740;
  --line:      #2a3452;
  --line-soft: #202a42;

  /* ink / text */
  --text:      #eef1f4;
  --text-dim:  #9aa8b6;
  --text-faint:#5f6d7a;

  /* signal accent (brand brass, tuned for dark bg) */
  --amber:     #b08d57;
  --amber-hi:  #c9a876;
  --amber-deep:#8c6d3f;
  --amber-glow: rgba(176,141,87,0.20);

  /* ember — literal heat/anomaly callouts only, never brand chrome */
  --ember:      #e0824f;
  --ember-soft: rgba(224,130,79,0.16);

  /* type */
  --f-display: 'Space Grotesk', system-ui, sans-serif;
  --f-body:    'IBM Plex Sans', system-ui, sans-serif;
  --f-mono:    'IBM Plex Mono', ui-monospace, monospace;
  --f-serif:   Georgia, 'Times New Roman', serif;

  /* rhythm */
  --maxw: 1200px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 3px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--f-body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }

/* selection */
::selection{ background:var(--amber); color:#0c1220; }

/* ---- layout helpers ---- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(72px, 10vw, 130px); position:relative; }
.section--tight{ padding-block:clamp(48px, 6vw, 80px); }

/* ---- eyebrow / labels (mono, tracks the instrument theme) ---- */
.eyebrow{
  font-family:var(--f-mono);
  font-size:12px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--amber);
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin:0 0 22px;
}
.eyebrow::before{
  content:"";
  width:26px; height:1px;
  background:var(--amber);
  opacity:.7;
}

/* ---- headings ---- */
h1,h2,h3{ font-family:var(--f-display); font-weight:600; letter-spacing:-0.015em; line-height:1.05; margin:0; }
.h-xl{ font-size:clamp(2.6rem, 6.4vw, 4.6rem); }
.h-lg{ font-size:clamp(2rem, 4.4vw, 3.1rem); }
.h-md{ font-size:clamp(1.35rem, 2.4vw, 1.7rem); }
.lede{ font-size:clamp(1.05rem, 1.7vw, 1.28rem); color:var(--text-dim); line-height:1.55; max-width:46ch; }

.section-head{ max-width:62ch; margin-bottom:clamp(40px,5vw,64px); }
.section-head .lede{ margin-top:18px; }

/* ---- brand tagline (serif italic, used sparingly) ---- */
.brand-tagline{
  font-family:var(--f-serif); font-style:italic; font-weight:400;
  color:var(--amber-hi); font-size:clamp(1rem, 1.6vw, 1.2rem);
  margin:0 0 22px;
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gutter);
  background:rgba(14,18,22,0);
  border-bottom:1px solid transparent;
  transition:background .3s ease, border-color .3s ease, padding .3s ease;
}
.nav.is-scrolled{
  background:rgba(14,18,22,0.82);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-soft);
  padding-block:12px;
}
.brand{ display:flex; align-items:center; gap:0; }
.brand svg{ height:42px; width:auto; display:block; }
.nav-links{ display:flex; align-items:center; gap:34px; }
.nav-links a{
  font-family:var(--f-mono);
  font-size:12.5px; letter-spacing:.08em; text-transform:uppercase;
  color:var(--text-dim); transition:color .18s ease; position:relative;
}
.nav-links a:hover{ color:var(--text); }
.nav-links a.active{ color:var(--text); }
.nav-cta{
  font-family:var(--f-mono) !important;
  font-size:12.5px !important;
  color:var(--text) !important;
  border:1px solid var(--line);
  padding:9px 16px; border-radius:var(--radius);
  transition:border-color .18s ease, background .18s ease, color .18s ease !important;
}
.nav-cta:hover{ border-color:var(--amber); background:var(--amber-glow); }
.nav-toggle{ display:none; background:none; border:0; color:var(--text); cursor:pointer; padding:6px; }
.nav-toggle svg{ width:24px; height:24px; }

@media (max-width:860px){
  .nav-links{
    position:fixed; inset:0 0 0 auto; width:min(78vw,320px);
    flex-direction:column; align-items:flex-start; justify-content:center;
    gap:26px; padding:40px var(--gutter);
    background:var(--bg-2); border-left:1px solid var(--line);
    transform:translateX(100%); transition:transform .32s cubic-bezier(.4,0,.2,1);
  }
  .nav-links.open{ transform:translateX(0); }
  .nav-toggle{ display:inline-flex; z-index:101; }
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--f-mono); font-size:13px; letter-spacing:.06em;
  padding:15px 26px; border-radius:var(--radius);
  cursor:pointer; border:1px solid transparent;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
  will-change:transform;
}
.btn:hover{ transform:translateY(-2px); }
.btn:active{ transform:translateY(0); }
.btn-primary{
  background:var(--amber); color:#0c1220; font-weight:600;
  box-shadow:0 0 0 rgba(229,138,52,0);
}
.btn-primary:hover{ background:var(--amber-hi); box-shadow:0 14px 40px -12px var(--amber-glow); }
.btn-primary .arrow{ transition:transform .2s ease; }
.btn-primary:hover .arrow{ transform:translateX(4px); }
.btn-ghost{ border-color:var(--line); color:var(--text); }
.btn-ghost:hover{ border-color:var(--amber); color:var(--amber-hi); }
:focus-visible{ outline:2px solid var(--amber); outline-offset:3px; }

/* ============================================================
   HERO  (the signature moment)
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; padding-top:96px; overflow:hidden; }
.hero-grid{
  display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(30px,5vw,72px);
  align-items:center; width:100%;
}
.hero-copy{ position:relative; z-index:2; }
.hero h1{ margin-bottom:26px; }
.hero h1 .accent{ color:var(--amber); }
.hero .lede{ margin-bottom:38px; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; }

/* ambient grid + vignette behind hero */
.hero::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(var(--line-soft) 1px, transparent 1px),
    linear-gradient(90deg, var(--line-soft) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 90% 70% at 60% 40%, #000 20%, transparent 78%);
  opacity:.5;
}
.hero::after{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(ellipse 60% 50% at 85% 20%, var(--amber-glow), transparent 70%);
}

/* --- SCAN VISUAL --- */
.scanviz{ position:relative; z-index:1; }
.scanviz svg{ width:100%; height:auto; overflow:visible; }
.scan-sweep{ animation:scan 5.5s cubic-bezier(.65,0,.35,1) infinite; }
@keyframes scan{
  0%   { transform:translateY(0);    opacity:0; }
  8%   { opacity:1; }
  50%  { transform:translateY(206px); opacity:1; }
  58%  { opacity:0; }
  100% { transform:translateY(0);    opacity:0; }
}
.anomaly-pulse{ transform-origin:center; animation:pulse 2.6s ease-in-out infinite; }
@keyframes pulse{ 0%,100%{ opacity:.35; } 50%{ opacity:1; } }
.tick-live{ animation:flick 3.2s steps(1) infinite; }
@keyframes flick{ 0%,100%{ opacity:1; } 48%{ opacity:.55; } }

@media (prefers-reduced-motion: reduce){
  .scan-sweep, .anomaly-pulse, .tick-live{ animation:none; }
  .scan-sweep{ transform:translateY(120px); opacity:1; }
}

@media (max-width:900px){
  .hero-grid{ grid-template-columns:1fr; }
  .scanviz{ max-width:440px; margin-inline:auto; order:-1; }
  .hero{ min-height:auto; padding-block:130px 70px; }
}

/* ============================================================
   SPEC STRIP  (mono capability readout)
   ============================================================ */
.specstrip{ border-block:1px solid var(--line); background:var(--bg-2); }
.specstrip .wrap{ display:grid; grid-template-columns:repeat(4,1fr); }
.spec{ padding:30px var(--gutter); border-left:1px solid var(--line-soft); }
.spec:first-child{ border-left:0; }
.spec .num{ font-family:var(--f-display); font-size:2rem; font-weight:600; color:var(--text); line-height:1; }
.spec .num .unit{ color:var(--amber); font-size:1.1rem; }
.spec .cap{ font-family:var(--f-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--text-faint); margin-top:12px; }
@media (max-width:760px){
  .specstrip .wrap{ grid-template-columns:repeat(2,1fr); }
  .spec{ padding:24px var(--gutter); }
  .spec:nth-child(odd){ border-left:0; }
  .spec:nth-child(3),.spec:nth-child(4){ border-top:1px solid var(--line-soft); }
}

/* ============================================================
   USE CASES
   ============================================================ */
.cases{ display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.case{
  position:relative; background:var(--surface);
  border:1px solid var(--line); border-radius:var(--radius);
  padding:36px 34px 34px; overflow:hidden;
  transition:border-color .25s ease, transform .25s ease, background .25s ease;
}
.case::before{
  content:""; position:absolute; top:0; left:0; width:100%; height:2px;
  background:linear-gradient(90deg, var(--amber), transparent);
  transform:scaleX(0); transform-origin:left; transition:transform .35s ease;
}
.case:hover{ border-color:var(--line); transform:translateY(-4px); background:var(--surface-2); }
.case:hover::before{ transform:scaleX(1); }
.case .code{ font-family:var(--f-mono); font-size:12px; letter-spacing:.16em; color:var(--amber); }
.case h3{ font-size:1.42rem; margin:18px 0 12px; }
.case p{ color:var(--text-dim); font-size:15.5px; margin:0 0 22px; }
.case .tags{ display:flex; flex-wrap:wrap; gap:8px; }
.case .tags span{
  font-family:var(--f-mono); font-size:11px; letter-spacing:.05em;
  color:var(--text-dim); border:1px solid var(--line);
  padding:5px 10px; border-radius:100px;
}
@media (max-width:760px){ .cases{ grid-template-columns:1fr; } }

/* ============================================================
   PROCESS  (real sequence → numbering earns its place)
   ============================================================ */
.process{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.step{ padding:36px 30px 40px; border-left:1px solid var(--line-soft); position:relative; }
.step:first-child{ border-left:0; }
.step .idx{ font-family:var(--f-mono); font-size:12px; color:var(--amber); letter-spacing:.2em; }
.step h3{ font-size:1.3rem; margin:20px 0 12px; }
.step p{ color:var(--text-dim); font-size:14.5px; margin:0; }
.step .rule{ height:2px; width:34px; background:var(--amber); margin-top:22px; opacity:.5; }
@media (max-width:860px){
  .process{ grid-template-columns:1fr 1fr; }
  .step:nth-child(odd){ border-left:0; }
  .step:nth-child(3),.step:nth-child(4){ border-top:1px solid var(--line-soft); }
}
@media (max-width:520px){
  .process{ grid-template-columns:1fr; }
  .step{ border-left:0; border-top:1px solid var(--line-soft); }
  .step:first-child{ border-top:0; }
}

/* ============================================================
   VALUE / WHY  (split)
   ============================================================ */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,6vw,90px); align-items:center; }
.valuelist{ list-style:none; margin:0; padding:0; }
.valuelist li{ padding:26px 0; border-top:1px solid var(--line); display:grid; grid-template-columns:auto 1fr; gap:22px; align-items:start; }
.valuelist li:last-child{ border-bottom:1px solid var(--line); }
.valuelist .vk{ font-family:var(--f-mono); font-size:12px; color:var(--amber); letter-spacing:.1em; padding-top:4px; white-space:nowrap; }
.valuelist h3{ font-size:1.18rem; margin:0 0 6px; }
.valuelist p{ margin:0; color:var(--text-dim); font-size:15px; }
@media (max-width:860px){ .split{ grid-template-columns:1fr; } }

/* deliverables mini-cards */
.deliv{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.deliv .d{ border:1px solid var(--line); border-radius:var(--radius); padding:22px; background:var(--bg-2); }
.deliv .d .dt{ font-family:var(--f-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--amber); }
.deliv .d h4{ font-family:var(--f-display); font-weight:500; font-size:1.05rem; margin:12px 0 6px; }
.deliv .d p{ margin:0; font-size:13.5px; color:var(--text-dim); }

/* ============================================================
   COMPLIANCE RIBBON
   ============================================================ */
.ribbon{ border-block:1px solid var(--line); background:var(--bg-2); }
.ribbon .wrap{ display:flex; flex-wrap:wrap; gap:14px 40px; align-items:center; padding-block:26px; }
.ribbon .item{ display:flex; align-items:center; gap:12px; font-family:var(--f-mono); font-size:12.5px; letter-spacing:.06em; color:var(--text-dim); }
.ribbon .item svg{ width:18px; height:18px; color:var(--amber); flex:none; }

/* ============================================================
   CTA BAND
   ============================================================ */
.ctaband{ position:relative; overflow:hidden; }
.ctaband .wrap{ text-align:center; position:relative; z-index:1; }
.ctaband h2{ margin-bottom:20px; }
.ctaband .lede{ margin:0 auto 34px; }
.ctaband::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(ellipse 50% 80% at 50% 120%, var(--amber-glow), transparent 70%);
}

/* ============================================================
   CONTACT / FORM
   ============================================================ */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,6vw,80px); }
.form{ display:grid; gap:18px; }
.field{ display:grid; gap:8px; }
.field label{ font-family:var(--f-mono); font-size:11.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--text-dim); }
.field input, .field select, .field textarea{
  font-family:var(--f-body); font-size:15px; color:var(--text);
  background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius);
  padding:13px 15px; transition:border-color .18s ease, background .18s ease;
  width:100%;
}
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--amber); background:var(--surface); }
.field textarea{ resize:vertical; min-height:120px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.form .btn{ justify-self:start; margin-top:6px; }
.form-note{ font-family:var(--f-mono); font-size:11.5px; color:var(--text-faint); line-height:1.6; }
.form-status{ font-family:var(--f-mono); font-size:13px; padding:14px 16px; border-radius:var(--radius); border:1px solid var(--amber); background:var(--amber-glow); color:var(--amber-hi); display:none; }
.form-status.show{ display:block; }

.contact-detail{ border-top:1px solid var(--line); padding-top:22px; margin-top:4px; }
.contact-detail .k{ font-family:var(--f-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--text-faint); margin-bottom:6px; }
.contact-detail .v{ font-size:16px; color:var(--text); }
.contact-detail + .contact-detail{ margin-top:26px; }
.placeholder-flag{
  font-family:var(--f-mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--amber-deep); background:rgba(179,89,26,.14); border:1px solid rgba(179,89,26,.4);
  padding:2px 7px; border-radius:100px; margin-left:8px; vertical-align:middle;
}
@media (max-width:800px){ .contact-grid{ grid-template-columns:1fr; } .field-row{ grid-template-columns:1fr; } }

/* ============================================================
   GENERIC PAGE HERO (about / contact)
   ============================================================ */
.pagehero{ padding-top:150px; padding-bottom:24px; position:relative; }
.pagehero::after{
  content:""; position:absolute; inset:0; z-index:-1; pointer-events:none;
  background:radial-gradient(ellipse 50% 60% at 80% 0%, var(--amber-glow), transparent 65%);
}
.pagehero h1{ margin-bottom:20px; }

.prose{ max-width:64ch; }
.prose p{ color:var(--text-dim); margin:0 0 20px; }
.prose h2{ font-size:1.5rem; margin:44px 0 16px; }
.prose strong{ color:var(--text); font-weight:600; }

/* ============================================================
   FOOTER
   ============================================================ */
.foot{ border-top:1px solid var(--line); background:var(--bg-2); }
.foot .wrap{ display:grid; grid-template-columns:2fr 1fr 1fr; gap:40px; padding-block:64px 40px; }
.foot .brand svg{ height:38px; }
.foot .tag{ color:var(--text-faint); font-size:14px; margin-top:18px; max-width:34ch; }
.foot h5{ font-family:var(--f-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--text-faint); margin:0 0 16px; font-weight:400; }
.foot ul{ list-style:none; margin:0; padding:0; display:grid; gap:11px; }
.foot ul a{ color:var(--text-dim); font-size:14.5px; transition:color .16s ease; }
.foot ul a:hover{ color:var(--amber-hi); }
.foot-base{ border-top:1px solid var(--line-soft); }
.foot-base .wrap{ display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; padding-block:22px; grid-template-columns:none; }
.foot-base span{ font-family:var(--f-mono); font-size:11.5px; color:var(--text-faint); letter-spacing:.04em; }
@media (max-width:760px){ .foot .wrap{ grid-template-columns:1fr 1fr; } .foot .brand{ grid-column:1/-1; } }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s cubic-bezier(.2,.7,.3,1), transform .7s cubic-bezier(.2,.7,.3,1); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

/* ============================================================
   CAPABILITY HIGHLIGHTS  (lead-in band above the use cases)
   ============================================================ */
.highlights{
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
  margin-bottom:44px;
}
.hl{
  border:1px solid var(--line); border-radius:var(--radius);
  background:linear-gradient(180deg, var(--surface), var(--bg-2));
  padding:26px 24px;
}
.hl .hk{ display:flex; align-items:center; gap:11px; margin-bottom:14px; }
.hl .hk svg{ width:20px; height:20px; color:var(--amber); flex:none; }
.hl .hk span{ font-family:var(--f-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--text-faint); }
.hl h3{ font-family:var(--f-display); font-weight:500; font-size:1.12rem; line-height:1.25; margin:0; }
.hl h3 em{ color:var(--amber); font-style:normal; }
@media (max-width:860px){ .highlights{ grid-template-columns:1fr; gap:14px; } }

/* ============================================================
   WHAT THE RESULTS DRIVE  (uses strip inside value section)
   ============================================================ */
.uses{ border-top:1px solid var(--line); margin-top:clamp(48px,6vw,72px); padding-top:clamp(40px,5vw,56px); }
.uses-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:32px; }
.use{ display:grid; grid-template-columns:auto 1fr; gap:16px; align-items:start; }
.use .un{ font-family:var(--f-mono); font-size:12px; color:var(--amber); letter-spacing:.1em; padding-top:3px; }
.use h4{ font-family:var(--f-display); font-weight:500; font-size:1.05rem; margin:0 0 5px; }
.use p{ margin:0; font-size:14px; color:var(--text-dim); }
@media (max-width:860px){ .uses-grid{ grid-template-columns:1fr; gap:22px; } }

/* ============================================================
   THREE SERVICES  (overview grid — three distinct offerings)
   ============================================================ */
.services{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.svc{
  position:relative; display:flex; flex-direction:column;
  background:linear-gradient(180deg, var(--surface), var(--bg-2));
  border:1px solid var(--line); border-radius:var(--radius);
  padding:34px 30px 30px; overflow:hidden;
  transition:border-color .25s ease, transform .25s ease;
}
.svc::before{
  content:""; position:absolute; top:0; left:0; width:100%; height:2px;
  background:linear-gradient(90deg, var(--amber), transparent);
  transform:scaleX(0); transform-origin:left; transition:transform .35s ease;
}
.svc:hover{ transform:translateY(-4px); border-color:var(--amber-deep); }
.svc:hover::before{ transform:scaleX(1); }
.svc-head{ display:flex; align-items:baseline; justify-content:space-between; gap:12px; margin-bottom:20px; }
.svc-no{ font-family:var(--f-display); font-weight:600; font-size:2.4rem; line-height:1; color:var(--amber); }
.svc-tier{ font-family:var(--f-mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--bg); background:var(--amber); padding:4px 9px; border-radius:100px; }
.svc-tier.is-support{ color:var(--amber-hi); background:transparent; border:1px solid var(--amber-deep); }
.svc h3{ font-family:var(--f-display); font-weight:600; font-size:1.3rem; line-height:1.15; margin:0 0 12px; }
.svc .svc-lede{ color:var(--text-dim); font-size:14.5px; margin:0 0 22px; }
.svc ul{ list-style:none; margin:0 0 24px; padding:0; display:grid; gap:9px; flex:1; }
.svc ul li{ font-family:var(--f-mono); font-size:12px; color:var(--text-dim); letter-spacing:.02em; padding-left:16px; position:relative; }
.svc ul li::before{ content:"—"; position:absolute; left:0; color:var(--amber); }
.svc-link{ font-family:var(--f-mono); font-size:12.5px; letter-spacing:.05em; color:var(--amber-hi); display:inline-flex; align-items:center; gap:8px; margin-top:auto; }
.svc-link .arrow{ transition:transform .2s ease; }
.svc:hover .svc-link .arrow{ transform:translateX(4px); }
@media (max-width:860px){ .services{ grid-template-columns:1fr; gap:16px; } }

/* service-section divider label (keeps the three deep-dives visually parallel) */
.svc-marker{ font-family:var(--f-mono); font-size:12px; letter-spacing:.22em; text-transform:uppercase; color:var(--amber); display:inline-flex; align-items:center; gap:10px; }
.svc-marker::before{ content:""; width:26px; height:1px; background:var(--amber); opacity:.7; }
