/*
 * Безопасность данных + Валидация (Фаза 6, SITE_IMPROVEMENT_PLAN.md §8).
 *
 * Слой поверх site.css/tokens.css для страниц /security и /validation и тизера на
 * лендинге. Переиспользует токены и язык компонентов приложения (Р11/Р12). Карточки
 * берём из site.css (.module-card / .scaffold-grid), здесь — только специфика:
 * нормативные чипы, степпер IQ/OQ/PQ, блок «данные ваши» и форма запроса пакета.
 * Грузится только на этих страницах + лендинге (через head_extra), не в общий site.css.
 */

/* ── Бейджи нормативов в page-hero ── */
.trust-badges { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1.4rem; }
.trust-badge {
  display: inline-flex; align-items: center; gap: .4rem;
  background: rgba(255, 255, 255, .08); border: 1px solid rgba(255, 255, 255, .16);
  border-radius: var(--radius-full); padding: .4em .9em;
  font-size: var(--text-xs); font-weight: var(--weight-medium); color: rgba(255, 255, 255, .85);
}
.trust-badge i { color: var(--accent-light); }

/* ── Карточки с чек-листом (storage / backups / export / …) ── */
.trust-card-list { list-style: none; padding: 0; margin: .5rem 0 0; }
.trust-card-list li {
  display: flex; align-items: flex-start; gap: .5rem;
  font-size: var(--text-sm); color: var(--body); line-height: 1.55; padding: .28rem 0;
}
.trust-card-list .chk { color: var(--accent); font-size: var(--text-xs); margin-top: .25rem; flex-shrink: 0; }

/* ── Блок «Ваши данные — ваши» (тёмный, стекло-на-авроре как hero) ── */
.own-band {
  position: relative; overflow: hidden;
  background: var(--dark-bg); color: #fff; padding: 72px 0;
}
.own-band::after {
  content: ''; position: absolute; inset: -30%; z-index: 0; pointer-events: none;
  mix-blend-mode: screen;
  background-image:
    radial-gradient(ellipse 60% 45% at 80% 10%, rgba(13, 148, 136, .40) 0%, transparent 55%),
    radial-gradient(ellipse 50% 40% at 15% 90%, rgba(29, 78, 216, .30) 0%, transparent 55%);
  animation: aurora-float 26s ease-in-out infinite alternate;
}
.own-band > .container { position: relative; z-index: 1; }
.own-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.1rem; margin-top: 1.75rem; }
.own-item {
  background: rgba(255, 255, 255, .05); border: 1px solid rgba(255, 255, 255, .1);
  border-radius: var(--radius-lg); padding: 1.1rem 1.2rem;
}
.own-item i { font-size: 1.4rem; color: var(--accent-light); }
.own-item h4 { font-size: var(--text-base); font-weight: var(--weight-bold); color: #fff; margin: .6rem 0 .3rem; }
.own-item p { font-size: var(--text-sm); color: rgba(255, 255, 255, .6); line-height: 1.55; margin: 0; }

/* ── Степпер IQ/OQ/PQ ── */
.iqoqpq { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; margin-top: 1.5rem; counter-reset: stage; }
.iq-stage {
  position: relative; background: var(--bg); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 1.4rem 1.3rem; box-shadow: var(--shadow-sm);
}
.iq-stage::before {
  counter-increment: stage; content: counter(stage);
  position: absolute; top: -16px; left: 1.3rem;
  width: 34px; height: 34px; border-radius: 50%;
  background: var(--accent); color: #fff; font-weight: var(--weight-bold); font-size: var(--text-sm);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 14px rgba(13, 148, 136, .4);
}
.iq-stage .iq-code { font-size: var(--text-xs); font-weight: var(--weight-bold); letter-spacing: .08em; color: var(--accent); text-transform: uppercase; }
.iq-stage h4 { font-size: var(--text-base); font-weight: var(--weight-bold); color: var(--ink); margin: .3rem 0 .5rem; }
.iq-stage p { font-size: var(--text-sm); color: var(--muted); line-height: 1.6; margin: 0; }

/* ── Нормативный список ── */
.norm-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: .75rem; margin-top: 1.5rem; }
.norm-row {
  display: flex; align-items: flex-start; gap: .75rem;
  background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-md); padding: .9rem 1rem;
}
.norm-row .norm-ic {
  flex-shrink: 0; width: 38px; height: 38px; border-radius: var(--radius-sm);
  background: var(--accent-subtle); color: var(--accent);
  display: flex; align-items: center; justify-content: center; font-size: 1.1rem;
}
.norm-row .norm-code { font-weight: var(--weight-bold); color: var(--ink); font-size: var(--text-sm); }
.norm-row .norm-desc { font-size: var(--text-xs); color: var(--muted); margin-top: .15rem; line-height: 1.5; }

/* ── Форма запроса пакета (стеклянная карточка) ── */
.req-wrap { max-width: 640px; margin: 0 auto; }
.req-card {
  background: var(--glass-bg-card); backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border); border-radius: var(--radius-xl);
  box-shadow: var(--glass-shadow); padding: 2rem;
}
.req-card .form-control {
  border-radius: var(--radius-md); font-size: var(--text-sm); padding: .65rem .85rem;
}
.req-list { list-style: none; padding: 0; margin: 0 0 1.25rem; }
.req-list li { display: flex; align-items: flex-start; gap: .5rem; font-size: var(--text-sm); color: var(--body); padding: .25rem 0; }
.req-list .chk { color: var(--accent); margin-top: .2rem; flex-shrink: 0; }

[data-theme="dark"] .req-card .form-control {
  background: rgba(255, 255, 255, .06); border-color: rgba(255, 255, 255, .12); color: #e8eef5;
}
[data-theme="dark"] .req-card .form-control:focus {
  background: rgba(255, 255, 255, .09); border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(13, 148, 136, .2);
}
[data-theme="dark"] .req-card .form-control::placeholder { color: rgba(255, 255, 255, .3); }

/* ── Тизер доверия на лендинге (тёмная полоса перед тарифами) ── */
.trust-teaser { position: relative; overflow: hidden; background: var(--dark-bg2); color: #fff; padding: 72px 0; }
.trust-teaser::after {
  content: ''; position: absolute; inset: -30%; z-index: 0; pointer-events: none; mix-blend-mode: screen;
  background-image:
    radial-gradient(ellipse 55% 45% at 90% 100%, rgba(13, 148, 136, .35) 0%, transparent 55%),
    radial-gradient(ellipse 45% 40% at 5% 0%, rgba(109, 40, 217, .25) 0%, transparent 55%);
  animation: aurora-float 28s ease-in-out infinite alternate;
}
.trust-teaser > .container { position: relative; z-index: 1; }
.trust-teaser-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; margin-top: 1.75rem; }
.trust-teaser-card {
  display: block; text-decoration: none;
  background: rgba(255, 255, 255, .05); border: 1px solid rgba(255, 255, 255, .1);
  border-radius: var(--radius-lg); padding: 1.5rem 1.6rem;
  transition: transform var(--motion-base) var(--motion-ease), border-color var(--motion-base) var(--motion-ease), background var(--motion-base) var(--motion-ease);
}
.trust-teaser-card:hover { transform: translateY(-3px); border-color: rgba(13, 148, 136, .4); background: rgba(255, 255, 255, .07); }
.trust-teaser-card .tt-ic { font-size: 1.6rem; color: var(--accent-light); }
.trust-teaser-card h3 { font-size: var(--text-lg); font-weight: var(--weight-bold); color: #fff; margin: .7rem 0 .4rem; }
.trust-teaser-card p { font-size: var(--text-sm); color: rgba(255, 255, 255, .6); line-height: 1.6; margin: 0 0 .8rem; }
.trust-teaser-card .tt-more { font-size: var(--text-sm); font-weight: var(--weight-semibold); color: var(--accent-light); }

/* ── Адаптив ── */
@media (max-width: 760px) {
  .iqoqpq { grid-template-columns: 1fr; gap: 1.6rem; }
  .trust-teaser-grid { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) {
  .own-band::after, .trust-teaser::after { animation: none !important; }
}
