/* =============================================================
   Pi Strategica — Official brand v3
   Colors:    blue #167acb · yellow #ecd660 · teal #5dc5c1
              black #26272f · white #ffffff · grey #e5e5e5
   Type:      Oswald (DIN Condensed sub) / Bodoni Moda italic
              (Bodoni 72 sub) / Mulish (Avenir Next sub) /
              IBM Plex Mono (technical labels)
   ============================================================= */

:root{
  /* brand palette */
  --blue:      #167acb;
  --blue-d:    #0F5C9C;
  --blue-soft: rgba(22,122,203,.10);
  --yellow:    #ecd660;
  --yellow-d:  #c8b443;
  --teal:      #5dc5c1;
  --teal-d:    #3a9d99;
  --ink:       #26272f;
  --ink-soft:  #3a3b44;
  --ink-mute:  rgba(38,39,47,.60);
  --ink-faint: rgba(38,39,47,.30);
  --ink-rule:  rgba(38,39,47,.14);
  --ink-line:  rgba(38,39,47,.08);
  --grey:      #e5e5e5;
  --paper:     #ffffff;
  --paper-2:   #fafafa;
  --paper-3:   #f3f3f3;

  /* accent (Lead) — driven by data-accent */
  --accent: var(--blue);
  --accent-soft: var(--blue-soft);

  /* The Shift 2030 sister-brand gradient (used only in footer) */
  --shift-grad: linear-gradient(90deg, #854DF1 0%, #4F87C7 50%, #3FAE6A 100%);

  /* type */
  --display: "Oswald", "Arial Narrow", Impact, sans-serif;
  --italic:  "Bodoni Moda", "Bodoni 72", "Didot", Georgia, serif;
  --body:    "Mulish", "Avenir Next", ui-sans-serif, system-ui, sans-serif;
  --mono:    "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, monospace;

  /* layout */
  --gutter: clamp(28px, 5vw, 88px);
  --maxw: 1440px;
}

/* accent variants */
html[data-accent="yellow"]{ --accent: var(--yellow-d); --accent-soft: rgba(236,214,96,.18); }
html[data-accent="teal"]  { --accent: var(--teal-d);   --accent-soft: rgba(93,197,193,.18); }
html[data-accent="blue"]  { --accent: var(--blue);     --accent-soft: var(--blue-soft); }

/* dark theme */
html[data-theme="dark"]{
  --paper:    #1a1b22;
  --paper-2:  #20222b;
  --paper-3:  #272935;
  --ink:      #f3f1ea;
  --ink-soft: #d6d4cc;
  --ink-mute: rgba(243,241,234,.62);
  --ink-faint:rgba(243,241,234,.30);
  --ink-rule: rgba(243,241,234,.14);
  --ink-line: rgba(243,241,234,.08);
}

/* reset */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0;background:var(--paper);color:var(--ink);
  font-family:var(--body);font-size:16px;line-height:1.55;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
::selection{background:var(--blue);color:#fff}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

.wrap{max-width:var(--maxw);margin:0 auto;
  padding-left:var(--gutter);padding-right:var(--gutter)}
.mono{font-family:var(--mono);letter-spacing:.04em}

/* =============================================================
   BRAND-SIGNATURE: paired YELLOW + BLUE vertical bars
   ============================================================= */
.vbars{display:inline-flex;gap:4px;align-items:stretch}
.vbar{display:block;width:3px;border-radius:1px}
.vbar.y{background:var(--yellow);height:46px}
.vbar.b{background:var(--blue);height:46px}
.vbars-mini{display:inline-flex;gap:3px;vertical-align:middle;margin-right:10px}
.vbars-mini .vbar{height:14px;width:2px}

/* =============================================================
   TYPE PRIMITIVES
   ============================================================= */
.display-h{font-family:var(--display);font-weight:700;text-transform:uppercase;
  letter-spacing:.005em;line-height:1.02}
.italic-sub{font-family:var(--italic);font-weight:400;font-style:italic;
  letter-spacing:0;line-height:1.25;color:var(--ink-soft)}

/* =============================================================
   SITE-UPDATE BANNER  (currently rebuilding the website)
   ============================================================= */
.update-banner{background:var(--ink);color:#fff;border-bottom:1px solid rgba(255,255,255,.08)}
.update-banner::after{content:"";display:block;height:3px;
  background:linear-gradient(90deg, var(--yellow) 0%, var(--yellow) 50%,
                             var(--blue) 50%, var(--blue) 100%)}
.update-banner-inner{display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  padding-top:14px;padding-bottom:14px;font-size:13px;line-height:1.45}
.ub-dot{width:8px;height:8px;border-radius:999px;background:var(--yellow);
  box-shadow:0 0 0 4px rgba(236,214,96,.22);animation:pulse 2.6s ease-in-out infinite;flex:none}
.ub-label{font-family:var(--mono);font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--yellow);font-weight:600}
.ub-sep{color:rgba(255,255,255,.35)}
.ub-text{color:rgba(255,255,255,.82);font-family:var(--body);font-size:13.5px;
  letter-spacing:.005em;max-width:none}
.ub-text a{color:#fff;border-bottom:1px solid rgba(255,255,255,.45);
  transition:border-color .15s,color .15s}
.ub-text a:hover{color:var(--yellow);border-bottom-color:var(--yellow)}

/* =============================================================
   TOP BAR  · old logo + live region clocks
   ============================================================= */
.topbar{display:flex;align-items:center;justify-content:space-between;gap:32px;
  padding-top:18px;padding-bottom:18px;border-bottom:1px solid var(--ink-rule)}
.brand{display:inline-flex;align-items:center;gap:14px}
.brand .brand-mark{height:88px;width:auto;display:block;
  object-fit:contain;object-position:left center}
/* dark-mode logo: src is swapped via pi-i18n.js setTheme() */

.tb-rail{display:flex;align-items:stretch;gap:18px;min-width:0}

.tb-tools{display:inline-flex;align-items:center;gap:8px;align-self:center}
.tb-toggle{font-family:var(--mono);font-size:11px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--ink-mute);
  background:transparent;border:1px solid var(--ink-rule);
  padding:9px 11px;cursor:pointer;display:inline-flex;align-items:center;gap:7px;
  line-height:1;transition:border-color .2s, color .2s, background .2s}
.tb-toggle:hover{border-color:var(--ink);color:var(--ink)}
.tb-toggle .tt-opt{display:inline-flex;align-items:center;gap:5px;transition:color .15s, font-weight .15s}
.tb-toggle .tt-opt[data-active="true"]{color:var(--ink);font-weight:600}
.tb-toggle .tt-icon{display:block;opacity:.7;transition:opacity .15s, transform .2s}
.tb-toggle .tt-opt[data-active="true"] .tt-icon{opacity:1}
.tb-toggle:hover .tt-opt[data-active="false"] .tt-icon{opacity:.9}
.tb-toggle .tt-sep{color:var(--ink-mute);opacity:.45}
.tb-toggle:focus-visible{outline:2px solid var(--blue);outline-offset:2px}
html[data-theme="dark"] .tb-toggle{border-color:rgba(255,255,255,.22);color:rgba(255,255,255,.55)}
html[data-theme="dark"] .tb-toggle:hover{border-color:rgba(255,255,255,.75);color:#fff}
html[data-theme="dark"] .tb-toggle .tt-opt[data-active="true"]{color:#fff}
html[data-theme="dark"] .tb-toggle .tt-sep{color:rgba(255,255,255,.4)}

.tb-clocks{list-style:none;padding:0;margin:0;display:flex;align-items:stretch;
  gap:0;border-left:1px solid var(--ink-rule);border-right:1px solid var(--ink-rule)}
.tb-clock{display:flex;flex-direction:column;justify-content:center;gap:3px;
  padding:8px 16px;border-right:1px solid var(--ink-rule);
  cursor:default;position:relative;min-width:0;overflow:hidden}
.tb-clock:last-child{border-right:none}
.tb-clock-head{display:inline-flex;align-items:center;gap:7px;line-height:1}
.tb-clock-dot{width:5px;height:5px;border-radius:999px;flex:none;
  background:transparent;border:1px solid var(--ink-faint);
  transition:background .25s ease, border-color .25s ease}
.tb-clock-dot[data-state="open"]{background:var(--teal);border-color:var(--teal)}
.tb-clock-city{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-mute);font-weight:600;line-height:1;
  white-space:nowrap}
.tb-clock-time{font-family:var(--mono);font-size:15.5px;font-weight:500;
  color:var(--ink);font-variant-numeric:tabular-nums;letter-spacing:.02em;
  line-height:1.15;white-space:nowrap;margin-top:1px}
.tb-clock-time .sec{color:var(--blue);font-weight:400;
  animation:tbSecPulse 2s linear infinite}
@keyframes tbSecPulse{0%,100%{opacity:.55}50%{opacity:1}}
.tb-clock-utc{font-size:9px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-faint);font-weight:500;line-height:1;white-space:nowrap;
  display:inline-flex;align-items:center;gap:6px}
.tb-clock-utc .off{color:var(--ink-mute);margin-left:3px;letter-spacing:.04em}
.tb-clock-utc .state{color:var(--ink-faint);letter-spacing:.14em}
.tb-clock[data-open="true"] .tb-clock-utc .state{color:var(--teal-d)}

.tb-contact{font-family:var(--display);font-weight:600;text-transform:uppercase;
  font-size:12.5px;letter-spacing:.08em;color:var(--ink);
  display:inline-flex;align-items:center;gap:8px;align-self:center;
  padding:11px 16px;border:1px solid var(--ink);
  transition:background .2s, color .2s, transform .2s, box-shadow .2s}
.tb-contact .arr{transition:transform .2s}
.tb-contact:hover{background:var(--ink);color:var(--paper);
  transform:translateY(-1px);box-shadow:0 8px 18px -12px rgba(38,39,47,.5)}
.tb-contact:hover .arr{transform:translateX(3px)}
html[data-theme="dark"] .tb-contact{color:#fff;border-color:rgba(255,255,255,.55)}
html[data-theme="dark"] .tb-contact:hover{background:#fff;color:var(--ink)}

@media (max-width: 1180px){
  .tb-clock{padding:10px 14px}
  .tb-clock-time{font-size:14px}
}
@media (max-width: 980px){
  .tb-clocks .tb-clock:nth-child(3){display:none}
}
@media (max-width: 820px){
  .tb-clocks .tb-clock:nth-child(2){display:none}
}
@media (max-width: 680px){
  .tb-clocks{display:none}
}

/* =============================================================
   HERO
   ============================================================= */
.hero{padding-top:clamp(56px,6vw,96px);padding-bottom:clamp(40px,5vw,72px)}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,0.85fr);
  gap:clamp(40px,5vw,80px);align-items:start}
.hero-copy--full{max-width:1080px}
.hero-copy--full h1.display{max-width:18ch}

.kicker{display:inline-flex;flex-wrap:wrap;align-items:center;gap:8px;
  font-family:var(--mono);font-size:11.5px;color:var(--ink-mute);
  letter-spacing:.08em;text-transform:uppercase;margin-bottom:clamp(24px,3vw,36px)}
.kicker .dot-y{width:8px;height:8px;border-radius:999px;background:var(--yellow);
  display:inline-block;margin-right:6px}
.kicker .sep{color:var(--ink-faint)}

h1.display{font-family:var(--display);font-weight:700;text-transform:uppercase;
  font-size:clamp(54px, 7.4vw, 124px);
  line-height:1.04;letter-spacing:.002em;
  margin:0 0 20px;color:var(--ink);
  text-wrap:balance;max-width:14ch}
h1.display .blue{color:var(--blue)}

.sub-italic{font-family:var(--italic);font-style:italic;font-weight:400;
  font-size:clamp(20px,1.8vw,28px);line-height:1.3;color:var(--ink-soft);
  max-width:36ch;margin:0 0 clamp(24px,3vw,32px);
  padding-left:14px;border-left:2px solid var(--blue)}

.lede{font-family:var(--body);font-weight:400;
  font-size:clamp(16px,1.15vw,18px);line-height:1.62;
  color:var(--ink-soft);max-width:56ch;margin:0 0 clamp(28px,3vw,36px)}

.hero-actions{display:flex;flex-wrap:wrap;gap:12px}
.btn{display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;background:var(--blue);color:#fff;
  font-family:var(--display);font-weight:600;font-size:13px;
  letter-spacing:.08em;text-transform:uppercase;
  border:1px solid var(--blue);border-radius:0;cursor:pointer;
  transition:transform .2s, box-shadow .2s, background .2s, border-color .2s}
.btn:hover{background:var(--blue-d);border-color:var(--blue-d);
  transform:translateY(-1px);box-shadow:0 10px 22px -12px rgba(22,122,203,.55)}
.btn .btn-arrow{display:inline-block;transition:transform .25s}
.btn:hover .btn-arrow{transform:translateX(3px)}
.btn.ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* Hero side: type-driven, NOT a map */
.hero-side{position:relative;border:1px solid var(--ink-rule);background:var(--paper-2);
  padding:32px 32px 28px;color:var(--ink);overflow:hidden;
  display:flex;flex-direction:column;gap:24px;min-height:480px}
.hero-side .vbars{position:absolute;top:22px;right:22px}

.pi-mark{display:flex;align-items:center;gap:18px;margin-top:8px}
.pi-mark .pi-glyph-lg{font-family:var(--italic);font-style:italic;font-weight:500;
  font-size:110px;line-height:.85;color:var(--blue)}
.pi-mark-cap{font-size:11.5px;color:var(--ink-mute);letter-spacing:.1em;
  text-transform:uppercase;font-weight:600;max-width:14ch;line-height:1.3}

.side-process{list-style:none;padding:0;margin:6px 0 0;display:flex;flex-direction:column;
  gap:0;border-top:1px solid var(--ink-rule)}
.side-process li{display:grid;grid-template-columns:48px 1fr;gap:14px;align-items:center;
  padding:13px 0;border-bottom:1px solid var(--ink-rule);
  font-family:var(--display);font-weight:600;text-transform:uppercase;
  font-size:14px;letter-spacing:.04em;color:var(--ink);position:relative}
.side-process li .mono{font-size:11.5px;font-weight:500;color:var(--blue);
  letter-spacing:.06em;text-transform:none}
.side-process li::before{content:"";position:absolute;left:34px;top:0;bottom:0;width:2px;
  background:var(--yellow);opacity:0}
.side-process li:first-child::before{opacity:1;top:50%}
.side-process li:last-child::before{opacity:1;bottom:50%}
.side-process li:not(:first-child):not(:last-child)::before{opacity:1}
.side-foot{font-size:10.5px;color:var(--ink-faint);letter-spacing:.1em;
  text-transform:uppercase;margin-top:4px;font-weight:600}

/* Brand-coloured service tiles below hero */
.strap{display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  margin-top:clamp(48px,5vw,72px)}
.strap.strap-5{grid-template-columns:repeat(5,1fr)}
.strap.strap-4{grid-template-columns:repeat(4,1fr)}
.strap-tile{position:relative;padding:32px 26px 32px;display:flex;flex-direction:column;
  gap:12px;min-height:260px;overflow:hidden}
.strap-tile.tile-yellow{background:var(--yellow);color:var(--ink)}
.strap-tile.tile-teal{background:var(--teal);color:var(--ink)}
.strap-tile.tile-blue{background:var(--blue);color:#fff}
.strap-tile.tile-dark{background:var(--ink);color:#fff}
.strap-tile.tile-white{background:var(--paper);color:var(--ink);
  border:1px solid var(--ink-rule)}
.strap-tile.tile-blue .t-sub em,.strap-tile.tile-blue .t-body{color:rgba(255,255,255,.88)}
.strap-tile.tile-blue .t-num{color:rgba(255,255,255,.7)}
.strap-tile.tile-dark .t-sub em,.strap-tile.tile-dark .t-body{color:rgba(255,255,255,.85)}
.strap-tile.tile-dark .t-num{color:var(--yellow)}
.strap-tile.tile-white .t-num{color:var(--blue)}
.t-num{font-size:12px;font-weight:600;letter-spacing:.1em;color:var(--ink-mute);
  font-family:var(--mono)}
.t-head{font-family:var(--display);font-weight:700;text-transform:uppercase;
  font-size:clamp(22px,2.1vw,32px);line-height:1.06;letter-spacing:.005em;color:inherit}
.t-sub{font-family:var(--italic);font-style:italic;font-weight:400;font-size:15px;
  color:var(--ink-soft);margin:-2px 0 4px}
.t-body{font-size:14px;line-height:1.55;color:var(--ink-soft);max-width:32ch;margin:0}

/* =============================================================
   SECTION HEAD (shared)
   ============================================================= */
.section-head.two-col{display:grid;grid-template-columns:1.05fr 1fr;
  gap:clamp(32px,5vw,80px);align-items:end;margin-bottom:clamp(40px,5vw,72px)}
.section-h{font-family:var(--display);font-weight:700;text-transform:uppercase;
  font-size:clamp(36px,4.4vw,72px);line-height:1.08;letter-spacing:.003em;
  margin:8px 0 14px;color:var(--ink);text-wrap:balance;max-width:18ch}
.section-sub{font-family:var(--italic);font-style:italic;font-weight:400;
  font-size:clamp(17px,1.4vw,22px);line-height:1.3;color:var(--blue);
  margin:0;max-width:36ch}
.head-text{font-family:var(--body);font-weight:400;
  font-size:clamp(15px,1.1vw,17.5px);line-height:1.62;
  color:var(--ink-soft);max-width:50ch;margin:0}
.on-dark{color:#fff !important}
.on-dark.section-sub{color:var(--yellow) !important}
.on-dark.head-text{color:rgba(255,255,255,.78) !important}
.on-dark .vbars-mini .vbar.y{background:var(--yellow)}
.on-dark .vbars-mini .vbar.b{background:var(--teal)}

/* =============================================================
   THE SHIFT
   ============================================================= */
.shift{padding-top:clamp(72px,8vw,128px);padding-bottom:clamp(48px,6vw,88px);
  border-top:1px solid var(--ink-rule)}
.shift-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--ink-rule)}
.shift-col{padding:28px 28px 32px;border-right:1px solid var(--ink-rule);
  display:flex;flex-direction:column;gap:10px;position:relative}
.shift-col:last-child{border-right:none}
.col-bars{position:absolute;top:-1px;left:28px;display:flex;gap:3px}
.col-bars .vbar{width:3px;height:24px}
.col-bars .vbar.y{background:var(--yellow)}
.col-bars .vbar.b{background:var(--blue)}
.col-num{font-size:11.5px;color:var(--ink-mute);font-weight:600;letter-spacing:.08em;
  margin-top:20px}
.col-h{font-family:var(--display);font-weight:700;text-transform:uppercase;
  font-size:clamp(20px,1.7vw,26px);line-height:1.10;letter-spacing:.003em;
  color:var(--ink);margin:0 0 4px;max-width:20ch}
.col-sub{font-family:var(--italic);font-style:italic;font-weight:400;font-size:15px;
  color:var(--blue);margin:6px 0 0}
.col-body{margin:8px 0 0;color:var(--ink-soft);font-size:14.5px;line-height:1.62}
.col-body strong{color:var(--ink);font-weight:600}

/* =============================================================
   STRATEGIC DOMAINS
   ============================================================= */
.domains{padding-top:clamp(72px,8vw,128px);padding-bottom:clamp(48px,6vw,88px);
  border-top:1px solid var(--ink-rule)}
.domains-list{display:flex;flex-direction:column;border-top:1px solid var(--ink-rule)}
.domain{display:grid;grid-template-columns:80px 1fr 220px;
  gap:clamp(20px,3vw,48px);padding:clamp(28px,3vw,44px) 0;
  border-bottom:1px solid var(--ink-rule);align-items:start;
  transition:background .2s;position:relative}
.domain::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  display:flex;flex-direction:column;gap:3px;width:0;height:0;pointer-events:none}
.domain:hover{background:var(--paper-2)}
.d-num{font-size:14px;color:var(--blue);font-weight:600;padding-top:6px;
  letter-spacing:.08em;font-family:var(--mono)}
.d-body h3{font-family:var(--display);font-weight:700;text-transform:uppercase;
  font-size:clamp(22px,2.3vw,34px);line-height:1.10;letter-spacing:.003em;
  margin:0 0 10px;color:var(--ink);text-wrap:balance;max-width:24ch}
.d-sub{font-family:var(--italic);font-style:italic;font-weight:400;
  font-size:clamp(16px,1.2vw,19px);line-height:1.32;color:var(--blue);
  margin:6px 0 14px;max-width:48ch}
.d-text{margin:0 0 14px;color:var(--ink-soft);font-size:15px;line-height:1.62;max-width:62ch}
.d-tags{display:flex;flex-wrap:wrap;gap:6px;list-style:none;padding:0;margin:6px 0 0}
.d-tags li{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;
  color:var(--ink-mute);padding:5px 9px;border:1px solid var(--ink-rule);
  text-transform:uppercase}
.d-meta{display:flex;flex-direction:column;gap:6px;padding-top:8px;
  border-left:2px solid var(--yellow);padding-left:12px}
.d-meta-k{font-size:10.5px;color:var(--ink-mute);letter-spacing:.1em;text-transform:uppercase;
  font-weight:600}
.d-meta-v{font-family:var(--display);font-weight:600;text-transform:uppercase;
  font-size:13px;color:var(--ink);letter-spacing:.04em;line-height:1.3}
.inline{border-bottom:1px solid var(--blue);color:var(--blue)}
.inline:hover{color:var(--blue-d)}

/* =============================================================
   REGIONAL STRATEGY — DARK section (signature contrast)
   ============================================================= */
.region{background:var(--ink);color:#fff;
  padding-top:clamp(72px,9vw,128px);padding-bottom:clamp(72px,9vw,128px);
  margin-top:clamp(56px,6vw,88px);position:relative;overflow:hidden}
.region::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;
  background:linear-gradient(90deg, var(--yellow) 0%, var(--yellow) 50%,
                             var(--blue) 50%, var(--blue) 100%);}
.region-wrap{position:relative}
.region-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(40px,5vw,80px);
  align-items:start;margin-top:clamp(20px,2vw,32px)}
.region-thesis .thesis-body{margin:0 0 16px;color:rgba(255,255,255,.82);
  font-family:var(--body);font-size:16px;line-height:1.68;max-width:60ch}
.thesis-body strong{color:#fff;font-weight:600}
.thesis-foot{font-size:11px;color:rgba(255,255,255,.55);letter-spacing:.1em;
  text-transform:uppercase;margin-top:28px !important;padding-top:18px;
  border-top:1px solid rgba(255,255,255,.18);max-width:none}

.region-stats{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.stat{display:flex;flex-direction:column;gap:14px;padding:24px 22px;
  border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.03);
  position:relative;overflow:hidden}
.stat::before{content:"";position:absolute;top:18px;right:18px;width:2px;height:24px;
  background:var(--yellow)}
.stat::after{content:"";position:absolute;top:18px;right:13px;width:2px;height:24px;
  background:var(--blue)}
.donut{width:130px;height:130px;display:block;align-self:center}
.stat-cap{text-align:center}
.stat-h{font-family:var(--display);font-weight:700;text-transform:uppercase;
  font-size:14px;letter-spacing:.06em;color:#fff;margin-bottom:6px}
.stat-d{font-family:var(--body);font-weight:400;font-size:13px;line-height:1.5;
  color:rgba(255,255,255,.7)}

.region-note{margin-top:36px;font-size:11px;color:rgba(255,255,255,.45);
  letter-spacing:.08em;text-transform:uppercase}

/* =============================================================
   RESEARCH & INSIGHTS
   ============================================================= */
.insights{padding-top:clamp(72px,8vw,128px);padding-bottom:clamp(48px,6vw,88px)}
.insight-list{list-style:none;padding:0;margin:0;border-top:1px solid var(--ink-rule)}
.insight{display:grid;grid-template-columns:1fr 2fr 110px;gap:clamp(20px,3vw,48px);
  padding:clamp(24px,2.6vw,40px) 0;border-bottom:1px solid var(--ink-rule);
  align-items:start;transition:background .2s}
.insight:hover{background:var(--paper-2)}
.i-meta{display:flex;flex-wrap:wrap;align-items:center;gap:6px 8px;font-size:11px;
  color:var(--ink-mute);letter-spacing:.08em;text-transform:uppercase;padding-top:8px}
.i-meta .dot{color:var(--ink-faint)}
.i-h{font-family:var(--display);font-weight:700;text-transform:uppercase;
  font-size:clamp(22px,2vw,30px);line-height:1.10;letter-spacing:.003em;
  margin:0 0 8px;color:var(--ink);text-wrap:balance;max-width:32ch}
.i-sub{font-family:var(--italic);font-style:italic;font-weight:400;font-size:15.5px;
  color:var(--blue);margin:6px 0 12px;max-width:42ch}
.insight p:not(.i-sub){margin:0;color:var(--ink-soft);font-size:14.5px;line-height:1.55;max-width:60ch}
.i-state{font-family:var(--mono);font-size:10.5px;color:var(--ink-mute);letter-spacing:.08em;
  text-transform:uppercase;padding:6px 10px;border:1px solid var(--ink-rule);
  justify-self:end;align-self:start;margin-top:6px;white-space:nowrap}

/* =============================================================
   WHO WE SERVE — brand tile composition (matches 'Applications')
   ============================================================= */
.serve{padding-top:clamp(64px,7vw,112px);padding-bottom:clamp(56px,6vw,96px);
  border-top:1px solid var(--ink-rule)}
.serve-grid{list-style:none;padding:0;margin:0;display:grid;
  grid-template-columns:repeat(3,1fr);gap:1px;background:var(--ink-rule);
  border:1px solid var(--ink-rule)}
.serve-tile{padding:36px 28px 32px;display:flex;flex-direction:column;
  align-items:flex-start;gap:14px;min-height:180px;
  font-family:var(--display);font-weight:700;text-transform:uppercase;
  letter-spacing:.005em;transition:filter .2s}
.serve-tile:hover{filter:brightness(0.96)}
.serve-tile.tile-white{background:var(--paper);color:var(--ink)}
.serve-tile.tile-yellow{background:var(--yellow);color:var(--ink)}
.serve-tile.tile-teal{background:var(--teal);color:var(--ink)}
.serve-tile.tile-blue{background:var(--blue);color:#fff}
.serve-tile.tile-dark{background:var(--ink);color:#fff}
.serve-tile .s-letter{font-family:var(--mono);font-size:12px;font-weight:600;
  letter-spacing:.06em;opacity:.7;text-transform:none}
.serve-tile.tile-blue .s-letter,.serve-tile.tile-dark .s-letter{color:var(--yellow);opacity:1}
.serve-tile .s-name{font-size:clamp(20px,1.7vw,24px);line-height:1.12;letter-spacing:.005em}

/* =============================================================
   CONTACT
   ============================================================= */
.contact{padding-top:clamp(80px,9vw,140px);padding-bottom:clamp(56px,6vw,96px);
  border-top:1px solid var(--ink-rule)}
.contact-inner{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(40px,5vw,80px);
  align-items:start;margin-bottom:48px}
.contact-h{font-family:var(--display);font-weight:700;text-transform:uppercase;
  font-size:clamp(40px,5.2vw,80px);line-height:1.06;letter-spacing:.003em;
  margin:8px 0 16px;color:var(--ink);text-wrap:balance;max-width:14ch}
.contact-sub{font-family:var(--italic);font-style:italic;font-weight:400;
  font-size:clamp(18px,1.6vw,24px);line-height:1.3;color:var(--blue);
  margin:0 0 20px;padding-left:14px;border-left:2px solid var(--blue)}
.contact-text{font-family:var(--body);font-weight:400;
  font-size:clamp(15px,1.1vw,17px);line-height:1.62;color:var(--ink-soft);
  max-width:46ch;margin:0}

.contact-right{display:flex;flex-direction:column;gap:24px;
  padding:32px 30px;border:1px solid var(--ink);background:var(--paper);position:relative}
.contact-right .vbars.top-right{position:absolute;top:18px;right:18px}
.contact-block{display:flex;flex-direction:column;gap:5px}
.cb-label{font-size:10.5px;color:var(--ink-mute);letter-spacing:.1em;text-transform:uppercase;
  font-weight:600}
.cb-val{font-family:var(--display);font-weight:600;text-transform:uppercase;
  font-size:clamp(18px,1.6vw,22px);letter-spacing:.005em;color:var(--ink);
  transition:color .15s;line-height:1.2}
a.cb-val{position:relative;display:inline-block;align-self:flex-start}
a.cb-val::after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:2px;
  background:var(--blue);transform-origin:left;transform:scaleX(0);transition:transform .25s}
a.cb-val:hover{color:var(--blue)}
a.cb-val:hover::after{transform:scaleX(1)}

.status-strip{display:flex;align-items:center;gap:14px;
  font-size:11px;color:var(--ink-mute);letter-spacing:.08em;text-transform:uppercase;
  padding:18px 22px;border:1px solid var(--ink-rule);background:var(--paper-2)}
.status-dot{width:8px;height:8px;border-radius:999px;background:var(--blue);
  box-shadow:0 0 0 4px rgba(22,122,203,.18);animation:pulse 2.6s ease-in-out infinite}
@keyframes pulse{50%{box-shadow:0 0 0 8px rgba(22,122,203,0)}}

/* =============================================================
   FOOTER
   ============================================================= */
footer{position:relative;background:var(--ink);color:#fff;
  padding-top:clamp(64px,7vw,96px);padding-bottom:32px}
footer .brand-mark{height:64px;width:auto;align-self:flex-start;
  object-fit:contain;object-position:left center;background:transparent}
.footer-grad{position:absolute;left:0;right:0;top:0;height:3px;
  background:linear-gradient(90deg, var(--yellow) 0%, var(--yellow) 50%,
                             var(--blue) 50%, var(--blue) 100%)}

.footer-inner{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;
  gap:clamp(32px,4vw,64px);padding-top:8px;padding-bottom:48px}
.foot-col{display:flex;flex-direction:column;gap:10px}
.foot-h{font-family:var(--mono);font-size:10.5px;color:rgba(255,255,255,.55);
  letter-spacing:.12em;text-transform:uppercase;font-weight:600;margin-bottom:8px}
.foot-col a{color:rgba(255,255,255,.85);font-size:14px;transition:color .15s}
.foot-col a:hover{color:var(--yellow)}
.foot-col .muted{color:rgba(255,255,255,.55);font-size:13px}
.foot-brand .foot-tag{font-family:var(--italic);font-style:italic;font-weight:400;
  font-size:15px;line-height:1.5;color:rgba(255,255,255,.75);max-width:32ch;margin:6px 0 0}

.foot-sister .sister-link{display:flex;align-items:center;gap:10px;
  padding:10px 14px;border:1px solid rgba(255,255,255,.18);
  align-self:flex-start;transition:border-color .2s}
.foot-sister .sister-link:hover{border-color:rgba(255,255,255,.45)}
.sister-grad{width:10px;height:10px;border-radius:999px;background:var(--shift-grad)}
.sister-name{font-family:var(--italic);font-style:italic;font-weight:500;font-size:14.5px;color:#fff}

.foot-legal{display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding-top:24px;border-top:1px solid rgba(255,255,255,.12);
  font-size:11px;color:rgba(255,255,255,.55);letter-spacing:.08em}
.foot-legal a{color:rgba(255,255,255,.65)}
.foot-legal a:hover{color:var(--yellow)}
.foot-legal .legal-links{display:inline-flex;align-items:center;gap:10px}
.foot-legal .dot{opacity:.5}

/* =============================================================
   APPROACH — 5-phase methodology flow
   ============================================================= */
.approach{padding-top:clamp(72px,8vw,128px);padding-bottom:clamp(48px,6vw,88px);
  border-top:1px solid var(--ink-rule);background:var(--paper-2)}
.approach-flow{list-style:none;padding:0;margin:clamp(20px,2vw,32px) 0 0;
  display:grid;grid-template-columns:1fr 24px 1fr 24px 1fr 24px 1fr 24px 1fr;
  gap:0;align-items:stretch}
.ap-step{padding:28px 24px 32px;background:var(--paper);
  border:1px solid var(--ink-rule);display:flex;flex-direction:column;gap:8px;
  position:relative;min-height:240px}
.ap-step::before{content:"";position:absolute;top:-1px;left:24px;width:32px;height:3px;
  background:var(--yellow)}
.ap-step::after{content:"";position:absolute;top:-1px;left:60px;width:32px;height:3px;
  background:var(--blue)}
.ap-step-accent{background:var(--ink);color:#fff;border-color:var(--ink)}
.ap-step-accent .ap-h,.ap-step-accent .ap-num{color:#fff}
.ap-step-accent .ap-body{color:rgba(255,255,255,.78)}
.ap-step-accent::before{background:var(--yellow)}
.ap-step-accent::after{background:var(--teal)}
.ap-num{font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.08em;
  color:var(--blue);margin-top:12px}
.ap-h{font-family:var(--display);font-weight:700;text-transform:uppercase;
  font-size:clamp(16px,1.3vw,20px);line-height:1.04;letter-spacing:.005em;
  margin:6px 0 0;color:var(--ink)}
.ap-body{font-family:var(--body);font-size:13.5px;line-height:1.55;color:var(--ink-soft);
  margin:8px 0 0}
.ap-arrow{position:relative;display:flex;align-items:center;justify-content:center;
  pointer-events:none}
.ap-arrow::before{content:"";position:absolute;left:0;right:0;top:50%;height:1px;
  background:var(--ink-rule)}
.ap-arrow::after{content:"→";position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%);font-family:var(--mono);font-size:14px;
  color:var(--blue);background:var(--paper-2);padding:0 4px}

/* =============================================================
   SECTORS — 4 brand-coloured tiles
   ============================================================= */
.sectors{padding-top:clamp(72px,8vw,128px);padding-bottom:clamp(48px,6vw,88px);
  border-top:1px solid var(--ink-rule)}
.sector-grid{list-style:none;padding:0;margin:0;display:grid;
  grid-template-columns:repeat(4,1fr);gap:1px;background:var(--ink-rule);
  border:1px solid var(--ink-rule)}
.sec-tile{padding:32px 28px 36px;display:flex;flex-direction:column;gap:10px;
  min-height:260px;transition:filter .2s}
.sec-tile:hover{filter:brightness(0.97)}
.sec-tile.tile-yellow{background:var(--yellow);color:var(--ink)}
.sec-tile.tile-teal{background:var(--teal);color:var(--ink)}
.sec-tile.tile-blue{background:var(--blue);color:#fff}
.sec-tile.tile-dark{background:var(--ink);color:#fff}
.sec-num{font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.1em;
  color:inherit;opacity:.6;margin-bottom:4px}
.sec-tile.tile-blue .sec-num,.sec-tile.tile-dark .sec-num{color:var(--yellow);opacity:1}
.sec-h{font-family:var(--display);font-weight:700;text-transform:uppercase;
  font-size:clamp(22px,1.9vw,30px);line-height:1.04;letter-spacing:.005em;
  margin:6px 0 0;color:inherit}
.sec-body{font-family:var(--body);font-size:14px;line-height:1.55;
  margin:8px 0 0;color:inherit;opacity:.78}
.sec-tile.tile-blue .sec-body,.sec-tile.tile-dark .sec-body{opacity:.85}

/* =============================================================
   PERSPECTIVE — 3 columns
   ============================================================= */
.perspective{padding-top:clamp(72px,8vw,128px);padding-bottom:clamp(48px,6vw,88px);
  border-top:1px solid var(--ink-rule)}
.persp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--ink-rule)}
.persp-col{padding:32px 32px 36px;border-right:1px solid var(--ink-rule);
  display:flex;flex-direction:column;gap:10px;position:relative}
.persp-col:last-child{border-right:none}
.persp-col .col-bars{position:absolute;top:-1px;left:32px;display:flex;gap:3px}
.persp-col .col-bars .vbar{width:3px;height:24px}
.persp-col .col-bars .vbar.y{background:var(--yellow)}
.persp-col .col-bars .vbar.b{background:var(--blue)}
.persp-col .col-num{margin-top:24px;font-family:var(--mono);font-size:14px;
  font-weight:600;letter-spacing:.04em;color:var(--blue);text-transform:lowercase}
.persp-col .col-h{font-family:var(--display);font-weight:700;text-transform:uppercase;
  font-size:clamp(20px,1.7vw,26px);line-height:1.08;letter-spacing:.003em;
  color:var(--ink);margin:4px 0 0;max-width:22ch}
.persp-col .col-body{margin:10px 0 0;color:var(--ink-soft);font-size:14.5px;line-height:1.62}
.persp-col .col-body em{font-family:var(--italic);font-style:italic;color:var(--ink)}

/* =============================================================
   Density tweak
   ============================================================= */
html[data-density="compact"] .hero{padding-top:clamp(40px,5vw,72px);padding-bottom:clamp(36px,5vw,64px)}
html[data-density="compact"] .about,
html[data-density="compact"] .domains,
html[data-density="compact"] .approach,
html[data-density="compact"] .sectors,
html[data-density="compact"] .perspective,
html[data-density="compact"] .contact{padding-top:clamp(48px,6vw,80px);padding-bottom:clamp(40px,5vw,68px)}
html[data-density="compact"] h1.display{font-size:clamp(40px,5.4vw,88px)}
html[data-density="compact"] .section-h{font-size:clamp(28px,3.6vw,56px)}

/* =============================================================
   ABOUT — prose + Pi callout
   ============================================================= */
.about{padding-top:clamp(72px,8vw,128px);padding-bottom:clamp(48px,6vw,88px);
  border-top:1px solid var(--ink-rule)}
.about-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(40px,5vw,80px);
  align-items:start;margin-top:clamp(8px,1vw,16px)}
.about-prose p{font-family:var(--body);font-size:clamp(16px,1.15vw,18px);line-height:1.7;
  color:var(--ink-soft);margin:0 0 20px;max-width:60ch}
.about-prose p:last-child{margin-bottom:0}
.about-prose strong{color:var(--ink);font-weight:600}

.pi-callout{position:relative;padding:36px 32px 32px;background:var(--paper-2);
  border:1px solid var(--ink-rule);overflow:hidden}
.pi-callout::before{content:"";position:absolute;top:0;left:32px;display:block;width:6px;height:30px;
  background:linear-gradient(180deg, var(--yellow) 0%, var(--yellow) 50%, var(--blue) 50%, var(--blue) 100%);
  /* render as two stacked rects instead */
  background:none}
.pi-callout .pi-glyph{position:absolute;right:-20px;bottom:-40px;
  font-family:var(--italic);font-style:italic;font-weight:500;
  font-size:280px;line-height:.7;color:var(--blue);opacity:.10;
  pointer-events:none;user-select:none}
.pi-cap{font-size:11px;color:var(--ink-mute);letter-spacing:.12em;text-transform:uppercase;
  font-weight:600;margin-bottom:10px;position:relative;z-index:1}
.pi-h{font-family:var(--display);font-weight:700;text-transform:uppercase;
  font-size:clamp(44px,4vw,64px);line-height:.92;letter-spacing:.005em;
  color:var(--ink);margin:0 0 14px;position:relative;z-index:1}
.pi-text{font-family:var(--body);font-size:15px;line-height:1.62;color:var(--ink-soft);
  margin:0 0 22px;position:relative;z-index:1}
.pi-text em{font-family:var(--italic);font-style:italic;color:var(--blue)}
.pi-words{list-style:none;padding:0;margin:18px 0 0;display:flex;flex-direction:column;
  gap:8px;position:relative;z-index:1;padding-top:16px;border-top:1px solid var(--ink-rule)}
.pi-words li{display:flex;align-items:center;gap:12px;
  font-family:var(--display);font-weight:600;text-transform:uppercase;
  font-size:13px;letter-spacing:.08em;color:var(--ink)}
.pi-bullet{display:inline-block;width:10px;height:10px;border-radius:999px;flex:none}
.pi-bullet[data-c="b"]{background:var(--blue)}
.pi-bullet[data-c="y"]{background:var(--yellow)}
.pi-bullet[data-c="t"]{background:var(--teal)}
.pi-bullet[data-c="d"]{background:var(--ink)}

/* =============================================================
   PERSPECTIVE — 6-column grid override
   ============================================================= */
.shift-grid.six-grid{grid-template-columns:repeat(3,1fr)}
.shift-grid.six-grid .shift-col:nth-child(3n){border-right:none}
.shift-grid.six-grid .shift-col:nth-child(n+4){border-top:1px solid var(--ink-rule)}

/* =============================================================
   CORE PRINCIPLES — 5 brand-colored tiles
   ============================================================= */
.principles{padding-top:clamp(72px,8vw,128px);padding-bottom:clamp(48px,6vw,88px);
  border-top:1px solid var(--ink-rule)}
.principle-grid{list-style:none;padding:0;margin:0;display:grid;
  grid-template-columns:repeat(5,1fr);gap:1px;background:var(--ink-rule);
  border:1px solid var(--ink-rule)}
.p-tile{padding:32px 26px 36px;display:flex;flex-direction:column;gap:10px;
  min-height:280px;position:relative;transition:filter .2s}
.p-tile:hover{filter:brightness(0.97)}
.p-tile.tile-white{background:var(--paper);color:var(--ink)}
.p-tile.tile-yellow{background:var(--yellow);color:var(--ink)}
.p-tile.tile-teal{background:var(--teal);color:var(--ink)}
.p-tile.tile-blue{background:var(--blue);color:#fff}
.p-tile.tile-dark{background:var(--ink);color:#fff}
.p-num{font-family:var(--mono);font-size:14px;font-weight:500;letter-spacing:.04em;
  color:var(--ink-mute);text-transform:lowercase}
.p-tile.tile-blue .p-num,.p-tile.tile-dark .p-num{color:var(--yellow);font-weight:600}
.p-tile.tile-yellow .p-num,.p-tile.tile-teal .p-num{color:var(--ink);opacity:.55}
.p-h{font-family:var(--display);font-weight:700;text-transform:uppercase;
  font-size:clamp(20px,1.7vw,26px);line-height:1.06;letter-spacing:.003em;
  margin:8px 0 0;color:inherit}
.p-sub{font-family:var(--italic);font-style:italic;font-weight:400;
  font-size:14.5px;line-height:1.3;margin:4px 0 0;color:inherit;opacity:.78}
.p-tile.tile-blue .p-sub,.p-tile.tile-dark .p-sub{opacity:.85}
.p-body{font-family:var(--body);font-size:14px;line-height:1.6;margin:10px 0 0;
  color:inherit;opacity:.78}
.p-tile.tile-blue .p-body,.p-tile.tile-dark .p-body{opacity:.85}

/* =============================================================
   AREAS OF FOCUS — chip cloud
   ============================================================= */
.areas{padding-top:clamp(72px,8vw,128px);padding-bottom:clamp(48px,6vw,88px);
  border-top:1px solid var(--ink-rule)}
.areas-chips{list-style:none;padding:0;margin:clamp(24px,3vw,40px) 0 0;
  display:flex;flex-wrap:wrap;gap:10px}
.areas-chips li{font-family:var(--display);font-weight:600;text-transform:uppercase;
  font-size:13px;letter-spacing:.05em;color:var(--ink);
  padding:12px 18px;border:1px solid var(--ink);background:var(--paper);
  transition:background .2s, color .2s}
.areas-chips li:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
/* Sprinkle accent colors */
.areas-chips li:nth-child(4n+1){border-color:var(--ink)}
.areas-chips li:nth-child(4n+2){border-left:4px solid var(--yellow);padding-left:14px}
.areas-chips li:nth-child(4n+3){border-left:4px solid var(--blue);padding-left:14px}
.areas-chips li:nth-child(4n+4){border-left:4px solid var(--teal);padding-left:14px}
html[data-density="compact"] .shift,
html[data-density="compact"] .domains,
html[data-density="compact"] .insights,
html[data-density="compact"] .serve,
html[data-density="compact"] .contact{padding-top:clamp(48px,6vw,80px);padding-bottom:clamp(40px,5vw,68px)}
html[data-density="compact"] h1.display{font-size:clamp(40px,5.4vw,88px)}
html[data-density="compact"] .section-h{font-size:clamp(28px,3.6vw,56px)}

/* =============================================================
   Accent emphasis (Yellow / Teal lead)
   ============================================================= */
html[data-accent="yellow"] h1.display .blue{color:var(--yellow-d)}
html[data-accent="yellow"] .section-sub,
html[data-accent="yellow"] .col-sub,
html[data-accent="yellow"] .d-sub,
html[data-accent="yellow"] .i-sub,
html[data-accent="yellow"] .contact-sub,
html[data-accent="yellow"] .brand-sub{color:var(--yellow-d)}
html[data-accent="yellow"] .sub-italic{border-left-color:var(--yellow-d)}
html[data-accent="yellow"] .btn{background:var(--yellow-d);border-color:var(--yellow-d);color:var(--ink)}
html[data-accent="yellow"] .btn:hover{background:var(--yellow);border-color:var(--yellow)}
html[data-accent="yellow"] .d-num,
html[data-accent="yellow"] .corridor-svg path[stroke="var(--blue)"]{}

html[data-accent="teal"] h1.display .blue{color:var(--teal-d)}
html[data-accent="teal"] .section-sub,
html[data-accent="teal"] .col-sub,
html[data-accent="teal"] .d-sub,
html[data-accent="teal"] .i-sub,
html[data-accent="teal"] .contact-sub,
html[data-accent="teal"] .brand-sub{color:var(--teal-d)}
html[data-accent="teal"] .sub-italic{border-left-color:var(--teal-d)}
html[data-accent="teal"] .btn{background:var(--teal-d);border-color:var(--teal-d)}
html[data-accent="teal"] .btn:hover{background:var(--teal);border-color:var(--teal)}

/* =============================================================
   Responsive
   ============================================================= */
@media (max-width: 1200px){
  .strap.strap-5{grid-template-columns:repeat(3,1fr)}
  .strap.strap-4{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 1100px){
  .domain{grid-template-columns:60px 1fr}
  .domain .d-meta{grid-column:2;border-left:none;border-top:2px solid var(--yellow);
    padding-left:0;padding-top:10px;flex-direction:row;gap:10px;margin-top:4px}
  .approach-flow{grid-template-columns:1fr 1fr;gap:16px}
  .approach-flow .ap-arrow{display:none}
  .sector-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 900px){
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .strap,
  .strap.strap-5,
  .strap.strap-4{grid-template-columns:1fr}
  .section-head.two-col{grid-template-columns:1fr;gap:18px}
  .about-grid{grid-template-columns:1fr;gap:32px}
  .approach-flow{grid-template-columns:1fr}
  .sector-grid{grid-template-columns:1fr}
  .persp-grid{grid-template-columns:1fr}
  .persp-col{border-right:none;border-bottom:1px solid var(--ink-rule)}
  .persp-col:last-child{border-bottom:none}
  .contact-inner{grid-template-columns:1fr;gap:32px}
  .footer-inner{grid-template-columns:1fr 1fr;gap:32px}
  .update-banner-inner{font-size:12.5px;gap:10px}
}
@media (max-width: 560px){
  .footer-inner{grid-template-columns:1fr}
  .foot-legal{flex-direction:column;align-items:flex-start;gap:8px}
}

/* =============================================================
   CONTACT MODAL  ·  triggered by hero "Begin a conversation"
   ============================================================= */
.contact-modal{position:fixed;inset:0;z-index:100;
  display:flex;align-items:center;justify-content:center;
  padding:24px;pointer-events:none}
.contact-modal[data-state="closed"]{visibility:hidden}
.contact-modal[data-state="open"],
.contact-modal[data-state="closing"]{visibility:visible;pointer-events:auto}

.cm-backdrop{position:absolute;inset:0;
  background:rgba(20,21,28,.55);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  opacity:0;transition:opacity .28s ease}
html[data-theme="dark"] .cm-backdrop{background:rgba(8,9,12,.72)}
.contact-modal[data-state="open"] .cm-backdrop{opacity:1}

.cm-card{position:relative;width:100%;max-width:620px;
  background:var(--paper);color:var(--ink);
  padding:clamp(28px,4vw,44px) clamp(24px,4vw,44px) clamp(28px,3.5vw,40px);
  border:1px solid var(--ink-rule);
  box-shadow:0 32px 64px -28px rgba(0,0,0,.45),
             0 12px 24px -16px rgba(0,0,0,.25);
  transform:translateY(14px) scale(.97);opacity:0;
  transition:opacity .32s cubic-bezier(.2,.7,.2,1),
             transform .42s cubic-bezier(.2,.7,.2,1)}
.contact-modal[data-state="open"] .cm-card{transform:translateY(0) scale(1);opacity:1}
.cm-card::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;
  background:linear-gradient(90deg, var(--yellow) 0%, var(--yellow) 50%,
                             var(--blue) 50%, var(--blue) 100%)}

.cm-close{position:absolute;top:16px;right:16px;
  width:34px;height:34px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:transparent;border:1px solid var(--ink-rule);color:var(--ink-mute);
  cursor:pointer;transition:color .2s, border-color .2s, transform .2s, background .2s}
.cm-close:hover{color:var(--ink);border-color:var(--ink);transform:rotate(90deg)}
.cm-close:focus-visible{outline:2px solid var(--blue);outline-offset:2px}

.cm-bars{display:inline-flex;gap:4px;margin-bottom:18px}
.cm-bars .vbar{height:32px}

.cm-eyebrow{font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  font-weight:600;color:var(--ink-mute);margin-bottom:10px;
  display:flex;align-items:center;gap:10px}
.cm-eyebrow::before,
.cm-eyebrow::after{content:"";flex:1;height:1px;background:var(--ink-line);max-width:0}
.cm-eyebrow::after{flex:none;display:none}

.cm-title{font-family:var(--display);font-weight:700;text-transform:uppercase;
  font-size:clamp(28px,3.4vw,44px);line-height:1.04;letter-spacing:.003em;
  margin:0 0 12px;color:var(--ink);max-width:18ch}
.cm-sub{font-family:var(--italic);font-style:italic;font-weight:400;
  font-size:clamp(16px,1.3vw,19px);line-height:1.35;color:var(--blue);
  margin:0 0 clamp(20px,2.5vw,28px);max-width:36ch}
html[data-theme="dark"] .cm-sub{color:var(--blue-bright)}

.cm-options{display:flex;flex-direction:column;gap:12px}

.cm-opt{position:relative;display:grid;
  grid-template-columns:auto auto 1fr auto;align-items:center;gap:18px;
  padding:18px 20px;border:1px solid var(--ink-rule);background:var(--paper-2);
  color:var(--ink);text-decoration:none;
  transform:translateY(10px);opacity:0;
  transition:transform .15s ease, background .2s ease, border-color .2s ease,
             box-shadow .2s ease, opacity .35s ease, color .2s ease}
.contact-modal[data-state="open"] .cm-opt{
  transform:translateY(0);opacity:1;
  transition-delay:calc(120ms + var(--i) * 90ms),0s,0s,0s,calc(120ms + var(--i) * 90ms),0s}
.cm-opt:hover{background:var(--paper);border-color:var(--ink);
  box-shadow:0 14px 24px -18px rgba(0,0,0,.35);transform:translateY(-1px)}
.cm-opt:focus-visible{outline:2px solid var(--blue);outline-offset:3px}

.cm-opt-rule{width:3px;align-self:stretch;background:var(--ink-rule);
  transition:background .2s, transform .25s;transform-origin:center}
.cm-opt:hover .cm-opt-rule{background:var(--blue);transform:scaleY(1.05)}
.cm-opt:nth-child(1):hover .cm-opt-rule{background:var(--yellow-d)}

.cm-opt-num{font-size:11px;font-weight:600;letter-spacing:.1em;
  color:var(--ink-mute);align-self:flex-start;padding-top:3px}

.cm-opt-body{display:flex;flex-direction:column;gap:4px;min-width:0}
.cm-opt-h{font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-mute);font-weight:600}
.cm-opt-v{font-family:var(--display);font-weight:600;text-transform:none;
  font-size:clamp(18px,1.8vw,22px);line-height:1.15;letter-spacing:.005em;
  color:var(--ink);word-break:break-word}
.cm-opt-foot{font-size:11px;color:var(--ink-mute);letter-spacing:.04em}

.cm-opt-arr{font-family:var(--display);font-size:22px;color:var(--ink-mute);
  transition:transform .25s, color .2s}
.cm-opt:hover .cm-opt-arr{color:var(--ink);transform:translateX(4px)}

/* dark-mode surfaces */
html[data-theme="dark"] .cm-card{background:var(--paper-2);
  border-color:rgba(255,255,255,.10);
  box-shadow:0 32px 64px -28px rgba(0,0,0,.7),
             0 12px 24px -16px rgba(0,0,0,.5)}
html[data-theme="dark"] .cm-opt{background:var(--paper-3);
  border-color:rgba(255,255,255,.08)}
html[data-theme="dark"] .cm-opt:hover{background:#2f323e;
  border-color:rgba(255,255,255,.4)}
html[data-theme="dark"] .cm-close{border-color:rgba(255,255,255,.18);
  color:rgba(255,255,255,.62)}
html[data-theme="dark"] .cm-close:hover{color:#fff;border-color:#fff}

@media (max-width: 520px){
  .cm-opt{grid-template-columns:auto 1fr auto;gap:14px;padding:16px}
  .cm-opt-rule{display:none}
  .cm-title{font-size:30px}
}

@media (prefers-reduced-motion: reduce){
  .cm-backdrop,.cm-card,.cm-opt{transition-duration:.01ms}
}

/* =============================================================
   DARK-MODE  ·  surface & contrast pass
   Brand color tokens (--blue/--yellow/--teal/literal --ink) stay
   anchored to the light system; these overrides preserve dark
   surfaces that would otherwise invert, and rescue any text that
   relied on the assumption "--ink == always dark".
   ============================================================= */
html[data-theme="dark"]{
  /* brightened blue for italic accents on dark surfaces */
  --blue-bright: #6ab0ec;
  /* an anchored dark surface that does NOT flip with the theme */
  --surface-dark: #0e0f15;
}

/* Surfaces that must stay dark regardless of theme */
html[data-theme="dark"] .update-banner,
html[data-theme="dark"] footer,
html[data-theme="dark"] .strap-tile.tile-dark,
html[data-theme="dark"] .sec-tile.tile-dark,
html[data-theme="dark"] .ap-step-accent{
  background:var(--surface-dark);
  color:#fff;
  border-color:var(--surface-dark)
}
html[data-theme="dark"] .ap-step-accent{border-color:rgba(255,255,255,.10)}
html[data-theme="dark"] .update-banner{border-bottom-color:rgba(255,255,255,.08)}

/* Yellow & teal tiles: text was var(--ink) (now light) → restore dark text */
html[data-theme="dark"] .strap-tile.tile-yellow,
html[data-theme="dark"] .strap-tile.tile-teal,
html[data-theme="dark"] .sec-tile.tile-yellow,
html[data-theme="dark"] .sec-tile.tile-teal{color:#1a1b22}
html[data-theme="dark"] .strap-tile.tile-yellow .t-sub em,
html[data-theme="dark"] .strap-tile.tile-yellow .t-body,
html[data-theme="dark"] .strap-tile.tile-yellow .t-num,
html[data-theme="dark"] .strap-tile.tile-teal .t-sub em,
html[data-theme="dark"] .strap-tile.tile-teal .t-body,
html[data-theme="dark"] .strap-tile.tile-teal .t-num{color:rgba(26,27,34,.82)}

/* Regular ap-step cards: faint border becomes invisible — lift to paper-2 */
html[data-theme="dark"] .ap-step{background:var(--paper-2);border-color:rgba(255,255,255,.10)}

/* Default .contact-right border was var(--ink) (now light + too loud) */
html[data-theme="dark"] .contact-right{
  background:var(--paper-2);
  border-color:rgba(255,255,255,.18)
}

/* Brighten italic blue subheads + blue numbers — #167acb is borderline on dark */
html[data-theme="dark"] .section-sub,
html[data-theme="dark"] .d-sub,
html[data-theme="dark"] .i-sub,
html[data-theme="dark"] .contact-sub,
html[data-theme="dark"] .ap-num,
html[data-theme="dark"] .persp-col .col-num{color:var(--blue-bright)}
html[data-theme="dark"] .contact-sub{border-left-color:var(--blue-bright)}
html[data-theme="dark"] h1.display .blue{color:var(--blue-bright)}

/* Hero italic sub had a left rule in --blue — match brighter tone */
html[data-theme="dark"] .sub-italic{border-left-color:var(--blue-bright)}

/* Footer brand-mark uses the dark variant in both themes — sits on dark surface */
html[data-theme="dark"] footer .brand-mark{filter:none}

/* Footer typography contrast */
html[data-theme="dark"] footer .muted{color:rgba(255,255,255,.55)}
html[data-theme="dark"] footer .foot-h{color:rgba(255,255,255,.7)}
html[data-theme="dark"] .foot-legal{color:rgba(255,255,255,.45)}

/* Status strip dot was --blue → brighter */
html[data-theme="dark"] .status-strip .status-dot{background:var(--blue-bright)}

/* Pi callout sits on var(--paper-2) in light mode with --ink-rule border —
   already inherits. Just brighten the inner italic body. */
html[data-theme="dark"] .pi-callout .pi-text em{color:var(--ink-soft)}

/* Domain tag borders fade out at --ink-rule alpha; lift slightly */
html[data-theme="dark"] .d-tags li{border-color:rgba(255,255,255,.18)}
