/* ============================================================
   COCOLI EVOLUTION 2026 — deck stylesheet
   Design language inspired by the "Pivot results COCOLI v2" PDF:
   grainy gradient backgrounds, bold black headlines, peach/blue
   pastel palette, thin top header rule with logo + url.
   ============================================================ */

:root{
  --bg:#f3eee6;
  --ink:#0d0d0d;
  --ink-soft:#2a2a2a;
  --ink-mute:#5a5a5a;
  --paper:#ffffff;
  --line:rgba(0,0,0,.12);

  --peach-1:#fef2e2;
  --peach-2:#f6d3ad;
  --peach-3:#e9b079;

  --blue-1:#eaf1fa;
  --blue-2:#cbdcef;
  --blue-3:#7ea3cf;
  --blue-deep:#0d1e3c;

  --accent-strategic:#0d1e3c;
  --accent-ongoing:#9b6a3a;
  --accent-tactical:#6b3a5b;

  --good:#3b7a3b;
  --bad:#a23232;

  --radius:18px;
  --radius-lg:26px;

  --font-sans:'Inter', system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --font-serif:'Cormorant Garamond', "Iowan Old Style", Georgia, serif;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:#1a1a1a;
  font-family:var(--font-sans);
  color:var(--ink);
  overflow:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

/* ---------- Deck container & slide sizing ---------------- */
.deck{
  position:fixed;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
}

.slide{
  position:absolute;
  inset:0;
  width:100vw;
  height:100vh;
  display:none;
  overflow:hidden;
  background:var(--bg);
}

.slide.is-active{display:block; animation:slideIn .55s cubic-bezier(.2,.7,.2,1) both}

@keyframes slideIn{
  from{opacity:0; transform:translateY(8px) scale(.995)}
  to  {opacity:1; transform:none}
}

/* Grain overlay — sits above background gradient, below content */
.slide__grain{
  position:absolute; inset:0;
  pointer-events:none;
  filter:url(#grain);
  opacity:.55;
  mix-blend-mode:multiply;
  z-index:1;
}

/* Background gradients ------------------------------------ */
.bg-gradient{position:absolute; inset:0; z-index:0}

.bg-gradient--peach{
  background:
    radial-gradient(120% 80% at 10% 0%,  #fff1de 0%, transparent 55%),
    radial-gradient(110% 90% at 100% 100%, #e9b079 0%, transparent 60%),
    linear-gradient(180deg, #fbe3c6 0%, #f4cfa1 100%);
}
.bg-gradient--blue{
  background:
    radial-gradient(100% 80% at 0% 0%, #ffffff 0%, transparent 60%),
    radial-gradient(120% 90% at 100% 100%, #9bbde6 0%, transparent 60%),
    linear-gradient(180deg, #e9f0fa 0%, #c2d6ef 100%);
}
.bg-gradient--soft{
  background:
    radial-gradient(100% 80% at 0% 0%, #fdf0f7 0%, transparent 60%),
    radial-gradient(100% 100% at 100% 100%, #e6efff 0%, transparent 60%),
    linear-gradient(180deg, #fbf6ef 0%, #f1ecff 100%);
}

/* ---------- Shared slide header (logo + url + rule) ------ */
.slide__header{
  position:absolute;
  top:0; left:0; right:0;
  padding:26px 56px 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  z-index:5;
  border-bottom:1px solid rgba(0,0,0,.12);
  background:linear-gradient(180deg, rgba(255,255,255,.18), rgba(255,255,255,0));
  backdrop-filter:blur(.5px);
}
.slide__logo{height:30px; width:auto; display:block; user-select:none}
.slide__url{
  font-size:14px;
  letter-spacing:.02em;
  color:var(--ink);
  font-weight:500;
}

/* Body */
.slide__body{
  position:relative;
  z-index:4;
  padding:96px 56px 56px;
  width:100%;
  height:100%;
  display:flex;
  flex-direction:column;
}

/* Title row used by content slides */
.title-row{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:24px;
  margin:8px 0 18px;
}
.slide__title{
  font-size:54px;
  line-height:1;
  letter-spacing:-.02em;
  font-weight:800;
  color:var(--ink);
  margin:0;
}
.slide__title em{
  font-family:var(--font-serif);
  font-style:italic;
  font-weight:500;
  letter-spacing:-.01em;
}
.tag-eff{
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  color:var(--ink);
  background:#ffffff;
  border:1px solid rgba(0,0,0,.15);
  padding:8px 14px;
  border-radius:999px;
  white-space:nowrap;
  box-shadow:0 1px 0 rgba(0,0,0,.05);
}

.lede{
  font-size:16.5px;
  line-height:1.55;
  color:var(--ink-soft);
  max-width:1100px;
  margin:0 0 22px;
}
.lede strong{color:var(--ink); font-weight:700}

.footnote{
  margin-top:auto;
  padding-top:14px;
  font-size:10.5px;
  color:var(--ink-mute);
  line-height:1.5;
  max-width:1200px;
}

/* ============================================================
   SLIDE 1 — COVER
   ============================================================ */
.slide--cover{background:#1a2638; color:#fff}
.cover-bg{
  position:absolute; inset:0;
  background:
    radial-gradient(80% 60% at 20% 70%, rgba(255,255,255,.08), transparent 60%),
    radial-gradient(80% 80% at 80% 20%, rgba(255,255,255,.04), transparent 70%),
    linear-gradient(160deg, #1a2c46 0%, #0c1827 40%, #0a1320 100%);
  z-index:0;
}
.slide--cover .slide__grain{opacity:.35}

.cover-tag{
  position:absolute;
  top:46px; left:56px;
  color:#fff;
  font-size:14px;
  letter-spacing:.02em;
  z-index:3;
}
.cover-center{
  position:absolute;
  top:50%; left:56px;
  transform:translateY(-50%);
  z-index:3;
  max-width:54%;
}
.cover-logo{
  width:520px;
  max-width:80%;
  display:block;
  filter:invert(1) brightness(1.2);
  margin-bottom:36px;
}
.cover-title{
  font-size:74px;
  line-height:.95;
  font-weight:800;
  letter-spacing:-.025em;
  color:#fff;
}
.cover-sub{
  margin-top:14px;
  font-family:var(--font-serif);
  font-style:italic;
  font-weight:500;
  font-size:30px;
  color:#e2c79c;
  letter-spacing:.01em;
}
.cover-confidential{
  margin-top:26px;
  font-size:13px;
  letter-spacing:.32em;
  text-transform:uppercase;
  font-weight:600;
  color:rgba(255,255,255,.65);
  padding-left:36px;
  position:relative;
}
.cover-confidential::before{
  content:""; position:absolute; left:0; top:50%;
  width:24px; height:1px; background:rgba(255,255,255,.45);
}
.cover-foot{
  position:absolute;
  bottom:36px; left:56px;
  color:rgba(255,255,255,.85);
  font-size:14px;
  z-index:3;
}

/* Phone mockup on the right */
.cover-mock{
  position:absolute;
  right:4%;
  bottom:-2%;
  top:6%;
  width:420px;
  z-index:3;
  display:flex;
  align-items:center;
  justify-content:center;
}
.phone{
  position:relative;
  width:330px;
  height:660px;
  background:#fdfbf7;
  border-radius:46px;
  border:8px solid #1f1f1f;
  box-shadow:
    0 30px 80px rgba(0,0,0,.55),
    inset 0 0 0 1px rgba(255,255,255,.1);
  overflow:hidden;
  transform:rotate(2deg) translateY(-10px);
}
.phone__notch{
  position:absolute;
  top:0; left:50%; transform:translateX(-50%);
  width:120px; height:24px;
  background:#1f1f1f;
  border-radius:0 0 14px 14px;
  z-index:3;
}
.phone__bar{
  position:relative;
  padding:36px 14px 10px;
  display:flex; align-items:center; justify-content:space-between;
  font-size:11px; color:#1f1f1f;
  border-bottom:1px solid rgba(0,0,0,.08);
}
.phone__menu{font-size:18px}
.phone__logo{
  font-family:var(--font-serif);
  font-size:22px;
  letter-spacing:.04em;
  font-weight:600;
}
.phone__logo i{font-style:normal; color:#000}
.phone__icons{letter-spacing:.18em; opacity:.7}

.phone__hero{
  position:relative;
  padding:34px 22px 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.6), rgba(255,255,255,.2)),
    linear-gradient(180deg, #d9d3c8 0%, #b8b1a4 100%);
  min-height:380px;
}
.phone__headline{
  font-family:var(--font-serif);
  font-weight:500;
  font-size:54px;
  line-height:.95;
  color:#ffffff;
  letter-spacing:-.01em;
  text-shadow:0 1px 2px rgba(0,0,0,.15);
}
.phone__headline em{font-style:italic}
.phone__copy{
  margin-top:16px;
  color:#fff;
  font-size:12.5px;
  line-height:1.5;
  font-weight:500;
}
.phone__cta{
  position:absolute;
  bottom:30px; left:50%; transform:translateX(-50%);
  background:#fff;
  color:#1f1f1f;
  padding:11px 28px;
  border-radius:999px;
  font-size:12px;
  font-weight:600;
  letter-spacing:.05em;
  box-shadow:0 6px 18px rgba(0,0,0,.18);
}
.phone__features{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:8px;
  padding:14px 10px;
  font-size:9.5px;
  color:#3a3a3a;
  text-align:center;
}
.phone__features div{
  display:flex; flex-direction:column; gap:4px; align-items:center;
  font-weight:500; line-height:1.2;
}
.phone__features span{font-size:14px}

/* ============================================================
   SLIDE 2 — AGENDA
   ============================================================ */
.slide__body--agenda{
  padding-top:120px;
  align-items:center;
}
.agenda-title{
  font-size:96px;
  font-weight:800;
  letter-spacing:-.02em;
  text-align:center;
  margin:0 0 60px;
  color:var(--ink);
}
.agenda-wrap{
  width:100%;
  max-width:1180px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
}

.agenda{
  list-style:none; padding:0; margin:0;
  position:relative;
  display:flex; flex-direction:column; gap:34px;
}
.agenda::before{
  content:"";
  position:absolute;
  top:14px; bottom:14px;
  left:18px;
  width:1px;
  background:rgba(0,0,0,.35);
}
.agenda li{
  position:relative;
  padding-left:60px;
  display:flex; align-items:center;
  font-size:24px;
  font-weight:700;
  color:var(--ink);
  letter-spacing:-.01em;
}
.agenda .dot{
  position:absolute; left:0; top:50%; transform:translateY(-50%);
  width:36px; height:36px;
  border-radius:50%;
  background:var(--c);
  box-shadow:0 0 0 4px rgba(255,255,255,.6), 0 2px 6px rgba(0,0,0,.12);
}
.agenda .num{
  font-family:var(--font-serif);
  font-style:italic;
  font-weight:500;
  font-size:18px;
  color:var(--ink-mute);
  margin-right:14px;
  min-width:30px;
}
.agenda .label{font-weight:700}

.agenda-side{
  position:relative;
  padding:34px;
  background:rgba(255,255,255,.55);
  border:1px solid rgba(0,0,0,.08);
  border-radius:var(--radius-lg);
  backdrop-filter:blur(2px);
}
.badge-pill{
  display:inline-block;
  background:var(--blue-deep);
  color:#fff;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  padding:8px 14px;
  border-radius:999px;
  margin-bottom:24px;
}
.agenda-quote{
  font-family:var(--font-serif);
  font-style:italic;
  font-weight:400;
  font-size:30px;
  line-height:1.25;
  color:var(--ink);
  position:relative;
}
.agenda-quote em{font-weight:600; font-style:italic}
.agenda-quote__mark{
  font-family:var(--font-serif);
  font-size:80px;
  line-height:0;
  position:absolute;
  left:-20px; top:24px;
  color:var(--blue-deep);
  opacity:.4;
}

/* ============================================================
   SLIDE 3 — STRATEGIC OVERVIEW (3 streams)
   ============================================================ */
.streams{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:22px;
  margin-top:6px;
}
.stream{
  background:rgba(255,255,255,.78);
  border:1px solid rgba(0,0,0,.08);
  border-radius:var(--radius);
  padding:24px 22px;
  position:relative;
  display:flex; flex-direction:column;
  box-shadow:0 6px 22px rgba(0,0,0,.05);
}
.stream::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:var(--radius);
  border-top:4px solid var(--accent);
  pointer-events:none;
}
.stream--strategic{--accent:var(--accent-strategic)}
.stream--ongoing  {--accent:var(--accent-ongoing)}
.stream--tactical {--accent:var(--accent-tactical)}

.stream__chip{
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  color:var(--accent);
  margin-bottom:10px;
}
.stream__title{
  font-size:34px;
  font-weight:800;
  letter-spacing:-.02em;
  margin:0 0 12px;
  color:var(--ink);
}
.stream__lead{
  font-size:14px;
  line-height:1.5;
  margin:0 0 14px;
  color:var(--ink-soft);
}
.stream__lead strong{color:var(--ink); font-weight:700}
.stream__points{
  list-style:none; padding:0; margin:0 0 16px;
  display:flex; flex-direction:column; gap:10px;
}
.stream__points li{
  position:relative;
  padding-left:18px;
  font-size:13px;
  line-height:1.5;
  color:var(--ink-soft);
}
.stream__points li::before{
  content:"";
  position:absolute; left:0; top:8px;
  width:8px; height:8px; border-radius:50%;
  background:var(--accent);
  opacity:.85;
}
.stream__points strong{color:var(--ink); font-weight:700}

.stream__metric{
  margin-top:auto;
  padding-top:14px;
  border-top:1px dashed rgba(0,0,0,.18);
  display:flex; flex-direction:column;
}
.metric__big{
  font-size:40px;
  font-weight:800;
  letter-spacing:-.02em;
  line-height:1;
  color:var(--accent);
}
.metric__sub{
  margin-top:4px;
  font-size:11.5px;
  color:var(--ink-mute);
  line-height:1.4;
}

/* ============================================================
   SLIDES 4 & 5 — DEEP DIVES
   ============================================================ */
.dd-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  margin-top:14px;
  flex:1;
  min-height:0;
}
.dd-col{display:flex; flex-direction:column; gap:18px; min-height:0}

.dd-block{
  background:rgba(255,255,255,.78);
  border:1px solid rgba(0,0,0,.08);
  border-radius:var(--radius);
  padding:22px 22px;
  box-shadow:0 4px 18px rgba(0,0,0,.04);
}
.dd-block--terms{background:rgba(255,255,255,.6)}
.dd-block--potential{
  background:linear-gradient(180deg, rgba(13,30,60,.96), rgba(13,30,60,.92));
  color:#f3eee6;
  border-color:rgba(255,255,255,.15);
  height:100%;
  display:flex; flex-direction:column;
}
.dd-block--potential .dd-h{color:#f9e3c2}
.dd-block--potential .dd-text strong{color:#fff}
.dd-block--potential .dd-text{color:rgba(255,255,255,.85)}

.dd-h{
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  color:var(--blue-deep);
  margin:0 0 12px;
}
.dd-sh{
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  margin:18px 0 8px;
  color:#f9e3c2;
}

.dd-text{
  font-size:14px;
  line-height:1.55;
  margin:0 0 14px;
  color:var(--ink-soft);
}
.dd-text--note{font-size:12.5px; opacity:.85; margin-top:14px}
.dd-text strong{color:var(--ink); font-weight:700}

.dd-list{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; gap:8px;
}
.dd-list--tight{gap:5px}
.dd-list li{
  position:relative;
  padding-left:18px;
  font-size:13.5px;
  line-height:1.5;
  color:var(--ink-soft);
}
.dd-list li::before{
  content:""; position:absolute; left:0; top:8px;
  width:6px; height:6px; border-radius:50%;
  background:var(--accent-ongoing);
}
.dd-list strong{color:var(--ink); font-weight:700}
.dd-block--potential .dd-list li{color:rgba(255,255,255,.85)}
.dd-block--potential .dd-list li::before{background:#f9c986}
.dd-block--potential .dd-list strong{color:#fff}

/* Contract terms grid */
.terms-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
.term{
  border:1px solid rgba(0,0,0,.08);
  background:rgba(255,255,255,.6);
  border-radius:12px;
  padding:12px 14px;
  font-size:12.5px;
  line-height:1.45;
  color:var(--ink-soft);
}
.term__h{
  font-size:10.5px;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink);
  margin-bottom:4px;
}
.term strong{color:var(--ink)}

/* Revenue grid (LaaS) */
.revenue-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  margin:6px 0 6px;
}
.rev{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.15);
  border-radius:14px;
  padding:14px 12px;
  display:flex; flex-direction:column; gap:2px;
}
.rev__year{
  font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  color:#f9e3c2; font-weight:700;
}
.rev__amount{
  font-size:28px;
  font-weight:800;
  color:#fff;
  letter-spacing:-.02em;
  line-height:1;
  margin-top:4px;
}
.rev__label{
  font-size:11px;
  color:rgba(255,255,255,.7);
  margin-top:2px;
}
.rev--mid .rev__amount{color:#fce0b1}
.rev--high .rev__amount{color:#f9c986}

.pcii-note{
  margin-top:auto;
  padding-top:14px;
  font-size:12.5px;
  line-height:1.5;
  color:rgba(255,255,255,.85);
  position:relative;
  padding-left:18px;
}
.pcii-note__dot{
  position:absolute; left:0; top:18px;
  width:8px; height:8px; border-radius:50%; background:#7ad08a;
}
.pcii-note strong{color:#fff; font-weight:700}

/* Callout (3rd-party CAC arbitrage) */
.callout{
  margin-top:14px;
  background:linear-gradient(180deg, #fff8ec, #ffe6c4);
  border:1px solid #e9b079;
  border-radius:14px;
  padding:14px 16px;
  font-size:13px;
  color:var(--ink-soft);
  line-height:1.5;
}
.callout__h{
  font-size:10.5px;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:#8a4a14;
  margin-bottom:6px;
}
.callout strong{color:var(--ink)}

/* Partners (3rd-party) */
.partners{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
.partner{
  background:rgba(255,255,255,.6);
  border:1px solid rgba(0,0,0,.1);
  border-radius:12px;
  padding:12px 14px;
}
.partner__name{
  font-size:14px;
  font-weight:700;
  color:var(--ink);
}
.partner__state{
  font-size:12px;
  color:var(--ink-mute);
  margin-top:2px;
  line-height:1.4;
}
.partner--hot{
  background:linear-gradient(180deg, #fff5e1, #ffe0b3);
  border-color:#e9b079;
}
.partner--hot .partner__state{color:#8a4a14; font-weight:600}

/* Bridge waterfall (3rd-party potential) */
.bridge{
  display:flex; flex-direction:column; gap:10px;
  margin-top:4px;
}
.bridge__row{
  display:grid;
  grid-template-columns:160px 1fr 90px;
  align-items:center;
  gap:10px;
  font-size:12.5px;
  color:rgba(255,255,255,.85);
}
.bridge__l{font-weight:500}
.bridge__bar{
  height:14px;
  border-radius:8px;
  background:linear-gradient(90deg, rgba(249,201,134,.9), rgba(249,201,134,.5));
  width:var(--w);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.12);
}
.bridge__bar--mid{background:linear-gradient(90deg, #fce0b1, rgba(252,224,177,.4))}
.bridge__bar--neg{background:linear-gradient(90deg, #d96a6a, rgba(217,106,106,.3))}
.bridge__bar--good{background:linear-gradient(90deg, #7ad08a, rgba(122,208,138,.3))}
.bridge__v{
  text-align:right;
  font-weight:800;
  color:#fff;
  font-size:14px;
  letter-spacing:-.01em;
}
.bridge__row--total{padding-top:8px; border-top:1px dashed rgba(255,255,255,.25)}
.bridge__row--total .bridge__l{color:#fff; font-weight:700}

.kpi-pair{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:16px;
}
.kpi{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.2);
  border-radius:14px;
  padding:14px;
}
.kpi__v{
  display:block;
  font-size:32px;
  font-weight:800;
  color:#7ad08a;
  letter-spacing:-.02em;
  line-height:1;
}
.kpi__l{
  display:block;
  margin-top:4px;
  font-size:11.5px;
  color:rgba(255,255,255,.7);
  line-height:1.35;
}
.kpi--alt .kpi__v{color:#f5b97a}

/* ============================================================
   SLIDE 6 — THANK YOU
   ============================================================ */
/* Thank-you uses flex centering, but only when active — otherwise the
   base `.slide { display:none }` rule must win. */
.slide--thanks.is-active{display:flex; align-items:center; justify-content:center; flex-direction:column}
.thanks-mark{
  position:relative; z-index:3;
  margin-bottom:30px;
}
.thanks-mark__g{
  width:90px; height:90px;
  color:var(--ink);
  opacity:.92;
}
.thanks-mark__g svg{width:100%; height:100%}
.thanks-title{
  position:relative; z-index:3;
  font-size:120px;
  font-weight:800;
  letter-spacing:-.03em;
  margin:0;
  color:var(--ink);
}
.thanks-sub{
  position:relative; z-index:3;
  margin-top:20px;
  font-family:var(--font-serif);
  font-style:italic;
  font-size:28px;
  color:var(--ink-soft);
  font-weight:500;
}
.thanks-logo-bg{
  position:absolute;
  left:0; right:0; bottom:-80px;
  text-align:center;
  font-family:var(--font-serif);
  font-size:520px;
  font-weight:500;
  letter-spacing:-.02em;
  color:transparent;
  -webkit-text-stroke:2px rgba(189,140,210,.35);
  z-index:1;
  user-select:none;
  pointer-events:none;
  line-height:1;
}
.thanks-foot{
  position:absolute;
  bottom:24px; left:0; right:0;
  text-align:center;
  font-size:12px;
  color:var(--ink-mute);
  letter-spacing:.08em;
  z-index:3;
}

/* ============================================================
   NAV CONTROLS
   ============================================================ */
.nav{
  position:fixed;
  top:50%; transform:translateY(-50%);
  background:rgba(0,0,0,.35);
  color:#fff;
  border:none;
  width:44px; height:44px;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer;
  z-index:1000;
  transition:background .2s, transform .15s;
  backdrop-filter:blur(6px);
}
.nav:hover{background:rgba(0,0,0,.6); transform:translateY(-50%) scale(1.05)}
.nav--prev{left:18px}
.nav--next{right:18px}

.progress{
  position:fixed; top:0; left:0; right:0;
  height:3px; z-index:1000;
  background:rgba(0,0,0,.08);
}
.progress__bar{
  height:100%;
  background:linear-gradient(90deg, #e9b079, #c97a3e);
  width:0;
  transition:width .35s ease;
}

.counter{
  position:fixed;
  bottom:18px; right:24px;
  z-index:1000;
  font-size:12px;
  letter-spacing:.05em;
  color:rgba(0,0,0,.55);
  background:rgba(255,255,255,.7);
  padding:6px 12px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.08);
  font-variant-numeric:tabular-nums;
}
.slide--cover ~ .counter, .slide--thanks ~ .counter{}
.counter__sep{margin:0 4px; opacity:.5}

/* ============================================================
   PRINT — produce a clean PDF if exported
   ============================================================ */
@media print{
  body{background:#fff}
  .nav, .progress, .counter{display:none !important}
  .slide{display:block !important; page-break-after:always; position:relative; height:100vh}
}

/* ============================================================
   SAFETY — small screens (deck is designed for 16:9 desktop)
   ============================================================ */
@media (max-width:1100px){
  .slide__body{padding:90px 32px 36px}
  .streams{grid-template-columns:1fr; gap:14px}
  .dd-grid{grid-template-columns:1fr}
  .agenda-wrap{grid-template-columns:1fr; gap:30px}
  .cover-mock{display:none}
  .cover-center{max-width:90%}
  .cover-title{font-size:54px}
  .agenda-title{font-size:64px}
  .slide__title{font-size:36px}
  .thanks-title{font-size:72px}
  .thanks-logo-bg{font-size:280px; bottom:-40px}
}
