/* ============================================================
   Масла.сайт — promo.css
   Две партнёрские страницы:
   • Продвижение бренда (.pr-*)
   • Поставщикам ГСМ УРАЛ (.sup-*)
   Опирается на токены styles.css / tokens.css.
   ============================================================ */

/* ---------- общий заголовок секции (как .sec-head, но локально) ---------- */
.pr-sec-head { max-width: 760px; margin-bottom: 26px; }
.pr-sec-head .t { font-family: var(--font-display); font-weight: 800; font-size: 27px; letter-spacing: -0.02em; color: var(--masla-navy); line-height: 1.1; margin-top: 10px; }
.pr-sec-head .s { font-size: 15px; line-height: 1.55; color: var(--neutral-500); margin-top: 10px; }

/* hero CTA-ряд + meta */
.pr-hero-cta { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 24px; }

/* ============================================================
   PROMO — variant A hero meta (наследует .jobs-hero)
   ============================================================ */
.pr-hero .meta .it svg { color: var(--masla-bronze-700); }

/* ---------- PROMO — variant B: split hero с превью размещений ---------- */
.pr-hero-split { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 40px; align-items: center;
  border-radius: var(--r-lg); padding: 40px 44px; margin-top: 14px;
  background:
    radial-gradient(120% 150% at 92% 4%, rgba(190,159,99,0.30), transparent 52%),
    linear-gradient(150deg, #FBF6EC 0%, #F5ECDA 60%, #ECDFC4 100%);
}
.pr-hero-split .copy h1 { font-family: var(--font-display); font-weight: 800; font-size: 38px; letter-spacing: -0.024em; color: var(--masla-navy); line-height: 1.06; margin-top: 12px; }
.pr-hero-split .copy .lead { font-size: 16px; line-height: 1.55; color: var(--neutral-700); margin-top: 14px; max-width: 480px; }

/* мини-превью где появляется бренд (рамка «сайта») */
.pr-preview { background: #fff; border-radius: var(--r-md); box-shadow: var(--el-3); overflow: hidden; border: var(--hairline); }
.pr-preview .bar { display: flex; align-items: center; gap: 7px; padding: 11px 14px; border-bottom: var(--hairline); background: var(--soft); }
.pr-preview .bar i { width: 9px; height: 9px; border-radius: 50%; background: var(--neutral-300); }
.pr-preview .bar .u { margin-left: 10px; height: 18px; flex: 1; border-radius: var(--r-pill); background: #fff; border: var(--hairline); }
.pr-preview .body { padding: 14px; display: flex; flex-direction: column; gap: 12px; }
/* рекламный баннер-слот */
.pr-preview .ad { position: relative; border-radius: var(--r-sm); padding: 16px 18px; color: #fff; overflow: hidden;
  background: linear-gradient(120deg, #16273A 0%, #1E4A6B 100%); }
.pr-preview .ad .tag { font-size: 9.5px; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; color: var(--masla-bronze-300); }
.pr-preview .ad .h { font-family: var(--font-display); font-weight: 800; font-size: 15px; margin-top: 4px; line-height: 1.1; }
.pr-preview .ad .sub { font-size: 11px; color: rgba(255,255,255,0.7); margin-top: 4px; }
.pr-preview .ad .pin { position: absolute; right: 12px; top: 12px; font-size: 9px; font-weight: 700; color: #14181F; background: var(--masla-bronze); border-radius: var(--r-pill); padding: 3px 8px; }
/* строка карточек, одна — продвигаемая */
.pr-preview .row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.pr-pc { border: var(--hairline); border-radius: var(--r-sm); padding: 10px; background: #fff; position: relative; }
.pr-pc .ph { height: 38px; border-radius: 5px; background: var(--soft-2); margin-bottom: 8px; }
.pr-pc .l1 { height: 7px; border-radius: 4px; background: var(--neutral-200); }
.pr-pc .l2 { height: 7px; width: 64%; border-radius: 4px; background: var(--neutral-200); margin-top: 5px; }
.pr-pc .pr2 { height: 9px; width: 46%; border-radius: 4px; background: var(--neutral-300); margin-top: 9px; }
.pr-pc.on { border-color: var(--cyan); box-shadow: 0 0 0 2px var(--cyan-100); }
.pr-pc.on .ph { background: linear-gradient(135deg, #DDF0F7, #EFE6CF); }
.pr-pc .rec { position: absolute; top: -8px; left: 8px; font-size: 8.5px; font-weight: 700; letter-spacing: 0.03em; text-transform: uppercase; color: #fff; background: var(--cyan); border-radius: var(--r-pill); padding: 3px 8px; }
.pr-preview .cap { font-size: 11px; color: var(--neutral-400); text-align: center; padding: 0 14px 12px; }

/* ============================================================
   PROMO — каналы (variant A: grid)
   ============================================================ */
.pr-channels { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.pr-channel { border: var(--hairline); border-radius: var(--r-md); padding: 22px; background: #fff; box-shadow: var(--el-1); transition: box-shadow 160ms, transform 160ms; }
.pr-channel:hover { box-shadow: var(--el-2); transform: translateY(-2px); }
.pr-channel .ic { width: 44px; height: 44px; border-radius: var(--r-sm); background: var(--cyan-50); color: var(--cyan-700); display: flex; align-items: center; justify-content: center; margin-bottom: 16px; }
.pr-channel h4 { font-family: var(--font-display); font-weight: 700; font-size: 16px; color: var(--masla-navy); line-height: 1.2; margin-bottom: 8px; }
.pr-channel p { font-size: 13.5px; line-height: 1.55; color: var(--neutral-500); }
.pr-channel.span2 { grid-column: span 2; background: linear-gradient(150deg, var(--soft), #fff 70%); }

/* PROMO — каналы (variant B: rows) */
.pr-rows { display: flex; flex-direction: column; border-top: var(--hairline); }
.pr-row { display: grid; grid-template-columns: 56px minmax(0, 1fr) auto; gap: 22px; align-items: center; padding: 22px 4px; border-bottom: var(--hairline); }
.pr-row .num { font-family: var(--font-display); font-weight: 800; font-size: 22px; color: var(--neutral-300); font-variant-numeric: tabular-nums; }
.pr-row .tx h4 { font-family: var(--font-display); font-weight: 700; font-size: 17px; color: var(--masla-navy); margin-bottom: 5px; }
.pr-row .tx p { font-size: 14px; line-height: 1.55; color: var(--neutral-500); max-width: 70ch; }
.pr-row .ic { width: 46px; height: 46px; border-radius: var(--r-sm); background: var(--cyan-50); color: var(--cyan-700); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }

/* ============================================================
   PROMO — как запускаем (3 шага)
   ============================================================ */
.pr-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.pr-step { border: var(--hairline); border-radius: var(--r-md); padding: 24px; position: relative; }
.pr-step .n { width: 36px; height: 36px; border-radius: 50%; background: var(--ink); color: #fff; font-family: var(--font-display); font-weight: 800; font-size: 15px; display: flex; align-items: center; justify-content: center; margin-bottom: 16px; }
.pr-step h4 { font-family: var(--font-display); font-weight: 700; font-size: 16.5px; color: var(--masla-navy); margin-bottom: 7px; }
.pr-step p { font-size: 13.5px; line-height: 1.55; color: var(--neutral-500); }

/* ============================================================
   PROMO — тарифные пакеты
   ============================================================ */
.pr-tiers { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; align-items: start; }
.pr-tier { border: var(--hairline); border-radius: var(--r-lg); padding: 28px 26px; background: #fff; box-shadow: var(--el-1); display: flex; flex-direction: column; }
.pr-tier.feat { border-color: var(--cyan); box-shadow: var(--el-3); position: relative; }
.pr-tier .badge { position: absolute; top: -12px; left: 26px; font-size: 11px; font-weight: 700; letter-spacing: 0.03em; text-transform: uppercase; color: #fff; background: var(--cyan); border-radius: var(--r-pill); padding: 5px 13px; }
.pr-tier .nm { font-family: var(--font-display); font-weight: 800; font-size: 19px; color: var(--masla-navy); }
.pr-tier .desc { font-size: 13px; color: var(--neutral-500); margin-top: 6px; line-height: 1.45; min-height: 36px; }
.pr-tier .price { font-family: var(--font-display); font-weight: 800; font-size: 30px; letter-spacing: -0.02em; color: var(--masla-navy); margin-top: 16px; line-height: 1; }
.pr-tier .price small { display: block; font-family: var(--font-body); font-weight: 500; font-size: 12px; color: var(--neutral-400); margin-top: 7px; letter-spacing: 0; }
.pr-tier ul { list-style: none; margin: 20px 0 22px; padding: 18px 0 0; border-top: var(--hairline); display: flex; flex-direction: column; gap: 11px; flex: 1; }
.pr-tier li { display: grid; grid-template-columns: 18px 1fr; gap: 10px; font-size: 13.5px; line-height: 1.45; color: var(--neutral-700); }
.pr-tier li svg { color: var(--success); margin-top: 2px; }
.pr-tier li.base { color: var(--neutral-500); font-weight: 600; }
.pr-tier li.base svg { color: var(--neutral-400); }
.pr-tier .btn { width: 100%; }
.pr-tiers-note { font-size: 13px; color: var(--neutral-500); line-height: 1.55; margin-top: 18px; max-width: 760px; }
.pr-tiers-note b { color: var(--masla-navy); }

/* PROMO — hero meta-строка (вариант A, на базе .pg-hero) */
.pr-hero .pr-meta { display: flex; flex-wrap: wrap; gap: 18px 22px; margin-top: 20px; }
.pr-hero .pr-meta .it { display: inline-flex; align-items: center; gap: 8px; font-size: 14px; font-weight: 600; color: var(--neutral-700); }
.pr-hero .pr-meta .it svg { color: var(--masla-bronze-700); flex-shrink: 0; }

/* ============================================================
   SUPPLIERS — таблица требований к данным
   ============================================================ */
.sup-table { width: 100%; border-collapse: collapse; border: var(--hairline); border-radius: var(--r-md); overflow: hidden; background: #fff; }
.sup-table thead th { background: var(--soft); font-size: 11px; font-weight: 700; letter-spacing: 0.03em; text-transform: uppercase; color: var(--neutral-500); padding: 13px 18px; text-align: left; white-space: nowrap; }
.sup-table tbody tr { border-top: var(--hairline); transition: background 120ms; }
.sup-table tbody tr:hover { background: var(--soft); }
.sup-table td { padding: 14px 18px; font-size: 14px; vertical-align: top; line-height: 1.45; }
.sup-table .field { font-weight: 600; color: var(--masla-navy); }
.sup-table .field .grp { display: block; font-size: 11px; font-weight: 700; letter-spacing: 0.03em; text-transform: uppercase; color: var(--masla-bronze-700); margin-bottom: 4px; }
.sup-table .fmt { color: var(--neutral-700); }
.sup-table .ex { color: var(--neutral-500); }
.sup-table .ex.mono { font-family: var(--font-mono); font-size: 12.5px; }
.req-pill { display: inline-flex; align-items: center; gap: 6px; font-size: 11.5px; font-weight: 700; border-radius: var(--r-pill); padding: 4px 11px; white-space: nowrap; }
.req-pill.must { color: #fff; background: var(--masla-navy); }
.req-pill.opt { color: var(--neutral-500); border: var(--hairline); background: #fff; }

/* SUPPLIERS — карточки качества данных */
.sup-quality { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.sup-q { border: var(--hairline); border-radius: var(--r-md); padding: 20px; }
.sup-q .ic { width: 42px; height: 42px; border-radius: var(--r-sm); background: var(--masla-bronze-100); color: var(--masla-bronze-700); display: flex; align-items: center; justify-content: center; margin-bottom: 14px; }
.sup-q h4 { font-family: var(--font-display); font-weight: 700; font-size: 15.5px; color: var(--masla-navy); margin-bottom: 7px; }
.sup-q p { font-size: 13px; line-height: 1.55; color: var(--neutral-500); }

/* SUPPLIERS — лента «ежедневное обновление» */
.sup-update { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 36px; align-items: center;
  border-radius: var(--r-lg); padding: 32px 36px; color: #fff;
  background: linear-gradient(125deg, #0C141D 0%, #16273A 55%, #1E4A6B 100%); }
.sup-update .h-eyebrow { color: var(--masla-bronze-300); }
.sup-update h3 { font-family: var(--font-display); font-weight: 800; font-size: 26px; letter-spacing: -0.02em; line-height: 1.1; margin: 12px 0 12px; }
.sup-update p { font-size: 15px; line-height: 1.6; color: rgba(255,255,255,0.78); max-width: 52ch; }
.sup-formats { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.sup-fmt { display: flex; align-items: center; gap: 12px; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12); border-radius: var(--r-md); padding: 16px 18px; }
.sup-fmt .ic { width: 40px; height: 40px; border-radius: var(--r-sm); background: rgba(190,159,99,0.18); color: var(--masla-bronze-300); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.sup-fmt b { font-family: var(--font-display); font-weight: 700; font-size: 15px; color: #fff; }
.sup-fmt span { display: block; font-size: 12px; color: rgba(255,255,255,0.6); margin-top: 2px; }

/* SUPPLIERS → баннер на «Продвижение бренда» */
.sup-banner { display: grid; grid-template-columns: 1fr auto; gap: 28px; align-items: center;
  border-radius: var(--r-lg); padding: 30px 36px; overflow: hidden; position: relative;
  background:
    radial-gradient(110% 180% at 90% 0%, rgba(190,159,99,0.45), transparent 55%),
    linear-gradient(150deg, #FBF6EC 0%, #F2E7CF 60%, #E7D7B4 100%); }
.sup-banner .bn-eyebrow { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; color: var(--masla-bronze-700); }
.sup-banner h3 { font-family: var(--font-display); font-weight: 800; font-size: 26px; letter-spacing: -0.02em; color: var(--masla-navy); line-height: 1.1; margin: 12px 0 8px; }
.sup-banner p { font-size: 14.5px; line-height: 1.55; color: var(--neutral-700); max-width: 60ch; }
.sup-banner .btn { white-space: nowrap; }

/* ============================================================
   адаптив
   ============================================================ */
@media (max-width: 1100px) {
  .pr-channels { grid-template-columns: repeat(2, 1fr); }
  .pr-channel.span2 { grid-column: span 2; }
  .sup-quality { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 900px) {
  .pr-hero-split { grid-template-columns: 1fr; gap: 28px; padding: 30px 26px; }
  .pr-tiers { grid-template-columns: 1fr; }
  .pr-steps { grid-template-columns: 1fr; }
  .sup-update { grid-template-columns: 1fr; gap: 24px; padding: 26px 24px; }
  .sup-banner { grid-template-columns: 1fr; gap: 20px; padding: 26px 24px; }
  .sup-banner .btn { width: fit-content; }
}
@media (max-width: 600px) {
  .pr-channels { grid-template-columns: 1fr; }
  .pr-channel.span2 { grid-column: span 1; }
  .pr-hero-split .copy h1 { font-size: 28px; }
  .pr-sec-head .t { font-size: 23px; }
  .pr-row { grid-template-columns: 44px minmax(0, 1fr); gap: 14px; }
  .pr-row .ic { display: none; }
  .sup-quality { grid-template-columns: 1fr; }
  .sup-formats { grid-template-columns: 1fr; }
  .sup-update h3, .sup-banner h3 { font-size: 22px; }
  .pr-vswitch { right: 12px; bottom: 86px; }
  /* таблица требований → горизонтальный скролл внутри обёртки */
  .sup-table { min-width: 620px; }
}
