/* ========================================
   pages-auth.css — Authentification,
   connexion, inscription, espace client
   ======================================== */

/* ===== Authentification ===== */
.auth-container { max-width: 480px; margin: 0 auto; background: var(--color-white); border-radius: 8px; padding: 2rem; box-shadow: var(--shadow-sm); }
.auth-tabs { display: flex; margin-bottom: 2rem; border-bottom: 2px solid var(--color-bg-alt); }
.auth-tab {
  flex: 1; padding: 0.75rem; text-align: center; background: none; border: none;
  font-size: 1rem; font-weight: 600; cursor: pointer; color: var(--color-text-light);
  border-bottom: 3px solid transparent; margin-bottom: -2px; transition: all var(--transition-fast);
}
.auth-tab.active { color: var(--color-accent); border-bottom-color: var(--color-accent); }
.auth-tab:hover { color: var(--color-accent); }
.auth-info { text-align: center; margin-top: 2rem; padding-top: 1.5rem; border-top: 1px solid var(--color-bg-alt); }
.auth-info p { font-size: 0.9rem; color: var(--color-text-light); }

/* ===== Artisan Login Screen ===== */
.artisan-login-screen {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
}
.artisan-login-box {
  background: var(--color-white); border-radius: 12px; padding: 2.5rem; width: 100%; max-width: 400px;
  box-shadow: var(--shadow-lg); text-align: center;
}
.artisan-login-logo { display: flex; align-items: center; justify-content: center; gap: 0.75rem; margin-bottom: 2rem; font-size: 1.15rem; color: var(--color-primary-dark); }
.artisan-login-error { color: var(--color-error); font-size: 0.9rem; margin-top: 0.75rem; min-height: 1.2em; }
.artisan-login-back { display: inline-block; margin-top: 1.5rem; font-size: 0.85rem; color: var(--color-text-light); }
.artisan-login-back:hover { color: var(--color-accent); }

/* ===== Espace Client (Dashboard client) ===== */
.dashboard { display: grid; grid-template-columns: 1fr; gap: 2rem; }
.dashboard-sidebar {
  background: var(--color-primary-dark); border-radius: 8px; padding: 2rem; color: var(--color-white);
}
.dashboard-profile { text-align: center; margin-bottom: 1.5rem; padding-bottom: 1.5rem; border-bottom: 1px solid rgba(255, 255, 255, 0.15); }
.dashboard-avatar {
  width: 64px; height: 64px; border-radius: 50%; background: var(--color-accent);
  color: var(--color-white); display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem; font-weight: 800; margin: 0 auto 0.75rem;
}
.dashboard-profile h2 { color: var(--color-white); font-size: 1.2rem; margin-bottom: 0.25rem; }
.dashboard-profile p { color: rgba(255, 255, 255, 0.7); font-size: 0.85rem; margin-bottom: 0; }
.dashboard-nav { display: flex; flex-direction: column; gap: 0.4rem; }
.dashboard-nav-btn {
  display: block; width: 100%; padding: 0.7rem 1rem; text-align: left; background: none;
  border: none; color: rgba(255, 255, 255, 0.8); font-size: 0.95rem; cursor: pointer;
  border-radius: 4px; transition: all var(--transition-fast);
}
.dashboard-nav-btn:hover { background: rgba(255, 255, 255, 0.1); color: var(--color-white); }
.dashboard-nav-btn.active { background: rgba(255, 255, 255, 0.15); color: var(--color-white); font-weight: 600; }
.dashboard-nav-btn--logout { color: rgba(255, 255, 255, 0.5); margin-top: 0.5rem; border-top: 1px solid rgba(255, 255, 255, 0.1); padding-top: 1rem; }
.dashboard-nav-btn--logout:hover { color: var(--color-error); }

.dashboard-main { min-height: 300px; }
.dashboard-panel h2 { margin-bottom: 1.5rem; }
.dashboard-empty { text-align: center; padding: 3rem 1rem; color: var(--color-text-light); }
.dashboard-empty p { margin: 1rem 0; }

.devis-card {
  background: var(--color-white); border: 1px solid var(--color-border); border-radius: 8px;
  padding: 1.25rem; margin-bottom: 1rem; transition: box-shadow var(--transition-fast);
}
.devis-card:hover { box-shadow: var(--shadow-sm); }
.devis-card-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 0.5rem; }
.devis-card-type { font-weight: 600; color: var(--color-primary-dark); }
.devis-card-desc { color: var(--color-text-light); font-size: 0.9rem; margin-bottom: 0.5rem; }
.devis-card-meta { display: flex; gap: 1rem; font-size: 0.8rem; color: var(--color-text-light); }
