/* ========================================================================
   WebApp Hub - feuille de style SPECIFIQUE AU HUB
   ========================================================================
   Charge APRES ds-vars.css et ds.css (cf. base.html / login.html).
   Ne contient ICI que ce qui est specifique au Hub :
     - Hero de la page d'accueil
     - Cards d'apps (hub-card)
     - Grille de cards (hub-grid)
     - Empty state
     - Page login (layout autonome)
   Tout le reste (boutons, inputs, badges, topbar, flash, footer) vient
   du Design System dans ds.css.
   ======================================================================== */


/* ============================================================
   HERO de la page d'accueil
   ============================================================ */
.hub-hero {
  text-align: center;
  margin-bottom: var(--space-7);
  padding: var(--space-5) 0 var(--space-6);
}
.hub-hero__title {
  font-size: var(--text-4xl);
  font-weight: var(--weight-semibold);
  letter-spacing: -0.02em;
  margin: 0;
}
.hub-hero__title .accent { color: var(--accent); }
.hub-hero__subtitle {
  margin-top: var(--space-3);
  font-size: var(--text-md);
  color: var(--text-muted);
  max-width: 540px;
  margin-left: auto;
  margin-right: auto;
}

@media (max-width: 540px) {
  .hub-hero { padding: var(--space-3) 0 var(--space-5); margin-bottom: var(--space-5); }
  .hub-hero__title { font-size: var(--text-2xl); }
}


/* ============================================================
   GRILLE DE CARDS (apps)
   ============================================================ */
.hub-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-5);
}

.hub-card {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  min-height: 180px;
}
.hub-card:hover { text-decoration: none; }

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

.hub-card__title {
  font-size: var(--text-lg);
  font-weight: var(--weight-semibold);
  color: var(--text);
  margin: 0;
}

.hub-card__desc {
  margin-top: var(--space-2);
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.6;
  flex: 1;
}

.hub-card__foot {
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: var(--text-xs);
  color: var(--text-faint);
  transition: var(--transition-fast);
}
.hub-card:hover .hub-card__foot {
  color: var(--text-muted);
}

@media (max-width: 540px) {
  .hub-grid { grid-template-columns: 1fr; gap: var(--space-4); }
  .hub-card { min-height: auto; }
}


/* ============================================================
   EMPTY STATE (aucune app active)
   ============================================================ */
.empty-state {
  grid-column: 1 / -1;
  padding: var(--space-6);
  text-align: center;
  color: var(--text-muted);
  background: var(--bg-elevated);
  border: 1px dashed var(--border);
  border-radius: var(--radius-lg);
}


/* ============================================================
   PAGE LOGIN (layout autonome - login.html n'etend pas base.html)
   ============================================================ */
.login-body {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-5);
  background:
    radial-gradient(circle at 20% 20%, rgba(22,163,74,0.08), transparent 50%),
    radial-gradient(circle at 80% 80%, rgba(59,130,246,0.06), transparent 50%),
    var(--bg);
}

.login-wrap {
  width: 100%;
  max-width: 400px;
}

.login-card {
  /* On herite de .card .card-spacious du DS, on ajoute juste l'ombre. */
  box-shadow: var(--shadow-lg);
}

.login-brand {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-5);
}

.login-title {
  font-size: var(--text-2xl);
  font-weight: var(--weight-semibold);
  letter-spacing: -0.02em;
  margin: 0;
  text-align: center;
}

.login-hint-intro {
  margin: var(--space-2) 0 var(--space-5);
  font-size: var(--text-sm);
  color: var(--text-muted);
  text-align: center;
}

.login-hint {
  margin: var(--space-2) 0 0;
  font-size: var(--text-sm);
  color: var(--text-muted);
  text-align: center;
}
.login-hint strong { color: var(--text); }

.login-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.login-form .checkbox-row {
  margin: var(--space-1) 0;
}

.login-footer {
  margin-top: var(--space-5);
  font-size: var(--text-xs);
  color: var(--text-faint);
  text-align: center;
}

@media (max-width: 540px) {
  .login-body { padding: var(--space-4); }
}
