/* Landing «Визуальный конвейер эксперта» — кастомные стили поверх tokens.css */

/* ---- NAV ---- */
.vk-nav-bar {
  position: sticky; top: 0; z-index: 50;
  background: #171B24;
  border-bottom: 1px solid var(--color-border);
}
.vk-nav {
  display: flex; align-items: center; justify-content: space-between; gap: 2rem;
  max-width: var(--container-max);
  margin: 0 auto; padding: 5px 1rem;
}
.vk-logo { display: flex; align-items: center; gap: 0.625rem; flex-shrink: 0; min-width: 0; }
.vk-logo-img { height: 62px; width: auto; max-width: 100%; display: block; flex-shrink: 0; object-fit: contain; }
.vk-nav-links { display: flex; gap: 1.75rem; font-size: 0.95rem; color: var(--color-text-light); }
.vk-nav-links a:hover { color: var(--color-white); }
.vk-nav-cta { padding: 0.5rem 1.5rem; font-size: 0.875rem; }
@media (max-width: 980px) { .vk-nav-links { display: none; } }
@media (max-width: 600px) {
  .vk-logo-img { height: 44px; }
  .vk-nav { gap: 0.75rem; padding: 5px 0.75rem; }
}

/* ---- HERO ---- */
.vk-hero { padding-top: 6rem; padding-bottom: 7rem; }
.vk-hero-chips {
  display: flex; flex-wrap: wrap; gap: 0.5rem; justify-content: center;
  margin: 0 0 2.25rem;
}
.vk-chip--hero {
  background: rgba(20, 20, 35, 0.6);
  border: 1px solid #2d2d3f;
  color: #d4d4d8;
  font-size: 0.8125rem; font-weight: 500;
  padding: 0.4rem 0.95rem;
  border-radius: 9999px;
  letter-spacing: 0;
}
.vk-hero-text { max-width: 1000px; margin: 0 auto; text-align: center; }
.vk-hero-title {
  font-size: clamp(2.25rem, 5.4vw, 4.5rem);
  letter-spacing: -0.03em; line-height: 1.06; font-weight: 800;
  text-wrap: balance; margin: 0;
  color: #fff;
}
.vk-w { color: #fff; }
.vk-grad-purple, .vk-grad-pink, .vk-grad-cyan, .vk-grad-neon {
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.vk-grad-purple { background-image: linear-gradient(135deg, #a78bfa, #8b5cf6); }
.vk-grad-pink { background-image: linear-gradient(135deg, #f472b6, #ec4899); }
.vk-grad-cyan { background-image: linear-gradient(135deg, #22d3ee, #06b6d4); }
.vk-grad-neon { background-image: linear-gradient(135deg, #a78bfa 0%, #ec4899 50%, #22d3ee 100%); font-weight: 600; }
.vk-hero-sub {
  max-width: 700px; margin: 2.25rem auto 0;
  color: #d4d4d8; font-size: clamp(1rem, 1.5vw, 1.35rem); line-height: 1.5;
  font-weight: 400;
}
.vk-hero-subsub {
  max-width: 600px; margin: 1.125rem auto 0;
  color: #a1a1aa; font-size: 1.0625rem; line-height: 1.55;
}
.vk-cta-row--center { justify-content: center; margin-top: 0; gap: 1rem; }
.vk-hero-cta-block { margin-top: 4.5rem; text-align: center; }
.vk-hero-finemeta { color: #71717a; font-size: 0.8125rem; margin-top: 1.125rem; }

/* hero gallery */
.vk-hero-gallery-v3 {
  margin-top: 5.5rem;
  max-width: 1240px; margin-left: auto; margin-right: auto;
  display: flex; flex-direction: column; gap: 1rem;
}
.vk-hg-row {
  display: grid;
  gap: 1rem;
  align-items: stretch;
}
.vk-hg-row--lr { grid-template-columns: 4fr 8fr; }
.vk-hg-row--rl { grid-template-columns: 8fr 4fr; }
.vk-hg-row > .vk-gx-card { height: 100%; }
.vk-hg-bottom { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }

@media (max-width: 880px) {
  .vk-hero { padding-top: 4rem; padding-bottom: 4.5rem; }
  .vk-hero-cta-block { margin-top: 3rem; }
  .vk-hero-gallery-v3 { margin-top: 3.5rem; }
  .vk-cta-row--center { flex-direction: column; align-items: stretch; }
  .vk-hg-row--lr,
  .vk-hg-row--rl { grid-template-columns: 1fr; }
  .vk-hg-bottom { grid-template-columns: 1fr; }
  /* Follow-карточки на мобильном теряют контекст высоты от лид-пары — задаём собственный aspect-ratio */
  .vk-gx-card.is-follow .vk-gx-img-wrap {
    flex: none !important;
    min-height: 0 !important;
  }
  .vk-gx-card--b .vk-gx-img-wrap { aspect-ratio: 16 / 9; }
  .vk-gx-card--d .vk-gx-img-wrap { aspect-ratio: 9 / 16; }
}

.vk-gx-cta {
  display: inline-flex; align-items: center; gap: 0.35rem;
  margin-top: 0.5rem;
  font-size: 0.8125rem; font-weight: 600;
  background: linear-gradient(135deg, #a78bfa, #22d3ee);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.vk-gx-cap {
  display: flex; flex-direction: column; gap: 0.35rem;
  padding: 0.5rem 0.25rem 0.25rem;
}
.vk-gx-chip {
  align-self: flex-start;
  font-size: 0.625rem; padding: 0.25rem 0.55rem; border-radius: 9999px;
  background: rgba(139,92,246,0.12); border: 1px solid rgba(139,92,246,0.25);
  color: #c4b5fd; letter-spacing: 0.1em; font-weight: 700;
}
.vk-gx-title { color: #fff; font-weight: 500; font-size: 0.9375rem; line-height: 1.4; }

.vk-gx-card {
  position: relative; margin: 0;
  border-radius: 1.25rem;
  background: rgba(20, 20, 35, 0.7);
  border: 1px solid var(--color-border-light);
  backdrop-filter: blur(10px);
  padding: 0.75rem;
  display: flex; flex-direction: column; gap: 0.5rem;
  overflow: hidden;
  transform: perspective(900px) rotateX(var(--rx, 0deg)) rotateY(var(--ry, 0deg));
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease, translate 0.3s ease;
}
.vk-gx-card:hover {
  translate: 0 -4px;
  border-color: rgba(139, 92, 246, 0.4);
  box-shadow: 0 12px 32px rgba(139, 92, 246, 0.25), 0 0 0 1px rgba(139, 92, 246, 0.4);
}
.vk-gx-img-wrap {
  position: relative; width: 100%;
  border-radius: 0.75rem; overflow: hidden;
  background: #0a0a1a;
}
.vk-gx-img-wrap img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.vk-gx-glow {
  position: absolute; inset: 0; pointer-events: none; opacity: 0;
  transition: opacity 0.3s ease;
  background: radial-gradient(250px circle at var(--mx, 50%) var(--my, 50%),
    rgba(139, 92, 246, 0.35), rgba(236, 72, 153, 0.18) 40%, transparent 70%);
  z-index: 1;
}
.vk-changes-sub {
  max-width: 800px; font-size: clamp(1.125rem, 1.4vw, 1.25rem);
  color: #D4D4D8;
}
.vk-changes-sub em {
  font-style: normal; color: #fff; font-weight: 500;
}

/* format icon + chip tooltips */
.vk-format-head { display: flex; align-items: center; gap: 1.125rem; margin-bottom: 1rem; }
.vk-format-head--v3 { gap: 1.625rem; margin-bottom: 2.25rem; align-items: center; }
.vk-format-head-text { display: flex; flex-direction: column; gap: 0.1875rem; min-width: 0; }
.vk-format-head-text > .vk-format-title { line-height: 1; margin-bottom: 0.375rem; }
.vk-format-head-text > .vk-format-subtitle { line-height: 1.15; }
.vk-format-icon--xl { width: 104px; height: 104px; padding: 26px; border-radius: 22px; background: rgba(20,20,35,0.7); }
.vk-format-icon--xl svg { width: 52px; height: 52px; stroke-width: 2; }
.vk-format-icon--xl.vk-format-icon--purple { box-shadow: inset 0 0 28px rgba(139,92,246,0.18); }
.vk-format-icon--xl.vk-format-icon--pink   { box-shadow: inset 0 0 28px rgba(236,72,153,0.18); }
.vk-format-icon--xl.vk-format-icon--cyan   { box-shadow: inset 0 0 28px rgba(6,182,212,0.18); }
.vk-format-num-label { font-size: 1.0625rem; color: #a1a1aa; font-weight: 600; letter-spacing: 0.05em; }
.vk-format-title { font-size: clamp(1.875rem, 3.2vw, 2.625rem); font-weight: 800; color: #fff; line-height: 1.02; margin: 0; letter-spacing: -0.02em; }
.vk-format-subtitle { font-size: 1.25rem; font-weight: 500; line-height: 1.2; margin: 0; }
.vk-format-subtitle--purple { color: #C4B5FD; }
.vk-format-subtitle--pink   { color: #F9A8D4; }
.vk-format-subtitle--cyan   { color: #67E8F9; }
@media (max-width: 700px) {
  .vk-format-icon--xl { width: 64px; height: 64px; padding: 14px; border-radius: 14px; }
  .vk-format-icon--xl svg { width: 32px; height: 32px; }
  .vk-format-head--v3 { gap: 1rem; margin-bottom: 1.75rem; }
}
.vk-case-strip--v2 { padding: 1.75rem; border-radius: 1.125rem; }
.vk-case-strip-dot { color: #6b7280; }
.vk-case-strip--purple .vk-case-strip-meta svg { color: #A78BFA; }
.vk-case-strip--pink   .vk-case-strip-meta svg { color: #F472B6; }
.vk-case-strip--cyan   .vk-case-strip-meta svg { color: #22D3EE; }
.vk-case-strip-meta { display: flex; align-items: center; gap: 0.625rem; flex-wrap: wrap; }
.vk-case-strip-meta span { display: inline-flex; align-items: center; gap: 0.4rem; }
.vk-chip--more { opacity: 0.55; border-style: dashed !important; }
.vk-set-grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
.vk-set-card { padding: 2rem 2rem 2rem; }
.vk-set-art .vk-change-body { gap: 0.9rem; }
.vk-set-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 56px; height: 56px; border-radius: 14px; margin-bottom: 0.5rem;
  background: rgba(139, 92, 246, 0.14); color: #C4B5FD;
  border: 1px solid rgba(139, 92, 246, 0.28);
}
.vk-set-icon--purple { background: rgba(139, 92, 246, 0.14); color: #C4B5FD; border-color: rgba(139, 92, 246, 0.28); }
.vk-set-icon--pink   { background: rgba(236, 72, 153, 0.14); color: #F9A8D4; border-color: rgba(236, 72, 153, 0.28); }
.vk-set-icon--cyan   { background: rgba(6, 182, 212, 0.14);  color: #67E8F9; border-color: rgba(6, 182, 212, 0.28); }
.vk-set-tags { display: flex; flex-wrap: wrap; gap: 0.45rem; margin-top: 0.5rem; }
.vk-set-foot {
  text-align: center; max-width: 760px; margin: 2rem auto 0;
  font-size: 1.0625rem; color: #D4D4D8; font-weight: 500;
}
.vk-set-foot strong { color: #fff; }
.vk-format-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 60px; height: 60px;
  padding: 15px;
  border-radius: 15px;
  background: linear-gradient(135deg, #1A1A2E, #0F0F1A);
  border: 1px solid transparent;
  background-origin: border-box;
  background-clip: padding-box, border-box;
  flex-shrink: 0;
}
.vk-format-icon svg { stroke-width: 1.75; }
.vk-format-icon--purple { color: #A78BFA; background-image: linear-gradient(135deg, #1A1A2E, #0F0F1A), linear-gradient(135deg, rgba(139,92,246,0.5), rgba(139,92,246,0.15)); }
.vk-format-icon--pink   { color: #F472B6; background-image: linear-gradient(135deg, #1A1A2E, #0F0F1A), linear-gradient(135deg, rgba(236,72,153,0.5), rgba(236,72,153,0.15)); }
.vk-format-icon--cyan   { color: #22D3EE; background-image: linear-gradient(135deg, #1A1A2E, #0F0F1A), linear-gradient(135deg, rgba(6,182,212,0.5),  rgba(6,182,212,0.15)); }

.vk-chip--hov { position: relative; cursor: default; }
.vk-chip--hov:hover, .vk-chip--hov:focus-visible { color: #fff; border-color: rgba(255,255,255,0.3); }
.vk-chip-pop {
  position: absolute; left: 50%; bottom: calc(100% + 10px);
  transform: translateX(-50%) translateY(4px);
  width: 240px; height: 320px;
  background: #0e0e1a;
  border-radius: 16px;
  padding: 12px;
  border: 1px solid transparent;
  background-image: linear-gradient(#0e0e1a, #0e0e1a), linear-gradient(135deg, #8B5CF6, #22D3EE);
  background-origin: border-box; background-clip: padding-box, border-box;
  box-shadow: 0 12px 32px rgba(0,0,0,0.6);
  display: flex; flex-direction: column; gap: 8px;
  opacity: 0; pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
  z-index: 50;
}
.vk-chip--hov:hover .vk-chip-pop, .vk-chip--hov:focus-visible .vk-chip-pop {
  opacity: 1; transform: translateX(-50%) translateY(0);
}
.vk-chip-pop-tag {
  font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase;
  color: #a1a1aa; font-weight: 600;
}
.vk-chip-pop-img {
  flex: 1; border-radius: 10px;
  background: linear-gradient(135deg, rgba(139,92,246,0.15), rgba(34,211,238,0.1));
  display: flex; align-items: center; justify-content: center;
  color: #71717a; font-size: 12px; text-align: center; padding: 16px;
}
.vk-chip--more {
  background: transparent;
  color: #d4d4d8; font-weight: 500;
  border: 1px solid transparent;
  background-image: linear-gradient(#0a0a14, #0a0a14), linear-gradient(135deg, #8B5CF6, #22D3EE);
  background-origin: border-box; background-clip: padding-box, border-box;
}

.vk-case-strip--v2 {
  display: flex; flex-direction: column; gap: 0.625rem;
  padding: 1.25rem 1.25rem 1.125rem;
  background: linear-gradient(135deg, rgba(139,92,246,0.08), rgba(34,211,238,0.05));
  border: 1px solid rgba(139,92,246,0.2);
  border-radius: 0.875rem;
}
.vk-case-strip-title {
  font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
  color: #A78BFA; font-weight: 700;
}
.vk-case-strip-text {
  margin: 0; color: #D4D4D8; font-size: 0.9375rem; line-height: 1.55;
}
.vk-case-strip--v2 .vk-case-strip-meta { gap: 1.25rem; color: #fff; }
.vk-case-strip--v2 .vk-case-strip-meta span { display: inline-flex; align-items: center; gap: 0.4rem; color: #d4d4d8; }
.vk-case-strip--v2 .vk-case-strip-meta b { color: #fff; }
.vk-case-strip-meta span svg { vertical-align: -2px; }

/* change cards with bg illustration */
.vk-changes { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1.25rem; }
@media (max-width: 880px) { .vk-changes { grid-template-columns: 1fr; } }
.vk-change-card {
  position: relative; overflow: hidden;
  border-radius: 1.25rem;
  background: #0e0e1a;
  border: 1px solid var(--color-border-light);
  min-height: 320px;
  display: flex;
  isolation: isolate;
  transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}
.vk-change-card:hover { transform: translateY(-4px); }
.vk-change-card--purple:hover { border-color: rgba(139,92,246,0.45); box-shadow: 0 12px 32px rgba(139,92,246,0.2); }
.vk-change-card--pink:hover { border-color: rgba(236,72,153,0.45); box-shadow: 0 12px 32px rgba(236,72,153,0.2); }
.vk-change-card--cyan:hover { border-color: rgba(6,182,212,0.45); box-shadow: 0 12px 32px rgba(6,182,212,0.2); }

.vk-change-bg { position: absolute; inset: 0; opacity: 0.3; z-index: 0; }
.vk-change-bg svg { width: 100%; height: 100%; display: block; }
.vk-change-overlay {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(to top, rgba(14,14,26,0.95) 0%, rgba(14,14,26,0.7) 50%, rgba(14,14,26,0.35) 100%);
}
.vk-change-num {
  position: absolute; top: 0.75rem; right: 1.25rem; z-index: 2;
  font-family: var(--font-display, inherit);
  font-size: clamp(7rem, 10vw, 9.5rem);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.04em;
  pointer-events: none;
  user-select: none;
}
.vk-change-card--purple .vk-change-num { color: #8B5CF6; opacity: 0.11; }
.vk-change-card--pink .vk-change-num { color: #EC4899; opacity: 0.11; }
.vk-change-card--cyan .vk-change-num { color: #06B6D4; opacity: 0.11; }
.vk-change-body {
  position: relative; z-index: 3;
  padding: 2.25rem;
  display: flex; flex-direction: column; justify-content: flex-end;
  flex: 1;
}
.vk-change-title {
  color: #fff; font-size: clamp(1.375rem, 1.6vw, 1.5rem);
  font-weight: 700; line-height: 1.2; letter-spacing: -0.01em;
  margin: 0 0 1rem;
}
.vk-change-text {
  color: #D4D4D8; font-size: 0.9375rem; line-height: 1.55;
  margin: 0;
}

@media (hover: none) {
  .vk-gx-card:hover { translate: none; box-shadow: none; }
  .vk-gx-card { transform: none !important; }
}
@media (max-width: 880px) {
  .vk-gx-card { aspect-ratio: auto; }
}
.vk-hero-grid { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: 4rem; align-items: center; }
.vk-hero-chips { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 0.5rem; }
.vk-chip--hero {
  background: linear-gradient(to right, rgba(139,92,246,0.12), rgba(6,182,212,0.08));
  border: 1px solid rgba(139,92,246,0.3);
  color: var(--color-white);
  font-weight: 600;
  padding: 0.4rem 0.85rem;
}
.vk-pre {
  font-size: 0.875rem; color: var(--color-text);
  max-width: 520px; line-height: 1.55;
  padding-left: 1rem; border-left: 2px solid var(--color-purple);
  margin-bottom: 1.5rem;
}
.vk-cta-row { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 2rem; align-items: center; }
.vk-cta-meta { color: var(--color-text); font-size: 0.875rem; line-height: 1.55; margin-top: 1rem; }
.vk-cta-meta strong { color: var(--color-white); font-weight: 600; }

.vk-timer {
  display: inline-flex; gap: 0.75rem; margin-top: 2rem;
  padding: 1rem 1.25rem; border-radius: 1rem;
  background: linear-gradient(to right, rgba(245,158,11,0.10), rgba(236,72,153,0.10));
  border: 1px solid rgba(245,158,11,0.25);
  backdrop-filter: blur(8px);
  align-items: center;
}
.vk-timer-label { font-size: 0.75rem; color: var(--color-amber); text-transform: uppercase; letter-spacing: 0.1em; font-weight: 700; }
.vk-timer-units { display: flex; gap: 0.5rem; font-variant-numeric: tabular-nums; }
.vk-timer-unit {
  display: flex; flex-direction: column; align-items: center;
  min-width: 48px; padding: 0.4rem 0.5rem; border-radius: 0.5rem;
  background: rgba(0,0,0,0.4); border: 1px solid var(--color-border);
}
.vk-timer-num { font-size: 1.25rem; font-weight: 800; color: var(--color-white); line-height: 1; }
.vk-timer-name { font-size: 0.65rem; color: var(--color-text); letter-spacing: 0.1em; text-transform: uppercase; margin-top: 0.25rem; }

/* hero collage */
.vk-hero-visual { position: relative; min-height: 540px; }
.vk-collage {
  position: relative; width: 100%; aspect-ratio: 1; max-width: 540px; margin: 0 auto;
}
.vk-collage-card {
  position: absolute;
  border-radius: 0.875rem;
  background: linear-gradient(to bottom right, rgba(255,255,255,0.10), rgba(255,255,255,0.03));
  backdrop-filter: blur(20px);
  border: 1px solid var(--color-border-light);
  overflow: hidden;
  box-shadow: 0 20px 50px rgba(0,0,0,0.4);
}
.vk-collage-card--c1 { top: 0; left: 0; width: 58%; aspect-ratio: 3/4; transform: rotate(-4deg); z-index: 3; }
.vk-collage-card--c2 { top: 8%; right: 0; width: 50%; aspect-ratio: 4/5; transform: rotate(5deg); z-index: 2; }
.vk-collage-card--c3 { bottom: 8%; left: 14%; width: 52%; aspect-ratio: 1; transform: rotate(-2deg); z-index: 4; }
.vk-collage-card--c4 { bottom: 0; right: 6%; width: 44%; aspect-ratio: 5/4; transform: rotate(6deg); z-index: 5; }

.vk-mini-pdf, .vk-mini-pres, .vk-mini-post, .vk-mini-info { padding: 1rem; height: 100%; display: flex; flex-direction: column; gap: 0.5rem; }
.vk-mini-tag { font-size: 0.65rem; color: var(--color-text); letter-spacing: 0.1em; text-transform: uppercase; font-weight: 700; }
.vk-mini-h { font-size: 0.95rem; color: var(--color-white); font-weight: 700; line-height: 1.2; }
.vk-skel { height: 0.5rem; border-radius: 0.25rem; background: linear-gradient(to right, rgba(139,92,246,0.35), rgba(6,182,212,0.2)); }
.vk-skel-img { flex: 1; border-radius: 0.5rem;
  background: linear-gradient(135deg, rgba(139,92,246,0.4), rgba(236,72,153,0.25), rgba(6,182,212,0.3));
  position: relative; overflow: hidden;
}
.vk-skel-img::after {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.18), transparent 50%);
}
.vk-mini-info .vk-skel-img { background: conic-gradient(from 180deg, rgba(139,92,246,0.5), rgba(6,182,212,0.3), rgba(245,158,11,0.4), rgba(139,92,246,0.5)); }

@media (max-width: 980px) {
  .vk-hero-grid { grid-template-columns: 1fr; gap: 2rem; }
  .vk-hero-visual { min-height: 380px; }
}

/* ---- 3 CHANGES ---- */
.vk-changes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.vk-change-num {
  font-size: 3.5rem; font-weight: 800; line-height: 1;
  background: var(--gradient-text); -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; letter-spacing: -0.04em;
}
@media (max-width: 880px) { .vk-changes { grid-template-columns: 1fr; } }

/* ---- 10 FORMATS ---- */
.vk-formats { display: grid; gap: 6.5rem; }
.vk-format { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 3rem; align-items: center; }
.vk-format--rev { grid-template-columns: 0.9fr 1.1fr; }
.vk-format--rev .vk-format-text { order: 2; }
.vk-format--rev .vk-format-visual { order: 1; }
.vk-format--big-visual { grid-template-columns: 1.25fr 0.75fr; gap: 2.5rem; }
.vk-format--big-visual.vk-format--rev { grid-template-columns: 1.25fr 0.75fr; }
.vk-format-num {
  display: inline-flex; align-items: center; gap: 0.75rem;
  font-size: 0.75rem; color: var(--color-text); letter-spacing: 0.15em; text-transform: uppercase; font-weight: 700;
  margin-bottom: 0.75rem;
}
.vk-format-num span:first-child {
  font-size: 1.875rem; line-height: 1; color: var(--color-white); letter-spacing: -0.02em;
  font-weight: 800;
}
.vk-format-emoji { font-size: 1.75rem; }
.vk-format h3 { font-size: clamp(1.5rem, 3vw, 2rem); margin-bottom: 1rem; }
.vk-format h3 .gradient-text { display: inline; }
.vk-format-body { color: var(--color-text-light); line-height: 1.7; margin-bottom: 1.25rem; }
.vk-format-list { list-style: none; padding: 0; margin: 0 0 1.25rem; display: grid; gap: 0.5rem; }
.vk-format-list li { display: flex; gap: 0.65rem; color: var(--color-text-light); font-size: 0.95rem; line-height: 1.5; }
.vk-format-styles { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 1rem; }
.vk-chip {
  font-size: 0.75rem; padding: 0.35rem 0.75rem; border-radius: 9999px;
  background: rgba(255,255,255,0.05); border: 1px solid var(--color-border);
  color: var(--color-text-light);
}
.vk-case-strip {
  margin-top: 1rem; padding: 1rem 1.25rem;
  border-radius: 0.875rem;
  background: linear-gradient(to right, rgba(139,92,246,0.08), rgba(6,182,212,0.05));
  border: 1px solid rgba(139,92,246,0.2);
  font-size: 0.9rem; line-height: 1.6;
}
.vk-case-strip strong { color: var(--color-white); }
.vk-case-strip-meta { display: flex; gap: 1.25rem; margin-top: 0.5rem; font-size: 0.8rem; color: var(--color-text); flex-wrap: wrap; }
.vk-case-strip-meta b { color: var(--color-amber); font-weight: 700; }

/* placeholders for format visuals */
.vk-ph {
  position: relative;
  aspect-ratio: 4/5;
  border-radius: 1rem;
  background: linear-gradient(to bottom right, rgba(255,255,255,0.06), rgba(255,255,255,0.02));
  border: 1px solid var(--color-border-light);
  backdrop-filter: blur(8px);
  overflow: hidden;
  display: flex; flex-direction: column;
}
.vk-ph--wide { aspect-ratio: 5/4; }
.vk-ph--square { aspect-ratio: 1; }
.vk-ph--tall { aspect-ratio: 3/4; }
.vk-ph-tag {
  position: absolute; top: 1rem; left: 1rem;
  font-size: 0.65rem; padding: 0.3rem 0.65rem; border-radius: 9999px;
  background: rgba(0,0,0,0.5); border: 1px solid var(--color-border-light);
  color: var(--color-text); letter-spacing: 0.1em; text-transform: uppercase; font-weight: 700;
  z-index: 2;
}
.vk-ph-fill {
  flex: 1; margin: 1rem; border-radius: 0.5rem; position: relative; overflow: hidden;
  background: linear-gradient(135deg, rgba(139,92,246,0.4), rgba(236,72,153,0.25), rgba(6,182,212,0.35));
}
.vk-ph-fill--cyan { background: linear-gradient(135deg, rgba(6,182,212,0.45), rgba(139,92,246,0.25)); }
.vk-ph-fill--pink { background: linear-gradient(135deg, rgba(236,72,153,0.4), rgba(245,158,11,0.25)); }
.vk-ph-fill--amber { background: linear-gradient(135deg, rgba(245,158,11,0.4), rgba(236,72,153,0.25)); }
.vk-ph-fill--green { background: linear-gradient(135deg, rgba(16,185,129,0.4), rgba(6,182,212,0.25)); }
.vk-ph-fill::after {
  content: attr(data-label); position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.55); font-weight: 700; font-size: 0.875rem; letter-spacing: 0.1em;
}
.vk-ph-grid { padding: 1rem; display: grid; gap: 0.5rem; flex: 1; }
.vk-ph-grid--3x2 { grid-template-columns: repeat(3, 1fr); grid-template-rows: repeat(2, 1fr); }
.vk-ph-grid--2x2 { grid-template-columns: repeat(2, 1fr); grid-template-rows: repeat(2, 1fr); }
.vk-ph-grid > div { border-radius: 0.4rem; background: linear-gradient(135deg, rgba(139,92,246,0.35), rgba(6,182,212,0.25)); border: 1px solid var(--color-border-light); }

/* carousel gallery — clickable cells + lightbox */
.vk-cg-cell {
  border-radius: 0.4rem; border: 1px solid var(--color-border-light);
  background: linear-gradient(135deg, rgba(139,92,246,0.35), rgba(6,182,212,0.25));
  cursor: zoom-in; transition: transform 0.2s ease, box-shadow 0.2s ease;
  padding: 0;
}
.vk-cg-cell:hover { transform: scale(1.04); box-shadow: 0 8px 24px rgba(139,92,246,0.35); }
.vk-cg-cell.vk-ph-fill--cyan { background: linear-gradient(135deg, rgba(6,182,212,0.45), rgba(139,92,246,0.25)); }
.vk-cg-cell.vk-ph-fill--pink { background: linear-gradient(135deg, rgba(236,72,153,0.4), rgba(245,158,11,0.25)); }
.vk-cg-cell.vk-ph-fill--amber { background: linear-gradient(135deg, rgba(245,158,11,0.4), rgba(236,72,153,0.25)); }
.vk-cg-cell.vk-ph-fill--green { background: linear-gradient(135deg, rgba(16,185,129,0.4), rgba(6,182,212,0.25)); }

.vk-lb {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(8,6,16,0.9); backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  animation: vk-lb-in 0.2s ease;
}
@keyframes vk-lb-in { from { opacity: 0; } to { opacity: 1; } }
.vk-lb-img {
  width: min(80vw, 700px); aspect-ratio: 1;
  border-radius: 1rem; border: 1px solid var(--color-border-light);
  position: relative;
}
.vk-lb-img::after {
  content: attr(data-label); position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.6); font-weight: 700; font-size: 1.25rem; letter-spacing: 0.1em;
}
.vk-lb-close {
  position: absolute; top: 1.5rem; right: 1.5rem;
  width: 40px; height: 40px; border-radius: 50%;
  background: rgba(255,255,255,0.1); border: 1px solid var(--color-border-light);
  color: #fff; font-size: 1.5rem; cursor: pointer; line-height: 1;
}
.vk-lb-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 48px; height: 48px; border-radius: 50%;
  background: rgba(255,255,255,0.1); border: 1px solid var(--color-border-light);
  color: #fff; font-size: 2rem; cursor: pointer; line-height: 1;
  display: flex; align-items: center; justify-content: center;
}
.vk-lb-nav--prev { left: 2rem; }
.vk-lb-nav--next { right: 2rem; }
.vk-lb-nav:hover, .vk-lb-close:hover { background: rgba(255,255,255,0.2); }

/* banners composition — 1 wide + 2 square */
.vk-banners { display: flex; flex-direction: column; gap: 0.75rem; padding: 1rem; }
.vk-banner {
  position: relative; border-radius: 0.6rem; overflow: hidden;
  border: 1px solid var(--color-border-light);
}
.vk-banner--wide { aspect-ratio: 16/9; }
.vk-banner-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; }
.vk-banner--sq { aspect-ratio: 1; }
.vk-banner .vk-ph-fill { margin: 0; border-radius: 0; flex: none; position: absolute; inset: 0; }
.vk-banner-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }

/* youtube player */
.vk-yt { padding: 1rem; display: flex; flex-direction: column; gap: 0.75rem; }
.vk-yt-player {
  position: relative; background: #0a0a0a; border-radius: 0.6rem; overflow: hidden;
  border: 1px solid rgba(255,255,255,0.08);
}
.vk-yt-screen { position: relative; aspect-ratio: 16/9; overflow: hidden; }
.vk-yt-thumb { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; background: #000; display: block; }
.vk-yt-titlebar {
  position: absolute; top: 0; left: 0; right: 0; padding: 0.75rem 1rem;
  background: linear-gradient(180deg, rgba(0,0,0,0.6), transparent);
  color: rgba(255,255,255,0.9); font-size: 0.8rem; z-index: 3;
  text-align: left;
}
.vk-yt-play {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 64px; height: 64px; border-radius: 50%;
  background: rgba(255,255,255,0.95); color: #111;
  border: 0; cursor: pointer; z-index: 3;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 8px 24px rgba(0,0,0,0.5);
}
.vk-yt-duration {
  position: absolute; right: 0.6rem; bottom: 0.6rem; z-index: 3;
  background: rgba(0,0,0,0.8); color: #fff; padding: 0.15rem 0.4rem;
  border-radius: 3px; font-size: 0.7rem; font-weight: 600;
}
.vk-yt-arrow {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(0,0,0,0.6); border: 0; color: #fff;
  font-size: 1.5rem; cursor: pointer; line-height: 1; z-index: 3;
  opacity: 0; transition: opacity 0.2s;
}
.vk-yt-player:hover .vk-yt-arrow { opacity: 1; }
.vk-yt-arrow--prev { left: 0.5rem; }
.vk-yt-arrow--next { right: 0.5rem; }
.vk-yt-controls {
  position: absolute; left: 0; right: 0; bottom: 0; z-index: 3;
  background: linear-gradient(0deg, rgba(0,0,0,0.85), transparent);
  padding: 0.5rem 0.75rem 0.5rem;
}
.vk-yt-progress {
  display: block; height: 3px; background: rgba(255,255,255,0.25);
  border-radius: 2px; overflow: hidden; margin-bottom: 0.4rem;
}
.vk-yt-progress > span { display: block; height: 100%; background: #ff0033; }
.vk-yt-ctl-row { display: flex; justify-content: space-between; align-items: center; color: #fff; }
.vk-yt-ctl-group { display: inline-flex; align-items: center; gap: 0.55rem; }
.vk-yt-time { font-size: 0.7rem; opacity: 0.85; }
.vk-yt-dots { display: flex; justify-content: center; gap: 0.4rem; padding: 0.5rem 0; background: #0a0a0a; }
.vk-yt-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: rgba(255,255,255,0.3); border: 0; padding: 0; cursor: pointer;
}
.vk-yt-dot.is-active { background: #fff; width: 18px; border-radius: 4px; }
.vk-yt-meta { display: flex; align-items: center; gap: 0.7rem; padding: 0 0.25rem; }
.vk-yt-avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: linear-gradient(135deg, rgba(139,92,246,0.6), rgba(236,72,153,0.5));
  flex-shrink: 0;
}
.vk-yt-channel { color: #fff; font-weight: 600; font-size: 0.85rem; }
.vk-yt-stats { color: rgba(255,255,255,0.55); font-size: 0.75rem; margin-top: 0.1rem; }

/* laptop mockup — sits in .vk-format-visual, replaces .vk-ph for format 02 (Презентации) */
.vk-laptop {
  position: relative;
  width: 100%;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: stretch;
}
.vk-laptop-frame {
  position: relative;
  background: linear-gradient(180deg, #3a3a45 0%, #24242c 100%);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 14px 14px 4px 4px;
  padding: 14px 14px 16px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.12),
    0 30px 60px -25px rgba(0,0,0,0.55),
    0 8px 24px -8px rgba(139,92,246,0.22);
}
.vk-laptop-frame::before {
  content: '';
  position: absolute;
  top: 5px; left: 50%;
  width: 5px; height: 5px;
  border-radius: 50%;
  background: rgba(255,255,255,0.18);
  box-shadow: inset 0 0 0 1px rgba(0,0,0,0.5);
  transform: translateX(-50%);
}
.vk-laptop-screen {
  position: relative;
  aspect-ratio: 16/9;
  border-radius: 3px;
  overflow: hidden;
  background: var(--color-surface);
  box-shadow: inset 0 0 0 1px rgba(0,0,0,0.4);
}
.vk-laptop-slide {
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 25% 30%, rgba(236,72,153,0.55), transparent 55%),
    radial-gradient(circle at 75% 70%, rgba(245,158,11,0.4), transparent 60%),
    linear-gradient(135deg, rgba(236,72,153,0.4), rgba(245,158,11,0.25));
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.92);
  font-family: var(--font-display, 'Inter', system-ui, sans-serif);
  font-weight: 600; font-size: 2.2rem; letter-spacing: -0.01em;
}
.vk-laptop-slide::before {
  content: attr(data-label);
}
.vk-laptop-hinge {
  height: 4px;
  width: 102%;
  margin: 0 -1%;
  background: linear-gradient(180deg, #2a2a34 0%, #16161e 100%);
  position: relative;
  z-index: 2;
}
.vk-laptop-base {
  position: relative;
  width: 110%;
  margin: -2px -5% 0;
  height: 16px;
  background: linear-gradient(180deg, #42424c 0%, #2c2c36 50%, #18181f 100%);
  border-radius: 0 0 22px 22px;
  clip-path: polygon(1.5% 0, 98.5% 0, 100% 100%, 0 100%);
  box-shadow: 0 10px 24px -6px rgba(0,0,0,0.5);
}
.vk-laptop-base::after {
  content: '';
  position: absolute;
  top: 0; left: 50%; transform: translateX(-50%);
  width: 16%; height: 5px;
  background: linear-gradient(180deg, rgba(0,0,0,0.55), rgba(0,0,0,0.15));
  border-radius: 0 0 8px 8px;
}
.vk-laptop-shadow {
  width: 78%;
  margin: 14px auto 0;
  height: 24px;
  background: radial-gradient(ellipse at center, rgba(139,92,246,0.22) 0%, rgba(139,92,246,0.08) 40%, transparent 70%);
  filter: blur(6px);
}

/* presentation visual: laptop + style tabs ----------------------------------*/
.vk-pres-visual { display: flex; flex-direction: column; gap: 1.25rem; align-items: center; width: 100%; }
.vk-pres-visual .vk-laptop { width: 82%; }
@media (max-width: 880px) { .vk-pres-visual .vk-laptop { width: 92%; } }

.vk-laptop-slide--styled {
  display: flex; flex-direction: column; align-items: flex-start; justify-content: center;
  padding: 14% 12%;
  text-align: left;
  gap: 0.55rem;
}
.vk-laptop-slide--styled::before { content: none; }
.vk-laptop-slide-bar {
  width: 28%; height: 3px; border-radius: 2px;
  margin-bottom: 0.4rem;
}
.vk-laptop-slide-title {
  font-size: 1.85rem; font-weight: 700; letter-spacing: -0.02em; line-height: 1.05;
}
.vk-laptop-slide-sub {
  font-size: 0.85rem; opacity: 0.7; font-weight: 500; letter-spacing: 0.02em;
  text-transform: uppercase;
}

.vk-pres-tabs {
  display: flex; flex-wrap: wrap; gap: 0.5rem; justify-content: center;
  width: 100%;
}
.vk-pres-tab {
  font: inherit;
  padding: 0.45rem 0.95rem;
  border-radius: 9999px;
  border: 1px solid var(--color-border);
  background: rgba(255,255,255,0.03);
  color: var(--color-text-light);
  font-size: 0.85rem; font-weight: 500;
  cursor: pointer;
  transition: all 0.18s ease;
  white-space: nowrap;
}
.vk-pres-tab:hover { color: var(--color-white); border-color: rgba(255,255,255,0.18); background: rgba(255,255,255,0.06); }
.vk-pres-tab.is-active {
  background: rgba(236,72,153,0.18);
  border-color: rgba(236,72,153,0.55);
  color: #fff;
  box-shadow: 0 0 0 1px rgba(236,72,153,0.35), 0 4px 14px -4px rgba(236,72,153,0.45);
}
.vk-pres-tabs--cyan .vk-pres-tab.is-active {
  background: rgba(6,182,212,0.18);
  border-color: rgba(6,182,212,0.55);
  box-shadow: 0 0 0 1px rgba(6,182,212,0.35), 0 4px 14px -4px rgba(6,182,212,0.45);
}
.vk-pres-tabs--purple .vk-pres-tab.is-active {
  background: rgba(139,92,246,0.18);
  border-color: rgba(139,92,246,0.55);
  box-shadow: 0 0 0 1px rgba(139,92,246,0.35), 0 4px 14px -4px rgba(139,92,246,0.45);
}
.vk-pres-tab--more {
  cursor: default;
  pointer-events: none;
}

.vk-laptop-slide-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  z-index: 1;
  animation: vkSlideIn 0.45s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.vk-laptop-slide-img--prev { animation-name: vkSlideInPrev; }
@keyframes vkSlideIn {
  0% { opacity: 0; transform: translateX(8%) scale(1.02); filter: blur(4px); }
  100% { opacity: 1; transform: translateX(0) scale(1); filter: blur(0); }
}
@keyframes vkSlideInPrev {
  0% { opacity: 0; transform: translateX(-8%) scale(1.02); filter: blur(4px); }
  100% { opacity: 1; transform: translateX(0) scale(1); filter: blur(0); }
}

/* Stacked format card (Презентации) */
.vk-format--stacked {
  display: flex; flex-direction: column;
  gap: 1.75rem;
}
.vk-format-head--full { width: 100%; }
.vk-format-cols {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 1.75rem; align-items: start;
}
@media (max-width: 880px) {
  .vk-format-cols { grid-template-columns: 1fr; }
}
.vk-format-col { display: flex; flex-direction: column; gap: 1rem; min-width: 0; }
.vk-format-col .vk-format-body { margin: 0; }
.vk-format-visual--full {
  width: 100%; max-width: 880px;
  margin: 0.5rem auto 0;
}
.vk-format-visual--full .vk-laptop { width: 100%; max-width: 880px; }
.vk-pres-arrow {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(0,0,0,0.55); color: #fff; border: none;
  font-size: 1.4rem; line-height: 1; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  z-index: 4; opacity: 0; transition: opacity 0.2s, background 0.2s;
  padding-bottom: 2px;
}
.vk-pres-arrow:hover { background: rgba(0,0,0,0.8); }
.vk-laptop-screen:hover .vk-pres-arrow,
.vk-info-frame:hover .vk-pres-arrow { opacity: 1; }
@media (hover: none) {
  .vk-pres-arrow { opacity: 1; }
}
.vk-pres-arrow--prev { left: 0.6rem; }
.vk-pres-arrow--next { right: 0.6rem; }
.vk-pres-counter {
  position: absolute; bottom: 0.6rem; right: 0.6rem; z-index: 4;
  background: rgba(0,0,0,0.7); color: #fff;
  font-size: 0.7rem; font-weight: 600;
  padding: 0.2rem 0.5rem; border-radius: 999px;
  letter-spacing: 0.02em;
}
.vk-pres-dots {
  display: flex; flex-wrap: wrap; gap: 0.4rem; justify-content: center;
  width: 100%;
}
.vk-pres-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: rgba(255,255,255,0.18); border: none; padding: 0;
  cursor: pointer; transition: background 0.2s, transform 0.2s;
}
.vk-pres-dot:hover { background: rgba(255,255,255,0.4); }
.vk-pres-dot.is-active {
  background: var(--color-pink, #ec4899);
  transform: scale(1.3);
}

.site-footer {
  border-top: 1px solid rgba(255,255,255,0.06);
  padding: 1.75rem 0;
  background: transparent;
}
.site-footer__inner {
  max-width: 1170px; margin: 0 auto;
  padding: 0 1rem;
  display: grid; grid-template-columns: 1fr auto 1fr;
  align-items: center; gap: 1.5rem;
}
.site-footer__left { justify-self: start; }
.site-footer__right { justify-self: end; text-align: right; }
.site-footer__text {
  margin: 0; color: rgba(255,255,255,0.55);
  font-size: 0.85rem; line-height: 1.5;
}
.site-footer__social {
  justify-self: center;
  display: inline-flex; align-items: center; gap: 0.5rem;
}
.site-footer__tg,
.site-footer__max {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px;
  color: rgba(255,255,255,0.5);
  transition: color 0.2s, transform 0.2s;
}
.site-footer__tg:hover { color: #2aabee; transform: translateY(-2px); }
.site-footer__max:hover { color: #FFD600; transform: translateY(-2px); }
@media (max-width: 720px) {
  .site-footer__inner { grid-template-columns: 1fr; text-align: center; gap: 1rem; }
  .site-footer__left, .site-footer__right { justify-self: center; text-align: center; }
}

.vk-info-carousel {
  display: flex; flex-direction: column; align-items: center; gap: 0.85rem;
  width: 100%;
}
.vk-info-frame {
  position: relative;
  width: 100%;
  max-width: 460px;
  aspect-ratio: 720 / 1280;
  border-radius: 18px;
  overflow: hidden;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 24px 60px -20px rgba(0,0,0,0.55);
}
.vk-info-slide {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  animation: vkSlideIn 0.45s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.vk-info-slide--prev { animation-name: vkSlideInPrev; }

/* lead-magnet slider — sits in .vk-format-visual, replaces .vk-ph for format 01 */
.vk-lm-slider {
  position: relative;
  aspect-ratio: 3/4;
  border-radius: 1rem;
  overflow: hidden;
  background: linear-gradient(135deg, rgba(139,92,246,0.4), rgba(236,72,153,0.25), rgba(6,182,212,0.35));
  border: 1px solid var(--color-border-light);
  isolation: isolate;
}
.vk-lm-track { position: absolute; inset: 0; }
.vk-lm-slide {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; visibility: hidden;
  transition: opacity 0.35s ease, transform 0.35s ease;
  transform: scale(1.02);
}
.vk-lm-slide.is-active { opacity: 1; visibility: visible; transform: scale(1); }
.vk-lm-slide img { width: 100%; height: 100%; object-fit: cover; display: block; }
.vk-lm-slide--plus {
  background: linear-gradient(135deg, rgba(139,92,246,0.55), rgba(236,72,153,0.35), rgba(6,182,212,0.45));
}
.vk-lm-plus {
  text-align: center; padding: 1.5rem;
  display: flex; flex-direction: column; gap: 0.6rem; align-items: center;
}
.vk-lm-plus-big {
  font-size: clamp(2.25rem, 5vw, 3.5rem); font-weight: 800; color: #fff; letter-spacing: -0.02em; line-height: 1;
  text-shadow: 0 4px 24px rgba(139,92,246,0.5);
}
.vk-lm-plus-sub { color: rgba(255,255,255,0.85); font-size: 1rem; max-width: 22ch; line-height: 1.35; }
.vk-lm-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 40px; height: 40px; border-radius: 9999px;
  background: rgba(20,20,35,0.7); color: #fff; border: 1px solid rgba(255,255,255,0.18);
  font-size: 22px; font-weight: 600; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; opacity: 0; transition: opacity 0.2s ease, background 0.2s ease;
  z-index: 3; backdrop-filter: blur(8px);
}
.vk-lm-nav:hover { background: rgba(139,92,246,0.7); }
.vk-lm-nav--prev { left: 12px; }
.vk-lm-nav--next { right: 12px; }
.vk-lm-slider:hover .vk-lm-nav,
.vk-lm-slider:focus-within .vk-lm-nav { opacity: 1; }
.vk-lm-dots {
  position: absolute; left: 0; right: 0; bottom: 14px;
  display: flex; gap: 0.5rem; justify-content: center; z-index: 3;
}
.vk-lm-dot {
  width: 8px; height: 8px; border-radius: 9999px;
  background: rgba(255,255,255,0.35); border: 0; cursor: pointer; padding: 0;
  transition: background 0.2s ease, transform 0.2s ease;
}
.vk-lm-dot.is-active { background: #fff; transform: scale(1.3); }
@media (hover: none) {
  .vk-lm-nav { opacity: 1; }
}

@media (max-width: 880px) {
  .vk-format, .vk-format--rev { grid-template-columns: 1fr; gap: 1.5rem; }
  .vk-format--rev .vk-format-text, .vk-format--rev .vk-format-visual { order: initial; }
}

/* ---- BEFORE/AFTER ---- */
.vk-ba-list { display: grid; gap: 2rem; }
.vk-ba-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.vk-ba-card { padding: 0; overflow: hidden; }
.vk-ba-head { padding: 1.25rem 1.5rem 0.5rem; display: flex; align-items: center; gap: 0.75rem; }
.vk-ba-pill {
  font-size: 0.65rem; padding: 0.3rem 0.65rem; border-radius: 9999px;
  letter-spacing: 0.1em; text-transform: uppercase; font-weight: 700;
}
.vk-ba-pill--was { background: rgba(255,255,255,0.06); border: 1px solid var(--color-border); color: var(--color-text); }
.vk-ba-pill--now { background: linear-gradient(to right, rgba(139,92,246,0.2), rgba(6,182,212,0.15)); border: 1px solid rgba(139,92,246,0.4); color: var(--color-white); }
.vk-ba-card .vk-ph { aspect-ratio: 4/3; border-radius: 0; border: 0; border-top: 1px solid var(--color-border); margin-top: 0.5rem; }
.vk-ba-card--was { filter: grayscale(0.85); opacity: 0.85; }
.vk-ba-card--was .vk-ph-fill { background: linear-gradient(135deg, rgba(120,120,140,0.35), rgba(80,80,100,0.25)); }
.vk-ba-foot { padding: 1rem 1.5rem 1.5rem; }
.vk-ba-foot .vk-ba-text { color: var(--color-text-light); font-size: 0.95rem; line-height: 1.55; }
.vk-ba-meta { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 0.75rem; font-size: 0.8rem; color: var(--color-text); }
.vk-ba-meta b { color: var(--color-amber); font-weight: 700; }
.vk-ba-effect { margin-top: 0.75rem; padding-top: 0.75rem; border-top: 1px solid var(--color-border); font-size: 0.875rem; color: var(--color-green); }
@media (max-width: 720px) { .vk-ba-row { grid-template-columns: 1fr; } }

/* ---- PIPELINE ---- */
.vk-pipeline { display: grid; gap: 1rem; }
.vk-pipe-step { display: grid; grid-template-columns: 56px 1fr; gap: 1.25rem; align-items: flex-start; padding: 1.5rem; }
.vk-pipe-num {
  width: 56px; height: 56px; border-radius: 1rem;
  background: linear-gradient(135deg, rgba(139,92,246,0.25), rgba(6,182,212,0.15));
  border: 1px solid rgba(139,92,246,0.4);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.25rem; font-weight: 800; color: var(--color-white);
  box-shadow: 0 0 20px rgba(139,92,246,0.3);
}
.vk-pipe-step h4 { font-size: 1.1rem; margin-bottom: 0.5rem; }
.vk-pipe-result {
  margin-top: 2rem; padding: 2rem;
  border-radius: 1rem;
  background: linear-gradient(to right, rgba(16,185,129,0.1), rgba(6,182,212,0.08));
  border: 1px solid rgba(16,185,129,0.3);
  text-align: center;
}
.vk-pipe-stats { display: flex; gap: 2rem; justify-content: center; margin-top: 1rem; flex-wrap: wrap; font-variant-numeric: tabular-nums; }
.vk-pipe-stats > div { text-align: center; }
.vk-pipe-stats .vk-pipe-stat-num {
  font-size: 1.875rem; font-weight: 800; line-height: 1;
  color: var(--color-green);
}

/* ---- PAINS LIST ---- */
.vk-pains { display: grid; gap: 0.75rem; }
.vk-pain {
  display: grid; grid-template-columns: 36px 1fr; gap: 1rem; align-items: flex-start;
  padding: 1.25rem 1.5rem;
}
.vk-pain-check {
  width: 28px; height: 28px; border-radius: 0.5rem;
  background: rgba(255,255,255,0.04); border: 1px solid var(--color-border);
  margin-top: 2px;
}
.vk-pain p { margin: 0; color: var(--color-text-light); line-height: 1.55; }
.vk-pains-bridge {
  text-align: center; max-width: 760px; margin: 2.25rem auto 0;
  font-size: 1.125rem; color: #fff; font-weight: 500; line-height: 1.5;
}
.vk-author-photo { padding: 0; overflow: hidden; aspect-ratio: 3/4; background: transparent; }
.vk-author-photo img { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }
.vk-author-photo-wrap { max-width: 420px; }
@media (max-width: 880px) { .vk-author-photo-wrap { margin: 0 auto; } }
.vk-author-name { text-align: center; margin-top: 1rem; font-weight: 600; font-size: 1.125rem; color: #fff; }
.vk-author-lead { font-size: 1.375rem; color: #fff; font-weight: 600; line-height: 1.35; margin-top: 0; }
.vk-author-close { color: #fff; font-style: italic; }
.vk-author-facts { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; margin-top: 1.5rem; }
.vk-author-fact { display: flex; gap: 0.85rem; align-items: flex-start; padding: 1rem 1.15rem; }
.vk-author-fact p { margin: 0; font-size: 0.95rem; color: var(--color-text-light); line-height: 1.5; }
@media (max-width: 880px) { .vk-author-facts { grid-template-columns: 1fr; } }

/* ---- TWO COLUMNS NEW WORLD ---- */
.vk-new-world { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; align-items: stretch; }
.vk-nw-card { padding: 2rem; }
.vk-nw-card h4 { margin-bottom: 0.75rem; }
.vk-nw-card ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.65rem; }
.vk-nw-card li { display: flex; gap: 0.65rem; color: var(--color-text-light); line-height: 1.5; }
.vk-nw-good li::before { content: '✓'; color: var(--color-green); font-weight: 800; }
.vk-nw-bad li::before { content: '×'; color: var(--color-text); font-weight: 800; font-size: 1.1rem; line-height: 1; }
.vk-nw-bad { filter: grayscale(0.7); opacity: 0.85; }
@media (max-width: 720px) { .vk-new-world { grid-template-columns: 1fr; } }

/* ---- STACK 3 TOOLS ---- */
.vk-stack { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; align-items: stretch; }
.vk-stack-card h3 { margin: 1rem 0 0.5rem; font-size: 1.25rem; }
.vk-stack-card .vk-stack-role { color: var(--color-text); font-size: 0.875rem; margin-bottom: 1rem; }
.vk-stack-card ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.5rem; }
.vk-stack-card li { display: flex; gap: 0.5rem; color: var(--color-text-light); font-size: 0.9rem; line-height: 1.5; }
.vk-stack-card li::before { content: '·'; color: var(--color-purple); font-weight: 800; font-size: 1.25rem; line-height: 1; }
.vk-stack-arrow { display: flex; align-items: center; justify-content: center; color: var(--color-text); }
@media (max-width: 880px) { .vk-stack { grid-template-columns: 1fr; } }

/* ---- TAKEAWAYS ---- */
.vk-takeaways { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; }
.vk-takeaway { display: grid; grid-template-columns: 48px 1fr; gap: 1rem; padding: 1.5rem; }
.vk-takeaway .vk-emoji { font-size: 2rem; line-height: 1; }
.vk-takeaway h4 { font-size: 1.05rem; margin-bottom: 0.4rem; }
.vk-takeaway p { color: var(--color-text-light); font-size: 0.9rem; margin: 0; line-height: 1.55; }
@media (max-width: 720px) { .vk-takeaways { grid-template-columns: 1fr; } }

/* ---- PROMPTS ---- */
.vk-prompts { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.vk-prompt-card {
  padding: 1.5rem;
  display: flex; flex-direction: column; gap: 0.5rem;
}
.vk-prompt-cat { font-size: 0.7rem; color: var(--color-text); letter-spacing: 0.15em; text-transform: uppercase; font-weight: 700; }
.vk-prompt-count {
  font-size: 2.5rem; font-weight: 800; line-height: 1; letter-spacing: -0.03em;
  background: var(--gradient-text); -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.vk-prompt-card h4 { font-size: 1.05rem; }
.vk-prompt-card p { font-size: 0.875rem; color: var(--color-text-light); margin: 0; line-height: 1.5; }
@media (max-width: 980px) { .vk-prompts { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .vk-prompts { grid-template-columns: 1fr; } }

/* ---- BONUSES ---- */
.vk-bonuses { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; }
.vk-bonus { padding: 1.75rem; }
.vk-bonus-tag { font-size: 0.7rem; color: var(--color-amber); letter-spacing: 0.15em; text-transform: uppercase; font-weight: 700; margin-bottom: 0.5rem; }
.vk-bonus h4 { font-size: 1.15rem; margin-bottom: 0.5rem; }
.vk-bonus p { color: var(--color-text-light); font-size: 0.9rem; margin: 0; line-height: 1.6; }
.vk-bonus ul { list-style: none; padding: 0; margin: 0.75rem 0 0; display: grid; gap: 0.4rem; }
.vk-bonus li { color: var(--color-text-light); font-size: 0.875rem; line-height: 1.5; padding-left: 1rem; position: relative; }
.vk-bonus li::before { content: '·'; position: absolute; left: 0; color: var(--color-purple); font-weight: 800; }
@media (max-width: 720px) { .vk-bonuses { grid-template-columns: 1fr; } }

/* ---- PROGRAM ---- */
.vk-program { display: grid; gap: 0.75rem; }
.vk-prog-step { display: grid; grid-template-columns: 64px 1fr 200px; gap: 1.5rem; padding: 1.5rem; align-items: center; }
.vk-prog-time {
  font-size: 0.75rem; color: var(--color-text); letter-spacing: 0.1em; text-transform: uppercase; font-weight: 700;
}
.vk-prog-step h4 { font-size: 1.15rem; margin-bottom: 0.4rem; }
.vk-prog-step p { color: var(--color-text-light); font-size: 0.9rem; margin: 0; line-height: 1.55; }
.vk-prog-out {
  font-size: 0.8rem; padding: 0.65rem 0.875rem; border-radius: 0.6rem;
  background: linear-gradient(to right, rgba(16,185,129,0.12), rgba(6,182,212,0.08));
  border: 1px solid rgba(16,185,129,0.3);
  color: var(--color-text-light); line-height: 1.4;
}
.vk-prog-out b { color: var(--color-green); display: block; font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 0.2rem; }
@media (max-width: 880px) {
  .vk-prog-step { grid-template-columns: 1fr; gap: 0.75rem; }
}

/* ---- RECOGNIZE ---- */
.vk-rec-list { padding: 2.25rem; max-width: 800px; margin: 0 auto; display: grid; gap: 0.4rem; }
.vk-rec-row {
  display: grid; grid-template-columns: 24px 1fr; gap: 0.875rem; align-items: flex-start;
  padding: 0.75rem 0.85rem; border-radius: 0.625rem; cursor: pointer;
  transition: background 0.18s ease;
  position: relative;
}
.vk-rec-row:hover { background: rgba(255,255,255,0.03); }
.vk-rec-row input[type="checkbox"] { position: absolute; opacity: 0; pointer-events: none; }
.vk-rec-box {
  width: 22px; height: 22px; border: 1.5px solid #D4D4D8; border-radius: 5px;
  background: rgba(255,255,255,0.02); position: relative; margin-top: 1px;
  transition: border-color 0.15s ease, background 0.18s ease;
  flex-shrink: 0;
}
.vk-rec-row:hover .vk-rec-box { border-color: #FFFFFF; }
.vk-rec-row.is-checked .vk-rec-box { background: #8B5CF6; border-color: #8B5CF6; }
.vk-rec-row.is-checked .vk-rec-box::after {
  content: ""; position: absolute; left: 7px; top: 2px; width: 5px; height: 11px;
  border: solid #fff; border-width: 0 2px 2px 0; transform: rotate(45deg);
}
.vk-rec-text { font-size: 1rem; color: #D4D4D8; line-height: 1.55; transition: color 0.18s ease; }
.vk-rec-row.is-checked .vk-rec-text { color: #fff; }
.vk-rec-counter { text-align: center; font-size: 0.9375rem; color: #A1A1AA; margin-top: 1.5rem; }
.vk-rec-result { display: none; max-width: 720px; margin: 2rem auto 0; }
.vk-rec-result.is-on { display: block; animation: fadeInUp 0.4s ease both; }
.vk-rec-result-card { padding: 2.5rem; border-radius: 1.5rem; text-align: center; display: grid; gap: 1rem; justify-items: center; background: linear-gradient(160deg, rgba(139,92,246,0.12), rgba(34,211,238,0.08)), var(--color-bg-card); }
.vk-rec-result-ico { color: #A78BFA; }
.vk-rec-result-card h3 { font-size: clamp(1.875rem, 3vw, 2.375rem); font-weight: 700; color: #fff; margin: 0; }
.vk-rec-result-card p { font-size: 1.0625rem; color: #D4D4D8; max-width: 600px; margin: 0; line-height: 1.6; }

/* ---- STYLES CAROUSEL ---- */
.vk-styles-carousel { position: relative; max-width: 1200px; margin: 0 auto; }
.vk-styles-track {
  display: flex; gap: 1.125rem; overflow-x: auto; scroll-snap-type: x mandatory;
  padding: 0.5rem 0.5rem 1.5rem; scrollbar-width: none;
  scroll-padding: 1rem;
}
.vk-styles-track::-webkit-scrollbar { display: none; }
.vk-style-slide {
  flex: 0 0 280px; scroll-snap-align: start;
  display: grid; gap: 0.625rem;
  transition: transform 0.2s ease;
}
.vk-style-slide:hover { transform: translateY(-4px); }
.vk-style-preview {
  width: 100%; aspect-ratio: 4/5; border-radius: 0.875rem;
  border: 1px solid rgba(255,255,255,0.08);
  background: #1a1530;
  overflow: hidden;
  box-shadow: 0 12px 32px rgba(0,0,0,0.35);
  transition: box-shadow 0.2s ease, border-color 0.2s ease;
}
.vk-style-preview img { width: 100%; height: 100%; object-fit: cover; display: block; }
.vk-style-slide:hover .vk-style-preview { box-shadow: 0 0 32px rgba(139,92,246,0.35); border-color: rgba(167,139,250,0.5); }
.vk-style-preview--more {
  background: rgba(255,255,255,0.04) !important;
  color: #A78BFA !important;
  display: flex; align-items: center; justify-content: center; text-align: center;
  border: 1px dashed rgba(167,139,250,0.5);
  padding: 1.25rem;
}
.vk-style-preview-more { font-size: 1.25rem; font-weight: 600; line-height: 1.4; }
.vk-style-name { font-size: 1.0625rem; font-weight: 600; color: #fff; }
.vk-style-sub { font-size: 0.8125rem; color: #A1A1AA; line-height: 1.5; }
.vk-styles-arrow {
  position: absolute; top: 38%; transform: translateY(-50%);
  width: 44px; height: 44px; border-radius: 50%;
  background: rgba(20,20,30,0.9); border: 1px solid rgba(255,255,255,0.12); color: #fff;
  display: flex; align-items: center; justify-content: center; cursor: pointer; z-index: 2;
  transition: background 0.18s ease, border-color 0.18s ease;
}
.vk-styles-arrow:hover { background: #8B5CF6; border-color: #8B5CF6; }
.vk-styles-arrow--left { left: -22px; }
.vk-styles-arrow--right { right: -22px; }
@media (max-width: 720px) { .vk-styles-arrow { display: none; } }
.vk-styles-dots { display: flex; gap: 6px; justify-content: center; margin-top: 1.25rem; flex-wrap: wrap; max-width: 320px; margin-left: auto; margin-right: auto; }
.vk-styles-dot { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,0.18); transition: background 0.18s ease, transform 0.18s ease; }
.vk-styles-dot.is-active { background: #A78BFA; transform: scale(1.3); }
.vk-styles-conclusion { text-align: center; margin-top: 3.5rem; max-width: 720px; margin-left: auto; margin-right: auto; }
.vk-styles-key { font-size: clamp(1.375rem, 2.4vw, 1.75rem); font-weight: 600; color: #fff; line-height: 1.4; margin: 0; }
.vk-styles-keysub { font-size: 1rem; color: #A1A1AA; margin: 0.875rem 0 0; }

/* ---- AUDIENCE ---- */
.vk-audience { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.vk-aud-card { padding: 2rem; }
.vk-aud-card h4 { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 1.25rem; font-size: 1.25rem; }
.vk-aud-card ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.7rem; }
.vk-aud-card li { display: flex; gap: 0.6rem; color: var(--color-text-light); font-size: 0.95rem; line-height: 1.5; }
.vk-aud-good li::before { content: '✓'; color: var(--color-green); font-weight: 800; flex-shrink: 0; }
.vk-aud-bad li::before { content: '×'; color: var(--color-pink); font-weight: 800; flex-shrink: 0; font-size: 1.05rem; line-height: 1.4; }
@media (max-width: 880px) { .vk-audience { grid-template-columns: 1fr; } }

/* ---- FEARS ---- */
.vk-fears { display: grid; gap: 1rem; }
.vk-fear { padding: 1.75rem 2rem; display: grid; grid-template-columns: auto 1fr; gap: 1rem; align-items: flex-start; }
.vk-fear-num {
  font-size: 0.7rem; padding: 0.3rem 0.6rem; border-radius: 9999px;
  background: rgba(236,72,153,0.15); border: 1px solid rgba(236,72,153,0.3);
  color: var(--color-pink); letter-spacing: 0.1em; text-transform: uppercase; font-weight: 700;
  white-space: nowrap;
}
.vk-fear h4 { font-size: 1.05rem; margin-bottom: 0.5rem; font-weight: 600; color: var(--color-white); }
.vk-fear h4::before { content: '«'; }
.vk-fear h4::after { content: '»'; }
.vk-fear p { color: var(--color-text-light); margin: 0; line-height: 1.6; }

/* ---- AUTHOR ---- */
.vk-author-grid { display: grid; grid-template-columns: 420px 1fr; gap: 3rem; align-items: start; }
.vk-author-photo {
  aspect-ratio: 3/4;
  width: 100%; height: auto;
  border-radius: 1.5rem; padding: 0; overflow: hidden; position: relative; background: transparent;
}
.vk-photo-fallback {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(139,92,246,0.3), rgba(6,182,212,0.2)),
              repeating-linear-gradient(135deg, rgba(255,255,255,0.03) 0 12px, transparent 12px 24px);
  display: flex; align-items: center; justify-content: center;
  color: var(--color-text); font-size: 0.75rem; letter-spacing: 0.1em; text-transform: uppercase;
}
.vk-author-text h3 { font-size: clamp(1.5rem, 3vw, 2rem); margin-bottom: 1rem; }
.vk-author-text p { color: var(--color-text-light); line-height: 1.7; margin-bottom: 1rem; }
.vk-author-proofs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; margin-top: 1.5rem; }
.vk-proof { padding: 1.25rem; text-align: center; }
.vk-proof .vk-proof-num {
  font-size: 1.5rem; font-weight: 800; line-height: 1;
  background: var(--gradient-text); -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.vk-proof .vk-proof-label { font-size: 0.8rem; color: var(--color-text); margin-top: 0.4rem; line-height: 1.4; }
@media (max-width: 880px) { .vk-author-grid { grid-template-columns: 1fr; gap: 2rem; } }

/* ---- BUY BLOCK ---- */
.vk-buy-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2.5rem; align-items: start; }
@media (max-width: 880px) { .vk-buy-grid { grid-template-columns: 1fr; gap: 2rem; } }
.vk-buy-sub { font-size: 1.125rem; color: #D4D4D8; margin: 0 0 1.5rem; }
.vk-buy-eyebrow { font-size: 0.9375rem; color: #A1A1AA; font-weight: 600; letter-spacing: 0.04em; margin: 1.5rem 0 1rem; }
.vk-buy-eyebrow-accent { color: #06B6D4; }
.vk-buy-formats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.875rem; margin-bottom: 1.75rem; grid-auto-rows: 1fr; }
.vk-buy-formats > :nth-child(5),
.vk-buy-formats > :nth-child(6),
.vk-buy-formats > :nth-child(7) { grid-column: span 1; }
@media (max-width: 720px) { .vk-buy-formats { grid-template-columns: repeat(2, 1fr); } }
.vk-buy-fcard {
  position: relative; padding: 1.25rem 0.75rem; border-radius: 0.875rem; min-height: 110px;
  background: rgba(255,255,255,0.02); border: 1px solid var(--color-border);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 0.6rem; text-align: center;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}
.vk-buy-fcard::before {
  content: ""; position: absolute; inset: 0; border-radius: inherit; opacity: 0.08; pointer-events: none;
  background: radial-gradient(circle at 30% 0%, currentColor, transparent 70%);
}
.vk-buy-fcard--purple { color: #A78BFA; }
.vk-buy-fcard--pink { color: #F472B6; }
.vk-buy-fcard--cyan { color: #22D3EE; }
.vk-buy-fcard:hover { transform: translateY(-2px); border-color: currentColor; box-shadow: 0 0 24px rgba(139,92,246,0.18); }
.vk-buy-fico { display: inline-flex; }
.vk-buy-fname { font-size: 0.875rem; font-weight: 500; color: #fff; line-height: 1.2; }
.vk-buy-of100 { color: #A1A1AA; font-weight: 400; }
.vk-buy-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 1.625rem; }
.vk-buy-list li { display: grid; grid-template-columns: 32px 1fr; gap: 1rem; align-items: flex-start; }
.vk-buy-ico { display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px; }
.vk-buy-ico--purple { color: #A78BFA; }
.vk-buy-ico--pink { color: #F472B6; }
.vk-buy-ico--cyan { color: #22D3EE; }
.vk-buy-text { display: grid; gap: 0.25rem; }
.vk-buy-text strong { font-weight: 600; font-size: 1.0625rem; color: #fff; }
.vk-buy-text span { font-size: 0.9375rem; color: #A1A1AA; line-height: 1.55; }
.vk-buy-card { padding: 2.25rem; border-radius: 1.5rem; }
.vk-buy-old-row { font-size: 1rem; color: #71717A; }
.vk-buy-old-row s { color: #71717A; }
.vk-buy-price { font-size: clamp(3rem, 5vw, 3.75rem); font-weight: 800; color: #fff; line-height: 1; margin-top: 0.4rem; letter-spacing: -0.02em; }
.vk-buy-until { font-size: 1rem; color: #06B6D4; margin-top: 0.4rem; font-weight: 500; }
.vk-buy-meta { display: grid; gap: 0.625rem; margin-top: 1.5rem; }
.vk-buy-when { display: flex; align-items: center; gap: 0.5rem; font-size: 1rem; color: #D4D4D8; font-weight: 500; flex-wrap: wrap; }
.vk-buy-when svg { color: #22D3EE; flex-shrink: 0; }
.vk-buy-when s { color: #71717A; font-weight: 400; }
.vk-buy-arrow { color: #71717A; }
.vk-buy-left-mark { color: #F472B6; font-weight: 600; }
.vk-buy-divider { height: 1px; background: #2D2D3F; margin: 1.5rem 0 2.25rem; }
.vk-buy-form { display: grid; gap: 0.9375rem; }
.vk-buy-input {
  width: 100%; min-height: 54px;
  background: rgba(255,255,255,0.03); border: 1px solid #D4D4D8; border-radius: 0.75rem;
  padding: 1rem 1.125rem; color: #fff; font-size: 1rem; font-family: inherit; outline: none;
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}
.vk-buy-input:focus { border-color: #8B5CF6; box-shadow: 0 0 0 3px rgba(139,92,246,0.18); }
.vk-buy-input::placeholder { color: #71717A; opacity: 1; }
.vk-buy-input:focus::placeholder { color: transparent; }
.vk-buy-form { display: grid; gap: 1rem; }
.vk-buy-field { display: grid; gap: 0.4rem; }
.vk-buy-field > span { font-size: 0.8125rem; color: #A1A1AA; }
.vk-buy-field input {
  background: rgba(255,255,255,0.03); border: 1px solid #D4D4D8; border-radius: 0.75rem;
  padding: 0.875rem 1rem; color: #fff; font-size: 1rem; font-family: inherit; outline: none;
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}
.vk-buy-field input:focus { border-color: #8B5CF6; box-shadow: 0 0 0 3px rgba(139,92,246,0.18); }
.vk-buy-field input::placeholder { color: #71717A; opacity: 1; }
.vk-buy-field input:focus::placeholder { color: transparent; }
.vk-buy-check-row { display: grid; grid-template-columns: auto 1fr; gap: 0.6rem; align-items: flex-start; font-size: 0.8125rem; color: #A1A1AA; line-height: 1.5; cursor: pointer; }
.vk-buy-check-row input[type="checkbox"] {
  appearance: none; -webkit-appearance: none;
  width: 18px; height: 18px; border: 1.5px solid #D4D4D8; border-radius: 5px;
  background: rgba(255,255,255,0.02); margin-top: 2px; cursor: pointer; position: relative;
  transition: border-color 0.15s ease, background 0.15s ease;
}
.vk-buy-check-row input[type="checkbox"]:hover { border-color: #FFFFFF; }
.vk-buy-check-row input[type="checkbox"]:checked { background: #8B5CF6; border-color: #8B5CF6; }
.vk-buy-check-row input[type="checkbox"]:checked::after {
  content: ""; position: absolute; left: 5px; top: 1px; width: 5px; height: 10px;
  border: solid #fff; border-width: 0 2px 2px 0; transform: rotate(45deg);
}
.vk-buy-check-row a { color: #22D3EE; text-decoration: none; }
.vk-buy-check-row a:hover { text-decoration: underline; }
.vk-buy-btn {
  margin-top: 0.75rem; min-height: 56px; width: 100%;
  background: linear-gradient(90deg, #8B5CF6, #06B6D4); color: #fff;
  font-weight: 700; font-size: 1.0625rem; letter-spacing: 0.02em;
  border: none; border-radius: 0.875rem; padding: 1.125rem; cursor: pointer;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.vk-buy-btn:hover { transform: scale(1.02); box-shadow: 0 0 32px rgba(139,92,246,0.45); }
.vk-buy-note { margin: 0.875rem 0 0; font-size: 0.8125rem; color: #A1A1AA; line-height: 1.5; text-align: center; }
.vk-buy-alt { margin: 0.625rem 0 0; font-size: 0.8125rem; color: #A1A1AA; line-height: 1.5; text-align: center; }
.vk-buy-alt a { color: #A78BFA; text-decoration: underline; text-underline-offset: 3px; }
.vk-buy-alt a:hover { color: #C4B5FD; }
.vk-buy-foot { text-align: center; max-width: 760px; margin: 2rem auto 0; font-size: 0.9375rem; color: #A1A1AA; line-height: 1.6; }

/* ---- PRICING ---- */
.vk-pricing-card { padding: 0; max-width: 760px; margin: 0 auto; overflow: hidden; }
.vk-stack-table {
  display: grid; gap: 0;
  background: rgba(0,0,0,0.25);
}
.vk-stack-row {
  display: grid; grid-template-columns: 1fr 140px;
  gap: 1rem; padding: 1rem 1.5rem;
  border-bottom: 1px solid var(--color-border);
  align-items: center;
}
.vk-stack-row:last-child { border-bottom: 0; }
.vk-stack-row .vk-stack-name { color: var(--color-text-light); font-size: 0.95rem; line-height: 1.5; }
.vk-stack-row .vk-stack-price { color: var(--color-text); font-size: 0.95rem; font-weight: 600; text-align: right; font-variant-numeric: tabular-nums; }
.vk-stack-foot {
  padding: 2rem; text-align: center;
  background: linear-gradient(to bottom, rgba(139,92,246,0.08), rgba(6,182,212,0.05));
  border-top: 1px solid var(--color-border-light);
}
.vk-old-total { color: var(--color-text); font-size: 1.05rem; }
.vk-old-total s { font-weight: 700; }
.vk-new-price {
  font-size: clamp(3rem, 7vw, 4.5rem); font-weight: 800; letter-spacing: -0.03em; line-height: 1;
  background: var(--gradient-text); -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; margin: 0.75rem 0 0.25rem;
}
.vk-new-price-meta { color: var(--color-text); font-size: 0.85rem; margin-bottom: 1.5rem; }
@media (max-width: 720px) {
  .vk-stack-row { grid-template-columns: 1fr; gap: 0.25rem; padding: 1rem 1.25rem; }
  .vk-stack-row .vk-stack-price { text-align: left; color: var(--color-amber); font-size: 0.85rem; }
}

/* ---- URGENCY ---- */
.vk-urgency { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; }
.vk-urg-card { padding: 1.75rem; }
.vk-urg-card .vk-emoji { font-size: 1.75rem; margin-bottom: 0.75rem; }
.vk-urg-card h4 { font-size: 1.05rem; margin-bottom: 0.5rem; }
.vk-urg-card p { color: var(--color-text-light); font-size: 0.9rem; margin: 0; line-height: 1.6; }
@media (max-width: 880px) { .vk-urgency { grid-template-columns: 1fr; } }

/* ---- FAQ ---- */
.vk-faq { display: grid; gap: 0.75rem; }
.vk-faq-item { padding: 0; }
.vk-faq-q {
  width: 100%; background: transparent; border: 0; cursor: pointer;
  padding: 1.25rem 1.5rem;
  display: flex; justify-content: space-between; align-items: center; gap: 1rem;
  font: inherit; font-size: 1rem; font-weight: 500; color: var(--color-white);
  text-align: left;
}
.vk-faq-icon { color: var(--color-text); transition: transform 0.3s ease, color 0.3s ease; display: inline-flex; }
.vk-faq-item.is-open .vk-faq-icon { transform: rotate(45deg); color: var(--color-purple); }
.vk-faq-a { padding: 0 1.5rem 1.25rem; color: var(--color-text-light); font-size: 0.95rem; line-height: 1.65; }

/* ---- GUARANTEE ---- */
.vk-guarantee {
  display: grid; grid-template-columns: 120px 1fr; gap: 2rem; align-items: center;
  padding: 2.5rem;
}
.vk-shield {
  width: 120px; height: 120px; border-radius: 50%;
  background: linear-gradient(135deg, rgba(16,185,129,0.25), rgba(6,182,212,0.15));
  border: 2px solid rgba(16,185,129,0.4);
  display: flex; align-items: center; justify-content: center;
  color: var(--color-green);
  box-shadow: 0 0 60px rgba(16,185,129,0.3);
}
.vk-guarantee p { color: var(--color-text-light); line-height: 1.7; margin: 0 0 0.75rem; }
.vk-guarantee p:last-child { margin-bottom: 0; }
@media (max-width: 720px) { .vk-guarantee { grid-template-columns: 1fr; text-align: center; }
  .vk-shield { margin: 0 auto; } }

/* ---- FINAL CTA ---- */
.vk-final-cta {
  text-align: center;
  padding: 4rem 2rem;
  border-radius: 1.5rem;
  background: linear-gradient(135deg, rgba(139,92,246,0.15), rgba(236,72,153,0.10), rgba(6,182,212,0.12));
  border: 1px solid rgba(139,92,246,0.3);
  position: relative; overflow: hidden;
}
.vk-final-cta .vk-final-list {
  list-style: none; padding: 0; margin: 2rem auto;
  max-width: 560px; display: grid; gap: 0.6rem; text-align: left;
}
.vk-final-cta .vk-final-list li { display: flex; gap: 0.65rem; color: var(--color-text-light); font-size: 0.95rem; }
.vk-final-cta .vk-final-list li::before { content: '✓'; color: var(--color-green); font-weight: 800; }

.vk-ps {
  margin-top: 4rem;
  padding: 2.5rem;
  border-radius: 1rem;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-amber);
}
.vk-ps h4 { font-size: 1.5rem; margin-bottom: 1rem; color: var(--color-amber); }
.vk-ps p { color: var(--color-text-light); line-height: 1.7; margin: 0 0 0.875rem; }
.vk-ps p:last-of-type { margin-bottom: 1.5rem; }

/* ---- FOOTER ---- */
.vk-footer { padding: 3rem 1rem; border-top: 1px solid var(--color-border); margin-top: 2rem; }
.vk-footer-row { display: flex; justify-content: space-between; gap: 2rem; flex-wrap: wrap; max-width: var(--container-max); margin: 0 auto; }
.vk-footer-meta { font-size: 0.8rem; color: var(--color-text); line-height: 1.6; text-align: right; }
@media (max-width: 720px) { .vk-footer-meta { text-align: left; } }

/* ---- DOC MODAL (оферта, политика) ---- */
.vk-doc-modal { position: fixed; inset: 0; z-index: 10000; display: flex; align-items: center; justify-content: center; padding: 2rem 1rem; animation: vk-lb-in 0.2s ease; }
.vk-doc-modal__overlay { position: absolute; inset: 0; background: rgba(8,6,16,0.85); backdrop-filter: blur(8px); cursor: pointer; }
.vk-doc-modal__panel {
  position: relative;
  width: min(820px, 100%);
  max-height: calc(100vh - 4rem);
  background: linear-gradient(160deg, rgba(20,16,32,0.98), rgba(12,10,22,0.98));
  border: 1px solid var(--color-border-light);
  border-radius: 1.25rem;
  box-shadow: 0 0 60px rgba(139,92,246,0.25);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.vk-doc-modal__close {
  position: absolute; top: 0.75rem; right: 0.75rem;
  width: 40px; height: 40px;
  background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.12);
  border-radius: 50%; color: var(--color-white);
  font-size: 1.5rem; line-height: 1;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background 0.2s ease, transform 0.2s ease;
  z-index: 2;
}
.vk-doc-modal__close:hover { background: rgba(255,255,255,0.16); transform: scale(1.05); }
.vk-doc-modal__body {
  overflow-y: auto;
  padding: 2.5rem 2.5rem 2rem;
  color: var(--color-text-light);
  font-size: 0.95rem;
  line-height: 1.65;
  scrollbar-width: thin;
  scrollbar-color: rgba(139,92,246,0.5) transparent;
}
.vk-doc-modal__body::-webkit-scrollbar { width: 8px; }
.vk-doc-modal__body::-webkit-scrollbar-thumb { background: rgba(139,92,246,0.5); border-radius: 4px; }
.vk-doc-modal__body h2 { font-size: 1.5rem; color: #fff; margin: 0 2.5rem 0.25rem 0; line-height: 1.25; }
.vk-doc-modal__body h3 { font-size: 1.15rem; color: #fff; margin: 1.5rem 0 0.5rem; }
.vk-doc-modal__body h4 { font-size: 1rem; color: #fff; margin: 1.5rem 0 0.5rem; font-weight: 600; }
.vk-doc-modal__body p { margin: 0 0 0.75rem; }
.vk-doc-modal__body ul { margin: 0 0 0.75rem; padding-left: 1.25rem; }
.vk-doc-modal__body li { margin-bottom: 0.25rem; }
.vk-doc-modal__body strong { color: var(--color-white); }
.vk-doc-modal__body .vk-doc-meta { font-size: 0.85rem; color: var(--color-text); margin-bottom: 1.25rem; line-height: 1.5; }

@media (max-width: 600px) {
  .vk-doc-modal { padding: 0; }
  .vk-doc-modal__panel { max-height: 100vh; height: 100vh; border-radius: 0; border: 0; }
  .vk-doc-modal__body { padding: 3.25rem 1.25rem 1.5rem; }
  .vk-doc-modal__body h2 { font-size: 1.25rem; }
}

/* ---- COVERS GRID (Обложки курсов и модулей) ---- */
.vk-covers {
  position: relative;
  border-radius: 1rem;
  background: linear-gradient(to bottom right, rgba(255,255,255,0.06), rgba(255,255,255,0.02));
  border: 1px solid var(--color-border-light);
  backdrop-filter: blur(8px);
  padding: 1rem;
}
.vk-covers-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.625rem;
}
.vk-covers-cell {
  aspect-ratio: 4/5;
  border-radius: 0.5rem;
  overflow: hidden;
  border: 1px solid var(--color-border-light);
  background: #1a1530;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.vk-covers-cell:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 24px rgba(139,92,246,0.3);
}
.vk-covers-cell img { width: 100%; height: 100%; object-fit: cover; display: block; }
@media (max-width: 600px) {
  .vk-covers-grid { grid-template-columns: repeat(2, 1fr); gap: 0.5rem; }
}

/* ---- PLACES LEFT — Thanos-style number swap ---- */
[data-places-left] {
  display: inline-block;
  will-change: transform, filter, opacity;
}
@keyframes vk-places-out {
  0%   { opacity: 1; filter: blur(0)    saturate(1);   transform: scale(1)   translateY(0); letter-spacing: 0; }
  60%  { opacity: 0.55; filter: blur(4px) saturate(1.4); transform: scale(1.25) translateY(-6px); letter-spacing: 0.15em; }
  100% { opacity: 0; filter: blur(14px) saturate(0);   transform: scale(1.7) translateY(-14px); letter-spacing: 0.6em; }
}
@keyframes vk-places-in {
  0%   { opacity: 0; filter: blur(14px) saturate(0);   transform: scale(0.4) translateY(14px); letter-spacing: 0.6em; }
  55%  { opacity: 1; filter: blur(2px)  saturate(1.4); transform: scale(1.15) translateY(-3px); letter-spacing: 0.05em; }
  100% { opacity: 1; filter: blur(0)    saturate(1);   transform: scale(1)   translateY(0); letter-spacing: 0; }
}
[data-places-left].vk-places-out { animation: vk-places-out 0.6s cubic-bezier(.55,.05,.65,.95) forwards; }
[data-places-left].vk-places-in  { animation: vk-places-in  0.55s cubic-bezier(.18,.89,.32,1.28) both; }
