/* ═══════════════════════════════════════════════════════════════════
   Quillon Start · landing — premium light
   Поверх /v4/css (tokens + base + components). Светлая палитра,
   один акцент var(--q-accent) #5E6AD2, мягкие слоистые тени, воздух.
   ═══════════════════════════════════════════════════════════════════ */

:root{
  --l-maxw: 1180px;
  --l-pad: clamp(20px, 5vw, 40px);
  --l-sec: clamp(64px, 8.5vw, 120px);
  --l-card: #fff;
  --l-page: #FCFCFD;
  --l-alt:  #F4F5F9;
  --l-soft: color-mix(in srgb, var(--q-accent) 9%, #fff);
  --l-soft2: color-mix(in srgb, var(--q-accent) 14%, transparent);
  --l-ring: color-mix(in srgb, var(--q-accent) 24%, transparent);
  --l-ink:  #0C0E1A;
  --l-green: #16A34A;  /* success / оплата */
  --l-amber: #D97706;
  --l-rose:  #C2526B;  /* «не так» / отрицание */
  --l-brown: #92724E;
  --l-radius: 18px;
  --l-radius-sm: 13px;
  --l-sh-sm: 0 1px 2px rgba(16,18,42,.05);
  --l-sh:    0 1px 2px rgba(16,18,42,.05), 0 14px 30px -18px rgba(16,18,42,.18);
  --l-sh-lg: 0 2px 6px rgba(16,18,42,.05), 0 34px 64px -30px rgba(16,18,42,.26);
  --l-ease: cubic-bezier(.22,1,.36,1);
}

[data-theme="light"]{ color-scheme: light; }
body{ background: var(--l-page); counter-reset: lsec; }

/* ── layout primitives ── */
.l-container{ max-width: var(--l-maxw); margin: 0 auto; padding: 0 var(--l-pad); }
.l-section{ padding: var(--l-sec) 0; position: relative; }
.l-section--tight{ padding: clamp(44px,6vw,76px) 0; }
.l-section--alt{ background: var(--l-alt); }
/* hairline-шов между секциями (сепаратор) */
.l-section + .l-section, .l-section + .ai-section{ border-top: 1px solid var(--q-line); }

.l-head{ max-width: 760px; margin: 0 0 clamp(36px,4.5vw,60px); }
.l-head--xl{ max-width: 900px; }
.l-head__eyebrow{
  counter-increment: lsec;
  display: inline-flex; align-items: center; gap: 9px;
  font-family: var(--q-font-mono); font-size: 12px; font-weight: 500;
  letter-spacing: .14em; text-transform: uppercase; color: var(--q-accent);
  margin-bottom: 18px;
}
.l-head__eyebrow::before{
  content: counter(lsec, decimal-leading-zero) "  —";
  color: var(--q-text-low); letter-spacing: .12em;
}
.l-head__title{
  font-size: clamp(27px, 3.6vw, 42px); font-weight: 660;
  letter-spacing: -.03em; line-height: 1.08; color: var(--l-ink);
  text-wrap: balance;
}
.l-head__title em{ font-style: normal; color: var(--q-accent); }
.l-head__sub{
  margin-top: 18px; font-size: clamp(15px,1.5vw,17px); line-height: 1.62;
  color: var(--q-text-mid); max-width: 64ch;
}

/* ── topbar minimal ── */
.q-topbar--minimal{
  position: sticky; top: 0; z-index: 50; height: 62px; display: flex; align-items: center;
  background: color-mix(in srgb, var(--l-page) 82%, transparent);
  backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid var(--q-line);
}
.q-topbar--minimal .q-topbar__brand{ display: flex; align-items: center; padding: 0 var(--l-pad); }
.q-topbar__brand-logo img{ height: 22px; width: auto; display: block; }
[data-theme="light"] .q-topbar__brand-logo img{ filter: invert(1) hue-rotate(180deg); }

/* ── buttons ── */
.q-btn--lg{ padding: 13px 22px; font-size: 15px; border-radius: 12px; }
.hero__btn, .mf-submit{ width: 100%; justify-content: center; }
.q-btn--primary{ box-shadow: 0 1px 2px rgba(94,106,210,.25), 0 10px 24px -10px rgba(94,106,210,.6); }

/* списки-факты flush-left: сброс дефолтного padding/margin <ul>/<ol> (маркеры живут на li) */
.hero__points, .problem-list, .jobs-col__list, .gh__facts, .l-mentor__facts, .jobs-board__facts, .mini-form__points, .steps{ margin: 0; padding: 0; }

/* ═══════════════ HERO ═══════════════ */
.hero{ position: relative; padding: clamp(40px,5vw,72px) 0 clamp(52px,6vw,88px); overflow: hidden; }
.hero::before{
  content:""; position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background:
    radial-gradient(60% 50% at 78% 12%, color-mix(in srgb,var(--q-accent) 12%,transparent), transparent 70%),
    radial-gradient(50% 45% at 8% 0%, color-mix(in srgb,var(--q-accent) 7%,transparent), transparent 70%);
}
.hero .l-container{ position: relative; z-index: 1; }
.hero__grid{ display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(32px,4vw,64px); align-items: start; }

/* ── LEFT · заявление + одна CTA (8pt вертикальный ритм) ── */
.hero__left{ padding-top: 8px; }
.hero__eyebrow{
  display: flex; align-items: center; gap: 11px; flex-wrap: wrap;
  font-family: var(--q-font-mono); font-size: 12px; letter-spacing: .12em;
  text-transform: uppercase; color: var(--q-text-low); line-height: 1.5;
}
.hero__eyebrow::before{ content:""; width: 22px; height: 2px; background: var(--q-accent); flex-shrink: 0; }
.hero__title{
  margin-top: 24px;
  font-size: clamp(36px, 5vw, 60px); font-weight: 690;
  letter-spacing: -.035em; line-height: 1.02; color: var(--l-ink);
  text-wrap: balance; max-width: 16ch;
}
.hero__title em{ font-style: normal; color: var(--q-accent); }
.hero__sub{
  margin-top: 20px; font-size: clamp(16px,1.7vw,19px); line-height: 1.55;
  color: var(--q-text-mid); max-width: 38ch; letter-spacing: -.005em;
}
/* ── LEFT · лид-форма (8pt ритм, max-width 460) ── */
.hero__form{ margin-top: 28px; display: flex; flex-direction: column; gap: 12px; max-width: 460px; }
.hero__input{
  width: 100%; height: 50px; padding: 0 16px; border-radius: 12px;
  border: 1px solid var(--q-line-strong); background: var(--l-card); color: var(--l-ink);
  font-family: var(--q-font-sans); font-size: 15px; box-shadow: var(--l-sh-sm);
  transition: border-color .18s var(--l-ease), box-shadow .18s var(--l-ease);
}
.hero__input::placeholder{ color: var(--q-text-low); }
.hero__input:focus-visible{ outline: none; border-color: var(--q-accent); box-shadow: 0 0 0 3px var(--l-ring); }
.hero__consent{ display: flex; align-items: flex-start; gap: 9px; font-size: 12px; line-height: 1.45; color: var(--q-text-low); cursor: pointer; }
.hero__consent input{ margin-top: 1px; width: 15px; height: 15px; accent-color: var(--q-accent); flex-shrink: 0; cursor: pointer; }
.hero__consent u{ text-underline-offset: 2px; }
.hero__btn{ margin-top: 4px; white-space: normal; text-align: center; }
.hero__trust{
  margin-top: 16px; display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  font-size: 13px; color: var(--q-text-low);
}
.hero__trust-sep{ color: var(--q-line-strong); }

/* ── RIGHT · пруф: 3 пункта над моком ── */
.hero__right{ display: flex; flex-direction: column; gap: 28px; }
.hero__points{ list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 16px; }
.hero__points li{ display: flex; align-items: flex-start; gap: 13px; font-size: clamp(14px,1.45vw,15.5px); line-height: 1.5; color: var(--q-text-mid); }
.hero__points li strong{ color: var(--l-ink); font-weight: 600; }
.hero__point-icon{ width: 36px; height: 36px; border-radius: 10px; display: grid; place-items: center; color: var(--q-accent); background: var(--l-soft); flex-shrink: 0; }
.hero__point-icon svg{ width: 19px; height: 19px; }

/* hero product-proof — реальный экран биржи Quillon Jobs (живой артефакт) */
.hero__proof{ margin: 0; }
.hero__proof .q-mock{ overflow: hidden; }
.q-mock--shot{ border-color: var(--q-line); box-shadow: 0 2px 8px rgba(16,18,42,.06), 0 40px 80px -42px color-mix(in srgb,var(--q-accent) 36%,rgba(16,18,42,.5)); }
.q-mock--shot .q-mock__url{ color: var(--q-accent); max-width: 78%; }
/* светлый кадр 1500×1371 — кадрируем сверху (приветствие + заказы), рамка завершена */
.q-mock__screen--shot{ aspect-ratio: 16 / 10; background: var(--l-alt); box-shadow: inset 0 0 0 1px var(--q-line); }
.q-mock--shot .q-mock__img{ object-position: top center; }
.hero__proof-cap{ display: flex; align-items: flex-start; gap: 9px; margin-top: 16px; font-size: 12.5px; line-height: 1.45; color: var(--q-text-mid); max-width: 42ch; }
.hero__proof-cap strong{ color: var(--l-ink); font-weight: 600; }

/* ═══════════════ TRUST STRIP ═══════════════ */
.trust-strip{ display: grid; grid-template-columns: repeat(4,1fr); background: var(--l-card); border: 1px solid var(--q-line); border-radius: var(--l-radius); box-shadow: var(--l-sh-sm); overflow: hidden; }
.trust-item{ display: flex; align-items: center; gap: 13px; padding: 22px; border-left: 1px solid var(--q-line); transition: background .2s var(--l-ease); }
.trust-item:first-child{ border-left: 0; }
.trust-item:hover{ background: var(--l-soft); }
.trust-item__icon{ width: 36px; height: 36px; border-radius: 10px; display: grid; place-items: center; color: var(--q-accent); background: var(--l-soft); flex-shrink: 0; }
.trust-item__icon svg{ width: 19px; height: 19px; }
.trust-item__text{ font-size: 12.5px; line-height: 1.38; color: var(--q-text-mid); }
.trust-item__text strong{ display: block; color: var(--l-ink); font-weight: 600; margin-bottom: 2px; }
@media (max-width:1024px){ .trust-strip{ grid-template-columns: repeat(2,1fr); } .trust-item:nth-child(2n+1){ border-left: 0; } .trust-item:nth-child(n+3){ border-top: 1px solid var(--q-line); } }
@media (max-width:640px){ .trust-strip{ grid-template-columns: 1fr; } .trust-item{ border-left: 0; border-top: 1px solid var(--q-line); } .trust-item:first-child{ border-top: 0; } }

/* ═══════════════ PROBLEM ═══════════════ */
.problem-grid{ display: grid; grid-template-columns: 1fr 1.04fr; gap: 22px; align-items: start; }
.problem-card{ position: relative; border-radius: var(--l-radius); padding: clamp(26px,3vw,40px); border: 1px solid var(--q-line); background: var(--l-card); overflow: hidden; }
.problem-card--dont{ background: var(--l-alt); box-shadow: none; opacity: .94; }
.problem-card--do{ background: linear-gradient(165deg, #fff, color-mix(in srgb,var(--q-accent) 7%, #fff)); border-color: var(--l-ring); box-shadow: var(--l-sh-lg); transform: translateY(-8px); }
.problem-card--do::before{ content:""; position: absolute; left: 0; right: 0; top: 0; height: 3px; background: var(--q-accent); }
.problem-card__label{ position: relative; font-family: var(--q-font-mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 24px; display: flex; align-items: center; gap: 10px; }
.problem-card__label::after{ content:""; flex: 1; height: 1px; background: var(--q-line); }
.problem-card--dont .problem-card__label{ color: var(--q-text-low); }
.problem-card--do .problem-card__label{ color: var(--q-accent); }
.problem-list{ position: relative; list-style: none; display: flex; flex-direction: column; gap: 16px; }
.problem-card--do .problem-list{ gap: 18px; }
.problem-list li{ display: flex; gap: 13px; font-size: 14.5px; line-height: 1.5; }
.problem-list li svg{ width: 22px; height: 22px; flex-shrink: 0; padding: 4px; }
.problem-card--dont .problem-list li{ color: var(--q-text-low); }
.problem-card--dont .problem-list li svg{ color: var(--l-rose); background: color-mix(in srgb,var(--l-rose) 8%,transparent); border-radius: 50%; }
.problem-card--do .problem-list li{ color: var(--q-text-mid); }
.problem-card--do .problem-list li svg{ color: #fff; background: var(--q-accent); border-radius: 7px; }
.problem-list li strong{ color: var(--l-ink); font-weight: 600; }

/* ═══════════════ q-mock · светлые device-рамки (под замену) ═══════════════ */
.q-mock{ background: var(--l-card); border: 1px solid var(--q-line); border-radius: 16px; box-shadow: var(--l-sh); overflow: hidden; }
.q-mock__bar{ display: flex; align-items: center; gap: 10px; padding: 11px 14px; border-bottom: 1px solid var(--q-line); background: #FBFBFD; }
.q-mock__dots{ display: flex; gap: 6px; flex-shrink: 0; }
.q-mock__dots i{ width: 9px; height: 9px; border-radius: 50%; background: var(--q-line-strong); display: block; }
.q-mock__url{ font-family: var(--q-font-mono); font-size: 11px; color: var(--q-text-low); background: var(--l-alt); padding: 4px 12px; border-radius: 7px; flex: 1; max-width: 62%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.q-mock__screen{ position: relative; aspect-ratio: 16 / 10; background: linear-gradient(140deg, #F5F6FC, #E9ECF6); overflow: hidden; }
.q-mock--phone{ max-width: 244px; margin: 0 auto; border-radius: 30px; padding: 8px; background: var(--l-card); border: 1px solid var(--q-line-strong); }
.q-mock--phone .q-mock__screen{ aspect-ratio: 9 / 19.5; border-radius: 22px; }
.q-mock__img{ position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: top center; display: block; }
/* premium placeholder (faux light UI + label) */
.q-mock__ph{ position: absolute; inset: 0; }
.q-mock__ph::before{ content:""; position: absolute; left: 0; right: 0; top: 0; height: 30%; background: linear-gradient(135deg, color-mix(in srgb,var(--q-accent) 15%,#EEF0FA), color-mix(in srgb,var(--q-accent) 5%,#F2F4FC)); border-bottom: 1px solid color-mix(in srgb,var(--q-accent) 12%,transparent); }
.q-mock__ph::after{ content: attr(data-label); position: absolute; inset: 0; display: grid; place-items: center; font-family: var(--q-font-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--q-text-low); }
.q-mock__ph .q-mock__lines{ position: absolute; left: 14%; right: 14%; bottom: 22%; display: flex; flex-direction: column; gap: 9px; }
.q-mock__ph .q-mock__lines i{ height: 8px; border-radius: 4px; background: var(--q-line-strong); display: block; }
.q-mock__ph .q-mock__lines i:nth-child(2){ width: 70%; }
.q-mock__ph .q-mock__lines i:nth-child(3){ width: 45%; }

/* ── faux-UI внутри моков: светлый продуктовый UI (легко заменить на <img class="q-mock__img">) ── */
.q-mock__ui{ position: absolute; inset: 0; display: flex; flex-direction: column; background: #F5F6FB; font-family: var(--q-font-sans); overflow: hidden; }
.fx-line{ display: block; height: 7px; border-radius: 4px; background: rgba(0,0,0,.11); }
.fx-line--s{ background: rgba(0,0,0,.06); }
.fx-w100{ width: 100%; } .fx-w90{ width: 90%; } .fx-w75{ width: 75%; } .fx-w60{ width: 60%; } .fx-w45{ width: 45%; }
.fx-av{ border-radius: 50%; display: grid; place-items: center; color: #fff; font-weight: 600; flex-shrink: 0; font-family: var(--q-font-mono); }
.ui-st{ display: flex; align-items: center; justify-content: space-between; padding: 9px 16px 3px; font-family: var(--q-font-mono); font-size: 9px; font-weight: 600; color: var(--q-text-mid); }
.ui-st__r{ display: flex; gap: 3px; } .ui-st__r i{ width: 4px; height: 4px; border-radius: 1px; background: var(--q-text-low); display: block; }
.ui-hd{ display: flex; align-items: center; gap: 10px; padding: 10px 14px; background: #fff; border-bottom: 1px solid rgba(0,0,0,.06); }
.ui-hd__av{ width: 30px; height: 30px; font-size: 13px; }
.ui-hd__t{ display: flex; flex-direction: column; gap: 5px; flex: 1; min-width: 0; }
.ui-on{ display: flex; align-items: center; gap: 5px; } .ui-on i{ width: 6px; height: 6px; border-radius: 50%; background: var(--l-green); display: block; }
/* Meet */
.ui-meet{ background: #EDEFF7; padding: 14px; gap: 10px; }
.ui-meet__bar{ display: flex; }
.ui-meet__timer{ font-family: var(--q-font-mono); font-size: 10px; color: #fff; background: rgba(20,22,40,.5); padding: 4px 9px; border-radius: 7px; }
.ui-meet__grid{ flex: 1; display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 8px; }
.ui-meet__tile{ border-radius: 12px; background: linear-gradient(135deg,#E0E4F2,#C8CFE6); display: grid; place-items: center; }
.ui-meet__tile.is-live{ box-shadow: inset 0 0 0 2px var(--q-accent); }
.ui-meet__tile .fx-av{ width: 40px; height: 40px; font-size: 13px; box-shadow: 0 2px 6px rgba(0,0,0,.15); }
.ui-meet__ctrl{ display: flex; justify-content: center; gap: 8px; }
.ui-meet__ctrl i{ width: 30px; height: 30px; border-radius: 50%; background: #fff; box-shadow: 0 2px 5px rgba(0,0,0,.12); display: block; }
.ui-meet__ctrl i.hang{ width: 42px; border-radius: 15px; background: #F0556B; }
/* Quilly chat */
.ui-feed{ flex: 1; display: flex; flex-direction: column; gap: 9px; padding: 12px; }
.ui-msg{ max-width: 82%; display: flex; flex-direction: column; gap: 6px; padding: 10px 11px; border-radius: 13px; }
.ui-msg.ai{ align-self: flex-start; background: #fff; border: 1px solid rgba(0,0,0,.06); border-bottom-left-radius: 4px; }
.ui-msg.me{ align-self: flex-end; background: var(--q-accent); border-bottom-right-radius: 4px; }
.ui-msg.me .fx-line{ background: rgba(255,255,255,.6); }
.ui-code{ margin-top: 2px; background: #16182A; border-radius: 7px; padding: 8px; display: flex; flex-direction: column; gap: 5px; }
.ui-code i{ height: 5px; border-radius: 3px; background: rgba(255,255,255,.28); display: block; } .ui-code i:nth-child(2){ width: 60%; }
.ui-input{ display: flex; align-items: center; gap: 8px; margin: 0 12px 12px; padding: 9px 12px; background: #fff; border: 1px solid rgba(0,0,0,.08); border-radius: 999px; }
.ui-input .fx-line{ flex: 1; }
.ui-send{ width: 26px; height: 26px; border-radius: 50%; background: var(--q-accent); flex-shrink: 0; display: block; position: relative; }
.ui-send::after{ content: ""; position: absolute; inset: 0; margin: auto; width: 0; height: 0; border-left: 5px solid transparent; border-right: 5px solid transparent; border-bottom: 7px solid #fff; top: -1px; }
/* LMS lesson */
.ui-lms__body{ flex: 1; display: flex; flex-direction: column; gap: 11px; padding: 12px; }
.ui-lms__prog{ height: 4px; border-radius: 3px; background: rgba(0,0,0,.08); overflow: hidden; } .ui-lms__prog i{ display: block; height: 100%; width: 64%; background: var(--q-accent); }
.ui-lms__video{ aspect-ratio: 16/9; border-radius: 11px; background: linear-gradient(135deg,#2A2E52,var(--q-accent)); display: grid; place-items: center; }
.ui-lms__play{ width: 38px; height: 38px; border-radius: 50%; background: rgba(255,255,255,.92); position: relative; }
.ui-lms__play::after{ content: ""; position: absolute; inset: 0; margin: auto; width: 0; height: 0; border-top: 7px solid transparent; border-bottom: 7px solid transparent; border-left: 11px solid var(--q-accent); left: 2px; }
.ui-lms__card{ background: #fff; border: 1px solid rgba(0,0,0,.06); border-radius: 11px; padding: 11px; display: flex; flex-direction: column; gap: 8px; }
.ui-lms__code{ background: #16182A; border-radius: 7px; padding: 8px; display: flex; flex-direction: column; gap: 5px; } .ui-lms__code i{ height: 5px; border-radius: 3px; background: rgba(255,255,255,.26); display: block; } .ui-lms__code i:nth-child(2){ width: 70%; } .ui-lms__code i:nth-child(3){ width: 50%; }
.ui-lms__btn{ margin-top: auto; height: 36px; border-radius: 10px; background: var(--q-accent); display: grid; place-items: center; } .ui-lms__btn .fx-line{ width: 90px; background: rgba(255,255,255,.7); }
/* Chat channels */
.ui-chat2__search{ margin: 10px 12px; height: 30px; border-radius: 9px; background: #F1F2F8; display: flex; align-items: center; padding: 0 11px; } .ui-chat2__search .fx-line{ width: 50%; }
.ui-chat2__lbl{ padding: 2px 14px 6px; } .ui-chat2__lbl .fx-line{ width: 60px; height: 6px; }
.ui-row{ display: flex; align-items: center; gap: 11px; padding: 9px 14px; border-top: 1px solid rgba(0,0,0,.05); position: relative; }
.ui-row:first-of-type{ border-top: 0; }
.ui-row.is-active{ background: color-mix(in srgb,var(--q-accent) 8%, #fff); }
.ui-row.is-active::before{ content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--q-accent); }
.ui-row__av{ width: 32px; height: 32px; border-radius: 9px; font-size: 12px; }
.ui-row__t{ flex: 1; display: flex; flex-direction: column; gap: 5px; min-width: 0; }
.ui-row__badge{ width: 16px; height: 16px; border-radius: 50%; background: var(--q-accent); flex-shrink: 0; }
.ui-tab{ margin-top: auto; display: flex; justify-content: space-around; padding: 9px 0; border-top: 1px solid rgba(0,0,0,.06); }
.ui-tab i{ width: 18px; height: 18px; border-radius: 5px; background: rgba(0,0,0,.10); display: block; } .ui-tab i:first-child{ background: var(--q-accent); }

/* ═══════════════ PRACTICE · Product Board ═══════════════ */
.practice-meta{ display: flex; flex-wrap: wrap; gap: 10px 28px; padding: 15px 0; border-top: 1px solid var(--q-line); border-bottom: 1px solid var(--q-line); margin-bottom: 28px; font-family: var(--q-font-mono); font-size: 11px; letter-spacing: .08em; color: var(--q-text-low); }
.practice-meta__cell em{ font-style: normal; color: var(--q-accent); }

.prodline{ background: var(--l-card); border: 1px solid var(--q-line); border-radius: var(--l-radius); padding: clamp(22px,2.6vw,30px); margin-bottom: 28px; box-shadow: var(--l-sh-sm); }
.prodline__head{ display: flex; justify-content: space-between; align-items: baseline; gap: 16px; margin-bottom: 22px; }
.prodline__title{ font-size: 16px; font-weight: 620; color: var(--l-ink); }
.prodline__rangelabel{ font-family: var(--q-font-mono); font-size: 10.5px; letter-spacing: .08em; color: var(--q-text-low); }
.prodline__pill{ display: inline-block; font-family: var(--q-font-mono); font-size: 11px; letter-spacing: .04em; color: #fff; background: var(--q-accent); padding: 6px 13px; border-radius: 999px; margin-bottom: 16px; box-shadow: 0 6px 16px -8px rgba(94,106,210,.7); }
.prodline__rail{ display: flex; justify-content: space-between; gap: 4px; }
.prodline-dot{ flex: 1; border: 0; background: transparent; padding: 10px 0 0; cursor: pointer; }
.prodline-dot::before{ content:""; display: block; height: 5px; border-radius: 4px; background: var(--q-line-strong); transition: background .15s; }
.prodline-dot span{ display: block; font-family: var(--q-font-mono); font-size: 9px; letter-spacing: .03em; color: var(--q-text-low); margin-top: 8px; text-align: center; transition: color .15s; }
.prodline-dot:hover::before, .prodline-dot.is-active::before{ background: var(--q-accent); }
.prodline-dot.is-active span{ color: var(--q-accent); }
.prodline__caption{ margin-top: 22px; font-size: 14px; line-height: 1.55; color: var(--q-text-mid); min-height: 44px; }
.prodline__hint{ font-family: var(--q-font-mono); font-size: 9.5px; letter-spacing: .08em; color: var(--q-text-faint); margin-top: 10px; }

.products{ display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; }
.product{ background: var(--l-card); border: 1px solid var(--q-line); border-radius: var(--l-radius); padding: 24px; display: flex; flex-direction: column; gap: 15px; box-shadow: var(--l-sh-sm); transition: transform .2s var(--l-ease), box-shadow .2s; }
.product:hover{ box-shadow: var(--l-sh); border-color: var(--l-ring); }
.product--hero{ grid-column: 1 / -1; display: grid; grid-template-columns: .92fr 1.08fr; gap: clamp(24px,3vw,48px); align-items: center; }
.product--hero .product__info{ display: flex; flex-direction: column; gap: 15px; }
.product__head{ display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.product__brand{ display: flex; gap: 12px; align-items: center; }
.product__brand img{ width: 42px; height: 42px; border-radius: 10px; object-fit: cover; background: var(--l-alt); }
.product__id{ font-family: var(--q-font-mono); font-size: 10px; letter-spacing: .08em; color: var(--q-text-low); }
.product__name{ font-size: 18px; font-weight: 650; color: var(--l-ink); margin-top: 3px; }
.product__state{ font-family: var(--q-font-mono); font-size: 9.5px; letter-spacing: .06em; color: var(--q-accent); background: var(--l-soft); border: 1px solid var(--l-ring); padding: 4px 9px; border-radius: 7px; white-space: nowrap; }
.product__desc{ font-size: 13.5px; line-height: 1.55; color: var(--q-text-mid); }
.product__stack, .product__platforms{ display: flex; flex-wrap: wrap; gap: 6px; }
.product__visual{ margin-top: auto; }
.product--hero .product__visual{ margin-top: 0; position: relative; }

/* ═══════════════ FEAT GRID ═══════════════ */
.feat-grid{ display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.feat-card{ background: var(--l-card); border: 1px solid var(--q-line); border-radius: var(--l-radius); padding: 26px; box-shadow: var(--l-sh-sm); transition: transform .2s var(--l-ease), box-shadow .2s; }
.feat-card:hover{ box-shadow: var(--l-sh); border-color: var(--l-ring); }
.feat-card__icon{ width: 42px; height: 42px; border-radius: 12px; display: grid; place-items: center; margin-bottom: 18px; color: var(--q-accent); background: var(--l-soft); }
.feat-card__icon svg{ width: 21px; height: 21px; }
.feat-card__icon--green{ color: var(--l-green); background: color-mix(in srgb,var(--l-green) 10%,transparent); }
.feat-card__icon--amber{ color: var(--l-amber); background: color-mix(in srgb,var(--l-amber) 10%,transparent); }
.feat-card__icon--brown{ color: var(--l-brown); background: color-mix(in srgb,var(--l-brown) 10%,transparent); }
.feat-card__icon--grey{ color: var(--q-text-mid); background: var(--l-alt); }
.feat-card__icon--money{ color: var(--l-green); background: color-mix(in srgb,var(--l-green) 10%,transparent); }
.feat-card__title{ font-size: 16.5px; font-weight: 630; color: var(--l-ink); margin-bottom: 9px; }
.feat-card__text{ font-size: 13.5px; line-height: 1.55; color: var(--q-text-mid); }
.feat-card__text strong{ color: var(--l-ink); font-weight: 600; }

/* ═══════════════ STATS ═══════════════ */
.stats-band{ display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; }
.stat-cell{ background: var(--l-card); border: 1px solid var(--q-line); border-radius: var(--l-radius-sm); padding: 28px 24px; box-shadow: var(--l-sh-sm); }
.stat-cell__num{ font-size: clamp(28px,3.2vw,38px); font-weight: 700; letter-spacing: -.03em; color: var(--q-accent); font-variant-numeric: tabular-nums; }
.stat-cell__lbl{ margin-top: 12px; font-size: 13px; line-height: 1.5; color: var(--q-text-mid); }
.stats-source{ margin-top: 18px; font-family: var(--q-font-mono); font-size: 11px; color: var(--q-text-faint); }

/* ═══════════════ URGENCY — light premium ═══════════════ */
.urgency{ display: flex; justify-content: space-between; align-items: center; gap: clamp(24px,4vw,56px); flex-wrap: wrap; background: linear-gradient(135deg, #fff, var(--l-soft)); border: 1px solid var(--l-ring); border-radius: var(--l-radius); padding: clamp(30px,3.4vw,46px); box-shadow: var(--l-sh-lg); }
.urgency > div:first-child{ max-width: 52ch; }
.urgency__title{ font-size: clamp(23px,2.7vw,32px); font-weight: 670; letter-spacing: -.025em; line-height: 1.12; color: var(--l-ink); }
.urgency__title em{ font-style: normal; color: var(--q-accent); }
.urgency__sub{ margin-top: 11px; font-size: 14px; color: var(--q-text-mid); }
.urgency__actions{ display: flex; gap: 12px; flex-wrap: wrap; }
.urgency .q-btn--ghost{ border-color: var(--q-line-strong); color: var(--l-ink); }

/* ═══════════════ TESTIMONIALS ═══════════════ */
.testi-grid{ display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.testi-card{ background: var(--l-card); border: 1px solid var(--q-line); border-radius: var(--l-radius); padding: 26px; display: flex; flex-direction: column; gap: 16px; box-shadow: var(--l-sh-sm); transition: transform .2s var(--l-ease), box-shadow .2s; }
.testi-card:hover{ box-shadow: var(--l-sh); border-color: var(--l-ring); }
.testi-card__head{ display: flex; gap: 13px; align-items: center; }
.testi-avatar{ width: 44px; height: 44px; border-radius: 50%; display: grid; place-items: center; color: #fff; font-weight: 600; font-size: 14px; flex-shrink: 0; box-shadow: 0 0 0 1px rgba(0,0,0,.06), 0 5px 12px -5px rgba(16,18,42,.3); }
.testi-avatar--py{ background: var(--q-accent); }
.testi-avatar--qa{ background: var(--l-green); }
.testi-avatar--flutter{ background: var(--l-amber); }
.testi-card__name{ font-size: 15px; font-weight: 630; color: var(--l-ink); }
.testi-card__path{ font-size: 12px; color: var(--q-text-low); margin-top: 2px; }
.before-after{ display: flex; align-items: baseline; gap: 10px; font-family: var(--q-font-mono); font-variant-numeric: tabular-nums; background: var(--l-soft); border: 1px solid var(--l-ring); border-radius: 11px; padding: 13px 15px; }
.before-after__old{ font-size: 14px; color: var(--q-text-low); text-decoration: line-through; }
.before-after__arr{ color: var(--q-accent); }
.before-after__new{ font-size: 21px; font-weight: 600; color: var(--q-accent); }
.before-after__new small{ font-size: 11px; color: var(--q-text-low); font-weight: 400; }
.testi-card__quote{ position: relative; font-size: 14px; line-height: 1.58; color: var(--q-text-mid); padding-top: 8px; }
.testi-card__quote::before{ content: "\201C"; position: absolute; left: -2px; top: -8px; font-size: 38px; line-height: 1; color: var(--q-accent); opacity: .2; font-family: Georgia, "Times New Roman", serif; }
.testi-card__foot{ display: flex; align-items: center; gap: 7px; font-family: var(--q-font-mono); font-size: 9.5px; letter-spacing: .05em; color: var(--q-text-faint); margin-top: auto; }
.testi-card__foot::before{ content:""; width: 6px; height: 6px; border-radius: 50%; background: var(--l-green); flex-shrink: 0; }

/* ═══════════════ PHASES ═══════════════ */
.phases{ display: flex; flex-direction: column; gap: 14px; }
.phase{ display: grid; grid-template-columns: 72px 1fr; gap: 22px; background: var(--l-card); border: 1px solid var(--q-line); border-radius: var(--l-radius); padding: 28px; box-shadow: var(--l-sh-sm); transition: box-shadow .2s, border-color .2s; }
.phase:hover{ box-shadow: var(--l-sh); border-color: var(--l-ring); }
.phase__num{ font-family: var(--q-font-mono); font-size: 28px; font-weight: 600; color: var(--q-accent); letter-spacing: -.02em; opacity: .5; }
.phase__eyebrow{ font-family: var(--q-font-mono); font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--q-accent); margin-bottom: 11px; }
.phase__title{ font-size: 19px; font-weight: 650; color: var(--l-ink); margin-bottom: 11px; }
.phase__text{ font-size: 14px; line-height: 1.62; color: var(--q-text-mid); }
.phase__text strong{ color: var(--l-ink); font-weight: 600; }
.phase__tags{ display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.phase-tag{ font-family: var(--q-font-mono); font-size: 11px; color: var(--q-text-mid); background: var(--l-alt); border: 1px solid var(--q-line); padding: 5px 11px; border-radius: 8px; }

/* ═══════════════ TRACKS ═══════════════ */
.tracks-3{ display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.track-card{ display: flex; flex-direction: column; background: var(--l-card); border: 1px solid var(--q-line); border-radius: var(--l-radius); padding: 28px; box-shadow: var(--l-sh-sm); transition: transform .2s var(--l-ease), box-shadow .2s; }
.track-card:hover{ box-shadow: var(--l-sh-lg); border-color: var(--l-ring); }
.track-card__tag{ align-self: flex-start; font-family: var(--q-font-mono); font-size: 9.5px; letter-spacing: .07em; color: var(--q-accent); background: var(--l-soft); border: 1px solid var(--l-ring); padding: 4px 10px; border-radius: 7px; margin-bottom: 18px; }
.track-card__name{ font-size: 19px; font-weight: 660; color: var(--l-ink); }
.track-card__price{ font-size: 27px; font-weight: 700; color: var(--q-accent); letter-spacing: -.02em; margin-top: 14px; font-variant-numeric: tabular-nums; }
.track-card__price-sub{ font-size: 12px; color: var(--q-text-low); margin-top: 3px; }
.track-card__desc{ font-size: 13.5px; line-height: 1.55; color: var(--q-text-mid); margin: 18px 0; }
.track-card__stack{ display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 18px; }
.track-card__meta{ font-size: 12.5px; color: var(--q-text-low); padding-top: 16px; border-top: 1px solid var(--q-line); }
.track-card__meta-num{ color: var(--l-ink); font-weight: 600; }
.track-card__cta{ margin-top: 20px; font-size: 14px; font-weight: 600; color: var(--q-accent); text-decoration: none; transition: gap .15s; }
.track-card__cta:hover{ text-decoration: underline; }

.callout-green{ display: flex; justify-content: space-between; align-items: center; gap: 24px; flex-wrap: wrap; background: linear-gradient(135deg,#fff,var(--l-soft)); border: 1px solid var(--l-ring); border-radius: var(--l-radius); padding: 26px 30px; margin-top: 24px; box-shadow: var(--l-sh); }
.callout-green__title{ font-size: 17px; font-weight: 640; color: var(--l-ink); }
.callout-green__sub{ font-size: 13.5px; color: var(--q-text-mid); margin-top: 6px; max-width: 56ch; }
.callout-green__cta{ background: var(--q-accent); color: #fff; white-space: nowrap; }
.callout-green--narrow{ display: block; }
.callout-green--narrow .callout-green__text{ font-size: 14px; line-height: 1.6; color: var(--q-text-mid); }
.callout-green--narrow strong{ color: var(--l-ink); }
.callout-green--gap{ margin-top: 32px; }

/* ═══════════════ MINI CARDS ═══════════════ */
.mini-grid{ display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; }
.mini-card{ background: var(--l-card); border: 1px solid var(--q-line); border-radius: var(--l-radius-sm); padding: 24px; box-shadow: var(--l-sh-sm); }
.mini-card__num{ font-family: var(--q-font-mono); font-size: 10.5px; letter-spacing: .08em; color: var(--q-accent); margin-bottom: 16px; }
.mini-card__title{ font-size: 16.5px; font-weight: 640; color: var(--l-ink); margin-bottom: 9px; }
.mini-card__text{ font-size: 13px; line-height: 1.55; color: var(--q-text-mid); }

/* ═══════════════ LAUNCH — light ═══════════════ */
.launch-grid{ display: grid; grid-template-columns: 1.4fr 1fr; gap: 28px; align-items: start; }
.steps{ list-style: none; display: flex; flex-direction: column; gap: 10px; }
.step{ display: grid; grid-template-columns: 36px 1fr; gap: 16px; align-items: start; background: var(--l-card); border: 1px solid var(--q-line); border-radius: var(--l-radius-sm); padding: 18px 20px; box-shadow: var(--l-sh-sm); }
.step__num{ width: 30px; height: 30px; border-radius: 50%; display: grid; place-items: center; background: var(--l-soft); color: var(--q-accent); font-family: var(--q-font-mono); font-weight: 600; font-size: 13px; }
.step__title{ font-size: 15px; font-weight: 630; color: var(--l-ink); margin-bottom: 5px; }
.step__text{ font-size: 13px; line-height: 1.5; color: var(--q-text-mid); }
.launch-stat{ position: sticky; top: 84px; background: linear-gradient(160deg, #fff, var(--l-soft)); border: 1px solid var(--l-ring); border-radius: var(--l-radius); padding: 34px; box-shadow: var(--l-sh-lg); overflow: hidden; }
.launch-stat__k{ font-family: var(--q-font-mono); font-size: 10.5px; letter-spacing: .1em; color: var(--q-accent); position: relative; }
.launch-stat__v{ font-size: clamp(38px,4.6vw,52px); font-weight: 720; letter-spacing: -.03em; margin: 12px 0; color: var(--l-ink); position: relative; font-variant-numeric: tabular-nums; }
.launch-stat__v .rub{ color: var(--q-accent); }
.launch-stat__cap{ font-size: 13px; line-height: 1.62; color: var(--q-text-mid); position: relative; }

/* ═══════════════ JOBS + PORTFOLIO ═══════════════ */
.jobs-grid{ display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.jobs-col{ background: var(--l-card); border: 1px solid var(--q-line); border-radius: var(--l-radius); padding: 28px; box-shadow: var(--l-sh-sm); }
.jobs-col__eyebrow{ font-family: var(--q-font-mono); font-size: 10px; letter-spacing: .08em; color: var(--q-accent); margin-bottom: 12px; }
.jobs-col__title{ font-size: 18px; font-weight: 640; color: var(--l-ink); margin-bottom: 18px; }
.jobs-col__list{ list-style: none; display: flex; flex-direction: column; gap: 12px; }
.jobs-col__list li{ position: relative; padding-left: 24px; font-size: 13.5px; line-height: 1.5; color: var(--q-text-mid); }
.jobs-col__list li::before{ content: ""; position: absolute; left: 2px; top: 7px; width: 8px; height: 8px; border-radius: 3px; background: var(--l-soft2); }
.port-eyebrow{ font-family: var(--q-font-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--q-text-low); margin: 40px 0 16px; }
.port-grid-cards{ display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; }
.port-card{ background: var(--l-card); border: 1px solid var(--q-line); border-radius: var(--l-radius-sm); padding: 22px; box-shadow: var(--l-sh-sm); }
.port-card__icon{ color: var(--q-accent); margin-bottom: 14px; display: block; }
.port-card__icon svg{ width: 20px; height: 20px; }
.port-card__title{ font-size: 14.5px; font-weight: 630; color: var(--l-ink); margin-bottom: 7px; }
.port-card__text{ font-size: 12.5px; line-height: 1.5; color: var(--q-text-mid); }

/* ═══════════════ EDITORIAL PHOTO (.l-figure) ═══════════════ */
.l-figure{ margin: 0; position: relative; }
.l-figure__media{ position: relative; border-radius: var(--l-radius); overflow: hidden; border: 1px solid var(--q-line); box-shadow: var(--l-sh-sm); background: var(--l-alt); }
.l-figure__media::after{ content: ""; position: absolute; inset: 0; pointer-events: none; border-radius: inherit; box-shadow: inset 0 0 0 1px color-mix(in srgb,var(--q-accent) 14%,transparent); background: linear-gradient(180deg, color-mix(in srgb,var(--q-accent) 5%,transparent), transparent 24%, transparent 62%, color-mix(in srgb,var(--q-accent) 8%,transparent)); }
.l-figure__img{ display: block; width: 100%; height: 100%; object-fit: cover; filter: saturate(.94) brightness(1.02); }
.l-figure--portrait .l-figure__media{ aspect-ratio: 4/5; }
.l-figure--wide .l-figure__media{ aspect-ratio: 16/10; }
.l-figure__cap{ margin-top: 12px; font-family: var(--q-font-mono); font-size: 11px; letter-spacing: .06em; text-transform: uppercase; color: var(--q-text-low); }
.l-figbadge{ position: absolute; z-index: 2; display: inline-flex; align-items: center; font-family: var(--q-font-mono); font-size: 11px; letter-spacing: .06em; text-transform: uppercase; color: var(--l-ink); padding: 7px 11px; border-radius: 10px; background: color-mix(in srgb,#fff 78%,transparent); backdrop-filter: blur(10px) saturate(1.1); -webkit-backdrop-filter: blur(10px) saturate(1.1); border: 1px solid rgba(255,255,255,.55); box-shadow: 0 6px 20px -10px rgba(16,18,42,.45); }
.l-figbadge--tl{ top: 12px; left: 12px; }
.l-figbadge--bl{ left: 14px; bottom: 14px; }
/* Неформальные emoji-пузыри, вылетают за край фото (лежат в .l-figure, не в media) */
.l-bub{ position: absolute; z-index: 4; display: grid; place-items: center; border-radius: 50%; line-height: 1;
  background: color-mix(in srgb,#fff 86%,transparent); backdrop-filter: blur(8px) saturate(1.15); -webkit-backdrop-filter: blur(8px) saturate(1.15);
  border: 1px solid rgba(255,255,255,.7);
  box-shadow: 0 1px 0 rgba(255,255,255,.9) inset, 0 10px 22px -8px rgba(16,18,42,.32), 0 0 0 4px color-mix(in srgb,var(--q-accent) 7%,transparent); }
.l-bub--j1{ width: 56px; height: 56px; font-size: 30px; top: 18px; right: -22px; transform: rotate(-7deg); z-index: 6; }
.l-bub--j2{ width: 40px; height: 40px; font-size: 22px; top: 74px; right: -10px; transform: rotate(5deg); z-index: 5; }
.l-bub--j3{ width: 30px; height: 30px; font-size: 16px; top: 130px; right: 6px; transform: rotate(-4deg); z-index: 4; }
.l-bub--f1{ width: 52px; height: 52px; font-size: 28px; top: -18px; right: 64px; transform: rotate(6deg); }
.l-bub--f2{ width: 38px; height: 38px; font-size: 20px; top: 26px; right: 18px; transform: rotate(-5deg); }
@media (max-width: 640px){
  .l-bub{ transform: scale(.8); }
  .l-bub--j1{ right: -6px; } .l-bub--j2{ right: -2px; }
}
.jobs-hero{ display: grid; grid-template-columns: 1fr 300px; gap: clamp(28px,4vw,56px); align-items: start; margin-bottom: clamp(36px,4.5vw,56px); }
.jobs-hero .l-head{ margin-bottom: 0; }
.format-figure{ margin: 0 0 clamp(28px,3.6vw,44px); }
.format-figure .l-figure__media{ aspect-ratio: auto; height: clamp(200px,24vw,300px); }
.format-figure .l-figure__img{ object-position: center 40%; }

/* ═══════════════ MENTORS / SPEAKERS ═══════════════ */
.l-mentors{ display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.l-mentor{ display: flex; flex-direction: column; background: var(--l-card); border: 1px solid var(--q-line); border-radius: var(--l-radius); padding: 26px; box-shadow: var(--l-sh-sm); }
.l-mentor__head{ display: flex; align-items: center; gap: 14px; margin-bottom: 16px; }
.l-mentor__photo{ width: 60px; height: 60px; border-radius: 16px; object-fit: cover; border: 1px solid var(--q-line); flex-shrink: 0; }
.l-mentor__role{ font-family: var(--q-font-mono); font-size: 10.5px; letter-spacing: .05em; text-transform: uppercase; color: var(--q-accent); line-height: 1.45; }
.l-mentor__name{ font-size: 18px; font-weight: 660; color: var(--l-ink); margin-bottom: 10px; }
.l-mentor__bio{ font-size: 13.5px; line-height: 1.55; color: var(--q-text-mid); margin-bottom: 14px; }
.l-mentor__facts{ list-style: none; display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.l-mentor__facts li{ position: relative; padding-left: 18px; font-size: 12.5px; line-height: 1.45; color: var(--q-text-mid); }
.l-mentor__facts li::before{ content: ""; position: absolute; left: 2px; top: 7px; width: 6px; height: 6px; border-radius: 2px; background: var(--l-soft2); }
.l-mentor__facts b{ color: var(--l-ink); font-weight: 640; }
.l-mentor__stack{ margin-top: auto; display: flex; flex-wrap: wrap; gap: 6px; }
.l-mentor__stack span{ font-family: var(--q-font-mono); font-size: 10.5px; color: var(--q-text-low); background: var(--l-alt); border: 1px solid var(--q-line); padding: 3px 8px; border-radius: 7px; }

/* ═══════════════ AI ═══════════════ */
.ai-section{ position: relative; overflow: hidden; }
.ai-answer{ font-size: clamp(23px,3.2vw,36px); font-weight: 640; letter-spacing: -.025em; line-height: 1.3; color: var(--l-ink); max-width: 760px; margin-bottom: 40px; }
.ai-answer em{ font-style: normal; color: var(--q-accent); }
.ai-grid{ display: grid; grid-template-columns: 1fr 1fr; gap: 28px; max-width: 900px; }
.ai-col{ background: var(--l-card); border: 1px solid var(--q-line); border-radius: var(--l-radius); padding: 28px; box-shadow: var(--l-sh-sm); }
.ai-col__eyebrow{ font-family: var(--q-font-mono); font-size: 10.5px; letter-spacing: .1em; color: var(--q-accent); margin-bottom: 12px; }
.ai-col__text{ font-size: 14px; line-height: 1.62; color: var(--q-text-mid); }
.ai-col__text strong{ color: var(--l-ink); font-weight: 600; }
.ai-bg{ position: absolute; right: -60px; top: 50%; transform: translateY(-50%); width: 440px; height: 440px; color: var(--q-accent); opacity: .1; pointer-events: none; }
.ai-bg svg{ width: 100%; height: 100%; }
/* AI pipeline (mono-line) */
.ai-flow{ position: relative; z-index: 1; display: flex; flex-wrap: wrap; align-items: stretch; gap: 8px; margin-top: 32px; max-width: 900px; }
.ai-flow__node{ flex: 1 1 0; min-width: 110px; display: flex; flex-direction: column; gap: 6px; background: var(--l-card); border: 1px solid var(--q-line); border-radius: var(--l-radius-sm); padding: 14px 16px; box-shadow: var(--l-sh-sm); }
.ai-flow__step{ font-family: var(--q-font-mono); font-size: 10px; letter-spacing: .1em; color: var(--q-text-low); }
.ai-flow__label{ font-size: 13.5px; font-weight: 600; color: var(--l-ink); }
.ai-flow__node--you{ border-color: var(--l-ring); background: var(--l-soft); }
.ai-flow__node--you .ai-flow__step{ color: var(--q-accent); }
.ai-flow__node--merge .ai-flow__label{ color: var(--q-accent); }
.ai-flow__arr{ align-self: center; width: 16px; height: 1.5px; background: var(--q-line-strong); flex-shrink: 0; position: relative; }
.ai-flow__arr::after{ content: ""; position: absolute; right: -1px; top: 50%; width: 6px; height: 6px; border-top: 1.5px solid var(--q-line-strong); border-right: 1.5px solid var(--q-line-strong); transform: translateY(-50%) rotate(45deg); }

/* testimonial proof line */
.testi-proof{ font-family: var(--q-font-mono); font-size: 11px; letter-spacing: .02em; line-height: 1.5; color: var(--q-text-mid); padding-top: 14px; border-top: 1px solid var(--q-line); }
.testi-proof b{ color: var(--q-accent); font-weight: 600; }

/* il-jobs proof overlay (glass data plate) */
.l-figproof{ position: absolute; left: 12px; bottom: 12px; z-index: 2; display: flex; flex-direction: column; gap: 1px; padding: 9px 12px; border-radius: 11px; background: color-mix(in srgb,#fff 80%,transparent); backdrop-filter: blur(10px) saturate(1.1); -webkit-backdrop-filter: blur(10px) saturate(1.1); border: 1px solid rgba(255,255,255,.55); box-shadow: 0 6px 20px -10px rgba(16,18,42,.45); }
.l-figproof b{ font-size: 14px; font-weight: 680; color: var(--l-ink); letter-spacing: -.01em; }
.l-figproof span{ font-family: var(--q-font-mono); font-size: 10px; letter-spacing: .04em; color: var(--q-text-low); }

/* GitHub contribution graph (faux-UI) */
.q-mock__screen--gh{ background: var(--l-card); aspect-ratio: auto; height: auto; }
.gh{ position: static; display: flex; flex-direction: column; gap: 14px; padding: clamp(16px,2.4vw,24px); }
.gh__head{ display: flex; flex-direction: column; gap: 2px; }
.gh__title{ font-size: 14px; font-weight: 660; color: var(--l-ink); }
.gh__sub{ font-family: var(--q-font-mono); font-size: 10.5px; letter-spacing: .04em; color: var(--q-text-low); }
.gh__graph{ display: grid; grid-auto-flow: column; grid-template-rows: repeat(7, 1fr); gap: 3px; aspect-ratio: 17 / 7; }
.gh-cell{ border-radius: 2px; background: var(--l-alt); }
.gh-cell.l1{ background: color-mix(in srgb,var(--q-accent) 22%, #fff); }
.gh-cell.l2{ background: color-mix(in srgb,var(--q-accent) 42%, #fff); }
.gh-cell.l3{ background: color-mix(in srgb,var(--q-accent) 64%, #fff); }
.gh-cell.l4{ background: var(--q-accent); }
.gh__facts{ list-style: none; display: flex; flex-direction: column; gap: 6px; margin-top: auto; }
.gh__facts li{ font-size: 12px; line-height: 1.4; color: var(--q-text-mid); }
.gh__facts b{ color: var(--l-ink); font-weight: 640; }

/* Jobs paid-task card + before→after timeline */
.jobs-proof{ display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin: 32px 0 0; }
.jobs-task{ background: var(--l-card); border: 1px solid var(--q-line); border-radius: var(--l-radius); padding: 22px; box-shadow: var(--l-sh-sm); display: flex; flex-direction: column; gap: 12px; }
.jobs-task__top{ display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.jobs-task__src{ font-family: var(--q-font-mono); font-size: 10px; letter-spacing: .07em; color: var(--q-text-low); }
.jobs-task__pay{ font-family: var(--q-font-mono); font-size: 13px; font-weight: 600; color: var(--l-green); background: color-mix(in srgb,var(--l-green) 12%, transparent); padding: 3px 10px; border-radius: 8px; }
.jobs-task__title{ font-size: 16px; font-weight: 640; color: var(--l-ink); line-height: 1.35; }
.jobs-task__meta{ font-size: 12.5px; color: var(--q-text-mid); }
.jobs-task__status{ display: flex; align-items: center; gap: 8px; font-size: 12.5px; color: var(--q-text-mid); margin-top: auto; }
.jobs-task__status code{ font-family: var(--q-font-mono); font-size: 11.5px; background: var(--l-alt); padding: 1px 6px; border-radius: 5px; }
.jobs-task__dot{ width: 7px; height: 7px; border-radius: 50%; background: var(--l-green); flex-shrink: 0; }
.ba-timeline{ display: flex; flex-direction: column; gap: 0; background: var(--l-card); border: 1px solid var(--q-line); border-radius: var(--l-radius); padding: 22px 24px; box-shadow: var(--l-sh-sm); justify-content: center; }
.ba-step{ display: flex; flex-direction: column; gap: 2px; }
.ba-step__k{ font-family: var(--q-font-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--q-text-low); }
.ba-step__v{ font-size: 14.5px; font-weight: 600; color: var(--l-ink); }
.ba-step--win .ba-step__v{ color: var(--q-accent); }
.ba-arr{ width: 1.5px; height: 22px; background: var(--q-line-strong); margin: 6px 0 6px 8px; position: relative; }
.ba-arr::after{ content: ""; position: absolute; bottom: -1px; left: 50%; width: 6px; height: 6px; border-bottom: 1.5px solid var(--q-line-strong); border-right: 1.5px solid var(--q-line-strong); transform: translateX(-50%) rotate(45deg); }
.jobs-proof--solo{ grid-template-columns: 1fr; max-width: 600px; }

/* Quillon Jobs board (реальный скрин биржи) */
.jobs-board{ display: grid; grid-template-columns: .92fr 1.08fr; gap: clamp(28px,4vw,56px); align-items: center; }
.jobs-board__facts{ list-style: none; display: flex; flex-direction: column; gap: 12px; margin-top: 24px; }
.jobs-board__facts li{ position: relative; padding-left: 24px; font-size: 14.5px; line-height: 1.5; color: var(--q-text-mid); }
.jobs-board__facts li::before{ content: ""; position: absolute; left: 2px; top: 8px; width: 8px; height: 8px; border-radius: 3px; background: var(--l-soft2); }
.jobs-board__facts b{ color: var(--l-ink); font-weight: 640; }
.jobs-board__shot{ margin: 0; }
.jobs-board__shot .q-mock{ box-shadow: 0 2px 8px rgba(16,18,42,.06), 0 40px 80px -44px color-mix(in srgb,var(--q-accent) 34%,rgba(16,18,42,.5)); }
.q-mock__screen--shot{ aspect-ratio: 16 / 11; background: #15161B; }

/* ═══════════════ PROD-GRID ═══════════════ */
.prod-grid{ display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px,4vw,56px); align-items: center; }
.prod-title{ font-size: clamp(27px,3.4vw,40px); font-weight: 670; letter-spacing: -.025em; line-height: 1.08; color: var(--l-ink); }
.prod-title em{ font-style: normal; color: var(--q-accent); }
.prod-text-p{ font-size: 15px; line-height: 1.62; color: var(--q-text-mid); margin: 20px 0 24px; }
.prod-text-p strong{ color: var(--l-ink); font-weight: 600; }
.prod-cta{ max-width: 400px; }
.prod-meta{ font-family: var(--q-font-mono); font-size: 11px; letter-spacing: .04em; color: var(--q-text-low); margin-top: 14px; }
.prod-price{ margin-top: 28px; border-top: 1px solid var(--q-line); padding-top: 24px; }
.prod-price__amount{ font-size: 22px; font-weight: 680; color: var(--l-ink); font-variant-numeric: tabular-nums; }
.prod-price__caption{ font-size: 13px; color: var(--q-text-low); margin-left: 12px; }
.prod-price__sub{ display: flex; gap: 28px; margin-top: 16px; }
.prod-price__cell{ display: flex; flex-direction: column; }
.ppv{ font-size: 18px; font-weight: 660; color: var(--q-accent); }
.ppk{ font-size: 11px; color: var(--q-text-low); margin-top: 2px; }

/* ═══════════════ MINI FORM ═══════════════ */
.mini-form{ background: var(--l-card); border: 1px solid var(--q-line); border-radius: clamp(18px,2vw,26px); padding: clamp(30px,4vw,56px); box-shadow: var(--l-sh-lg); }
.mini-form__title{ font-size: clamp(25px,3vw,36px); font-weight: 670; letter-spacing: -.025em; color: var(--l-ink); }
.mini-form__title em{ font-style: normal; color: var(--q-accent); }
.mini-form__lead{ margin-top: 16px; font-size: 15px; line-height: 1.62; color: var(--q-text-mid); max-width: 60ch; }
.mini-form__layout{ display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(28px,4vw,56px); margin-top: 34px; align-items: start; }
.mini-form__points{ list-style: none; display: flex; flex-direction: column; gap: 20px; }
.mini-form__points li{ display: flex; gap: 14px; align-items: flex-start; font-size: 14.5px; line-height: 1.45; color: var(--q-text-mid); }
.mfp-num{ font-family: var(--q-font-mono); font-size: 12px; color: var(--q-accent); flex-shrink: 0; padding-top: 1px; }
.mini-form__fields{ display: flex; flex-direction: column; gap: 14px; }
.mf-row{ display: grid; grid-template-columns: 30px 1fr; gap: 12px; align-items: center; }
.mf-num{ font-family: var(--q-font-mono); font-size: 12px; color: var(--q-text-faint); }
.mf-field{ display: flex; flex-direction: column; gap: 6px; }
.mf-label{ font-family: var(--q-font-mono); font-size: 10px; letter-spacing: .08em; color: var(--q-text-low); }
.mf-label em{ color: var(--q-accent); font-style: normal; }
.mf-input{ height: 46px; padding: 0 14px; border-radius: 11px; border: 1px solid var(--q-line-strong); background: var(--l-page); font: inherit; font-size: 14px; color: var(--l-ink); transition: border-color .15s, box-shadow .15s; }
.mf-input:focus-visible{ outline: none; border-color: var(--q-accent); box-shadow: 0 0 0 3px var(--l-ring); background: #fff; }
.mf-check{ display: flex; gap: 10px; align-items: flex-start; font-size: 12px; line-height: 1.45; color: var(--q-text-low); }
.mf-check input{ margin-top: 2px; accent-color: var(--q-accent); flex-shrink: 0; }
.mf-check u{ text-decoration-color: var(--q-line-strong); cursor: pointer; }
.mf-check em{ color: var(--q-accent); font-style: normal; }
.mf-submit{ margin-top: 6px; }

/* ═══════════════ FIT ═══════════════ */
.fit-grid-2{ display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.fit-item{ display: flex; gap: 13px; align-items: flex-start; background: var(--l-card); border: 1px solid var(--q-line); border-radius: var(--l-radius-sm); padding: 18px 20px; font-size: 14px; line-height: 1.5; color: var(--q-text-mid); box-shadow: var(--l-sh-sm); }
.fit-check{ width: 26px; height: 26px; border-radius: 50%; display: grid; place-items: center; background: var(--l-soft); color: var(--q-accent); flex-shrink: 0; }
.fit-check svg{ width: 13px; height: 13px; }

/* ═══════════════ FAQ ═══════════════ */
.faq-list{ max-width: 840px; display: flex; flex-direction: column; gap: 10px; }
.faq-item{ background: var(--l-card); border: 1px solid var(--q-line); border-radius: var(--l-radius-sm); overflow: hidden; box-shadow: var(--l-sh-sm); transition: box-shadow .2s; }
.faq-item.open{ box-shadow: var(--l-sh); }
.faq-q{ width: 100%; display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 19px 24px; background: none; border: 0; cursor: pointer; font: inherit; font-size: 15px; font-weight: 570; color: var(--l-ink); text-align: left; }
.faq-q__icon{ position: relative; width: 16px; height: 16px; flex-shrink: 0; }
.faq-q__icon::before, .faq-q__icon::after{ content: ""; position: absolute; background: var(--q-accent); border-radius: 2px; transition: transform .2s; }
.faq-q__icon::before{ left: 0; top: 7px; width: 16px; height: 2px; }
.faq-q__icon::after{ left: 7px; top: 0; width: 2px; height: 16px; }
.faq-item.open .faq-q__icon::after{ transform: scaleY(0); }
.faq-a{ display: grid; grid-template-rows: 0fr; transition: grid-template-rows .25s ease; }
.faq-item.open .faq-a{ grid-template-rows: 1fr; }
.faq-a > div{ overflow: hidden; padding: 0 24px; }
.faq-item.open .faq-a > div{ padding-bottom: 20px; font-size: 14px; line-height: 1.6; color: var(--q-text-mid); }
.faq-a strong{ color: var(--l-ink); }

/* ═══════════════ FOOTER — light ═══════════════ */
.l-footer{ background: var(--l-alt); border-top: 1px solid var(--q-line); padding: clamp(48px,6vw,72px) 0 32px; }
.l-footer__top{ display: grid; grid-template-columns: 1fr 2fr; gap: 40px; padding-bottom: 36px; border-bottom: 1px solid var(--q-line); }
.l-footer__brand img{ height: 24px; }
[data-theme="light"] .l-footer__brand img{ filter: invert(1) hue-rotate(180deg); }
.l-footer__tag{ margin-top: 14px; font-size: 13px; color: var(--q-text-low); }
.l-footer__cols{ display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; }
.l-footer__col h5{ font-family: var(--q-font-mono); font-size: 10.5px; letter-spacing: .1em; color: var(--q-text-faint); margin-bottom: 14px; }
.l-footer__col a{ display: block; font-size: 13.5px; color: var(--q-text-mid); text-decoration: none; padding: 4px 0; transition: color .15s; }
.l-footer__col a:hover{ color: var(--q-accent); }
.l-footer__bottom{ padding-top: 24px; font-family: var(--q-font-mono); font-size: 11px; color: var(--q-text-faint); }

/* ═══════════════ RESPONSIVE ═══════════════ */
@media (max-width: 1024px){
  .hero__grid{ grid-template-columns: 1fr; gap: clamp(28px,5vw,40px); }
  .hero__left{ padding-top: 0; }
  .hero__title{ max-width: 18ch; }
  .hero__sub{ max-width: 52ch; }
  .hero__right{ max-width: 560px; }
  .hero__proof-cap{ max-width: 56ch; }
  .trust-cards{ grid-template-columns: repeat(2,1fr); }
  .products{ grid-template-columns: 1fr 1fr; }
  .product--hero{ grid-template-columns: 1fr; }
  .feat-grid, .testi-grid, .tracks-3, .port-grid-cards{ grid-template-columns: 1fr 1fr; }
  .l-mentors{ grid-template-columns: 1fr; }
  .mini-grid, .stats-band{ grid-template-columns: 1fr 1fr; }
  .launch-grid, .prod-grid, .mini-form__layout{ grid-template-columns: 1fr; }
  .jobs-hero{ grid-template-columns: 1fr; }
  .jobs-hero .l-figure--portrait{ max-width: 280px; margin: 0 auto; }
  .jobs-board{ grid-template-columns: 1fr; }
  .launch-stat{ position: static; }
  .ai-bg{ display: none; }
  .problem-card--do{ transform: none; }
}
@media (max-width: 640px){
  .hero__form{ max-width: none; }
  .problem-grid, .feat-grid, .products, .testi-grid, .tracks-3, .jobs-grid,
  .port-grid-cards, .mini-grid, .stats-band, .fit-grid-2, .ai-grid, .trust-cards{ grid-template-columns: 1fr; }
  .phase{ grid-template-columns: 1fr; gap: 12px; }
  .urgency, .callout-green{ flex-direction: column; align-items: flex-start; }
  .jobs-proof{ grid-template-columns: 1fr; }
  .ai-flow{ flex-direction: column; }
  .ai-flow__arr{ display: none; }
  .launch-showcase{ padding: 14px; }
  .l-footer__top{ grid-template-columns: 1fr; }
  .l-footer__cols{ grid-template-columns: 1fr 1fr; }
  .prodline__rail .prodline-dot span{ font-size: 8px; }
}

@media (prefers-reduced-motion: reduce){
  *{ transition: none !important; animation: none !important; }
}

/* ── launch showcase: живой мок выпускного стартапа «Полка» (scaled iframe) ── */
.launch-showcase{ margin: 0 0 clamp(28px,4vw,44px); padding: clamp(16px,3vw,40px); border-radius: 24px; background: radial-gradient(120% 90% at 50% 12%, color-mix(in srgb,var(--q-accent) 7%,var(--l-page)), var(--l-page) 72%); }
.launch-showcase .q-mock{ max-width: 920px; margin: 0 auto; box-shadow: 0 2px 8px rgba(16,18,42,.06), 0 48px 88px -44px color-mix(in srgb,var(--q-accent) 38%,rgba(16,18,42,.5)); }
.q-mock--wide .q-mock__screen{ aspect-ratio: 16 / 9.5; background: #0A0E16; box-shadow: inset 0 0 0 1px rgba(255,255,255,.06); }
.q-mock__embed{ position: absolute; top: 0; left: 0; width: 150%; height: 150%; border: 0; transform: scale(.6667); transform-origin: 0 0; pointer-events: none; }
.launch-showcase__cap{ margin-top: 14px; text-align: center; font-size: 13px; color: var(--q-text-low); }
.launch-showcase__cap b{ color: var(--l-ink); font-weight: 600; }

/* ── risk-reversal strip (перед финальной формой) ── */
.risk-strip{ display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin: 0 0 clamp(32px,3.6vw,48px); }
.risk-strip__item{ display: flex; align-items: flex-start; gap: 16px; background: var(--l-card); border: 1px solid var(--q-line); border-radius: var(--l-radius-sm); padding: 24px; box-shadow: var(--l-sh-sm); }
.risk-strip__icon{ width: 40px; height: 40px; border-radius: 10px; display: grid; place-items: center; color: var(--q-accent); background: var(--l-soft); flex-shrink: 0; }
.risk-strip__icon svg{ width: 20px; height: 20px; }
.risk-strip__txt{ font-size: 13px; line-height: 1.45; color: var(--q-text-mid); }
.risk-strip__txt b{ display: block; color: var(--l-ink); font-weight: 620; font-size: 14px; margin-bottom: 4px; }
@media (max-width: 900px){ .risk-strip{ grid-template-columns: 1fr; } }

/* ── mobile sticky CTA ── */
.sticky-cta{ position: fixed; inset: auto 0 0 0; z-index: 60; display: none; align-items: center; justify-content: space-between; gap: 12px; padding: 12px 16px calc(12px + env(safe-area-inset-bottom)); background: var(--l-card); border-top: 1px solid var(--q-line-strong); box-shadow: 0 -10px 30px -16px rgba(16,18,42,.28); transform: translateY(112%); transition: transform .34s var(--l-ease); }
.sticky-cta.is-on{ transform: translateY(0); }
.sticky-cta__txt{ font-size: 12px; line-height: 1.3; color: var(--q-text-mid); min-width: 0; }
.sticky-cta__txt b{ display: block; font-size: 14px; color: var(--l-ink); font-weight: 640; }
.sticky-cta__btn{ flex-shrink: 0; padding: 12px 20px; touch-action: manipulation; }
@media (max-width: 760px){ .sticky-cta{ display: flex; } body{ padding-bottom: 76px; } }
