deck-stage:not(:defined){ visibility:hidden; }

:root{
  --lp-navy:#001941;
  --lp-navy-light:#00235A;
  --lp-blue:#0033A0;
  --lp-blue-soft:#E8EEFB;
  --lp-yellow:#FDEA00;
  --lp-yellow-dark:#CFB700;
  --lp-green:#3D9E52;
  --lp-red:#D2222D;
  --lp-white:#FFFFFF;
  --lp-off:#F5F7FA;
  --lp-off-2:#F0F4FD;
  --lp-line:#D7DCE0;
  --lp-line-light:#E5E7EB;
  --lp-muted:#6B7280;
  --lp-text:#1F2937;
  --lp-ink:#111827;
  --f-display:'Barlow',sans-serif;
  --f-body:'Inter',sans-serif;
  --t-display:104px;
  --t-title:66px;
  --t-h2:48px;
  --t-sub:34px;
  --t-lead:28px;
  --t-body:24px;
  --t-small:20px;
  --t-eyebrow:18px;
  --t-meta:16px;
  --pad-x:100px;
  --pad-top:80px;
  --pad-bottom:72px;
}

*{ box-sizing:border-box; }

body{
  margin:0;
  background:#0c0c0c;
}

.slide{
  position:relative;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  padding:var(--pad-top) var(--pad-x) var(--pad-bottom);
  background:var(--lp-white);
  color:var(--lp-text);
  font-family:var(--f-body);
  font-size:var(--t-body);
  line-height:1.4;
}

.slide.lp-navy{ background:var(--lp-navy); color:var(--lp-white); }
.slide.lp-navy-light{ background:var(--lp-navy-light); color:var(--lp-white); }
.slide.lp-off{ background:var(--lp-off); }
.slide.center{ justify-content:center; }

.bleed{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}

.scrim{
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(0,25,65,.94) 0%,rgba(0,25,65,.72) 42%,rgba(0,25,65,.18) 74%,rgba(0,25,65,0) 100%);
}

.scrim.full{ background:rgba(0,25,65,.68); }
.scrim.bottom{ background:linear-gradient(0deg,rgba(0,25,65,.9) 0%,rgba(0,25,65,.42) 42%,rgba(0,25,65,0) 74%); }
.over{ position:relative; z-index:2; }

.eyebrow{
  margin:0;
  font-family:var(--f-display);
  font-size:var(--t-eyebrow);
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--lp-muted);
}

.slide.lp-navy .eyebrow,
.slide.lp-navy-light .eyebrow{ color:rgba(255,255,255,.7); }

.eyebrow.acc{ color:var(--lp-yellow-dark); }
.slide.lp-navy .eyebrow.acc,
.slide.lp-navy-light .eyebrow.acc{ color:var(--lp-yellow); }

.title{
  margin:0;
  max-width:1320px;
  font-family:var(--f-display);
  font-size:var(--t-title);
  font-weight:800;
  line-height:1.04;
  letter-spacing:0;
}

.display{
  margin:0;
  font-family:var(--f-display);
  font-size:var(--t-display);
  font-weight:900;
  line-height:.96;
  letter-spacing:0;
}

.h2{
  margin:0;
  font-family:var(--f-display);
  font-size:var(--t-h2);
  font-weight:800;
  line-height:1.08;
  letter-spacing:0;
}

.sub{
  margin:0;
  font-family:var(--f-display);
  font-size:var(--t-sub);
  font-weight:700;
  line-height:1.12;
}

.lead{
  margin:0;
  font-size:var(--t-lead);
  line-height:1.42;
  color:var(--lp-muted);
}

.slide.lp-navy .lead,
.slide.lp-navy-light .lead{ color:rgba(255,255,255,.85); }

.lead b,
.lead strong{ color:var(--lp-ink); font-weight:700; }
.slide.lp-navy .lead b,
.slide.lp-navy-light .lead b{ color:#fff; }

.small{ font-size:var(--t-small); line-height:1.45; }
.muted{ color:var(--lp-muted); }
.yel{ color:var(--lp-yellow); }
.navy{ color:var(--lp-navy); }

.head{
  position:relative;
  z-index:2;
  display:flex;
  flex-direction:column;
  gap:14px;
}

.rule{
  width:56px;
  height:5px;
  margin:0;
  border:0;
  border-radius:3px;
  background:var(--lp-yellow);
}

.idx{
  position:absolute;
  top:48px;
  right:var(--pad-x);
  z-index:4;
  font-family:var(--f-display);
  font-size:var(--t-small);
  font-weight:700;
  letter-spacing:.12em;
  color:var(--lp-muted);
}

.slide.lp-navy .idx,
.slide.lp-navy-light .idx{ color:rgba(255,255,255,.5); }
.idx-chap{ color:var(--lp-yellow-dark); }
.slide.lp-navy .idx-chap,
.slide.lp-navy-light .idx-chap{ color:var(--lp-yellow); }
.idx-sep{ opacity:.35; margin:0 14px; }

.kicker-tag{
  position:absolute;
  top:46px;
  left:var(--pad-x);
  z-index:5;
  display:flex;
  align-items:center;
  gap:10px;
  font-family:var(--f-body);
  font-size:var(--t-meta);
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--lp-muted);
}

.slide.lp-navy .kicker-tag,
.slide.lp-navy-light .kicker-tag{ color:rgba(255,255,255,.7); }

.kicker-tag .dot{
  width:10px;
  height:10px;
  flex:0 0 auto;
  border-radius:50%;
  background:var(--lp-yellow);
}

.row{ display:flex; }
.col{ display:flex; flex-direction:column; }
.grow{ flex:1; }
.between{ justify-content:space-between; }
.aic{ align-items:center; }
.aifs{ align-items:flex-start; }
.centered{ align-items:center; justify-content:center; text-align:center; }
.gap-xs{ gap:10px; }
.gap-s{ gap:16px; }
.gap-m{ gap:24px; }
.gap-l{ gap:36px; }
.gap-xl{ gap:48px; }

.g2{ display:grid; grid-template-columns:1fr 1fr; }
.g3{ display:grid; grid-template-columns:repeat(3,1fr); }
.g4{ display:grid; grid-template-columns:repeat(4,1fr); }
.g5{ display:grid; grid-template-columns:repeat(5,1fr); }

.card{
  display:flex;
  flex-direction:column;
  gap:14px;
  padding:28px;
  border:1px solid var(--lp-line-light);
  border-radius:8px;
  background:var(--lp-white);
  box-shadow:0 1px 2px rgba(0,0,0,.04), 0 16px 34px -28px rgba(0,25,65,.55);
}

.card.navy{
  border-color:rgba(255,255,255,.13);
  background:rgba(255,255,255,.08);
  box-shadow:none;
}

.card.yellow{
  border-color:rgba(0,0,0,.08);
  background:var(--lp-yellow);
}

.card .c-t{
  margin:0;
  font-family:var(--f-display);
  font-size:28px;
  font-weight:800;
  line-height:1.08;
  color:var(--lp-navy);
}

.card.navy .c-t{ color:#fff; }
.card .c-b{
  margin:0;
  font-size:var(--t-small);
  line-height:1.44;
  color:var(--lp-muted);
}
.card.navy .c-b{ color:rgba(255,255,255,.76); }
.card.yellow .c-b{ color:#5A4600; }

.chip{
  width:56px;
  height:56px;
  flex:0 0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  background:var(--lp-yellow);
  color:var(--lp-ink);
}

.chip.ghost{ background:rgba(0,25,65,.06); color:var(--lp-navy); }
.chip.navy{ background:var(--lp-navy); color:var(--lp-yellow); }
.chip.white{ background:#fff; color:var(--lp-navy); }
.ic{ width:30px; height:30px; display:block; }
.ic.sm{ width:22px; height:22px; }

.pill{
  display:inline-flex;
  align-items:center;
  gap:10px;
  width:max-content;
  max-width:100%;
  min-height:44px;
  padding:10px 20px;
  border-radius:999px;
  font-size:18px;
  font-weight:700;
  line-height:1.2;
  white-space:normal;
}

.pill.y{ background:var(--lp-yellow); color:var(--lp-ink); }
.pill.o{ border:1.5px solid currentColor; color:var(--lp-muted); }
.pill.blue{ background:var(--lp-blue-soft); color:var(--lp-blue); border:1px solid var(--lp-blue); }

.slide-logo-bar{
  position:absolute;
  right:var(--pad-x);
  bottom:28px;
  z-index:10;
  display:flex;
  align-items:center;
  gap:14px;
  pointer-events:none;
}

.slide-logo-bar .sl-sep{
  width:1px;
  height:16px;
  flex:0 0 auto;
  background:var(--lp-line);
}

.slide-logo-bar .sl-lp{
  height:26px;
  display:block;
  opacity:.7;
}

.slide.lp-navy .slide-logo-bar .sl-sep,
.slide.lp-navy-light .slide-logo-bar .sl-sep{ background:rgba(255,255,255,.3); }

.hero-logos{
  display:flex;
  align-items:center;
  gap:22px;
}

.hero-logos img{ display:block; }
.logo-sep{
  width:1px;
  height:34px;
  background:rgba(255,255,255,.35);
}

.hero-mark{
  position:absolute;
  right:92px;
  bottom:28px;
  z-index:1;
  font-family:var(--f-display);
  font-size:310px;
  font-weight:900;
  line-height:.8;
  color:rgba(253,234,0,.1);
  pointer-events:none;
}

.split{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:1fr .78fr;
  gap:58px;
  align-items:stretch;
  margin-top:44px;
  flex:1;
  min-height:0;
}

.photo-panel{
  position:relative;
  min-height:430px;
  overflow:hidden;
  border-radius:8px;
  background:var(--lp-navy);
  box-shadow:0 22px 44px -34px rgba(0,25,65,.55);
}

.photo-panel img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.photo-panel::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(0deg,rgba(0,25,65,.68),rgba(0,25,65,.04));
}

.photo-caption{
  position:absolute;
  left:24px;
  right:24px;
  bottom:22px;
  z-index:2;
  color:#fff;
}

.image-strip{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin-top:24px;
}

.image-strip .photo-panel{
  min-height:150px;
}

.image-strip .photo-caption{
  left:18px;
  right:18px;
  bottom:16px;
}

.image-strip .photo-caption .sub{
  font-size:24px;
}

.agenda-grid{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:14px;
  margin-top:34px;
  flex:1;
  align-items:stretch;
}

.agenda-item{
  display:flex;
  flex-direction:column;
  gap:14px;
  min-height:360px;
  padding:20px 18px;
  border:1px solid var(--lp-line-light);
  border-radius:8px;
  background:#fff;
  box-shadow:0 18px 40px -32px rgba(0,25,65,.55);
}

.agenda-item .num{
  font-family:var(--f-display);
  font-size:28px;
  font-weight:900;
  color:var(--lp-yellow-dark);
}

.agenda-item .chip{
  width:50px;
  height:50px;
  border-radius:8px;
}

.agenda-item .chip .ic{
  width:25px;
  height:25px;
}

.agenda-item .label{
  margin:0;
  font-family:var(--f-display);
  font-size:23px;
  font-weight:800;
  line-height:1.08;
  color:var(--lp-navy);
}

.agenda-item .desc{
  margin:0;
  font-size:16px;
  line-height:1.38;
  color:var(--lp-muted);
}

.network-diagram{
  display:grid;
  grid-template-columns:1fr 1.15fr 1fr;
  gap:30px;
  align-items:stretch;
  margin-top:52px;
  flex:1;
}

.network-node{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:18px;
  min-height:440px;
  padding:34px;
  border:1px solid var(--lp-line-light);
  border-radius:8px;
  background:#fff;
  box-shadow:0 18px 42px -32px rgba(0,25,65,.55);
}

.network-node.primary{
  background:var(--lp-navy);
  color:#fff;
  border-color:var(--lp-navy);
}

.network-node.primary .c-t,
.network-node.primary .sub{ color:#fff; }
.network-node.primary .small{ color:rgba(255,255,255,.78); }

.connector{
  position:absolute;
  top:50%;
  width:44px;
  height:3px;
  background:var(--lp-yellow-dark);
}

.connector.left{ left:-37px; }
.connector.right{ right:-37px; }

.criterion-wrap{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:46px;
  align-items:stretch;
  margin-top:40px;
  flex:1;
}

.criterion-main{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:22px;
  padding:36px;
  border-radius:8px;
  background:var(--lp-navy);
  color:#fff;
  overflow:hidden;
}

.criterion-line{
  display:grid;
  grid-template-columns:130px 1fr;
  gap:18px;
  align-items:center;
  padding:19px 0;
  border-top:1px solid rgba(255,255,255,.18);
}

.criterion-line:first-of-type{ border-top:0; }
.criterion-no{
  font-family:var(--f-display);
  font-size:56px;
  font-weight:900;
  color:var(--lp-yellow);
  line-height:.9;
}

.criterion-text{
  margin:0;
  font-family:var(--f-display);
  font-size:34px;
  font-weight:800;
  line-height:1.08;
}

.validation-list{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}

.validation-card{
  display:flex;
  align-items:center;
  gap:14px;
  min-height:98px;
  padding:18px;
  border:1px solid var(--lp-line-light);
  border-radius:8px;
  background:#fff;
}

.validation-card b{
  font-family:var(--f-display);
  font-size:23px;
  line-height:1.08;
  color:var(--lp-navy);
}

.scenario-grid{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:.72fr 1.28fr;
  gap:44px;
  align-items:stretch;
  margin-top:34px;
  flex:1;
}

.scenario-card{
  display:flex;
  flex-direction:column;
  gap:14px;
  padding:24px;
  border-radius:8px;
  background:var(--lp-navy);
  color:#fff;
}

.scenario-card.alt{ background:var(--lp-navy-light); }

.field-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  align-content:stretch;
}

.field{
  display:flex;
  align-items:flex-start;
  gap:12px;
  min-height:116px;
  padding:17px;
  border:1px solid var(--lp-line-light);
  border-radius:8px;
  background:#fff;
}

.field .chip{
  width:42px;
  height:42px;
  border-radius:8px;
}

.field .chip .ic{
  width:21px;
  height:21px;
}

.field span{
  display:block;
  font-family:var(--f-display);
  font-size:22px;
  font-weight:800;
  line-height:1.1;
  color:var(--lp-navy);
}

.scenario-note{
  display:flex;
  align-items:center;
  gap:14px;
  min-height:92px;
  padding:18px 20px;
  border-radius:8px;
  background:var(--lp-yellow);
  color:var(--lp-ink);
}

.module-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:16px;
  margin-top:40px;
  flex:1;
  align-items:stretch;
}

.module-card{
  display:flex;
  flex-direction:column;
  gap:12px;
  padding:20px;
  border:1px solid var(--lp-line-light);
  border-radius:8px;
  background:#fff;
  box-shadow:0 18px 38px -32px rgba(0,25,65,.5);
}

.module-card .c-t{
  margin:0;
  font-family:var(--f-display);
  font-size:24px;
  font-weight:800;
  line-height:1.08;
  color:var(--lp-navy);
}

.module-ui{
  margin-top:auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  min-height:36px;
  padding:0 10px;
  border:1px solid var(--lp-line-light);
  border-radius:8px;
  background:var(--lp-off-2);
  color:var(--lp-navy);
  font-size:12px;
  font-weight:800;
}

.mini-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--lp-yellow-dark);
}

.viability-grid{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:1fr 1fr 1fr 1fr;
  gap:18px;
  margin-top:44px;
  flex:1;
}

.source-list{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:auto;
}

.source-list span{
  display:inline-flex;
  align-items:center;
  gap:7px;
  min-height:34px;
  padding:8px 13px;
  border-radius:999px;
  background:var(--lp-off-2);
  color:var(--lp-navy);
  font-size:15px;
  font-weight:800;
}

.source-list span::before{
  content:"";
  width:7px;
  height:7px;
  flex:0 0 auto;
  border-radius:50%;
  background:var(--lp-yellow-dark);
}

.role-layout{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:1.25fr .75fr;
  gap:34px;
  margin-top:34px;
  flex:1;
}

.role-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}

.role-card{
  display:flex;
  align-items:flex-start;
  gap:18px;
  min-height:164px;
  padding:22px;
  border:1px solid var(--lp-line-light);
  border-radius:8px;
  background:#fff;
  box-shadow:0 18px 38px -32px rgba(0,25,65,.5);
}

.role-card .chip{
  width:62px;
  height:62px;
}

.role-visual{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.role-visual .photo-panel{
  min-height:410px;
}

.timeline{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:1fr 1fr .78fr;
  gap:24px;
  margin-top:34px;
}

.track{
  display:flex;
  flex-direction:column;
  gap:16px;
  min-height:286px;
  padding:30px;
  border:1px solid rgba(255,255,255,.16);
  border-radius:8px;
  background:rgba(255,255,255,.08);
}

.timeline-photo{
  position:relative;
  min-height:286px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.16);
  border-radius:8px;
  background:var(--lp-navy);
}

.timeline-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:.56;
}

.timeline-photo::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(0deg,rgba(0,25,65,.78),rgba(0,25,65,.08));
}

.timeline-photo .photo-caption{
  left:22px;
  right:22px;
  bottom:22px;
}

.milestones{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-top:22px;
}

.milestone{
  display:flex;
  align-items:flex-start;
  gap:12px;
  min-height:116px;
  padding:17px;
  border:1px solid rgba(255,255,255,.16);
  border-radius:8px;
  background:rgba(255,255,255,.08);
  color:#fff;
}

.milestone .chip{
  width:42px;
  height:42px;
  border-radius:8px;
}

.milestone .chip .ic{
  width:21px;
  height:21px;
}

.milestone b{
  display:block;
  font-family:var(--f-display);
  font-size:21px;
  line-height:1.1;
}

.closing-grid{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:48px;
  align-items:stretch;
  margin-top:38px;
}

.formal-card{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:22px;
  padding:42px;
  border-radius:8px;
  background:var(--lp-yellow);
  color:var(--lp-ink);
}

.formal-card .display{
  font-size:58px;
  line-height:1;
  color:var(--lp-ink);
}

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

.action-card{
  display:flex;
  flex-direction:column;
  gap:12px;
  min-height:128px;
  padding:16px;
  border:1px solid rgba(255,255,255,.16);
  border-radius:8px;
  background:rgba(255,255,255,.08);
}

.action-card .chip{
  width:42px;
  height:42px;
  border-radius:8px;
}

.action-card .chip .ic{
  width:21px;
  height:21px;
}

.action-card b{
  display:block;
  font-family:var(--f-display);
  font-size:21px;
  line-height:1.08;
  color:#fff;
}

/* ── Export UI ─────────────────────────────────────────────── */
#export-btn{
  position:fixed;
  bottom:24px;
  right:24px;
  z-index:9999;
  display:flex;
  align-items:center;
  gap:8px;
  padding:10px 20px;
  border:none;
  border-radius:8px;
  background:var(--lp-navy);
  color:#fff;
  font-family:var(--f-body);
  font-size:14px;
  font-weight:700;
  letter-spacing:.04em;
  cursor:pointer;
  box-shadow:0 4px 16px rgba(0,25,65,.35);
  transition:background .15s;
}
#export-btn:hover{ background:var(--lp-blue); }

#export-overlay{
  position:fixed;
  inset:0;
  z-index:99999;
  display:none;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:20px;
  background:rgba(0,25,65,.92);
  color:#fff;
  font-family:var(--f-body);
}
#export-label{ margin:0; font-size:20px; font-weight:600; }
.export-bar{
  width:320px;
  height:4px;
  border-radius:2px;
  background:rgba(255,255,255,.18);
  overflow:hidden;
}
#export-fill{
  height:100%;
  width:0%;
  border-radius:2px;
  background:var(--lp-yellow);
  transition:width .25s;
}

/* Suppress entrance animations inside export clones */
body.exporting .anim,
body.exporting .anim2,
body.exporting .anim3{
  animation:none !important;
  opacity:1 !important;
  transform:none !important;
}

@media (prefers-reduced-motion:no-preference){
  [data-deck-active] .anim{ animation:rise .5s both cubic-bezier(.2,.7,.2,1); }
  [data-deck-active] .anim2{ animation:rise .5s .06s both cubic-bezier(.2,.7,.2,1); }
  [data-deck-active] .anim3{ animation:rise .5s .12s both cubic-bezier(.2,.7,.2,1); }
  @keyframes rise{
    from{ opacity:0; transform:translateY(22px); }
    to{ opacity:1; transform:none; }
  }
}
