/* ======================================================
   КАДУЦЕЙ | LOGIN — FINAL STABLE v2.0
   Исправлена адаптивность для всех устройств
====================================================== */

/* ======================================================
   CSS VARIABLES — для удобного управления
====================================================== */
:root {
  --caduceus-bg-dark: #461C1B;
  --caduceus-bg-card: #242220;
  --caduceus-bg-input: #2B2825;
  --caduceus-gold: #D9BD98;
  --caduceus-gold-light: #E4CFAD;
  --caduceus-text: #F1E7D6;
  --caduceus-text-muted: rgba(241, 231, 214, 0.7);
  --caduceus-error: #E57373;
  --caduceus-shadow: rgba(217, 189, 152, 0.24);
}

/* ======================================================
   PAGE WRAPPER
====================================================== */
.login-wrapper {
  background: var(--caduceus-bg-dark) !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  min-height: 100vh !important;
  min-height: 100dvh !important; /* для мобильных браузеров */
  padding: 20px !important;
  box-sizing: border-box !important;
}

/* ======================================================
   CARD CONTAINER
====================================================== */
.login-wrapper > div {
  background: var(--caduceus-bg-card) !important;
  border-radius: 15px !important;
  border: 2px solid var(--caduceus-gold) !important;
  box-shadow: 0 18px 60px var(--caduceus-shadow) !important;
  display: flex !important;
  width: 900px !important;
  max-width: calc(100vw - 40px) !important;
  overflow: hidden !important;
  position: relative !important;
  min-height: 520px !important;
  box-sizing: border-box !important;
}

/* ======================================================
   LEFT COLUMN — FORM AREA
====================================================== */
.login-wrapper ._auth_form_wrapper_p3cc9_46 {
  width: 55% !important;
  padding: 40px !important;
  z-index: 2 !important;
  position: relative !important;
  box-sizing: border-box !important;
}

/* ======================================================
   TITLE
====================================================== */
.login-wrapper .login-school-name {
  font-size: 20px !important;
  color: var(--caduceus-gold) !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  line-height: 1.3 !important;
}

/* ======================================================
   SECTION TITLES
====================================================== */
.login-wrapper h3,
.login-wrapper .ant-typography {
  color: var(--caduceus-text) !important;
}

/* ======================================================
   INPUTS — UNIFIED & STABLE
====================================================== */

/* Password wrapper */
.login-wrapper .ant-input-affix-wrapper {
  background: var(--caduceus-bg-input) !important;
  border: 1px solid rgba(217, 189, 152, 0.85) !important;
  border-radius: 10px !important;
  height: 50px !important;
  transition: border-color 0.3s ease, box-shadow 0.3s ease !important;
}

/* Email input */
.login-wrapper input.ant-input[type="email"],
.login-wrapper input.ant-input[type="text"],
.login-wrapper input.ant-input[type="tel"] {
  background: var(--caduceus-bg-input) !important;
  border: 1px solid rgba(217, 189, 152, 0.85) !important;
  border-radius: 10px !important;
  height: 50px !important;
  padding: 0 14px !important;
  color: var(--caduceus-text) !important;
  font-size: 16px !important; /* предотвращает zoom на iOS */
  transition: border-color 0.3s ease, box-shadow 0.3s ease !important;
  box-sizing: border-box !important;
}

/* Inner input */
.login-wrapper .ant-input,
.login-wrapper .ant-input-affix-wrapper input {
  background: transparent !important;
  border: none !important;
  color: var(--caduceus-text) !important;
  caret-color: var(--caduceus-text) !important;
  font-size: 16px !important; /* предотвращает zoom на iOS */
}

/* Hover states */
.login-wrapper .ant-input-affix-wrapper:hover,
.login-wrapper input.ant-input[type="email"]:hover,
.login-wrapper input.ant-input[type="text"]:hover,
.login-wrapper input.ant-input[type="tel"]:hover {
  border-color: var(--caduceus-gold) !important;
}

/* Focus states */
.login-wrapper .ant-input-affix-wrapper:focus-within,
.login-wrapper input.ant-input[type="email"]:focus,
.login-wrapper input.ant-input[type="text"]:focus,
.login-wrapper input.ant-input[type="tel"]:focus {
  border-color: var(--caduceus-gold) !important;
  box-shadow: 0 0 0 3px rgba(217, 189, 152, 0.22) !important;
  outline: none !important;
}

/* Placeholder */
.login-wrapper input::placeholder {
  color: var(--caduceus-text-muted) !important;
  opacity: 1 !important;
}

/* Autofill fix */
.login-wrapper input:-webkit-autofill,
.login-wrapper input:-webkit-autofill:hover,
.login-wrapper input:-webkit-autofill:focus,
.login-wrapper input:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0 1000px var(--caduceus-bg-input) inset !important;
  -webkit-text-fill-color: var(--caduceus-text) !important;
  transition: background-color 5000s ease-in-out 0s !important;
}

/* ======================================================
   ERRORS & LABELS
====================================================== */
.login-wrapper .ant-form-item-explain-error {
  color: var(--caduceus-error) !important;
  font-size: 13px !important;
  margin-top: 4px !important;
}

.login-wrapper .ant-form-item-label label {
  color: var(--caduceus-text) !important;
}

/* ======================================================
   BUTTON
====================================================== */
.login-wrapper .ant-btn {
  background: var(--caduceus-bg-dark) !important;
  color: #fff !important;
  border: 2px solid var(--caduceus-gold) !important;
  border-radius: 40px !important;
  width: 100% !important;
  height: 56px !important;
  min-height: 48px !important;
  margin-top: 20px !important;
  box-shadow: 0 10px 28px rgba(217, 189, 152, 0.18) !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: background-color 0.3s ease, transform 0.2s ease, box-shadow 0.3s ease !important;
}

.login-wrapper .ant-btn:hover {
  background: #3B1514 !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 14px 32px rgba(217, 189, 152, 0.25) !important;
}

.login-wrapper .ant-btn:active {
  transform: translateY(0) !important;
  box-shadow: 0 8px 20px rgba(217, 189, 152, 0.15) !important;
}

/* Focus state для accessibility */
.login-wrapper .ant-btn:focus-visible {
  outline: 2px solid var(--caduceus-gold) !important;
  outline-offset: 2px !important;
}

/* ======================================================
   LINKS
====================================================== */
.login-wrapper a {
  color: var(--caduceus-gold) !important;
  text-decoration: none !important;
  transition: color 0.3s ease !important;
}

.login-wrapper a:hover {
  color: var(--caduceus-gold-light) !important;
  text-decoration: underline !important;
}

/* ======================================================
   RIGHT IMAGE — DECORATIVE PANEL
====================================================== */
.login-wrapper > div::after {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  right: 0 !important;
  width: 45% !important;
  height: 100% !important;
  background-image:
    linear-gradient(to left,
      rgba(36, 34, 32, 0) 0%,
      rgba(36, 34, 32, 0.35) 60%,
      rgba(36, 34, 32, 0.65) 82%,
      #242220 100%
    ),
    url('https://con.xl.ru/-PRgI1FY0k-ihkI2XhpGYg/images/sMvGY9HtX0eakdSSdJcn6w.png') !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  z-index: 1 !important;
  pointer-events: none !important;
}

/* ======================================================
   FOOTER TEXT
====================================================== */
.login-wrapper ._auth_form_wrapper_footer_1gq79_14,
.login-wrapper ._auth_form_wrapper_footer_1gq79_14 * {
  color: var(--caduceus-text-muted) !important;
}

/* Скрываем надпись "Работает на" */
.flex.flex-col.align-center > .fw-500 {
  display: none !important;
}

/* ======================================================
   ADAPTIVE — TABLET (768px - 900px)
====================================================== */
@media (max-width: 900px) {
  .login-wrapper > div {
    flex-direction: column !important;
    width: 100% !important;
    max-width: 500px !important;
    min-height: auto !important;
  }

  .login-wrapper ._auth_form_wrapper_p3cc9_46 {
    width: 100% !important;
    padding: 32px !important;
  }

  .login-wrapper > div::after {
    display: none !important;
  }
}

/* ======================================================
   ADAPTIVE — SMALL TABLET (576px - 768px)
====================================================== */
@media (max-width: 768px) {
  .login-wrapper {
    padding: 16px !important;
  }

  .login-wrapper > div {
    max-width: 100% !important;
    border-radius: 12px !important;
  }

  .login-wrapper ._auth_form_wrapper_p3cc9_46 {
    padding: 28px 24px !important;
  }

  .login-wrapper .login-school-name {
    font-size: 18px !important;
  }

  .login-wrapper .ant-btn {
    height: 52px !important;
    margin-top: 16px !important;
  }
}

/* ======================================================
   ADAPTIVE — MOBILE (до 576px)
====================================================== */
@media (max-width: 576px) {
  .login-wrapper {
    padding: 12px !important;
    align-items: flex-start !important;
    padding-top: 24px !important;
  }

  .login-wrapper > div {
    border-radius: 10px !important;
    border-width: 1px !important;
  }

  .login-wrapper ._auth_form_wrapper_p3cc9_46 {
    padding: 24px 20px !important;
  }

  .login-wrapper .login-school-name {
    font-size: 16px !important;
    letter-spacing: 0.04em !important;
  }

  .login-wrapper h3 {
    font-size: 20px !important;
  }

  .login-wrapper .ant-input-affix-wrapper,
  .login-wrapper input.ant-input[type="email"],
  .login-wrapper input.ant-input[type="text"],
  .login-wrapper input.ant-input[type="tel"] {
    height: 48px !important;
    border-radius: 8px !important;
  }

  .login-wrapper .ant-btn {
    height: 50px !important;
    border-radius: 25px !important;
    font-size: 15px !important;
    margin-top: 16px !important;
  }

  .login-wrapper .ant-form-item-explain-error {
    font-size: 12px !important;
  }
}

/* ======================================================
   ADAPTIVE — EXTRA SMALL MOBILE (до 360px)
====================================================== */
@media (max-width: 360px) {
  .login-wrapper {
    padding: 8px !important;
    padding-top: 16px !important;
  }

  .login-wrapper ._auth_form_wrapper_p3cc9_46 {
    padding: 20px 16px !important;
  }

  .login-wrapper .login-school-name {
    font-size: 14px !important;
  }

  .login-wrapper h3 {
    font-size: 18px !important;
  }

  .login-wrapper .ant-btn {
    height: 48px !important;
    font-size: 14px !important;
  }
}

/* ======================================================
   LANDSCAPE MODE — MOBILE
====================================================== */
@media (max-height: 500px) and (orientation: landscape) {
  .login-wrapper {
    align-items: flex-start !important;
    padding-top: 10px !important;
    padding-bottom: 10px !important;
  }

  .login-wrapper > div {
    min-height: auto !important;
  }

  .login-wrapper ._auth_form_wrapper_p3cc9_46 {
    padding: 20px !important;
  }

  .login-wrapper .ant-btn {
    height: 46px !important;
    margin-top: 12px !important;
  }
}

/* ======================================================
   HIGH DPI / RETINA DISPLAYS
====================================================== */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
  .login-wrapper > div {
    border-width: 1px !important;
  }
}

/* ======================================================
   ACCESSIBILITY — REDUCED MOTION
====================================================== */
@media (prefers-reduced-motion: reduce) {
  .login-wrapper .ant-btn,
  .login-wrapper .ant-input-affix-wrapper,
  .login-wrapper input.ant-input,
  .login-wrapper a {
    transition: none !important;
  }

  .login-wrapper .ant-btn:hover {
    transform: none !important;
  }
}

/* ======================================================
   DARK MODE SUPPORT (если система в dark mode)
====================================================== */
@media (prefers-color-scheme: dark) {
  /* Стили уже оптимизированы для тёмной темы */
}

/* ======================================================
   PRINT STYLES (для печати, если понадобится)
====================================================== */
@media print {
  .login-wrapper {
    background: #fff !important;
    min-height: auto !important;
  }

  .login-wrapper > div {
    box-shadow: none !important;
    border: 1px solid #000 !important;
  }

  .login-wrapper > div::after {
    display: none !important;
  }
}

/* ======================================================
   SAFE AREA INSETS — для iPhone X+ и современных устройств
====================================================== */
@supports (padding: max(0px)) {
  .login-wrapper {
    padding-left: max(12px, env(safe-area-inset-left)) !important;
    padding-right: max(12px, env(safe-area-inset-right)) !important;
    padding-bottom: max(12px, env(safe-area-inset-bottom)) !important;
  }
}
