/* =========================
   Pro Hero (personal specialist)
   независимый блок: .pro-hero*
========================= */

.pro-hero__wrap {
  display: grid;
  gap: var(--s-10);
  align-items: center;
}

@media (min-width: 1024px) {
  .pro-hero__wrap {
    grid-template-columns: 1.15fr 0.85fr;
    gap: var(--s-12);
  }
}

.pro-hero__kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 var(--s-4);
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--txt);
  font-size: var(--fz-1);
}

.pro-hero__title {
  margin: 0 0 var(--s-5);
  max-width: 28ch;
}

.pro-hero__lead {
  margin: 0 0 var(--s-6);
  max-width: 70ch;
  font-size: var(--fz-3);
  color: var(--mut);
}

.pro-hero__proof {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--s-4);
  margin-bottom: var(--s-6);
}

@media (max-width: 640px) {
  .pro-hero__proof {
    grid-template-columns: 1fr;
  }
}

.pro-metric {
  padding: var(--s-5);
  border-radius: var(--r-4);
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg) 78%, white 10%);
  min-width: 0;
}

html[data-theme="light"] .pro-metric {
  background: color-mix(in srgb, white 92%, var(--bg) 8%);
}

.pro-metric__value {
  font-weight: 750;
  letter-spacing: -0.01em;
  color: var(--txt);
}

.pro-metric__label {
  margin-top: 6px;
  font-size: var(--fz-1);
  color: var(--mut);
}

.pro-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-4);
  margin-bottom: var(--s-6);
}

.pro-hero__chips {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--s-6);
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
}

.pro-chip {
  display: inline-flex;
  align-items: center;
  height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg) 72%, white 7%);
  color: var(--txt);
  font-size: var(--fz-1);
}

.pro-hero__mini {
  display: grid;
  gap: var(--s-3);
  max-width: 56ch;
}

.pro-mini__row {
  display: flex;
  justify-content: space-between;
  gap: var(--s-6);
  padding: 12px 14px;
  border-radius: var(--r-3);
  border: 1px solid var(--line);
  background: var(--surface);
}

.pro-mini__label {
  color: var(--mut);
  font-size: var(--fz-1);
}

.pro-mini__value {
  color: var(--txt);
  font-weight: 600;
  text-decoration: none;
}
.pro-mini__value:hover {
  text-decoration: underline;
}

/* ===== Portrait card (selling photo) ===== */

.pro-portrait {
  padding: 0;
  overflow: hidden;
  position: relative;
  min-width: 0;
  background: color-mix(in srgb, var(--bg) 78%, white 10%);
  border: 1px solid color-mix(in srgb, var(--line) 90%, transparent);
}

html[data-theme="light"] .pro-portrait {
  background: color-mix(in srgb, white 92%, var(--bg) 8%);
}

.pro-portrait__frame {
  position: relative;
  aspect-ratio: 4 / 5;
  background: radial-gradient(
      700px 420px at 20% 10%,
      color-mix(in srgb, var(--accent) 18%, transparent),
      transparent 60%
    ),
    radial-gradient(
      700px 420px at 85% 15%,
      color-mix(in srgb, var(--accent-2) 14%, transparent),
      transparent 60%
    ),
    color-mix(in srgb, var(--bg) 78%, white 10%);
}

/* Фото — максимально презентабельно */
.pro-portrait__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 20%; /* лицо выше центра */
  display: block;
  filter: contrast(1.03) saturate(1.02);
}

/* Лёгкая виньетка + “глянец” */
.pro-portrait__frame::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(120% 90% at 50% 20%, transparent 55%, rgba(0, 0, 0, 0.28) 100%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 30%, rgba(0, 0, 0, 0.25));
  pointer-events: none;
}

.pro-portrait__cap {
  padding: var(--s-8);
  display: grid;
  gap: 8px;
}

.pro-portrait__name {
  font-weight: 800;
  letter-spacing: -0.01em;
  font-size: var(--fz-4);
  line-height: 1.1;
}

.pro-portrait__cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  margin-top: var(--s-3);
}

.btn--sm {
  height: 34px;
  padding: 0 12px;
  border-radius: 12px;
  font-size: var(--fz-1);
}

/* Декоративный “штамп” доверия */
.pro-portrait__stamp {
  position: absolute;
  right: 14px;
  top: 14px;
  display: grid;
  gap: 6px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  background: color-mix(in srgb, var(--bg) 72%, transparent);
  backdrop-filter: blur(8px);
  font-size: 11px;
  color: color-mix(in srgb, var(--txt) 80%, transparent);
}

/* Mobile tightening */
@media (max-width: 640px) {
  .pro-hero__wrap {
    gap: var(--s-8);
  }

  .pro-portrait__cap {
    padding: var(--s-6);
  }

  .pro-hero__actions .btn {
    width: 100%;
  }

  .pro-mini__row {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
}

/* =========================
   Pro Quote Hero (interview style)
========================= */
.proq-hero__wrap {
  padding: 0;
  overflow: hidden;
  background: color-mix(in srgb, var(--bg) 80%, white 10%);
  border: 1px solid color-mix(in srgb, var(--line) 90%, transparent);
}

html[data-theme="light"] .proq-hero__wrap {
  background: color-mix(in srgb, white 94%, var(--bg) 6%);
}

.proq-hero__wrap {
  display: grid;
  gap: 0;
}

@media (min-width: 1024px) {
  .proq-hero__wrap {
    grid-template-columns: 0.95fr 1.05fr;
  }
}

/* Photo side */
.proq-hero__media {
  margin: 0;
  position: relative;
  min-height: 360px;
  background: radial-gradient(
      900px 520px at 15% 15%,
      color-mix(in srgb, var(--accent) 16%, transparent),
      transparent 60%
    ),
    radial-gradient(
      900px 520px at 85% 10%,
      color-mix(in srgb, var(--accent-2) 12%, transparent),
      transparent 60%
    ),
    color-mix(in srgb, var(--bg) 72%, white 10%);
}

.proq-hero__img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: 50% 20%;
  filter: contrast(1.03) saturate(1.02);
}

.proq-hero__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(120% 90% at 50% 20%, transparent 55%, rgba(0, 0, 0, 0.35) 100%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 35%, rgba(0, 0, 0, 0.3));
  pointer-events: none;
}

.proq-hero__tag {
  position: absolute;
  left: 16px;
  bottom: 16px;
  display: grid;
  gap: 4px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  background: color-mix(in srgb, var(--bg) 70%, transparent);
  backdrop-filter: blur(10px);
  color: var(--txt);
}

.proq-hero__name {
  font-weight: 800;
  letter-spacing: -0.01em;
}
.proq-hero__role {
  font-size: var(--fz-1);
  color: color-mix(in srgb, var(--txt) 80%, transparent);
}

/* Content */
.proq-hero__content {
  padding: var(--s-12);
  display: grid;
  gap: var(--s-6);
  min-width: 0;
}

@media (max-width: 640px) {
  .proq-hero__content {
    padding: var(--s-8);
  }
}

.proq-hero__kicker {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--txt);
  font-size: var(--fz-1);
  width: fit-content;
}

.proq-hero__title {
  margin: 0;
  max-width: 30ch;
}

.proq-hero__quote {
  margin: 0;
  padding: var(--s-6);
  border-radius: var(--r-4);
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--surface) 70%, transparent);
}

.proq-hero__quote p {
  margin: 0;
  color: color-mix(in srgb, var(--txt) 90%, transparent);
  font-size: var(--fz-3);
  line-height: 1.35;
}

.proq-hero__bullets {
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 10px;
  color: var(--mut);
}

.proq-hero__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--s-4);
}

@media (max-width: 640px) {
  .proq-hero__stats {
    grid-template-columns: 1fr;
  }
}

.proq-stat {
  padding: var(--s-5);
  border-radius: var(--r-4);
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg) 78%, white 10%);
}

html[data-theme="light"] .proq-stat {
  background: color-mix(in srgb, white 92%, var(--bg) 8%);
}

.proq-stat__v {
  font-weight: 800;
  letter-spacing: -0.01em;
}
.proq-stat__l {
  margin-top: 6px;
  font-size: var(--fz-1);
  color: var(--mut);
}

.proq-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-4);
}

@media (max-width: 640px) {
  .proq-hero__actions .btn {
    width: 100%;
  }
}

.proq-hero__note {
  margin: 0;
}

/* =========================
   Pro Background Hero (premium portrait)
========================= */
.probg-hero {
  position: relative;
  overflow: hidden;
}

/* full background image */
.probg-hero__bg {
  position: absolute;
  inset: 0;
  z-index: -2;
}

.probg-hero__bgimg {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 20%;
  display: block;
  filter: contrast(1.03) saturate(1.02);
}

/* overlays to keep text readable */
.probg-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: radial-gradient(
      900px 520px at 15% 15%,
      color-mix(in srgb, var(--accent) 14%, transparent),
      transparent 60%
    ),
    radial-gradient(
      900px 520px at 85% 10%,
      color-mix(in srgb, var(--accent-2) 12%, transparent),
      transparent 60%
    ),
    linear-gradient(180deg, rgba(0, 0, 0, 0.55), rgba(0, 0, 0, 0.7));
}

html[data-theme="light"] .probg-hero::before {
  background: radial-gradient(900px 520px at 15% 15%, rgba(11, 107, 255, 0.14), transparent 60%),
    radial-gradient(900px 520px at 85% 10%, rgba(107, 77, 255, 0.1), transparent 60%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.7), rgba(255, 255, 255, 0.82));
}

.probg-hero__wrap {
  display: grid;
  gap: var(--s-10);
  align-items: center;
  padding-block: calc(var(--section-py) + var(--s-6)); /* можно как у hero */
}

@media (min-width: 1024px) {
  .probg-hero__wrap {
    grid-template-columns: 1.05fr 0.45fr;
    gap: var(--s-12);
  }
}

/* glass panel */
.probg-hero__panel {
  padding: var(--s-12);
  border-radius: calc(var(--r-4) + 8px);
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  /* background: color-mix(in srgb, var(--bg) 68%, transparent);
  backdrop-filter: blur(14px); */
  box-shadow: var(--shadow-2);
}

/* html[data-theme="light"] .probg-hero__panel {
  background: rgba(255, 255, 255, 0.74);
}*/

@media (max-width: 640px) {
  .probg-hero__panel {
    padding: var(--s-8);
  }
}

.probg-hero__kicker {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  background: color-mix(in srgb, var(--surface) 70%, transparent);
  color: var(--txt);
  font-size: var(--fz-1);
  margin: 0 0 var(--s-5);
  width: fit-content;
}

.probg-hero__title {
  margin: 0 0 var(--s-4);
  font-size: clamp(34px, 4vw, 56px);
  line-height: 1.05;
  letter-spacing: -0.02em;
}

.probg-hero__subtitle {
  margin: 0 0 var(--s-6);
  font-size: var(--fz-3);
  color: color-mix(in srgb, var(--txt) 85%, transparent);
  max-width: 70ch;
}

.probg-hero__highlights {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  margin-bottom: var(--s-6);
}

.probg-pill {
  display: inline-flex;
  align-items: center;
  height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  background: color-mix(in srgb, var(--bg) 72%, transparent);
  color: var(--txt);
  font-size: var(--fz-1);
}

.probg-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-4);
  margin-bottom: var(--s-6);
}

@media (max-width: 640px) {
  .probg-hero__actions .btn {
    width: 100%;
  }
}

.probg-hero__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--s-4);
  margin-bottom: var(--s-6);
}

@media (max-width: 640px) {
  .probg-hero__stats {
    grid-template-columns: 1fr;
  }
}

.probg-stat {
  padding: 12px 14px;
  border-radius: var(--r-4);
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  background: color-mix(in srgb, var(--surface) 70%, transparent);
}

.probg-stat__v {
  font-weight: 850;
  letter-spacing: -0.01em;
}
.probg-stat__l {
  margin-top: 4px;
  font-size: var(--fz-1);
  color: color-mix(in srgb, var(--txt) 75%, transparent);
}

.probg-hero__note {
  margin: 0;
}

/* side badge */
.probg-badge {
  padding: var(--s-8);
  border-radius: calc(var(--r-4) + 6px);
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  background: color-mix(in srgb, var(--bg) 68%, transparent);
  backdrop-filter: blur(12px);
}

html[data-theme="light"] .probg-badge {
  background: rgba(255, 255, 255, 0.74);
}

.probg-badge__title {
  font-weight: 800;
  margin-bottom: var(--s-4);
}

.probg-badge__links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  margin-top: var(--s-4);
}

/* =========================
   Pro Video Hero
========================= */
.prov-hero__wrap {
  display: grid;
  gap: var(--s-10);
  align-items: start;
}

@media (min-width: 1024px) {
  .prov-hero__wrap {
    grid-template-columns: 1.1fr 0.9fr;
    gap: var(--s-12);
    align-items: center;
  }
}

.prov-hero__kicker {
  display: inline-flex;
  align-items: center;
  margin: 0 0 var(--s-4);
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--txt);
  font-size: var(--fz-1);
  width: fit-content;
}

.prov-hero__title {
  margin: 0 0 var(--s-5);
  max-width: 30ch;
}

.prov-hero__lead {
  margin: 0 0 var(--s-6);
  font-size: var(--fz-3);
  color: var(--mut);
  max-width: 75ch;
}

.prov-hero__facts {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--s-4);
  margin-bottom: var(--s-6);
}

@media (max-width: 640px) {
  .prov-hero__facts {
    grid-template-columns: 1fr;
  }
}

.prov-fact {
  padding: var(--s-5);
  border-radius: var(--r-4);
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg) 78%, white 10%);
}

html[data-theme="light"] .prov-fact {
  background: color-mix(in srgb, white 92%, var(--bg) 8%);
}

.prov-fact__v {
  font-weight: 850;
  letter-spacing: -0.01em;
  color: var(--txt);
}
.prov-fact__l {
  margin-top: 6px;
  font-size: var(--fz-1);
  color: var(--mut);
}

.prov-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-4);
  margin-bottom: var(--s-6);
}
@media (max-width: 640px) {
  .prov-hero__actions .btn {
    width: 100%;
  }
}

.prov-hero__mini {
  display: grid;
  gap: var(--s-3);
  max-width: 70ch;
}
.prov-mini__row {
  display: flex;
  justify-content: space-between;
  gap: var(--s-6);
  padding: 12px 14px;
  border-radius: var(--r-3);
  border: 1px solid var(--line);
  background: var(--surface);
}
.prov-mini__label {
  color: var(--mut);
  font-size: var(--fz-1);
}
.prov-mini__value {
  color: var(--txt);
  font-weight: 600;
}

/* Video card */
.prov-video {
  padding: 0;
  overflow: hidden;
  background: color-mix(in srgb, var(--bg) 78%, white 10%);
  border: 1px solid color-mix(in srgb, var(--line) 90%, transparent);
  position: relative;
}

html[data-theme="light"] .prov-video {
  background: color-mix(in srgb, white 92%, var(--bg) 8%);
}

.prov-video__frame {
  position: relative;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  background: radial-gradient(
      900px 520px at 15% 15%,
      color-mix(in srgb, var(--accent) 14%, transparent),
      transparent 60%
    ),
    radial-gradient(
      900px 520px at 85% 10%,
      color-mix(in srgb, var(--accent-2) 12%, transparent),
      transparent 60%
    ),
    color-mix(in srgb, var(--bg) 74%, white 8%);
}

.prov-video__el,
.prov-video__poster {
  width: 100%;
  aspect-ratio: 10 / 16;
  display: block;
  object-fit: cover;
  object-position: 50% 20%;
}

.prov-video__cap {
  padding: var(--s-8);
  display: grid;
  gap: 6px;
}

@media (max-width: 640px) {
  .prov-video__cap {
    padding: var(--s-6);
  }
}

.prov-video__name {
  font-weight: 850;
  letter-spacing: -0.01em;
  font-size: var(--fz-4);
  line-height: 1.1;
}
.prov-video__badge {
  position: absolute;
  top: 14px;
  right: 14px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  background: color-mix(in srgb, var(--bg) 72%, transparent);
  backdrop-filter: blur(10px);
  font-size: 12px;
  color: color-mix(in srgb, var(--txt) 85%, transparent);
}

/* =========================
   Pro Social Proof Hero
========================= */
.pros-hero__wrap {
  display: grid;
  gap: var(--s-10);
  align-items: start;
}

@media (min-width: 1024px) {
  .pros-hero__wrap {
    grid-template-columns: 0.85fr 1.15fr;
    gap: var(--s-12);
    align-items: center;
  }
}

.pros-hero__kicker {
  display: inline-flex;
  align-items: center;
  margin: 0 0 var(--s-4);
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--txt);
  font-size: var(--fz-1);
  width: fit-content;
}

.pros-hero__title {
  margin: 0 0 var(--s-5);
  max-width: 34ch;
}

.pros-hero__lead {
  margin: 0 0 var(--s-6);
  font-size: var(--fz-3);
  color: var(--mut);
  max-width: 75ch;
}

/* Portrait card */
.pros-card {
  padding: 0;
  overflow: hidden;
  background: color-mix(in srgb, var(--bg) 78%, white 10%);
  border: 1px solid color-mix(in srgb, var(--line) 90%, transparent);
}

html[data-theme="light"] .pros-card {
  background: color-mix(in srgb, white 92%, var(--bg) 8%);
}

.pros-card__photo {
  position: relative;
  aspect-ratio: 4 / 5;
  background: radial-gradient(
      900px 520px at 15% 15%,
      color-mix(in srgb, var(--accent) 14%, transparent),
      transparent 60%
    ),
    radial-gradient(
      900px 520px at 85% 10%,
      color-mix(in srgb, var(--accent-2) 12%, transparent),
      transparent 60%
    ),
    color-mix(in srgb, var(--bg) 74%, white 8%);
}

.pros-card__img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: 50% 18%;
  filter: contrast(1.03) saturate(1.02);
}

.pros-card__photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(120% 90% at 50% 20%, transparent 55%, rgba(0, 0, 0, 0.32) 100%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 35%, rgba(0, 0, 0, 0.25));
  pointer-events: none;
}

.pros-card__cap {
  padding: var(--s-8);
  display: grid;
  gap: 6px;
}

@media (max-width: 640px) {
  .pros-card__cap {
    padding: var(--s-6);
  }
}

.pros-card__name {
  font-weight: 900;
  letter-spacing: -0.01em;
  font-size: var(--fz-4);
  line-height: 1.1;
}

.pros-card__cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  margin-top: var(--s-4);
}

/* logos */
.pros-hero__logos {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: var(--s-3);
  margin: 0 0 var(--s-6);
}

@media (max-width: 900px) {
  .pros-hero__logos {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 640px) {
  .pros-hero__logos {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.pros-logo {
  height: 44px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg) 72%, white 7%);
  display: grid;
  place-items: center;
  color: color-mix(in srgb, var(--txt) 75%, transparent);
  font-weight: 800;
  letter-spacing: 0.06em;
  font-size: 12px;
  text-transform: uppercase;
}

/* stats */
.pros-hero__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--s-4);
  margin-bottom: var(--s-6);
}

@media (max-width: 640px) {
  .pros-hero__stats {
    grid-template-columns: 1fr;
  }
}

.pros-stat {
  padding: var(--s-5);
  border-radius: var(--r-4);
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg) 78%, white 10%);
}

html[data-theme="light"] .pros-stat {
  background: color-mix(in srgb, white 92%, var(--bg) 8%);
}

.pros-stat__v {
  font-weight: 900;
  letter-spacing: -0.01em;
  color: var(--txt);
}
.pros-stat__l {
  margin-top: 6px;
  font-size: var(--fz-1);
  color: var(--mut);
}

/* bullets */
.pros-hero__bullets {
  display: grid;
  gap: var(--s-4);
  margin-bottom: var(--s-6);
}

@media (min-width: 900px) {
  .pros-hero__bullets {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.pros-bullet {
  padding: var(--s-5);
  border-radius: var(--r-4);
  border: 1px solid var(--line);
  background: var(--surface);
}

.pros-bullet__t {
  font-weight: 850;
  margin-bottom: 6px;
}
.pros-bullet__d {
  margin: 0;
}

.pros-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-4);
}

@media (max-width: 640px) {
  .pros-hero__actions .btn {
    width: 100%;
  }
}

.pros-hero__note {
  margin: var(--s-6) 0 0;
}

/* =========================
   HERO-DOC A/B (documents-first)
========================= */

.dochtero__wrap {
  display: grid;
  gap: var(--s-10);
  align-items: start;
  min-width: 0;
}
@media (min-width: 1024px) {
  .dochtero__wrap {
    grid-template-columns: 1.05fr 0.95fr;
    gap: var(--s-12);
  }
}

.dochtero__main {
  min-width: 0;
}
.dochtero__kicker {
  display: inline-flex;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--surface);
  margin: 0 0 var(--s-4);
  font-size: var(--fz-1);
  color: var(--txt);
}
.dochtero__title {
  margin: 0 0 var(--s-5);
  letter-spacing: -0.02em;
  line-height: 1.08;
  max-width: 28ch;
}
.dochtero__lead {
  margin: 0 0 var(--s-6);
  font-size: var(--fz-3);
  color: var(--mut);
  max-width: 70ch;
}
.dochtero__stats {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--s-6);
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--s-4);
}
@media (max-width: 640px) {
  .dochtero__stats {
    grid-template-columns: 1fr;
  }
}
.dochtero__stat {
  padding: var(--s-5);
  display: grid;
  gap: 6px;
  min-width: 0;
}
.dochtero__stat b {
  font-size: var(--fz-3);
  letter-spacing: -0.01em;
}
.dochtero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-4);
  margin-bottom: var(--s-4);
}
.dochtero__foot {
  font-size: var(--fz-1);
}

/* docs card */
.dochtero__docs {
  padding: var(--s-8);
  min-width: 0;
}
.dochtero__docs-head {
  display: grid;
  gap: var(--s-6);
  align-items: start;
  margin-bottom: var(--s-6);
}
@media (min-width: 720px) {
  .dochtero__docs-head {
    grid-template-columns: 1fr auto;
    gap: var(--s-8);
  }
}
.dochtero__docs-title h2 {
  margin: 0 0 6px;
  font-size: var(--fz-4);
}
.dochtero__docs-title p {
  margin: 0;
}

.dochtero__portrait {
  width: 92px;
  height: 92px;
  border-radius: 22px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg) 72%, white 8%);
  overflow: hidden;
}
.dochtero__portrait-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 22%;
  display: block;
}

/* document grid */
.dochtero__docgrid {
  display: grid;
  gap: var(--s-4);
  min-width: 0;
}
@media (min-width: 640px) {
  .dochtero__docgrid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.dochtero__doc {
  min-width: 0;
}
.dochtero__doc-link {
  display: flex;
  gap: var(--s-4);
  align-items: center;
  padding: var(--s-5);
  border-radius: var(--r-4);
  border: 1px solid color-mix(in srgb, var(--line) 75%, transparent);
  background: color-mix(in srgb, var(--bg) 74%, white 8%);
  text-decoration: none;
  color: var(--txt);
  min-width: 0;
  transition: border-color 0.15s ease, background 0.15s ease, transform 0.15s ease;
}
.dochtero__doc-link:hover {
  border-color: color-mix(in srgb, var(--accent) 35%, var(--line));
  background: color-mix(in srgb, var(--bg) 70%, white 10%);
}
.dochtero__doc-link:active {
  transform: translateY(1px);
}

.dochtero__doc-thumb {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: radial-gradient(
      120px 80px at 30% 20%,
      color-mix(in srgb, var(--accent) 16%, transparent),
      transparent 60%
    ),
    var(--surface);
  flex: 0 0 auto;
}
.dochtero__doc-thumb--case {
  background: radial-gradient(
      120px 80px at 30% 20%,
      color-mix(in srgb, var(--accent-2) 16%, transparent),
      transparent 60%
    ),
    var(--surface);
}

.dochtero__doc-meta {
  min-width: 0;
  display: grid;
  gap: 2px;
}
.dochtero__doc-name {
  font-weight: 700;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.dochtero__doc-sub {
  font-size: var(--fz-1);
}

.dochtero__docs-actions {
  margin-top: var(--s-6);
  display: grid;
  gap: var(--s-4);
}
@media (min-width: 520px) {
  .dochtero__docs-actions {
    grid-template-columns: 1fr 1fr;
  }
}
.dochtero__docs-actions .btn {
  width: 100%;
}

/* =========================
   HERO-DOC B (portrait first on mobile)
========================= */

.dochteroB {
  display: grid;
  gap: var(--s-10);
  align-items: start;
  min-width: 0;
}

/* desktop layout */
@media (min-width: 1024px) {
  .dochteroB {
    grid-template-columns: 0.9fr 1.1fr;
    grid-template-areas:
      "main portrait"
      "main docs";
    gap: var(--s-12);
  }
  .dochteroB__main {
    grid-area: main;
  }
  .dochteroB__portrait {
    grid-area: portrait;
  }
  .dochteroB__docs {
    grid-area: docs;
  }
}

/* mobile order: portrait -> docs -> main */
.dochteroB__portrait {
  padding: 0;
  overflow: hidden;
  min-width: 0;
  position: relative;
}
.dochteroB__portrait-img {
  width: 100%;
  aspect-ratio: 16 / 11;
  object-fit: cover;
  object-position: 50% 18%;
  display: block;
}
.dochteroB__portrait-badge {
  position: absolute;
  left: 12px;
  bottom: 12px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg) 78%, transparent);
  backdrop-filter: blur(10px);
  font-size: 12px;
  color: color-mix(in srgb, var(--txt) 85%, transparent);
}

.dochteroB__docs {
  padding: var(--s-8);
  min-width: 0;
}
@media (max-width: 640px) {
  .dochteroB__docs {
    padding: var(--s-6);
  }
}

.dochteroB__docs-title {
  margin: 0 0 var(--s-6);
  font-size: var(--fz-4);
}

.dochteroB__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--s-4);
}

.dochteroB__link {
  display: flex;
  gap: var(--s-4);
  align-items: center;
  padding: var(--s-5);
  border-radius: var(--r-4);
  border: 1px solid color-mix(in srgb, var(--line) 75%, transparent);
  background: color-mix(in srgb, var(--bg) 74%, white 8%);
  text-decoration: none;
  color: var(--txt);
  min-width: 0;
}

.dochteroB__icon {
  width: 40px;
  height: 40px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--accent) 45%, transparent);
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  flex: 0 0 auto;
}

.dochteroB__txt {
  min-width: 0;
  display: grid;
  gap: 2px;
}
.dochteroB__txt b {
  overflow-wrap: anywhere;
  word-break: break-word;
}
.dochteroB__docs-actions {
  margin-top: var(--s-6);
  display: grid;
  gap: var(--s-4);
}
@media (min-width: 520px) {
  .dochteroB__docs-actions {
    grid-template-columns: 1fr 1fr;
  }
}
.dochteroB__docs-actions .btn {
  width: 100%;
}

.dochteroB__main {
  min-width: 0;
}

/* =========================
   doc-hero-b (B)
   HTML: .dochteroB__portrait (1), .dochteroB__docs (2), .dochteroB__main (3)
   Mobile: portrait -> docs -> main
   Desktop: 2x2 grid:
     1) portrait = (row1, col1)
     2) docs     = (col2, rows1-2)
     3) main     = (row2, col1)
========================= */

.dochero--B .dochteroB {
  display: grid;
  gap: var(--s-10);
  align-items: start;
}

/* cards spacing */
.dochero--B .dochteroB__portrait,
.dochero--B .dochteroB__docs {
  padding: var(--s-8);
}

/* portrait card */
.dochero--B .dochteroB__portrait {
  position: relative;
  overflow: hidden;
  min-width: 0;
}

/* image fills portrait card box */
.dochero--B .dochteroB__portrait-img {
  width: 100%;
  display: block;
  object-fit: cover;
  object-position: 50% 18%;
  border-radius: calc(var(--r-4) - 2px);
}

/* badge */
.dochero--B .dochteroB__portrait-badge {
  position: absolute;
  left: var(--s-6);
  bottom: var(--s-6);
  display: inline-flex;
  align-items: center;
  height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg) 82%, transparent);
  color: var(--txt);
  font-size: var(--fz-1);
  backdrop-filter: blur(10px);
}

/* docs card */
.dochero--B .dochteroB__docs {
  min-width: 0;
}

.dochero--B .dochteroB__docs-title {
  margin: 0 0 var(--s-6);
  line-height: 1.12;
}

/* list base */
.dochero--B .dochteroB__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--s-4);
  min-width: 0;
}

.dochero--B .dochteroB__link {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: var(--s-4);
  align-items: center;

  padding: var(--s-5);
  border-radius: var(--r-3);
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg) 72%, white 7%);
  text-decoration: none;
  color: var(--txt);

  min-width: 0;
}

.dochero--B .dochteroB__link:hover {
  border-color: color-mix(in srgb, var(--accent) 35%, var(--line));
  background: color-mix(in srgb, var(--bg) 68%, white 9%);
}

.dochero--B .dochteroB__icon {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--accent) 45%, var(--line));
  background: color-mix(in srgb, var(--accent) 14%, transparent);
}

.dochero--B .dochteroB__txt {
  min-width: 0;
  display: grid;
  gap: 6px;
}

.dochero--B .dochteroB__txt b {
  font-weight: 650;
  line-height: 1.15;
}

.dochero--B .dochteroB__txt .muted {
  color: var(--mut);
  font-size: var(--fz-1);
}

/* actions */
.dochero--B .dochteroB__docs-actions {
  margin-top: var(--s-6);
  display: grid;
  gap: var(--s-4);
}

@media (min-width: 520px) {
  .dochero--B .dochteroB__docs-actions {
    grid-template-columns: 1fr 1fr;
  }
}

.dochero--B .dochteroB__docs-actions .btn {
  width: 100%;
  min-width: 0;
}

/* main text */
.dochero--B .dochteroB__main {
  min-width: 0;
}

/* safety: no overflow */
.dochero--B .dochteroB,
.dochero--B .dochteroB__portrait,
.dochero--B .dochteroB__docs,
.dochero--B .dochteroB__main,
.dochero--B .dochteroB__txt {
  min-width: 0;
}

/* =========================
   Desktop 2x2 + correct stretching + scroll inside docs
========================= */
@media (min-width: 1024px) {
  .dochero--B .dochteroB {
    /* 2 колонки */
    grid-template-columns: 1.05fr 0.95fr;

    /* 2 строки: row1 фиксируем (это высота фото), row2 растягиваем */
    grid-template-rows: clamp(320px, 40vh, 460px) minmax(0, 1fr);

    /* ограничиваем высоту блока под 1 экран (иначе 1fr внутри не “дефайнат”) */
    min-height: min(760px, 78vh);

    align-items: stretch;
    gap: var(--s-10);
  }

  /* 1) portrait в (row1, col1) и заполняет свою строку */
  .dochero--B .dochteroB__portrait {
    grid-column: 1;
    grid-row: 1;
    padding: 0; /* важное: чтобы картинка реально “до краёв” */
    border-radius: var(--r-4);
  }

  .dochero--B .dochteroB__portrait-img {
    height: 100%;
    width: 100%;
    border-radius: var(--r-4);
  }

  /* badge чуть внутрь */
  .dochero--B .dochteroB__portrait-badge {
    left: var(--s-6);
    bottom: var(--s-6);
  }

  /* 3) main в (row2, col1) */
  .dochero--B .dochteroB__main {
    grid-column: 1;
    grid-row: 2;
    align-self: start;
  }

  /* 2) docs занимает col2 и rows1-2 (то есть 2+4 ячейки) */
  .dochero--B .dochteroB__docs {
    grid-column: 2;
    grid-row: 1 / span 2;

    /* внутренний лейаут: title / list(1fr) / actions */
    display: grid;
    grid-template-rows: auto minmax(0, 1fr) auto;

    min-height: 0;
    align-self: stretch;
  }

  /* список получает “остаток” и скроллится */
  .dochero--B .dochteroB__list {
    min-height: 0;
    overflow: auto;
    padding-right: 6px;
  }

  /* аккуратный скроллбар */
  .dochero--B .dochteroB__list::-webkit-scrollbar {
    width: 10px;
  }
  .dochero--B .dochteroB__list::-webkit-scrollbar-thumb {
    background: color-mix(in srgb, var(--line) 70%, transparent);
    border-radius: 999px;
    border: 2px solid transparent;
    background-clip: padding-box;
  }
}

/* Небольшие ноуты / 67% масштаб: чуть плотнее */
@media (min-width: 1024px) and (max-height: 860px) {
  .dochero--B .dochteroB {
    grid-template-rows: clamp(300px, 36vh, 420px) minmax(0, 1fr);
    min-height: min(720px, 76vh);
    gap: var(--s-8);
  }

  .dochero--B .dochteroB__docs {
    padding: var(--s-6);
  }
}

/* Mobile tightening */
@media (max-width: 640px) {
  .dochero--B .dochteroB__portrait,
  .dochero--B .dochteroB__docs {
    padding: var(--s-6);
  }
}

/* =========================
   DOCS: Showcase (large previews)
========================= */

.docs-showcase__grid {
  display: grid;
  gap: var(--s-6);
  min-width: 0;
}
@media (min-width: 900px) {
  .docs-showcase__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.docs-showcase__card {
  overflow: hidden;
  min-width: 0;
}
.docs-showcase__link {
  display: grid;
  grid-template-rows: auto 1fr;
  text-decoration: none;
  color: var(--txt);
}

.docs-showcase__thumb {
  width: 100%;
  aspect-ratio: 16/10;
  background: radial-gradient(
      900px 500px at 10% 15%,
      color-mix(in srgb, var(--accent) 14%, transparent),
      transparent 60%
    ),
    color-mix(in srgb, var(--bg) 74%, white 8%);
  border-bottom: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
}
.docs-showcase__thumb--alt {
  background: radial-gradient(
      900px 500px at 10% 15%,
      color-mix(in srgb, var(--accent-2) 14%, transparent),
      transparent 60%
    ),
    color-mix(in srgb, var(--bg) 74%, white 8%);
}

.docs-showcase__body {
  padding: var(--s-8);
  display: grid;
  gap: var(--s-4);
  min-width: 0;
}
@media (max-width: 640px) {
  .docs-showcase__body {
    padding: var(--s-6);
  }
}

.docs-showcase__name {
  margin: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.docs-showcase__meta {
  margin: 0;
}

.docs-showcase__actions {
  display: flex;
  gap: var(--s-3);
  flex-wrap: wrap;
}
.docs-showcase__action {
  display: inline-flex;
  align-items: center;
  height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--surface);
  font-size: var(--fz-1);
}
.docs-showcase__action--muted {
  color: var(--mut);
}

.docs-showcase__cta {
  margin-top: var(--s-10);
  padding: var(--s-8);
  display: grid;
  gap: var(--s-6);
  align-items: center;
}
@media (min-width: 900px) {
  .docs-showcase__cta {
    grid-template-columns: 1fr auto;
  }
}
.docs-showcase__cta-title {
  margin: 0 0 6px;
}
.docs-showcase__cta-text p {
  margin: 0;
}
.docs-showcase__cta-actions {
  display: grid;
  gap: var(--s-4);
}
@media (min-width: 520px) {
  .docs-showcase__cta-actions {
    grid-template-columns: 1fr 1fr;
  }
}
.docs-showcase__cta-actions .btn {
  width: 100%;
}

/* =========================
   DOCS: Archive (many items, compact)
========================= */

.docs-archive__toolbar {
  padding: var(--s-8);
  display: grid;
  gap: var(--s-6);
  margin-bottom: var(--s-8);
}
@media (max-width: 640px) {
  .docs-archive__toolbar {
    padding: var(--s-6);
  }
}

.docs-archive__filters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
}

.docs-archive__search {
  min-width: 0;
}

.docs-archive__grid {
  display: grid;
  gap: var(--s-4);
  min-width: 0;
}

@media (min-width: 900px) {
  .docs-archive__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--s-6);
  }
}

.docs-archive__item {
  min-width: 0;
  overflow: hidden;
}

.docs-archive__link {
  display: grid;
  grid-template-columns: 54px 1fr auto;
  gap: var(--s-4);
  align-items: center;
  padding: var(--s-5);
  text-decoration: none;
  color: var(--txt);
  min-width: 0;
}

.docs-archive__thumb {
  width: 54px;
  height: 54px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: radial-gradient(
      120px 80px at 30% 20%,
      color-mix(in srgb, var(--accent) 14%, transparent),
      transparent 60%
    ),
    var(--surface);
}
.docs-archive__thumb--alt {
  background: radial-gradient(
      120px 80px at 30% 20%,
      color-mix(in srgb, var(--accent-2) 14%, transparent),
      transparent 60%
    ),
    var(--surface);
}

.docs-archive__meta {
  min-width: 0;
  display: grid;
  gap: 2px;
}
.docs-archive__name {
  font-weight: 650;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.docs-archive__sub {
  font-size: var(--fz-1);
}

.docs-archive__tag {
  justify-self: end;
  display: inline-flex;
  align-items: center;
  height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg) 74%, white 8%);
  font-size: var(--fz-1);
  white-space: nowrap;
}
.docs-archive__tag--muted {
  color: var(--mut);
}

@media (max-width: 520px) {
  .docs-archive__link {
    grid-template-columns: 54px 1fr;
    grid-template-areas:
      "thumb meta"
      "tag tag";
    align-items: start;
  }
  .docs-archive__thumb {
    grid-area: thumb;
  }
  .docs-archive__meta {
    grid-area: meta;
  }
  .docs-archive__tag {
    grid-area: tag;
    justify-self: start;
    margin-top: 8px;
  }
}

.docs-archive__more {
  margin-top: var(--s-10);
  display: grid;
  gap: var(--s-4);
}
@media (min-width: 520px) {
  .docs-archive__more {
    grid-template-columns: 1fr 1fr;
  }
}
.docs-archive__more .btn {
  width: 100%;
}
