/* Booking — Auth page (F88.W5)
 * Standalone web-вход. Premium: Inter + tokens.css палитра (light/dark auto).
 * Канон: Linear / Cal.com auth card — центрированная карточка, мягкие тени.
 */

@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/landing/fonts/inter-cyrillic-400.woff2") format("woff2");
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("/landing/fonts/inter-cyrillic-600.woff2") format("woff2");
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: "Inter", var(--font-sans);
  font-size: var(--text-base);
  line-height: var(--leading-base);
  color: var(--color-text);
  background:
    radial-gradient(1200px 600px at 50% -10%, rgba(37, 99, 235, .08), transparent 60%),
    var(--color-bg-muted);
  -webkit-font-smoothing: antialiased;
}

.auth {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-6) var(--space-4);
  gap: var(--space-4);
}

.auth__card {
  width: 100%;
  max-width: 408px;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  padding: var(--space-8) var(--space-8) var(--space-6);
}

.auth__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-6);
}

.auth__brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-weight: var(--font-semibold);
  font-size: var(--text-lg);
  color: var(--color-text);
  text-decoration: none;
}
.auth__logo { width: 24px; height: 24px; color: var(--brand-primary); fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

.lang { display: inline-flex; gap: 2px; background: var(--color-bg-subtle); border-radius: var(--radius-full); padding: 3px; }
.lang__btn {
  border: 0; background: transparent; cursor: pointer;
  font: inherit; font-size: var(--text-xs); font-weight: var(--font-medium);
  color: var(--color-text-muted);
  padding: 4px 9px; border-radius: var(--radius-full);
  transition: color var(--dur-fast) var(--ease-standard), background var(--dur-fast) var(--ease-standard);
}
.lang__btn.is-active { background: var(--color-bg); color: var(--color-text); box-shadow: var(--shadow-sm); }

.auth__title { margin: 0 0 var(--space-1); font-size: var(--text-2xl); font-weight: var(--font-semibold); letter-spacing: -.01em; }
.auth__subtitle { margin: 0 0 var(--space-6); color: var(--color-text-muted); font-size: var(--text-sm); }

.auth__tabs { display: flex; gap: 2px; background: var(--color-bg-subtle); border-radius: var(--radius-md); padding: 3px; margin-bottom: var(--space-5); }
.auth__tab {
  flex: 1; border: 0; background: transparent; cursor: pointer;
  font: inherit; font-size: var(--text-sm); font-weight: var(--font-medium);
  color: var(--color-text-muted);
  padding: 8px 12px; border-radius: var(--radius-sm);
  transition: color var(--dur-fast) var(--ease-standard), background var(--dur-fast) var(--ease-standard);
}
.auth__tab.is-active { background: var(--color-bg); color: var(--color-text); box-shadow: var(--shadow-sm); }

.auth__form { display: none; flex-direction: column; gap: var(--space-4); }
.auth__form.is-active { display: flex; }

/* F88.W12 — сегмент-переключатель Email ↔ Телефон (компактнее табов). */
.auth__mode { display: flex; gap: 2px; background: var(--color-bg-subtle); border-radius: var(--radius-md); padding: 3px; }
.auth__mode-btn {
  flex: 1; border: 0; background: transparent; cursor: pointer;
  font: inherit; font-size: var(--text-xs); font-weight: var(--font-medium);
  color: var(--color-text-muted);
  padding: 6px 10px; border-radius: var(--radius-sm);
  transition: color var(--dur-fast) var(--ease-standard), background var(--dur-fast) var(--ease-standard);
}
.auth__mode-btn.is-active { background: var(--color-bg); color: var(--color-text); box-shadow: var(--shadow-sm); }

.field { display: flex; flex-direction: column; gap: var(--space-2); }
.field__label { font-size: var(--text-sm); font-weight: var(--font-medium); color: var(--color-text); }
.field__hint { font-weight: var(--font-regular, 400); color: var(--color-text-subtle); font-size: var(--text-xs); }
.field__wrap { position: relative; display: flex; align-items: center; }
.field__icon {
  position: absolute; left: 12px; width: 18px; height: 18px;
  color: var(--color-text-subtle); fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
  pointer-events: none;
}
.field__input {
  width: 100%;
  font: inherit; font-size: var(--text-base);
  color: var(--color-text);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 11px 12px 11px 38px;
  transition: border-color var(--dur-fast) var(--ease-standard), box-shadow var(--dur-fast) var(--ease-standard);
}
.field__input::placeholder { color: var(--color-text-subtle); }
.field__input:focus {
  outline: none;
  border-color: var(--brand-primary);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, .15);
}
/* F88.W12 — inline-валидация: подсветка поля + текст ошибки под ним. */
.field.has-error .field__input { border-color: var(--color-status-cancelled); }
.field.has-error .field__input:focus { box-shadow: 0 0 0 3px rgba(239, 68, 68, .15); }
.field__error { font-size: var(--text-xs); color: var(--color-status-cancelled); }
.field__eye {
  position: absolute; right: 8px; display: inline-flex; align-items: center; justify-content: center;
  width: 30px; height: 30px; border: 0; background: transparent; cursor: pointer; color: var(--color-text-subtle);
  border-radius: var(--radius-sm);
}
.field__eye svg { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.field__eye:hover { color: var(--color-text-muted); }

.auth__submit {
  position: relative;
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  margin-top: var(--space-1);
  font: inherit; font-size: var(--text-base); font-weight: var(--font-semibold);
  color: var(--color-text-inverse);
  background: var(--brand-primary);
  border: 0; border-radius: var(--radius-md);
  padding: 12px 16px; cursor: pointer;
  transition: background var(--dur-fast) var(--ease-standard), transform var(--dur-fast) var(--ease-standard);
}
.auth__submit:hover { background: var(--brand-primary-hover); }
.auth__submit:active { transform: translateY(1px); }
.auth__submit[disabled] { opacity: .65; cursor: default; }
.auth__submit-icon { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.auth__submit.is-loading .auth__submit-label,
.auth__submit.is-loading .auth__submit-icon { visibility: hidden; }
.auth__spinner {
  position: absolute; width: 18px; height: 18px;
  border: 2px solid rgba(255,255,255,.4); border-top-color: #fff; border-radius: var(--radius-full);
  animation: auth-spin .7s linear infinite;
}
@keyframes auth-spin { to { transform: rotate(360deg); } }

.auth__link {
  margin: var(--space-2) auto 0;
  border: 0; background: transparent; cursor: pointer;
  font: inherit; font-size: var(--text-sm); color: var(--brand-primary);
}
.auth__link:hover { text-decoration: underline; }

.auth__msg {
  display: flex; align-items: flex-start; gap: var(--space-2);
  font-size: var(--text-sm);
  padding: 10px 12px; border-radius: var(--radius-md);
  margin-bottom: var(--space-4);
  background: rgba(239, 68, 68, .10);
  color: var(--color-status-cancelled);
  border: 1px solid rgba(239, 68, 68, .25);
}
/* F88.W14 — без этого правила атрибут `hidden` не скрывает баннер: author
 * `.auth__msg{display:flex}` перебивает UA `[hidden]{display:none}` → пустой
 * красный баннер висит на загрузке. Специфичность (0,2,0) > (0,1,0). */
.auth__msg[hidden] { display: none; }
.auth__msg.is-success {
  background: rgba(16, 185, 129, .10);
  color: var(--color-status-confirmed);
  border-color: rgba(16, 185, 129, .25);
}
.auth__msg-icon { flex: 0 0 auto; width: 18px; height: 18px; margin-top: 1px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.auth__msg.is-success .auth__msg-icon use { }

/* F88.W4 — социальный OAuth (Google/Yandex). Premium neutral-кнопки с бренд-
 * логотипами (канон Cal.com/Linear): белый фон + бордер + цветной логотип слева. */
.oauth { display: flex; flex-direction: column; gap: var(--space-3); margin-top: var(--space-2); }
.oauth__divider { display: flex; align-items: center; gap: var(--space-3); color: var(--color-text-subtle); font-size: var(--text-xs); }
.oauth__divider::before, .oauth__divider::after { content: ""; flex: 1; height: 1px; background: var(--color-border); }
.oauth__btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  font: inherit; font-size: var(--text-sm); font-weight: var(--font-medium);
  color: var(--color-text);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 10px 14px; cursor: pointer;
  transition: background var(--dur-fast) var(--ease-standard), border-color var(--dur-fast) var(--ease-standard);
}
.oauth__btn:hover { background: var(--color-bg-subtle); border-color: var(--color-border-strong); }
.oauth__btn:active { transform: translateY(1px); }
.oauth__logo { display: inline-flex; flex: 0 0 auto; width: 18px; height: 18px; }
.oauth__logo svg { width: 18px; height: 18px; display: block; }

.auth__foot { color: var(--color-text-subtle); font-size: var(--text-xs); margin: 0; }
