/* === Глобальные стили (портировано из src/index.css) === */

:root {
  /* neutral base — slightly warmer, deeper ink for stronger contrast */
  --bg-page: #FBFBFD;
  --bg-tint: #F4F6FB;           /* tinted band for alternating sections */
  --surface: #FFFFFF;
  --surface-muted: #F3F5F9;
  --border: #EAECF2;
  --border-strong: #D6DAE3;
  --ink: #0B1220;
  --ink-secondary: #5A6577;
  --ink-tertiary: #98A1B2;

  /* action — refined indigo-blue with gradient for depth */
  --primary: #3056F5;
  --primary-hover: #1E40E0;
  --primary-soft: #EDF0FE;
  --primary-grad: linear-gradient(135deg, #3056F5 0%, #5B6FFF 100%);
  --ink-button: #0B1220;
  --ink-button-hover: #1C2638;
  --ink-button-grad: linear-gradient(135deg, #141C2E 0%, #0B1220 100%);

  /* semantic */
  --danger: #EF4444;
  --danger-soft: #FEE6E6;
  --success: #0FAE73;
  --success-text: #0E9E68;
  --success-soft: #E7F9F1;
  --neutral-badge: #374151;
  --warning: #F59E0B;

  /* tints */
  --tech-bg: #EEE9FE;
  --tech-text: #6D33E8;
  --grade-mid-bg: #FFE9D5;
  --grade-mid-fg: #EA580C;
  --grade-sen-bg: #E2E6FF;
  --grade-sen-fg: #4338CA;

  /* radius — a touch larger for a softer, more premium feel */
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 18px;
  --radius-xl: 24px;

  /* shadows — layered, soft, with a cool tint; real depth */
  --shadow-xs: 0 1px 2px rgba(11,18,32,.05);
  --shadow-card: 0 1px 2px rgba(11,18,32,.04), 0 4px 12px rgba(11,18,32,.05);
  --shadow-card-hover: 0 2px 6px rgba(11,18,32,.06), 0 16px 32px rgba(11,18,32,.10);
  --shadow-dropdown: 0 6px 20px rgba(11,18,32,.12);
  --shadow-modal: 0 12px 24px rgba(11,18,32,.08), 0 32px 64px rgba(11,18,32,.16);
  --shadow-primary: 0 4px 14px rgba(48,86,245,.32);
  --shadow-primary-hover: 0 6px 20px rgba(48,86,245,.42);

  /* page-wide focus ring */
  --ring: 0 0 0 3px rgba(48,86,245,.20);

  /* section rhythm — clean & airy 2026: generous vertical breathing room */
  --section-pad: 120px;
  --section-pad-sm: 72px;
}

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
}

@media (max-width: 768px) {
  :root { --section-pad: var(--section-pad-sm); }
}

body {
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  background: var(--bg-page);
  color: var(--ink);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-feature-settings: "cv05" 1, "ss01" 1;
}

a {
  color: inherit;
  text-decoration: none;
}

#root {
  width: 100%;
}

:focus-visible {
  outline: none;
  box-shadow: var(--ring);
  border-radius: var(--radius-sm);
}

::selection {
  background: rgba(48,86,245,.16);
}

/* Thin, unobtrusive scrollbars inside framed previews */
*::-webkit-scrollbar { width: 8px; height: 8px; }
*::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 999px; }
*::-webkit-scrollbar-track { background: transparent; }

/* Reveal-on-scroll — "motion по делу": лёгкий fade-up, объясняющий иерархию,
   а не декоративный. Элементы с [data-reveal] стартуют приглушёнными и
   проявляются, когда попадают во вьюпорт (класс is-visible вешает JS). */
[data-reveal] {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.6s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: opacity, transform;
}
[data-reveal].is-visible {
  opacity: 1;
  transform: none;
}

@media (prefers-reduced-motion: reduce) {
  [data-reveal] {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* === 01-header === */
.hdr-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(255,255,255,0.78);
  border-bottom: 1px solid var(--border);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
}

.hdr-inner {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 24px;
  height: 60px;
  display: flex;
  align-items: center;
  gap: 32px;
}

.hdr-logo {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
}
.hdr-logoImg {
  height: 26px;
  width: auto;
  display: block;
}

.hdr-nav {
  display: flex;
  gap: 24px;
  flex: 1;
}

.hdr-nav a {
  font-size: 14px;
  font-weight: 500;
  color: var(--ink-secondary);
  transition: color 0.15s;
}
.hdr-nav a:hover { color: var(--ink); }

.hdr-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}

.hdr-loginLink {
  font-size: 14px;
  font-weight: 500;
  color: var(--ink-secondary);
  transition: color 0.15s;
}
.hdr-loginLink:hover { color: var(--ink); }

.hdr-ctaBtn {
  display: inline-flex;
  align-items: center;
  background: var(--primary-grad);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  padding: 9px 18px;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-primary);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
  white-space: nowrap;
}
.hdr-ctaBtn:hover { transform: translateY(-1px); box-shadow: var(--shadow-primary-hover); }
.hdr-ctaBtn:active { transform: translateY(0); }

.hdr-burger {
  display: none;
  margin-left: auto;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--ink);
  padding: 4px;
}
.hdr-burger .hdr-icon-x { display: none; }
.hdr-burger.hdr-burger--open .hdr-icon-menu { display: none; }
.hdr-burger.hdr-burger--open .hdr-icon-x { display: block; }

.hdr-mobileMenu {
  display: none;
  flex-direction: column;
  gap: 4px;
  padding: 12px 24px 20px;
  border-top: 1px solid var(--border);
}
.hdr-mobileMenu a {
  font-size: 15px;
  font-weight: 500;
  color: var(--ink-secondary);
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
}
.hdr-mobileMenu a:last-child { border-bottom: none; }
.hdr-mobileMenu .hdr-ctaBtn {
  margin-top: 8px;
  justify-content: center;
}

@media (max-width: 768px) {
  .hdr-nav, .hdr-actions { display: none; }
  .hdr-burger { display: flex; }
  .hdr-mobileMenu.hdr-mobileMenu--open { display: flex; }
}

/* === 02-hero === */
.hero-hero {
  position: relative;
  padding: 104px 24px 120px;
  overflow: hidden;
  background:
    radial-gradient(60% 80% at 78% 12%, rgba(91,111,255,.10) 0%, rgba(91,111,255,0) 60%),
    radial-gradient(50% 60% at 8% 95%, rgba(48,86,245,.07) 0%, rgba(48,86,245,0) 60%),
    linear-gradient(180deg, #FFFFFF 0%, var(--bg-page) 100%);
}

/* subtle dotted grid texture behind the hero — reads as "engineered" */
.hero-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(11,18,32,.045) 1px, transparent 1px);
  background-size: 22px 22px;
  -webkit-mask-image: radial-gradient(70% 60% at 50% 30%, #000 0%, transparent 75%);
  mask-image: radial-gradient(70% 60% at 50% 30%, #000 0%, transparent 75%);
  pointer-events: none;
}

.hero-inner {
  position: relative;
  z-index: 1;
  max-width: 1160px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}

.hero-content {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* Фиксированный хедлайн-«крыша» над слайдером — единый h1, не зависит от слайда */
.hero-umbrella {
  font-size: 21px;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -0.4px;
  color: var(--ink);
  max-width: 540px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--border);
}

.hero-slideText {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

@keyframes hero-fadeUp {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

.hero-slideText {
  animation: hero-fadeUp 0.4s ease both;
}

@media (prefers-reduced-motion: reduce) {
  .hero-slideText { animation: none; }
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-secondary);
  background: rgba(255,255,255,0.7);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 6px 14px 6px 10px;
  width: fit-content;
  box-shadow: var(--shadow-xs);
  backdrop-filter: blur(4px);
}

.hero-badgeDot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--success);
  flex-shrink: 0;
  box-shadow: 0 0 0 3px rgba(15,174,115,.18);
}

.hero-title {
  font-size: 48px;
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -2px;
  color: var(--ink);
}

.hero-subtitle {
  font-size: 17px;
  line-height: 1.65;
  color: var(--ink-secondary);
  max-width: 480px;
}

.hero-bullets {
  display: flex;
  flex-direction: column;
  gap: 10px;
  list-style: none;
}

.hero-bullets li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 15px;
  font-weight: 500;
  color: var(--ink);
}

.hero-check {
  color: var(--success);
  flex-shrink: 0;
}

.hero-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 4px;
}

.hero-primaryCta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--primary-grad);
  color: #fff;
  font-size: 15px;
  font-weight: 600;
  padding: 14px 26px;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-primary);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.hero-primaryCta:hover { transform: translateY(-2px); box-shadow: var(--shadow-primary-hover); }
.hero-primaryCta:active { transform: translateY(0); }
.hero-primaryCta svg { transition: transform 0.15s ease; }
.hero-primaryCta:hover svg { transform: translateX(3px); }

.hero-secondaryCta {
  display: inline-flex;
  align-items: center;
  font-size: 15px;
  font-weight: 600;
  color: var(--ink);
  background: var(--surface);
  border: 1px solid var(--border);
  padding: 14px 24px;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-xs);
  transition: border-color 0.15s, box-shadow 0.15s, transform 0.15s;
}
.hero-secondaryCta:hover { border-color: var(--border-strong); box-shadow: var(--shadow-card); transform: translateY(-1px); }

.hero-freeNote {
  font-size: 13px;
  color: var(--ink-tertiary);
}

/* Slider controls */
.hero-controls {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 8px;
}

.hero-arrow {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--ink-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.15s;
  flex-shrink: 0;
}
.hero-arrow:hover { border-color: var(--border-strong); color: var(--ink); }

.hero-dots {
  display: flex;
  gap: 8px;
  flex: 1;
}

.hero-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  border: none;
  background: var(--border-strong);
  cursor: pointer;
  padding: 0;
  transition: all 0.2s;
}
.hero-dotActive {
  width: 24px;
  background: var(--primary);
}

/* Report card visual */
.hero-visual {
  display: flex;
  justify-content: center;
}

.hero-reportCard {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-modal);
  padding: 26px;
  width: 100%;
  max-width: 380px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  animation: hero-fadeUp 0.4s ease both;
}

/* gradient halo behind the card to lift it off the page */
.hero-reportCard::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(160deg, rgba(91,111,255,.45), rgba(91,111,255,0) 40%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}

@media (prefers-reduced-motion: reduce) {
  .hero-reportCard { animation: none; }
}

.hero-reportHeader {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.hero-reportName {
  font-size: 16px;
  font-weight: 600;
  color: var(--ink);
}

.hero-reportRole {
  font-size: 13px;
  color: var(--ink-secondary);
  margin-top: 2px;
}

.hero-gradeChip {
  background: var(--grade-mid-bg);
  color: var(--grade-mid-fg);
  font-size: 12px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: var(--radius-sm);
}

.hero-gradeChipSen {
  background: var(--grade-sen-bg);
  color: var(--grade-sen-fg);
  font-size: 12px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: var(--radius-sm);
}

.hero-matchLabel {
  font-size: 12px;
  font-weight: 500;
  color: var(--ink-secondary);
  margin-bottom: 8px;
}

.hero-matchRow {
  display: flex;
  align-items: center;
  gap: 12px;
}

.hero-matchBarWrap {
  flex: 1;
  height: 6px;
  background: var(--surface-muted);
  border-radius: 999px;
  overflow: hidden;
}

.hero-matchBar {
  height: 100%;
  border-radius: 999px;
  transition: width 0.6s ease;
}

.hero-matchScore {
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
  flex-shrink: 0;
}

.hero-matchVacancy {
  font-size: 12px;
  color: var(--ink-tertiary);
  margin-top: 6px;
}

.hero-gapsLabel {
  font-size: 12px;
  font-weight: 600;
  color: var(--ink-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.hero-gaps {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.hero-gapItem {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  background: var(--surface-muted);
  border-radius: var(--radius-sm);
}

.hero-gapTopic {
  font-size: 13px;
  font-weight: 500;
  color: var(--ink);
}

.hero-gapLevel {
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 999px;
}

.hero-gapCritical {
  background: var(--danger-soft);
  color: var(--danger);
}

.hero-gapMedium {
  background: #FEF3C7;
  color: #D97706;
}

.hero-passport {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 500;
  color: var(--success-text);
  background: #ECFDF5;
  border-radius: var(--radius-sm);
  padding: 8px 12px;
}

.hero-passportIcon { font-size: 16px; }

@media (max-width: 900px) {
  .hero-inner {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .hero-title {
    font-size: 36px;
  }
  .hero-visual {
    order: -1;
  }
}

@media (max-width: 480px) {
  .hero-hero { padding: 48px 16px 64px; }
  .hero-title { font-size: 30px; }
}

/* === 03-trustbar === */
.tb-trustBar {
  background: var(--ink-button-grad);
  padding: 36px 24px 28px;
}

.tb-inner {
  max-width: 1160px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 40px;
}

.tb-part {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-width: 0;
}

.tb-partLabel {
  font-size: 13px;
  font-weight: 500;
  color: rgba(255,255,255,0.55);
}
.tb-partLabel strong { color: rgba(255,255,255,0.9); font-weight: 600; }

.tb-divider {
  width: 1px;
  align-self: stretch;
  background: rgba(255,255,255,0.12);
  flex-shrink: 0;
}

.tb-logos {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 28px;
  align-items: center;
}

.tb-logo {
  font-size: 18px;
  font-weight: 700;
  color: rgba(255,255,255,0.85);
  letter-spacing: -0.3px;
}

.tb-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.tb-award {
  font-size: 12px;
  font-weight: 500;
  color: rgba(255,255,255,0.7);
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 999px;
  padding: 5px 12px;
}

/* Членство в АПКИТ — выделяем как маркер легитимности, а не рядовую награду */
.tb-member {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 600;
  color: #fff;
  background: rgba(124,58,237,0.22);
  border-color: rgba(124,58,237,0.45);
}

.tb-message {
  max-width: 1160px;
  margin: 22px auto 0;
  text-align: center;
  font-size: 14px;
  font-weight: 500;
  color: rgba(255,255,255,0.5);
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,0.08);
}

@media (max-width: 820px) {
  .tb-inner { flex-direction: column; align-items: flex-start; gap: 28px; }
  .tb-divider { display: none; }
}

/* === 04-about === */
.ab-section {
  padding: var(--section-pad) 24px;
  background: var(--bg-tint);
}

.ab-inner {
  max-width: 1160px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}

.ab-content {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.ab-eyebrow {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  font-size: 12px;
  font-weight: 600;
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  background: var(--primary-soft);
  border-radius: 999px;
  padding: 5px 12px;
}

.ab-title {
  font-size: 40px;
  font-weight: 800;
  letter-spacing: -1.4px;
  color: var(--ink);
  line-height: 1.1;
}

.ab-lead {
  font-size: 16px;
  line-height: 1.7;
  color: var(--ink-secondary);
}
.ab-lead strong { color: var(--ink); font-weight: 600; }

.ab-note {
  font-size: 15px;
  line-height: 1.65;
  color: var(--ink-secondary);
  padding-left: 16px;
  border-left: 3px solid var(--primary);
}

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

.ab-fact {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px;
  box-shadow: var(--shadow-card);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.ab-fact:hover { transform: translateY(-2px); box-shadow: var(--shadow-card-hover); }

.ab-iconWrap {
  width: 40px;
  height: 40px;
  flex-shrink: 0;
  border-radius: var(--radius-md);
  background: var(--grade-sen-bg);
  color: var(--grade-sen-fg);
  display: flex;
  align-items: center;
  justify-content: center;
}

.ab-factValue {
  font-size: 17px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.3px;
  margin-bottom: 4px;
}

.ab-factLabel {
  font-size: 13px;
  line-height: 1.5;
  color: var(--ink-secondary);
}

@media (max-width: 900px) {
  .ab-inner { grid-template-columns: 1fr; gap: 40px; }
}
@media (max-width: 480px) {
  .ab-title { font-size: 26px; }
}

/* === 05-problems === */
.prob-section {
  padding: var(--section-pad) 24px;
  background: var(--surface);
}

.prob-inner {
  max-width: 1160px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 48px;
}

.prob-header {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 560px;
}

.prob-title {
  font-size: 42px;
  font-weight: 800;
  letter-spacing: -1.5px;
  color: var(--ink);
  line-height: 1.08;
}

.prob-subtitle {
  font-size: 16px;
  color: var(--ink-secondary);
  line-height: 1.6;
}

.prob-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.prob-card {
  background: var(--bg-tint);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px 24px;
  display: flex;
  gap: 14px;
  align-items: flex-start;
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}
.prob-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-card); background: var(--surface); }

.prob-icon {
  color: var(--danger);
  flex-shrink: 0;
  margin-top: 2px;
}

.prob-text {
  font-size: 15px;
  line-height: 1.55;
  color: var(--ink);
}

@media (max-width: 680px) {
  .prob-grid { grid-template-columns: 1fr; }
  .prob-title { font-size: 28px; }
}

/* === 06-howitworks === */
.hiw-section {
  padding: var(--section-pad) 24px;
  background: var(--bg-tint);
}

.hiw-inner {
  max-width: 1160px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 56px;
}

.hiw-header {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 600px;
}

.hiw-eyebrow {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  font-size: 12px;
  font-weight: 600;
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  background: var(--primary-soft);
  border-radius: 999px;
  padding: 5px 12px;
}

.hiw-title {
  font-size: 40px;
  font-weight: 800;
  letter-spacing: -1.4px;
  color: var(--ink);
  line-height: 1.1;
}

.hiw-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}

.hiw-step {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.hiw-stepTop {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 4px;
}

.hiw-iconWrap {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  background: var(--tech-bg);
  color: var(--tech-text);
  display: flex;
  align-items: center;
  justify-content: center;
}

.hiw-stepNum {
  font-size: 36px;
  font-weight: 700;
  color: var(--border);
  letter-spacing: -1px;
}

.hiw-stepTitle {
  font-size: 16px;
  font-weight: 600;
  color: var(--ink);
}

.hiw-stepDesc {
  font-size: 14px;
  line-height: 1.6;
  color: var(--ink-secondary);
}

.hiw-variants {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px dashed var(--border);
}

.hiw-variant {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.hiw-variantTag {
  align-self: flex-start;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: var(--tech-text);
  background: var(--tech-bg);
  border-radius: 999px;
  padding: 2px 8px;
}

.hiw-variantText {
  font-size: 12.5px;
  line-height: 1.45;
  color: var(--ink-secondary);
}

@media (max-width: 900px) {
  .hiw-steps { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px) {
  .hiw-steps { grid-template-columns: 1fr; }
  .hiw-title { font-size: 26px; }
}

/* === 07-deliverables === */
.del-section {
  padding: var(--section-pad) 24px;
  background: var(--surface);
}

.del-inner {
  max-width: 1160px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 48px;
}

.del-header {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 600px;
}

.del-eyebrow {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  font-size: 12px;
  font-weight: 600;
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  background: var(--primary-soft);
  border-radius: 999px;
  padding: 5px 12px;
}

.del-title {
  font-size: 40px;
  font-weight: 800;
  letter-spacing: -1.4px;
  color: var(--ink);
  line-height: 1.1;
}

.del-subtitle {
  font-size: 16px;
  color: var(--ink-secondary);
  line-height: 1.6;
}

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

.del-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  box-shadow: var(--shadow-card);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.del-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-card-hover); }

.del-iconWrap {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
}

.del-cardTitle {
  font-size: 16px;
  font-weight: 600;
  color: var(--ink);
}

.del-cardDesc {
  font-size: 14px;
  line-height: 1.6;
  color: var(--ink-secondary);
}

@media (max-width: 900px) {
  .del-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .del-grid { grid-template-columns: 1fr; }
  .del-title { font-size: 26px; }
}

/* === 08-reportshowcase === */
.rs-section {
  padding: var(--section-pad) 24px;
  background: var(--bg-tint);
}

.rs-inner {
  max-width: 1160px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 48px;
}

.rs-header {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 600px;
}

.rs-eyebrow {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  font-size: 12px;
  font-weight: 600;
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  background: var(--primary-soft);
  border-radius: 999px;
  padding: 5px 12px;
}

.rs-title {
  font-size: 40px;
  font-weight: 800;
  letter-spacing: -1.4px;
  color: var(--ink);
  line-height: 1.1;
}

.rs-subtitle {
  font-size: 16px;
  color: var(--ink-secondary);
  line-height: 1.6;
}

.rs-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 24px;
  align-items: start;
}

/* Report panel */
.rs-reportPanel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  box-shadow: var(--shadow-card);
}

.rs-panelHead {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}

.rs-panelTitle {
  font-size: 16px;
  font-weight: 600;
  color: var(--ink);
}

.rs-panelSub {
  font-size: 13px;
  color: var(--ink-secondary);
  margin-top: 4px;
}

.rs-gradeChip {
  background: var(--grade-mid-bg);
  color: var(--grade-mid-fg);
  font-size: 12px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: var(--radius-sm);
}

.rs-scoreSummary {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 18px;
  background: linear-gradient(135deg, var(--success-soft) 0%, rgba(231,249,241,0) 90%);
  border: 1px solid rgba(15,174,115,.22);
  border-radius: var(--radius-md);
}

.rs-scoreBig {
  font-size: 40px;
  font-weight: 700;
  color: var(--success-text);
  letter-spacing: -1px;
  line-height: 1;
}
.rs-scoreBig span {
  font-size: 18px;
  color: var(--ink-tertiary);
  font-weight: 600;
}

.rs-scoreLabel {
  font-size: 13px;
  color: var(--ink-secondary);
  line-height: 1.5;
}
.rs-scoreLabel strong { color: var(--ink); font-weight: 600; }

.rs-skillsLabel {
  font-size: 12px;
  font-weight: 600;
  color: var(--ink-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.rs-skills {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.rs-skillRow {
  display: grid;
  grid-template-columns: 160px 1fr 32px;
  align-items: center;
  gap: 12px;
}

.rs-skillTopic {
  font-size: 13px;
  font-weight: 500;
  color: var(--ink);
}

.rs-skillBarWrap {
  height: 6px;
  background: var(--surface-muted);
  border-radius: 999px;
  overflow: hidden;
}

.rs-skillBar {
  height: 100%;
  border-radius: 999px;
}

.rs-skillScore {
  font-size: 13px;
  font-weight: 600;
  color: var(--ink-secondary);
  text-align: right;
}

.rs-priorities {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-top: 20px;
  border-top: 1px solid var(--border);
}

.rs-priorityItem {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13px;
  line-height: 1.5;
  color: var(--ink-secondary);
}
.rs-priorityItem strong { color: var(--ink); font-weight: 600; }

.rs-iconBad { color: var(--danger); flex-shrink: 0; margin-top: 1px; }
.rs-iconGood { color: var(--success); flex-shrink: 0; margin-top: 1px; }
/* Миниатюры артефактов (сбоку от полного отчёта) */
.rs-thumbs {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.rs-thumbsLabel {
  font-size: 12px;
  font-weight: 600;
  color: var(--ink-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.rs-thumb {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 16px 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  box-shadow: var(--shadow-card);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.rs-thumb:hover { transform: translateY(-2px); box-shadow: var(--shadow-card-hover); }

.rs-thumbDark {
  background: linear-gradient(160deg, #0F172A 0%, #1E293B 100%);
  border-color: transparent;
  box-shadow: var(--shadow-modal);
}

.rs-thumbTop {
  display: flex;
  align-items: center;
  gap: 8px;
}

.rs-thumbIcon { color: var(--primary); flex-shrink: 0; }
.rs-thumbIconLight { color: rgba(255,255,255,0.85); flex-shrink: 0; }

.rs-thumbTitle {
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
}
.rs-thumbTitleLight {
  font-size: 14px;
  font-weight: 600;
  color: #fff;
}

.rs-thumbBadge {
  margin-left: auto;
  font-size: 11px;
  font-weight: 700;
  color: var(--grade-mid-fg);
  background: var(--grade-mid-bg);
  border-radius: 999px;
  padding: 2px 8px;
  white-space: nowrap;
}

.rs-thumbDesc {
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--ink-secondary);
}
.rs-thumbDescLight {
  font-size: 12.5px;
  line-height: 1.5;
  color: rgba(255,255,255,0.6);
}

/* Passport thumb */
.rs-thumbGradeRow {
  display: flex;
  align-items: center;
  gap: 10px;
}
.rs-thumbGradeValue {
  font-size: 18px;
  font-weight: 700;
  color: var(--grade-mid-bg);
  letter-spacing: -0.3px;
}
.rs-thumbVerified {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 500;
  color: rgba(255,255,255,0.7);
}

/* Vacancy Match thumb — точки-индикаторы статусов */
.rs-thumbDots {
  display: flex;
  gap: 6px;
}
.rs-thumbDot {
  width: 16px;
  height: 8px;
  border-radius: 999px;
}

/* ИПР thumb — прогресс-бар */
.rs-thumbBarWrap {
  height: 8px;
  background: var(--surface-muted);
  border-radius: 999px;
  overflow: hidden;
}
.rs-thumbBar {
  height: 100%;
  border-radius: 999px;
  background: var(--success);
}

@media (max-width: 820px) {
  .rs-grid { grid-template-columns: 1fr; }
}
@media (max-width: 520px) {
  .rs-title { font-size: 26px; }
  .rs-skillRow { grid-template-columns: 120px 1fr 28px; gap: 8px; }
  .rs-skillTopic { font-size: 12px; }
}

/* === 09-passportdemo === */
.pd-section {
  padding: var(--section-pad) 24px;
  background: var(--surface);
}

.pd-inner {
  max-width: 1160px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 64px;
  align-items: center;
}

/* Реальный паспорт — скриншот в рамке-«окне браузера» */
.pd-cardWrap {
  display: flex;
  justify-content: center;
}

.pd-frame {
  width: 100%;
  max-width: 440px;
  margin: 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-modal);
}

.pd-frameBar {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 11px 14px;
  background: var(--surface-muted);
  border-bottom: 1px solid var(--border);
}

.pd-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--border-strong);
  flex-shrink: 0;
}

.pd-frameUrl {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-left: 8px;
  font-size: 12px;
  color: var(--ink-secondary);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 4px 12px;
  font-variant-numeric: tabular-nums;
}

/* Окно фиксированной высоты со скроллом — даёт ощущение «живого» документа */
.pd-shot {
  height: 460px;
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: thin;
}

.pd-shot img {
  display: block;
  width: 100%;
  height: auto;
}

/* Объяснение */
.pd-content {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.pd-eyebrow {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  font-size: 12px;
  font-weight: 600;
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  background: var(--primary-soft);
  border-radius: 999px;
  padding: 5px 12px;
}

.pd-title {
  font-size: 40px;
  font-weight: 800;
  letter-spacing: -1.4px;
  color: var(--ink);
  line-height: 1.1;
}

.pd-lead {
  font-size: 16px;
  line-height: 1.7;
  color: var(--ink-secondary);
}

.pd-points {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 8px;
}

.pd-point {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}

.pd-pointIcon {
  width: 38px;
  height: 38px;
  flex-shrink: 0;
  border-radius: var(--radius-md);
  background: var(--tech-bg);
  color: var(--tech-text);
  display: flex;
  align-items: center;
  justify-content: center;
}

.pd-pointTitle {
  font-size: 15px;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 3px;
}

.pd-pointText {
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--ink-secondary);
}

@media (max-width: 900px) {
  .pd-inner { grid-template-columns: 1fr; gap: 40px; }
  .pd-cardWrap { order: 2; }
}
@media (max-width: 480px) {
  .pd-title { font-size: 26px; }
}

/* === 10-segments === */
.seg-section {
  padding: var(--section-pad) 24px;
  background: var(--bg-tint);
}

.seg-inner {
  max-width: 1160px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.seg-header {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.seg-eyebrow {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  font-size: 12px;
  font-weight: 600;
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  background: var(--primary-soft);
  border-radius: 999px;
  padding: 5px 12px;
}

.seg-title {
  font-size: 40px;
  font-weight: 800;
  letter-spacing: -1.4px;
  color: var(--ink);
  line-height: 1.1;
}

.seg-tabs {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.seg-tab {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--surface);
  font-size: 14px;
  font-weight: 500;
  color: var(--ink-secondary);
  cursor: pointer;
  transition: all 0.15s;
}
.seg-tab:hover { border-color: var(--border-strong); color: var(--ink); }

.seg-tabActive {
  background: var(--ink-button);
  border-color: var(--ink-button);
  color: #fff;
  box-shadow: var(--shadow-card);
}
.seg-tabActive:hover { color: #fff; }

.seg-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 36px 40px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  box-shadow: var(--shadow-card);
  max-width: 720px;
}

.seg-panelHidden {
  display: none;
}

.seg-tagRow {
  display: flex;
}

.seg-segTag {
  background: var(--tech-bg);
  color: var(--tech-text);
  font-size: 12px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: var(--radius-sm);
}

.seg-usp {
  font-size: 20px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.4;
}

.seg-bullets {
  display: flex;
  flex-direction: column;
  gap: 10px;
  list-style: none;
}

.seg-bullet {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 15px;
  color: var(--ink-secondary);
}

.seg-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--primary);
  flex-shrink: 0;
  margin-top: 7px;
}

.seg-footer {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
  padding-top: 8px;
  border-top: 1px solid var(--border);
}

.seg-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--primary-grad);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  padding: 11px 20px;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-primary);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.seg-cta:hover { transform: translateY(-1px); box-shadow: var(--shadow-primary-hover); }

.seg-price {
  font-size: 14px;
  font-weight: 500;
  color: var(--ink-secondary);
}

@media (max-width: 640px) {
  .seg-panel { padding: 24px 20px; }
  .seg-usp { font-size: 17px; }
  .seg-title { font-size: 26px; }
}

/* === 11-whytrust === */
.wt-section {
  padding: var(--section-pad) 24px;
  background: var(--surface);
}

.wt-inner {
  max-width: 1160px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 48px;
}

.wt-header {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.wt-eyebrow {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  font-size: 12px;
  font-weight: 600;
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  background: var(--primary-soft);
  border-radius: 999px;
  padding: 5px 12px;
}

.wt-title {
  font-size: 40px;
  font-weight: 800;
  letter-spacing: -1.4px;
  color: var(--ink);
  line-height: 1.1;
}

.wt-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.wt-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 24px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.wt-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-card-hover); }

.wt-iconWrap {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  background: var(--grade-sen-bg);
  color: var(--grade-sen-fg);
  display: flex;
  align-items: center;
  justify-content: center;
}

.wt-cardTitle {
  font-size: 15px;
  font-weight: 600;
  color: var(--ink);
}

.wt-cardDesc {
  font-size: 14px;
  line-height: 1.6;
  color: var(--ink-secondary);
}

.wt-honesty {
  background: #FFFBEB;
  border: 1px solid #FDE68A;
  border-radius: var(--radius-lg);
  padding: 20px 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.wt-honestyLabel {
  font-size: 12px;
  font-weight: 700;
  color: #D97706;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.wt-honestyText {
  font-size: 14px;
  color: #78350F;
  line-height: 1.6;
}
.wt-honestyText strong { font-weight: 600; }

@media (max-width: 900px) {
  .wt-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .wt-grid { grid-template-columns: 1fr; }
  .wt-title { font-size: 26px; }
}

/* === 12-testimonials === */
.tst-section {
  padding: var(--section-pad) 24px;
  background: var(--bg-tint);
}

.tst-inner {
  max-width: 1160px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 48px;
}

.tst-header {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 640px;
}

.tst-eyebrow {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  font-size: 12px;
  font-weight: 600;
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  background: var(--primary-soft);
  border-radius: 999px;
  padding: 5px 12px;
}

.tst-title {
  font-size: 40px;
  font-weight: 800;
  letter-spacing: -1.4px;
  color: var(--ink);
  line-height: 1.1;
}

.tst-subtitle {
  font-size: 16px;
  color: var(--ink-secondary);
  line-height: 1.6;
}

.tst-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.tst-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  box-shadow: var(--shadow-card);
  margin: 0;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.tst-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-card-hover); }

.tst-iconWrap {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  background: var(--tech-bg);
  color: var(--tech-text);
  display: flex;
  align-items: center;
  justify-content: center;
}

.tst-cardTitle {
  font-size: 16px;
  font-weight: 600;
  color: var(--ink);
}

.tst-cardText {
  font-size: 14px;
  line-height: 1.6;
  color: var(--ink-secondary);
}

.tst-note {
  font-size: 14px;
  color: var(--ink-secondary);
  text-align: center;
  padding-top: 8px;
}

@media (max-width: 700px) {
  .tst-grid { grid-template-columns: 1fr; }
  .tst-title { font-size: 26px; }
}

/* === 13-growthmethod === */
.gm-section {
  padding: var(--section-pad) 24px;
  background: var(--surface);
}

.gm-inner {
  max-width: 1160px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 64px;
  align-items: center;
}

.gm-content {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.gm-eyebrow {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  font-size: 12px;
  font-weight: 600;
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  background: var(--primary-soft);
  border-radius: 999px;
  padding: 5px 12px;
}

.gm-title {
  font-size: 40px;
  font-weight: 800;
  letter-spacing: -1.4px;
  color: var(--ink);
  line-height: 1.1;
}
.gm-accent {
  color: var(--tech-text);
  white-space: nowrap;
}

.gm-lead {
  font-size: 16px;
  line-height: 1.7;
  color: var(--ink-secondary);
}

/* ROI + цена бездействия */
.gm-roi {
  background: var(--bg-tint);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 4px;
}

.gm-roiRow {
  display: flex;
  align-items: center;
  gap: 16px;
}

.gm-roiCol {
  flex: 1;
  min-width: 0;
}

.gm-roiLabel {
  font-size: 12px;
  color: var(--ink-secondary);
  margin-bottom: 4px;
}

.gm-roiValue {
  font-size: 22px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.5px;
  line-height: 1.1;
}
.gm-roiGain { color: var(--success-text); }

.gm-roiSub {
  font-size: 11.5px;
  color: var(--ink-tertiary);
  margin-top: 4px;
  line-height: 1.4;
}

.gm-roiArrow {
  font-size: 20px;
  color: var(--ink-tertiary);
  flex-shrink: 0;
}

.gm-roiNote {
  font-size: 12.5px;
  line-height: 1.55;
  color: var(--ink-secondary);
  padding-top: 12px;
  border-top: 1px solid var(--border);
}
.gm-roiNote strong { color: var(--ink); font-weight: 600; }

.gm-principles {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 8px;
}

.gm-principle {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}

.gm-iconWrap {
  width: 40px;
  height: 40px;
  flex-shrink: 0;
  border-radius: var(--radius-md);
  background: var(--tech-bg);
  color: var(--tech-text);
  display: flex;
  align-items: center;
  justify-content: center;
}

.gm-principleTitle {
  font-size: 15px;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 3px;
}

.gm-principleText {
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--ink-secondary);
}

/* Визуал ИПР */
.gm-visual {
  display: flex;
  justify-content: center;
}

.gm-planCard {
  width: 100%;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  box-shadow: var(--shadow-card-hover);
}

.gm-planHead {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.gm-planTitle {
  font-size: 15px;
  font-weight: 600;
  color: var(--ink);
}

.gm-planSub {
  font-size: 12.5px;
  color: var(--ink-secondary);
  margin-top: 3px;
}

.gm-planProgress {
  font-size: 13px;
  font-weight: 700;
  color: var(--ink-secondary);
  white-space: nowrap;
}

.gm-barWrap {
  height: 8px;
  background: var(--surface-muted);
  border-radius: 999px;
  overflow: hidden;
}
.gm-bar {
  height: 100%;
  border-radius: 999px;
  background: var(--success);
}

.gm-eta {
  font-size: 12.5px;
  color: var(--ink-secondary);
  margin-top: -4px;
}

.gm-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 4px;
}

.gm-item {
  display: grid;
  grid-template-columns: 16px 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  background: var(--bg-tint);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
}

.gm-itemDone .gm-itemTopic {
  color: var(--ink-tertiary);
  text-decoration: line-through;
}

.gm-itemTopic {
  font-size: 13px;
  color: var(--ink);
  line-height: 1.4;
}

.gm-itemTag {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: var(--tech-text);
  background: var(--tech-bg);
  border-radius: 999px;
  padding: 2px 8px;
  white-space: nowrap;
}

.gm-iconGood { color: var(--success); flex-shrink: 0; }
.gm-iconActive { color: var(--warning); flex-shrink: 0; }
.gm-iconTodo { color: var(--ink-tertiary); flex-shrink: 0; }

.gm-reassess {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--ink-secondary);
  padding-top: 12px;
  border-top: 1px solid var(--border);
}

@media (max-width: 900px) {
  .gm-inner { grid-template-columns: 1fr; gap: 40px; }
}
@media (max-width: 480px) {
  .gm-title { font-size: 26px; }
  .gm-accent { white-space: normal; }
  .gm-roiRow { flex-direction: column; align-items: stretch; gap: 12px; }
  .gm-roiArrow { transform: rotate(90deg); align-self: center; }
}

/* === 14-pricing === */
.pr-section {
  padding: var(--section-pad) 24px;
  background: var(--bg-tint);
}

.pr-inner {
  max-width: 1160px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 48px;
}

.pr-header {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 600px;
}

.pr-eyebrow {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  font-size: 12px;
  font-weight: 600;
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  background: var(--primary-soft);
  border-radius: 999px;
  padding: 5px 12px;
}

.pr-title {
  font-size: 40px;
  font-weight: 800;
  letter-spacing: -1.4px;
  color: var(--ink);
  line-height: 1.1;
}

.pr-subtitle {
  font-size: 16px;
  color: var(--ink-secondary);
  line-height: 1.6;
}

.pr-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  align-items: start;
}

.pr-card {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  box-shadow: var(--shadow-card);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.pr-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-card-hover); }

.pr-cardHighlighted {
  border-color: transparent;
  box-shadow: 0 0 0 2px var(--primary), var(--shadow-card-hover);
}
.pr-cardHighlighted::before {
  content: '';
  position: absolute;
  inset: -20px -8px -8px;
  background: radial-gradient(60% 50% at 50% 0%, rgba(48,86,245,.16) 0%, rgba(48,86,245,0) 70%);
  border-radius: var(--radius-xl);
  z-index: -1;
  pointer-events: none;
}
.pr-cardHighlighted:hover { transform: translateY(-4px); }

.pr-popularBadge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--primary-grad);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 5px 14px;
  border-radius: 999px;
  white-space: nowrap;
  letter-spacing: 0.3px;
  box-shadow: var(--shadow-primary);
}

.pr-cardTop {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.pr-planName {
  font-size: 14px;
  font-weight: 600;
  color: var(--ink-secondary);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.pr-priceRow {
  display: flex;
  align-items: baseline;
  gap: 8px;
  flex-wrap: wrap;
}

.pr-price {
  font-size: 28px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.5px;
}

.pr-priceSale {
  font-size: 14px;
  font-weight: 600;
  color: var(--ink-secondary);
  text-decoration: line-through;
}

.pr-saleBadge {
  font-size: 11px;
  font-weight: 500;
  color: var(--success-text);
  background: #ECFDF5;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  width: fit-content;
}

.pr-priceSub {
  font-size: 12px;
  color: var(--ink-tertiary);
}

.pr-planDesc {
  font-size: 14px;
  color: var(--ink-secondary);
  line-height: 1.5;
  margin-top: 4px;
}

.pr-features {
  display: flex;
  flex-direction: column;
  gap: 8px;
  list-style: none;
  flex: 1;
}

.pr-feature {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 13px;
  color: var(--ink);
  line-height: 1.4;
}

.pr-featureCheck {
  color: var(--success);
  flex-shrink: 0;
  margin-top: 2px;
}

.pr-cta {
  display: block;
  text-align: center;
  font-size: 14px;
  font-weight: 600;
  padding: 11px 16px;
  border-radius: var(--radius-md);
  transition: all 0.15s;
  border: 1px solid transparent;
}

.pr-cta_primary {
  background: var(--primary-grad);
  color: #fff;
  box-shadow: var(--shadow-primary);
}
.pr-cta_primary:hover { box-shadow: var(--shadow-primary-hover); transform: translateY(-1px); }

.pr-cta_secondary {
  background: var(--surface);
  color: var(--ink);
  border-color: var(--border);
}
.pr-cta_secondary:hover { border-color: var(--border-strong); }

.pr-cta_dark {
  background: var(--ink-button);
  color: #fff;
}
.pr-cta_dark:hover { background: var(--ink-button-hover); }

/* AI upsell strip */
.pr-aiUpsell {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px 24px;
  box-shadow: var(--shadow-card);
}

.pr-aiIcon { font-size: 24px; flex-shrink: 0; }

.pr-aiTitle {
  font-size: 15px;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 4px;
}

.pr-aiDesc {
  font-size: 14px;
  color: var(--ink-secondary);
  line-height: 1.55;
}

@media (max-width: 1024px) {
  .pr-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .pr-grid { grid-template-columns: 1fr; }
  .pr-title { font-size: 26px; }
}

/* === 15-faq === */
.faq-section {
  padding: var(--section-pad) 24px;
  background: var(--surface);
}

.faq-inner {
  max-width: 760px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.faq-header {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.faq-eyebrow {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  font-size: 12px;
  font-weight: 600;
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  background: var(--primary-soft);
  border-radius: 999px;
  padding: 5px 12px;
}

.faq-title {
  font-size: 40px;
  font-weight: 800;
  letter-spacing: -1.4px;
  color: var(--ink);
  line-height: 1.1;
}

.faq-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--surface);
  box-shadow: var(--shadow-card);
}

.faq-item {
  border-bottom: 1px solid var(--border);
}
.faq-item:last-child { border-bottom: none; }

.faq-question {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 24px;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  font-size: 15px;
  font-weight: 500;
  color: var(--ink);
  transition: background 0.12s;
}
.faq-question:hover { background: var(--surface-muted); }

.faq-chevron {
  flex-shrink: 0;
  color: var(--ink-tertiary);
  transition: transform 0.2s;
}
.faq-chevronOpen { transform: rotate(180deg); }

.faq-answer {
  padding: 0 24px 18px;
  font-size: 14px;
  line-height: 1.65;
  color: var(--ink-secondary);
}

@media (max-width: 560px) {
  .faq-title { font-size: 26px; }
  .faq-question { padding: 16px 16px; }
  .faq-answer { padding: 0 16px 16px; }
}

/* === 16-finalcta === */
.fcta-section {
  position: relative;
  padding: var(--section-pad) 24px;
  background:
    radial-gradient(60% 120% at 50% 0%, rgba(48,86,245,.35) 0%, rgba(48,86,245,0) 55%),
    radial-gradient(50% 100% at 90% 100%, rgba(91,111,255,.25) 0%, rgba(91,111,255,0) 60%),
    var(--ink-button);
  overflow: hidden;
}

.fcta-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 24px 24px;
  -webkit-mask-image: radial-gradient(60% 60% at 50% 40%, #000, transparent 75%);
  mask-image: radial-gradient(60% 60% at 50% 40%, #000, transparent 75%);
  pointer-events: none;
}

.fcta-inner {
  position: relative;
  z-index: 1;
  max-width: 680px;
  margin: 0 auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}

.fcta-title {
  font-size: 40px;
  font-weight: 800;
  letter-spacing: -1.4px;
  color: #fff;
  line-height: 1.15;
}

.fcta-subtitle {
  font-size: 16px;
  color: rgba(255,255,255,0.6);
  line-height: 1.6;
}

.fcta-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
}

.fcta-primaryCta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #fff;
  color: var(--ink);
  font-size: 15px;
  font-weight: 700;
  padding: 14px 28px;
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px rgba(0,0,0,.28);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.fcta-primaryCta:hover { transform: translateY(-2px); box-shadow: 0 12px 32px rgba(0,0,0,.36); }
.fcta-primaryCta:active { transform: translateY(0); }

.fcta-secondaryCta {
  display: inline-flex;
  align-items: center;
  font-size: 15px;
  font-weight: 500;
  color: rgba(255,255,255,0.7);
  border: 1px solid rgba(255,255,255,0.2);
  padding: 13px 26px;
  border-radius: var(--radius-md);
  transition: border-color 0.15s, color 0.15s;
}
.fcta-secondaryCta:hover { border-color: rgba(255,255,255,0.4); color: #fff; }

@media (max-width: 560px) {
  .fcta-title { font-size: 26px; }
}

/* === 17-footer === */
.ftr-footer {
  background: var(--ink-button-grad);
  color: rgba(255,255,255,0.7);
}

.ftr-inner {
  max-width: 1160px;
  margin: 0 auto;
  padding: 56px 24px 48px;
  display: grid;
  grid-template-columns: 2fr 3fr;
  gap: 64px;
}

.ftr-brand {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.ftr-logo {
  display: inline-flex;
  align-items: center;
}
.ftr-logoImg {
  height: 26px;
  width: auto;
  display: block;
}

.ftr-tagline {
  font-size: 14px;
  line-height: 1.6;
  color: rgba(255,255,255,0.45);
  max-width: 260px;
}

.ftr-links {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}

.ftr-col {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.ftr-colTitle {
  font-size: 12px;
  font-weight: 600;
  color: rgba(255,255,255,0.5);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin-bottom: 4px;
}

.ftr-col a {
  font-size: 14px;
  color: rgba(255,255,255,0.65);
  transition: color 0.15s;
}
.ftr-col a:hover { color: #fff; }

.ftr-bottom {
  border-top: 1px solid rgba(255,255,255,0.1);
}

.ftr-bottomInner {
  max-width: 1160px;
  margin: 0 auto;
  padding: 20px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  font-size: 13px;
  color: rgba(255,255,255,0.4);
}

.ftr-legal {
  display: flex;
  gap: 20px;
}

.ftr-legal a {
  color: rgba(255,255,255,0.4);
  transition: color 0.15s;
}
.ftr-legal a:hover { color: rgba(255,255,255,0.7); }

@media (max-width: 768px) {
  .ftr-inner { grid-template-columns: 1fr; gap: 40px; }
  .ftr-links { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .ftr-links { grid-template-columns: 1fr; }
}
