/* ==========================================================
   SGL Stakeholder Deck — global type, color, layout tokens
   ========================================================== */
:root {
  /* brand */
  --brand: #1F4DCE;
  --brand-2: #173FAA;
  --brand-tint: #EEF3FE;

  /* accent */
  --purple: #7C5CD8;
  --purple-tint: #F1ECFB;
  --green: #10B981;
  --green-tint: #E8F5EE;
  --amber: #F0B656;
  --amber-tint: #FEF7E6;
  --orange: #F08A4B;
  --orange-tint: #FDEDE2;
  --red: #DC4D4D;
  --red-tint: #FCE7E7;
  --teal: #0EA5A5;
  --teal-tint: #DEF4F4;

  /* navy */
  --navy: #0F1F3D;
  --navy-2: #162C53;

  /* ink */
  --ink: #0E1B33;
  --ink-2: #2A3656;
  --ink-3: #67738E;
  --ink-4: #98A2B8;

  /* surfaces */
  --bg: #FFFFFF;
  --bg-soft: #F4F6FA;
  --line: #E5E9F2;
  --line-2: #EEF1F7;

  --shadow-sm: 0 1px 2px rgba(15,31,61,.04), 0 1px 3px rgba(15,31,61,.06);
  --shadow-md: 0 4px 8px rgba(15,31,61,.04), 0 12px 24px rgba(15,31,61,.06);
  --shadow-lg: 0 10px 20px rgba(15,31,61,.06), 0 30px 50px rgba(15,31,61,.10);
}

* { box-sizing: border-box; -webkit-font-smoothing: antialiased; }
html, body { margin:0; padding:0; background:#0E1B33; }
body {
  font-family: 'Plus Jakarta Sans', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  color: var(--ink);
  font-feature-settings: "ss01" on, "ss02" on, "cv11" on;
}

deck-stage section {
  background: #FFFFFF;
  color: var(--ink);
  position: relative;
  overflow: hidden;
}

.slide {
  position: relative;
  width: 100%;
  height: 100%;
  padding: 64px 72px;
  display: flex;
  flex-direction: column;
}

/* ---- typography helpers ---- */
.kicker {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 13px;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: var(--brand);
  text-transform: uppercase;
}
.kicker .bar { width:36px; height:2px; background: var(--brand); display:inline-block; }

.s-title {
  font-size: 64px;
  letter-spacing: -0.02em;
  line-height: 1.05;
  font-weight: 800;
  color: var(--ink);
  margin: 18px 0 14px;
  text-wrap: balance;
}
.s-title.lg { font-size: 96px; }
.s-sub {
  font-size: 22px;
  line-height: 1.4;
  color: var(--ink-3);
  font-weight: 400;
  max-width: 1100px;
  text-wrap: pretty;
  margin: 0;
}

.muted { color: var(--ink-3); }

/* ---- pills ---- */
.pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 99px;
  font-size: 12px;
  font-weight: 600;
  background: var(--bg-soft);
  color: var(--ink-2);
  white-space: nowrap;
}
.pill .dot { width: 6px; height: 6px; border-radius: 99px; display:inline-block; }
.pill.blue   { background: var(--brand-tint); color: var(--brand-2); }
.pill.purple { background: var(--purple-tint); color: #5b3fb1; }
.pill.green  { background: var(--green-tint); color: #067a55; }
.pill.amber  { background: var(--amber-tint); color: #a96a00; }
.pill.gray   { background: var(--bg-soft); color: var(--ink-3); }

/* ---- card ---- */
.card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: var(--shadow-sm);
}
.card.tinted {
  background: var(--brand-tint);
  border-color: #D7E2FB;
  box-shadow: none;
}

/* ---- footer ---- */
.footer {
  margin-top: auto;
  padding-top: 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
  color: var(--ink-4);
  font-weight: 500;
  letter-spacing: 0.04em;
}
.footer .brand-mark { display:inline-flex; align-items:center; gap:8px; }

/* ---- hero (slide 1) ---- */
.hero-bg {
  position:absolute; inset:0;
  background: radial-gradient(1200px 800px at 80% 20%, rgba(31,77,206,0.10), transparent 60%),
              radial-gradient(1000px 700px at 10% 100%, rgba(124,92,216,0.08), transparent 65%),
              linear-gradient(180deg,#FCFDFF 0%, #F6F8FC 100%);
}
.hero-grid {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(15,31,61,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(15,31,61,0.06) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(ellipse 80% 60% at 50% 50%, #000 30%, transparent 75%);
}

/* ---- SGL brand mark ---- */
.sgl-logo { display: inline-flex; align-items: center; gap: 12px; }
.sgl-logo .shield {
  width: 46px; height: 52px;
  background: linear-gradient(160deg, var(--brand), var(--brand-2));
  clip-path: path('M23 0 L46 8 L46 32 C46 44 35 50 23 52 C11 50 0 44 0 32 L0 8 Z');
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-weight: 800; font-size: 14px; letter-spacing: 0.04em;
}
.sgl-logo .word { display:flex; flex-direction:column; line-height:1.1; }
.sgl-logo .word b { font-size: 20px; font-weight: 800; letter-spacing:.02em; }
.sgl-logo .word small { font-size: 9px; letter-spacing: 0.22em; color: var(--ink-3); font-weight: 600; margin-top:2px; }

/* ---- arrows ---- */
.arrow-right {
  width: 0; height: 0;
  border-left: 12px solid var(--brand);
  border-top: 8px solid transparent;
  border-bottom: 8px solid transparent;
}

/* ---- step number badge (slide 5) ---- */
.num-badge {
  width: 28px; height: 28px; border-radius: 99px;
  background: linear-gradient(160deg, #4F7BEC, #1F4DCE);
  color: #fff; font-weight: 800; font-size: 13px;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 10px rgba(31,77,206,.35);
  border: 3px solid #fff;
}

.legend-dot {
  width: 10px; height: 10px; border-radius: 99px; display: inline-block;
}

/* ---- timeline dot ---- */
.tl-dot { width: 14px; height: 14px; border-radius: 99px; border: 3px solid #fff; box-shadow: 0 0 0 1px var(--line); }

/* ---- banner ---- */
.banner {
  background: linear-gradient(90deg, #0F1F3D 0%, #1A3680 100%);
  color: #fff;
  border-radius: 14px;
  padding: 18px 26px;
  display: flex;
  align-items: center;
  gap: 14px;
  font-size: 17px;
  letter-spacing: 0.01em;
}
.banner .star {
  width: 30px; height: 30px; border-radius: 99px;
  background: rgba(255,255,255,.12);
  display: inline-flex; align-items: center; justify-content: center;
  color: #fff; font-size: 14px;
}

/* ---- App-frame mockups (slides 10-13) ---- */
.app-frame {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  box-shadow: 0 30px 60px rgba(15,31,61,.10), 0 6px 16px rgba(15,31,61,.06);
  overflow: hidden;
  display: flex; flex-direction: column;
}
.app-frame .topbar {
  height: 36px;
  background: #F4F6FA;
  border-bottom: 1px solid var(--line);
  display: flex; align-items: center;
  padding: 0 14px;
  gap: 14px;
  flex-shrink: 0;
}
.app-frame .topbar .dots { display:flex; gap:6px; }
.app-frame .topbar .dots i {
  display:block; width:10px; height:10px; border-radius:99px;
  background: #DDE2EC;
}
.app-frame .topbar .dots i:nth-child(1) { background:#FF6058; }
.app-frame .topbar .dots i:nth-child(2) { background:#FFBD2D; }
.app-frame .topbar .dots i:nth-child(3) { background:#28C940; }
.app-frame .topbar .url {
  flex: 1;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 4px 10px;
  font-size: 11px;
  color: var(--ink-3);
  font-weight: 500;
  text-align: center;
  max-width: 460px;
  margin: 0 auto;
  font-family: 'JetBrains Mono', monospace;
}

.dense .s-title { font-size: 48px; }
.dense .s-sub { font-size: 18px; }

/* ---- print sizing already handled by deck-stage component ---- */
