/**
 * Page connexion — layout plein écran responsive
 * Chargé après responsive-base/modules pour écraser les conflits tablette/mobile
 */

body.page-login {
  color-scheme: light;
  overflow-x: hidden;
}

body.page-login .sidebar,
body.page-login .sidebar-overlay,
body.page-login .top-header,
body.page-login .footer-hl,
body.page-login .mobile-menu-toggle {
  display: none !important;
}

body.page-login .app-container {
  width: 100%;
  max-width: 100vw;
}

body.page-login .main-content {
  margin: 0 !important;
  margin-left: 0 !important;
  width: 100% !important;
  max-width: 100vw !important;
  padding: 0 !important;
  min-height: 100dvh;
  min-height: -webkit-fill-available;
  background: transparent;
  color: #0f172a;
}

body.page-login .main-content[style*="margin-left"] {
  margin-left: 0 !important;
  width: 100% !important;
}

body.page-login .content-wrapper {
  max-width: 100% !important;
  margin: 0;
  padding: 0;
  min-height: 100dvh;
  min-height: -webkit-fill-available;
  display: flex;
  flex-direction: column;
  width: 100%;
}

body.page-login nav.app-breadcrumb {
  display: none;
}

.login-container {
  flex: 1;
  width: 100%;
  max-width: 100vw;
  min-height: 100dvh;
  min-height: -webkit-fill-available;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: max(1rem, env(safe-area-inset-top, 0px))
           max(1rem, env(safe-area-inset-right, 0px))
           max(1rem, env(safe-area-inset-bottom, 0px))
           max(1rem, env(safe-area-inset-left, 0px));
  box-sizing: border-box;
  background: #eef2f7;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.login-card {
  --lc-ink: #0f172a;
  --lc-heading: #0c4a6e;
  --lc-accent: #0e7490;
  --lc-muted: #475569;
  --lc-soft: #64748b;
  --lc-surface: #fafcfe;
  --lc-field: #f0f7fb;
  --lc-field-focus: #ffffff;
  --lc-line: #e2e8f0;
  --lc-line-input: #c5d4e0;
  --lc-btn-a: #0c4a6e;
  --lc-focus: rgba(12, 74, 110, 0.18);

  background: var(--lc-surface);
  color: var(--lc-ink);
  border: 1px solid #d0e0ed;
  border-radius: 20px;
  padding: 2rem;
  width: min(450px, 100%);
  max-width: 100%;
  margin: 0 auto;
  box-shadow:
    0 16px 48px rgba(12, 74, 110, 0.1),
    0 1px 0 rgba(255, 255, 255, 0.8) inset;
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
}

.login-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--lc-heading);
  border-radius: 20px 20px 0 0;
}

.login-header {
  text-align: center;
  margin-bottom: 1.5rem;
  flex-shrink: 0;
}

.login-logo {
  font-size: 3rem;
  margin-bottom: 0.5rem;
  color: var(--lc-accent);
}

.login-title {
  font-size: clamp(1.35rem, 4vw, 1.75rem);
  font-weight: 700;
  color: var(--lc-heading);
  margin: 0 0 0.25rem;
  line-height: 1.2;
  letter-spacing: -0.02em;
}

.login-subtitle {
  color: var(--lc-muted);
  font-size: clamp(0.8rem, 2.5vw, 0.9rem);
  font-weight: 500;
  margin: 0;
}

.login-container .form-group {
  margin-bottom: 1.25rem;
}

.login-container .form-label {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--lc-ink);
  font-weight: 600;
  margin-bottom: 0.5rem;
  font-size: 0.9rem;
}

.login-container .form-label i {
  color: var(--lc-accent);
  width: 1.1em;
  text-align: center;
}

.login-container .form-control {
  width: 100%;
  min-width: 0;
  padding: 0.875rem 1rem;
  background: var(--lc-field);
  border: 1px solid var(--lc-line-input);
  border-radius: 10px;
  color: var(--lc-ink);
  font-size: 1rem;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
  box-sizing: border-box;
}

.login-container .form-control:focus {
  outline: none;
  border-color: var(--lc-heading);
  background: var(--lc-field-focus);
  box-shadow: 0 0 0 3px var(--lc-focus);
}

.login-container .form-control::placeholder {
  color: var(--lc-soft);
  opacity: 1;
}

.login-container .form-check {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1.25rem;
}

.login-container .form-check-input {
  width: 20px;
  height: 20px;
  min-width: 20px;
  flex-shrink: 0;
  accent-color: var(--lc-heading);
}

.login-container .form-check-label {
  color: var(--lc-muted);
  font-size: 0.95rem;
}

.btn-login {
  width: 100%;
  min-height: 48px;
  padding: 0.875rem 1.5rem;
  background: var(--lc-btn-a);
  color: #ffffff;
  border: none;
  border-radius: 10px;
  font-weight: 700;
  font-size: 1rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  box-shadow: 0 4px 14px rgba(12, 74, 110, 0.35);
}

.btn-login:hover {
  filter: brightness(1.04);
}

.login-container .alert,
.login-container .login-flash {
  padding: 0.875rem 1rem;
  border-radius: 10px;
  margin-bottom: 1.25rem;
  border: 2px solid;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 0.9rem;
  font-weight: 600;
}

.login-container .alert-error,
.login-container .alert-danger {
  background: #fef2f2;
  border-color: #f87171;
  color: #991b1b;
}

.login-container .alert-success {
  background: #ecfdf5;
  border-color: #6ee7b7;
  color: #047857;
}

.login-footer {
  text-align: center;
  margin-top: 1.25rem;
  padding-top: 1rem;
  border-top: 1px solid var(--lc-line);
}

.login-footer p {
  color: var(--lc-soft);
  font-size: 0.85rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  margin: 0;
}

.login-forgot-wrap {
  text-align: center;
  margin-top: 1.25rem;
}

.login-forgot-link {
  color: var(--lc-heading);
  text-decoration: none;
  font-weight: 600;
  font-size: 0.9rem;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  min-height: 44px;
}

.login-forgot-link:hover {
  color: var(--lc-accent);
}

@media (max-width: 768px) {
  body.page-login .login-container {
    align-items: flex-start;
    padding-top: max(0.75rem, env(safe-area-inset-top, 0px));
  }

  body.page-login .login-card {
    padding: 1.5rem 1.25rem;
    border-radius: 16px;
    width: 100%;
  }

  body.page-login .login-container .form-control {
    font-size: 16px;
  }
}

@media (max-width: 480px) {
  body.page-login .login-card {
    padding: 1.25rem 1rem;
  }

  body.page-login .login-logo {
    font-size: 2.25rem;
  }
}

@media (max-height: 700px) and (orientation: landscape) {
  body.page-login .login-container {
    align-items: flex-start;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
  }

  body.page-login .login-header {
    margin-bottom: 0.75rem;
  }

  body.page-login .login-logo {
    font-size: 2rem;
    margin-bottom: 0.25rem;
  }

  body.page-login .login-container .form-group {
    margin-bottom: 0.75rem;
  }

  body.page-login .login-footer {
    margin-top: 0.75rem;
    padding-top: 0.5rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  body.page-login *,
  body.page-login *::before,
  body.page-login *::after {
    animation: none !important;
    transition: none !important;
  }
}
