  /* Avenir Next — the live truit.io typeface (self-hosted from the brand's own font files).
     Faces available: Regular 400, Demi 600, Bold 700, Italic. Headings requesting 800/900
     map to the Bold 700 face (nearest), no faux-bold synthesis. */
  @font-face {
    font-family: "Avenir Next"; font-style: normal; font-weight: 400; font-display: swap;
    src: url("/assets/fonts/AvenirNextLTPro-Regular.woff2") format("woff2"),
         url("/assets/fonts/AvenirNextLTPro-Regular.woff") format("woff");
  }
  @font-face {
    font-family: "Avenir Next"; font-style: italic; font-weight: 400; font-display: swap;
    src: url("/assets/fonts/AvenirNextLTPro-It.woff2") format("woff2"),
         url("/assets/fonts/AvenirNextLTPro-It.woff") format("woff");
  }
  @font-face {
    font-family: "Avenir Next"; font-style: normal; font-weight: 600; font-display: swap;
    src: url("/assets/fonts/AvenirNextCyr-Demi.woff2") format("woff2"),
         url("/assets/fonts/AvenirNextCyr-Demi.woff") format("woff");
  }
  @font-face {
    font-family: "Avenir Next"; font-style: normal; font-weight: 700; font-display: swap;
    src: url("/assets/fonts/AvenirNextLTPro-Bold.woff2") format("woff2"),
         url("/assets/fonts/AvenirNextLTPro-Bold.woff") format("woff");
  }

  :root {
    --cyan: #40baff;            /* azure — brand action color (sampled from truit.io) */
    --cyan-soft: #6fccff;
    --violet: #a343fc;
    --grad: linear-gradient(100deg, #44b6fd, #a343fc);
    --orange: #f5872e;
    --deep: #101012;
    --bg: #161616;              /* neutral charcoal — the live-site background */
    --surface: #1e1e22;
    --surface-2: #26262c;
    --border: #34343c;
    --border-soft: #262630;
    --text: #f4f5f7;
    --muted: #a7adb8;
    --faint: #7f8794;
    --ink: #061019;
    --r-sm: 8px; --r-md: 12px; --r-lg: 18px;
    --maxw: 1200px;
    --ease: cubic-bezier(0.16, 1, 0.3, 1);
    --z-nav: 100; --z-overlay: 200;
  }
  * { box-sizing: border-box; margin: 0; padding: 0; }
  html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
  body {
    font-family: "Avenir Next", "Montserrat", system-ui, -apple-system, sans-serif;
    background: var(--bg); color: var(--text); line-height: 1.65;
    -webkit-font-smoothing: antialiased; overflow-x: hidden;
  }
  a { color: inherit; text-decoration: none; }
  img { display: block; max-width: 100%; }
  ::selection { background: var(--cyan); color: var(--ink); }
  :focus-visible { outline: none; box-shadow: 0 0 0 3px rgba(68,182,253,0.55); border-radius: 6px; }
  .wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: clamp(20px, 5vw, 40px); }
  h1, h2, h3 { text-wrap: balance; letter-spacing: -0.02em; line-height: 1.06; font-weight: 800; }
  p { text-wrap: pretty; }

  /* kicker — used ONCE, in the hero. Not a per-section eyebrow. */
  .kicker { display:inline-flex; align-items:center; gap:10px; font-size:0.78rem; font-weight:700; letter-spacing:0.18em; text-transform:uppercase; color:var(--muted); }
  .kicker .dot { width:9px; height:9px; border-radius:2px; background:var(--grad); box-shadow:0 0 12px rgba(163,67,252,0.6); animation: blink 2.6s var(--ease) infinite; }
  @keyframes blink { 0%,100%{opacity:1} 50%{opacity:.35} }

  /* buttons */
  .btn { display:inline-flex; align-items:center; gap:9px; font:inherit; font-size:0.95rem; font-weight:700; padding:14px 28px; border-radius:var(--r-md); cursor:pointer; border:1px solid transparent; transition: transform .25s var(--ease), background .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease); }
  .btn svg { width:17px; height:17px; }
  .btn-primary { background:var(--cyan); color:var(--ink); text-transform:uppercase; letter-spacing:0.04em; font-size:0.82rem; }
  .btn-primary:hover { background:var(--cyan-soft); transform:translateY(-2px); box-shadow:0 12px 34px rgba(68,182,253,0.32); }
  .btn-ghost { background:transparent; color:var(--text); border-color:var(--border); }
  .btn-ghost:hover { border-color:var(--cyan); color:var(--cyan); }
  /* gradient-border button — the live site's signature outline box */
  .btn-outline { border:1.5px solid transparent; color:var(--text); background:linear-gradient(var(--bg),var(--bg)) padding-box, var(--grad) border-box; }
  .btn-outline:hover { transform:translateY(-2px); box-shadow:0 10px 28px rgba(68,182,253,0.18); }
  .btn-primary .arr { transition: transform .25s var(--ease); }
  .btn-primary:hover .arr { transform: translateX(3px); }

  /* ---------------- EMERGENCY BAR ---------------- */
  .ebar { background:#b91c1c; color:#fff; position:relative; z-index:150; }
  .ebar.hidden { display:none; }
  .ebar-inner { display:flex; align-items:center; gap:16px; padding:10px 0; }
  .ebar-pulse { flex-shrink:0; width:10px; height:10px; border-radius:50%; background:#fca5a5; animation:ebarpulse 2s ease-in-out infinite; }
  @keyframes ebarpulse { 0%,100%{ box-shadow:0 0 0 0 rgba(252,165,165,0.5); } 60%{ box-shadow:0 0 0 8px rgba(252,165,165,0); } }
  .ebar-msg { flex:1; font-size:0.88rem; font-weight:500; }
  .ebar-msg strong { font-weight:700; }
  .ebar-btn { background:#fff; color:#b91c1c; border-radius:6px; padding:6px 14px; font-weight:700; font-size:0.83rem; white-space:nowrap; flex-shrink:0; transition:opacity .15s; }
  .ebar-btn:hover { opacity:0.88; }
  .ebar-close { background:none; border:none; color:rgba(255,255,255,0.65); font-size:1rem; cursor:pointer; padding:4px 8px; margin-left:4px; flex-shrink:0; line-height:1; }
  .ebar-close:hover { color:#fff; }
  @media (max-width:680px) { .ebar-msg span.ebar-long { display:none; } .ebar-msg { font-size:0.8rem; } }

  /* ---------------- NAV ---------------- */
  header.nav { position:sticky; top:0; z-index:var(--z-nav); background:rgba(13,28,46,0); transition: background .35s var(--ease), border-color .35s var(--ease); border-bottom:1px solid transparent; }
  header.nav.scrolled { background:rgba(10,22,35,0.82); backdrop-filter:blur(16px); border-bottom-color:var(--border-soft); }
  .nav-inner { display:flex; align-items:center; justify-content:space-between; height:80px; gap:24px; }
  .nav-logo img { height:42px; width:auto; }
  .nav-links { display:flex; gap:32px; }
  .nav-links a { font-size:0.92rem; font-weight:600; color:var(--muted); position:relative; transition:color .2s; }
  .nav-links a::after { content:""; position:absolute; left:0; bottom:-6px; height:2px; width:0; background:var(--cyan); transition:width .25s var(--ease); }
  .nav-links a:hover { color:var(--text); }
  .nav-links a:hover::after { width:100%; }
  .nav-right { display:flex; align-items:center; gap:20px; }
  .nav-phone { font-size:0.9rem; font-weight:700; white-space:nowrap; }
  .nav-phone span { color:var(--faint); font-weight:500; }
  .nav-right .btn { white-space:nowrap; padding:11px 22px; font-size:0.88rem; }

  /* nav items + dropdown menus */
  .nav-item { font-size:0.92rem; font-weight:600; color:var(--muted); position:relative; transition:color .2s; }
  .has-menu { display:flex; align-items:center; }
  .nav-trigger { font:inherit; font-size:0.92rem; font-weight:600; color:var(--muted); background:none; border:0; padding:0; cursor:pointer; display:inline-flex; align-items:center; gap:7px; transition:color .2s; }
  a.nav-item::after { content:""; position:absolute; left:0; bottom:-6px; height:2px; width:0; background:var(--cyan); transition:width .25s var(--ease); }
  a.nav-item:hover { color:var(--text); }
  a.nav-item:hover::after { width:100%; }
  .nav-trigger:hover, .has-menu:hover .nav-trigger, .has-menu:focus-within .nav-trigger { color:var(--text); }
  .caret { width:7px; height:7px; border-right:2px solid currentColor; border-bottom:2px solid currentColor; transform:rotate(45deg) translateY(-2px); transition:transform .25s var(--ease); opacity:.8; }
  .has-menu:hover .caret, .has-menu.open .caret, .has-menu:focus-within .caret { transform:rotate(225deg) translateY(0); }
  .nav-menu { position:absolute; top:calc(100% + 14px); left:50%; transform:translate(-50%,8px); min-width:210px; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-md); padding:8px; display:flex; flex-direction:column; box-shadow:0 18px 44px rgba(0,0,0,0.5); opacity:0; visibility:hidden; pointer-events:none; transition:opacity .22s var(--ease), transform .22s var(--ease), visibility .22s; z-index:var(--z-overlay); }
  .nav-menu::before { content:""; position:absolute; top:-14px; left:0; right:0; height:14px; } /* hover bridge */
  .has-menu:hover .nav-menu, .has-menu:focus-within .nav-menu, .has-menu.open .nav-menu { opacity:1; visibility:visible; pointer-events:auto; transform:translate(-50%,0); }
  .nav-menu a { display:block; padding:10px 14px; border-radius:8px; font-size:0.9rem; font-weight:600; color:var(--muted); white-space:nowrap; transition:background .18s, color .18s; }
  .nav-menu a:hover { background:var(--surface-2); color:var(--text); }
  .nav-menu a.nav-emergency { color:#fca5a5; border-top:1px solid var(--border-soft); margin-top:4px; padding-top:14px; }
  .nav-menu a.nav-emergency:hover { background:rgba(185,28,28,0.15); color:#fca5a5; }
  .nav-drawer a.nav-emergency { color:#fca5a5; }

  /* burger + mobile drawer */
  .nav-burger { display:none; flex-direction:column; gap:5px; width:42px; height:42px; align-items:center; justify-content:center; background:none; border:1px solid var(--border); border-radius:10px; cursor:pointer; }
  .nav-burger span { display:block; width:20px; height:2px; background:var(--text); border-radius:2px; transition:transform .3s var(--ease), opacity .2s var(--ease); }
  .nav-burger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
  .nav-burger.open span:nth-child(2) { opacity:0; }
  .nav-burger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
  .nav-drawer { position:fixed; inset:80px 0 0; background:var(--bg); border-top:1px solid var(--border-soft); padding:24px clamp(20px,5vw,40px) 40px; display:flex; flex-direction:column; gap:6px; overflow-y:auto; transform:translateX(100%); transition:transform .32s var(--ease); z-index:var(--z-nav); }
  .nav-drawer.open { transform:none; }
  .nav-drawer details { border-bottom:1px solid var(--border-soft); }
  .nav-drawer summary { list-style:none; cursor:pointer; padding:16px 2px; font-size:1.05rem; font-weight:700; color:var(--text); }
  .nav-drawer summary::-webkit-details-marker { display:none; }
  .nav-drawer summary::after { content:"+"; float:right; color:var(--cyan); font-weight:700; }
  .nav-drawer details[open] summary::after { content:"–"; }
  .nav-drawer details a { display:block; padding:10px 14px; color:var(--muted); font-size:0.96rem; }
  .nav-drawer > a { padding:16px 2px; font-size:1.05rem; font-weight:700; color:var(--text); border-bottom:1px solid var(--border-soft); }
  .nav-drawer .btn { margin-top:20px; justify-content:center; }
  .nav-drawer .drawer-phone { border:0; color:var(--muted); font-weight:600; text-align:center; }

  @media (max-width:920px){
    .nav-links, .nav-phone, .nav-right .btn { display:none; }
    .nav-burger { display:flex; }
  }
  @media (min-width:921px){ .nav-drawer { display:none; } }

  /* ---------------- HERO ---------------- */
  .hero { position:relative; overflow:hidden; padding-block: clamp(48px,8vw,96px) clamp(56px,9vw,110px); }
  .hero-bg { position:absolute; inset:0; pointer-events:none; }
  .hero-bg::before { content:""; position:absolute; top:-28%; right:-12%; width:1040px; height:1040px; background:radial-gradient(circle at 55% 45%, rgba(68,182,253,0.16), rgba(163,67,252,0.12) 38%, transparent 66%); }
  .hero-bg::after { content:""; position:absolute; inset:0; opacity:.5; background-image:linear-gradient(rgba(29,53,81,0.3) 1px,transparent 1px),linear-gradient(90deg,rgba(29,53,81,0.3) 1px,transparent 1px); background-size:58px 58px; -webkit-mask-image:radial-gradient(ellipse 75% 70% at 70% 35%,#000 25%,transparent 72%); mask-image:radial-gradient(ellipse 75% 70% at 70% 35%,#000 25%,transparent 72%); }
  .hero-grid { position:relative; z-index:2; display:grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(32px,5vw,72px); align-items:center; }
  @media (max-width:900px){ .hero-grid { grid-template-columns:1fr; gap:48px; } }
  .hero h1 { font-size:clamp(2.9rem, 7.6vw, 5rem); font-weight:600; letter-spacing:-0.03em; line-height:1.0; margin:0 0 24px; }
  .hero h1 .lit { color:inherit; }
  .hero .sub { font-size:clamp(1.05rem,1.6vw,1.24rem); color:var(--muted); max-width:520px; margin-bottom:10px; }
  .hero .sub b { color:var(--text); font-weight:600; }
  .hero .sub-strong { font-size:1.06rem; font-weight:600; color:var(--text); max-width:520px; margin-bottom:32px; }
  .hero-actions { display:flex; gap:14px; flex-wrap:wrap; }
  .hero-meta { margin-top:30px; padding-top:24px; border-top:1px solid var(--border-soft); display:flex; flex-wrap:wrap; gap:8px 26px; font-size:0.84rem; color:var(--faint); }
  .hero-meta b { color:var(--muted); font-weight:600; }
  .hero-meta .sep { color:var(--cyan); }

  /* full-width bar band — single layer, smaller, gentle vertical parallax on scroll */
  .barband { position:relative; left:50%; transform:translateX(-50%); width:100vw; height:clamp(150px,20vw,210px); margin-top:14px; overflow:hidden;
    -webkit-mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent); mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent); }
  .blayer { position:absolute; inset:0; display:flex; flex-direction:column; justify-content:center; gap:14px; }
  .blayer.back { display:none; }                 /* one layer only */
  .blayer.front { z-index:2; }
  .brow { display:flex; gap:14px; width:max-content; will-change:transform; transform:translateY(var(--py,0px)); }
  .bbar { height:clamp(32px,3.8vw,46px); border-radius:6px; flex:none; }
  .bbar.fill { background:var(--grad); box-shadow:0 10px 34px rgba(68,182,253,0.12); }
  .bbar.out { background:linear-gradient(var(--bg),var(--bg)) padding-box, var(--grad) border-box; border:1.6px solid transparent; }
  .bars-cap { display:block; text-align:center; margin-top:14px; font-size:0.74rem; font-weight:700; letter-spacing:0.18em; text-transform:uppercase; color:var(--faint); }

  /* ---------------- SECTIONS ---------------- */
  section { position:relative; }
  .pad { padding-block: clamp(64px,9vw,118px); }
  .lead { font-size:clamp(1.8rem,4.2vw,3rem); font-weight:800; }

  /* positioning band */
  .stance { border-block:1px solid var(--border-soft); background:linear-gradient(180deg, var(--deep), var(--bg)); }
  .stance-grid { display:grid; grid-template-columns: 1.2fr 1fr; gap:clamp(32px,5vw,64px); align-items:end; }
  @media (max-width:820px){ .stance-grid { grid-template-columns:1fr; gap:28px; } }
  .stance h2 { font-size:clamp(2rem,4.6vw,3.3rem); }
  .stance h2 em { font-style:normal; color:var(--cyan); }
  .stance p { color:var(--muted); font-size:1.06rem; max-width:46ch; }
  .stance .facts { display:flex; flex-direction:column; gap:0; }
  .fact { display:flex; align-items:baseline; gap:16px; padding:18px 0; border-top:1px solid var(--border-soft); }
  .fact:last-child { border-bottom:1px solid var(--border-soft); }
  .fact .k { font-size:1.5rem; font-weight:800; color:var(--text); min-width:128px; }
  .fact .v { color:var(--muted); font-size:0.96rem; }

  /* people band — real photo + bar composite (brand illustration) */
  .people { position:relative; overflow:hidden; background:linear-gradient(180deg,var(--bg),var(--deep)); border-bottom:1px solid var(--border-soft); }
  .people .wrap { position:relative; display:flex; align-items:center; min-height:360px; }
  .people .copy { position:relative; z-index:2; max-width:430px; padding-block:56px; }
  .people h2 { font-size:clamp(1.8rem,3.6vw,2.6rem); }
  .people h2 .lit { color:var(--cyan); }
  .people p { color:var(--muted); margin:14px 0 22px; max-width:38ch; }
  .people .photo { position:absolute; right:-2%; top:0; height:100%; width:60%; object-fit:cover; object-position:right center; pointer-events:none;
    -webkit-mask:linear-gradient(90deg, transparent 0, #000 30%); mask:linear-gradient(90deg, transparent 0, #000 30%); }
  @media (max-width:820px){
    .people .wrap { flex-direction:column; align-items:flex-start; min-height:0; }
    .people .copy { padding:48px 0 0; }
    .people .photo { position:relative; right:0; width:108%; height:auto; max-height:230px; margin:6px 0 -1px -4%; -webkit-mask:none; mask:none; }
  }

  /* services — editorial row list, not identical cards */
  .svc-grid { display:grid; grid-template-columns: 0.8fr 1.2fr; gap:clamp(32px,5vw,72px); align-items:start; }
  @media (max-width:860px){ .svc-grid { grid-template-columns:1fr; gap:36px; } }
  .svc-intro { position:sticky; top:108px; }
  @media (max-width:860px){ .svc-intro { position:static; } }
  .svc-intro h2 { font-size:clamp(1.9rem,4vw,2.8rem); margin-bottom:18px; }
  .svc-intro p { color:var(--muted); max-width:36ch; margin-bottom:28px; }
  .svc-list { display:flex; flex-direction:column; }
  .svc { display:grid; grid-template-columns:auto 1fr auto; gap:22px; align-items:center; padding:26px 4px; border-top:1px solid var(--border-soft); cursor:default; transition:padding-left .3s var(--ease); }
  .svc:last-child { border-bottom:1px solid var(--border-soft); }
  .svc:hover { padding-left:14px; }
  .svc .ic { width:54px; height:50px; display:grid; place-items:center; flex:none; transition:transform .3s var(--ease); }
  .svc:hover .ic { transform:scale(1.07); }
  .svc .ic img { max-width:100%; max-height:100%; object-fit:contain; }
  .svc .body h3 { font-size:1.3rem; font-weight:700; letter-spacing:-0.01em; }
  .svc .body p { color:var(--muted); font-size:0.94rem; margin-top:3px; }
  .svc .meta { font-size:0.78rem; color:var(--faint); text-align:right; max-width:150px; line-height:1.45; }
  @media (max-width:560px){ .svc { grid-template-columns:auto 1fr; } .svc .meta { display:none; } }

  /* process — earned numbered sequence */
  .proc { position:relative; overflow:hidden; background:var(--deep); border-block:1px solid var(--border-soft); }
  /* large soft radial glow behind the wheel — matches the live site's blue atmospheric halo */
  .proc::before { content:''; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
    width:900px; height:900px; border-radius:50%;
    background:radial-gradient(circle, rgba(64,186,255,0.10) 0%, rgba(64,186,255,0.04) 40%, transparent 70%);
    pointer-events:none; z-index:0; }
  @media (max-width:760px){ .proc::before { width:500px; height:500px; } }

  /* circular process wheel — plan / discover / implement with orbiting photos */
  .sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
  .proc .wrap { display:flex; justify-content:center; }
  .wheel { position:relative; width:min(600px, 88vw); aspect-ratio:1; }
  /* ellipce.webp — the actual ring image from truit.io (gradient ring + glow + dots baked in). Static. */
  .wheel-ring { position:absolute; inset:0; width:100%; height:100%; object-fit:contain; z-index:1; pointer-events:none; }
  /* geer-pivot: full-size container that rotates around the ring center (46.4%, 49.1%).
     Live-site geometry: pivot = section center, geer top is 8px below pivot.
     Scale factor from live (ring 635px) to our build (ring ~600px): 0.9449. */
  .geer-pivot { position:absolute; inset:0;
    transform:rotate(var(--rot,0deg)); transform-origin:50% 58.2%; z-index:0; }
  /* geer.webp: 512×289 natural. Scaled 0.9449× → 484×273px. Positioned so its top is
     8px (scaled) below the pivot, matching the live site layout exactly. */
  .wheel-geer { position:absolute; width:88%; height:auto;
    top:50.35%; left:7%; pointer-events:none; }
.wlabel { position:absolute; font-weight:700; font-size:clamp(0.95rem,2.4vw,1.6rem); letter-spacing:-0.01em; color:var(--text); z-index:3; white-space:nowrap; text-shadow:0 2px 12px #161616, 0 0 6px #161616; }
  .wlabel.plan { top:26%; left:50%; transform:translate(-50%,calc(-100% - 47px)); }
  .wlabel.discover { top:calc(52% - 10px); left:18%; transform:translate(calc(-100% - 47px),-50%); }
  .wlabel.implement { top:50%; left:80%; transform:translate(47px,-50%); }
  .hub { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:50%; text-align:center; z-index:2; }
  .hub p { color:var(--text); font-weight:700; font-size:clamp(0.78rem,1.35vw,0.98rem); line-height:1.55; }
  @media (max-width:680px){
    .wheel { width:min(300px,58vw); }
    .wlabel { font-size:0.8rem; }
    .wlabel.discover { left:16%; }
    .wlabel.implement { left:82%; }
    .hub { width:64%; }
    .hub p { font-size:0.72rem; line-height:1.45; }
  }
  .proc-head { max-width:640px; margin-bottom:54px; }
  .proc-head h2 { font-size:clamp(1.9rem,4vw,2.8rem); margin-bottom:14px; }
  .proc-head p { color:var(--muted); font-size:1.05rem; }
  .steps { display:grid; grid-template-columns:repeat(3,1fr); gap:0; border:1px solid var(--border); border-radius:var(--r-lg); overflow:hidden; }
  @media (max-width:760px){ .steps { grid-template-columns:1fr; } }
  .step { padding:36px 30px; background:var(--surface); position:relative; }
  .step + .step { border-left:1px solid var(--border); }
  @media (max-width:760px){ .step + .step { border-left:none; border-top:1px solid var(--border); } }
  .step .n { font-size:0.82rem; font-weight:800; letter-spacing:0.1em; color:var(--cyan); }
  .step .bar { height:2px; width:38px; background:var(--cyan); margin:14px 0 18px; border-radius:2px; }
  .step h4 { font-size:1.25rem; font-weight:700; margin-bottom:8px; }
  .step p { color:var(--muted); font-size:0.94rem; }

  /* industries — big-type editorial list */
  .ind-head { display:flex; justify-content:space-between; align-items:flex-end; gap:24px; margin-bottom:40px; flex-wrap:wrap; }
  .ind-head h2 { font-size:clamp(1.9rem,4vw,2.8rem); }
  .ind-head p { color:var(--muted); max-width:34ch; }
  .ind-list { display:flex; flex-direction:column; }
  .ind { display:flex; align-items:center; gap:20px; padding:22px 4px; border-top:1px solid var(--border-soft); font-size:clamp(1.5rem,3.6vw,2.4rem); font-weight:800; letter-spacing:-0.02em; color:var(--muted); transition:color .25s var(--ease), padding-left .3s var(--ease); }
  .ind:last-child { border-bottom:1px solid var(--border-soft); }
  .ind:hover { color:var(--text); padding-left:12px; }
  .ind .num { font-size:0.8rem; font-weight:700; color:var(--faint); letter-spacing:0.1em; min-width:30px; }
  .ind .tag { margin-left:auto; font-size:0.8rem; font-weight:600; color:var(--faint); letter-spacing:0.04em; opacity:0; transform:translateX(-8px); transition:opacity .25s var(--ease), transform .25s var(--ease); }
  .ind:hover .tag { opacity:1; transform:none; color:var(--cyan); }
  @media (max-width:560px){ .ind .tag { display:none; } }

  /* why — asymmetric, not a card grid */
  .why { background:linear-gradient(180deg,var(--bg),var(--deep)); border-top:1px solid var(--border-soft); }
  .why-grid { display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,70px); align-items:start; }
  @media (max-width:820px){ .why-grid { grid-template-columns:1fr; gap:36px; } }
  .why h2 { font-size:clamp(2rem,4.4vw,3.1rem); }
  .why h2 .lit { color:var(--cyan); }
  .why-scene { width:100%; max-width:360px; margin-top:30px; filter:drop-shadow(0 20px 40px rgba(0,0,0,0.4)); }
  @media (max-width:820px){ .why-scene { max-width:300px; } }
  .why .reasons { display:flex; flex-direction:column; }
  .reason { padding:24px 0; border-top:1px solid var(--border-soft); }
  .reason:last-child { border-bottom:1px solid var(--border-soft); }
  .reason h4 { font-size:1.18rem; font-weight:700; display:flex; align-items:center; gap:11px; }
  .reason h4 .d { width:8px; height:8px; border-radius:50%; background:var(--cyan); flex:none; box-shadow:0 0 10px var(--cyan); }
  .reason p { color:var(--muted); font-size:0.96rem; margin-top:8px; padding-left:19px; }

  /* CTA */
  .cta { padding-block: clamp(64px,9vw,120px); }
  .cta-box { position:relative; overflow:hidden; border:1px solid var(--border); border-radius:26px; background:linear-gradient(135deg,var(--surface-2),var(--surface)); padding:clamp(40px,6vw,80px); text-align:center; }
  .cta-box::before { content:""; position:absolute; top:-60%; left:50%; transform:translateX(-50%); width:760px; height:760px; background:radial-gradient(circle, rgba(68,182,253,0.18), transparent 60%); pointer-events:none; }
  .cta-box > * { position:relative; z-index:1; }
  .cta-magic { position:absolute; top:26px; right:34px; width:120px; opacity:.65; z-index:0; pointer-events:none; }
  @media (max-width:600px){ .cta-magic { display:none; } }
  .cta-box h2 { font-size:clamp(2rem,4.6vw,3.2rem); margin-bottom:18px; }
  .cta-box p { color:var(--muted); max-width:50ch; margin:0 auto 32px; font-size:1.08rem; }
  .cta-actions { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
  .cta-box .micro { margin-top:22px; font-size:0.86rem; color:var(--faint); }
  .cta-box .micro b { color:var(--muted); font-weight:600; }

  /* footer */
  footer { background:var(--deep); border-top:1px solid var(--border-soft); padding:64px 0 36px; }
  .foot-top { display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:44px; padding-bottom:42px; border-bottom:1px solid var(--border-soft); }
  @media (max-width:760px){ .foot-top { grid-template-columns:1fr; gap:30px; } }
  .foot-logo img { height:46px; margin-bottom:18px; }
  .foot-blurb { color:var(--muted); font-size:0.94rem; max-width:34ch; }
  .foot-col h5 { font-size:0.76rem; letter-spacing:0.14em; text-transform:uppercase; color:var(--cyan); margin-bottom:16px; }
  .foot-col p, .foot-col a { display:block; color:var(--muted); font-size:0.92rem; margin-bottom:10px; transition:color .2s; }
  .foot-col a:hover { color:var(--text); }
  .foot-col p b { color:var(--text); font-weight:600; }
  .foot-bottom { display:flex; flex-wrap:wrap; gap:14px; justify-content:space-between; align-items:center; padding-top:26px; }
  .foot-bottom .svc-line { font-size:0.72rem; letter-spacing:0.13em; color:var(--faint); text-transform:uppercase; }
  .foot-bottom .legal { font-size:0.82rem; color:var(--faint); }

  /* ---------------- INNER PAGES: service + industry ---------------- */
  /* inner-page hero — single column, slightly tighter than the home hero */
  .svc-hero .hero-copy { max-width: 760px; }
  .svc-hero h1 { font-size:clamp(2.4rem,6vw,4.1rem); margin:18px 0 22px; }
  .svc-hero .kicker { margin-bottom:4px; }
  /* industry hero with optional background photo */
  .hero-photo { position:absolute; right:0; top:0; bottom:0; width:60%; z-index:0; pointer-events:none; }
  .hero-photo img { width:100%; height:100%; object-fit:cover; object-position:center; display:block; filter:brightness(0.55) saturate(0.3); }
  .hero-photo--dim img { filter:brightness(0.35) saturate(0.25); }
  .hero-photo::after { content:""; position:absolute; inset:0; background:linear-gradient(to right, var(--bg) 0%, rgba(9,19,31,0.7) 45%, transparent 75%), linear-gradient(to top, var(--bg) 0%, transparent 30%); }
  .svc-hero .hero-copy { position:relative; z-index:1; }
  @media (max-width:860px) { .hero-photo { display:none; } }

  /* feature / risk grid — uniform cards (used on service "included" + industry "risks") */
  .svc-page-head { max-width:640px; margin-bottom:48px; }
  .svc-page-head h2 { font-size:clamp(1.9rem,4vw,2.8rem); margin-bottom:14px; }
  .svc-page-head h2 em { font-style:normal; color:var(--cyan); }
  .svc-page-head p { color:var(--muted); font-size:1.05rem; }
  .feat-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
  .feat-grid--2 { grid-template-columns:repeat(2,1fr); }
  @media (max-width:860px){ .feat-grid { grid-template-columns:repeat(2,1fr); } }
  @media (max-width:560px){ .feat-grid { grid-template-columns:1fr; } .feat-grid--2 { grid-template-columns:1fr; } }
  .feat { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:26px 24px; transition:transform .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease); }
  .feat:hover { transform:translateY(-3px); border-color:var(--cyan); box-shadow:0 14px 34px rgba(0,0,0,0.4); }
  .feat-ic { display:grid; place-items:center; width:52px; height:52px; margin-bottom:16px;
    background:linear-gradient(var(--surface-2),var(--surface-2)) padding-box, var(--grad) border-box; border:1.5px solid transparent; border-radius:12px; }
  .feat-ic img { width:58%; height:58%; object-fit:contain; }
  .feat h3 { font-size:1.12rem; font-weight:700; letter-spacing:-0.01em; margin-bottom:7px; }
  .feat p { color:var(--muted); font-size:0.93rem; line-height:1.55; }

  /* stat strip — industry pages */
  .statstrip { background:var(--deep); border-block:1px solid var(--border-soft); padding-block:clamp(36px,5vw,56px); }
  .stat-row { display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(24px,4vw,48px); }
  @media (max-width:680px){ .stat-row { grid-template-columns:1fr; gap:26px; text-align:center; } }
  .stat { display:flex; flex-direction:column; gap:8px; }
  .stat + .stat { position:relative; }
  .stat .snum { font-size:clamp(2.2rem,5vw,3.2rem); font-weight:800; letter-spacing:-0.03em; color:var(--cyan); line-height:1; }
  .stat .slabel { color:var(--muted); font-size:0.96rem; max-width:34ch; }
  @media (min-width:681px){ .stat-row .stat + .stat { padding-left:clamp(24px,4vw,48px); border-left:1px solid var(--border-soft); } }

  /* reveal — progressive enhancement only. Content is visible by default;
     the hidden start state applies ONLY when JS is confirmed (html.js), so a
     no-JS / headless / slow render never ships a blank section. */
  .rv { transition:opacity .7s var(--ease), transform .7s var(--ease); }
  html.js .rv { opacity:0; transform:translateY(24px); }
  html.js .rv.in { opacity:1; transform:none; }
  /* directional reveals — slide in from the left / right */
  html.js .rv.from-left { transform:translateX(-80px); }
  html.js .rv.from-right { transform:translateX(80px); }
  html.js .rv.from-left.in, html.js .rv.from-right.in { transform:none; }

  /* ── Industry extensions ─────────────────────────────────────────────── */
  /* Systems grid */
  .ind-systems { background:linear-gradient(180deg,var(--bg),var(--deep)); }
  .sys-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:40px; }
  @media (max-width:860px){ .sys-grid { grid-template-columns:repeat(2,1fr); } }
  @media (max-width:540px){ .sys-grid { grid-template-columns:1fr; } }
  .sys-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:26px 24px; }
  .sys-num { font-size:0.72rem; font-weight:800; color:var(--cyan); letter-spacing:.1em; text-transform:uppercase; display:block; margin-bottom:12px; }
  .sys-card h4 { font-size:1.05rem; font-weight:700; margin-bottom:8px; }
  .sys-card p { font-size:0.9rem; color:var(--muted); line-height:1.55; }

  /* Threat landscape strip */
  .ind-threat-strip { background:var(--deep); border-block:1px solid var(--border-soft); padding:clamp(48px,7vw,88px) 0; }
  .threat-head { margin-bottom:44px; }
  .threat-head h2 { font-size:clamp(1.7rem,3.5vw,2.6rem); margin:14px 0 18px; max-width:54ch; letter-spacing:-0.02em; }
  .threat-head p { color:var(--muted); max-width:60ch; font-size:1.04rem; }
  .threat-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:28px; }
  @media (max-width:860px){ .threat-stats { grid-template-columns:repeat(2,1fr); } }
  @media (max-width:520px){ .threat-stats { grid-template-columns:1fr; } }
  .tstat { border-left:3px solid var(--cyan); padding-left:20px; }
  .tnum { font-size:2rem; font-weight:800; color:var(--text); display:block; margin-bottom:8px; letter-spacing:-0.02em; }
  .tlabel { font-size:0.86rem; color:var(--muted); line-height:1.55; }

  /* What's included */
  .ind-included { background:var(--bg); }
  .included-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:40px; }
  @media (max-width:860px){ .included-grid { grid-template-columns:repeat(2,1fr); } }
  @media (max-width:540px){ .included-grid { grid-template-columns:1fr; } }
  .inc-group { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:26px 24px; }
  .inc-group h4 { font-size:0.9rem; font-weight:700; color:var(--cyan); text-transform:uppercase; letter-spacing:.05em; margin-bottom:16px; }
  .inc-list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:9px; }
  .inc-list li { font-size:0.88rem; color:var(--muted); padding-left:18px; position:relative; line-height:1.5; }
  .inc-list li::before { content:"→"; position:absolute; left:0; color:var(--cyan); font-size:0.8rem; top:1px; }

  /* Fleet readiness checklist */
  .ind-checklist { background:linear-gradient(180deg,var(--deep),var(--bg)); padding:clamp(56px,8vw,96px) 0; }
  .ind-checklist-grid { display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,80px); align-items:center; }
  @media (max-width:760px){ .ind-checklist-grid { grid-template-columns:1fr; } }
  .ind-checklist h2 { font-size:clamp(1.8rem,3.5vw,2.5rem); margin:14px 0 16px; letter-spacing:-0.02em; }
  .ind-checklist p { color:var(--muted); font-size:1rem; max-width:44ch; margin-bottom:24px; }
  .chk-list { list-style:none; padding:0; margin:0 0 32px; display:flex; flex-direction:column; gap:11px; }
  .chk-list li { display:flex; align-items:flex-start; gap:10px; font-size:0.95rem; color:var(--muted); }
  .chk-list li::before { content:"✓"; color:var(--cyan); font-weight:800; flex-shrink:0; margin-top:1px; }
  .chk-score-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:32px; }
  .chk-score-label { font-size:0.8rem; font-weight:700; color:var(--muted); text-transform:uppercase; letter-spacing:.06em; margin-bottom:20px; }
  .score-tiers { display:flex; flex-direction:column; gap:12px; margin-bottom:20px; }
  .tier { padding:14px 18px; border-radius:var(--r-md); display:flex; align-items:center; gap:16px; }
  .tier span { font-size:0.92rem; font-weight:800; white-space:nowrap; }
  .tier p { font-size:0.87rem; margin:0; line-height:1.4; }
  .tier-good { background:rgba(34,197,94,0.1); border:1px solid rgba(34,197,94,0.25); }
  .tier-good span { color:#22c55e; } .tier-good p { color:rgba(34,197,94,0.8); }
  .tier-warn { background:rgba(234,179,8,0.1); border:1px solid rgba(234,179,8,0.25); }
  .tier-warn span { color:#eab308; } .tier-warn p { color:rgba(234,179,8,0.8); }
  .tier-danger { background:rgba(239,68,68,0.1); border:1px solid rgba(239,68,68,0.25); }
  .tier-danger span { color:#ef4444; } .tier-danger p { color:rgba(239,68,68,0.8); }
  .chk-micro { font-size:0.8rem; color:var(--muted); margin:0; }
  .inc-addon { margin-top:24px; }
  .inc-addon-inner { display:flex; align-items:center; gap:24px; background:rgba(0,212,237,0.06); border:1px solid rgba(0,212,237,0.22); border-radius:var(--r-lg); padding:24px 28px; flex-wrap:wrap; }
  .inc-addon-label { font-size:0.72rem; font-weight:800; color:var(--cyan); text-transform:uppercase; letter-spacing:.1em; white-space:nowrap; flex-shrink:0; }
  .inc-addon-body { flex:1; min-width:200px; }
  .inc-addon-body h4 { font-size:1rem; font-weight:700; margin-bottom:4px; }
  .inc-addon-body p { font-size:0.88rem; color:var(--muted); line-height:1.5; margin:0; }
  .inc-addon .btn { flex-shrink:0; }

  @media (prefers-reduced-motion: reduce) {
    html { scroll-behavior:auto; }
    *, *::before, *::after { animation:none !important; transition-duration:.01ms !important; }
    .rv { opacity:1 !important; transform:none !important; }
    .bar { opacity:1 !important; transform:none !important; animation:none !important; }
    .brow { animation:none !important; }
    .geer-pivot { transform:none !important; }
  }

/* --- Footer service-area directory ---------------------------------------- */
.foot-areas {
  border-top: 1px solid var(--border-soft);
  padding: 4px 0;
}
.fa-toggle { border: none; background: none; }
.fa-toggle[open] { padding-bottom: 16px; }
.fa-summary {
  display: flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  list-style: none;
  user-select: none;
  padding: 10px 0;
}
.fa-summary::-webkit-details-marker { display: none; }
.fa-label {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--muted);
  opacity: .6;
  margin: 0;
}
.fa-caret {
  width: 14px;
  height: 14px;
  color: var(--muted);
  opacity: .5;
  transition: transform .2s ease;
  flex-shrink: 0;
}
.fa-toggle[open] .fa-caret { transform: rotate(180deg); }
.fa-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 10px 20px;
  padding-top: 12px;
}
.fa-state {
  display: flex;
  flex-wrap: wrap;
  gap: 3px 8px;
  align-items: baseline;
  font-size: 0.72rem;
  line-height: 1.7;
}
.fa-state strong {
  color: var(--fg);
  font-size: 0.72rem;
  font-weight: 800;
  opacity: .7;
  flex-shrink: 0;
}
.fa-state a {
  color: var(--muted);
  text-decoration: none;
  opacity: .7;
  transition: opacity .15s, color .15s;
}
.fa-state a:hover { color: var(--accent); opacity: 1; }

/* --- Also serving cross-links (local SEO pages) --------------------------- */
.also-svc {
  background: var(--deep);
  border-top: 1px solid var(--border-soft);
  padding: 18px 0;
}
.also-label {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--muted);
  margin-bottom: 12px;
  opacity: .7;
}
.also-links {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 8px;
}
.also-links a {
  font-size: 0.8rem;
  color: var(--muted);
  text-decoration: none;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border-soft);
  border-radius: 99px;
  padding: 4px 14px;
  transition: color .15s, border-color .15s;
}
.also-links a:hover { color: var(--accent); border-color: var(--accent); }

/* =====================================================================
   BLOG
   ===================================================================== */
.bl-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 24px;
  margin-top: 16px;
}
.bl-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  transition: border-color .2s, transform .2s;
  display: flex;
  flex-direction: column;
}
.bl-card:hover { border-color: var(--cyan); transform: translateY(-4px); }
.bl-card-inner { padding: 28px 28px 24px; display: flex; flex-direction: column; flex: 1; }
.bl-meta-top { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 14px; }
.bl-tag {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--cyan);
  background: rgba(64,186,255,0.1);
  border: 1px solid rgba(64,186,255,0.25);
  border-radius: 99px;
  padding: 3px 12px;
}
.bl-card-title { font-size: 1.1rem; font-weight: 700; line-height: 1.35; margin-bottom: 12px; }
.bl-card-title a { color: var(--text); text-decoration: none; transition: color .2s; }
.bl-card-title a:hover { color: var(--cyan); }
.bl-card-excerpt { font-size: 0.9rem; color: var(--muted); line-height: 1.65; flex: 1; margin-bottom: 20px; }
.bl-card-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
  border-top: 1px solid var(--border-soft);
  padding-top: 16px;
}
.bl-byline { font-size: 0.78rem; color: var(--faint); }
.bl-readmore { font-size: 0.82rem; font-weight: 700; color: var(--cyan); text-decoration: none; transition: color .2s; }
.bl-readmore:hover { color: var(--cyan-soft); }

/* Blog post page */
.bl-post-wrap { padding: 60px 0 48px; }
.bl-breadcrumb { display: flex; align-items: center; gap: 8px; font-size: 0.8rem; color: var(--faint); margin-bottom: 36px; }
.bl-breadcrumb a { color: var(--muted); text-decoration: none; transition: color .2s; }
.bl-breadcrumb a:hover { color: var(--cyan); }
.bl-post-header { margin-bottom: 40px; max-width: 72ch; }
.bl-post-tags { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }
.bl-post-title { font-size: clamp(1.6rem, 3vw, 2.4rem); font-weight: 700; line-height: 1.2; letter-spacing: -0.02em; margin-bottom: 16px; }
.bl-post-meta { font-size: 0.83rem; color: var(--faint); display: flex; align-items: center; gap: 10px; }
.bl-sep { color: var(--border); }
.bl-post-body { max-width: 68ch; }
.bl-post-body p { font-size: 1rem; line-height: 1.8; color: var(--muted); margin-bottom: 20px; }
.bl-post-body h2 { font-size: 1.4rem; font-weight: 700; color: var(--text); margin: 36px 0 14px; }
.bl-post-body h3 { font-size: 1.1rem; font-weight: 700; color: var(--text); margin: 28px 0 10px; }
.bl-post-body ul, .bl-post-body ol { padding-left: 24px; margin-bottom: 20px; }
.bl-post-body li { font-size: 1rem; line-height: 1.75; color: var(--muted); margin-bottom: 6px; }
.bl-post-body strong, .bl-post-body b { color: var(--text); font-weight: 700; }
.bl-post-body a { color: var(--cyan); text-decoration: underline; text-underline-offset: 3px; }
.bl-post-body a:hover { color: var(--cyan-soft); }
.bl-back { margin-top: 48px; padding-top: 28px; border-top: 1px solid var(--border-soft); }
.bl-back a { font-size: 0.88rem; font-weight: 700; color: var(--cyan); text-decoration: none; transition: color .2s; }
.bl-back a:hover { color: var(--cyan-soft); }
@media (max-width: 600px) { .bl-post-wrap { padding: 36px 0 32px; } .bl-post-body { max-width: 100%; } }

/* =====================================================================
   EVENTS
   ===================================================================== */
.ev-section { padding: 64px 0 48px; }
.ev-section-label { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--cyan); margin-bottom: 28px; }
.ev-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 24px; }
.ev-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: border-color .2s, transform .2s;
}
.ev-card:hover { border-color: var(--cyan); transform: translateY(-3px); }
.ev-card-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.ev-date-block { background: rgba(64,186,255,0.1); border: 1px solid rgba(64,186,255,0.25); border-radius: var(--r-md); padding: 10px 16px; text-align: center; flex-shrink: 0; }
.ev-date-month { font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--cyan); }
.ev-date-day { font-size: 1.6rem; font-weight: 800; color: var(--text); line-height: 1; }
.ev-format-pill { font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; padding: 4px 10px; border-radius: 99px; }
.ev-format-pill.in-person { background: rgba(34,197,94,0.1); color: #4ade80; border: 1px solid rgba(34,197,94,0.25); }
.ev-format-pill.virtual { background: rgba(64,186,255,0.1); color: var(--cyan); border: 1px solid rgba(64,186,255,0.25); }
.ev-format-pill.hybrid { background: rgba(163,67,252,0.1); color: #c084fc; border: 1px solid rgba(163,67,252,0.25); }
.ev-title { font-size: 1.05rem; font-weight: 700; color: var(--text); line-height: 1.35; }
.ev-meta { display: flex; flex-direction: column; gap: 5px; }
.ev-meta-row { display: flex; align-items: center; gap: 8px; font-size: 0.82rem; color: var(--muted); }
.ev-meta-icon { color: var(--faint); flex-shrink: 0; }
.ev-desc { font-size: 0.88rem; color: var(--muted); line-height: 1.65; flex: 1; }
.ev-register { display: inline-flex; align-items: center; gap: 6px; font-size: 0.82rem; font-weight: 700; color: var(--cyan); text-decoration: none; transition: color .2s; margin-top: 4px; }
.ev-register:hover { color: var(--cyan-soft); }
.ev-empty { color: var(--muted); font-size: 0.95rem; padding: 20px 0; }
.ev-past { padding: 48px 0 64px; border-top: 1px solid var(--border-soft); }
.ev-past-grid { display: flex; flex-direction: column; gap: 12px; margin-top: 20px; }
.ev-past-row { display: flex; align-items: center; gap: 20px; padding: 14px 0; border-bottom: 1px solid var(--border-soft); }
.ev-past-date { font-size: 0.78rem; color: var(--faint); min-width: 90px; }
.ev-past-title { font-size: 0.92rem; color: var(--muted); }
.ev-past-loc { font-size: 0.78rem; color: var(--faint); margin-left: auto; }
@media (max-width: 600px) { .ev-past-loc { display: none; } .ev-card-head { flex-wrap: wrap; } }
