/* ZeroID public landing. Relies on the design tokens (:root vars, .brand*)
   defined in styles.css, which is loaded before this file. */

body.lp {
  background: var(--bg);
  min-height: 100vh;
  line-height: 1.5;
}
.lp a { color: inherit; text-decoration: none; }
.lp img { max-width: 100%; display: block; }
.lp-wrap { max-width: 1120px; margin: 0 auto; padding: 0 22px; }
.lp-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 700; letter-spacing: 0.2px;
  color: var(--brand); background: #e7edff;
  padding: 6px 13px; border-radius: 999px;
}
.lp-eyebrow .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--brand); }

/* ---------- buttons ---------- */
.lp-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  font-size: 15px; font-weight: 700; cursor: pointer;
  padding: 13px 22px; border-radius: 13px; border: 1px solid transparent;
  transition: transform .12s ease, box-shadow .2s ease, background .2s ease;
  white-space: nowrap;
}
.lp-btn:active { transform: translateY(1px); }
.lp-btn--primary { background: var(--brand); color: #fff; box-shadow: 0 10px 24px rgba(47,91,255,0.32); }
.lp-btn--primary:hover { background: #1f48ed; box-shadow: 0 14px 30px rgba(47,91,255,0.40); }
.lp-btn--ghost { background: #fff; color: var(--ink); border-color: var(--line); box-shadow: var(--shadow-sm); }
.lp-btn--ghost:hover { border-color: #c9d4f5; }
.lp-btn--lg { padding: 16px 28px; font-size: 16px; }
.lp-btn svg { width: 18px; height: 18px; }

/* ---------- nav ---------- */
.lp-nav {
  position: sticky; top: 0; z-index: 30;
  background: rgba(238,241,248,0.82);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid rgba(15,27,61,0.06);
}
.lp-nav__inner { display: flex; align-items: center; gap: 18px; height: 66px; }
.lp-nav__links { display: flex; gap: 26px; margin-left: 14px; }
.lp-nav__links a { font-size: 14.5px; font-weight: 600; color: var(--ink-soft); }
.lp-nav__links a:hover { color: var(--ink); }
.lp-nav__spacer { flex: 1; }
.lp-nav__cta { display: flex; align-items: center; gap: 12px; }
.lp-nav__login { font-size: 14.5px; font-weight: 700; color: var(--ink); }
.lp-nav__login:hover { color: var(--brand); }

/* ---------- hero ---------- */
.lp-hero {
  position: relative; overflow: hidden;
  background:
    radial-gradient(900px 460px at 78% -120px, #d4deff 0%, rgba(212,222,255,0) 70%),
    radial-gradient(700px 380px at 8% 120%, #e3e9ff 0%, rgba(227,233,255,0) 70%);
}
.lp-hero__grid {
  display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 48px; align-items: center;
  padding: 72px 0 84px;
}
.lp-hero h1 {
  font-size: 48px; line-height: 1.06; letter-spacing: -1.2px; font-weight: 800;
  margin: 20px 0 18px; color: var(--ink);
}
.lp-hero h1 .accent { color: var(--brand); }
.lp-hero__sub { font-size: 18px; color: var(--ink-soft); max-width: 520px; margin: 0 0 30px; }
.lp-hero__cta { display: flex; gap: 14px; flex-wrap: wrap; }
.lp-hero__trust { display: flex; gap: 26px; margin-top: 34px; flex-wrap: wrap; }
.lp-trust__item { display: flex; align-items: center; gap: 9px; font-size: 13.5px; font-weight: 600; color: var(--ink-soft); }
.lp-trust__item .tic { width: 22px; height: 22px; border-radius: 50%; display: grid; place-items: center; background: var(--ok-bg); color: var(--ok); flex: none; }
.lp-trust__item .tic svg { width: 13px; height: 13px; }

/* hero visual: mock verify card on a phone-ish panel */
.lp-hero__art { display: grid; place-items: center; }
.lp-phone {
  width: 300px; background: #fff; border-radius: 30px; padding: 16px;
  box-shadow: 0 30px 70px rgba(15,27,61,0.22); border: 1px solid var(--line);
  transform: rotate(2deg);
}
.lp-phone__status {
  display: flex; align-items: center; gap: 11px;
  background: var(--ok-bg); border-radius: 14px; padding: 12px 14px; margin-bottom: 13px;
}
.lp-phone__status .sic { width: 34px; height: 34px; border-radius: 50%; background: var(--ok); color: #fff; display: grid; place-items: center; flex: none; }
.lp-phone__status .sic svg { width: 19px; height: 19px; }
.lp-phone__status .st { font-size: 14px; font-weight: 800; color: #11823a; }
.lp-phone__status .ss { font-size: 12px; color: var(--ink-soft); }
.lp-card-mini { border: 1px solid var(--line); border-radius: 18px; padding: 15px; box-shadow: var(--shadow-sm); }
.lp-card-mini__top { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.lp-avatar { width: 56px; height: 56px; border-radius: 15px; flex: none; display: grid; place-items: center; color: #fff; font-weight: 800; font-size: 21px; background: linear-gradient(140deg, var(--brand), #8aa2ff); }
.lp-card-mini__name { font-size: 16px; font-weight: 800; letter-spacing: -0.2px; }
.lp-card-mini__pos { font-size: 12.5px; color: var(--ink-soft); }
.lp-chip { display: inline-block; margin-top: 5px; font-size: 11px; font-weight: 700; padding: 3px 9px; border-radius: 999px; background: var(--ok-bg); color: #11823a; }
.lp-doc { display: flex; align-items: center; gap: 11px; padding: 10px 0; border-top: 1px solid var(--line); }
.lp-doc__ic { width: 34px; height: 34px; border-radius: 10px; flex: none; display: grid; place-items: center; background: #eef2fc; color: var(--brand); }
.lp-doc__ic svg { width: 17px; height: 17px; }
.lp-doc__l { font-size: 13px; font-weight: 700; }
.lp-doc__m { font-size: 11.5px; color: var(--ink-soft); }
.lp-doc__ok { margin-left: auto; font-size: 11px; font-weight: 700; color: var(--ok); }

/* ---------- generic section ---------- */
.lp-section { padding: 76px 0; }
.lp-section--alt { background: #fff; }
.lp-section__head { text-align: center; max-width: 680px; margin: 0 auto 46px; }
.lp-section__head h2 { font-size: 34px; letter-spacing: -0.6px; font-weight: 800; margin: 14px 0 12px; color: var(--ink); }
.lp-section__head p { font-size: 17px; color: var(--ink-soft); margin: 0; }

/* steps */
.lp-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.lp-step { background: var(--bg); border: 1px solid var(--line); border-radius: var(--radius); padding: 24px 20px; position: relative; }
.lp-section--alt .lp-step { background: #f7f9ff; }
.lp-step__n { width: 36px; height: 36px; border-radius: 11px; display: grid; place-items: center; font-weight: 800; font-size: 16px; color: #fff; background: linear-gradient(135deg, var(--brand), var(--brand-2)); box-shadow: 0 8px 18px rgba(47,91,255,0.28); margin-bottom: 16px; }
.lp-step h3 { font-size: 17px; font-weight: 800; margin: 0 0 7px; }
.lp-step p { font-size: 14px; color: var(--ink-soft); margin: 0; }

/* features */
.lp-features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.lp-feature { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 26px 24px; box-shadow: var(--shadow-sm); transition: transform .15s ease, box-shadow .2s ease; }
.lp-section--alt .lp-feature { background: var(--bg); }
.lp-feature:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.lp-feature__ic { width: 50px; height: 50px; border-radius: 14px; display: grid; place-items: center; background: #e7edff; color: var(--brand); margin-bottom: 16px; }
.lp-feature__ic svg { width: 25px; height: 25px; }
.lp-feature h3 { font-size: 18px; font-weight: 800; margin: 0 0 8px; }
.lp-feature p { font-size: 14.5px; color: var(--ink-soft); margin: 0; }

/* audience band */
.lp-audience { display: flex; align-items: center; gap: 36px; background: linear-gradient(135deg, #14224d 0%, #20336e 100%); border-radius: 28px; padding: 44px 46px; color: #fff; flex-wrap: wrap; }
.lp-audience__txt { flex: 1; min-width: 260px; }
.lp-audience h2 { font-size: 30px; letter-spacing: -0.5px; font-weight: 800; margin: 0 0 12px; }
.lp-audience p { font-size: 16.5px; color: #c4ccea; margin: 0; max-width: 560px; }

/* ---------- application form ---------- */
.lp-apply { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 44px; align-items: start; }
.lp-apply__aside h2 { font-size: 32px; letter-spacing: -0.6px; font-weight: 800; margin: 14px 0 14px; }
.lp-apply__aside p { font-size: 16px; color: var(--ink-soft); margin: 0 0 22px; }
.lp-apply__list { display: grid; gap: 14px; }
.lp-apply__li { display: flex; gap: 12px; align-items: flex-start; font-size: 15px; color: var(--ink); }
.lp-apply__li .lic { width: 24px; height: 24px; border-radius: 50%; flex: none; display: grid; place-items: center; background: var(--ok-bg); color: var(--ok); }
.lp-apply__li .lic svg { width: 14px; height: 14px; }

.lp-form-card { background: #fff; border: 1px solid var(--line); border-radius: 24px; box-shadow: var(--shadow); padding: 30px; }
.lp-form { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.lp-field { display: grid; gap: 6px; }
.lp-field--full { grid-column: 1 / -1; }
.lp-field label { font-size: 12.5px; font-weight: 700; color: var(--ink-soft); }
.lp-field input {
  width: 100%; font-size: 15px; color: var(--ink);
  padding: 12px 14px; border: 1px solid var(--line); border-radius: 12px; background: #fbfcff;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.lp-field input:focus { outline: 0; border-color: var(--brand); box-shadow: 0 0 0 3px rgba(47,91,255,0.15); background: #fff; }
.lp-form__sep { grid-column: 1 / -1; display: flex; align-items: center; gap: 12px; font-size: 12px; font-weight: 700; letter-spacing: 0.4px; text-transform: uppercase; color: var(--ink-soft); margin-top: 6px; }
.lp-form__sep::before, .lp-form__sep::after { content: ""; height: 1px; flex: 1; background: var(--line); }
.lp-form__note { grid-column: 1 / -1; font-size: 12.5px; color: var(--ink-soft); margin-top: 2px; text-align: center; }
.lp-form__note a { color: var(--brand); font-weight: 700; }

/* ---------- footer ---------- */
.lp-footer { background: #0f1b3d; color: #aeb8d8; padding: 50px 0 34px; }
.lp-footer__grid { display: flex; justify-content: space-between; gap: 30px; flex-wrap: wrap; margin-bottom: 30px; }
.lp-footer__brand .brand-name, .lp-footer__brand .brand-name b { color: #fff; }
.lp-footer__tag { font-size: 14px; color: #8a96bd; margin: 12px 0 0; max-width: 300px; }
.lp-footer__col h4 { font-size: 13px; text-transform: uppercase; letter-spacing: 0.5px; color: #7c88b0; margin: 0 0 14px; }
.lp-footer__col a, .lp-footer__col span { display: block; font-size: 14.5px; color: #c2cae6; margin-bottom: 10px; }
.lp-footer__col a:hover { color: #fff; }
.lp-footer__bottom { border-top: 1px solid rgba(255,255,255,0.10); padding-top: 22px; font-size: 13px; color: #7c88b0; display: flex; justify-content: space-between; gap: 12px; flex-wrap: wrap; }

/* ---------- responsive ---------- */
@media (max-width: 920px) {
  .lp-hero__grid { grid-template-columns: 1fr; gap: 36px; padding: 52px 0 64px; }
  .lp-hero__art { order: -1; }
  .lp-hero h1 { font-size: 38px; }
  .lp-steps { grid-template-columns: repeat(2, 1fr); }
  .lp-features { grid-template-columns: repeat(2, 1fr); }
  .lp-apply { grid-template-columns: 1fr; gap: 30px; }
  .lp-nav__links { display: none; }
}
@media (max-width: 560px) {
  .lp-wrap { padding: 0 16px; }
  .lp-hero h1 { font-size: 31px; }
  .lp-hero__sub { font-size: 16px; }
  .lp-section { padding: 56px 0; }
  .lp-section__head h2 { font-size: 27px; }
  .lp-steps, .lp-features { grid-template-columns: 1fr; }
  .lp-form { grid-template-columns: 1fr; }
  .lp-hero__cta { flex-direction: column; }
  .lp-hero__cta .lp-btn { width: 100%; }
  .lp-audience { padding: 32px 26px; }
}
