/* ============================================================
   INNOVAI CONSULTING — Listmonk PUBLIC Pages Theme
   Cible: page login + pages publiques (subscription, archive)
   Structure reelle: body > div.container.wrap > section.login
   ============================================================ */

@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap");

:root {
  --innovai-dark: #003078;
  --innovai-primary: #1A5CA0;
  --innovai-accent: #1CA0E0;
  --innovai-accent-light: #E8F4FD;
  --innovai-accent-glow: rgba(28, 160, 224, 0.15);
  --innovai-text: #1E293B;
  --innovai-text-light: #64748B;
  --innovai-border: #E2E8F0;
  --innovai-radius: 12px;
  --innovai-radius-sm: 8px;
  --innovai-transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ============================================================
   LOGIN PAGE — Full-screen gradient with centered card
   body:has(section.login) cible uniquement la page login
   ============================================================ */

body:has(section.login) {
  background: linear-gradient(135deg, #001F4D 0%, #003078 40%, #1A5CA0 70%, #1CA0E0 100%) !important;
  min-height: 100vh !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  margin: 0 !important;
  padding: 0 !important;
}

body:has(section.login)::before {
  content: "" !important;
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  background-image:
    radial-gradient(circle at 20% 80%, rgba(28, 160, 224, 0.15) 0%, transparent 50%),
    radial-gradient(circle at 80% 20%, rgba(28, 160, 224, 0.1) 0%, transparent 50%),
    radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.03) 0%, transparent 70%) !important;
  pointer-events: none !important;
  z-index: 0 !important;
  animation: loginPulse 8s ease-in-out infinite alternate !important;
}

@keyframes loginPulse {
  0% { opacity: 0.6; transform: scale(1); }
  100% { opacity: 1; transform: scale(1.05); }
}

/* Carte blanche centree */
body:has(section.login) .container.wrap {
  background: rgba(255, 255, 255, 0.97) !important;
  backdrop-filter: blur(20px) !important;
  border-radius: 20px !important;
  border: 1px solid rgba(255, 255, 255, 0.3) !important;
  box-shadow:
    0 20px 60px rgba(0, 31, 77, 0.3),
    0 0 0 1px rgba(255, 255, 255, 0.1) !important;
  padding: 2.5rem !important;
  max-width: 420px !important;
  width: 100% !important;
  margin: 0 auto !important;
  position: relative !important;
  z-index: 1 !important;
  animation: loginSlideUp 0.6s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

@keyframes loginSlideUp {
  0% { opacity: 0; transform: translateY(30px); }
  100% { opacity: 1; transform: translateY(0); }
}

/* Cacher le logo Listmonk par defaut */
body:has(section.login) header.header {
  border-bottom: none !important;
  padding-bottom: 0 !important;
  margin-bottom: 0.5rem !important;
  text-align: center !important;
}

body:has(section.login) header.header .logo img {
  display: none !important;
}

/* Titre h2 "Connecter" */
body:has(section.login) section.login h2 {
  color: var(--innovai-dark) !important;
  font-family: "Inter", sans-serif !important;
  font-size: 1.4rem !important;
  font-weight: 700 !important;
  text-align: center !important;
  margin-bottom: 1.5rem !important;
  padding-bottom: 1rem !important;
  border-bottom: 2px solid var(--innovai-accent) !important;
}

/* Labels */
body:has(section.login) section.login label {
  color: var(--innovai-text) !important;
  font-family: "Inter", sans-serif !important;
  font-weight: 600 !important;
  font-size: 0.85rem !important;
  display: block !important;
  margin-bottom: 0.4rem !important;
}

/* Champs input */
body:has(section.login) section.login input[type="text"],
body:has(section.login) section.login input[type="password"] {
  border: 2px solid var(--innovai-border) !important;
  border-radius: var(--innovai-radius-sm) !important;
  padding: 0.75rem 1rem !important;
  font-size: 0.95rem !important;
  font-family: "Inter", sans-serif !important;
  transition: var(--innovai-transition) !important;
  background: #FAFBFC !important;
  width: 100% !important;
  box-shadow: none !important;
  box-sizing: border-box !important;
}

body:has(section.login) section.login input[type="text"]:focus,
body:has(section.login) section.login input[type="password"]:focus {
  border-color: var(--innovai-accent) !important;
  box-shadow: 0 0 0 3px var(--innovai-accent-glow) !important;
  background: #FFF !important;
  outline: none !important;
}

/* Espacement champs */
body:has(section.login) section.login form p {
  margin-bottom: 1rem !important;
}

/* Bouton Connecter */
body:has(section.login) section.login .submit {
  margin-top: 1.5rem !important;
}

body:has(section.login) section.login .button {
  background: linear-gradient(135deg, var(--innovai-primary) 0%, var(--innovai-accent) 100%) !important;
  border: none !important;
  border-radius: var(--innovai-radius-sm) !important;
  padding: 0.75rem 2rem !important;
  font-weight: 600 !important;
  font-size: 1rem !important;
  font-family: "Inter", sans-serif !important;
  letter-spacing: 0.3px !important;
  color: white !important;
  cursor: pointer !important;
  transition: var(--innovai-transition) !important;
  box-shadow: 0 4px 14px rgba(28, 160, 224, 0.25) !important;
  width: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

body:has(section.login) section.login .button:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(28, 160, 224, 0.35) !important;
  filter: brightness(1.05) !important;
}

body:has(section.login) section.login .button:active {
  transform: translateY(0) !important;
}

/* Lien mot de passe oublie */
body:has(section.login) section.login p.center {
  text-align: center !important;
  margin-top: 1.2rem !important;
}

body:has(section.login) section.login p.center a {
  color: var(--innovai-text-light) !important;
  font-size: 0.8rem !important;
  text-decoration: none !important;
  font-family: "Inter", sans-serif !important;
  transition: var(--innovai-transition) !important;
}

body:has(section.login) section.login p.center a:hover {
  color: var(--innovai-accent) !important;
}

/* Footer login */
body:has(section.login) footer.container {
  background: transparent !important;
  color: rgba(255, 255, 255, 0.5) !important;
  border: none !important;
  box-shadow: none !important;
  padding: 1rem !important;
  margin-top: 1rem !important;
  position: relative !important;
  z-index: 1 !important;
}

body:has(section.login) footer.container a {
  color: rgba(255, 255, 255, 0.7) !important;
}

/* ============================================================
   PAGES PUBLIQUES (subscription, archive)
   ============================================================ */
body:not(:has(section.login)) {
  background-color: #F0F5FA !important;
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
}

body:not(:has(section.login)) .container.wrap {
  border-radius: var(--innovai-radius) !important;
  border: 1px solid var(--innovai-border) !important;
  box-shadow: 0 1px 3px rgba(0, 48, 120, 0.08), 0 4px 12px rgba(0, 48, 120, 0.04) !important;
}

body:not(:has(section.login)) .button {
  background: linear-gradient(135deg, var(--innovai-primary) 0%, var(--innovai-accent) 100%) !important;
  border: none !important;
  border-radius: var(--innovai-radius-sm) !important;
  color: white !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: var(--innovai-transition) !important;
}

body:not(:has(section.login)) .button:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 14px rgba(28, 160, 224, 0.25) !important;
}
