@import url("colors_and_type.css");

* { box-sizing: border-box; }

deck-stage { background: #000; }

/* ---------- Slide base ---------- */
.slide {
  width: 1920px; height: 1080px;
  background: var(--navy);
  color: var(--text-primary);
  font-family: var(--font-sans);
  padding: 120px 140px;
  position: relative;
  overflow: hidden;
  font-feature-settings: "ss01", "ss02";
}
.slide::before {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 50% at 50% 0%, rgba(139, 92, 246, 0.07) 0%, transparent 60%);
  pointer-events: none;
}
.slide > * { position: relative; }

/* ---------- Corners ---------- */
.corner-top, .corner-bottom {
  position: absolute;
  left: 140px; right: 140px;
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 16px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-faint);
}
.corner-top { top: 60px; }
.corner-bottom { bottom: 60px; }
.corner-bottom .right { color: var(--text-dim); }

.brand-mark { display: inline-flex; align-items: center; gap: 12px; }
.brand-mark .dot {
  display: inline-block; width: 14px; height: 14px; border-radius: 50%;
  background: var(--brainz-gradient);
}
.brand-mark .word { color: var(--text-secondary); letter-spacing: 0.05em; font-weight: 600; }

/* ---------- Eyebrow ---------- */
.eyebrow {
  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--brand);
  margin-bottom: 36px;
}
.eyebrow.gradient {
  background: var(--brainz-gradient);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* ---------- Display headings ---------- */
.display {
  font-family: var(--font-serif);
  font-weight: 500;
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--text-primary);
  margin: 0;
}
.display.xl { font-size: 132px; }
.display.lg { font-size: 108px; }
.display.md { font-size: 84px; }
.display.sm { font-size: 64px; }

.gradient {
  background: var(--brainz-gradient);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* ---------- Lede ---------- */
.lede {
  font-size: 32px;
  line-height: 1.5;
  color: var(--text-secondary);
  max-width: 1200px;
  margin: 48px 0 0;
  font-weight: 400;
}
.lede strong { color: var(--text-primary); font-weight: 600; }
.lede em     { color: var(--text-primary); font-style: italic; }

.micro {
  font-family: var(--font-mono);
  font-size: 16px;
  color: var(--text-muted);
  letter-spacing: 0.06em;
}

/* ---------- Two-column ---------- */
.two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
  margin-top: 64px;
}

/* ---------- Comparison cards ---------- */
.card-pair {
  border-top: 2px solid rgba(43, 166, 255, 0.4);
  background: rgba(255, 255, 255, 0.015);
  padding: 36px 40px 40px;
}
.card-pair.purple { border-top-color: rgba(139, 92, 246, 0.4); }
.card-pair .label {
  font-family: var(--font-mono);
  font-size: 14px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 20px;
}
.card-pair.purple .label {
  background: var(--brainz-gradient);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.card-pair ul { margin: 0; padding-left: 0; list-style: none; display: flex; flex-direction: column; gap: 14px; }
.card-pair li { font-size: 22px; line-height: 1.5; color: var(--text-secondary); display: flex; gap: 14px; }
.card-pair li::before { content: "—"; color: var(--text-faint); font-family: var(--font-mono); }
.card-pair.affirmative li { color: var(--text-primary); }
.card-pair.affirmative li::before { color: var(--brand); }

/* ---------- Numbered moves grid ---------- */
.moves {
  margin-top: 64px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  column-gap: 80px;
  row-gap: 28px;
}
.move {
  display: grid;
  grid-template-columns: 80px 1fr;
  column-gap: 24px;
  padding-top: 20px;
  border-top: 1px solid var(--rule);
}
.move .n { font-family: var(--font-mono); font-size: 18px; color: var(--text-muted); letter-spacing: 0.04em; padding-top: 4px; }
.move .name { font-size: 28px; font-weight: 600; color: var(--text-primary); letter-spacing: -0.01em; }
.move .body { font-size: 19px; line-height: 1.5; color: var(--text-secondary); margin-top: 6px; }

/* ---------- Timeline rows ---------- */
.timeline {
  margin-top: 56px;
  display: flex; flex-direction: column;
}
.tl-row {
  display: grid;
  grid-template-columns: 140px 360px 1fr;
  gap: 32px;
  padding: 24px 28px;
  border-top: 1px solid var(--rule);
}
.tl-row.hero {
  border-top: 2px solid rgba(43, 166, 255, 0.55);
  background: rgba(43, 166, 255, 0.06);
}
.tl-row .week { font-family: var(--font-mono); font-size: 17px; color: var(--text-muted); letter-spacing: 0.06em; padding-top: 4px; }
.tl-row.hero .week { color: var(--brand-light); }
.tl-row .name { font-size: 24px; font-weight: 600; color: var(--text-primary); letter-spacing: -0.005em; }
.tl-row .desc { font-size: 19px; line-height: 1.55; color: var(--text-secondary); }
.tl-row .desc strong { color: var(--text-primary); }

/* ---------- Receipts table ---------- */
.tbl {
  margin-top: 56px;
  width: 100%; border-collapse: collapse;
  font-size: 24px;
}
.tbl th {
  text-align: left;
  font-family: var(--font-mono);
  font-size: 14px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 500;
  padding: 16px 0;
  border-bottom: 1px solid var(--rule-strong);
}
.tbl th + th { padding-left: 24px; }
.tbl td { padding: 22px 0; color: var(--text-primary); border-bottom: 1px solid var(--rule); }
.tbl td + td {
  padding-left: 24px;
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 18px;
}

/* ---------- Portfolio grid ---------- */
.port-grid {
  margin-top: 56px;
  display: grid; grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--rule);
}
.port-cell {
  padding: 32px 36px;
  border-bottom: 1px solid var(--rule);
}
.port-cell:nth-child(odd) { border-right: 1px solid var(--rule); }
.port-cell h3 {
  font-family: var(--font-serif);
  font-weight: 500; font-size: 44px; letter-spacing: -0.02em;
  margin: 0 0 10px;
}
.port-cell .ceo { font-family: var(--font-mono); font-size: 16px; color: var(--text-muted); letter-spacing: 0.04em; margin-bottom: 14px; }
.port-cell .pitch { font-size: 22px; line-height: 1.5; color: var(--text-secondary); margin: 0; }
.port-cell .status-row { display: flex; align-items: center; gap: 16px; margin-bottom: 20px; }
.port-cell .pill { display:inline-flex; align-items:center; gap:8px; font-family:var(--font-mono); font-size:14px; font-weight:500; letter-spacing:0.16em; text-transform:uppercase; color:var(--text-secondary); }
.port-cell .pill::before { content:""; width:10px; height:10px; border-radius:999px; }
.port-cell .pill.live::before    { background: var(--brand); }
.port-cell .pill.beta::before    { background: rgba(255,255,255,0.35); }
.port-cell .pill.concept::before { background: rgba(255,255,255,0.18); }

/* ---------- Big CTA ---------- */
.button {
  display: inline-flex; align-items: center; gap: 14px;
  padding: 22px 44px;
  background: var(--brand);
  color: #fff;
  font-family: var(--font-sans);
  font-size: 24px;
  font-weight: 600;
  border-radius: 8px;
  text-decoration: none;
  letter-spacing: 0.005em;
  margin-top: 64px;
}

/* ---------- Centered title slide ---------- */
.center-block {
  position: absolute; top: 50%; left: 140px; right: 140px;
  transform: translateY(-50%);
}
