/* ============================================================
   AI CJM — Components
   Готовые блоки/компоненты. Токены и сбросы — в tokens.css.
   ⚠️ Никаких #hex здесь. Только var(--…).
============================================================ */

/* ============================================================
   COMMON
============================================================ */
.container{
  width:100%;
  padding-left: var(--pad-x);
  padding-right: var(--pad-x);
}
.section{
  padding-top: var(--section-py);
  padding-bottom: var(--section-py);
  position:relative;
}
.section + .section{border-top: 1px solid var(--line)}
.section.dark{background: var(--bg-dark);color:#fff}
.section.dark + .section{border-top: none}
.section.soft{background: var(--bg-soft)}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:var(--muted);
  margin-bottom: 20px;
}
.eyebrow::before{
  content:"";width:8px;height:8px;border-radius:50%;background:var(--orange);
}

.h-section{
  margin:0 0 28px;
  font-weight:800;
  font-size: clamp(40px, 5.4vw, 84px);
  line-height: 1.02;
  letter-spacing: -.025em;
}
.h-section .a{color:var(--orange)}
.h-sub{
  max-width: 760px;
  font-size: clamp(17px, 1.4vw, 20px);
  line-height: 1.55;
  color: var(--ink-2);
  margin: 0 0 56px;
}
.h-sub b{font-weight:700;color:var(--ink)}
.dark .h-sub{color:#cfcac0}

/* ============================================================
   HEADER (sticky)
============================================================ */
.header{
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--bg);
  padding: 22px var(--pad-x);
  display:grid;
  grid-template-columns: auto 1fr auto;
  align-items:center;
  gap: 48px;
  border-bottom: 1px solid transparent;
  transition: border-color .2s ease, padding .2s ease;
}
.header.is-scrolled{
  border-bottom-color: var(--line);
  padding-top: 16px; padding-bottom: 16px;
}
.brand{
  display:flex;align-items:center;gap:18px;
  font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-size:13px;
}
.brand .dot{width:9px;height:9px;border-radius:50%;background:var(--orange);display:inline-block}
.brand .name{color:var(--ink);font-weight:800;letter-spacing:.06em}
.brand .sep{width:1px;height:16px;background:#bdb3a0;margin:0 4px}
.brand .section-name{color:#3b372f;font-weight:600;letter-spacing:.16em}

.nav{
  display:flex;justify-content:center;gap:clamp(20px, 2.6vw, 42px);
  font-weight:700;letter-spacing:.16em;text-transform:uppercase;font-size:12.5px;
}
.nav a{color:var(--ink);text-decoration:none;display:inline-flex;align-items:center;gap:8px}
.nav a:hover{color:var(--orange)}
.nav a .caret{
  display:inline-block;width:0;height:0;
  border-left:4px solid transparent;border-right:4px solid transparent;
  border-top:5px solid var(--orange);
  transform: translateY(1px);
}

/* ============================================================
   BUTTONS
============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:14px;
  border-radius: 999px;
  font-weight:800;letter-spacing:.14em;text-transform:uppercase;font-size:12.5px;
  cursor:pointer;border:1.5px solid var(--ink);background:transparent;color:var(--ink);
  padding: 14px 26px;
  white-space:nowrap;
  text-decoration:none;
  transition: background .15s ease, color .15s ease, transform .15s ease, box-shadow .15s ease, border-color .15s ease;
  font-family: inherit;
}
.btn:hover{background:var(--ink);color:#fff}
.btn .arrow{font-weight:700}
.btn-primary{
  background:var(--orange);border-color:var(--orange);color:#fff;
  box-shadow: 0 16px 32px -12px rgba(255,90,31,.55);
}
.btn-primary:hover{background:var(--orange-ink);border-color:var(--orange-ink);color:#fff}
.btn-lg{padding: 18px 32px;font-size:13.5px;letter-spacing:.16em}
.btn-ghost{border-color: rgba(255,255,255,.3);color:#fff}
.btn-ghost:hover{background:#fff;color:var(--ink);border-color:#fff}

/* ============================================================
   BLOCK 1 — HERO (100vh)
============================================================ */
.screen{
  min-height: 100vh;
  width: 100%;
  padding: 0;
  display:flex;
  flex-direction:column;
}
.hero{
  flex: 1 1 auto;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  gap: clamp(20px, 2.6vh, 32px);
  padding: clamp(24px, 4vh, 56px) var(--pad-x);
}
.hero h1{
  margin:0;
  font-weight:800;
  font-size: clamp(64px, 9.6vh, 140px);
  line-height: 1.04;
  letter-spacing: -.035em;
}
.hero h1 .accent{color:var(--orange);display:block;margin-top:.06em}
.hero-sub{
  max-width: 760px;
  font-size: clamp(18px, 2vh, 22px);
  line-height: 1.45;
  color: var(--ink-2);
  margin: 0;
}
.hero-sub b{font-weight:700;color:var(--ink)}
.hero-cta{
  margin-top: clamp(2px, .8vh, 8px);
  display:flex;flex-direction:column;align-items:center;
  gap: clamp(12px, 1.6vh, 18px);
}
.hero-cases{
  font-size: clamp(14px, 1.5vh, 16px);
  color: var(--ink-2);
  display:inline-flex;align-items:center;gap:6px;
}
.hero-cases a{
  color:var(--ink);font-weight:600;
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 1.5px;
}
.hero-cases a:hover{color:var(--orange)}

/* logos strip below hero */
.logo-strip{
  padding: clamp(28px, 4vh, 44px) var(--pad-x) clamp(28px, 4vh, 40px);
  border-bottom: 1px solid var(--line);
}
.logo-strip-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom: 14px;
}
.logo-strip-label{
  font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:#4a4538;
}
.logo-strip-more{font-size:13px;color:#3b372f;font-weight:500}
.logo-grid{
  display:grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 10px;
}
.logo-grid + .logo-grid{margin-top: 10px}
.logo-slot{
  height: 44px;
  border-radius: 10px;
  border: 1px dashed #b8ad96;
  background: rgba(255,255,255,.45);
  display:flex;align-items:center;justify-content:center;
  color:#9a907c;
  font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
}
.logo-slot.muted{opacity:.55}
.logo-slot.has-img{border:1px solid transparent;background:transparent;padding:6px}
.logo-slot.has-img img{max-height:30px;max-width:100%;width:auto;object-fit:contain;opacity:.92}
.logo-slot.has-img:hover img{opacity:1}

/* ============================================================
   BLOCK 2 — PAIN (лёгкий перечень)
============================================================ */
.pain-list-rows{
  display:flex;flex-direction:column;
  border-top: 1px solid var(--line);
  margin-top: 8px;
}
.pain-row{
  display:grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 56px;
  align-items: baseline;
  padding: 32px 0;
  border-bottom: 1px solid var(--line);
}
.pain-row .p-num{
  font-size: 14px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;
  color: var(--orange);
}
.pain-row .p-quote{
  font-size: clamp(24px, 2.4vw, 36px);
  font-weight:800;
  line-height: 1.15;
  letter-spacing:-.015em;
  margin:0;
  color: var(--ink);
}
.pain-row .p-desc{
  font-size: 15.5px;
  line-height: 1.55;
  color: var(--ink-2);
  margin:0;
}
.pain-row .p-desc em{
  color: var(--orange);
  font-style: normal;
  font-weight: 600;
}
.pain-bridge{
  margin-top: 64px;
  font-size: clamp(28px, 3.2vw, 44px);
  font-weight:800;
  line-height: 1.1;
  letter-spacing:-.02em;
  text-align:center;
}
.pain-bridge .a{color:var(--orange)}

@media (max-width: 900px){
  .pain-row{grid-template-columns: 1fr;gap: 14px}
}

/* ============================================================
   BLOCK 3 — FORMATS + CATALOG
============================================================ */
.format-group-label{
  display:flex;align-items:center;gap:14px;
  margin: 48px 0 20px;
}
.format-group-label .line{
  flex:1;height:1px;background:var(--line);
}
.format-group-label .txt{
  font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);
}

.formats-3{
  display:grid;grid-template-columns: repeat(3, 1fr);gap: 18px;
}
.formats-2{
  grid-template-columns: repeat(2, 1fr);
}
.format-card{
  background: var(--bg-card);
  border-radius: var(--r-lg);
  padding: 30px 28px;
  display:flex;flex-direction:column;gap:16px;
}
.format-card.wide{grid-column: 1 / -1}
.format-card .fc-label{
  font-size: 11px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color: var(--muted);
}
.format-card h3{
  margin:0;
  font-size: clamp(22px, 1.8vw, 28px);
  font-weight:800;
  line-height: 1.15;
  letter-spacing: -.01em;
}
.format-card .fc-tag{
  font-size:14px;color:var(--orange);font-weight:600;font-style:italic;
}
.format-card .fc-desc{font-size:14.5px;line-height:1.55;color:var(--ink-2);margin:0}
.format-card .fc-list{
  list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;
}
.format-card .fc-list li{
  font-size:13.5px;color:var(--ink-2);padding-left:18px;position:relative;line-height:1.45;
}
.format-card .fc-list li::before{
  content:"";position:absolute;left:0;top:8px;width:6px;height:1.5px;background:var(--orange);
}
.format-card .fc-foot{
  margin-top: auto;padding-top: 14px;border-top:1px dashed var(--line-soft);
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--muted);
}
.format-card .fc-foot .price{color: var(--ink)}

/* clients-strip inside a format card */
.fc-clients{
  margin-top: 12px;
  padding-top: 14px;
  border-top: 1px dashed var(--line-soft);
}
.fc-clients-label{
  font-size:10.5px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
  margin-bottom: 10px;
}
.fc-case-row{
  display:grid;
  grid-template-columns: 84px 1fr;
  gap: 14px;
  align-items: center;
  padding: 8px 0;
}
.fc-case-row + .fc-case-row{border-top: 1px dashed var(--line-soft)}
.fc-case-logo{
  height: 32px;
  border-radius: 6px;
  border: 1px dashed #c8be9f;
  background: rgba(255,255,255,.55);
  display:flex;align-items:center;justify-content:center;
  font-size: 9.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#a89e88;
}
.fc-case-desc{
  font-size: 12.5px;color: var(--ink-2);line-height: 1.4;
}
.fc-case-desc b{color: var(--ink);font-weight:700}

/* mid-section CTA banner */
.formats-cta{
  margin: 56px 0 64px;
  background: var(--bg-card);
  border-radius: var(--r-xl);
  padding: 28px 36px;
  display:flex;align-items:center;justify-content:space-between;gap: 28px;
  flex-wrap: wrap;
}
.formats-cta .txt{flex:1;min-width:280px}
.formats-cta h3{
  margin:0 0 6px;
  font-size: clamp(20px, 1.8vw, 26px);
  font-weight:800;letter-spacing:-.01em;line-height:1.2;
}
.formats-cta p{margin:0;font-size:15px;color:var(--ink-2);line-height:1.5}

.format-card.wide{
  display:grid;grid-template-columns: 1.1fr 1fr;gap: 28px;
  padding: 36px;
}
.format-card.wide .left{display:flex;flex-direction:column;gap:14px}
.format-card.wide .right{display:flex;flex-direction:column;gap:12px;border-left:1px solid var(--line);padding-left:28px}

/* catalog */
.catalog-wrap{margin-top: 72px}
.catalog{
  width:100%;
  border-collapse: separate;
  border-spacing: 0;
  background: var(--bg-card);
  border-radius: var(--r-lg);
  overflow:hidden;
}
.catalog th, .catalog td{
  text-align:left;
  padding: 18px 22px;
  font-size: 14px;
  vertical-align: top;
  border-bottom: 1px solid var(--line-soft);
}
.catalog th{
  font-size: 11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
  background: #fbf6ec;
}
.catalog tr:last-child td{border-bottom:none}
.catalog td.dir{font-weight:800;font-size:15.5px;width: 32%;color:var(--ink)}
.catalog td.what{color:var(--ink-2);width: 38%;line-height:1.5}
.catalog td.tools{color:var(--muted);width: 30%;font-size:13.5px}
.catalog-note{
  margin-top: 18px;
  font-size: 13.5px;
  color: var(--muted);
  font-style: italic;
  text-align: center;
}

/* ============================================================
   BLOCK 4 — PERSONAL AI OS
============================================================ */
.aios{
  display:grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 72px;
  align-items:center;
}
.aios-visual{
  position:relative;
  aspect-ratio: 1 / 1;
  border-radius: var(--r-xl);
  background:
    radial-gradient(55% 55% at 50% 50%, rgba(255,90,31,.14), transparent 65%),
    linear-gradient(160deg, #161616, #2a2a2a);
  overflow:hidden;
}
.aios-visual .grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 40px 40px;
  mask-image: radial-gradient(70% 70% at 50% 50%, #000, transparent);
}
.aios-net{
  position:absolute;inset:0;width:100%;height:100%;pointer-events:none;
}
.aios-net line{
  stroke: rgba(255,255,255,.16);
  stroke-width: 1;
  stroke-dasharray: 3 5;
}
.aios-center{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width: 34%;aspect-ratio:1;border-radius:50%;
  background: radial-gradient(circle at 32% 28%, #ffb087, var(--orange) 55%, #b8330d 100%);
  box-shadow:
    0 0 80px rgba(255,90,31,.5),
    inset 0 0 30px rgba(0,0,0,.25);
  display:flex;align-items:center;justify-content:center;text-align:center;
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 18px;
  line-height: 1.2;
  z-index: 3;
}
.aios-center::before{
  content:"";position:absolute;inset:-12%;border-radius:50%;
  border: 1.5px dashed rgba(255,255,255,.16);
  animation: spin 40s linear infinite;
}
.aios-center::after{
  content:"";position:absolute;inset:-26%;border-radius:50%;
  border: 1px solid rgba(255,255,255,.08);
}
@keyframes spin{ to { transform: rotate(360deg) } }

.aios-node{
  position:absolute;
  transform: translate(-50%,-50%);
  display:inline-flex;align-items:center;gap:10px;
  padding: 10px 14px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  color: rgba(255,255,255,.94);
  font-size: 12.5px;
  font-weight: 600;
  white-space: nowrap;
  backdrop-filter: blur(6px);
  z-index: 2;
  letter-spacing:.01em;
}
.aios-node .ic{
  width: 7px;height:7px;border-radius:50%;background: var(--orange);flex-shrink:0;
}
.aios-node.kind-llm  .ic{background:#6ce0c0}
.aios-node.kind-data .ic{background:#a3b6ff}
.aios-node.kind-team .ic{background:#ff9ec8}
.aios-node.kind-skill .ic{background:#ffd166}

.aios-features{
  display:grid;grid-template-columns:1fr 1fr;gap: 28px;margin-top: 48px;
}
.aios-feature{
  padding-top: 22px;border-top: 1px solid var(--line);
}
.aios-feature h4{
  margin:0 0 8px;
  font-size: 18px;font-weight:800;letter-spacing:-.005em;
}
.aios-feature p{margin:0;font-size:14.5px;line-height:1.55;color:var(--ink-2)}

.aios-chars{
  margin-top: 56px;padding-top: 32px;border-top: 1px solid var(--line);
}
.aios-chars-label{
  font-size:12px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:18px;
}
.aios-chars ul{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:1fr 1fr;gap: 14px 32px;
}
.aios-chars li{
  font-size:15px;line-height:1.5;color:var(--ink-2);
  padding-left: 22px;position:relative;
}
.aios-chars li::before{
  content:"";position:absolute;left:0;top:8px;width:10px;height:2px;background:var(--orange);
}

/* ============================================================
   BLOCK 5 — CASES
============================================================ */
.stats-row{
  display:grid;grid-template-columns: repeat(4, 1fr);gap: 32px;
  padding: 36px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  margin-bottom: 64px;
}
.stat .num{
  font-weight:800;font-size: clamp(40px, 4.4vw, 64px);
  line-height: 1;letter-spacing:-.02em;display:flex;align-items:baseline;
}
.stat .num .plus{color:var(--orange);margin-left:2px}
.stat .num .slash{color:var(--orange)}
.stat .label{
  margin-top:10px;font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#4a4538;
  line-height:1.4;
}
.stat .label .accent{color:var(--orange)}

.case{
  background: var(--bg-card);
  border-radius: var(--r-xl);
  padding: 40px;
  margin-bottom: 18px;
  display:grid;grid-template-columns: 1.1fr 1fr;gap: 40px;
  align-items: stretch;
}
.case-head{display:flex;flex-direction:column;gap:14px}
.case .label{
  font-size:11px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);
}
.case h3{
  margin:0;font-size: clamp(24px, 2.2vw, 34px);font-weight:800;line-height:1.15;letter-spacing:-.015em;
}
.case .industry{
  font-size:14px;color:var(--ink-2);font-style:italic;
}
.case .desc{font-size:15px;line-height:1.55;color:var(--ink-2);margin:0}
.case .effect{
  margin-top: auto;padding-top: 18px;border-top: 1px dashed var(--line-soft);
  font-size:15px;color:var(--ink);
}
.case .effect b{color:var(--orange);font-weight:700}

.case-table{
  background: #fbf6ec;
  border-radius: var(--r-lg);
  padding: 22px;
}
.case-table dl{margin:0;display:grid;grid-template-columns: 1fr 1fr;gap: 14px 18px}
.case-table dt{
  font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);
  grid-column: 1;
}
.case-table dd{
  font-size:14.5px;font-weight:600;color:var(--ink);margin:0;
  grid-column: 2;
}

/* ============================================================
   BLOCK 6 — TEAM
============================================================ */
.team-core{
  display:grid;grid-template-columns: repeat(2, 1fr);gap: 24px;margin-bottom: 40px;
}
.team-core .person{
  background: var(--bg-card);
  border-radius: var(--r-xl);
  padding: 36px;
  display:grid;grid-template-columns: auto 1fr;gap: 28px;
  align-items:center;
}
.avatar-lg{
  width: 120px;height:120px;border-radius:50%;
  background: linear-gradient(135deg, #ffd5be, #ff7e44);
  display:flex;align-items:center;justify-content:center;
  font-size:38px;font-weight:800;color:#fff;
  flex-shrink:0;
}
.avatar-lg.dark{background:linear-gradient(135deg,#3a3a3a,#0e0e0e)}
.avatar-lg.has-img{padding:0;overflow:hidden;background:#eee}
.avatar-lg.has-img img{width:100%;height:100%;object-fit:cover;display:block}
.team-core .role{
  font-size:11px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--orange);margin-bottom:8px;
}
.team-core h3{margin:0 0 10px;font-size:24px;font-weight:800;letter-spacing:-.01em}
.team-core p{margin:0;font-size:14.5px;line-height:1.55;color:var(--ink-2)}

.team-speakers{
  display:grid;grid-template-columns: repeat(3, 1fr);gap: 16px;
}
.speaker{
  background: var(--bg-card);
  border-radius: var(--r-lg);
  padding: 24px;
  display:flex;flex-direction:column;gap: 14px;
}
.speaker-head{display:flex;align-items:center;gap:14px}
.avatar-sm{
  width: 52px;height:52px;border-radius:50%;
  background: linear-gradient(135deg, #cfd9ff, #5774ff);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;font-weight:800;color:#fff;
  flex-shrink: 0;
}
.avatar-sm.a2{background:linear-gradient(135deg,#caf2d2,#2e8f47)}
.avatar-sm.a3{background:linear-gradient(135deg,#ffd6f2,#d34ab2)}
.avatar-sm.a4{background:linear-gradient(135deg,#ffd5be,#ff7e44)}
.avatar-sm.a5{background:linear-gradient(135deg,#fff1a8,#d49a00)}
.avatar-sm.a6{background:linear-gradient(135deg,#a8e5ff,#0073b3)}
.avatar-sm.has-img{padding:0;overflow:hidden;background:#eee}
.avatar-sm.has-img img{width:100%;height:100%;object-fit:cover;display:block}
.speaker h4{margin:0 0 4px;font-size:17px;font-weight:800;letter-spacing:-.01em;line-height:1.15}
.speaker .direction{
  font-size:12.5px;color:var(--orange);font-weight:700;letter-spacing:.01em;line-height:1.3;
}
.speaker-bio{
  margin-top: auto;padding-top: 14px;border-top: 1px dashed var(--line-soft);
}
.speaker-bio-label{
  font-size:10.5px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
  margin-bottom: 4px;
}
.speaker-bio p{margin:0;font-size:13.5px;line-height:1.5;color:var(--ink-2)}
.speaker-bio b{color:var(--ink);font-weight:700}

/* ============================================================
   BLOCK 7 — PROCESS
============================================================ */
.process{
  display:grid;grid-template-columns: repeat(3, 1fr);gap: 18px;
}
.step{
  background: var(--bg-card);
  border-radius: var(--r-xl);
  padding: 36px 32px;
  display:flex;flex-direction:column;gap: 18px;
  position:relative;
}
.step .step-head{
  display:flex;align-items:baseline;justify-content:space-between;gap:14px;
}
.step .num{
  font-size: 56px;font-weight:800;line-height:.9;color:var(--orange);
  letter-spacing:-.02em;
}
.step .duration{
  font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
  text-align:right;
}
.step .duration .free{color:var(--orange)}
.step h3{margin:0;font-size:22px;font-weight:800;letter-spacing:-.01em}
.step .what{font-size:14.5px;line-height:1.55;color:var(--ink-2);margin:0}
.step .get-label{
  font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
  margin-top: 8px;
}
.step ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.step ul li{
  font-size:13.5px;line-height:1.5;color:var(--ink-2);
  padding-left:18px;position:relative;
}
.step ul li::before{
  content:"";position:absolute;left:0;top:8px;width:6px;height:1.5px;background:var(--orange);
}

/* ============================================================
   BLOCK 8 — METHODOLOGY
============================================================ */
.method{
  display:grid;grid-template-columns:repeat(4, 1fr);gap: 16px;
}
.method-card{
  background: var(--bg-card);
  border-radius: var(--r-lg);
  padding: 24px;
  display:flex;flex-direction:column;gap:10px;
}
.method-card .m-num{
  font-size: 11px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--orange);
}
.method-card h3{margin:0;font-size: 18px;font-weight:800;letter-spacing:-.005em;line-height:1.25}
.method-card p{margin:0;font-size:13.5px;line-height:1.5;color:var(--ink-2)}
.method-card .means{
  margin-top: 8px;padding-top: 12px;border-top: 1px dashed var(--line-soft);
  font-size:12.5px;font-style:italic;color:var(--ink-2);line-height:1.5;
}
.method-card .means b{color:var(--orange);font-style:normal;font-weight:700}

/* ============================================================
   BLOCK 9 — RESULT + GUARANTEES
============================================================ */
.result-transfer{
  display:grid;grid-template-columns: repeat(5, 1fr);gap: 16px;margin-bottom: 80px;
}
.transfer-card{
  background: var(--bg-card);
  border-radius: var(--r-lg);
  padding: 22px;
  display:flex;flex-direction:column;gap:10px;
}
.transfer-card .t-label{
  font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--orange);
}
.transfer-card h4{margin:0;font-size:17px;font-weight:800;line-height:1.2}
.transfer-card p{margin:0;font-size:13.5px;line-height:1.5;color:var(--ink-2)}

.levels{
  display:grid;grid-template-columns: repeat(3, 1fr);gap: 18px;margin-bottom: 80px;
}
.levels-2{
  grid-template-columns: repeat(2, 1fr);
}
.level{
  border-radius: var(--r-xl);
  padding: 32px;
  display:flex;flex-direction:column;gap:14px;
  background: var(--bg-card);
}
.level .lvl{
  font-size:11px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--orange);
}
.level h4{margin:0;font-size:24px;font-weight:800;letter-spacing:-.01em}
.level .when{font-size:13px;color:var(--muted);font-weight:600}
.level p{margin:0;font-size:14.5px;line-height:1.55;color:var(--ink-2)}
.level.featured{background:var(--bg-dark);color:#fff}
.level.featured h4,.level.featured .lvl{color:#fff}
.level.featured .lvl{color:var(--orange)}
.level.featured p{color:#cfcac0}

.guarantees{
  display:grid;grid-template-columns: repeat(4, 1fr);gap: 18px;
}
.guarantee{
  background: var(--bg-card);
  border-radius: var(--r-lg);
  padding: 26px;
  display:flex;flex-direction:column;gap:10px;
}
.guarantee .g-num{
  font-size:36px;font-weight:800;color:var(--orange);line-height:1;letter-spacing:-.02em;
}
.guarantee h4{margin:0;font-size:17px;font-weight:800;letter-spacing:-.005em}
.guarantee p{margin:0;font-size:13.5px;line-height:1.5;color:var(--ink-2)}

/* ============================================================
   BLOCK 10 — CTA
============================================================ */
.cta-block{
  text-align:center;
}
.cta-block .h-section{margin-bottom: 20px}
.cta-block .cta-sub{
  max-width: 720px;
  margin: 0 auto 40px;
  font-size: clamp(17px, 1.4vw, 20px);
  line-height: 1.55;
  color: #cfcac0;
}
.cta-block .actions{
  display:inline-flex;gap:14px;flex-wrap:wrap;justify-content:center;
}
.cta-block .contacts{
  margin-top: 36px;
  font-size: 14px;color:#9a9286;
}
.cta-block .contacts b{color:#fff;font-weight:600}
.dark .btn{border-color:#fff;color:#fff}
.dark .btn:hover{background:#fff;color:var(--ink)}
.dark .btn-primary{background:var(--orange);border-color:var(--orange)}

/* ============================================================
   BLOCK 11 — FAQ
============================================================ */
.faq{
  max-width: 920px;margin: 0 auto;
}
.faq details{
  border-top: 1px solid var(--line);
  padding: 22px 0;
}
.faq details:last-of-type{border-bottom: 1px solid var(--line)}
.faq summary{
  list-style:none;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  font-size: clamp(18px, 1.6vw, 22px);
  font-weight:700;letter-spacing:-.005em;
  color: var(--ink);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary .plus{
  width: 32px;height:32px;border-radius:50%;
  border:1.5px solid var(--ink);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  font-size: 18px;font-weight:700;
  transition: transform .2s ease, background .2s ease, color .2s ease;
}
.faq details[open] summary .plus{
  background: var(--ink);color:#fff;transform: rotate(45deg);
}
.faq .answer{
  margin-top: 16px;
  max-width: 760px;
  font-size: 16px;line-height: 1.6;color: var(--ink-2);
}
.faq .answer b{font-weight:700;color:var(--ink)}

/* ============================================================
   FOOTER
============================================================ */
.footer{
  background: var(--bg-dark);
  color: #cfcac0;
  padding: 64px var(--pad-x) 36px;
}
.footer-grid{
  display:grid;grid-template-columns: 2fr 1fr 1fr 1fr;gap: 48px;
  padding-bottom: 48px;border-bottom: 1px solid #2a2a2a;
  margin-bottom: 28px;
}
.footer .brand{color:#fff}
.footer .brand .name{color:#fff}
.footer .brand .section-name{color:#888}
.footer .brand .sep{background:#444}
.footer-tagline{
  margin-top: 18px;max-width: 320px;font-size:14px;line-height:1.55;color:#9a9286;
}
.footer-col h5{
  margin:0 0 16px;font-size:11px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:#fff;
}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.footer-col a{
  color:#cfcac0;text-decoration:none;font-size:14px;
}
.footer-col a:hover{color:var(--orange)}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;gap:20px;
  font-size:12px;color:#6f6a60;letter-spacing:.08em;
}

/* ============================================================
   RESPONSIVE GUARDS (tablet/mobile soft fallback)
============================================================ */
@media (max-width: 1200px){
  .formats-3{grid-template-columns: 1fr 1fr}
  .method{grid-template-columns: 1fr 1fr}
  .case{grid-template-columns: 1fr}
  .aios{grid-template-columns: 1fr;gap: 48px}
  .team-speakers{grid-template-columns: 1fr 1fr}
  .result-transfer{grid-template-columns: 1fr 1fr 1fr}
  .guarantees{grid-template-columns: 1fr 1fr}
  .logo-grid{grid-template-columns: repeat(4, 1fr)}
}
@media (max-width: 760px){
  .formats-3, .process, .levels, .method,
  .team-core, .team-speakers, .result-transfer, .guarantees,
  .footer-grid, .aios-features, .aios-chars ul, .stats-row{
    grid-template-columns: 1fr;
  }
  .nav{display:none}
  .case{padding: 28px}
  .case-table dl{grid-template-columns: 1fr}
  .case-table dt{margin-top: 8px}
  .logo-grid{grid-template-columns: repeat(2, 1fr)}
}
