/* ============================================================
   pages.css — дизайн внутренних страниц (продукты, услуги и т.п.)
   Дополняет styles.css. Использует те же токены (:root).
   ============================================================ */

/* ---------- Продуктовая интро-полоса (фото + факты) ---------- */
.pintro { background: #fff; }
.pintro__in {
  max-width: var(--maxw); margin: 0 auto; padding: 56px 20px;
  display: grid; grid-template-columns: 1fr; gap: 30px; align-items: center;
}
@media (min-width: 920px) { .pintro__in { grid-template-columns: 1.02fr .98fr; gap: 50px; } }
.pintro__media {
  position: relative; border-radius: var(--rl); overflow: hidden;
  box-shadow: 0 24px 60px rgba(9,20,42,.16); aspect-ratio: 4 / 3; background: var(--light);
}
.pintro__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pintro__media .pintro__badge {
  position: absolute; top: 16px; left: 16px; background: var(--blue); color: #fff;
  font: 700 12px var(--fh); padding: 7px 13px; border-radius: 100px; letter-spacing: .02em;
}
.pintro__tag { font: 700 13px var(--fh); color: var(--blue); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 12px; }
.pintro h2 { font: 800 30px var(--fh); color: var(--tb); letter-spacing: -.015em; margin: 0 0 14px; line-height: 1.15; }
.pintro p.pintro__lead { color: var(--tmu); font-size: 16.5px; line-height: 1.7; margin: 0 0 24px; }
.pfacts { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin: 0 0 26px; }
.pfact { display: flex; gap: 12px; align-items: center; background: var(--light); border: 1px solid var(--bl); border-radius: var(--r); padding: 13px 15px; }
.pfact svg { width: 24px; height: 24px; color: var(--blue); flex: none; }
.pfact b { display: block; font: 700 14.5px var(--fh); color: var(--tb); }
.pfact span { font-size: 12px; color: var(--tmu); }
.pintro__cta { display: flex; gap: 12px; flex-wrap: wrap; }

/* ---------- Блок преимуществ (почему мы) ---------- */
.featwrap { background: var(--light); }
.featwrap .sec__in { max-width: var(--maxw); margin: 0 auto; }
.featgrid { display: grid; grid-template-columns: 1fr; gap: 16px; }
@media (min-width: 600px) { .featgrid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 980px) { .featgrid { grid-template-columns: repeat(4, 1fr); } }
.feat { background: #fff; border: 1px solid var(--bl); border-radius: var(--r); padding: 24px 20px; transition: transform .2s, box-shadow .2s; }
.feat:hover { box-shadow: 0 12px 30px rgba(9,20,42,.08); transform: translateY(-3px); }
.feat__ic { width: 46px; height: 46px; display: grid; place-items: center; border-radius: 12px; background: rgba(26,85,216,.1); color: var(--blue); margin-bottom: 14px; }
.feat__ic svg { width: 24px; height: 24px; }
.feat h3 { font: 700 16px var(--fh); color: var(--tb); margin: 0 0 6px; }
.feat p { font-size: 13.5px; color: var(--tmu); line-height: 1.55; margin: 0; }

/* ---------- Похожие продукты ---------- */
.related .sec__in { max-width: var(--maxw); margin: 0 auto; }
.rgrid { display: grid; grid-template-columns: 1fr; gap: 16px; }
@media (min-width: 600px) { .rgrid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 980px) { .rgrid { grid-template-columns: repeat(3, 1fr); } }
.rcard { position: relative; display: block; border-radius: var(--rl); overflow: hidden; aspect-ratio: 16 / 11; box-shadow: 0 8px 24px rgba(9,20,42,.10); }
.rcard img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.rcard:hover img { transform: scale(1.06); }
.rcard__ov { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: flex-end; padding: 18px; background: linear-gradient(to top, rgba(5,13,27,.82) 12%, rgba(5,13,27,.05) 62%); }
.rcard__t { font: 700 17px var(--fh); color: #fff; }
.rcard__s { font-size: 12.5px; color: rgba(255,255,255,.7); margin-top: 3px; display: inline-flex; align-items: center; gap: 6px; }
.rcard__s svg { width: 14px; height: 14px; }

/* ---------- Шаги (процесс работы) ---------- */
.steps { counter-reset: st; display: grid; grid-template-columns: 1fr; gap: 14px; }
@media (min-width: 760px) { .steps { grid-template-columns: 1fr 1fr; } }
.step { position: relative; background: #fff; border: 1px solid var(--bl); border-radius: var(--r); padding: 20px 20px 20px 66px; }
.step::before { counter-increment: st; content: counter(st); position: absolute; left: 18px; top: 18px; width: 36px; height: 36px; background: var(--blue); color: #fff; border-radius: 50%; display: grid; place-items: center; font: 800 16px var(--fh); }
.step b { display: block; font: 700 16px var(--fh); color: var(--tb); margin-bottom: 4px; }
.step span { font-size: 13.5px; color: var(--tmu); line-height: 1.5; }

/* ---------- Полиш .prose (читаемость, маркеры, ссылки) ---------- */
.prose { font-size: 16.5px; }
.prose ul { list-style: none; margin: 0 0 18px 0; padding: 0; }
.prose ul li { position: relative; padding-left: 28px; margin-bottom: 10px; }
.prose ul li::before { content: ''; position: absolute; left: 3px; top: 9px; width: 9px; height: 9px; background: var(--blue); border-radius: 50%; }
.prose h2 { padding-top: 4px; }

/* ---------- .specs как карточки-плитки ---------- */
.specs, .prose .specs { display: grid !important; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)) !important; gap: 14px !important; margin: 6px 0 8px !important; }
.specs > div, .prose .specs > div {
  display: flex !important; flex-direction: column; align-items: flex-start; gap: 6px;
  background: #fff; border: 1px solid var(--bl) !important; border-radius: var(--r); padding: 18px 18px !important; border-bottom: 1px solid var(--bl) !important;
}
.specs > div span:first-child, .prose .specs span:first-child { color: var(--tmu) !important; font-size: 12.5px; text-transform: uppercase; letter-spacing: .04em; }
.specs > div span:last-child, .prose .specs span:last-child { color: var(--tb) !important; font: 800 19px var(--fh) !important; text-align: left !important; }
.specs a { color: var(--blue); text-decoration: none; }

/* ---------- Карточки услуг/продуктов: ровная высота даже без картинки ---------- */
.pc { aspect-ratio: 4 / 3; background: var(--card); }
.pc img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
