/* ===== Tokens ===== */
:root{
  --bg:#0F172A;
  --bg-2:#0c1426;
  --card:#172235;
  --card-2:#1e2a40;
  --card-edge:#22324b;
  --cyan:#38BDF8;
  --cyan-2:#0EA5E9;
  --green:#10B981;
  --green-2:#059669;
  --green-dark:#0A2B22;
  --amber:#F59E0B;
  --red:#EF4444;
  --white:#F8FAFC;
  --light:#CBD5E1;
  --muted:#94A3B8;
  --slate:#334155;
  --pink:#EC4899;
  --blue:#3B82F6;
  --shadow:0 25px 50px -12px rgba(0,0,0,.45);
  --slide-w:1300px;
  --slide-h:731px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;height:100%;background:var(--bg);color:var(--white);font-family:'Montserrat',-apple-system,sans-serif;overflow:hidden}
body{background:radial-gradient(ellipse at top,#162446 0%,var(--bg) 60%,var(--bg-2) 100%)}

/* ===== Deck container ===== */
#deck{
  position:fixed;inset:0;
  perspective:1500px;
  background:var(--bg);
}

/* ===== Slide base — fills viewport edge-to-edge ===== */
.slide{
  position:absolute;inset:0;
  background:var(--bg);
  display:flex;flex-direction:column;
  justify-content:center; /* distribute content vertically by default */
  padding:clamp(50px, 4.5vw, 90px) clamp(56px, 5.5vw, 120px);
  overflow:hidden;
  opacity:0;visibility:hidden;
  transform:translateX(60px) scale(.985);
  transition:opacity .45s ease, transform .55s cubic-bezier(.22,.9,.35,1.05), visibility 0s linear .45s;
}
/* Slides with table/chart content need top-aligned layout, not centered */
.slide[data-slide="visibility"],
.slide[data-slide="projections"],
.slide[data-slide="dashboard"],
.slide[data-slide="radar-sample"],
.slide[data-slide="roadmap"]{
  justify-content:flex-start;
}
.slide.active{
  opacity:1;visibility:visible;
  transform:translateX(0) scale(1);
  transition:opacity .45s ease, transform .55s cubic-bezier(.22,.9,.35,1.05), visibility 0s linear 0s;
}
.slide.exit-left{ transform:translateX(-60px) scale(.985); }

/* Subtle ambient glow */
.slide::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(900px 350px at 20% -10%, rgba(56,189,248,.08), transparent 60%),
    radial-gradient(700px 300px at 100% 100%, rgba(16,185,129,.05), transparent 60%);
  pointer-events:none;
}

/* ===== Slide head ===== */
.slide-head{margin-bottom:clamp(20px,2vw,36px)}
.slide-head h2{font-size:clamp(40px, 3.6vw, 58px);font-weight:800;color:var(--white);margin:0;letter-spacing:-.8px;line-height:1.05}
.head-rule{width:84px;height:5px;background:var(--cyan);margin-top:14px;border-radius:3px}
.slide-intro{font-size:clamp(17px, 1.25vw, 22px);line-height:1.55;color:var(--light);margin:10px 0 28px;max-width:1500px}
.slide-intro.center{text-align:center;margin-left:auto;margin-right:auto}

/* ===== Slide 1 — Title ===== */
[data-slide="title"]{
  align-items:center;justify-content:center;
  background:linear-gradient(180deg,#0c1426 0%,#0F172A 60%);
}
[data-slide="title"]{align-items:center;justify-content:center}
.title-stack{display:flex;flex-direction:column;align-items:center;gap:30px}
.client-logo{width:clamp(280px,28vw,420px);height:auto;filter:drop-shadow(0 10px 30px rgba(56,189,248,.18));animation:fade-up .9s .15s both ease}
.title-main{font-size:clamp(72px,8vw,124px);font-weight:800;letter-spacing:2px;margin:24px 0 0;animation:fade-up .9s .35s both ease;line-height:1}
.title-main .cyan{color:var(--cyan)}
.title-underline{width:140px;height:5px;background:linear-gradient(90deg,var(--cyan),transparent);border-radius:3px;animation:expand .9s .55s both ease}
.title-sub{font-size:clamp(15px,1.4vw,24px);color:var(--light);margin:8px 0 0;text-align:center;max-width:none;animation:fade-up .9s .7s both ease;line-height:1.4;white-space:nowrap}
.title-corner-tl{position:absolute;top:48px;left:64px;color:var(--muted);font-size:13px;letter-spacing:2px;font-weight:600}
.title-corner-br{position:absolute;bottom:48px;right:64px;text-align:right;animation:fade-up .9s .9s both ease}
.title-corner-br .prepared{color:var(--muted);font-size:11px;letter-spacing:2.5px;font-weight:600;margin-bottom:4px}
.procloser-mark{font-size:clamp(22px,2vw,32px);font-weight:800;letter-spacing:1px;color:var(--white)}
.procloser-logo{display:block;height:clamp(28px,3.5vh,42px);width:auto;margin-top:6px;opacity:.95}

/* ===== Slide 2 — Visibility ===== */
.hero-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:22px;margin:8px 0 18px}
.hero-stat{text-align:center}
.hero-stat .v{font-size:clamp(38px,3.4vw,52px);font-weight:800;line-height:1.05;letter-spacing:-1.5px}
.hero-stat .l{font-size:11.5px;font-weight:700;letter-spacing:1.6px;color:var(--light);margin-top:8px;text-transform:uppercase}
.cyan{color:var(--cyan)}
.green{color:var(--green)}
.amber{color:var(--amber)}
.white{color:var(--white)}
.leader-callout{
  display:flex;align-items:center;gap:12px;
  background:rgba(56,189,248,.08);
  border:1.5px solid var(--cyan);
  border-radius:10px;
  padding:11px 18px;
  font-size:14px;font-weight:600;
  color:var(--cyan);
  margin:8px 0 14px;
}
.leader-callout .star{font-size:18px;flex-shrink:0}
.leader-callout span{color:var(--cyan)}
.leader-callout b{color:var(--white);font-weight:700}
.charts-row{display:grid;grid-template-columns:1fr 1fr;gap:30px;flex:1;min-height:0}
.chart-pane{display:flex;flex-direction:column;min-height:0}
.chart-pane h3{font-size:16px;color:var(--white);margin:0 0 4px;font-weight:700}
.chart-sub{font-size:10.5px;color:var(--muted);margin:0 0 8px}
.chart-wrap{flex:1;min-height:0;position:relative}
.chart-donut{display:flex;align-items:center;justify-content:center}

/* ===== Slide 3 — Strategic Opportunity ===== */
.two-col-cards{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.opp-card{
  background:var(--card);
  border-left:5px solid var(--cyan);
  border-radius:10px;padding:24px 30px;
  font-size:clamp(15px,1.1vw,19px);line-height:1.6;color:var(--light);
}
.opp-card.green-edge{border-left-color:var(--green)}
.card-label{font-size:clamp(13px,.95vw,16px);font-weight:800;letter-spacing:1.8px;margin-bottom:14px;text-transform:uppercase}
.opp-card p{margin:0}
.prompts-h{font-size:clamp(20px,1.5vw,26px);color:var(--white);margin:28px 0 14px;font-weight:700}
.prompts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.prompts-grid.cols-3{grid-template-columns:repeat(3,1fr);gap:12px}
.prompts-grid.cols-3 .prompt-pill{padding:14px 18px 14px 38px;font-size:clamp(13px,1vw,16px)}
.prompts-grid.cols-3 .prompt-pill::before{left:14px;width:8px;height:8px}
.prompt-pill{
  background:var(--card);
  border:1px solid var(--card-edge);
  border-radius:8px;
  padding:16px 20px 16px 40px;
  font-size:clamp(14px,1.05vw,17px);
  color:var(--light);
  position:relative;
  transition:transform .2s, border-color .2s, background .2s;
}
.prompt-pill::before{
  content:"";position:absolute;left:16px;top:50%;
  width:9px;height:9px;border-radius:50%;
  background:var(--cyan);
  transform:translateY(-50%);
  box-shadow:0 0 14px rgba(56,189,248,.7);
}
.prompt-pill:hover{transform:translateX(4px);border-color:var(--cyan);background:#1c2a44}

/* ===== Slide 4 — Projections ===== */
.proj-row{display:grid;grid-template-columns:1.2fr 1fr;gap:24px;flex:1;min-height:0}
.proj-chart{display:flex;flex-direction:column;min-height:0}
.proj-chart h3{font-size:13px;color:var(--cyan);margin:0 0 10px;letter-spacing:1.2px;font-weight:700}
.proj-table{border-collapse:collapse;width:100%;font-size:12px;color:var(--light)}
.proj-table th{background:var(--card);color:var(--cyan);padding:14px;text-align:left;font-weight:700;font-size:clamp(12px,.95vw,16px);letter-spacing:1px}
.proj-table td{padding:14px 16px;border-bottom:1px solid var(--card-edge);font-size:clamp(13px,1.05vw,17px)}
.proj-table tr td:first-child{color:var(--cyan);font-weight:600}
.proj-table tr:hover td{background:rgba(56,189,248,.04)}

.callout{
  background:var(--green-dark);
  border:2px solid var(--green);
  border-radius:12px;
  padding:14px 22px;
  margin-top:14px;
  text-align:center;
  position:relative;
}
.callout::before{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:var(--green);border-radius:12px 0 0 12px}
.green-callout .cl-label{font-size:clamp(12px,.95vw,15px);font-weight:800;letter-spacing:1.6px;color:var(--green);margin-bottom:6px}
.green-callout .cl-value{font-size:clamp(17px,1.4vw,22px);font-weight:700;color:var(--white)}
.callout.small .cl-value{font-size:clamp(14px,1.1vw,18px);font-weight:600;color:var(--light)}
.callout.small em{color:var(--muted);font-size:clamp(12px,.95vw,15px)}
.green-callout .cl-sub{font-size:clamp(13px,1vw,16px);font-weight:500;color:var(--light);margin-top:8px;font-style:italic}

/* ===== Slide 2 — TL;DR forwarder grid ===== */
.tldr-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin:12px 0 18px}
.tldr-card{
  background:var(--card);
  border:1px solid var(--card-edge);
  border-radius:14px;
  padding:20px 24px;
  display:flex;align-items:flex-start;gap:18px;
  position:relative;
}
.tldr-card.cyan-edge{border-left:5px solid var(--cyan)}
.tldr-card.green-edge{border-left:5px solid var(--green)}
.tldr-num{
  flex:0 0 44px;height:44px;width:44px;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;
  font-size:20px;font-weight:800;
  background:rgba(56,189,248,.12);
}
.tldr-num.green{background:rgba(16,185,129,.14)}
.tldr-card p{margin:0;font-size:clamp(14px,1.05vw,17px);line-height:1.55;color:var(--light)}

/* ===== Optional tag (slide titles) ===== */
.opt-tag{
  display:inline-block;
  margin-left:14px;
  padding:5px 12px;
  background:rgba(245,158,11,.14);
  border:1px solid rgba(245,158,11,.42);
  color:var(--amber);
  font-size:clamp(10px,.78vw,13px);
  font-weight:700;
  letter-spacing:1.4px;
  border-radius:999px;
  vertical-align:middle;
  white-space:nowrap;
}

.disclaimer{font-size:9.5px;color:var(--muted);margin:8px 0 0;font-style:italic}

/* ===== Slides 5–8 — radar/outbound/inbound 4-card grids ===== */
.radar-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;flex:1;min-height:0}
.radar-card{
  background:var(--card);
  border:1px solid var(--card-edge);
  border-left:5px solid var(--cyan);
  border-radius:12px;
  padding:24px 30px;
  font-size:clamp(15px,1.1vw,19px);line-height:1.6;color:var(--light);
  transition:transform .2s, box-shadow .2s, border-left-color .2s;
  display:flex;flex-direction:column;justify-content:center;
}
.radar-card:hover{transform:translateY(-4px);box-shadow:0 14px 32px -10px rgba(56,189,248,.3)}
.rcard-h{font-size:clamp(18px,1.4vw,24px);font-weight:700;margin-bottom:10px;color:var(--white)}
.rcard-h.cyan{color:var(--cyan)}
.rcard-h.green{color:var(--green)}
.radar-card p{margin:0}
.radar-card:has(.green){border-left-color:var(--green)}

/* Card icon badge — 44px circle w/ centered SVG glyph */
.rcard-icon{
  width:44px;height:44px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:14px;
  box-shadow:0 0 18px -4px currentColor;
}
.rcard-icon.cyan-bg{background:rgba(56,189,248,.14);color:var(--cyan)}
.rcard-icon.green-bg{background:rgba(16,185,129,.14);color:var(--green)}
.rcard-icon svg{width:24px;height:24px;display:block}

/* ===== Slide 6 — Sample Radar Output ===== */
.radar-table{
  width:100%;border-collapse:separate;border-spacing:0;
  font-size:12px;color:var(--light);
  background:var(--card);border:1px solid var(--card-edge);
  border-radius:10px;overflow:hidden;
}
.radar-table thead th{
  background:#1c2a44;color:var(--cyan);
  padding:16px 18px;text-align:left;font-weight:800;font-size:clamp(12px,.95vw,15px);letter-spacing:1.3px;
}
.radar-table tbody{font-size:clamp(13px,1vw,16px)}
.radar-table tbody td{padding:16px 18px;border-bottom:1px solid var(--card-edge);vertical-align:middle;line-height:1.5}
.radar-table tbody tr:nth-child(even){background:#121b2b}
.radar-table tbody tr:hover{background:#1c2a44}
.radar-table tbody tr:last-child td{border-bottom:none}
.radar-table b{color:var(--white)}
.badge{
  display:inline-block;padding:5px 10px;border-radius:14px;
  font-size:9.5px;font-weight:800;letter-spacing:1px;
  border:1.5px solid;
  white-space:nowrap;
}
.badge.strong{color:var(--green);border-color:var(--green);background:rgba(16,185,129,.08)}
.badge.adjacent{color:var(--amber);border-color:var(--amber);background:rgba(245,158,11,.06)}
.badge.reference{color:var(--muted);border-color:var(--muted);background:transparent}

/* ===== Slide 9 — 90-Day Editorial Roadmap ===== */
.roadmap-row{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
  margin:14px 0 18px;flex:1;min-height:0;
}
.rmap-col{
  background:var(--card);
  border:1px solid var(--card-edge);
  border-top:5px solid var(--cyan);
  border-radius:14px;
  padding:30px 26px 22px;
  position:relative;
  display:flex;flex-direction:column;gap:14px;
  transition:transform .25s, box-shadow .25s;
}
.rmap-col:hover{transform:translateY(-3px);box-shadow:0 14px 32px -10px rgba(56,189,248,.25)}
.rmap-col:nth-child(2){border-top-color:var(--green)}
.rmap-col:nth-child(3){border-top-color:var(--amber)}
.rmap-num{
  position:absolute;top:-22px;left:30px;
  width:46px;height:46px;border-radius:50%;
  background:var(--cyan);color:#0d1b30;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;font-weight:800;
  box-shadow:0 6px 16px -4px rgba(56,189,248,.5);
}
.rmap-col:nth-child(2) .rmap-num{background:var(--green);box-shadow:0 6px 16px -4px rgba(16,185,129,.5)}
.rmap-col:nth-child(3) .rmap-num{background:var(--amber);box-shadow:0 6px 16px -4px rgba(245,158,11,.5)}
.rmap-month{
  font-size:clamp(20px,1.6vw,28px);
  font-weight:800;color:var(--white);
  letter-spacing:.3px;margin-top:14px;
}
.rmap-block{display:flex;flex-direction:column;gap:4px}
.rb-label{font-size:clamp(10px,.8vw,12px);font-weight:800;letter-spacing:1.6px;text-transform:uppercase}
.rmap-block p{
  font-size:clamp(13px,.95vw,16px);
  color:var(--light);line-height:1.55;margin:0;
}
.rmap-block b{color:var(--white)}

.rmap-volume{
  background:rgba(15,23,42,.5);
  border:1px solid var(--card-edge);
  border-radius:12px;padding:18px 22px;
}
.rv-label{
  font-size:clamp(11px,.85vw,14px);
  font-weight:800;letter-spacing:1.6px;
  color:var(--cyan);text-transform:uppercase;
  text-align:center;margin-bottom:14px;
}
.rv-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.rv-card{
  background:var(--card);
  border:1px solid var(--card-edge);
  border-radius:10px;
  padding:14px 16px;
  display:flex;align-items:center;gap:14px;
  transition:transform .2s, border-color .2s;
}
.rv-card:hover{transform:translateY(-2px);border-color:var(--cyan)}
.rv-num{
  width:42px;height:42px;border-radius:50%;
  background:rgba(56,189,248,.12);
  border:1.5px solid var(--cyan);
  color:var(--cyan);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;font-weight:800;flex-shrink:0;
}
.rv-name{font-size:clamp(13px,1vw,16px);font-weight:700;color:var(--white);line-height:1.2}
.rv-desc{font-size:clamp(11px,.85vw,13px);color:var(--muted);margin-top:2px;line-height:1.3}

/* ===== Slide 10 — Tracking Dashboard ===== */
.dashboard-grid{display:flex;flex-direction:column;gap:14px;flex:1;min-height:0}
.dash-stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.dash-stat{
  background:var(--card);border:1px solid var(--card-edge);
  border-radius:10px;padding:14px 18px;
  position:relative;overflow:hidden;
}
.dash-stat::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 60%, rgba(56,189,248,.05) 100%)}
.ds-label{font-size:9.5px;font-weight:800;letter-spacing:1.3px;color:var(--muted);text-transform:uppercase}
.ds-value{font-size:32px;font-weight:800;line-height:1.1;margin:8px 0 4px}
.ds-trend{font-size:11px;color:var(--muted)}
.ds-trend.up{color:var(--green)}
.dash-trend-card{
  flex:1;min-height:0;
  background:var(--card);border:1px solid var(--card-edge);
  border-radius:10px;padding:16px 20px;
  display:flex;flex-direction:column;
}
.dash-trend-card h3{font-size:14px;color:var(--white);margin:0 0 10px;font-weight:700}

/* ===== Slide 10 — Compliance ===== */
.compliance-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;flex:1;min-height:0;
}
.comp-card{
  background:var(--card);border:1px solid var(--card-edge);
  border-radius:12px;padding:26px 30px;
  transition:transform .25s, box-shadow .25s, border-color .25s;
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;justify-content:center;
}
.comp-card:hover{transform:translateY(-4px);border-color:var(--cyan);box-shadow:0 12px 26px -10px rgba(56,189,248,.3)}
.comp-icon{font-size:36px;margin-bottom:10px}
.comp-card h4{font-size:clamp(18px,1.3vw,24px);color:var(--cyan);margin:6px 0 12px;font-weight:700}
.comp-card p{font-size:clamp(14px,1.05vw,18px);color:var(--light);margin:0;line-height:1.55}

/* ===== Slide 11 — Team ===== */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;flex:1}
.person-card{
  background:var(--card);border:1px solid var(--card-edge);
  border-radius:14px;padding:30px 32px;
  display:flex;flex-direction:column;justify-content:center;
  transition:transform .25s, border-color .25s, box-shadow .25s;
}
.person-card:hover{transform:translateY(-3px);border-color:var(--cyan)}
.person-card.recommended{border-color:var(--cyan);box-shadow:0 0 30px -10px rgba(56,189,248,.3)}
.pc-role{font-size:clamp(11px,.85vw,14px);letter-spacing:1.8px;color:var(--cyan);font-weight:800;margin-bottom:10px}
.pc-name{font-size:clamp(22px,1.7vw,30px);font-weight:800;color:var(--white)}
.pc-title{font-size:clamp(13px,1vw,17px);color:var(--light);margin-bottom:18px}
.pc-bullets{margin:0;padding-left:22px;color:var(--light);font-size:clamp(14px,1.05vw,18px);line-height:1.7}
.pc-bullets li{margin-bottom:7px}
.pc-bullets li::marker{color:var(--green)}

/* ===== Slide 12 — Case Study ===== */
.metric-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:0 0 18px}
.metric-card{
  background:var(--card);
  border:1px solid var(--cyan);
  border-radius:10px;padding:18px;text-align:center;
  position:relative;overflow:hidden;
  transition:transform .25s, box-shadow .25s;
}
.metric-card:hover{transform:translateY(-3px);box-shadow:0 12px 28px -10px rgba(56,189,248,.35)}
.m-value{font-size:clamp(36px,3vw,48px);font-weight:800;line-height:1}
.m-label{font-size:12.5px;color:var(--light);margin-top:8px;font-weight:600}

/* ===== Slide 13 — Pricing ===== */
.pricing-card{
  background:var(--card);
  border:2px solid var(--cyan);
  border-radius:14px;padding:22px 28px;
  position:relative;
  margin:6px 0 16px;
  box-shadow:0 0 40px -8px rgba(56,189,248,.25);
}
.rec-badge{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--green);color:#04211c;
  padding:6px 18px;border-radius:18px;
  font-size:10.5px;font-weight:800;letter-spacing:1.5px;
}
.pc-name-big{font-size:24px;font-weight:800;text-align:center;color:var(--white);margin-top:6px}
.pc-price{text-align:center;margin:8px 0 14px}
.price-num{font-size:clamp(48px,4.5vw,68px);font-weight:800;color:var(--cyan);letter-spacing:-1px}
.price-suffix{font-size:clamp(14px,1.1vw,18px);color:var(--light);margin-left:10px}
.pc-features{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:6px 30px}
.pc-features li{font-size:clamp(14px,1.1vw,18px);color:var(--light);padding-left:28px;position:relative;line-height:1.55}
.pc-features li::before{
  content:"✓";position:absolute;left:0;top:0;
  color:var(--green);font-weight:800;
}
.founding-note{
  margin-top:14px;padding:10px 14px;
  background:rgba(245,158,11,.08);
  border:1px solid var(--amber);border-radius:8px;
  font-size:12px;color:var(--white);text-align:center;
}
.impact-strip{margin-top:6px}
.impact-label{
  font-size:11px;letter-spacing:1.5px;font-weight:800;
  color:var(--green);text-align:center;text-transform:uppercase;margin-bottom:8px;
}
.impact-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.impact-card{
  background:var(--green-dark);
  border:1.5px solid var(--green);
  border-radius:12px;padding:14px 18px;text-align:center;
  transition:transform .25s, box-shadow .25s;
}
.impact-card:hover{transform:scale(1.02);box-shadow:0 12px 28px -10px rgba(16,185,129,.4)}
.ic-v{font-size:clamp(28px,2.6vw,40px);font-weight:800;color:var(--green);line-height:1;letter-spacing:-.5px}
.ic-l{font-size:12.5px;color:var(--light);margin-top:8px;font-weight:600}

/* 3-card pricing row (Foundation / Growth / Enterprise) */
.pricing-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:14px}
.pricing-row .pricing-card{
  margin:6px 0;padding:20px 22px;
  display:flex;flex-direction:column;
  border-color:var(--card-edge);
  box-shadow:0 0 24px -10px rgba(56,189,248,.15);
}
.pricing-row .pricing-card.recommended{
  border-color:var(--green);
  box-shadow:0 0 36px -8px rgba(16,185,129,.3);
  transform:translateY(-6px);
}
.pricing-row .pc-features{display:block}
.pricing-row .pc-features li{margin-bottom:8px;font-size:13px;line-height:1.45}
.pricing-row .pc-name-big{font-size:20px;margin-top:4px}
.pricing-row .price-num{font-size:42px}
.pricing-row .price-suffix{font-size:13px;display:block;margin-top:4px}
.pc-fit{
  margin-top:14px;padding-top:12px;
  border-top:1px solid var(--card-edge);
  font-size:12px;color:var(--muted);font-style:italic;line-height:1.5;
}

/* ===== Slide 14 — Packaging ===== */
.package-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;flex:1}
.package-card{
  background:var(--card);
  border:1px solid var(--card-edge);
  border-radius:14px;padding:24px 28px;
  position:relative;
  display:flex;flex-direction:column;
  transition:transform .25s, border-color .25s;
}
.package-card.recommended{border:2px solid var(--green);box-shadow:0 0 36px -8px rgba(16,185,129,.3)}
.package-card:hover{transform:translateY(-3px)}
.pkg-label{font-size:10.5px;letter-spacing:1.5px;color:var(--cyan);font-weight:800;margin-bottom:6px}
.pkg-name{font-size:clamp(28px,2.2vw,38px);font-weight:800;color:var(--white);margin-bottom:18px}
.pkg-price{margin-bottom:22px}
.pkg-price span:first-child{font-size:clamp(40px,3.5vw,56px);font-weight:800;letter-spacing:-1px}
.pkg-suffix{font-size:clamp(14px,1.1vw,18px);color:var(--light);margin-left:6px;display:block;margin-top:4px}
.pkg-features{list-style:none;padding:0;margin:0;flex:1}
.pkg-features li{font-size:clamp(14px,1.1vw,18px);color:var(--light);line-height:1.55;padding-left:26px;position:relative;margin-bottom:10px}
.pkg-features li::before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:800}
.pkg-footer{margin-top:18px;padding-top:18px;border-top:1px solid var(--card-edge);font-size:clamp(13px,1vw,16px);color:var(--muted);font-style:italic;line-height:1.5}

/* ===== Slide 15 — Free Audit ===== */
.audit-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin:24px 0}
.audit-steps.four{grid-template-columns:repeat(4,1fr);gap:20px}
.audit-card{
  background:var(--card);
  border:1.5px solid var(--cyan);
  border-radius:16px;padding:36px 30px 26px;
  position:relative;
  transition:transform .25s, box-shadow .25s;
  display:flex;flex-direction:column;
}
.audit-card:hover{transform:translateY(-4px);box-shadow:0 16px 36px -10px rgba(56,189,248,.35)}
.audit-num{
  position:absolute;top:-26px;left:50%;transform:translateX(-50%);
  width:54px;height:54px;border-radius:50%;
  background:var(--cyan);color:#0d1b30;
  display:flex;align-items:center;justify-content:center;
  font-size:26px;font-weight:800;
  box-shadow:0 6px 18px -4px rgba(56,189,248,.5);
}
.audit-card h3{font-size:clamp(20px,1.5vw,28px);font-weight:700;color:var(--white);text-align:center;margin:8px 0 12px}
.audit-card p{font-size:clamp(14px,1.05vw,18px);color:var(--light);line-height:1.6;margin:0}
.audit-cta{text-align:center;margin-top:14px}
.cta-top{font-size:clamp(24px,2vw,32px);font-weight:800;color:var(--green)}
.cta-bottom{font-size:clamp(13px,1vw,17px);color:var(--light);margin-top:6px;letter-spacing:.5px}

/* ===== Slide 16 — Next Steps ===== */
.ready-block{text-align:center;margin-top:24px}
.ready-title{font-size:clamp(46px,4.5vw,72px);font-weight:800;margin:0 0 36px;letter-spacing:-1px;line-height:1.1}
.contact-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:900px;margin:0 auto}
.contact-card{padding:14px}
.cc-label{font-size:clamp(12px,.95vw,15px);letter-spacing:1.6px;color:var(--muted);font-weight:700;margin-bottom:8px}
.cc-value{font-size:clamp(20px,1.6vw,26px);font-weight:700;color:var(--white)}

/* ===== Navigation — auto-hide overlay ===== */
.deck-nav{
  position:fixed;bottom:32px;left:50%;transform:translateX(-50%);
  display:flex;align-items:center;gap:14px;
  background:rgba(15,23,42,.78);
  backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);
  border:1px solid rgba(255,255,255,.1);
  border-radius:40px;
  padding:8px 14px;
  box-shadow:0 18px 48px rgba(0,0,0,.5);
  z-index:100;
  opacity:1;
  transition:opacity .35s ease, transform .35s ease;
}
.deck-nav.hidden{opacity:0;pointer-events:none;transform:translateX(-50%) translateY(14px)}
.nav-btn{
  width:46px;height:46px;border-radius:50%;
  background:transparent;color:var(--white);
  border:1px solid rgba(255,255,255,.18);
  font-size:20px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s, transform .15s, border-color .2s;
}
.nav-btn:hover{background:rgba(56,189,248,.2);border-color:var(--cyan);transform:scale(1.06)}
.nav-btn:active{transform:scale(.94)}
.nav-btn:disabled{opacity:.3;cursor:not-allowed;transform:none}
.counter{font-size:13px;font-weight:600;color:var(--light);min-width:62px;text-align:center;letter-spacing:.4px;font-variant-numeric:tabular-nums}

/* Edge hover targets — large invisible click zones on left/right edges
   so the user can advance even when the nav bar is hidden */
.edge-zone{
  position:fixed;top:0;bottom:0;width:14vw;max-width:240px;
  z-index:90;cursor:pointer;
  background:linear-gradient(to right, rgba(56,189,248,.0), transparent);
  opacity:0;transition:opacity .2s ease;
}
.edge-zone.left{left:0}
.edge-zone.right{right:0;background:linear-gradient(to left, rgba(56,189,248,.0), transparent)}
.edge-zone:hover{opacity:1}
.edge-zone .arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:54px;height:54px;border-radius:50%;
  background:rgba(15,23,42,.85);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;color:var(--white);
  opacity:0;transition:opacity .25s ease, transform .2s ease;
}
.edge-zone.left  .arrow{left:24px}
.edge-zone.right .arrow{right:24px}
.edge-zone:hover .arrow{opacity:1;transform:translateY(-50%) scale(1.04)}

/* Progress bar at top — discreet, always visible */
.deck-progress{
  position:fixed;left:0;right:0;top:0;
  height:3px;background:rgba(255,255,255,.04);
  z-index:99;
}
.dp-bar{
  height:100%;width:0%;
  background:linear-gradient(90deg,var(--cyan),var(--green));
  transition:width .55s cubic-bezier(.22,.9,.35,1.05);
  box-shadow:0 0 12px rgba(56,189,248,.55);
}

.deck-help{
  position:fixed;top:22px;right:28px;
  font-size:11px;color:var(--muted);
  background:rgba(15,23,42,.7);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  padding:6px 14px;border-radius:14px;
  border:1px solid rgba(255,255,255,.06);
  z-index:100;
  letter-spacing:.4px;
  opacity:1;
  transition:opacity .35s ease;
}
.deck-help.hidden{opacity:0;pointer-events:none}

/* Hide cursor when nav is hidden — full-presentation feel */
body.idle{cursor:none}
body.idle .edge-zone{cursor:none}

/* ===== Animations ===== */
@keyframes fade-up{
  from{opacity:0;transform:translateY(18px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes expand{
  from{width:0}
  to{width:120px}
}
@keyframes pop{
  from{opacity:0;transform:scale(.8)}
  to{opacity:1;transform:scale(1)}
}

/* Per-slide enter animations: cards fade-in staggered when slide becomes active */
.slide.active .hero-stat,
.slide.active .opp-card,
.slide.active .radar-card,
.slide.active .comp-card,
.slide.active .person-card,
.slide.active .metric-card,
.slide.active .package-card,
.slide.active .audit-card,
.slide.active .impact-card,
.slide.active .dash-stat,
.slide.active .prompt-pill,
.slide.active .contact-card,
.slide.active .leader-callout,
.slide.active .callout,
.slide.active .pricing-card,
.slide.active .radar-table,
.slide.active .proj-table{
  animation:fade-up .55s both ease;
}

/* Stagger by index — works because :nth-child applies to siblings */
.slide.active .hero-stat:nth-child(1){animation-delay:.05s}
.slide.active .hero-stat:nth-child(2){animation-delay:.12s}
.slide.active .hero-stat:nth-child(3){animation-delay:.19s}
.slide.active .hero-stat:nth-child(4){animation-delay:.26s}
.slide.active .hero-stat:nth-child(5){animation-delay:.33s}

.slide.active .radar-card:nth-child(1),.slide.active .opp-card:nth-child(1),.slide.active .comp-card:nth-child(1),.slide.active .person-card:nth-child(1),.slide.active .metric-card:nth-child(1),.slide.active .package-card:nth-child(1),.slide.active .audit-card:nth-child(1),.slide.active .impact-card:nth-child(1),.slide.active .dash-stat:nth-child(1),.slide.active .contact-card:nth-child(1){animation-delay:.08s}
.slide.active .radar-card:nth-child(2),.slide.active .opp-card:nth-child(2),.slide.active .comp-card:nth-child(2),.slide.active .person-card:nth-child(2),.slide.active .metric-card:nth-child(2),.slide.active .package-card:nth-child(2),.slide.active .audit-card:nth-child(2),.slide.active .impact-card:nth-child(2),.slide.active .dash-stat:nth-child(2),.slide.active .contact-card:nth-child(2){animation-delay:.18s}
.slide.active .radar-card:nth-child(3),.slide.active .comp-card:nth-child(3),.slide.active .person-card:nth-child(3),.slide.active .metric-card:nth-child(3),.slide.active .audit-card:nth-child(3),.slide.active .impact-card:nth-child(3),.slide.active .dash-stat:nth-child(3),.slide.active .contact-card:nth-child(3){animation-delay:.28s}
.slide.active .radar-card:nth-child(4),.slide.active .comp-card:nth-child(4),.slide.active .metric-card:nth-child(4),.slide.active .dash-stat:nth-child(4){animation-delay:.38s}
.slide.active .comp-card:nth-child(5){animation-delay:.48s}
.slide.active .comp-card:nth-child(6){animation-delay:.58s}

.slide.active .prompt-pill{animation-delay:calc(0.04s * var(--i, 1))}

/* ===== Aaron feedback 2026-05-06: nowrap + larger projection table ===== */
.nowrap{white-space:nowrap}
.muted-sm{color:var(--muted);font-weight:400;font-size:.85em;display:block;margin-top:2px}
.proj-table-lg th{font-size:clamp(13px,1vw,16px);padding:14px 12px;white-space:nowrap}
.proj-table-lg td{font-size:clamp(15px,1.15vw,19px);padding:18px 14px;line-height:1.45}
.proj-table-lg td:first-child{font-weight:700;color:var(--white)}
.proj-table-lg td:not(:first-child){font-weight:700;color:var(--cyan)}

/* ===== Single-card pricing (Engagement slide) ===== */
.pricing-card.single-card{
  max-width:920px;margin:0 auto 24px;
  padding:32px 44px;
}
.pricing-card.single-card .pc-features{grid-template-columns:1fr 1fr;gap:10px 36px}
.pricing-card.single-card .pc-name-big{font-size:clamp(28px,2.4vw,36px)}
.pricing-card.single-card .price-num{font-size:clamp(54px,5vw,76px)}

/* ===== 3-card packaging row ===== */
.package-row-3{grid-template-columns:repeat(3,1fr) !important}
.package-row-3 .package-card{padding:22px 24px}
.package-row-3 .pkg-price span:first-child{font-size:clamp(34px,3vw,46px)}
.package-row-3 .pkg-features li{font-size:clamp(13px,.95vw,16px);line-height:1.5;margin-bottom:8px}

/* ===== Allow scroll on slides whose content exceeds the viewport ===== */
.slide{overflow-y:auto;overflow-x:hidden}
/* Custom scrollbar for the dark theme */
.slide::-webkit-scrollbar{width:8px}
.slide::-webkit-scrollbar-track{background:transparent}
.slide::-webkit-scrollbar-thumb{background:rgba(56,189,248,.25);border-radius:4px}
.slide::-webkit-scrollbar-thumb:hover{background:rgba(56,189,248,.45)}

/* ===== Mobile responsive (≤768px — phones) ===== */
@media (max-width:768px){
  /* Let body grow with content so window scroll works (desktop locks to 100%) */
  html,body{overflow:auto;height:auto;min-height:100%}
  #deck{position:relative;perspective:none;height:auto;inset:auto}
  /* Scroll container with right-edge fade indicating swipeable table content */
  .table-scroll{
    position:relative;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    margin:0 -8px;     /* let scroll edge reach phone gutters */
    padding:0 8px;
  }
  .table-scroll::after{
    content:"";position:sticky;right:0;top:0;
    display:block;width:32px;height:100%;
    background:linear-gradient(90deg,transparent,var(--bg) 70%);
    pointer-events:none;float:right;margin-top:-100%;
  }
  /* Tables inside scroll container can keep desktop layout but stay min-content */
  .table-scroll > table{min-width:max-content}
  .table-scroll .proj-table-lg{font-size:12px}
  .table-scroll .proj-table-lg th,
  .table-scroll .proj-table-lg td{padding:10px 12px}
  .table-scroll .radar-table{font-size:11px;white-space:normal}
  .table-scroll .radar-table thead th,
  .table-scroll .radar-table tbody td{padding:10px 12px}
  .slide{
    position:relative;inset:auto;
    opacity:1;visibility:visible;transform:none;
    transition:none;
    padding:32px 20px 60px;
    min-height:auto;
    border-bottom:1px solid var(--card-edge);
  }
  .slide.exit-left{transform:none}
  .slide-head h2{font-size:28px;line-height:1.1}
  .head-rule{width:60px;height:3px;margin-top:10px}
  .slide-intro{font-size:15px;margin:8px 0 18px}
  /* Slide 1 — title */
  .title-stack{padding-top:20px}
  .title-main{font-size:42px;line-height:1.05}
  .title-sub{font-size:14px;white-space:normal}
  .client-logo{max-width:200px}
  /* Hero stats stack 2-up on phones */
  .hero-stats{grid-template-columns:repeat(2,1fr);gap:12px}
  .hero-stat .v{font-size:32px}
  .hero-stat .l{font-size:11px}
  .leader-callout{font-size:13px;padding:12px 14px}
  /* Charts stack vertically */
  .charts-row{grid-template-columns:1fr;gap:24px}
  .chart-pane h3{font-size:16px}
  .chart-wrap{height:280px}
  .chart-wrap.chart-donut{height:340px}
  /* Strategic Opportunity 2-col → 1-col */
  .two-col-cards{grid-template-columns:1fr;gap:16px}
  .opp-card p{font-size:14px;line-height:1.55}
  .prompts-grid{grid-template-columns:1fr;gap:8px}
  .prompt-pill{font-size:13px;padding:10px 14px}
  /* Projections — chart above table on phones */
  .proj-row{grid-template-columns:1fr;gap:24px}
  .proj-table-lg th,.proj-table-lg td{font-size:12px;padding:10px 8px}
  /* Radar grids 2x2 → 1-col */
  .radar-grid{grid-template-columns:1fr;gap:14px}
  .radar-card{padding:18px 20px}
  .rcard-h{font-size:17px}
  .radar-card p{font-size:14px;line-height:1.55}
  .rcard-icon{width:36px;height:36px;margin-bottom:10px}
  .rcard-icon svg{width:20px;height:20px}
  /* Sample radar table — make it scrollable horizontally */
  .radar-table{font-size:11px;display:block;overflow-x:auto;white-space:nowrap}
  /* Dashboard 4 stats → 2x2 */
  .dash-stat-row{grid-template-columns:repeat(2,1fr)}
  .dashboard-grid{grid-template-columns:1fr}
  .dash-trend-card{margin-top:16px}
  .dash-trend-card .chart-wrap{height:280px}
  /* Team 3-col → 1-col */
  .team-grid{grid-template-columns:1fr;gap:14px}
  .person-card{padding:18px 22px}
  /* Case study metrics — 4-col → 2x2 */
  .metric-row{grid-template-columns:repeat(2,1fr);gap:10px}
  .m-value{font-size:28px}
  /* Single pricing card */
  .pricing-card.single-card{padding:24px 22px}
  .pricing-card.single-card .pc-features{grid-template-columns:1fr;gap:8px}
  .pricing-card.single-card .price-num{font-size:48px}
  /* Packaging — 3-col → 1-col stack */
  .package-row,.package-row-3{grid-template-columns:1fr !important;gap:14px}
  .package-card{padding:20px 22px}
  .pkg-name{font-size:22px}
  .pkg-price span:first-child{font-size:36px !important}
  /* Audit steps + Next Steps — 3/4-col → 1-col */
  .audit-steps{grid-template-columns:1fr !important;gap:14px}
  .audit-card{padding:18px 22px}
  /* Impact strip 3-col → 1-col */
  .impact-cards{grid-template-columns:1fr;gap:10px}
  /* Contact row 3-col → 1-col */
  .contact-row{grid-template-columns:1fr;gap:10px}
  .ready-title{font-size:26px;line-height:1.2}
  /* Hide nav arrows on touch devices, rely on swipe + scroll */
  .deck-nav{bottom:16px}
  .nav-btn{width:38px;height:38px;font-size:18px}
  .counter{font-size:11px}
  .edge-zone,.deck-help,.deck-progress{display:none}
  /* Title-corner labels off-screen on mobile to declutter */
  .title-corner-tl{font-size:10px;top:14px;left:14px}
  .title-corner-br{bottom:14px;right:14px}
  .procloser-logo{height:24px}
  .prepared{font-size:9px}
}

/* ===== Tablet tweaks (769-1024px) ===== */
@media (min-width:769px) and (max-width:1024px){
  .slide{padding:48px 56px}
  .slide-head h2{font-size:36px}
  .charts-row{grid-template-columns:1fr 1fr;gap:24px}
  .chart-wrap{height:340px}
  .package-row-3{grid-template-columns:1fr}
  .package-row-3 .package-card{margin-bottom:14px}
}

/* Print — single-page-per-slide PDF export */
@media print{
  body, html{background:white;overflow:visible;height:auto}
  #deck{position:static;display:block}
  .slide{
    width:11in;height:6.18in;max-height:none;
    page-break-after:always;break-after:page;
    position:relative;opacity:1;visibility:visible;transform:none;
    box-shadow:none;border:none;border-radius:0;
    margin:0;padding:36px 48px;
  }
  .deck-nav,.deck-progress,.deck-help{display:none}
}
