/* ============================================================
   MVNO — инвестиционная презентация (idea-mvno-1). Концепт «Vector».
   Фокус: РФ → Грузия → Сербия · российский контроль · independent MVNO.
   Чистый фин-минимализм · прохладный фон · indigo-сигнал.
   ============================================================ */

:root {
  --bg:        #FBFCFE;   /* прохладный почти-белый */
  --bg-2:      #F1F4F9;   /* панель/зебра */
  --card:      #FFFFFF;
  --ink:       #111826;   /* near-black navy */
  --ink-soft:  #45506180; /* перекрыт ниже */
  --ink-soft:  #4A5568;   /* вторичный текст */
  --ink-faint: #8A94A6;   /* подписи */
  --line:      #E2E8F0;   /* волосяная линия */
  --line-soft: #EEF2F7;

  --accent:    #2E5BFF;   /* indigo — primary */
  --accent-dk: #1E40D8;
  --teal:      #0E9F6E;   /* позитив/подтверждено */
  --amber:     #D98A12;   /* внимание/риск-средний */
  --risk:      #E0483D;   /* риск/негатив */

  --dark-bg:   #0E1726;   /* deep navy */
  --dark-2:    #16223A;   /* тёмная панель */
  --dark-line: #26344E;
  --dark-text: #EEF2FA;
  --dark-soft: #9FB0C9;
  --dark-acc:  #6E8CFF;   /* indigo на тёмном */

  --sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;

  --frame: clamp(24px, 3.6vw, 64px);
  --maxw: 1300px;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html, body { height: 100%; }

body {
  background: var(--dark-bg);
  color: var(--ink);
  font-family: var(--sans);
  font-size: clamp(14px, 1.02vw, 18px);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow: hidden;
}

/* ---------- Каркас ---------- */
.deck { position: fixed; inset: 0; }

.slide {
  position: absolute; inset: 0;
  display: none;
  flex-direction: column;
  padding: var(--frame);
  background: var(--bg);
  background-image: radial-gradient(var(--line) 0.8px, transparent 0.9px);
  background-size: 28px 28px;
  background-position: -14px -14px;
  overflow: hidden;
}
.slide.is-active { display: flex; }

/* Тёмные слайды */
.slide--dark {
  background: var(--dark-bg);
  color: var(--dark-text);
  background-image: radial-gradient(var(--dark-line) 0.8px, transparent 0.9px);
  background-size: 28px 28px;
}
.slide--dark .stitle { color: var(--dark-text); }
.slide--dark .lead { color: var(--dark-soft); }
.slide--dark .content, .slide--dark .content p, .slide--dark .content li { color: var(--dark-soft); }
.slide--dark .content strong { color: #fff; }
.slide--dark .kicker { color: var(--dark-acc); }
.slide--dark .pageno { color: #62718C; }
.slide--dark .rule { background: var(--dark-acc); }
.slide--dark .foot { color: #62718C; border-color: var(--dark-line); }
.slide--dark .content li::before { color: var(--dark-acc); }
.slide--dark .content a { color: var(--dark-acc); }
.slide--dark .visual { background: var(--dark-2); border-color: var(--dark-line); }
.slide--dark .visual .vlabel { color: var(--dark-acc); }
.slide--dark table { color: var(--dark-text); }
.slide--dark thead th { color: var(--dark-acc); border-color: var(--dark-text); }
.slide--dark td, .slide--dark th { border-color: var(--dark-line); }
.slide--dark tbody tr:nth-child(even) { background: rgba(255,255,255,.03); }
.slide--dark .card { background: var(--dark-2); border-color: var(--dark-line); }
.slide--dark .card h4 { color: #fff; }

/* ---------- Шапка ---------- */
.head { display: flex; justify-content: space-between; align-items: baseline; gap: 16px; flex: 0 0 auto; }
.kicker {
  font-family: var(--mono); font-size: clamp(10px, .8vw, 12.5px);
  letter-spacing: .22em; text-transform: uppercase; color: var(--accent-dk);
  font-weight: 600; display: inline-flex; align-items: center; gap: 11px;
}
.kicker .bars { display: inline-flex; align-items: flex-end; gap: 2px; height: 12px; }
.kicker .bars i { width: 3px; background: var(--accent); display: block; }
.kicker .bars i:nth-child(1){height:4px}
.kicker .bars i:nth-child(2){height:7px}
.kicker .bars i:nth-child(3){height:10px}
.kicker .bars i:nth-child(4){height:13px; opacity:.4}
.slide--dark .kicker .bars i { background: var(--dark-acc); }
.pageno { font-family: var(--mono); font-size: clamp(10px,.8vw,12.5px); color: var(--ink-faint); letter-spacing: .12em; }

/* ---------- Тело ---------- */
.body {
  flex: 1 1 auto; display: flex; flex-direction: column; justify-content: flex-start;
  min-height: 0; max-width: var(--maxw); width: 100%; margin: 0 auto;
  padding: clamp(12px, 2.2vh, 28px) 0; overflow: hidden;
}

/* Две колонки: контент слева (скролл), график справа (всегда виден) */
.cols { display: flex; gap: clamp(18px, 2.6vw, 44px); align-items: stretch; flex: 1 1 auto; min-height: 0; margin-top: 6px; }
.col-main { flex: 1 1 44%; min-width: 0; overflow-y: auto; overflow-x: auto; padding-right: 8px; }
.col-main::-webkit-scrollbar { width: 7px; height: 7px; }
.col-main::-webkit-scrollbar-thumb { background: var(--line); border-radius: 7px; }
.col-side { flex: 1 1 56%; min-width: 0; display: flex; align-items: center; }
.col-side .visual { margin: 0; width: 100%; }
.cols:only-child, .col-main:only-child { flex-basis: 100%; }
@media (max-width: 900px) { .cols { flex-direction: column; } .col-main, .col-side { flex-basis: auto; } }

.stitle {
  font-weight: 800; font-size: clamp(24px, 3.5vw, 46px);
  line-height: 1.05; letter-spacing: -0.02em; color: var(--ink); flex: 0 0 auto;
}
.lead {
  font-size: clamp(15px, 1.4vw, 22px); color: var(--ink-soft);
  max-width: 64ch; line-height: 1.45; font-weight: 500; margin-top: 14px;
}
.lead b, .lead strong { color: var(--accent-dk); font-weight: 700; }
.slide--dark .lead b, .slide--dark .lead strong { color: var(--dark-acc); }
.rule { height: 3px; width: 56px; background: var(--accent); border: 0; margin: 18px 0; border-radius: 3px; }

/* ---------- Контент (рендер markdown) ---------- */
.content { font-size: clamp(13px, 1.04vw, 16.5px); color: var(--ink-soft); }
.content > *:first-child { margin-top: 0; }
.content p { margin: .55em 0; }
.content strong { font-weight: 700; color: var(--ink); }
.content em { font-style: italic; }
.content code {
  font-family: var(--mono); font-size: .86em; background: var(--bg-2);
  padding: 1px 6px; border-radius: 4px; color: var(--accent-dk);
}
.slide--dark .content code { background: var(--dark-2); color: var(--dark-acc); }

.content ul, .content ol { list-style: none; margin: .4em 0; padding: 0; }
.content li { position: relative; padding-left: 22px; margin: 7px 0; line-height: 1.45; }
.content ul > li::before { content: "—"; position: absolute; left: 0; color: var(--accent); font-weight: 700; }
.content ol { counter-reset: li; }
.content ol > li { counter-increment: li; }
.content ol > li::before {
  content: counter(li); position: absolute; left: 0; top: .05em;
  font-family: var(--mono); font-size: .76em; font-weight: 700; color: var(--accent);
}
/* вложенные списки */
.content li ul, .content li ol { margin: 5px 0 2px; }
.content li li { font-size: .96em; }
.content li li::before { color: var(--ink-faint); }

/* ---------- Таблицы ---------- */
.content table { width: 100%; border-collapse: collapse; font-size: clamp(11px,.95vw,14.5px); margin: 12px 0; }
.content thead th {
  font-family: var(--mono); font-size: clamp(10px,.76vw,12px); letter-spacing: .06em; text-transform: uppercase;
  color: var(--accent-dk); text-align: left; font-weight: 600; padding: 8px 11px 9px; border-bottom: 1.5px solid var(--ink);
}
.content td, .content th { padding: 8px 11px; vertical-align: top; border-bottom: 1px solid var(--line); }
.content tbody tr:nth-child(even) { background: rgba(46,91,255,.03); }
.content td:first-child { color: var(--ink); font-weight: 600; }
.content table .num, .content td { font-variant-numeric: tabular-nums; }

/* ---------- Визуал: SVG-график (описание скрыто, показ по «S») ---------- */
.visual { margin: 16px 0 0; border: 1px solid var(--line); background: var(--card); border-radius: 8px; padding: 10px 12px; }
.visual .chart { width: 100%; }
.visual .chart svg { width: 100%; height: auto; display: block; }
.visual .vdesc { display: none; }
.visual .vlabel {
  display: block; font-family: var(--mono); font-size: 10px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--accent-dk); margin-bottom: 5px; font-weight: 600;
}
body.show-notes .slide.is-active .visual .vdesc {
  display: block; margin-top: 12px; padding-top: 12px; border-top: 1px dashed var(--line);
  font-size: clamp(12px,.92vw,14px); color: var(--ink-soft);
}
.slide--dark .visual .vdesc { color: var(--dark-soft); border-color: var(--dark-line); }

/* ---------- Карточки (адаптация под аудиторию) ---------- */
.cards3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 14px; }
@media (max-width: 900px){ .cards3 { grid-template-columns: 1fr; } }
.card {
  background: var(--card); border: 1px solid var(--line); border-top: 3px solid var(--accent);
  border-radius: 4px; padding: clamp(14px,1.3vw,20px);
}
.card h4 { font-size: clamp(14px,1.1vw,17px); font-weight: 800; margin-bottom: 8px; color: var(--ink); letter-spacing: -.01em; }
.card .content { font-size: clamp(11.5px,.92vw,13.5px); }

/* ---------- Подвал ---------- */
.foot {
  flex: 0 0 auto; display: flex; justify-content: space-between; align-items: center;
  font-family: var(--mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--ink-faint); border-top: 1px solid var(--line); padding-top: 11px; margin-top: 10px;
}
.foot .src { text-transform: none; letter-spacing: .02em; }

/* ---------- Титул (cover) ---------- */
.slide--cover .body { justify-content: center; }
.slide--cover .stitle { font-size: clamp(38px, 6.4vw, 92px); line-height: .98; letter-spacing: -.03em; }
.slide--cover .lead { font-size: clamp(17px,1.7vw,26px); max-width: 46ch; }
.slide--cover .content { margin-top: 18px; }

/* ---------- Спикер-ноты ---------- */
.notes { display: none; }
body.show-notes .slide.is-active .notes {
  display: block; position: fixed; left: 0; right: 0; bottom: 0; z-index: 60;
  max-height: 42vh; overflow-y: auto;
  background: #0B1220; color: #D7E0EE; border-top: 2px solid var(--accent);
  padding: 16px clamp(20px,4vw,60px); font-size: 14px; line-height: 1.5;
  box-shadow: 0 -12px 40px rgba(0,0,0,.4);
}
.notes b { display: block; font-family: var(--mono); font-size: 10.5px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--dark-acc); margin-bottom: 7px; }

/* ---------- Прогресс / навигация ---------- */
.progress { position: fixed; top: 0; left: 0; right: 0; height: 3px; display: flex; gap: 2px; z-index: 50; }
.progress i { flex: 1; background: rgba(17,24,38,.10); transition: background .3s; }
.progress i.done { background: var(--accent); }
body.on-dark .progress i { background: rgba(255,255,255,.12); }
body.on-dark .progress i.done { background: var(--dark-acc); }

.nav { position: fixed; bottom: 14px; right: 16px; display: flex; align-items: center; gap: 8px; z-index: 50; }
.nav .counter { font-family: var(--mono); font-size: 11px; letter-spacing: .12em; color: var(--ink-faint); margin-right: 4px; }
body.on-dark .nav .counter { color: #7C8AA3; }
.nav button {
  font-family: var(--mono); font-size: 13px; min-width: 34px; height: 34px; padding: 0 10px;
  border: 1px solid var(--line); background: rgba(255,255,255,.75); color: var(--ink);
  border-radius: 50px; cursor: pointer; backdrop-filter: blur(4px); transition: all .15s;
}
.nav button:hover { background: var(--accent); color: #fff; border-color: var(--accent); }
body.on-dark .nav button { background: rgba(22,34,58,.7); color: var(--dark-text); border-color: var(--dark-line); }
body.on-dark .nav button:hover { background: var(--dark-acc); color: var(--dark-bg); }

.hint { position: fixed; bottom: 16px; left: 16px; z-index: 50; font-family: var(--mono); font-size: 10px;
  letter-spacing: .08em; text-transform: uppercase; color: var(--ink-faint); opacity: .75; }
body.on-dark .hint { color: #62718C; }

.edge { position: fixed; top: 0; bottom: 56px; width: 13%; z-index: 20; cursor: pointer; }
.edge.l { left: 0; } .edge.r { right: 0; }

/* ---------- Появление ---------- */
.reveal { opacity: 0; transform: translateY(13px); }
.is-active .reveal { animation: rise .58s cubic-bezier(.2,.7,.2,1) forwards; animation-delay: calc(var(--i, 0) * 80ms); }
@keyframes rise { to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce){ .reveal { opacity: 1; transform: none; animation: none; } }

/* ---------- Печать → PDF ---------- */
@media print {
  @page { size: 1280px 720px; margin: 0; }
  body { overflow: visible; background: #fff; }
  .deck { position: static; }
  .slide {
    display: flex !important; position: relative; inset: auto;
    width: 1280px; min-height: 720px; page-break-after: always; break-after: page; overflow: visible;
  }
  .body { overflow: visible; }
  .reveal { opacity: 1 !important; transform: none !important; animation: none !important; }
  .progress, .nav, .hint, .edge, .notes { display: none !important; }
}
