/* =================================================================
   Air · экраны аутентификации (Финал/Э5): login / register / restore(recover) / verification.

   Перенос из шаблона variant-01-air-service/css/screens/auth.css — ДОСЛОВНО auth-правила
   (.login-* / .register-* / .recover-*). Отличия от шаблонного файла:
     1. НЕ переносим хвост .profile-head/.profile-avatar/.profile-balance (стр.405-464 оригинала) —
        это профиль, артефакт бандлинга шаблона; профиль портирован отдельно в Э6/Э7 (.profile-hero).
     2. НЕ переносим auth-common.css (.auth-card-v2 и пр.) — мёртвый альтернативный v2-дизайн:
        разметка экранов его НЕ использует, сам шаблон его в <head> не подключает.
     3. Адаптив auth-* собран из шаблонного 90-responsive.css в конец файла (см. ниже).
     4. .auth-shell (внешний контейнер логина) — базовый, уже в 03-shared.css; здесь не дублируется.

   База темы (токены/shell) грузится через AirAsset (depends в AirAuthAsset).
   ================================================================= */

.login-shell {
  animation: scFade 0.4s ease;
  max-width: 1080px;
  margin: 0 auto;
  padding: 56px 22px 80px;
  color: var(--text);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  min-height: calc(100vh - 88px);
}

.login-layout {
  display: flex;
  justify-content: center;
  align-self: center;
}

.login-form-card {
  width: 100%;
  max-width: 576px;
  background: #fff;
  border: 1px solid var(--border-soft);
  border-radius: 24px;
  box-shadow: 0 10px 34px rgba(28, 58, 110, 0.07);
  padding: 44px;
}

.login-form-card h1 {
  margin: 0 0 7px;
  color: var(--text);
  font-size: 30px;
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -0.5px;
}

.login-form-card > p {
  margin: 0 0 30px;
  color: var(--muted-alt);
  font-size: 16px;
  line-height: 1.45;
}

.login-form-card .login-field-label {
  display: block;
  margin: 0 0 8px;
  color: var(--label);
  font-size: 13px;
  font-weight: 700;
}

.login-form-card .login-field-label input {
  display: block;
  width: 100%;
  min-height: 0;
  margin-top: 8px;
  margin-bottom: 18px;
  padding: 15px 16px;
  color: var(--text);
  font-size: 16px;
  font-weight: 400;
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 13px;
  outline: none;
}

.login-form-card .login-field-label input:focus {
  border-color: #b9cef2;
  box-shadow: 0 0 0 4px rgba(44, 107, 237, 0.08);
}

.login-remember-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 24px;
}

.login-remember {
  display: flex;
  align-items: center;
  gap: 9px;
  margin: 0;
  color: var(--label);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
}

.login-remember input {
  flex: 0 0 18px;
  width: 18px;
  min-width: 18px;
  height: 18px;
  min-height: 18px;
  padding: 0;
  margin: 0;
  accent-color: var(--blue);
  cursor: pointer;
}

/* Ссылки-«кнопки»: в шаблоне это <button data-target>, в боевых вьюхах — Yii <a href> (визуальный
   паритет: добавлен селектор ...note a к каждому button-правилу — даёт тот же синий/700/без-подчёркивания). */
.login-link,
.login-register-note button,
.login-register-note a {
  padding: 0;
  color: var(--blue);
  font: inherit;
  font-weight: 700;
  text-decoration: none;
  background: transparent;
  border: 0;
}

.login-link:hover,
.login-register-note button:hover,
.login-register-note a:hover {
  color: var(--blue-hover);
}

.login-submit {
  width: 100%;
  padding: 17px;
  color: #fff;
  font-size: 17px;
  font-weight: 700;
  background: var(--blue);
  border: 0;
  border-radius: 14px;
  box-shadow: 0 10px 24px rgba(44, 107, 237, 0.28);
}

.login-submit:hover {
  background: var(--blue-hover);
}

.login-register-note {
  margin-top: 22px;
  color: var(--muted-alt);
  font-size: 15px;
  text-align: center;
}

.register-shell {
  animation: scFade 0.4s ease;
  max-width: 1080px;
  margin: 0 auto;
  padding: 56px 22px 80px;
  color: var(--text);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  min-height: calc(100vh - 88px);
}

.register-layout {
  display: flex;
  justify-content: center;
  align-self: center;
}

.register-form-card {
  width: 100%;
  max-width: 576px;
  background: #fff;
  border: 1px solid var(--border-soft);
  border-radius: 24px;
  box-shadow: 0 10px 34px rgba(28, 58, 110, 0.07);
  padding: 44px;
}

.register-form-card h1 {
  margin: 0 0 7px;
  color: var(--text);
  font-size: 30px;
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -0.5px;
}

.register-form-card > p {
  margin: 0 0 30px;
  color: var(--muted-alt);
  font-size: 16px;
  line-height: 1.45;
}

.register-field-label {
  display: block;
  margin: 0 0 8px;
  color: var(--label);
  font-size: 13px;
  font-weight: 700;
}

.register-field-label > span {
  color: var(--red);
}

.register-field-label input {
  display: block;
  width: 100%;
  min-height: 0;
  margin-top: 8px;
  margin-bottom: 18px;
  padding: 15px 16px;
  color: var(--text);
  font-size: 16px;
  font-weight: 400;
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 13px;
  outline: none;
}

.register-field-label input:focus {
  border-color: #b9cef2;
  box-shadow: 0 0 0 4px rgba(44, 107, 237, 0.08);
}

.register-agreement {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 0 0 24px;
  color: var(--label);
  font-size: 14px;
  font-weight: 600;
  line-height: 1.45;
  cursor: pointer;
}

.register-agreement input {
  flex: 0 0 18px;
  width: 18px;
  min-width: 18px;
  height: 18px;
  min-height: 18px;
  padding: 0;
  margin: 1px 0 0;
  accent-color: var(--blue);
  cursor: pointer;
}

.register-agreement span {
  min-width: 0;
}

/* button (шаблон) → <a> (боевые вьюхи): см. коммент у .login-link выше. */
.register-agreement button,
.register-agreement a,
.register-login-note button,
.register-login-note a {
  padding: 0;
  color: var(--blue);
  font: inherit;
  font-weight: 700;
  text-decoration: none;
  background: transparent;
  border: 0;
}

.register-agreement button:hover,
.register-agreement a:hover,
.register-login-note button:hover,
.register-login-note a:hover {
  color: var(--blue-hover);
}

.register-submit {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  width: 100%;
  padding: 17px;
  color: #fff;
  font-size: 17px;
  font-weight: 700;
  background: var(--blue);
  border: 0;
  border-radius: 14px;
  box-shadow: 0 10px 24px rgba(44, 107, 237, 0.28);
}

.register-submit:hover {
  background: var(--blue-hover);
}

.register-login-note {
  margin-top: 22px;
  color: var(--muted-alt);
  font-size: 15px;
  text-align: center;
}

.recover-shell {
  animation: scFade 0.4s ease;
  max-width: 620px;
  margin: 0 auto;
  padding: 56px 22px 80px;
  color: var(--text);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  min-height: calc(100vh - 88px);
}

.recover-card {
  align-self: center;
  background: #fff;
  border: 1px solid var(--border-soft);
  border-radius: 24px;
  box-shadow: 0 10px 30px rgba(28, 58, 110, 0.06);
  padding: 44px;
}

.recover-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 60px;
  margin-bottom: 20px;
  border-radius: 16px;
  background: var(--blue-soft);
  color: var(--blue);
}

.recover-card h1 {
  margin: 0 0 8px;
  color: var(--text);
  font-size: 28px;
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -0.5px;
}

.recover-card > p {
  margin: 0 0 26px;
  color: var(--muted-alt);
  font-size: 16px;
  line-height: 1.45;
}

.recover-field-label {
  display: block;
  margin: 0 0 8px;
  color: var(--label);
  font-size: 13px;
  font-weight: 700;
}

.recover-field-label input {
  display: block;
  width: 100%;
  min-height: 0;
  margin-top: 8px;
  margin-bottom: 24px;
  padding: 15px 16px;
  color: var(--text);
  font-size: 16px;
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 13px;
  outline: none;
}

.recover-field-label input:focus {
  border-color: #b9cef2;
  box-shadow: 0 0 0 4px rgba(44, 107, 237, 0.08);
}

.recover-submit {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  width: 100%;
  padding: 17px;
  color: #fff;
  font-size: 17px;
  font-weight: 700;
  background: var(--blue);
  border: 0;
  border-radius: 14px;
  box-shadow: 0 10px 24px rgba(44, 107, 237, 0.28);
}

.recover-submit:hover {
  background: var(--blue-hover);
}

.recover-login-note {
  margin-top: 22px;
  color: var(--muted-alt);
  font-size: 15px;
  text-align: center;
}

/* button (шаблон) → <a> (боевые вьюхи restore/verification): см. коммент у .login-link выше. */
.recover-login-note button,
.recover-login-note a {
  padding: 0;
  color: var(--blue);
  font: inherit;
  font-weight: 700;
  text-decoration: none;
  background: transparent;
  border: 0;
}

.recover-login-note button:hover,
.recover-login-note a:hover {
  color: var(--blue-hover);
}

/* =================================================================
   Адаптив auth-экранов — перенесён из шаблонного css/90-responsive.css
   (контракт roadmap §7: все @media для auth-селекторов идут в per-screen CSS).
   Смешанное брекрамб-правило обрезано до auth-шеллов (profile/balance имеют свой CSS).
   ================================================================= */

/* Планшет: внешний шелл логина чуть уже (стр. 476 шаблона). */
@media (min-width: 721px) and (max-width: 1180px) {
  .auth-shell {
    max-width: 920px;
  }
}

/* Телефон: карточки auth разворачиваются на всю ширину (стр. 1031-1095 шаблона). */
@media (max-width: 720px) {
  .login-shell {
    display: block;
    min-height: 0;
    padding: 28px 8px 70px;
  }

  .login-shell .page-breadcrumb,
  .register-shell .page-breadcrumb,
  .recover-shell .page-breadcrumb {
    width: 100%;
    margin-left: 0;
  }

  .login-layout {
    display: block;
  }

  .login-form-card {
    max-width: none;
    min-width: 0;
    padding: 24px 20px;
    border-radius: 22px;
  }

  .login-form-card h1 {
    font-size: 26px;
  }

  .register-shell {
    display: block;
    min-height: 0;
    padding: 28px 8px 70px;
  }

  .register-layout {
    display: block;
  }

  .register-form-card {
    max-width: none;
    min-width: 0;
    padding: 24px 20px;
    border-radius: 22px;
  }

  .register-form-card h1 {
    font-size: 26px;
  }

  .recover-shell {
    display: block;
    min-height: 0;
    padding: 28px 8px 70px;
  }

  .recover-card {
    padding: 24px 20px;
    border-radius: 22px;
  }

  .recover-card h1 {
    font-size: 26px;
  }
}

/* Уведомления (.form-notice/.form-alert) — БЛОКОМ под кнопкой recover/login/register.
   База даёт margin-top:14px, но у кнопки тень box-shadow 0 10px 24px «съедает» зазор и плашка
   липнет к кнопке. Поднимаем отступ до 22px (в ритм карточки: recover-login-note тоже 22px),
   чтобы зазор перекрыл тень. Скоуп — только прямые дети auth-карточек (field-level ошибки
   login/register живут внутри формы и сюда НЕ попадают). */
.recover-card > .form-notice,
.recover-card > .form-alert,
.login-form-card > .form-notice,
.login-form-card > .form-alert,
.register-form-card > .form-notice,
.register-form-card > .form-alert {
  margin-top: 22px;
}

/* Фон под auth-экраны: секция шаблона .screen[data-screen] заменена на .air-*-page
   (даёт основной фон страницы — иначе прозрачный блок ляжет на дефолт). */
.air-login-page,
.air-register-page,
.air-restore-page,
.air-verification-page {
  background: var(--bg);
  min-height: 100%;
}
