:root {
  --ink: #17212b;
  --muted: #5c6874;
  --paper: #f7f5ef;
  --panel: #ffffff;
  --line: #d7d2c8;
  --blue: #00629b;
  --teal: #008f80;
  --green: #1f9d63;
  --amber: #d69400;
  --coral: #cf4f4f;
  --charcoal: #20272e;
}

html,
body {
  background: #161616;
}

.reveal {
  background: #161616;
  color: var(--ink);
  font-family: Inter, Avenir, "Helvetica Neue", Arial, sans-serif;
}

.reveal .slides {
  text-align: left;
}

.reveal .slides section.deck-slide {
  background:
    linear-gradient(90deg, rgba(0, 98, 155, 0.06), transparent 26%),
    var(--paper);
  box-sizing: border-box;
  color: var(--ink);
  height: 720px;
  overflow: hidden;
  padding: 44px 58px 42px;
  width: 1280px;
}

.deck-slide * {
  box-sizing: border-box;
}

.deck-slide h1,
.deck-slide h2,
.deck-slide h3,
.deck-slide p {
  margin: 0;
}

.deck-slide h1,
.deck-slide h2 {
  color: var(--ink);
  font-family: Georgia, "Times New Roman", serif;
  font-weight: 500;
  letter-spacing: 0;
}

.deck-slide h1 {
  font-size: 92px;
  line-height: 0.96;
}

.deck-slide h2 {
  font-size: 41px;
  line-height: 1.08;
  max-width: 1070px;
}

.deck-slide h3 {
  color: var(--ink);
  font-size: 22px;
  font-weight: 760;
  letter-spacing: 0;
  line-height: 1.12;
}

.split h2,
.architecture h2,
.cood h2 {
  font-size: 36px;
}

.deck-slide p,
.deck-slide li,
.deck-slide a,
.deck-slide span {
  font-size: 18px;
  letter-spacing: 0;
  line-height: 1.28;
}

.deck-slide header {
  align-items: flex-start;
  border-bottom: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-bottom: 18px;
}

.eyebrow {
  color: var(--blue);
  font-size: 13px !important;
  font-weight: 800;
  letter-spacing: 0.11em !important;
  text-transform: uppercase;
}

.lead {
  color: #34404b;
  font-size: 25px !important;
  line-height: 1.26 !important;
  margin-top: 24px !important;
  max-width: 820px;
}

.deck-slide footer {
  align-items: center;
  border-top: 1px solid var(--line);
  bottom: 26px;
  color: var(--muted);
  column-gap: 16px;
  display: grid;
  font-size: 12px;
  font-weight: 650;
  height: 22px;
  grid-template-columns: 410px minmax(0, 1fr) 64px;
  left: 58px;
  letter-spacing: 0.06em;
  position: absolute;
  right: 58px;
  text-transform: uppercase;
}

.deck-slide footer .footer-position,
.deck-slide footer .footer-page,
.deck-slide footer .footer-note {
  font-size: 10.5px !important;
  line-height: 1.2;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.deck-slide footer .footer-position {
  justify-self: start;
}

.deck-slide footer .footer-note {
  justify-self: center;
  max-width: 100%;
  text-align: center;
}

.deck-slide footer .footer-page {
  justify-self: end;
}

.deck-slide a {
  color: var(--blue);
  text-decoration: none;
}

.deck-slide a:hover,
.deck-slide a:focus-visible {
  text-decoration: underline;
  text-underline-offset: 3px;
}

img,
video {
  max-width: 100%;
}

video {
  background: #111820;
}

.tag {
  border-radius: 999px;
  color: #ffffff;
  display: inline-flex;
  font-size: 12px !important;
  font-weight: 800;
  letter-spacing: 0.06em !important;
  padding: 6px 10px;
  text-transform: uppercase;
}

.tag.green {
  background: var(--green);
}

.tag.blue {
  background: var(--blue);
}

.tag.amber {
  background: var(--amber);
  color: #1a2026;
}

.cover {
  background:
    radial-gradient(circle at 85% 18%, rgba(214, 148, 0, 0.28), transparent 30%),
    linear-gradient(132deg, #13202a 0%, #162c34 58%, #183a36 100%) !important;
  color: #ffffff;
}

.cover-mark {
  background:
    linear-gradient(45deg, #cf4f4f 0 18%, transparent 18% 30%, #1f9d63 30% 44%, transparent 44% 56%, #00629b 56% 72%, transparent 72%),
    linear-gradient(45deg, transparent 0 46%, #d69400 46% 58%, transparent 58%);
  height: 230px;
  opacity: 0.75;
  position: absolute;
  right: 70px;
  top: 56px;
  transform: rotate(-8deg);
  width: 360px;
}

.cover-grid {
  display: grid;
  grid-template-columns: minmax(0, 870px);
  margin-top: 76px;
  position: relative;
  z-index: 2;
}

.cover .eyebrow,
.cover h1,
.cover .lead {
  color: #ffffff;
}

.cover .lead {
  max-width: 860px;
}

.metric-strip {
  bottom: 92px;
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(5, 1fr);
  left: 58px;
  position: absolute;
  right: 58px;
  z-index: 2;
}

.metric-strip div {
  background: rgba(255, 255, 255, 0.94);
  border-top: 5px solid var(--blue);
  color: var(--ink);
  min-height: 104px;
  padding: 15px 14px;
}

.metric-strip strong {
  display: block;
  font-size: 31px;
  line-height: 1;
}

.metric-strip span {
  color: var(--muted);
  display: block;
  font-size: 14px !important;
  font-weight: 700;
  margin-top: 8px;
}

.cover footer {
  border-color: rgba(255, 255, 255, 0.32);
  color: rgba(255, 255, 255, 0.78);
}

.signal-grid {
  display: grid;
  gap: 22px;
  grid-template-columns: repeat(3, 1fr);
  margin-top: 56px;
}

.signal-grid article {
  background: var(--panel);
  border: 1px solid var(--line);
  min-height: 295px;
  padding: 28px;
}

.signal-grid h3 {
  font-size: 28px;
  margin-top: 34px;
}

.signal-grid p {
  color: var(--muted);
  margin-top: 18px;
}

.timeline {
  align-items: stretch;
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  margin-top: 38px;
  position: relative;
}

.timeline::before {
  background: linear-gradient(90deg, var(--blue), var(--teal), var(--amber), var(--coral));
  content: "";
  height: 3px;
  left: 5%;
  opacity: 0.7;
  position: absolute;
  right: 5%;
  top: 23px;
  z-index: 0;
}

.timeline article {
  background: var(--panel);
  border: 1px solid #d8d5cc;
  border-top: 6px solid var(--blue);
  box-shadow: 0 16px 34px rgba(23, 33, 43, 0.08);
  min-height: 332px;
  overflow: hidden;
  padding: 0;
  position: relative;
  z-index: 1;
}

.timeline article.education {
  border-top-color: var(--amber);
}

.timeline article.cern {
  border-top-color: var(--blue);
}

.timeline article.industry {
  border-top-color: var(--teal);
}

.timeline-top {
  align-items: center;
  display: flex;
  justify-content: center;
  padding: 14px 12px 0;
}

.timeline .year {
  background: var(--charcoal);
  color: #ffffff;
  display: inline-flex;
  font-size: 17px !important;
  font-weight: 850;
  justify-content: center;
  min-width: 66px;
  padding: 7px 9px;
}

.logo-tile {
  align-items: center;
  background:
    linear-gradient(135deg, rgba(0, 98, 155, 0.08), transparent 60%),
    #f5f2ea;
  border: 1px solid var(--line);
  display: flex;
  height: 82px;
  justify-content: center;
  margin: 20px 12px 18px;
}

.logo-tile img {
  display: block;
  max-height: 50px;
  max-width: 122px;
  object-fit: contain;
}

.timeline h3 {
  font-size: 19px;
  min-height: 74px;
  padding: 0 12px;
}

.timeline p {
  border-top: 1px solid var(--line);
  color: var(--muted);
  font-size: 14px !important;
  font-weight: 650;
  margin: 0 12px !important;
  padding-top: 12px;
}

.two-column {
  align-items: start;
  display: grid;
  gap: 24px;
  grid-template-columns: 400px 1fr;
  height: 400px;
  margin-top: 24px;
}

.migration-flow {
  background: #ffffff;
  border: 1px solid var(--line);
  border-top: 6px solid var(--blue);
  color: var(--ink);
  display: grid;
  gap: 14px;
  grid-template-rows: auto auto 1fr;
  min-height: 0;
  padding: 22px;
}

.panel-kicker {
  color: var(--blue);
  font-size: 12px !important;
  font-weight: 850;
  letter-spacing: 0.1em !important;
  text-transform: uppercase;
}

.tool-shift {
  align-items: stretch;
  display: grid;
  gap: 10px;
  grid-template-columns: 1fr 42px 1fr;
}

.tool-card {
  align-items: center;
  background: #f5f2ea;
  border: 1px solid var(--line);
  color: var(--ink);
  display: grid;
  gap: 8px;
  grid-template-rows: auto 1fr auto;
  justify-items: center;
  min-height: 0;
  padding: 12px;
}

.tool-card span {
  color: var(--muted);
  font-size: 11px !important;
  font-weight: 850;
  letter-spacing: 0.08em !important;
  text-transform: uppercase;
}

.tool-card img {
  max-height: 44px;
  object-fit: contain;
}

.tool-card strong {
  font-size: 17px;
  line-height: 1.1;
  text-align: center;
}

.tool-card.modern {
  background: #eef5f4;
  border-color: #bfd8d5;
}

.shift-marker {
  align-items: center;
  align-self: center;
  background: var(--amber);
  color: #1a2026;
  display: flex;
  font-size: 16px !important;
  font-weight: 850;
  height: 42px;
  justify-content: center;
  text-align: center;
  text-transform: uppercase;
}

.flow-arrow {
  display: block;
  fill: none;
  height: 22px;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 3.6;
  width: 34px;
}

.outcome-list {
  display: grid;
  gap: 10px;
}

.outcome-list div {
  border-left: 5px solid var(--teal);
  background: #f7faf9;
  padding: 10px 12px;
}

.outcome-list strong {
  display: block;
  font-size: 16px;
  line-height: 1.1;
}

.outcome-list span {
  color: var(--muted);
  display: block;
  font-size: 13px !important;
  font-weight: 690;
  margin-top: 4px;
}

.image-cluster {
  background: #ffffff;
  border: 1px solid var(--line);
  border-top: 6px solid var(--blue);
  display: grid;
  gap: 12px;
  grid-template-areas:
    "unit module"
    "bench bench"
    "adapter instrument";
  grid-template-columns: 1.24fr 1fr;
  grid-template-rows: 122px 126px 85px;
  height: 100%;
  min-height: 0;
  padding: 14px 14px 22px;
}

.image-cluster img {
  background: #ffffff;
  border: 1px solid var(--line);
  display: block;
  height: 100%;
  object-fit: contain;
  padding: 8px;
  width: 100%;
}

.image-cluster .gallery-unit {
  grid-area: unit;
}

.image-cluster .gallery-module {
  grid-area: module;
}

.image-cluster .gallery-bench {
  grid-area: bench;
}

.image-cluster .gallery-adapter {
  grid-area: adapter;
}

.image-cluster .gallery-instrument {
  grid-area: instrument;
}

.arch-grid,
.api-layout,
.leadership-grid,
.commerce-layout,
.cood-grid {
  display: grid;
  gap: 28px;
  margin-top: 24px;
}

.arch-grid {
  align-items: stretch;
  grid-template-columns: 760px 1fr;
}

.fortlogs-layout {
  grid-template-areas:
    "diagram stack"
    "requirements requirements";
  grid-template-rows: 354px 78px;
  gap: 18px;
}

.architecture-figure {
  align-items: center;
  background: #ffffff;
  border: 1px solid var(--line);
  display: flex;
  grid-area: diagram;
  height: 100%;
  justify-content: center;
  margin: 0;
  padding: 18px;
}

.architecture-figure img {
  display: block;
  height: 100%;
  object-fit: contain;
  width: 100%;
}

.fortlogs-stack {
  background:
    linear-gradient(180deg, rgba(0, 98, 155, 0.07), transparent 42%),
    #ffffff;
  border: 1px solid var(--line);
  border-top: 6px solid var(--blue);
  display: grid;
  gap: 10px;
  grid-area: stack;
  grid-template-rows: auto minmax(0, 1fr);
  overflow: hidden;
  padding: 16px 18px 18px;
}

.fortlogs-stack h3 {
  border-bottom: 1px solid var(--line);
  color: var(--blue);
  font-family: Inter, Avenir, "Helvetica Neue", Arial, sans-serif;
  font-size: 13px;
  font-weight: 850;
  letter-spacing: 0.08em;
  line-height: 1.1;
  padding-bottom: 10px;
  text-transform: uppercase;
}

.stack-logo-grid {
  align-content: stretch;
  display: grid;
  gap: 0 20px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: repeat(3, minmax(0, 1fr));
  min-height: 0;
  overflow: hidden;
}

.stack-logo-item {
  align-items: center;
  border-bottom: 1px solid rgba(215, 210, 200, 0.72);
  display: flex;
  justify-content: center;
  min-width: 0;
  padding: 6px 0;
}

.stack-logo-item img {
  display: block;
  max-height: 30px;
  max-width: 100%;
  object-fit: contain;
  width: auto;
}

.stack-logo-item .logo-python {
  max-height: 42px;
}

.websockets-lockup {
  align-items: center;
  display: flex;
  gap: 10px;
  min-width: 0;
}

.websockets-item {
  grid-column: 1 / -1;
  justify-content: center;
}

.websockets-lockup img {
  flex: 0 0 auto;
  height: 32px;
  max-height: none;
  max-width: none;
  width: 38px;
}

.websockets-word {
  color: #2f6f9d;
  display: inline-block;
  font-size: 20px !important;
  font-weight: 760;
  line-height: 1;
  white-space: nowrap;
}

.websockets-word span {
  color: #f1c52d;
  font-size: inherit !important;
}

.fortlogs-tech-list {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: repeat(3, minmax(0, 1fr));
  min-height: 0;
}

.fortlogs-tech-card {
  align-items: center;
  background: #ffffff;
  border: 1px solid var(--line);
  border-top: 5px solid var(--blue);
  display: grid;
  gap: 8px;
  grid-template-columns: 40px minmax(0, 1fr);
  min-height: 0;
  min-width: 0;
  padding: 8px 10px 7px;
}

.fortlogs-tech-card:nth-child(2) {
  border-top-color: var(--teal);
}

.fortlogs-tech-card:nth-child(3) {
  border-top-color: var(--green);
}

.fortlogs-tech-card:nth-child(4) {
  border-top-color: var(--amber);
}

.fortlogs-tech-card:nth-child(5) {
  border-top-color: var(--coral);
  grid-column: 1 / -1;
}

.fortlogs-tech-card img {
  justify-self: center;
  max-height: 30px;
  max-width: 40px;
  object-fit: contain;
}

.fortlogs-tech-card .stack-copy {
  gap: 2px;
}

.fortlogs-tech-card .stack-copy span {
  font-size: 9px !important;
}

.fortlogs-tech-card .stack-copy strong {
  font-size: 15px;
  white-space: normal;
}

.fortlogs-tech-card .stack-copy em {
  font-size: 10px;
  line-height: 1.15;
}

.fortlogs-requirements {
  display: grid;
  gap: 14px;
  grid-area: requirements;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.fortlogs-requirements article {
  background: #ffffff;
  border: 1px solid var(--line);
  border-left: 6px solid var(--teal);
  min-width: 0;
  padding: 13px 16px;
}

.fortlogs-requirements strong {
  color: var(--blue);
  display: block;
  font-size: 22px;
  line-height: 1;
}

.fortlogs-requirements span {
  color: var(--muted);
  display: block;
  font-size: 13px !important;
  font-weight: 720;
  margin-top: 7px;
}

.system-map,
.api-map,
.delivery-map {
  background: var(--panel);
  border: 1px solid var(--line);
  height: 270px;
  width: 100%;
}

.system-map .zone,
.api-map .zone,
.delivery-map .zone {
  fill: #f1eee6;
  stroke: #d4cec2;
}

.system-map .zone-tech {
  fill: #f4efe4;
}

.system-map .zone-gpn {
  fill: #edf5f5;
}

.system-map .box rect,
.api-map .box rect,
.delivery-map .box rect {
  fill: #ffffff;
  stroke: #bfc8cf;
  stroke-width: 2;
}

.system-map .box.primary rect,
.api-map .box.primary rect,
.delivery-map .box.primary rect {
  fill: #e6f2ef;
  stroke: var(--teal);
  stroke-width: 3;
}

.system-map text,
.api-map text,
.delivery-map text {
  fill: var(--ink);
  font-family: Inter, Avenir, Arial, sans-serif;
  font-size: 16px;
  font-weight: 750;
  text-anchor: middle;
}

.api-map .service-title {
  fill: var(--ink);
  font-size: 26px;
  font-weight: 900;
  letter-spacing: 0.5px;
}

.api-map .api-contract .contract-label {
  fill: var(--blue);
  font-size: 10.5px;
  font-weight: 900;
  letter-spacing: 1.8px;
  text-anchor: start;
}

.api-map .api-contract .contract-chip rect {
  fill: #f9fcfb;
  stroke: var(--teal);
  stroke-width: 1.6;
}

.api-map .api-contract .contract-chip text {
  fill: var(--ink);
  font-size: 11.8px;
  font-weight: 850;
  text-anchor: middle;
}

.api-map .api-contract .security-chip rect {
  fill: #eef6f4;
  stroke: #9bbdb8;
  stroke-width: 1.3;
}

.api-map .api-contract .security-chip text {
  fill: var(--muted);
  font-size: 12.2px;
  font-weight: 850;
  text-anchor: middle;
}

.api-map .api-flow path {
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.api-map .api-flow .flow-feed {
  opacity: 0.5;
  stroke: var(--blue);
  stroke-width: 2.2;
}

.api-map .api-flow .flow-rail {
  opacity: 0.82;
  stroke: var(--teal);
  stroke-width: 4;
}

.api-map .api-flow .flow-main {
  marker-end: url(#arrow2);
  stroke: var(--blue);
  stroke-width: 3.8;
}

.system-map .zone-label,
.api-map .zone-label,
.delivery-map .zone-label {
  fill: var(--blue);
  font-size: 13px;
  font-weight: 850;
  letter-spacing: 2px;
  text-anchor: start;
}

.system-map .caption,
.delivery-map .caption {
  fill: var(--muted);
  font-size: 15px;
  text-anchor: start;
}

.system-map line,
.api-map line,
.delivery-map line {
  marker-end: url(#arrow);
  stroke: var(--blue);
  stroke-width: 3;
}

.api-map line {
  marker-end: url(#arrow2);
}

.delivery-map line {
  marker-end: url(#arrow3);
}

.requirements,
.leader-panel,
.commerce-layout aside,
.adoption-panel {
  background: var(--panel);
  border: 1px solid var(--line);
  padding: 26px;
}

.requirements {
  padding: 16px;
}

.requirements h3 {
  font-size: 19px;
}

.requirements ul,
.leader-panel ul {
  list-style: none;
  margin: 18px 0 0;
  padding: 0;
}

.requirements li,
.leader-panel li {
  border-top: 1px solid var(--line);
  color: #34404b;
  font-weight: 690;
  padding: 12px 0;
}

.requirements li {
  font-size: 13.5px !important;
  padding: 4px 0;
}

.logo-row {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  margin-top: 26px;
}

.logo-row img {
  max-height: 44px;
  max-width: 132px;
  object-fit: contain;
}

.delivery-tech-list {
  display: grid;
  gap: 10px;
  grid-column: 1 / -1;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: -8px;
}

.delivery-tech-card {
  align-items: center;
  background: #ffffff;
  border: 1px solid var(--line);
  border-top: 5px solid var(--blue);
  display: grid;
  gap: 10px;
  grid-template-columns: 56px minmax(0, 1fr);
  min-width: 0;
  padding: 12px 14px 11px;
}

.delivery-tech-card:nth-child(2) {
  border-top-color: var(--teal);
}

.delivery-tech-card:nth-child(3) {
  border-top-color: var(--amber);
}

.delivery-tech-card img {
  justify-self: center;
  max-height: 42px;
  max-width: 56px;
  object-fit: contain;
}

.delivery-tech-card .stack-copy {
  gap: 3px;
}

.delivery-tech-card .stack-copy span {
  font-size: 9.5px !important;
}

.delivery-tech-card .stack-copy strong {
  font-size: 18px;
  white-space: normal;
}

.delivery-tech-card .stack-copy em {
  font-size: 11.5px;
  line-height: 1.16;
}

.requirements .logo-row {
  align-items: center;
  display: grid;
  border-bottom: 1px solid var(--line);
  gap: 7px 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 10px;
  padding-bottom: 10px;
}

.requirements ul {
  margin-top: 10px;
}

.requirements .logo-row img {
  justify-self: start;
  max-height: none;
  max-width: 100%;
  object-fit: contain;
  width: 116px;
}

.requirements .logo-row .logo-python {
  width: 84px;
}

.requirements .logo-row .logo-websockets {
  width: 106px;
}

.proof-grid {
  align-items: start;
  display: grid;
  gap: 18px;
  grid-template-columns: 390px minmax(0, 1fr);
  margin-top: 28px;
}

.screenshot-stack {
  align-self: start;
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin: 0;
}

.screenshot-stack img,
.video-card,
.before-after figure,
.commerce-layout figure,
.cood-grid video,
.community figure {
  background: var(--panel);
  border: 1px solid var(--line);
}

.screenshot-stack img {
  aspect-ratio: 1918 / 1051;
  display: block;
  height: auto;
  margin: 0;
  object-fit: contain;
  object-position: center;
  width: 100%;
}

.video-card {
  padding: 14px;
}

.proof .video-card {
  align-self: start;
  padding: 12px;
}

.video-card video,
.before-after video,
.cood-grid video {
  display: block;
  height: 252px;
  object-fit: contain;
  width: 100%;
}

.proof .video-card video {
  height: 286px;
}

.video-card p {
  color: var(--muted);
  font-size: 16px !important;
  font-weight: 800;
  margin-top: 14px;
}

.proof .video-card p {
  margin-top: 10px;
}

.adoption-panel {
  display: grid;
  align-content: start;
  gap: 26px;
}

.adoption-panel img {
  max-height: 64px;
  object-fit: contain;
  object-position: left center;
}

.reuse-strip {
  align-items: center;
  border-top: 1px solid var(--line);
  display: grid;
  gap: 16px;
  grid-template-columns: 180px minmax(0, 1fr);
  margin-top: 14px;
  padding-top: 12px;
}

.reuse-strip span {
  color: var(--blue);
  font-size: 12px !important;
  font-weight: 900;
  letter-spacing: 0.16em !important;
  line-height: 1.15;
  text-transform: uppercase;
}

.reuse-logos {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.reuse-logos img {
  background: #ffffff;
  border: 1px solid var(--line);
  height: 66px;
  object-fit: contain;
  padding: 12px 16px;
  width: 100%;
}

.before-after {
  align-items: start;
  display: grid;
  gap: 18px;
  grid-template-columns: 1fr 74px 1.3fr;
  margin-top: 20px;
}

.before-after figure {
  margin: 0;
  padding: 14px;
}

.before-after figcaption {
  color: var(--blue);
  font-size: 13px;
  font-weight: 850;
  letter-spacing: 0.08em;
  margin-bottom: 10px;
  text-transform: uppercase;
}

.before-after img,
.before-after video {
  height: 270px;
  object-fit: contain;
  width: 100%;
}

.before-after video,
.video-card video {
  pointer-events: none;
}

.direction {
  align-items: center;
  align-self: center;
  background: var(--teal);
  color: #ffffff;
  display: flex;
  font-size: 20px;
  font-weight: 850;
  height: 74px;
  justify-content: center;
  text-transform: uppercase;
}

.direction .flow-arrow {
  height: 30px;
  width: 46px;
}

.stack-strip {
  align-items: stretch;
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  height: 106px;
  margin-top: 10px;
  padding: 0;
}

.stack-card {
  align-items: center;
  background: #ffffff;
  border: 1px solid var(--line);
  border-top: 5px solid var(--blue);
  display: grid;
  gap: 10px;
  grid-template-columns: 50px minmax(0, 1fr);
  min-width: 0;
  padding: 12px 12px 10px;
}

.stack-card:last-child {
  border-right: 1px solid var(--line);
}

.stack-card:nth-child(2) {
  border-top-color: var(--teal);
}

.stack-card:nth-child(3) {
  border-top-color: var(--green);
}

.stack-card:nth-child(4) {
  border-top-color: var(--amber);
}

.stack-card:nth-child(5) {
  border-top-color: var(--coral);
}

.stack-card img {
  justify-self: center;
  max-height: 40px;
  max-width: 50px;
  object-fit: contain;
}

.stack-copy {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.stack-copy span {
  color: var(--blue);
  font-size: 10px !important;
  font-weight: 850;
  letter-spacing: 0.08em !important;
  line-height: 1;
  text-transform: uppercase;
}

.stack-copy strong {
  color: var(--ink);
  display: block;
  font-size: 18px;
  line-height: 1.05;
  min-width: 0;
  white-space: nowrap;
}

.stack-copy em {
  color: var(--muted);
  display: block;
  font-size: 11.5px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.1;
  min-width: 0;
}

.api-layout {
  gap: 14px;
  grid-template-columns: 1fr;
}

.api-map {
  height: 300px;
}

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

.api-tech-card {
  align-items: center;
  background: #ffffff;
  border: 1px solid var(--line);
  border-top: 5px solid var(--blue);
  display: grid;
  gap: 10px;
  grid-template-columns: 50px minmax(0, 1fr);
  min-height: 92px;
  min-width: 0;
  padding: 12px 12px 10px;
}

.api-tech-card:nth-child(2) {
  border-top-color: var(--teal);
}

.api-tech-card:nth-child(3) {
  border-top-color: var(--green);
}

.api-tech-card:nth-child(4) {
  border-top-color: var(--amber);
}

.api-tech-card:nth-child(5) {
  border-top-color: var(--coral);
}

.api-tech-card img {
  justify-self: center;
  max-height: 40px;
  max-width: 50px;
  object-fit: contain;
}

.api-tech-card .stack-copy {
  gap: 2px;
}

.api-tech-card .stack-copy span {
  font-size: 9.5px !important;
}

.api-tech-card .stack-copy strong {
  font-size: 16px;
  white-space: normal;
}

.api-tech-card .stack-copy em {
  font-size: 10.5px;
  line-height: 1.18;
}

.process-flow {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(4, 1fr);
  margin-top: 48px;
}

.process-flow article {
  background: var(--panel);
  border: 1px solid var(--line);
  border-top: 6px solid var(--teal);
  min-height: 152px;
  padding: 24px;
  position: relative;
}

.process-flow article::after {
  background: var(--blue);
  content: "";
  height: 3px;
  position: absolute;
  right: -18px;
  top: 72px;
  width: 18px;
}

.process-flow article:last-child::after {
  display: none;
}

.process-flow span {
  color: var(--amber);
  display: block;
  font-size: 38px !important;
  font-weight: 900;
  line-height: 1;
}

.process-flow strong {
  display: block;
  font-size: 22px;
  line-height: 1.15;
  margin-top: 24px;
}

blockquote {
  background: #ffffff;
  border-left: 7px solid var(--amber);
  color: #2e3740;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 25px;
  line-height: 1.25;
  margin: 46px 0 0;
  padding: 24px 32px;
}

blockquote cite {
  display: block;
  font-family: Inter, Avenir, Arial, sans-serif;
  font-size: 15px;
  font-style: normal;
  font-weight: 760;
  margin-top: 16px;
}

.leadership-grid {
  grid-template-columns: 760px 1fr;
  grid-template-rows: 318px auto;
}

.delivery-figure {
  align-items: center;
  background: #ffffff;
  border: 1px solid var(--line);
  box-sizing: border-box;
  display: flex;
  height: 318px;
  justify-content: center;
  margin: 0;
  padding: 12px;
}

.delivery-figure img {
  display: block;
  height: 100%;
  object-fit: contain;
  width: 100%;
}

.commerce-layout {
  align-items: stretch;
  grid-template-columns: 610px minmax(0, 1fr);
  height: 404px;
}

.commerce-layout figure {
  align-content: start;
  display: grid;
  gap: 12px;
  grid-template-rows: 206px auto auto;
  margin: 0;
  padding: 12px 12px 4px;
}

.commerce-visual > img {
  display: block;
  height: 206px;
  object-fit: contain;
  width: 100%;
}

.commerce-layout aside {
  display: grid;
  gap: 10px;
  align-content: start;
  grid-template-rows: auto auto;
  min-width: 0;
  padding: 18px 18px 8px;
}

.commerce-metrics {
  display: grid;
  gap: 7px;
  grid-template-columns: 1fr;
}

.commerce-metrics article {
  align-items: start;
  background: #f7faf9;
  border-left: 0;
  border-top: 5px solid var(--teal);
  display: grid;
  gap: 16px;
  grid-template-columns: 98px minmax(0, 1fr);
  min-height: 54px;
  min-width: 0;
  padding: 9px 12px 10px;
}

.commerce-metrics article:nth-child(1) {
  border-top-color: var(--amber);
}

.commerce-metrics article:nth-child(3) {
  border-top-color: var(--blue);
}

.commerce-metrics article:nth-child(4) {
  border-top-color: var(--coral);
}

.commerce-metrics .cloudflare-achievement {
  border-top-color: var(--green);
}

.commerce-metrics .cloudflare-achievement span {
  max-width: none;
}

.commerce-metrics strong {
  color: var(--ink);
  display: block;
  font-size: 20px;
  line-height: 1;
  white-space: nowrap;
}

.commerce-metrics span {
  color: var(--muted);
  display: block;
  font-size: 12px !important;
  font-weight: 720;
  line-height: 1.2;
  margin-top: 0;
}

.role-card {
  background:
    linear-gradient(90deg, rgba(214, 148, 0, 0.18), transparent 58%),
    #f8f3e8;
  border: 1px solid #dfd2b8;
  border-left: 6px solid var(--amber);
  padding: 12px 14px;
}

.role-card span,
.commerce-proof-list span {
  color: var(--blue);
  display: block;
  font-size: 10px !important;
  font-weight: 850;
  letter-spacing: 0.08em !important;
  line-height: 1.1;
  text-transform: uppercase;
}

.role-card strong {
  color: var(--ink);
  display: block;
  font-size: 25px;
  line-height: 1;
  margin-top: 6px;
}

.role-card em {
  color: #34404b;
  display: block;
  font-size: 12.5px;
  font-style: normal;
  font-weight: 720;
  line-height: 1.22;
  margin-top: 9px;
}

.commerce-section {
  display: grid;
  gap: 7px;
  min-height: 0;
}

.commerce-section h3 {
  border-bottom: 1px solid var(--line);
  color: var(--blue);
  font-family: Inter, Avenir, "Helvetica Neue", Arial, sans-serif;
  font-size: 11px;
  font-weight: 850;
  letter-spacing: 0.08em;
  line-height: 1.1;
  padding-bottom: 6px;
  text-transform: uppercase;
}

.achievements-section {
  border-top: 1px solid var(--line);
  padding-top: 11px;
}

.commerce-proof-list {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  min-height: 72px;
}

.commerce-proof-list article {
  background: #ffffff;
  border: 1px solid var(--line);
  border-top: 4px solid var(--blue);
  min-width: 0;
  padding: 12px 12px;
}

.commerce-proof-list article:nth-child(2) {
  border-top-color: var(--teal);
}

.commerce-proof-list article:nth-child(3) {
  border-top-color: var(--coral);
}

.commerce-proof-list article:nth-child(4) {
  border-top-color: var(--green);
}

.commerce-proof-list p {
  color: #34404b;
  font-size: 11px !important;
  font-weight: 690;
  line-height: 1.18 !important;
  margin-top: 5px !important;
}

.commerce-tech-list {
  display: grid;
  gap: 7px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-template-rows: repeat(2, 52px);
  margin-top: 16px;
  min-height: 0;
}

.commerce-tech-card {
  background: #ffffff;
  border: 1px solid var(--line);
  border-top: 4px solid var(--blue);
  display: grid;
  gap: 2px;
  grid-template-rows: auto auto 1fr;
  min-width: 0;
  padding: 5px 8px;
}

.commerce-tech-card:nth-child(2) {
  border-top-color: var(--teal);
}

.commerce-tech-card:nth-child(3) {
  border-top-color: var(--green);
}

.commerce-tech-card:nth-child(4) {
  border-top-color: var(--amber);
}

.commerce-tech-card:nth-child(5) {
  border-top-color: var(--coral);
}

.commerce-tech-card:nth-child(6) {
  border-top-color: var(--teal);
}

.commerce-tech-card span {
  color: var(--blue);
  display: block;
  font-size: 7.8px !important;
  font-weight: 850;
  letter-spacing: 0.08em !important;
  line-height: 1.1;
  text-transform: uppercase;
}

.commerce-tech-card strong {
  color: var(--ink);
  display: block;
  font-size: 12px;
  line-height: 1.05;
}

.commerce-tech-card em {
  color: var(--muted);
  display: block;
  font-size: 8.4px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.12;
}

.commerce-layout .logo-row {
  display: grid;
  align-items: center;
  background: #ffffff;
  border: 1px solid var(--line);
  gap: 10px;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  margin-top: 0;
  padding: 6px 12px;
}

.commerce-layout .logo-row img {
  display: block;
  height: auto;
  justify-self: center;
  max-height: 26px;
  max-width: 66px;
  object-fit: contain;
  width: auto;
}

.scribe {
  background:
    linear-gradient(90deg, rgba(0, 143, 128, 0.08), transparent 32%),
    var(--paper) !important;
}

.scribe-showcase {
  align-items: start;
  display: grid;
  gap: 16px 28px;
  grid-template-columns: minmax(0, 740px) 396px;
  margin-top: 24px;
}

.scribe-demo {
  display: block;
  margin: 0;
  width: 100%;
}

.scribe-demo img {
  display: block;
  height: auto;
  width: 100%;
}

.scribe-side {
  display: grid;
  gap: 14px;
  width: 100%;
}

.scribe-sync-line {
  border-left: 5px solid var(--amber);
  color: #24303a;
  font-size: 19px !important;
  font-weight: 780;
  line-height: 1.24 !important;
  padding-left: 15px;
}

.scribe-proof-row {
  display: grid;
  gap: 10px;
  grid-template-columns: 1fr;
  grid-template-rows: repeat(5, minmax(0, auto));
  margin-top: 0;
}

.scribe-proof-row article {
  background: #ffffff;
  border: 1px solid var(--line);
  border-top: 5px solid var(--green);
  min-height: 70px;
  padding: 12px 13px;
}

.scribe-proof-row article:nth-child(2) {
  border-top-color: var(--blue);
}

.scribe-proof-row article:nth-child(3) {
  border-top-color: var(--amber);
}

.scribe-proof-row article:nth-child(4) {
  border-top-color: var(--coral);
}

.scribe-proof-row article:nth-child(5) {
  border-top-color: var(--teal);
}

.scribe-install-line {
  display: block;
  margin-top: 12px;
}

.scribe-proof-row strong {
  color: var(--ink);
  display: block;
  font-size: 17px;
  line-height: 1.08;
}

.scribe-proof-row span {
  color: var(--muted);
  display: block;
  font-size: 12px !important;
  font-weight: 700;
  line-height: 1.2;
  margin-top: 7px;
}

.scribe-install-line code {
  background: #20272e;
  color: #f7f5ef;
  display: inline-block;
  font-family: Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size: 12px;
  font-weight: 760;
  line-height: 1.25;
  max-width: 100%;
  overflow: visible;
  overflow-wrap: normal;
  padding: 12px 14px;
  white-space: nowrap;
  width: fit-content;
}

.scribe-install-line code::before {
  color: #82d187;
  content: "$ ";
}

.cood-grid {
  grid-template-columns: 710px 1fr;
}

.cood-grid video {
  height: 300px;
}

.cood-grid aside {
  display: grid;
  gap: 10px;
}

.cood-grid aside img {
  background: #ffffff;
  border: 1px solid var(--line);
  max-height: 56px;
  object-fit: contain;
  padding: 12px;
  width: 100%;
}

.cood-grid aside .venue {
  max-height: 84px;
  object-fit: cover;
  padding: 0;
}

.talk-list {
  display: grid;
  gap: 10px;
  margin-top: 26px;
}

.talk-list a {
  align-items: center;
  background: var(--panel);
  border: 1px solid var(--line);
  display: grid;
  gap: 12px;
  grid-template-columns: 1fr 210px;
  min-height: 60px;
  padding: 11px 18px;
}

.talk-list strong {
  color: var(--ink);
  font-size: 18px;
  line-height: 1.16;
}

.talk-list span {
  color: var(--blue);
  font-size: 14px !important;
  font-weight: 800;
  text-align: right;
}

.closing-projects {
  display: grid;
  gap: 12px;
  margin-top: 20px;
}

.closing-bento {
  display: grid;
  gap: 10px;
  grid-template-columns: 1.22fr 1.42fr 0.86fr 0.9fr;
  grid-template-rows: repeat(2, 166px);
}

.bento-card {
  background: #ffffff;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: inherit;
  display: grid;
  overflow: hidden;
  text-decoration: none;
}

.bento-pizza,
.bento-rota {
  grid-row: span 2;
}

.bento-pizza { grid-column: 1; grid-row: 1 / span 2; }
.bento-rota { grid-column: 2; grid-row: 1 / span 2; }
.bento-slime { grid-column: 3; grid-row: 1; }
.bento-gba { grid-column: 4; grid-row: 1; }
.bento-fastapi { grid-column: 3 / span 2; grid-row: 2; }

.bento-card::before {
  content: "";
  display: block;
  height: 5px;
}

.bento-pizza::before { background: var(--amber); }
.bento-rota::before { background: var(--teal); }
.bento-slime::before { background: var(--coral); }
.bento-gba::before { background: var(--blue); }
.bento-fastapi::before { background: var(--blue); }

.bento-media {
  align-items: center;
  background: #f7f8f7;
  display: flex;
  justify-content: center;
  margin: 0;
  min-height: 0;
  overflow: hidden;
  padding: 0;
}

.bento-media img,
.bento-media video {
  display: block;
  height: 100%;
  object-fit: contain;
  object-position: center;
  width: 100%;
}

.bento-copy {
  align-content: center;
  background: #ffffff;
  display: grid;
  gap: 5px;
  min-height: 0;
  padding: 10px 12px;
}

.bento-copy span {
  color: var(--blue);
  display: block;
  font-size: 10px !important;
  font-weight: 850;
  letter-spacing: 0.08em !important;
  text-transform: uppercase;
}

.bento-copy strong {
  color: var(--ink);
  display: block;
  font-size: 20px;
  line-height: 1.04;
}

.bento-copy p {
  color: var(--muted);
  font-size: 12px !important;
  font-weight: 720;
  line-height: 1.18 !important;
  margin: 0 !important;
}

.bento-pizza,
.bento-rota {
  grid-template-rows: 5px auto 96px;
}

.bento-slime,
.bento-gba {
  grid-template-rows: 5px 1fr 52px;
}

.bento-fastapi {
  grid-template-columns: 0.88fr 1.12fr;
  grid-template-rows: 5px 1fr;
}

.bento-fastapi .bento-copy {
  border-right: 1px solid var(--line);
  grid-column: 1;
  grid-row: 2;
}

.bento-fastapi .bento-copy strong {
  font-size: 14px;
  line-height: 1.12;
}

.bento-fastapi .bento-media {
  align-items: start;
  background: #ffffff;
  grid-column: 2;
  grid-row: 2;
  padding: 0 10px 10px;
}

.bento-fastapi::before {
  grid-column: 1 / -1;
}

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

.closing-links a {
  background: #eef5f4;
  border: 1px solid #bfd8d5;
  color: var(--ink);
  display: block;
  font-size: 13px;
  font-weight: 800;
  min-height: 58px;
  overflow: hidden;
  padding: 10px 12px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.closing-links span {
  color: var(--blue);
  display: block;
  font-size: 10px !important;
  font-weight: 850;
  letter-spacing: 0.08em !important;
  margin-bottom: 5px;
  text-transform: uppercase;
}

.reveal .progress,
.reveal .controls {
  color: var(--blue);
}
