/* storefront: премиальные инфо-страницы (Доставка, Гарантия и возврат) */
.nup-page { max-width: 920px; margin: 0 auto; padding: 0 20px 64px; font-family: Inter, -apple-system, 'Segoe UI', sans-serif; color: #0c1f4a; -webkit-font-smoothing: antialiased; }
.nup-page__hero { text-align: center; padding: 64px 0 40px; }
.nup-page__eyebrow { display: inline-flex; align-items: center; gap: 7px; font-size: 11.5px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: #177ec9; background: linear-gradient(180deg,#eef6fd,#e6f2fb); border: 1px solid #d6e8f7; padding: 6px 14px; border-radius: 999px; margin-bottom: 18px; }
.nup-page__eyebrow svg { width: 14px; height: 14px; stroke: #177ec9; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.nup-page__title { font-size: clamp(30px,4.4vw,46px); font-weight: 800; text-transform: uppercase; letter-spacing: -.015em; line-height: 1.1; margin: 0 0 16px; }
.nup-page__lead { font-size: 17px; line-height: 1.6; color: #5b6b8c; margin: 0 auto; max-width: 660px; }

.nup-page__sections { display: grid; gap: 16px; }
.nup-card { display: flex; gap: 22px; background: linear-gradient(160deg,#ffffff,#f6fafd); border: 1px solid #e7edf4; border-radius: 20px; padding: 26px 28px; box-shadow: 0 1px 2px rgba(12,31,74,.04), 0 18px 44px -26px rgba(12,31,74,.28); }
.nup-card__icon { flex: 0 0 auto; width: 52px; height: 52px; border-radius: 15px; display: grid; place-items: center; background: linear-gradient(145deg,#1f8fd6,#27a7df); box-shadow: 0 8px 18px rgba(23,126,201,.3), inset 0 1px 0 rgba(255,255,255,.4); }
.nup-card__icon.green { background: linear-gradient(145deg,#13b06f,#23cd84); box-shadow: 0 8px 18px rgba(32,199,122,.32), inset 0 1px 0 rgba(255,255,255,.4); }
.nup-card__icon.amber { background: linear-gradient(145deg,#e2a324,#f3c044); box-shadow: 0 8px 18px rgba(226,163,36,.3), inset 0 1px 0 rgba(255,255,255,.4); }
.nup-card__icon svg { width: 26px; height: 26px; stroke: #fff; fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.nup-card__body { min-width: 0; }
.nup-card__body h2 { font-size: 18px; font-weight: 800; letter-spacing: -.01em; margin: 4px 0 9px; color: #0c1f4a; }
.nup-card__body p { font-size: 14.5px; line-height: 1.6; color: #3a4a6e; margin: 0 0 10px; }
.nup-card__body p:last-child { margin-bottom: 0; }
.nup-card__body strong { color: #0c1f4a; font-weight: 700; }
.nup-list { margin: 6px 0 0; padding: 0; list-style: none; }
.nup-list li { position: relative; padding-left: 26px; font-size: 14.5px; line-height: 1.55; color: #3a4a6e; margin-bottom: 8px; }
.nup-list li:last-child { margin-bottom: 0; }
.nup-list li::before { content: ''; position: absolute; left: 0; top: 2px; width: 17px; height: 17px; border-radius: 50%; background: rgba(32,199,122,.14); }
.nup-list li::after { content: ''; position: absolute; left: 4.5px; top: 7px; width: 7px; height: 4px; border-left: 2px solid #149a5c; border-bottom: 2px solid #149a5c; transform: rotate(-45deg); }
.nup-list--x li::before { background: rgba(140,156,182,.16); }
.nup-list--x li::after { content: ''; left: 5px; top: 9px; width: 8px; height: 0; border: 0; border-top: 2px solid #8d9cb6; transform: none; }

.nup-cta-card { text-align: center; background: linear-gradient(160deg,#f4f9ff,#eaf3fb); border: 1px solid #d8e7f6; border-radius: 20px; padding: 32px 28px; margin-top: 6px; }
.nup-cta-card h2 { font-size: 19px; font-weight: 800; margin: 0 0 6px; }
.nup-cta-card p { font-size: 14.5px; color: #5b6b8c; margin: 0 0 18px; }
.nup-page__cta { display: inline-flex; align-items: center; gap: 9px; padding: 15px 32px; border-radius: 999px; background: linear-gradient(180deg,#2f93dd,#177ec9 55%,#0e5f9c); color: #fff; font-weight: 700; font-size: 15px; text-decoration: none; box-shadow: 0 10px 24px rgba(14,95,156,.4), inset 0 1px 0 rgba(255,255,255,.4); transition: transform .15s ease, box-shadow .15s ease; }
.nup-page__cta:hover { transform: translateY(-2px); color: #fff; box-shadow: 0 14px 30px rgba(14,95,156,.48), inset 0 1px 0 rgba(255,255,255,.4); }
.nup-page__cta svg { width: 17px; height: 17px; stroke: #fff; fill: none; stroke-width: 2.4; stroke-linecap: round; stroke-linejoin: round; }
.nup-page__note { font-size: 13px; line-height: 1.55; color: #9aa8c0; text-align: center; margin: 26px auto 0; max-width: 660px; }

@media (max-width: 600px) {
  .nup-page__hero { padding: 44px 0 30px; }
  .nup-card { flex-direction: column; gap: 14px; padding: 22px 20px; }
  .nup-card__icon { width: 46px; height: 46px; }
}
