:root {
  --bg-0: #070807;
  --bg-1: #101210;
  --bg-2: #171a18;
  --panel: rgba(11, 13, 12, 0.52);
  --panel-strong: rgba(19, 21, 20, 0.76);
  --line: rgba(210, 221, 214, 0.18);
  --text: #f3f5f0;
  --muted: #b9c0b8;
  --accent: #7fd7b1;
  --accent-2: #f0d57c;
  --role-accent-soft: rgba(127, 215, 177, 0.14);
  --role-glow-1: rgba(127, 215, 177, 0.18);
  --role-glow-2: rgba(240, 213, 124, 0.13);
  --role-glow-3: rgba(107, 177, 255, 0.09);
  --role-tab-active-bg: rgba(228, 244, 236, 0.92);
  --role-tab-active-border: rgba(228, 244, 236, 0.72);
  --role-tab-active-text: #0e1713;
  --role-tab-hover-bg: rgba(24, 40, 34, 0.92);
  --role-focus: #99d5ff;
  --role-button-bg: rgba(255, 255, 255, 0.08);
  --role-button-hover: rgba(255, 255, 255, 0.13);
  --role-button-border: rgba(255, 255, 255, 0.18);
  --role-primary-text: #0e1713;
  --surface-1: rgba(255, 255, 255, 0.105);
  --surface-2: rgba(255, 255, 255, 0.035);
  --surface-border: rgba(255, 255, 255, 0.14);
  --surface-shadow: 0 12px 26px rgba(0, 0, 0, 0.25);
  --shadow: 0 24px 60px rgba(0, 0, 0, 0.35);
}

body[data-role="security"] {
  --accent: #7fd7b1;
  --accent-2: #f0d57c;
  --role-accent-soft: rgba(127, 215, 177, 0.14);
  --role-glow-1: rgba(127, 215, 177, 0.18);
  --role-glow-2: rgba(240, 213, 124, 0.13);
  --role-glow-3: rgba(107, 177, 255, 0.09);
  --role-tab-active-bg: rgba(228, 244, 236, 0.92);
  --role-tab-active-border: rgba(228, 244, 236, 0.72);
  --role-tab-active-text: #0e1713;
  --role-tab-hover-bg: rgba(24, 40, 34, 0.92);
  --role-focus: #98dcff;
  --role-button-bg: rgba(255, 255, 255, 0.08);
  --role-button-hover: rgba(255, 255, 255, 0.13);
  --role-button-border: rgba(255, 255, 255, 0.18);
  --role-primary-text: #0e1713;
  --surface-1: rgba(127, 215, 177, 0.12);
  --surface-2: rgba(240, 213, 124, 0.05);
  --surface-border: rgba(172, 233, 203, 0.22);
  --surface-shadow: 0 14px 28px rgba(10, 24, 18, 0.28);
}

body[data-role="frontend"] {
  --accent: #8cc6ff;
  --accent-2: #c4a6ff;
  --role-accent-soft: rgba(140, 198, 255, 0.14);
  --role-glow-1: rgba(140, 198, 255, 0.18);
  --role-glow-2: rgba(196, 166, 255, 0.14);
  --role-glow-3: rgba(255, 158, 198, 0.10);
  --role-tab-active-bg: rgba(232, 240, 255, 0.94);
  --role-tab-active-border: rgba(232, 240, 255, 0.78);
  --role-tab-active-text: #10111b;
  --role-tab-hover-bg: rgba(24, 30, 48, 0.94);
  --role-focus: #b6dbff;
  --role-button-bg: rgba(255, 255, 255, 0.08);
  --role-button-hover: rgba(255, 255, 255, 0.13);
  --role-button-border: rgba(255, 255, 255, 0.18);
  --role-primary-text: #10111b;
  --surface-1: rgba(140, 198, 255, 0.12);
  --surface-2: rgba(196, 166, 255, 0.05);
  --surface-border: rgba(181, 214, 255, 0.22);
  --surface-shadow: 0 14px 28px rgba(18, 24, 39, 0.28);
}

body[data-role="fullstack"] {
  --accent: #96ccff;
  --accent-2: #7fe0bf;
  --role-accent-soft: rgba(150, 204, 255, 0.14);
  --role-glow-1: rgba(150, 204, 255, 0.17);
  --role-glow-2: rgba(127, 224, 191, 0.12);
  --role-glow-3: rgba(151, 117, 255, 0.10);
  --role-tab-active-bg: rgba(232, 239, 250, 0.94);
  --role-tab-active-border: rgba(232, 239, 250, 0.78);
  --role-tab-active-text: #10131a;
  --role-tab-hover-bg: rgba(19, 27, 43, 0.94);
  --role-focus: #b7dbff;
  --role-primary-text: #10131a;
  --surface-1: rgba(150, 204, 255, 0.11);
  --surface-2: rgba(127, 224, 191, 0.05);
  --surface-border: rgba(175, 217, 255, 0.22);
  --surface-shadow: 0 14px 28px rgba(16, 25, 36, 0.28);
}

body[data-role="ai-llm"] {
  --accent: #c89bff;
  --accent-2: #78e6ff;
  --role-accent-soft: rgba(200, 155, 255, 0.14);
  --role-glow-1: rgba(200, 155, 255, 0.18);
  --role-glow-2: rgba(120, 230, 255, 0.13);
  --role-glow-3: rgba(138, 255, 196, 0.09);
  --role-tab-active-bg: rgba(240, 232, 255, 0.94);
  --role-tab-active-border: rgba(240, 232, 255, 0.78);
  --role-tab-active-text: #17131f;
  --role-tab-hover-bg: rgba(32, 24, 52, 0.94);
  --role-focus: #d3baff;
  --role-primary-text: #17131f;
  --surface-1: rgba(200, 155, 255, 0.11);
  --surface-2: rgba(120, 230, 255, 0.05);
  --surface-border: rgba(206, 185, 255, 0.22);
  --surface-shadow: 0 14px 28px rgba(24, 20, 36, 0.28);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; scroll-behavior: smooth; }
body {
  font-family: "SF Pro Text", "SF Pro Display", "Segoe UI", -apple-system, BlinkMacSystemFont, sans-serif;
  color: var(--text);
  background: var(--bg-1);
  line-height: 1.55;
  overflow-x: hidden;
  position: relative;
}

body.is-pdf-open {
  overflow: hidden;
}

.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;
}

body::before {
  content: "";
  position: fixed;
  inset: -20vmax;
  z-index: -2;
  background:
    radial-gradient(42vmax 30vmax at 8% 18%, var(--role-glow-1), transparent 72%),
    radial-gradient(40vmax 28vmax at 85% 10%, var(--role-glow-2), transparent 70%),
    radial-gradient(36vmax 26vmax at 82% 82%, var(--role-glow-3), transparent 72%),
    linear-gradient(135deg, var(--bg-0) 0%, var(--bg-1) 46%, var(--bg-2) 100%);
  animation: drift 18s ease-in-out infinite alternate;
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  opacity: 0.2;
  pointer-events: none;
  background-image:
    repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.03) 0 1px, transparent 1px 4px),
    radial-gradient(circle at 22% 32%, rgba(255, 255, 255, 0.08) 0 1px, transparent 1px 100%),
    radial-gradient(circle at 64% 68%, rgba(255, 255, 255, 0.06) 0 1px, transparent 1px 100%);
  background-size: auto, 130px 130px, 190px 190px;
  animation: grain 10s steps(10) infinite;
}

section[id] {
  scroll-margin-top: 18px;
}

.page-rail {
  position: fixed;
  left: 18px;
  top: 50%;
  z-index: 900;
  display: grid;
  gap: 12px;
  align-items: center;
  transform: translateY(-50%);
  color: rgba(238, 244, 239, .72);
  isolation: isolate;
}

.page-rail::before {
  content: "";
  position: absolute;
  left: -8px;
  right: -128px;
  top: -8px;
  bottom: -8px;
  z-index: -1;
}

.page-rail-label {
  display: none;
}

.page-rail-track {
  position: relative;
  display: grid;
  gap: 9px;
  padding: 8px 0;
  overflow: visible;
}

.page-rail-track::before {
  content: "";
  position: absolute;
  left: 5px;
  top: 14px;
  bottom: 14px;
  width: 1px;
  background: linear-gradient(180deg, transparent, rgba(255,255,255,.2), transparent);
}

.page-rail-link {
  position: relative;
  display: grid;
  grid-template-columns: 12px;
  gap: 0;
  align-items: center;
  justify-items: center;
  min-height: 22px;
  color: rgba(238, 244, 239, .52);
  text-decoration: none;
  outline: none;
  transition: color .18s ease, opacity .18s ease, transform .18s ease;
}

.page-rail-dot {
  position: relative;
  z-index: 1;
  width: 11px;
  height: 11px;
  border: 1px solid rgba(255,255,255,.22);
  border-radius: 999px;
  background: rgba(8, 10, 9, .96);
  box-shadow: 0 0 0 3px rgba(8, 10, 9, .84);
  transition: background .18s ease, border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}

.page-rail-text {
  position: absolute;
  left: 22px;
  top: 50%;
  min-width: max-content;
  padding: 4px 8px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  background: rgba(7, 8, 7, .82);
  color: var(--text);
  box-shadow: 0 14px 30px rgba(0,0,0,.24);
  backdrop-filter: blur(10px);
  font-size: .66rem;
  font-weight: 740;
  line-height: 1;
  text-transform: uppercase;
  opacity: 0;
  clip-path: inset(0 100% 0 0 round 999px);
  transform: translate(-7px, -50%);
  transform-origin: left center;
  transition:
    opacity .18s ease,
    clip-path .34s cubic-bezier(.16, 1, .22, 1),
    transform .34s cubic-bezier(.16, 1, .22, 1);
  transition-delay: 0s;
  pointer-events: auto;
}

.page-rail-link:hover,
.page-rail-link:focus-visible,
.page-rail-link.is-active {
  color: var(--text);
  transform: translateX(1px);
}

.page-rail-link:hover .page-rail-dot,
.page-rail-link:focus-visible .page-rail-dot,
.page-rail-link.is-active .page-rail-dot {
  border-color: color-mix(in srgb, var(--accent) 72%, white 28%);
  background: var(--accent);
  box-shadow: 0 0 0 3px rgba(8, 10, 9, .84), 0 0 22px var(--role-glow-1);
}

.page-rail-link:hover .page-rail-text,
.page-rail-link:focus-visible .page-rail-text,
.page-rail-link.is-active .page-rail-text {
  opacity: 1;
  clip-path: inset(0 0 0 0 round 999px);
  transform: translate(0, -50%);
  transition-delay: 0s;
}

.page-rail:hover .page-rail-link:not(:hover):not(:focus-visible) .page-rail-text {
  opacity: 1;
  clip-path: inset(0 0 0 0 round 999px);
  transform: translate(0, -50%);
  transition-delay: 0s;
}

.page-rail-chat {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  min-height: 34px;
  padding: 8px;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 999px;
  background:
    radial-gradient(circle at 20% 0%, var(--role-glow-1), transparent 60%),
    rgba(255,255,255,.07);
  color: var(--text);
  font-size: .72rem;
  font-weight: 760;
  line-height: 1;
  text-decoration: none;
  box-shadow: 0 18px 42px rgba(0,0,0,.22);
  overflow: hidden;
  white-space: nowrap;
  transition:
    width .28s cubic-bezier(.16, 1, .3, 1),
    transform .18s ease,
    background .18s ease,
    border-color .18s ease;
}

.page-rail-chat span {
  display: inline-block;
  margin-left: 0;
  max-width: 0;
  opacity: 0;
  overflow: hidden;
  transform: translateX(-4px);
  transition:
    max-width .28s cubic-bezier(.16, 1, .3, 1),
    margin-left .28s cubic-bezier(.16, 1, .3, 1),
    opacity .18s ease,
    transform .28s cubic-bezier(.16, 1, .3, 1);
}

.page-rail-chat svg {
  width: 15px;
  height: 15px;
  fill: currentColor;
}

.page-rail-chat:hover,
.page-rail-chat:focus-visible {
  width: 124px;
  border-color: color-mix(in srgb, var(--accent) 44%, white 16%);
  background: rgba(255,255,255,.11);
  transform: translateY(-1px);
}

.page-rail-chat:hover span,
.page-rail-chat:focus-visible span {
  margin-left: .5rem;
  max-width: 82px;
  opacity: 1;
  transform: translateX(0);
}

.wrap { max-width: none; margin: 0; padding: 0 0 56px; }

.hero-stage { height: 100vh; min-height: 720px; position: relative; margin-bottom: 18px; }
.hero-stick { position: sticky; top: 0; height: 100vh; min-height: 720px; display: flex; align-items: stretch; }
.hero-panel {
  width: 100%; height: 100%;
  background: #070807;
  border: 0; border-radius: 0; padding: 24px clamp(18px, 4vw, 58px);
  box-shadow: none; overflow: hidden; position: relative;
}

.hero-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  background: #070807;
}

.hero-vignette {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(7,8,7,.88) 0%, rgba(7,8,7,.58) 34%, rgba(7,8,7,.16) 62%, rgba(7,8,7,.48) 100%),
    linear-gradient(180deg, rgba(7,8,7,.48) 0%, rgba(7,8,7,0) 38%, rgba(7,8,7,.76) 100%);
}

.lock {
  position: relative;
  z-index: 3;
  display: inline-flex; align-items: center; gap: 8px; margin-bottom: 12px;
  padding: 6px 11px; border: 1px solid rgba(243,245,240,.24); border-radius: 999px;
  min-height: 30px;
  background: transparent; border-color: transparent; color: transparent; opacity: 0;
  pointer-events: none;
  font-size: 0.78rem;
  letter-spacing: 0; text-transform: uppercase;
  backdrop-filter: blur(16px);
}

.role-tabs {
  position: relative;
  z-index: 3;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}

body.is-pdf-open .role-tabs {
  z-index: 2105;
}

.role-tab {
  border: 1px solid var(--line);
  background: rgba(7, 8, 7, .42);
  color: #dce4dc;
  border-radius: 999px;
  padding: 8px 12px;
  font-size: .88rem;
  min-height: 38px;
  cursor: pointer;
  transition: background .2s ease, transform .2s ease, border-color .2s ease;
}

.role-tab:hover { transform: translateY(-1px); background: var(--role-tab-hover-bg); }
.role-tab.active { background: var(--role-tab-active-bg); border-color: var(--role-tab-active-border); color: var(--role-tab-active-text); box-shadow: 0 0 0 1px rgba(255,255,255,.18) inset, 0 8px 18px rgba(0,0,0,.28); }
.role-tab:focus-visible { outline: 2px solid var(--role-focus); outline-offset: 2px; }

.hero-grid {
  position: relative;
  z-index: 2;
  display: grid; grid-template-columns: minmax(320px, 560px) 1fr;
  gap: 18px; height: calc(100% - 76px); align-items: center;
  width: 100%;
  max-width: 1520px;
  margin: 0 auto;
}

.hero-copy, #kpis, #signature-grid, [data-bind="rolefit-lead"], #rolefit-list {
  transition: opacity .18s ease, transform .18s ease;
}

.eyebrow { margin: 0; color: var(--accent-2); text-transform: uppercase; letter-spacing: 0; font-size: 0.78rem; }
h1 { margin: 2px 0 0; font-size: clamp(3.6rem, 6.8rem, 7.2rem); font-weight: 760; letter-spacing: 0; line-height: .9; }
.subtitle { margin: 18px 0 0; color: var(--muted); max-width: 680px; font-size: 1.08rem; }
.hero-stack {
  display: flex;
  align-items: center;
  gap: 10px;
  width: min(680px, 100%);
  margin: 12px 0 0;
  color: #cbd7cf;
  font-size: 0.84rem;
  overflow: hidden;
}

.hero-stack-label {
  flex: none;
  color: rgba(240, 213, 124, .88);
  font-size: .68rem;
  font-weight: 820;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.hero-stack-marquee {
  position: relative;
  min-width: 0;
  overflow: hidden;
  flex: 1;
  mask-image: linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent);
}

.hero-stack-track {
  display: flex;
  width: max-content;
  animation: hero-stack-marquee 24s linear infinite;
}

.hero-stack-items {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding-right: 8px;
}

.hero-stack-item {
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 999px;
  padding: 5px 9px;
  background: rgba(255,255,255,.045);
  color: rgba(239, 246, 241, .82);
  font-size: .76rem;
  font-weight: 760;
  line-height: 1;
  white-space: nowrap;
}

.hero-stack:hover .hero-stack-track {
  animation-play-state: paused;
}

@keyframes hero-stack-marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

.hero-sell {
  display: grid;
  gap: 8px;
  margin-top: 14px;
}

.hero-sell[hidden] {
  display: none;
}

.hero-sell-label {
  color: var(--accent-2);
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.hero-sell-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.hero-sell-chip {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  border-radius: 999px;
  padding: 5px 10px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: #edf3ef;
  font-size: .76rem;
  font-weight: 600;
  letter-spacing: .01em;
}

.hero-profile-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

.profile-cta {
  min-height: 40px;
  padding: 9px 13px;
  border-radius: 12px;
  font-size: 0.9rem;
  box-shadow: none;
}

.profile-cta--primary {
  background: var(--accent-2);
  color: var(--role-primary-text);
  border-color: rgba(255,255,255,.08);
}

.chapter-track { margin-top: 20px; min-height: 96px; position: relative; }
.chapter-title {
  margin: 0; position: absolute; inset: 0 auto auto 0;
  font-size: clamp(1.6rem, 3.1rem, 3.4rem); line-height: 1.02; letter-spacing: 0;
  color: var(--accent); opacity: 0; transform: translateY(16px) scale(0.98); filter: blur(4px);
  transition: opacity .25s linear, transform .25s linear, filter .25s linear;
}
.chapter-title.active { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }

.cta { margin-top: 20px; display: flex; flex-wrap: wrap; gap: 10px; }
.btn {
  display: inline-flex; align-items: center; justify-content: center; text-decoration: none;
  border-radius: 12px; padding: 10px 14px; min-height: 44px; font-weight: 650; font-size: 0.95rem;
  letter-spacing: 0; color: #f5f5f7; background: var(--role-button-bg);
  border: 1px solid var(--role-button-border); transition: transform .2s ease, filter .2s ease, background .2s ease;
  backdrop-filter: blur(16px);
}
.btn:hover { transform: translateY(-1px); filter: brightness(1.04); background: var(--role-button-hover); }
.btn:focus-visible { outline: 2px solid var(--role-focus); outline-offset: 2px; }
.btn.primary-cv { color: var(--role-primary-text); background: var(--accent-2); border-color: rgba(255,255,255,.08); box-shadow: 0 14px 28px rgba(0,0,0,.22); }
.btn.disabled { background: rgba(255,255,255,.06); color: #a7adb5; cursor: not-allowed; pointer-events: none; }
.cv-icon-btn {
  display: inline-grid;
  place-items: center;
  width: 48px;
  height: 48px;
  color: #a7adb5;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 14px;
  text-decoration: none;
  backdrop-filter: blur(16px);
  transition: transform .2s ease, filter .2s ease, background .2s ease, color .2s ease;
}
.cv-icon-btn svg {
  display: block;
  width: 22px;
  height: 22px;
  fill: currentColor;
}
.cv-download-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: auto;
  padding-inline: 14px 16px;
}
.cv-download-icon {
  display: inline-grid;
  place-items: center;
  width: 22px;
  height: 22px;
  transform: translateY(1px);
}
.cv-download-svg {
  width: 100%;
  height: 100%;
}
.cv-download-svg--loading {
  display: none;
}
.cv-icon-btn:hover {
  transform: translateY(-1px);
  filter: brightness(1.08);
  background: rgba(255,255,255,.1);
  color: #f5f5f7;
}
.cv-download-btn.is-loading {
  border-color: rgba(255,255,255,.28);
  box-shadow: 0 8px 18px rgba(0,0,0,.16);
  animation: button-pulse 1.2s ease-in-out infinite;
}
.cv-download-btn.is-loading .cv-download-svg--idle {
  display: none;
}
.cv-download-btn.is-loading .cv-download-svg--loading {
  display: block;
}
.cv-download-dot {
  fill: currentColor;
  transform-origin: center;
  animation: dot-bounce 1.1s infinite ease-in-out;
}
.cv-download-dot--2 { animation-delay: .14s; }
.cv-download-dot--3 { animation-delay: .28s; }
.cv-icon-btn:focus-visible { outline: 2px solid var(--role-focus); outline-offset: 2px; }

.cv-visualizer-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: auto;
  padding-inline: 14px 16px;
  color: #f5f5f7;
  cursor: pointer;
}

.cv-visualizer-label {
  font-size: .86rem;
  font-weight: 750;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.pdf-visualizer {
  position: fixed;
  z-index: 2000;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4px;
  background: rgba(4, 5, 6, 0.58);
  backdrop-filter: blur(18px) saturate(1.12);
  pointer-events: none;
  --modal-origin-x: 50%;
  --modal-origin-y: 50%;
  animation: modal-overlay-in 240ms cubic-bezier(.22, 1, .36, 1);
}

.pdf-visualizer[hidden] {
  display: none;
}

.pdf-visualizer-inner {
  width: min(80vw, 1920px);
  height: min(80vh, 1680px);
  max-height: 80vh;
  display: flex;
  flex-direction: column;
  padding: 18px 18px 14px;
  border-radius: 22px;
  overflow: visible;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background:
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.012)),
    rgba(8, 9, 9, .92);
  box-shadow:
    0 46px 110px rgba(0, 0, 0, 0.48),
    0 2px 0 rgba(255,255,255,.06) inset;
  transform-origin: var(--modal-origin-x) var(--modal-origin-y);
  animation: modal-shell-in 360ms cubic-bezier(.16, 1, .3, 1);
  animation-fill-mode: both;
  pointer-events: auto;
}

.pdf-visualizer-toolbar {
  position: absolute;
  top: -0.75rem;
  right: 18px;
  z-index: 11;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  padding: 0;
  border: 0;
  background: transparent;
  color: #eff3f1;
  font-size: 0.92rem;
}

.pdf-visualizer-toolbar strong {
  display: none;
}

.pdf-close {
  display: inline-grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.24);
  background: rgba(255, 255, 255, 0.08);
  color: #f5f5f7;
  cursor: pointer;
  line-height: 1;
  -webkit-appearance: none;
  appearance: none;
  padding: 0;
}

.pdf-close:hover {
  background: rgba(255, 255, 255, 0.14);
}

.pdf-visualizer-frame {
  width: 100%;
  flex: 1;
  border: 0;
  border-radius: 14px;
  background: #fff;
}

.hero-visual {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  border-radius: 22px;
  overflow: visible;
  background: transparent;
  position: relative;
}

.proof-logos { display: none; }

.proof-panel {
  position: relative;
  z-index: 1;
  width: min(60vw, 780px);
  min-height: min(56vh, 560px);
  margin-right: clamp(12px, 2vw, 24px);
  border-radius: 28px;
  padding: clamp(20px, 3vw, 34px);
  background:
    linear-gradient(145deg, rgba(255,255,255,.14), rgba(255,255,255,.045)),
    rgba(14,15,15,.62);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 36px 90px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.18);
  overflow: hidden;
  transform: translate3d(0, 0, 0);
  transition: transform .28s ease, opacity .28s ease, filter .28s ease, box-shadow .28s ease;
  backdrop-filter: blur(26px) saturate(1.15);
}

.proof-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(135deg, rgba(255,255,255,.18), transparent 34%, rgba(255,255,255,.06));
}

.proof-panel-head {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
  margin-bottom: 24px;
}

.proof-panel-head span {
  color: #aeb6bd;
  font-size: .78rem;
  text-transform: uppercase;
}

.proof-panel-head strong {
  color: #f5f5f7;
  font-size: 1.25rem;
  font-weight: 720;
  text-align: right;
}

.proof-brand-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

body[data-role="fullstack"] .proof-brand-grid,
body[data-role="cloud-automation"] .proof-brand-grid {
  gap: 8px;
}

.proof-group-label {
  grid-column: 1 / -1;
  margin-top: 6px;
  color: #aeb6bd;
  font-size: .78rem;
  text-transform: uppercase;
}

.proof-group-label--section {
  margin-top: 18px;
}

.brand-tile {
  min-height: 92px;
  border-radius: 18px;
  border: 1px solid var(--surface-border);
  background:
    linear-gradient(145deg, var(--surface-1), var(--surface-2)),
    var(--panel-strong);
  display: grid;
  place-items: center;
  gap: 8px;
  padding: 14px 10px;
  color: #f5f5f7;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
  transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease;
}

.brand-tile {
  cursor: pointer;
}

.brand-tile:disabled {
  cursor: not-allowed;
  opacity: 0.72;
}

.brand-tile:disabled:hover {
  transform: translateY(0);
  border-color: var(--surface-border);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}

.trust-tile {
  background:
    linear-gradient(145deg, var(--surface-1), var(--surface-2)),
    var(--panel-strong);
  border-color: var(--surface-border);
}

.brand-tile img {
  width: 38px;
  height: 38px;
  object-fit: contain;
}

.brand-mark {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  display: block;
  position: relative;
  background: linear-gradient(145deg, rgba(245,245,247,.92), rgba(180,188,197,.64));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.45), 0 12px 24px rgba(0,0,0,.22);
}

.brand-mark::after {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: #111;
  font-weight: 760;
  font-size: .72rem;
  content: attr(data-mark-text);
}

.brand-mark[data-mark="code4rena"]::after { content: "C4"; }
.brand-mark[data-mark="code4rena"] { background: linear-gradient(145deg, #fbfbfc, #c5cad8); }
.brand-mark[data-mark="sherlock"]::after { content: "SH"; }
.brand-mark[data-mark="sherlock"] { background: linear-gradient(145deg, #f7f6fb, #c7d4ff); }

.brand-mark[data-mark="polychan"] { background: linear-gradient(145deg, #5fc9ff, #f77cb8); }
.brand-mark[data-mark="polychan"]::after { content: "PC"; }
.brand-mark[data-mark="solicitaria"] { background: linear-gradient(145deg, #ffe076, #69d39b); }
.brand-mark[data-mark="solicitaria"]::after { content: "SA"; }
.brand-mark[data-mark="fitora"] { background: linear-gradient(145deg, #f6f0d8, #79b87b); }
.brand-mark[data-mark="fitora"]::after { content: "FI"; }
.brand-mark[data-mark="ethporto-prize"] { background: linear-gradient(145deg, #d6f4ff, #89a7ff); }
.brand-mark[data-mark="ethporto-prize"]::after { content: "3"; }
.brand-mark[data-mark="zk-hack-lisbon"] { background: linear-gradient(145deg, #f2f2f2, #9cd8ff); }
.brand-mark[data-mark="zk-hack-lisbon"]::after { content: "ZK"; }
.brand-mark[data-mark="ethbogota"] { background: linear-gradient(145deg, #ffe58a, #ff8275); }
.brand-mark[data-mark="ethbogota"]::after { content: "BO"; }
.brand-mark[data-mark="wormhole-activate"] { background: linear-gradient(145deg, #ffffff, #7be0c5); }
.brand-mark[data-mark="wormhole-activate"]::after { content: "WH"; }
.brand-mark[data-mark="docker-deploy"]::after { content: "DK"; }
.brand-mark[data-mark="terraform-aws"]::after { content: "TF"; }
.brand-mark[data-mark="vs-code-extension"]::after { content: "VS"; }
.brand-mark[data-mark="ci-cd"]::after { content: "CI"; }
.brand-mark[data-mark="full-audit"]::after { content: "FA"; }
.brand-mark[data-mark="auditor-docker"]::after { content: "AD"; }
.brand-mark[data-mark="recon-docs"]::after { content: "RD"; }
.brand-mark[data-mark="recon-extension"]::after { content: "RX"; }
.brand-mark[data-mark="create-chimera-app"]::after { content: "CA"; }
.brand-mark[data-mark="log-parser"]::after { content: "LP"; }
.brand-mark[data-mark="property-generation"]::after { content: "PG"; }
.brand-mark[data-mark="prompt-injection-defense"]::after { content: "PI"; }
.brand-mark[data-mark="human-in-loop-eval"]::after { content: "EV"; }
.brand-mark[data-mark="github-workflows"]::after { content: "GH"; }
.brand-mark[data-mark="cli-agents"]::after { content: "CL"; }
.brand-mark[data-mark="rce-hardening"]::after { content: "RCE"; font-size: .62rem; }

.brand-tile span {
  font-size: .82rem;
  color: #d9dde2;
  text-align: center;
}

body[data-role="fullstack"] .proof-panel,
body[data-role="cloud-automation"] .proof-panel {
  width: min(60vw, 780px);
  min-height: clamp(660px, 72vh, 760px);
  padding: clamp(20px, 3vw, 34px);
}

body[data-role="fullstack"] .proof-panel-head,
body[data-role="cloud-automation"] .proof-panel-head {
  margin-bottom: 24px;
}

body[data-role="fullstack"] .brand-tile,
body[data-role="cloud-automation"] .brand-tile {
  min-height: 92px;
  border-radius: 18px;
  gap: 8px;
  padding: 14px 10px;
}

body[data-role="fullstack"] .brand-tile img,
body[data-role="cloud-automation"] .brand-tile img,
body[data-role="fullstack"] .brand-mark,
body[data-role="cloud-automation"] .brand-mark {
  width: 38px;
  height: 38px;
  border-radius: 12px;
}

body[data-role="fullstack"] .brand-tile span,
body[data-role="cloud-automation"] .brand-tile span {
  font-size: .82rem;
  line-height: 1.2;
}

body[data-role="fullstack"] .trust-tile,
body[data-role="cloud-automation"] .trust-tile {
  min-height: 92px;
  background:
    linear-gradient(145deg, var(--surface-1), var(--surface-2)),
    var(--panel-strong);
}

body[data-role="fullstack"] .proof-group-label,
body[data-role="cloud-automation"] .proof-group-label {
  margin-top: 6px;
  font-size: .78rem;
  letter-spacing: 0;
}

@media (max-width: 1360px) {
  .hero-grid {
    grid-template-columns: minmax(340px, 440px) minmax(0, 1fr);
    gap: 24px;
  }

  .hero-copy {
    max-width: 440px;
  }

  .proof-panel {
    width: min(58vw, 760px);
    min-height: min(58vh, 560px);
    margin-right: 0;
  }

  body[data-role="fullstack"] .proof-panel,
  body[data-role="cloud-automation"] .proof-panel {
    min-height: clamp(640px, 70vh, 720px);
  }
}

.proof-chip {
  border: 1px solid rgba(255,255,255,.14);
  background: var(--role-accent-soft);
  color: #e7ebee;
  border-radius: 999px;
  padding: 8px 11px;
  font-size: .84rem;
}

.proof-fact-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 12px 0 18px;
}

.proof-fact-strip .proof-chip {
  background: rgba(10, 16, 30, .9);
  border-color: rgba(255,255,255,.12);
  color: #f1f5f9;
}

.proof-skillset-block {
  margin-top: .5rem;
  margin-bottom: 20px;
}

.proof-skillset-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 12px;
}

.proof-panel-foot {
  position: relative;
  z-index: 1;
  margin-top: 20px;
  color: #aeb6bd;
  font-size: .86rem;
}

.proof-panel-foot-label {
  color: rgba(240, 213, 124, .88);
  font-size: .68rem;
  font-weight: 820;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.proof-panel-foot-signals {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 10px;
}

.proof-panel-foot-copy {
  margin: 12px 0 0;
  color: #aeb6bd;
  font-size: .84rem;
  line-height: 1.45;
}

.proof-collaborator-grid {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.collaborator-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 999px;
  padding: 8px 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: linear-gradient(145deg, rgba(21, 31, 61, 0.86), rgba(13, 19, 37, 0.9));
  color: #edf0f4;
  font-size: .84rem;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}

.collaborator-chip::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(145deg, rgba(96, 165, 250, .9), rgba(52, 211, 153, .9));
  box-shadow: 0 0 0 4px rgba(96, 165, 250, .08);
}

.prompt-grid,
.artifact-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.prompt-card,
.artifact-card {
  min-height: 110px;
  border-radius: 14px;
  border: 1px solid var(--surface-border);
  background:
    linear-gradient(145deg, var(--surface-1), var(--surface-2)),
    var(--panel-strong);
  padding: 14px;
  text-align: left;
  position: relative;
  overflow: hidden;
  transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease;
}

.difference-card::before,
.snapshot-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  background: linear-gradient(180deg, var(--accent), var(--accent-2));
  opacity: .82;
}

.prompt-card:hover,
.artifact-card:hover,
.brand-tile:hover {
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.24);
  box-shadow: var(--surface-shadow);
}

.brand-tile:not(:disabled):active {
  transform: translateY(0);
}

.brand-tile:not(:disabled):focus-visible {
  outline: 2px solid var(--role-focus);
  outline-offset: 2px;
}

.prompt-card h4,
.artifact-card h4 {
  margin: 0 0 6px;
  color: var(--accent);
  font-size: 0.98rem;
  line-height: 1.18;
}

.frontend-surface-card {
  display: grid;
  gap: 12px;
}

.frontend-launch-card {
  width: 100%;
  display: grid;
  gap: 12px;
  text-align: left;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  padding: 16px;
  color: inherit;
  background:
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04)),
    radial-gradient(circle at top right, rgba(95, 201, 255, .16), transparent 36%);
  box-shadow: var(--surface-shadow);
  cursor: pointer;
  transition: transform .28s ease, border-color .28s ease, box-shadow .28s ease, background .28s ease, filter .28s ease;
  position: relative;
  overflow: hidden;
}

.frontend-launch-card::after {
  content: "";
  position: absolute;
  inset: auto 14px 14px auto;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  opacity: .9;
  transform: translate3d(0, 0, 0);
  transition: transform .28s ease, opacity .28s ease, background .28s ease;
}

.frontend-launch-card::before {
  content: "Open";
  position: absolute;
  right: 24px;
  bottom: 22px;
  font-size: .72rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--accent-2);
  opacity: 0;
  transform: translateY(4px);
  transition: opacity .28s ease, transform .28s ease;
}

.frontend-launch-card:hover,
.frontend-launch-card:focus-visible {
  transform: translateY(-2px) scale(1.005);
  border-color: rgba(255,255,255,.2);
  box-shadow: 0 22px 44px rgba(0,0,0,.28);
  filter: brightness(1.04);
}

.frontend-launch-card:hover::after,
.frontend-launch-card:focus-visible::after {
  transform: translate3d(2px, -2px, 0) scale(1.04);
  opacity: 1;
}

.frontend-launch-card:hover::before,
.frontend-launch-card:focus-visible::before {
  opacity: 1;
  transform: translateY(0);
}

.frontend-launch-card-top,
.frontend-launch-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.frontend-launch-card-title {
  font-size: 1.02rem;
  font-weight: 760;
  color: var(--text);
}

.frontend-launch-card-state {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--muted);
  font-size: .78rem;
  white-space: nowrap;
}

.frontend-launch-card-state-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--accent);
  box-shadow: 0 0 0 4px rgba(27, 211, 155, .12);
  animation: launch-dot 1.8s ease-in-out infinite;
}

.frontend-launch-card-copy {
  color: var(--muted);
  font-size: .88rem;
  line-height: 1.5;
}

.frontend-launch-card-footer {
  align-items: flex-end;
}

.frontend-launch-card-arrow {
  color: var(--accent-2);
  font-size: 1.2rem;
  font-weight: 800;
  transition: transform .28s ease;
}

.frontend-launch-card:hover .frontend-launch-card-arrow,
.frontend-launch-card:focus-visible .frontend-launch-card-arrow {
  transform: translate3d(3px, -2px, 0);
}

.frontend-metrics-reveal {
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transform: translateY(-8px);
  transition: max-height .48s ease, opacity .32s ease, transform .32s ease;
}

.frontend-metrics-reveal.is-open {
  max-height: 1200px;
  opacity: 1;
  transform: translateY(0);
}

.frontend-metrics-reveal-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  padding-top: 16px;
}

.frontend-metrics-reveal .prompt-card {
  flex: 1 1 100%;
  min-width: 0;
  opacity: 0;
  transform: translateY(12px) scale(.985);
  transition: opacity .34s ease, transform .34s ease, box-shadow .18s ease, border-color .18s ease;
}

.frontend-metrics-reveal.is-open .prompt-card {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.frontend-metrics-reveal.is-open .prompt-card:nth-child(1) { transition-delay: .06s; }
.frontend-metrics-reveal.is-open .prompt-card:nth-child(2) { transition-delay: .12s; }
.frontend-metrics-reveal.is-open .prompt-card:nth-child(3) { transition-delay: .18s; }

@keyframes launch-dot {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(.78); }
}

.frontend-surface {
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  padding: 12px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}

.frontend-surface-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 12px;
}

.frontend-window-dots {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.frontend-window-dots i {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.24);
}

.frontend-window-dots i:nth-child(1) { background: rgba(255, 95, 86, .88); }
.frontend-window-dots i:nth-child(2) { background: rgba(255, 189, 46, .88); }
.frontend-window-dots i:nth-child(3) { background: rgba(39, 201, 98, .88); }

.frontend-surface-badge {
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  padding: 3px 8px;
  background: rgba(255,255,255,.05);
  color: var(--accent-2);
  font-size: .72rem;
  font-weight: 700;
}

.frontend-surface-body {
  display: grid;
  gap: 8px;
}

.frontend-surface-panel {
  height: 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
}

.frontend-surface-panel--hero {
  height: 64px;
  border-radius: 14px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04)),
    linear-gradient(90deg, rgba(95, 201, 255, .32), rgba(245, 126, 88, .22));
}

.frontend-surface-panel--row {
  width: 100%;
  background: rgba(255,255,255,.10);
}

.frontend-surface-panel--row.is-short {
  width: 72%;
}

.frontend-surface-copy h4 {
  margin-bottom: 0;
}

.frontend-surface-chip {
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  padding: 3px 8px;
  background: rgba(255,255,255,.05);
  color: var(--accent-2);
  font-size: .72rem;
  font-weight: 680;
  line-height: 1.2;
}

.prompt-score {
  margin: 0 0 6px;
  display: inline-flex;
  width: fit-content;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  padding: 3px 8px;
  background: var(--role-accent-soft);
  color: var(--accent-2);
  font-weight: 680;
  font-size: .76rem;
}

.prompt-card ul {
  margin: 6px 0 0;
  padding-left: 18px;
  color: var(--muted);
  font-size: 0.79rem;
  line-height: 1.35;
}

.fact-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}

.fact-chip {
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  padding: 3px 8px;
  background: var(--role-accent-soft);
  color: var(--accent-2);
  font-size: .72rem;
  font-weight: 680;
  line-height: 1.2;
}

.snapshot-card .artifact-summary {
  margin-top: 2px;
}

.snapshot-card .fact-row {
  margin-top: 10px;
}

.cv-card ul {
  margin-top: 0;
  padding-left: 16px;
}

.cv-card li {
  margin: 4px 0;
  color: #eef3ef;
  font-size: .88rem;
  line-height: 1.35;
}

.cv-card .fact-row {
  margin-top: 10px;
}

.cv-card--motion {
  position: relative;
}

.method-flow {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.method-step {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border-radius: 999px;
  padding: 6px 10px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  color: #eef3ef;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .02em;
}

.method-arrow {
  color: var(--accent-2);
  font-weight: 800;
  font-size: .95rem;
  line-height: 1;
  animation: arrow-pulse 1.8s ease-in-out infinite;
}

@keyframes arrow-pulse {
  0%, 100% { transform: translateX(0); opacity: .55; }
  50% { transform: translateX(2px); opacity: 1; }
}

.artifact-card button {
  all: unset;
  width: 100%;
  display: grid;
  gap: 6px;
  color: inherit;
  cursor: pointer;
}

.artifact-card strong {
  display: block;
  color: #f5f5f7;
  font-size: 0.92rem;
}

.artifact-impact,
.artifact-summary {
  display: block;
  color: #b4c0bb;
  font-size: 0.78rem;
  line-height: 1.35;
}

.artifact-meta {
  color: #95a49f;
  font-size: 0.74rem;
}

.artifact-section-head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: end;
  margin-bottom: 16px;
}

.artifact-count {
  color: #9fb0bd;
  font-size: .88rem;
  white-space: nowrap;
}

.artifact-tools {
  display: grid;
  grid-template-columns: minmax(220px, 320px) 1fr;
  gap: 18px;
  align-items: start;
  margin-bottom: 1rem;
}

.artifact-search {
  width: 100%;
  min-height: 44px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  background: rgba(255,255,255,.035);
  color: #f3f5f0;
  padding: 0 12px;
  font: inherit;
}

.artifact-search::placeholder {
  color: #7f8b93;
}

.artifact-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.artifact-filter {
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.045);
  color: #9aa6ad;
  padding: 8px 11px;
  font-size: .82rem;
  cursor: pointer;
}

.artifact-filter.active,
.artifact-filter:hover {
  color: #f5f5f7;
  background: var(--role-accent-soft);
}

.artifact-proof-card {
  min-height: 224px;
}

.artifact-action {
  margin-top: 4px;
  color: var(--accent);
  font-size: 0.8rem;
}

.artifact-proof-card button {
  min-height: 196px;
  place-items: center;
  text-align: center;
  align-content: start;
  gap: 9px;
}

.artifact-logo-wrap {
  display: grid;
  place-items: center;
  width: 54px;
  height: 54px;
  margin-bottom: 2px;
  border-radius: 12px;
  background: rgba(255,255,255,.055);
  border: 1px solid rgba(255,255,255,.08);
}

.artifact-logo-wrap img {
  width: 34px;
  height: 34px;
  object-fit: contain;
}

.artifact-tags {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 6px;
  min-height: 26px;
}

.artifact-tags span {
  border-radius: 999px;
  background: rgba(255,255,255,.055);
  color: #a9b2b9;
  padding: 4px 9px;
  font-size: .74rem;
}

.artifact-dots {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 4px 5px;
  min-height: 12px;
  width: min(100%, 132px);
  max-width: 132px;
  margin-inline: auto;
}

.artifact-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  opacity: .92;
}

.artifact-dot--a { background: #ff9fac; }
.artifact-dot--b { background: #ffc099; }
.artifact-dot--c { background: #aeb5ff; }
.artifact-dot--high { background: #ff4d4f; }
.artifact-dot--critical { background: #ff4d4f; }
.artifact-dot--medium { background: #ffb366; }
.artifact-dot--low { background: #9aa8ff; }
.artifact-dot--info { background: #9aa8ff; }

.artifact-dots--info-only .artifact-dot--low { background: #ffcb5b; }
.artifact-dots--info-only .artifact-dot--info { background: #9aa8ff; }

.artifact-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 18px;
  margin-top: 1rem;
}

.artifact-pagination[hidden] {
  display: none;
}

.signal-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.signal-copy-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.signal-copy-row #signal-copy {
  margin: 0;
}

.signal-rail-controls {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin: 0;
  flex: none;
  white-space: nowrap;
}

.signal-scroll-btn {
  min-width: 42px;
  min-height: 42px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid var(--surface-border);
  background: rgba(255,255,255,.04);
  color: var(--text);
  font-size: 1rem;
  line-height: 1;
  font-weight: 700;
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, background .18s ease, opacity .18s ease;
}

.signal-scroll-btn:hover:not(:disabled),
.signal-scroll-btn:focus-visible:not(:disabled) {
  transform: translateY(-1px);
  border-color: rgba(255,255,255,.24);
  background: rgba(255,255,255,.09);
}

.signal-scroll-btn:disabled {
  opacity: .36;
  cursor: not-allowed;
}

@media (min-width: 741px) {
  .signal-grid {
    display: flex;
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 8px;
    padding-right: 8px;
    scroll-snap-type: x proximity;
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    cursor: grab;
  }

  .signal-card {
    flex: 0 0 min(420px, 82vw);
    scroll-snap-align: start;
  }
}

.signal-card {
  display: grid;
  gap: 8px;
  align-content: start;
  min-height: 0;
  padding: 0;
  border-radius: 14px;
  border: 1px solid var(--surface-border);
  background:
    linear-gradient(145deg, var(--surface-1), var(--surface-2)),
    var(--panel-strong);
  color: inherit;
  text-align: left;
  cursor: pointer;
  transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease;
}

.signal-card:hover {
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.24);
  box-shadow: var(--surface-shadow);
}

.signal-card:focus-visible {
  outline: 2px solid var(--role-focus);
  outline-offset: 2px;
}

.signal-card--preview {
  overflow: hidden;
}

.signal-card--title-only .signal-card-media {
  aspect-ratio: 16 / 9;
  min-height: 0;
}

.signal-card--title-only .signal-card-overlay {
  gap: 10px;
  padding: 18px;
}

.signal-card--title-only h3 {
  display: -webkit-box;
  min-height: 2.36em;
  font-size: .95rem;
  line-height: 1.18;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.signal-card--title-only .signal-source {
  background: rgba(255,255,255,.06);
  color: #d6def2;
  border-color: rgba(255,255,255,.10);
}

.signal-card-media {
  position: relative;
  display: block;
  aspect-ratio: 16 / 9;
  min-height: 0;
  overflow: hidden;
  border-bottom: 1px solid rgba(255,255,255,.08);
  border-radius: 14px 14px 0 0;
}

.signal-card-image {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center center;
  filter: saturate(1.04) contrast(1.02);
  transform: scale(1.01);
}

.signal-card-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 8px;
  padding: 16px;
  background: linear-gradient(180deg, rgba(2, 6, 12, 0.08) 0%, rgba(2, 6, 12, 0.88) 100%);
}

.signal-card--preview .signal-source {
  background: rgba(4, 8, 15, .48);
  color: #f7fbff;
  border-color: rgba(255,255,255,.18);
}

.signal-card--preview h3 {
  color: #f7fbff;
  text-shadow: 0 2px 12px rgba(0,0,0,.42);
}

.signal-card--preview .signal-action {
  color: #d7e8ff;
  font-weight: 700;
}

.signal-card--preview p {
  padding: 0 14px 14px;
}

.signal-card h3 {
  margin: 0;
  color: var(--accent);
  font-size: 1rem;
  line-height: 1.2;
}

.signal-card p {
  margin: 0;
  color: var(--muted);
  font-size: .88rem;
  line-height: 1.45;
}

.artifact-summary,
.artifact-impact {
  display: block;
  margin: 6px 0 0;
  color: var(--muted);
  font-size: .84rem;
  line-height: 1.35;
}

.artifact-impact {
  color: rgba(255,255,255,.84);
  font-weight: 620;
}

.signal-source {
  display: inline-flex;
  width: fit-content;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  padding: 3px 8px;
  background: var(--role-accent-soft);
  color: var(--accent-2);
  font-size: .72rem;
  font-weight: 680;
}

.signal-action {
  margin-top: auto;
  color: var(--accent);
  font-size: .8rem;
}

.artifact-page-btn {
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: 999px;
  color: #dce6ee;
  background: rgba(255,255,255,.055);
  cursor: pointer;
}

.artifact-page-btn:disabled {
  opacity: .35;
  cursor: not-allowed;
}

.artifact-page-status {
  color: #aeb8bf;
  font-size: .9rem;
}

.artifact-viewer {
  position: fixed;
  z-index: 99999;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4px;
  background: rgba(4, 5, 6, 0.76);
  backdrop-filter: blur(18px) saturate(1.12);
  isolation: isolate;
  --modal-origin-x: 50%;
  --modal-origin-y: 50%;
  animation: modal-overlay-in 240ms cubic-bezier(.22, 1, .36, 1);
}

.artifact-viewer[hidden] {
  display: none;
}

.artifact-viewer-inner {
  width: min(80vw, 1920px);
  height: min(80vh, 1680px);
  max-height: 80vh;
  display: flex;
  flex-direction: column;
  position: relative;
  border-radius: 22px;
  overflow: visible;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background:
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.012)),
    rgba(8, 9, 9, .92);
  box-shadow:
    0 46px 110px rgba(0, 0, 0, 0.48),
    0 2px 0 rgba(255,255,255,.06) inset;
  transform-origin: var(--modal-origin-x) var(--modal-origin-y);
  animation: modal-shell-in 360ms cubic-bezier(.16, 1, .3, 1);
  animation-fill-mode: both;
}

.artifact-viewer-inner.is-switching .artifact-viewer-frame,
.artifact-viewer-inner.is-switching .artifact-viewer-copy,
.artifact-viewer-inner.is-switching .artifact-viewer-toolbar {
  opacity: .10;
  transform: translateY(2px) scale(.99);
  transition: opacity 320ms cubic-bezier(.16, 1, .3, 1), transform 320ms cubic-bezier(.16, 1, .3, 1);
}

.artifact-viewer-inner .artifact-viewer-frame,
.artifact-viewer-inner .artifact-viewer-copy,
.artifact-viewer-inner .artifact-viewer-toolbar {
  transition: opacity 320ms cubic-bezier(.16, 1, .3, 1), transform 320ms cubic-bezier(.16, 1, .3, 1);
}

.artifact-viewer-inner--web {
  width: min(80vw, 1920px);
  max-height: 80vh;
  height: min(80vh, 1680px);
}

.artifact-viewer-inner--article {
  /* Article modals now use the same shell as other artifact modals. */
}

.artifact-viewer-inner--pdf {
  width: min(80vw, 1920px);
  height: min(80vh, 1680px);
  max-height: 80vh;
  padding: 18px 18px 14px;
  margin-top: 10vh;
  margin-bottom: 10vh;
}

.artifact-viewer-inner--compact {
  width: min(calc(100vw - 6px), 80vw);
  max-height: 80vh;
  height: min(calc(100vh - 6px), 80vh);
}

.pdf-visualizer {
  z-index: 4000;
}

.artifact-viewer-toolbar {
  position: absolute;
  top: -3rem;
  right: 0.8rem;
  z-index: 11;
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  align-items: flex-start;
  padding: 0;
  border: 0;
  background: transparent;
}

.artifact-viewer-copy {
  display: none;
}

.artifact-viewer-copy #artifact-viewer-meta {
  display: none;
}

.artifact-viewer-loading {
  position: absolute;
  inset: 0;
  z-index: 8;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.01)),
    rgba(8, 9, 9, .96);
  border-radius: inherit;
  pointer-events: none;
}

.artifact-viewer-loading[hidden] {
  display: none;
}

.artifact-viewer-loading span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.06);
  color: #d7dbe0;
  font-size: .8rem;
  letter-spacing: .02em;
  padding: 9px 14px;
}

.loading-dots,
.artifact-download-svg--loading {
  width: 28px;
  height: 12px;
}

.loading-dot,
.artifact-download-dot {
  fill: #edf3f8;
  transform-origin: center;
  animation: dot-bounce 1.1s infinite ease-in-out;
}

.loading-dot--2,
.artifact-download-dot--2 { animation-delay: .14s; }
.loading-dot--3,
.artifact-download-dot--3 { animation-delay: .28s; }

.artifact-viewer-inner--compact,
.artifact-viewer-inner--web,
.artifact-viewer-inner--pdf,
.pdf-visualizer-inner {
  will-change: transform, opacity;
}

@keyframes modal-overlay-in {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes modal-shell-in {
  from {
    opacity: 0;
    transform: translate3d(0, 10px, 0) scale(.985);
    filter: blur(10px);
  }
  62% {
    opacity: 1;
    transform: translate3d(0, -1px, 0) scale(1.002);
    filter: blur(0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
    filter: blur(0);
  }
}

@keyframes dot-bounce {
  0%, 80%, 100% { transform: translateY(0); opacity: .5; }
  40% { transform: translateY(-2px); opacity: 1; }
}

@keyframes toast-in {
  from { opacity: 0; transform: translateY(8px) scale(.98); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

.artifact-toolbar-controls {
  display: flex;
  gap: 8px;
  align-items: center;
}

.artifact-btn {
  border: 1px solid rgba(255, 255, 255, 0.24);
  background: rgba(255, 255, 255, 0.08);
  color: #f5f5f7;
  border-radius: 10px;
  padding: 8px 10px;
  min-height: 34px;
  font-size: 0.8rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: transform .18s ease, background .18s ease, border-color .18s ease, box-shadow .18s ease, opacity .18s ease;
}

.artifact-btn[hidden] {
  display: none !important;
}

.artifact-btn:hover,
.artifact-btn:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(255, 255, 255, 0.3);
  background: rgba(255, 255, 255, 0.14);
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.18);
}

.artifact-btn:active,
.btn:active,
.chain-pill:active,
.token:active {
  transform: translateY(0) scale(.985);
}

.artifact-btn--external {
  display: inline-flex;
  align-items: center;
  gap: 0;
  overflow: hidden;
  white-space: nowrap;
  min-width: 36px;
  padding-bottom: 8px;
  transition: gap 0.18s ease, padding 0.18s ease, background 0.18s ease, border-color 0.18s ease;
}

.artifact-btn-icon {
  display: block;
  width: 14px;
  height: 14px;
  flex: 0 0 auto;
}

.artifact-btn-label {
  max-width: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-width 0.18s ease, opacity 0.18s ease;
}

.artifact-btn--external:hover,
.artifact-btn--external:focus-visible,
.artifact-btn--external[data-expanded="true"] {
  gap: 6px;
  padding-inline: 11px;
  position: relative;
  z-index: 1000000;
}

.artifact-btn--external:hover .artifact-btn-label,
.artifact-btn--external:focus-visible .artifact-btn-label,
.artifact-btn--external[data-expanded="true"] .artifact-btn-label {
  max-width: 12rem;
  opacity: 1;
}

.artifact-viewer-nav {
  display: inline-flex;
  gap: 8px;
}

.artifact-btn--nav {
  display: inline-grid;
  place-items: center;
  min-width: 34px;
  padding-inline: 0;
  padding-bottom: 11px;
  font-weight: 800;
}

.artifact-btn--nav:disabled {
  opacity: .35;
  cursor: not-allowed;
}

.artifact-toolbar-controls {
  position: relative;
  z-index: 1000001;
}

.artifact-btn--download {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.artifact-download-icon {
  display: inline-grid;
  place-items: center;
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
}

.artifact-download-svg {
  width: 100%;
  height: 100%;
}

.artifact-download-svg--loading {
  display: none;
}

.artifact-btn.is-loading {
  border-color: rgba(255,255,255,.3);
  background: rgba(255,255,255,.12);
  animation: button-pulse 1.2s ease-in-out infinite;
}

.artifact-btn.is-loading .artifact-download-svg--idle {
  display: none;
}

.artifact-btn.is-loading .artifact-download-svg--loading {
  display: block;
}

.toast-region {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 1200000;
  display: grid;
  gap: 10px;
  pointer-events: none;
}

.toast {
  pointer-events: none;
  min-width: 220px;
  max-width: min(92vw, 360px);
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(12, 17, 24, .94);
  color: #f5f7fa;
  box-shadow: 0 18px 40px rgba(0,0,0,.28);
  animation: toast-in 220ms ease-out;
}

.toast strong {
  display: block;
  font-size: .9rem;
  margin-bottom: 2px;
}

.toast span {
  display: block;
  color: #cfd7e1;
  font-size: .8rem;
  line-height: 1.35;
}

.toast--success { border-color: rgba(27, 211, 155, .2); }
.toast--loading { border-color: rgba(255,255,255,.16); }

.artifact-page-btn {
  transition: transform .18s ease, background .18s ease, box-shadow .18s ease, opacity .18s ease;
}

.artifact-page-btn:hover,
.artifact-page-btn:focus-visible {
  transform: translateY(-1px);
  background: rgba(255,255,255,.09);
  box-shadow: 0 8px 18px rgba(0,0,0,.16);
}

@keyframes button-pulse {
  0%, 100% { box-shadow: 0 0 0 rgba(255,255,255,0); }
  50% { box-shadow: 0 0 0 4px rgba(255,255,255,.04); }
}

.artifact-viewer-frame {
  width: 100%;
  flex: 1;
  min-height: 52vh;
  border: 0;
  border-radius: inherit;
  background: #fff;
}

.artifact-viewer-frame[hidden] {
  display: none;
}

.artifact-description {
  display: none;
}

.artifact-note {
  display: none;
}

.artifact-close {
  display: inline-grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.24);
  background: rgba(255, 255, 255, 0.08);
  color: #f5f5f7;
  cursor: pointer;
  line-height: 1;
  -webkit-appearance: none;
  appearance: none;
  padding: 0;
}

.artifact-close:hover {
  background: rgba(255, 255, 255, 0.14);
}

body.is-artifact-open {
  overflow: hidden;
}

body.is-artifact-open .role-tab {
  visibility: hidden;
  pointer-events: none;
  opacity: 0;
}

.hero-visual.media-swapping .proof-panel {
  opacity: .68;
  transform: scale(.992);
  filter: blur(1.2px);
}

.section {
  max-width: 1160px;
  margin: 0 auto;
  padding: 22px 20px;
  background: transparent;
  border: 0;
  border-radius: 0;
  backdrop-filter: none;
}
.section + .section { margin-top: 18px; }
.section#why-teams-hire-me { margin-top: 10px; }
.section#audit-reports { margin-top: 26px; }
.section h2 { margin: 0 0 10px; font-size: 1.28rem; letter-spacing: 0; }
.section .lead + .grid,
.section .lead + .prompt-grid,
.section .lead + .kpis,
.section .lead + .signal-grid {
  margin-top: 14px;
}

#frontend-metrics-kpis {
  margin-bottom: 2rem;
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

#kpis.kpis--metric-cards {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 9px;
  margin-top: 14px;
}

#kpis.kpis--metric-cards .result-metric-card {
  min-height: 116px;
  padding: 12px;
  border-radius: 18px;
  border-color: rgba(255,255,255,.16);
  background:
    radial-gradient(circle at 86% 12%, var(--role-glow-1), transparent 34%),
    linear-gradient(155deg, rgba(255,255,255,.095), rgba(255,255,255,.025) 52%, rgba(255,255,255,.055)),
    rgba(13, 16, 15, .78);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.07), 0 14px 30px rgba(0,0,0,.13);
}

#kpis.kpis--metric-cards .result-metric-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, var(--accent), var(--accent-2)) 0 0 / 100% 2px no-repeat,
    radial-gradient(circle at 0% 0%, var(--role-glow-2), transparent 42%);
  opacity: .75;
}

#kpis.kpis--metric-cards .frontend-metric-value {
  font-size: clamp(.96rem, 1.25vw, 1.08rem);
  letter-spacing: -0.02em;
}

#kpis.kpis--metric-cards .frontend-metric-label {
  margin-top: auto;
}

#kpis.kpis--metric-cards .frontend-metric-head {
  gap: 8px;
}

#kpis.kpis--metric-cards .frontend-metric-index {
  color: var(--accent);
}

#kpis.kpis--metric-cards .frontend-metric-source {
  padding: 2px 7px;
  border-color: rgba(255,255,255,.14);
  background: rgba(255,255,255,.055);
  font-size: .68rem;
}

#kpis.kpis--metric-cards .frontend-metric-label {
  font-size: .84rem;
}

body[data-role="cloud-automation"] #kpis.kpis--metric-cards {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

body[data-role="cloud-automation"] #kpis.kpis--metric-cards .frontend-metric-source {
  max-width: 100%;
  white-space: normal;
  text-align: right;
  line-height: 1.2;
}

.grid { display: grid; gap: 14px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.card {
  background:
    linear-gradient(145deg, var(--surface-1), var(--surface-2)),
    var(--panel-strong);
  border: 1px solid var(--surface-border);
  border-radius: 14px;
  padding: 16px;
  min-height: 150px;
  position: relative;
  overflow: hidden;
  transition: transform .25s ease, box-shadow .25s ease;
}
.card::after {
  content: "";
  position: absolute;
  inset: auto 14px 0 14px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(245,245,247,.28), transparent);
}
.card-kicker {
  display: inline-flex;
  margin-bottom: 8px;
  color: var(--accent-2);
  font-size: .72rem;
  text-transform: uppercase;
}
.cv-card {
  display: grid;
  align-content: start;
  gap: 6px;
}
.cv-card p,
.capability-card p {
  margin: 0;
  color: #eef3ef;
  font-size: .92rem;
}
.cv-highlight-proof {
  margin: 4px 0 0;
  color: #d6dddb;
  font-size: 0.82rem;
}
.signature-chip {
  flex: 0 1 auto;
  padding: 6px 10px;
  border-color: rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: #d6def2;
  max-width: 100%;
  white-space: normal;
  line-height: 1.2;
}
.signature-chip strong {
  color: var(--text);
  font-weight: 720;
}
.signature-chip em {
  color: var(--muted);
  font-style: normal;
  margin-left: 4px;
}
#signature-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.card:hover { transform: translateY(-2px); box-shadow: var(--surface-shadow); }
.card h3 { margin: 0 0 6px; font-size: 1.02rem; line-height: 1.18; }
ul { margin: 0; padding-left: 18px; }
li { margin: 4px 0; color: var(--muted); }

.kpis {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

body[data-role="security"] #kpis {
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 1px;
  margin-top: 18px;
  padding: 1px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 34px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.24), rgba(255,255,255,.045) 42%, rgba(240, 213, 124, .14)),
    rgba(11, 13, 12, .92);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 36px 90px rgba(0,0,0,.28);
  overflow: hidden;
}

body[data-role="security"] #kpis .kpi {
  position: relative;
  --kpi-accent-rgb: 127, 215, 177;
  --kpi-accent-soft: rgba(var(--kpi-accent-rgb), .12);
  --kpi-accent-line: rgba(var(--kpi-accent-rgb), .32);
  grid-column: span 4;
  min-height: 166px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: clamp(22px, 2.4vw, 34px);
  border: 0;
  border-radius: 0;
  background:
    radial-gradient(circle at 92% 8%, var(--kpi-accent-soft), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.048), rgba(255,255,255,.018)),
    rgba(13, 16, 15, .94);
  box-shadow: none;
  overflow: hidden;
  transition: background .22s ease, transform .22s ease;
}

body[data-role="security"] #kpis .kpi-tag {
  position: relative;
  z-index: 1;
  width: fit-content;
  margin-bottom: auto;
  padding: 5px 8px;
  border: 1px solid var(--kpi-accent-line);
  border-radius: 999px;
  background:
    linear-gradient(135deg, rgba(var(--kpi-accent-rgb), .12), rgba(255,255,255,.035));
  color: rgba(244, 249, 246, .8);
  font-size: .68rem;
  font-weight: 760;
  line-height: 1;
  letter-spacing: 0;
  text-transform: uppercase;
}

body[data-role="security"] #kpis .kpi:nth-child(1) { --kpi-accent-rgb: 127, 215, 177; }
body[data-role="security"] #kpis .kpi:nth-child(2) { --kpi-accent-rgb: 240, 213, 124; }
body[data-role="security"] #kpis .kpi:nth-child(3) { --kpi-accent-rgb: 128, 185, 255; }
body[data-role="security"] #kpis .kpi:nth-child(4) { --kpi-accent-rgb: 210, 183, 255; }
body[data-role="security"] #kpis .kpi:nth-child(5) { --kpi-accent-rgb: 255, 176, 126; }

body[data-role="security"] #kpis .kpi:nth-child(1),
body[data-role="security"] #kpis .kpi:nth-child(2) {
  min-height: 232px;
}

body[data-role="security"] #kpis .kpi:nth-child(1) {
  grid-column: span 7;
  background:
    radial-gradient(circle at 12% 8%, rgba(255,255,255,.12), transparent 34%),
    radial-gradient(circle at 88% 20%, var(--kpi-accent-soft), transparent 36%),
    linear-gradient(145deg, rgba(255,255,255,.07), rgba(255,255,255,.014)),
    rgba(15, 18, 17, .96);
}

body[data-role="security"] #kpis .kpi:nth-child(2) {
  grid-column: span 5;
}

body[data-role="security"] #kpis .kpi::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, var(--kpi-accent-line), transparent 46%) 0 0 / 100% 1px no-repeat,
    linear-gradient(180deg, var(--kpi-accent-line), transparent 52%) 0 0 / 1px 100% no-repeat,
    linear-gradient(135deg, rgba(255,255,255,.08), transparent 32%, rgba(255,255,255,.03));
  opacity: .85;
}

body[data-role="security"] #kpis .kpi .n {
  position: relative;
  z-index: 1;
  color: #f6f9ff;
  font-size: clamp(2.55rem, 4.2vw, 4.75rem);
  font-weight: 820;
  line-height: .92;
  letter-spacing: 0;
  white-space: nowrap;
}

body[data-role="security"] #kpis .kpi:nth-child(1) .n {
  font-size: clamp(3.25rem, 6.3vw, 6.6rem);
}

body[data-role="security"] #kpis .kpi:nth-child(2) .n {
  font-size: clamp(3rem, 5vw, 5.3rem);
}

body[data-role="security"] #kpis .kpi .l {
  position: relative;
  z-index: 1;
  color: rgba(245, 248, 250, .9);
  font-size: clamp(1rem, 1.2vw, 1.1rem);
  font-weight: 720;
  line-height: 1.36;
  max-width: 20ch;
  margin-top: .5rem;
}

body[data-role="security"] #kpis .kpi-note {
  position: relative;
  z-index: 1;
  max-width: 28ch;
  margin-top: .5rem;
  color: rgba(232, 238, 233, .56);
  font-size: .84rem;
  line-height: 1.42;
}

body[data-role="security"] #kpis .kpi:hover {
  background:
    radial-gradient(circle at 92% 8%, rgba(var(--kpi-accent-rgb), .16), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.064), rgba(255,255,255,.022)),
    rgba(16, 19, 18, .98);
}
.kpi { padding: 10px; border-radius: 12px; border: 1px solid var(--line); background: var(--panel-strong); }
.kpi .n { font-size: 1.2rem; font-weight: 700; color: var(--accent); }
.kpi .l { color: var(--muted); font-size: 0.86rem; }

.frontend-metric-card {
  display: grid;
  gap: 10px;
  align-content: start;
  min-height: 150px;
  border-radius: 14px;
  border: 1px solid var(--surface-border);
  background:
    linear-gradient(145deg, var(--surface-1), var(--surface-2)),
    var(--panel-strong);
  padding: 14px;
  position: relative;
  overflow: hidden;
  transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease;
}

.frontend-metric-card::after {
  content: "";
  position: absolute;
  inset: auto 14px 0 14px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(245,245,247,.28), transparent);
}

.frontend-metric-card:hover {
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.24);
  box-shadow: var(--surface-shadow);
}

.frontend-metric-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.frontend-metric-index {
  color: var(--accent-2);
  font-size: .72rem;
  letter-spacing: .08em;
  font-weight: 800;
}

.frontend-metric-source {
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  padding: 3px 8px;
  color: var(--muted);
  font-size: .72rem;
  font-weight: 700;
}

.frontend-metric-value {
  color: var(--text);
  font-size: 1.08rem;
  font-weight: 760;
  line-height: 1.15;
}

.frontend-metric-label {
  color: var(--muted);
  font-size: .9rem;
  line-height: 1.45;
}

.mono { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace; color: #b2c3dc; word-break: break-word; }
.summary { display: grid; gap: 12px; grid-template-columns: 1.2fr .8fr; }
.lead { margin: 0; color: #d9e5f8; font-size: 1.01rem; }
.foot { margin-top: 16px; color: var(--muted); font-size: 0.85rem; }

.section-heading {
  display: grid;
  gap: 10px;
  margin-bottom: 18px;
}

.section-heading--split {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
}

.section-heading h2,
.section#why-teams-hire-me h2,
.artifact-section-head h2,
.section#signals > h2,
.section#services > h2 {
  margin: 0;
  max-width: 780px;
  color: #f7f8f5;
  font-size: clamp(2.05rem, 4.8vw, 4.8rem);
  font-weight: 780;
  line-height: .94;
  letter-spacing: -0.034em;
  word-spacing: .045em;
}

.impact-section .section-heading h2,
.artifact-section-head h2,
.section#signals > h2,
.section#services > h2 {
  margin-bottom: .75rem;
}

.section-eyebrow {
  margin: 0 0 8px;
  color: rgba(240, 213, 124, .9);
  font-size: .78rem;
  font-weight: 760;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.section-lead,
#cv-highlights-copy {
  max-width: 720px;
  color: rgba(232, 238, 233, .72);
  font-size: clamp(1rem, 1.45vw, 1.18rem);
  line-height: 1.55;
}

.section-link-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  padding: 10px 14px;
  border-radius: 999px;
  color: #111412;
  background: rgba(245, 247, 242, .94);
  border: 1px solid rgba(255,255,255,.5);
  text-decoration: none;
  font-size: .9rem;
  font-weight: 760;
  box-shadow: 0 18px 38px rgba(0,0,0,.22);
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.section-link-cta::after {
  content: "";
  width: 7px;
  height: 7px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: rotate(45deg);
}

.section-link-cta:hover,
.section-link-cta:focus-visible {
  transform: translateY(-1px);
  background: #fff;
  box-shadow: 0 22px 44px rgba(0,0,0,.26);
}

.section-link-cta[hidden] {
  display: none;
}

#why-teams-hire-me #cv-highlights-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}

.section#why-teams-hire-me {
  margin-top: clamp(34px, 5vw, 68px);
}

.section#why-teams-hire-me > .lead {
  margin-top: 12px;
}

.section#why-teams-hire-me .cv-card {
  min-height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  padding: clamp(20px, 2.2vw, 28px);
  border-radius: 28px;
  background:
    radial-gradient(circle at 85% 0%, rgba(255,255,255,.07), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.016)),
    rgba(13, 15, 14, .78);
  border-color: rgba(240, 213, 124, .16);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.052);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease;
}

.section#why-teams-hire-me .cv-card--motion::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  padding: 1px;
  border-radius: inherit;
  background:
    linear-gradient(120deg,
      rgba(240, 213, 124, .16),
      rgba(255,255,255,.52),
      rgba(127, 215, 177, .32),
      rgba(240, 213, 124, .2));
  background-size: 240% 240%;
  opacity: .82;
  animation: process-card-border 7s linear infinite;
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
}

.section#why-teams-hire-me .cv-card:hover {
  transform: translateY(-2px);
  border-color: rgba(240, 213, 124, .28);
  background:
    radial-gradient(circle at 85% 0%, rgba(240, 213, 124, .09), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.02)),
    rgba(15, 18, 17, .86);
  box-shadow: 0 26px 54px rgba(0,0,0,.2), inset 0 1px 0 rgba(255,255,255,.055);
}

.section#why-teams-hire-me .cv-card--motion:hover::before {
  opacity: 1;
}

.section#why-teams-hire-me .cv-card .fact-row {
  margin-top: auto;
  padding-top: 24px;
}

.section#why-teams-hire-me .cv-card h3 {
  margin: 0 0 1rem;
  max-width: 13ch;
  font-size: clamp(1.45rem, 2.2vw, 2rem);
  font-weight: 780;
  line-height: 1.02;
  letter-spacing: -0.026em;
  word-spacing: .035em;
}

.section#why-teams-hire-me .cv-card p {
  margin-top: 0;
  color: rgba(230, 237, 232, .72);
  font-size: .98rem;
  line-height: 1.5;
}

.section#why-teams-hire-me .cv-card .method-flow {
  margin-top: 20px;
}

.section#why-teams-hire-me .cv-card .method-step {
  background: rgba(255,255,255,.045);
  border-color: rgba(255,255,255,.1);
  color: rgba(247, 248, 245, .9);
}

#proof-fact-strip {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
  margin: 22px 0 18px;
}

#proof-fact-strip .proof-chip {
  position: relative;
  min-height: 48px;
  padding: 12px 13px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.022)),
    rgba(11, 13, 12, .64);
  border-color: rgba(255,255,255,.085);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
  color: rgba(245, 248, 250, .86);
  font-size: .82rem;
  font-weight: 720;
  text-align: center;
}

#proof-fact-strip .proof-chip::before {
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 999px;
  margin-right: 8px;
  background: #d9ca72;
  box-shadow: 0 0 18px rgba(217, 202, 114, .34);
  flex: 0 0 auto;
}

.proof-skillset-block {
  margin-top: .6rem;
  margin-bottom: 28px;
  padding: clamp(18px, 2vw, 24px);
  border-radius: 30px;
  border: 1px solid rgba(255,255,255,.075);
  background:
    radial-gradient(circle at 100% 0%, rgba(127, 215, 177, .08), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.038), rgba(255,255,255,.012)),
    rgba(9, 11, 10, .66);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.045);
}

.proof-skillset-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-top: 14px;
}

.proof-skillset-grid .collaborator-chip {
  justify-content: center;
  min-height: 48px;
  padding: 11px 12px;
  text-align: center;
  border-radius: 999px;
  background: rgba(255,255,255,.045);
  border-color: rgba(255,255,255,.08);
  color: rgba(239, 246, 242, .88);
  box-shadow: none;
}

.stack-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: clamp(18px, 4vw, 54px);
  margin-top: clamp(30px, 4vw, 48px);
  padding: clamp(24px, 4vw, 46px);
  border-radius: 34px;
  color: #111412;
  background:
    radial-gradient(circle at 12% 0%, rgba(255,255,255,.95), transparent 32%),
    linear-gradient(135deg, rgba(249, 250, 245, .97), rgba(220, 226, 221, .9));
  border: 1px solid rgba(255,255,255,.66);
  box-shadow: 0 30px 80px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.9);
}

.stack-cta[hidden] {
  display: none;
}

.stack-cta-copy {
  max-width: 680px;
}

.stack-cta-copy span {
  display: inline-flex;
  margin-bottom: 10px;
  color: rgba(18, 20, 18, .58);
  font-size: .76rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.stack-cta-copy strong {
  display: block;
  color: #101311;
  font-size: clamp(1.9rem, 4vw, 4rem);
  font-weight: 800;
  line-height: .96;
  letter-spacing: -0.03em;
  word-spacing: .04em;
}

.stack-cta-copy p {
  max-width: 52ch;
  margin: 12px 0 0;
  color: rgba(18, 20, 18, .66);
  font-size: 1rem;
  line-height: 1.55;
}

.stack-cta-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
  flex: 0 0 auto;
}

.stack-cta-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 11px 15px;
  border-radius: 999px;
  border: 1px solid rgba(17, 20, 18, .14);
  color: #111412;
  background: rgba(255,255,255,.42);
  text-decoration: none;
  font-size: .9rem;
  font-weight: 780;
  transition: transform .18s ease, background .18s ease, box-shadow .18s ease;
}

.stack-cta-button--primary {
  color: #f7f8f5;
  background: #111412;
  border-color: #111412;
  box-shadow: 0 14px 30px rgba(0,0,0,.22);
}

.stack-cta-button--contact {
  border-color: color-mix(in srgb, var(--accent) 34%, #111412 12%);
  background:
    radial-gradient(circle at 16% 0%, rgba(127, 215, 177, .18), transparent 56%),
    rgba(255,255,255,.5);
}

.stack-cta-button:hover,
.stack-cta-button:focus-visible {
  transform: translateY(-1px);
  background: rgba(255,255,255,.72);
}

.stack-cta-button--primary:hover,
.stack-cta-button--primary:focus-visible {
  background: #000;
}

.skills-index {
  margin: 1.4rem auto 0;
  max-width: 920px;
  padding: 14px 16px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  background: rgba(255,255,255,.035);
  color: rgba(226, 235, 229, .62);
  text-align: left;
}

.skills-index h3 {
  margin: 0 0 .45rem;
  color: rgba(245, 248, 246, .82);
  font-size: .72rem;
  font-weight: 820;
  letter-spacing: .13em;
  text-transform: uppercase;
}

.skills-index p {
  margin: 0;
  font-size: .76rem;
  line-height: 1.65;
}

.contact-foot {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 2rem;
  text-align: center;
}
.contact-foot a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--text);
  text-decoration: none;
  font-weight: 700;
  cursor: pointer;
  transition: color .18s ease, transform .18s ease, opacity .18s ease;
}
.social-foot-icon {
  width: 14px;
  height: 14px;
  fill: currentColor;
  flex: none;
  opacity: .9;
}
.contact-foot a:hover,
.contact-foot a:focus-visible {
  color: #f5f7fa;
  text-decoration: underline;
  transform: translateY(-1px);
}

#signal-copy {
  margin-bottom: .5rem;
}

.other-lenses {
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,.12);
}

.other-lenses h3 {
  margin: 0 0 10px;
  color: #f5f5f7;
  font-size: .98rem;
}

.lens-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  align-items: stretch;
}

.lens-card {
  appearance: none;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.045);
  border-radius: 12px;
  padding: 12px;
  color: inherit;
  width: 100%;
  text-align: left;
  cursor: pointer;
  transition:
    transform .18s ease,
    background .18s ease,
    border-color .18s ease,
    box-shadow .18s ease,
    opacity .18s ease;
}

.lens-card:hover,
.lens-card:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(255,255,255,.2);
  background: rgba(255,255,255,.07);
}

.lens-card.is-active {
  border-color: color-mix(in srgb, var(--accent) 42%, rgba(255,255,255,.2));
  background:
    radial-gradient(circle at 18% 0%, rgba(127, 215, 177, .14), transparent 56%),
    rgba(255,255,255,.085);
  box-shadow:
    0 18px 40px rgba(0,0,0,.16),
    inset 0 1px 0 rgba(255,255,255,.12);
  transform: translateY(-2px);
  cursor: default;
}

.lens-card.is-active strong {
  color: #fff8df;
}

.lens-card.is-active span {
  color: rgba(240, 245, 241, .82);
}

.lens-card:disabled {
  opacity: 1;
}

.lens-card strong {
  display: block;
  color: #f5f5f7;
  margin-bottom: 4px;
}

.lens-card span {
  color: var(--muted);
  font-size: .88rem;
}

.reveal,
.reveal-up {
  opacity: 0;
  transform: translateY(18px);
  transition:
    opacity .3s cubic-bezier(0.4, 0, 0.2, 1),
    transform .4s cubic-bezier(0, -0.01, 0.19, 0.99);
  transition-delay: var(--reveal-delay, 0ms);
  will-change: opacity, transform;
}

.reveal.in,
.reveal-up.in {
  opacity: 1;
  transform: translateY(0);
}

@keyframes drift {
  0% { transform: translate3d(0, 0, 0) scale(1); }
  100% { transform: translate3d(-2%, 2%, 0) scale(1.07); }
}
@keyframes grain {
  0% { transform: translate(0, 0); }
  20% { transform: translate(-1%, 1%); }
  40% { transform: translate(1%, -1%); }
  60% { transform: translate(0.5%, -0.5%); }
  80% { transform: translate(-0.5%, 0.5%); }
  100% { transform: translate(0, 0); }
}

@keyframes process-card-border {
  0% { background-position: 0% 50%; }
  100% { background-position: 240% 50%; }
}

@media (prefers-reduced-motion: reduce) {
  body::before, body::after { animation: none; }
  .reveal, .card, .btn, .chapter-title, .role-tab { transition: none; }
  .pdf-visualizer, .artifact-viewer,
  .pdf-visualizer-inner, .artifact-viewer-inner { animation: none; }
  .section#why-teams-hire-me .cv-card--motion::before,
  .hero-stack-track { animation: none; }
  .hero-stage { height: auto; }
  .hero-stick { position: static; height: auto; }
  .chapter-title { position: static; opacity: 0; transform: none; filter: none; display: none; }
  .chapter-title.active { display: block; opacity: 1; }
}

@media (max-width: 980px) {
  .hero-stage { height: auto; min-height: 0; margin-bottom: 12px; }
  .hero-stick { position: static; height: auto; min-height: 0; }
  .hero-grid { grid-template-columns: 1fr; height: auto; align-items: start; }
  .hero-visual { height: auto; min-height: 260px; transform: none; justify-content: flex-start; align-items: flex-start; }
  .proof-panel { width: min(92vw, 700px); min-height: 360px; margin-right: 0; }
  .proof-brand-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .kpis { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  #kpis.kpis--metric-cards,
  body[data-role="cloud-automation"] #kpis.kpis--metric-cards {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  body[data-role="fullstack"] .proof-panel,
  body[data-role="cloud-automation"] .proof-panel {
    width: min(92vw, 700px);
  }
  body[data-role="security"] #kpis { grid-template-columns: repeat(6, minmax(0, 1fr)); }
  body[data-role="security"] #kpis .kpi,
  body[data-role="security"] #kpis .kpi:nth-child(1),
  body[data-role="security"] #kpis .kpi:nth-child(2) {
    grid-column: span 3;
    min-height: 0;
  }
  body[data-role="security"] #kpis .kpi:nth-child(5) {
    grid-column: 1 / -1;
  }
  #proof-fact-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .proof-skillset-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .stack-cta {
    align-items: flex-start;
    flex-direction: column;
  }
  .stack-cta-actions {
    justify-content: flex-start;
  }
  #frontend-metrics-kpis { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .summary { grid-template-columns: 1fr; }
  .lens-grid { grid-template-columns: 1fr; }
}

@media (max-width: 1120px) {
  .page-rail {
    left: 10px;
  }

  .page-rail::before {
    right: -8px;
  }

  .page-rail-text {
    display: none;
  }

  .page-rail-link {
    grid-template-columns: 12px;
    gap: 0;
  }

  .hero-stage { height: auto; min-height: 0; margin-bottom: 12px; }
  .hero-stick { position: static; height: auto; min-height: 0; }
  .hero-grid { grid-template-columns: 1fr; height: auto; align-items: start; }
  .hero-visual { height: auto; min-height: 260px; transform: none; justify-content: flex-start; align-items: flex-start; }
  .proof-panel { width: min(92vw, 780px); min-height: auto; margin-right: 0; }
  .artifact-viewer-inner--article {
    width: min(92vw, 980px);
  }
}

@media (min-width: 1680px) {
  .hero-grid {
    max-width: 1400px;
    grid-template-columns: minmax(420px, 560px) minmax(560px, 760px);
    gap: 28px;
  }

  .hero-copy {
    max-width: 620px;
  }

  .subtitle,
  .hero-stack {
    max-width: 620px;
  }

  .hero-visual {
    transform: none;
    justify-content: flex-end;
  }

  .proof-panel {
    width: min(52vw, 760px);
    margin-right: 0;
  }
}

@media (max-width: 740px) {
  section[id] {
    scroll-margin-top: 10px;
  }

  .page-rail {
    left: 12px;
    right: 12px;
    top: auto;
    bottom: 12px;
    grid-template-columns: 1fr auto;
    gap: 10px;
    padding: 8px;
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 999px;
    background: rgba(7, 8, 7, .78);
    box-shadow: 0 20px 44px rgba(0,0,0,.34);
    backdrop-filter: blur(12px);
    transform: none;
  }

  .page-rail::before {
    display: none;
  }

  .page-rail-label {
    display: none;
  }

  .page-rail-track {
    grid-auto-flow: column;
    grid-auto-columns: 1fr;
    gap: 0;
    justify-items: center;
    padding: 0;
  }

  .page-rail-track::before {
    left: 20px;
    right: 20px;
    top: 50%;
    bottom: auto;
    width: auto;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.18), transparent);
  }

  .page-rail-link {
    min-height: 30px;
    justify-items: center;
  }

  .page-rail-dot {
    width: 10px;
    height: 10px;
  }

  .page-rail-chat {
    width: 34px;
    min-height: 34px;
    padding: 8px 10px;
  }

  .page-rail-chat:hover,
  .page-rail-chat:focus-visible {
    width: 34px;
  }

  .page-rail-chat span {
    display: none;
  }

  .grid { grid-template-columns: 1fr; }
  .section-heading--split {
    grid-template-columns: 1fr;
    align-items: start;
  }
  .section-heading h2,
  .section#why-teams-hire-me h2,
  .artifact-section-head h2,
  .section#signals > h2,
  .section#services > h2 {
    font-size: clamp(2.2rem, 11vw, 3.05rem);
    letter-spacing: -0.024em;
    word-spacing: .08em;
  }
  .section-link-cta {
    width: 100%;
    justify-content: center;
  }
  .prompt-grid,
  .artifact-grid,
  .signal-grid { grid-template-columns: 1fr; }
  .signal-grid {
    display: grid;
    overflow: visible;
    padding-bottom: 0;
  }
  .signal-card {
    flex: initial;
  }
  .artifact-section-head { align-items: start; flex-direction: column; gap: 8px; }
  .artifact-tools { grid-template-columns: 1fr; gap: 12px; }
  .artifact-filter { padding: 7px 10px; }
  .kpis { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  #kpis.kpis--metric-cards,
  body[data-role="cloud-automation"] #kpis.kpis--metric-cards {
    grid-template-columns: 1fr;
  }
  #kpis.kpis--metric-cards .result-metric-card {
    min-height: 96px;
    padding: 11px 12px;
  }
  body[data-role="security"] #kpis { grid-template-columns: 1fr; }
  body[data-role="security"] #kpis .kpi,
  body[data-role="security"] #kpis .kpi:nth-child(1),
  body[data-role="security"] #kpis .kpi:nth-child(2) {
    grid-column: auto;
    min-height: 0;
  }
  body[data-role="security"] #kpis .kpi {
    min-height: 136px;
    padding: 22px;
  }
  body[data-role="security"] #kpis .kpi:nth-child(1),
  body[data-role="security"] #kpis .kpi:nth-child(2) {
    min-height: 154px;
  }
  body[data-role="security"] #kpis .kpi .n,
  body[data-role="security"] #kpis .kpi:nth-child(1) .n,
  body[data-role="security"] #kpis .kpi:nth-child(2) .n {
    font-size: clamp(2.55rem, 14vw, 3.75rem);
  }
  #proof-fact-strip { grid-template-columns: 1fr; }
  .proof-skillset-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .stack-cta {
    border-radius: 26px;
  }
  .stack-cta-actions,
  .stack-cta-button {
    width: 100%;
  }
  #frontend-metrics-kpis { grid-template-columns: 1fr; }
  #why-teams-hire-me #cv-highlights-grid { grid-template-columns: 1fr; }
  .hero-panel { padding: 18px; }
  .chapter-track { min-height: 76px; }
  h1 { font-size: 3.4rem; }
  .chapter-title { font-size: 1.65rem; }
  .proof-panel { min-height: auto; }
  .proof-panel-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
    margin-bottom: 16px;
  }
  .proof-panel-head strong {
    text-align: left;
    font-size: 1.14rem;
  }
  .proof-brand-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .brand-tile { min-height: 76px; }
  .pdf-visualizer-inner { width: min(100vw - 4px); height: min(100vh - 4px); }
  .artifact-viewer-inner { width: min(100vw - 4px); height: min(100vh - 4px); max-height: 100vh; }
  .artifact-viewer-inner--web,
  .artifact-viewer-inner--pdf,
  .artifact-viewer-inner--compact { width: min(100vw - 4px); height: min(100vh - 4px); max-height: 100vh; }
  .artifact-viewer-inner--pdf {
    margin-top: 0;
    margin-bottom: 0;
  }
  .pdf-visualizer,
  .artifact-viewer {
    padding: 8px;
    align-items: center;
    justify-content: center;
  }
  .pdf-visualizer-inner,
  .artifact-viewer-inner:not(.artifact-viewer-inner--article) {
    width: min(calc(100vw - 16px), 100%);
    height: min(calc(100dvh - 16px), calc(100vh - 16px));
    max-height: calc(100dvh - 16px);
    border-radius: 16px;
    overflow: hidden;
  }
  .pdf-visualizer-inner {
    padding: 56px 12px 12px;
  }
  .artifact-viewer-inner:not(.artifact-viewer-inner--article) {
    padding: 56px 12px 12px;
  }
  .pdf-visualizer-toolbar,
  .artifact-viewer-inner:not(.artifact-viewer-inner--article) .artifact-viewer-toolbar {
    top: 12px;
    right: 12px;
  }
  .artifact-viewer-inner--article {
    width: min(calc(100vw - 16px), 100%);
    height: min(calc(100dvh - 16px), calc(100vh - 16px));
    max-height: calc(100dvh - 16px);
    overflow: hidden;
  }
  .artifact-viewer-inner--article .artifact-viewer-toolbar {
    padding: 12px 12px 0;
  }
}
