/* POLY redesign v2 — компоненты секций. Под .poly-rd. */

/* ===== HERO ===== */
.prd-hero {
  background:
    radial-gradient(120% 120% at 80% 20%, rgba(44,105,173,.18), transparent 55%),
    var(--prd-navy-900);
  color: var(--prd-on-dark);
}
/* Hero с фоновым фото (эталон: тёмный промышленный фон). Скоуп — конфигом (ключ bg).
   Специфичность 3 класса — чтобы перебить .prd-section[data-band="dark"] в base.css. */
.prd-section.prd-hero.prd-hero--photo {
  background:
    linear-gradient(90deg, rgba(8,21,32,.97) 0%, rgba(8,21,32,.90) 42%, rgba(8,21,32,.55) 100%),
    var(--prd-hero-bg) center right / cover no-repeat,
    var(--prd-navy-900);
}
.prd-hero__grid {
  display: grid; grid-template-columns: 1.05fr .95fr; gap: 40px;
  align-items: center; padding-top: 56px; padding-bottom: 56px;
}
/* Hero без media-колонки (портфолио/служебные): текст над фото, шире отступ снизу */
.prd-hero--nomedia .prd-hero__grid { grid-template-columns: 1fr; min-height: 320px; padding-bottom: 64px; }
.prd-hero--nomedia .prd-hero__copy { max-width: 680px; }
.prd-hero__kicker { color: var(--prd-on-dark-soft); font-size: 13px; text-transform: uppercase; letter-spacing: .1em; margin: 0 0 14px; }
.prd-hero__title { color: #fff; margin: 0 0 16px; line-height: 1.12; }
.prd-hero__lead { color: var(--prd-on-dark-soft); font-size: 17px; max-width: 52ch; margin: 0 0 26px; }
.prd-hero__actions { display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 30px; }
.prd-hero__trust { display: flex; flex-wrap: wrap; gap: 18px 22px; }
.prd-hero__trust li { display: flex; align-items: center; gap: 10px; }
.prd-hero__trust .prd-icon--ph, .prd-hero__trust .prd-icon--img img { width: 34px; height: 34px; }
.prd-hero__trust b { display: block; color: #fff; font-size: 16px; line-height: 1.1; font-weight: 700; }
.prd-hero__trust i { display: block; color: var(--prd-on-dark-soft); font-size: 12px; font-style: normal; }

/* Media: «пирог пола» (слоёная заглушка) + буллеты. Панель — чтобы читалось над фото-фоном. */
.prd-hero__media {
  display: flex; align-items: center; justify-content: center; gap: 26px;
  background: rgba(8,21,32,.42); border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--prd-radius); padding: 26px 24px;
  -webkit-backdrop-filter: blur(3px); backdrop-filter: blur(3px);
}
.prd-hero__pirog {
  margin: 0; display: flex; flex-direction: column; align-items: stretch; gap: 7px;
  width: min(300px, 60%); transform: perspective(820px) rotateX(13deg);
}
.prd-hero__layer {
  display: flex; align-items: center; justify-content: center;
  height: 34px; border-radius: 7px; color: #fff; font-size: 0;
  position: relative; box-shadow: 0 6px 18px rgba(0,0,0,.25);
}
.prd-hero__layer i { font-size: 11px; font-style: normal; color: rgba(255,255,255,.92); }
.prd-hero__layer--1 { background: linear-gradient(90deg,#3f80cf,#2c69ad); }
.prd-hero__layer--2 { background: linear-gradient(90deg,#2c69ad,#245a97); height: 30px; }
.prd-hero__layer--3 { background: linear-gradient(90deg,#f57505,#e06800); height: 22px; }
.prd-hero__layer--4 { background: linear-gradient(90deg,#5a6b7d,#3d4b59); height: 46px; }
.prd-hero__pirog figcaption { grid-column: 1/-1; text-align: center; color: var(--prd-on-dark-soft); font-size: 12px; margin-top: 8px; }
.prd-hero__bullets { display: grid; gap: 12px; align-content: center; }
.prd-hero__bullets li { display: flex; align-items: center; gap: 9px; color: var(--prd-on-dark); font-size: 14px; }
.prd-hero__bullets .prd-icon--ph, .prd-hero__bullets .prd-icon--img img { width: 22px; height: 22px; }
.prd-hero__bullets .prd-icon--ph { background: rgba(245,117,5,.18); border-color: rgba(245,117,5,.4); }

/* ===== AEO ===== */
.prd-section--aeo { background: var(--prd-blue-50); }
.prd-aeo__def {
  background: #fff; border-left: 4px solid var(--prd-blue-600);
  border-radius: var(--prd-radius-sm); padding: 22px 26px; box-shadow: var(--prd-shadow-sm);
  margin-bottom: 22px; max-width: 940px;
}
.prd-aeo__tag { display: inline-block; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--prd-blue-700); margin-bottom: 8px; }
.prd-aeo__def p { margin: 0; font-size: 18px; color: var(--prd-ink); }
.prd-aeo__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.prd-aeo__card { background: #fff; border: 1px solid var(--prd-line); border-radius: var(--prd-radius-sm); padding: 16px 18px; }
.prd-aeo__card h3 { font-size: 14px; color: var(--prd-blue-700); margin: 0 0 6px; }
.prd-aeo__card p { margin: 0; font-size: 14px; color: var(--prd-ink-soft); }

/* ===== CARDS ===== */
.prd-cards { display: grid; grid-template-columns: repeat(var(--prd-cols, 4), 1fr); gap: 20px; }
.prd-cards--types { gap: 14px; }
.prd-cards--types .prd-card__body { padding: 14px 12px 16px; }
.prd-cards--types .prd-card__title { font-size: 14px; line-height: 1.25; }
.prd-cards--types .prd-card__num { top: -14px; font-size: 12px; padding: 3px 8px; }
.prd-cards--types .prd-card__price { font-size: 13px; margin-top: 8px; }
.prd-cards--types .prd-icon--img img, .prd-cards--types .prd-icon--ph { width: 30px; height: 30px; }
.prd-cards--types .prd-icon--svg svg { width: 26px; height: 26px; }
/* Компактный ряд отраслей: иконка + подпись, без описания */
.prd-cards--compact { gap: 12px; }
.prd-cards--compact .prd-card { border: none; background: transparent; text-align: center; align-items: center; }
.prd-cards--compact .prd-card__body { padding: 0; display: flex; flex-direction: column; align-items: center; gap: 10px; }
.prd-cards--compact .prd-card__title { font-size: 14px; margin: 0; font-weight: 600; }
a.prd-cards--compact .prd-card:hover, .prd-cards--compact a.prd-card:hover { box-shadow: none; }
.prd-card { background: #fff; border: 1px solid var(--prd-line); border-radius: var(--prd-radius); overflow: hidden; display: flex; flex-direction: column; color: inherit; }
a.prd-card:hover { border-color: var(--prd-blue-500); box-shadow: var(--prd-shadow); }
.prd-card__media { aspect-ratio: 16/10; overflow: hidden; background: var(--prd-surface); }
.prd-card__media img, .prd-card__media .prd-photo-ph { width: 100%; height: 100%; object-fit: cover; min-height: 0; }
.prd-card__body { padding: 18px 20px; position: relative; }
.prd-card__num { position: absolute; top: -16px; left: 18px; background: var(--prd-blue-700); color: #fff; font-size: 13px; font-weight: 700; padding: 4px 10px; border-radius: 6px; }
.prd-cards--apps .prd-card__body, .prd-cards--advantages .prd-card__body { padding-top: 22px; }
.prd-cards--apps .prd-icon, .prd-cards--advantages .prd-icon, .prd-cards--types .prd-icon { margin-bottom: 12px; }
.prd-card__title { font-size: 17px; margin: 0 0 8px; }
.prd-card__text { font-size: 14px; color: var(--prd-ink-soft); margin: 0; }
.prd-card__price { display: inline-block; margin-top: 12px; color: var(--prd-orange-600); font-weight: 700; font-size: 15px; }

/* ===== STEPS ===== */
.prd-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; counter-reset: step; }
.prd-step { position: relative; padding-top: 8px; }
.prd-step__no {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: 50%; background: var(--prd-blue-700);
  color: #fff; font-weight: 800; margin-bottom: 14px;
}
.prd-step__title { font-size: 16px; margin: 0 0 8px; }
.prd-step__text { font-size: 14px; color: var(--prd-ink-soft); margin: 0; }
.prd-steps .prd-step:not(:last-child)::after {
  content: ""; position: absolute; top: 28px; left: 52px; right: -11px; height: 2px;
  background: var(--prd-line); z-index: 0;
}

/* ===== PRICING ===== */
.prd-pricing__wrap { display: grid; grid-template-columns: 1.5fr 1fr; gap: 28px; align-items: start; }
.prd-pricing__note { color: var(--prd-ink-soft); margin: 0 0 16px; }
.prd-price-table { background: #fff; border: 1px solid var(--prd-line); border-radius: var(--prd-radius); overflow: hidden; }
.prd-price-table td { padding: 14px 18px; border-bottom: 1px solid var(--prd-line-soft); font-size: 15px; }
.prd-price-table tr:nth-child(even) { background: var(--prd-surface); }
.prd-price-table tr:last-child td { border-bottom: none; }
.prd-price-table td:last-child { text-align: right; color: var(--prd-ink); }
.prd-pricing__cta { background: var(--prd-blue-50); border: 1px solid var(--prd-blue-100); border-radius: var(--prd-radius); padding: 24px; }
.prd-pricing__cta h3 { font-size: 17px; margin: 12px 0 8px; }
.prd-pricing__cta p { font-size: 14px; color: var(--prd-ink-soft); margin: 0 0 16px; }

/* ===== CALC (цены + калькулятор) ===== */
.prd-calc { display: grid; grid-template-columns: 1.3fr 1fr; gap: 28px; align-items: start; }
.prd-calc__note { color: var(--prd-muted); font-size: 13px; margin: 14px 0 0; }
.prd-calc__widget { background: var(--prd-blue-50); border: 1px solid var(--prd-blue-100); border-radius: var(--prd-radius); padding: 26px; }
.prd-calc__widget h3 { font-size: 19px; margin: 0 0 18px; }
.prd-calc__field { display: grid; gap: 6px; font-size: 13px; color: var(--prd-ink-soft); margin-bottom: 14px; }
.prd-calc__field select, .prd-calc__field input { padding: 12px 14px; border: 1px solid var(--prd-line); border-radius: var(--prd-radius-sm); font-size: 15px; background: #fff; color: var(--prd-ink); }
.prd-calc__result { background: #fff; border-radius: var(--prd-radius-sm); padding: 16px 18px; margin: 6px 0 16px; font-size: 15px; color: var(--prd-ink-soft); }
.prd-calc__result b { display: block; font-size: 26px; color: var(--prd-ink); margin-top: 4px; }
.prd-calc__result .prd-calc__hint { display: block; font-size: 12px; color: var(--prd-muted); margin-top: 4px; }
.prd-calc__incl { display: grid; gap: 8px; margin: 0 0 18px; }
.prd-calc__incl li { display: flex; align-items: center; gap: 8px; font-size: 14px; color: var(--prd-ink-soft); }
.prd-calc__incl .prd-icon--img img, .prd-calc__incl .prd-icon--ph { width: 20px; height: 20px; }
.prd-calc__widget .prd-btn { width: 100%; }

/* ===== REVIEWS rating ===== */
.prd-reviews__rating { display: flex; align-items: center; gap: 14px; margin-bottom: 22px; }
.prd-reviews__score { font-size: 40px; font-weight: 800; color: var(--prd-ink); line-height: 1; }
.prd-reviews__stars { color: #f5a623; font-size: 22px; letter-spacing: 2px; }
.prd-reviews__count { color: var(--prd-muted); font-size: 14px; }

/* ===== ABOUT side (гарантия + реквизиты) ===== */
.prd-about__side { display: grid; gap: 18px; }
.prd-about__badge { background: var(--prd-blue-700); color: #fff; border-radius: var(--prd-radius); padding: 20px; text-align: center; }
.prd-about__badge .prd-icon--img img, .prd-about__badge .prd-icon--ph { width: 40px; height: 40px; margin: 0 auto 8px; filter: brightness(0) invert(1); }
.prd-about__badge b { display: block; font-size: 26px; }
.prd-about__badge span { font-size: 13px; opacity: .85; }
.prd-about__req { background: #fff; border: 1px solid var(--prd-line); border-radius: var(--prd-radius); padding: 18px 20px; }
.prd-about__req h3 { font-size: 15px; margin: 0 0 12px; }
.prd-about__req dl { display: grid; gap: 8px; margin: 0; }
.prd-about__req div { display: flex; justify-content: space-between; gap: 12px; font-size: 14px; }
.prd-about__req dt { color: var(--prd-muted); margin: 0; }
.prd-about__req dd { margin: 0; color: var(--prd-ink); font-weight: 600; }

/* ===== CTA form map ===== */
.prd-cta-form__map { margin-top: 32px; border-radius: var(--prd-radius); overflow: hidden; }
.prd-cta-form__map iframe { width: 100%; min-height: 300px; border: 0; display: block; }

/* ===== GALLERY ===== */
.prd-gallery { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.prd-gallery__item { margin: 0; border-radius: var(--prd-radius-sm); overflow: hidden; background: var(--prd-surface); }
.prd-gallery__item img { width: 100%; aspect-ratio: 4/3; object-fit: cover; }
.prd-gallery__item figcaption { padding: 8px 10px; font-size: 12px; color: var(--prd-muted); }

/* ===== CASES ===== */
.prd-cases { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.prd-case { background: #fff; border: 1px solid var(--prd-line); border-radius: var(--prd-radius); overflow: hidden; color: inherit; }
a.prd-case:hover { box-shadow: var(--prd-shadow); border-color: var(--prd-blue-500); }
.prd-case__media img, .prd-case__media .prd-photo-ph { aspect-ratio: 16/10; object-fit: cover; width: 100%; }
.prd-case__body { padding: 16px 18px; }
.prd-case__body h3 { font-size: 16px; margin: 0 0 6px; }
.prd-case__meta { font-size: 13px; color: var(--prd-muted); margin: 0; }

/* ===== REVIEWS ===== */
.prd-reviews { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.prd-review { margin: 0; background: #fff; border: 1px solid var(--prd-line); border-radius: var(--prd-radius); padding: 22px; }
.prd-review p { font-size: 15px; color: var(--prd-ink-soft); }
.prd-review footer b { display: block; color: var(--prd-ink); }
.prd-review footer i { color: var(--prd-muted); font-style: normal; font-size: 13px; }

/* ===== SEO spoiler ===== */
.prd-seo { background: #fff; border: 1px solid var(--prd-line); border-radius: var(--prd-radius); padding: 24px 28px; }
.prd-seo > summary { list-style: none; cursor: pointer; }
.prd-seo > summary::-webkit-details-marker { display: none; }
.prd-seo__intro { display: block; color: var(--prd-ink-soft); }
.prd-seo__more { display: inline-block; margin-top: 12px; color: var(--prd-blue-700); font-weight: 700; }
.prd-seo[open] .prd-seo__more { display: none; }
.prd-seo__full { margin-top: 14px; color: var(--prd-ink-soft); }
.prd-seo__full h3 { font-size: 17px; margin: 20px 0 8px; color: var(--prd-ink); }

/* ===== FAQ ===== */
.prd-faq { display: grid; gap: 12px; max-width: 960px; }
.prd-faq__item { background: #fff; border: 1px solid var(--prd-line); border-radius: var(--prd-radius-sm); padding: 4px 20px; }
.prd-faq__item > summary { list-style: none; cursor: pointer; padding: 16px 0; font-weight: 700; color: var(--prd-ink); position: relative; padding-right: 30px; }
.prd-faq__item > summary::-webkit-details-marker { display: none; }
.prd-faq__item > summary::after { content: "+"; position: absolute; right: 4px; top: 14px; font-size: 22px; color: var(--prd-blue-600); }
.prd-faq__item[open] > summary::after { content: "–"; }
.prd-faq__item > div { padding: 0 0 18px; color: var(--prd-ink-soft); }

/* ===== CTA FORM ===== */
.prd-cta-form { background: var(--prd-navy-850); color: var(--prd-on-dark); }
.prd-cta-form__grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--prd-s6); align-items: center; }
.prd-cta-form__copy h2 { color: #fff; }
.prd-cta-form__copy p { color: var(--prd-on-dark-soft); }
.prd-cta-form__perks { display: grid; gap: 10px; margin-top: 18px; }
.prd-cta-form__perks li { display: flex; align-items: center; gap: 10px; color: var(--prd-on-dark); font-size: 15px; }
.prd-cta-form__box { background: #fff; border-radius: var(--prd-radius); padding: 28px; box-shadow: var(--prd-shadow); }
.prd-form { display: grid; gap: 14px; }
.prd-form label { display: grid; gap: 6px; font-size: 13px; color: var(--prd-ink-soft); }
.prd-form input[type="text"], .prd-form input[type="tel"] {
  padding: 12px 14px; border: 1px solid var(--prd-line); border-radius: var(--prd-radius-sm);
  font-size: 15px; color: var(--prd-ink); background: #fff;
}
.prd-form__consent { font-size: 12px; color: var(--prd-muted); }
.prd-form__consent label { flex-direction: row; display: flex; gap: 8px; align-items: flex-start; }

/* CF7-форма внутри карточки cta_form (подгоняем под стиль редизайна) */
.prd-cta-form__box .wpcf7-form p { margin: 0 0 14px; }
.prd-cta-form__box .wpcf7-form input[type="text"],
.prd-cta-form__box .wpcf7-form input[type="tel"],
.prd-cta-form__box .wpcf7-form input[type="email"],
.prd-cta-form__box .wpcf7-form textarea {
  width: 100%; box-sizing: border-box; padding: 12px 14px;
  border: 1px solid var(--prd-line); border-radius: var(--prd-radius-sm);
  font-size: 15px; color: var(--prd-ink); background: #fff; font-family: inherit;
}
.prd-cta-form__box .wpcf7-form textarea { min-height: 96px; resize: vertical; }
.prd-cta-form__box .wpcf7-form input:focus,
.prd-cta-form__box .wpcf7-form textarea:focus { outline: none; border-color: var(--prd-blue-500); }
.prd-cta-form__box .wpcf7-form .wpcf7-list-item { margin: 0; }
.prd-cta-form__box .wpcf7-form .wpcf7-acceptance .wpcf7-list-item-label,
.prd-cta-form__box .wpcf7-form .wpcf7-checkbox .wpcf7-list-item-label { font-size: 12px; color: var(--prd-muted); }
.prd-cta-form__box .wpcf7-form input[type="submit"] {
  width: 100%; padding: 13px 20px; border: 0; border-radius: var(--prd-radius-sm);
  background: var(--prd-orange-600); color: #fff; font-weight: 700; font-size: 15px;
  cursor: pointer; transition: background .15s;
}
.prd-cta-form__box .wpcf7-form input[type="submit"]:hover { background: var(--prd-orange-500); }
.prd-cta-form__box .wpcf7-spinner { margin: 8px auto 0; display: block; }
.prd-cta-form__box .wpcf7-response-output { margin: 12px 0 0 !important; font-size: 13px; border-radius: var(--prd-radius-sm); }

/* ===== RELATED ===== */
.prd-related { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.prd-related a { display: flex; align-items: center; gap: 10px; background: #fff; border: 1px solid var(--prd-line); border-radius: var(--prd-radius-sm); padding: 14px 16px; font-weight: 600; color: var(--prd-ink); }
.prd-related a:hover { border-color: var(--prd-blue-500); color: var(--prd-blue-700); }
.prd-related__reverse { display: inline-block; margin-top: 20px; font-weight: 700; color: var(--prd-blue-700); }

/* ===== ABOUT ===== */
.prd-about__grid { display: grid; grid-template-columns: 2fr 1fr; gap: var(--prd-s6); align-items: start; }
.prd-about__points { display: grid; gap: 10px; margin-top: 16px; }
.prd-about__points li { display: flex; align-items: center; gap: 10px; }
.prd-about__expert { background: #fff; border: 1px solid var(--prd-line); border-radius: var(--prd-radius); padding: 20px; text-align: center; }
.prd-about__expert img, .prd-about__expert .prd-photo-ph { width: 120px; height: 120px; border-radius: 50%; object-fit: cover; margin: 0 auto 14px; min-height: 0; }
.prd-about__expert b { display: block; color: var(--prd-ink); }
.prd-about__expert i { color: var(--prd-muted); font-style: normal; font-size: 13px; }

/* ===== REQUISITES ===== */
.prd-req { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px 40px; max-width: 760px; }
.prd-req div { display: flex; justify-content: space-between; gap: 16px; padding: 12px 0; border-bottom: 1px solid var(--prd-line-soft); }
.prd-req dt { color: var(--prd-muted); margin: 0; }
.prd-req dd { margin: 0; color: var(--prd-ink); font-weight: 600; text-align: right; }

/* ===== CONTACTS ===== */
.prd-contacts__grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: var(--prd-s6); align-items: start; }
.prd-contacts__row { display: flex; align-items: center; gap: 12px; font-size: 16px; padding: 10px 0; border-bottom: 1px solid var(--prd-line-soft); }
.prd-contacts__map { border-radius: var(--prd-radius); overflow: hidden; min-height: 320px; }
.prd-contacts__map iframe { width: 100%; min-height: 320px; border: 0; }

/* ===== SPECS ===== */
.prd-specs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.prd-spec { background: #fff; border: 1px solid var(--prd-line); border-radius: var(--prd-radius-sm); padding: 16px 18px; }
.prd-spec__k { display: block; font-size: 13px; color: var(--prd-muted); margin-bottom: 4px; }
.prd-spec__v { display: block; font-size: 17px; font-weight: 700; color: var(--prd-ink); }

/* ===== ARTICLE ===== */
.prd-section--article { background: #fff; }
.prd-section--article .prd-container { max-width: 860px; }
.prd-toc { background: var(--prd-surface); border: 1px solid var(--prd-line); border-radius: var(--prd-radius-sm); padding: 18px 22px; margin-bottom: 28px; }
.prd-toc b { display: block; margin-bottom: 10px; }
.prd-toc ol { display: grid; gap: 6px; list-style: decimal inside; }
.prd-toc a { color: var(--prd-blue-700); }
.prd-article__body p { font-size: 17px; color: var(--prd-ink-soft); }
.prd-article__body h2 { margin-top: 36px; }
.prd-article__body h3 { margin-top: 24px; }
.prd-article__body ul { list-style: disc inside; margin: 0 0 16px; color: var(--prd-ink-soft); }

/* ===== RICH ===== */
.prd-rich { max-width: 860px; }
.prd-rich p { font-size: 17px; color: var(--prd-ink-soft); }

/* ===== Адаптив ===== */
@media (max-width: 1024px) {
  .prd-aeo__grid, .prd-cards, .prd-steps, .prd-related { grid-template-columns: repeat(2, 1fr) !important; }
  .prd-gallery { grid-template-columns: repeat(3, 1fr); }
  .prd-cases, .prd-reviews, .prd-specs { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 860px) {
  .prd-hero__grid, .prd-pricing__wrap, .prd-cta-form__grid, .prd-about__grid, .prd-contacts__grid, .prd-calc { grid-template-columns: 1fr; }
  .prd-hero__trust { grid-template-columns: repeat(2, 1fr); }
  .prd-cards, .prd-steps, .prd-related, .prd-cases, .prd-reviews, .prd-specs, .prd-req { grid-template-columns: 1fr !important; }
  .prd-gallery { grid-template-columns: repeat(2, 1fr); }
  .prd-steps .prd-step::after { display: none; }
  .prd-article__wrap { grid-template-columns: 1fr; }
  .prd-article__toc { position: static; }
}

/* ===== ARTICLE (статья блога) ===== */
.prd-article-hero { padding: 54px 0 40px; }
.prd-article-hero__kicker { color: var(--prd-orange-500); font-size: 13px; text-transform: uppercase; letter-spacing: .09em; margin: 0 0 14px; }
.prd-article-hero__title { color: #fff; margin: 0; max-width: 24ch; line-height: 1.14; }
.prd-article__wrap { display: grid; grid-template-columns: 260px 1fr; gap: 48px; align-items: start; padding-top: 44px; padding-bottom: 44px; }
.prd-article__toc { position: sticky; top: 24px; background: var(--prd-surface); border: 1px solid var(--prd-line); border-radius: var(--prd-radius); padding: 18px 20px; }
.prd-article__toc-h { margin: 0 0 10px; font-weight: 700; font-size: 14px; color: var(--prd-ink); }
.prd-article__toc ol { margin: 0; padding-left: 18px; display: grid; gap: 8px; }
.prd-article__toc a { color: var(--prd-ink-soft); font-size: 14px; line-height: 1.4; text-decoration: none; }
.prd-article__toc a:hover { color: var(--prd-blue-600); }

/* Prose — читаемая колонка тела статьи */
.prd-prose { max-width: 74ch; color: var(--prd-ink); font-size: 17px; line-height: var(--prd-lh); }
.prd-prose > *:first-child { margin-top: 0; }
.prd-prose p { margin: 0 0 18px; }
.prd-prose h2 { font-size: var(--prd-fs-h2); color: var(--prd-ink); margin: 38px 0 14px; line-height: 1.2; scroll-margin-top: 24px; }
.prd-prose h3 { font-size: var(--prd-fs-h3); color: var(--prd-ink); margin: 28px 0 10px; }
.prd-prose ul, .prd-prose ol { margin: 0 0 18px; padding-left: 22px; }
.prd-prose li { margin: 0 0 8px; }
.prd-prose ul li::marker { color: var(--prd-orange-600); }
.prd-prose a { color: var(--prd-blue-600); text-decoration: underline; text-underline-offset: 2px; }
.prd-prose a:hover { color: var(--prd-orange-600); }
.prd-prose strong { color: var(--prd-ink); font-weight: 700; }
.prd-prose img { max-width: 100%; height: auto; border-radius: var(--prd-radius); margin: 10px 0; }
.prd-prose table { width: 100%; border-collapse: collapse; margin: 0 0 20px; font-size: 15px; }
.prd-prose th, .prd-prose td { border: 1px solid var(--prd-line); padding: 9px 12px; text-align: left; }
.prd-prose th { background: var(--prd-surface); font-weight: 700; }
.prd-prose blockquote { margin: 0 0 18px; padding: 12px 18px; border-left: 3px solid var(--prd-orange-600); background: var(--prd-surface); color: var(--prd-ink-soft); }

/* ===== PROSE-SEC (вакансии, политика) ===== */
.prd-prose-sec__title { font-size: var(--prd-fs-h2); color: var(--prd-ink); margin: 0 0 22px; }
.prd-prose-sec .prd-prose { max-width: 820px; }
.prd-prose-sec .prd-prose h2 { font-size: 22px; }
.prd-prose-sec .prd-prose .standard-arrow ul,
.prd-prose-sec .prd-prose .list-divider ul { list-style: none; padding-left: 0; }
.prd-prose-sec .prd-prose .standard-arrow li,
.prd-prose-sec .prd-prose .list-divider li { position: relative; padding-left: 24px; }
.prd-prose-sec .prd-prose .standard-arrow li::before,
.prd-prose-sec .prd-prose .list-divider li::before { content: "→"; position: absolute; left: 0; color: var(--prd-orange-600); font-weight: 700; }

/* ===== PROJECT (кейс /project/) — стилизуем операторский блок .ep2 ===== */
.prd-project__body { max-width: 860px; margin: 0 auto; }
.prd-project__body .ep2 img { max-width: 100%; height: auto; border-radius: var(--prd-radius); display: block; margin: 0 0 18px; }
.prd-project__body .ep2-title { font-size: var(--prd-fs-h2); color: var(--prd-ink); margin: 34px 0 16px; line-height: 1.2; }
.prd-project__body .ep2-uses { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin: 0 0 26px; }
.prd-project__body .ep2-use-item { background: var(--prd-surface); border: 1px solid var(--prd-line); border-radius: var(--prd-radius-sm); padding: 14px 16px; font-size: 15px; color: var(--prd-ink-soft); }
.prd-project__body .ep2-use-item strong { display: block; color: var(--prd-ink); margin-bottom: 2px; }
.prd-project__body .ep2-use-icon { font-size: 22px; line-height: 1; margin-bottom: 8px; }
.prd-project__body .ep2-clear { clear: both; }
.prd-project__body .ep2 p { font-size: 17px; color: var(--prd-ink-soft); line-height: var(--prd-lh); margin: 0 0 16px; }
@media (max-width: 860px) {
  .prd-project__body .ep2-uses { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 520px) {
  .prd-project__body .ep2-uses { grid-template-columns: 1fr; }
}
