/*
 * design-system.css — Refonte visuelle ImpotLab
 * Override des variables neutres UNIQUEMENT.
 * Ne jamais modifier les couleurs fiscales (vert, rouge, or).
 * Chargé après common.css pour prendre le dessus sur les valeurs structurelles.
 */

/* ============================================================
   1. VARIABLES NEUTRES — mode clair
   ============================================================ */
:root {
  --color-bg:                 #F8FAFC;
  --color-bg-alt:             #FFFFFF;
  --color-surface:            #FFFFFF;
  --color-surface-alt:        #F1F5F9;

  --color-border:             rgba(10, 22, 40, 0.1);
  --color-border-light:       rgba(10, 22, 40, 0.06);

  --color-text:               #0A1628;
  --color-text-muted:         #475569;
  --color-label:              #334155;
  --color-hint:               #64748B;

  --color-accent:             #3B82F6;
  --color-accent-dark:        #2563EB;
  --color-accent-soft:        rgba(59, 130, 246, 0.1);

  --color-nav-next-bg:        #3B82F6;
  --color-nav-next-border:    #2563EB;
  --color-nav-next-hover-bg:  #2563EB;
  --color-nav-prev-bg:        transparent;
  --color-nav-prev-border:    rgba(10, 22, 40, 0.15);

  --color-input-bg:           #FFFFFF;
  --color-input-border:       rgba(10, 22, 40, 0.12);
  --color-input-focus-border: #3B82F6;
}

/* ============================================================
   2. VARIABLES NEUTRES — mode sombre (noir profond)
   ============================================================ */
body.dark-mode {
  --color-bg:                 #0A0A0A;
  --color-bg-alt:             #141414;
  --color-surface:            #141414;
  --color-surface-alt:        #1A1A1A;

  --color-border:             rgba(255, 255, 255, 0.08);
  --color-border-light:       rgba(255, 255, 255, 0.05);

  --color-text:               #FFFFFF;
  --color-text-muted:         #94A3B8;
  --color-label:              #CBD5E1;
  --color-hint:               #64748B;

  --color-accent:             #60A5FA;
  --color-accent-dark:        #3B82F6;
  --color-accent-soft:        rgba(96, 165, 250, 0.15);

  --color-nav-next-bg:        #60A5FA;
  --color-nav-next-border:    #3B82F6;
  --color-nav-next-hover-bg:  #3B82F6;
  --color-nav-prev-bg:        rgba(255, 255, 255, 0.06);
  --color-nav-prev-border:    rgba(255, 255, 255, 0.12);

  --color-input-bg:           #1A1A1A;
  --color-input-border:       rgba(255, 255, 255, 0.1);
  --color-input-focus-border: #60A5FA;
}

/* ============================================================
   3. BOUTON PRÉCÉDENT — lisible en mode sombre
   Les classes Tailwind bg-slate-200 / text-blue-700 sont écrasées
   par common.css avec !important → on contre avec !important aussi,
   en ciblant .nav-prev directement (même spécificité, chargé après).
   ============================================================ */
body.dark-mode .nav-prev {
  background-color: rgba(255, 255, 255, 0.08) !important;
  color: #FFFFFF !important;
}

/* ============================================================
   4. ANIMATION D'APPARITION — uniformisée et renforcée sur toutes les étapes
   ============================================================ */
body.page-ready main {
  animation-delay: 200ms !important;
  animation-duration: 0.55s !important;
}

main {
  transform: translateY(20px);
}

@keyframes uiFadeUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   5. BARRE DE PROGRESSION — bleu → vert selon l'avancement
   --progress-pct est une propriété CSS animatable (0 = départ, 1 = fin).
   Elle doit être positionnée via JS : bar.style.setProperty('--progress-pct', ratio)
   Voir proposition de modification de progress.js ci-dessous.
   ============================================================ */
@property --progress-pct {
  syntax: '<number>';
  initial-value: 0;
  inherits: false;
}

.progress-bar {
  background: color-mix(
    in srgb,
    var(--color-accent) calc((1 - var(--progress-pct)) * 100%),
    #4ade80
  );
  transition: width 0.52s cubic-bezier(0.4, 0, 0.2, 1),
              --progress-pct 0.52s ease;
}

/* ============================================================
   6. BANNIÈRE DE NAVIGATION — espace vertical et horizontal
   ============================================================ */
.nav-steps-footer-inner {
  padding: 12px 20px;   /* avant : 0 14px — ajout espace vertical */
}

/* Centrage Sauvegarder + largeur fixe bouton + suppression feedback parasite */
.nav-steps-links {
  display: grid !important;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 6px 0;
}

.nav-manual-save {
  margin-left: 0 !important;
}

.nav-next {
  justify-self: end;
  margin-left: 0 !important;
}

.nav-manual-save-btn {
  width: 210px;
  min-width: unset;
  white-space: nowrap;
  overflow: hidden;
}

.nav-manual-save-feedback {
  display: none !important;
}

/* ============================================================
   7. BANNIÈRE DE NAVIGATION — décollée du bord inférieur
   ============================================================ */
.nav-steps-footer {
  bottom: 24px;
}

body {
  padding-bottom: calc(var(--nav-footer-height) + 24px);
}

/* ============================================================
   9. BANNIERES CODE — animation slide-down au chargement
   ============================================================ */
@keyframes codeBannerSlideDown {
  from { opacity: 0; transform: translateY(-10px); }
  to   { opacity: 1; transform: translateY(0); }
}

body.page-ready .code-badge-banner,
body.page-ready .fortune-code-banner,
body.page-ready .debt-code-banner,
body.page-ready .deduction-code-banner {
  animation: codeBannerSlideDown 0.45s ease-out both;
  animation-delay: 380ms;
}

/* ============================================================
   8. LOGO IMPOTLAB — agrandi et stylisé
   ============================================================ */
.impotlab-floating-logo {
  color: var(--color-chip-text);   /* bleu marine #1e3a8a — cohérent avec les pastilles */
}

.impotlab-floating-logo-mark {
  width: clamp(160px, 16vw, 250px);   /* avant : clamp(90px, 9vw, 150px) */
  height: clamp(37px, 3.7vw, 57px);  /* avant : clamp(22px, 2.2vw, 34px) */
}

.impotlab-floating-logo-mark .titre {
  font-family: 'Plus Jakarta Sans', 'Manrope', sans-serif;
  letter-spacing: 2px;
}

/* ============================================================
   10. ANIMATION DES CARDS — universelle, toutes les étapes
   Remplace le sélecteur conditionnel :has(.code-chip) de common.css.
   Ne touche que l'élément .card lui-même, pas .card-head / .card-body.
   ============================================================ */
main .card,
main .code-badge-banner,
main .fortune-code-banner,
main .deduction-code-banner,
main .debt-code-banner {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 260ms ease, transform 320ms ease;
}

body.page-ready main .card,
body.page-ready main .code-badge-banner,
body.page-ready main .fortune-code-banner,
body.page-ready main .deduction-code-banner,
body.page-ready main .debt-code-banner {
  opacity: 1;
  transform: none;
}

body.page-ready main .card:nth-of-type(1) { transition-delay: 260ms; }
body.page-ready main .card:nth-of-type(2) { transition-delay: 320ms; }
body.page-ready main .card:nth-of-type(3) { transition-delay: 380ms; }
body.page-ready main .card:nth-of-type(4) { transition-delay: 420ms; }
body.page-ready main .card:nth-of-type(5) { transition-delay: 460ms; }
body.page-ready main .card:nth-of-type(6) { transition-delay: 500ms; }

/* ============================================================
   11. VALIDATION ETAPE 1 — bannière et champs invalides
   ============================================================ */
.validation-error-banner {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 9999;
  background: #EF4444;
  color: #FFFFFF;
  text-align: center;
  padding: 14px 20px;
  font-weight: 600;
  font-size: 0.95rem;
  animation: slideDownBanner 0.3s ease-out both;
}

@keyframes slideDownBanner {
  from { transform: translateY(-100%); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}

.field-invalid {
  border-color: #EF4444 !important;
  outline: 2px solid rgba(239, 68, 68, 0.25) !important;
  outline-offset: 1px !important;
}

/* ============================================================
   12. MODAL DE CONFIRMATION — étape 1
   ============================================================ */
.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(10, 22, 40, 0.5);
  padding: 20px;
  opacity: 0;
  transition: opacity 0.22s ease;
}
.modal-overlay[hidden] { display: none !important; }
.modal-overlay.is-visible { opacity: 1; }

.modal-card {
  background: #FFFFFF;
  border-radius: 14px;
  padding: 32px;
  max-width: 440px;
  width: 100%;
  opacity: 0;
  transform: translateY(20px);
  transition: transform 0.28s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.22s ease;
}
.modal-overlay.is-visible .modal-card {
  opacity: 1;
  transform: translateY(0);
}

.modal-title {
  font-size: 1.05rem;
  font-weight: 500;
  color: #0A1628;
  margin: 0 0 10px;
  line-height: 1.4;
}
.modal-subtitle {
  font-size: 0.875rem;
  font-weight: 400;
  color: #475569;
  margin: 0 0 28px;
  line-height: 1.5;
}
.modal-actions {
  display: flex;
  gap: 12px;
  justify-content: flex-end;
}
.modal-btn-primary,
.modal-btn-secondary {
  padding: 10px 20px;
  border-radius: 8px;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s ease, opacity 0.15s ease;
}
.modal-btn-primary {
  background: #3B82F6;
  color: #FFFFFF;
  border: none;
}
.modal-btn-primary:hover  { background: #2563EB; }
.modal-btn-secondary {
  background: transparent;
  color: #475569;
  border: 0.5px solid #475569;
}
.modal-btn-secondary:hover { background: rgba(10, 22, 40, 0.05); }

body.dark-mode .modal-overlay          { background: rgba(0, 0, 0, 0.7); }
body.dark-mode .modal-card             { background: #141414; }
body.dark-mode .modal-title            { color: #FFFFFF; }
body.dark-mode .modal-subtitle         { color: #94A3B8; }
body.dark-mode .modal-btn-primary      { background: #60A5FA; color: #0A0A0A; }
body.dark-mode .modal-btn-primary:hover  { background: #3B82F6; }
body.dark-mode .modal-btn-secondary    { color: rgba(255,255,255,0.8); border-color: rgba(255,255,255,0.15); }
body.dark-mode .modal-btn-secondary:hover { background: rgba(255,255,255,0.06); }

.modal-icon-warning {
  display: flex;
  justify-content: center;
  margin-bottom: 16px;
}

.modal-input {
  width: 100%;
  padding: 10px 14px;
  border: 1px solid rgba(10, 22, 40, 0.15);
  border-radius: 8px;
  font-size: 0.9rem;
  color: var(--color-text);
  background: var(--color-input-bg);
  margin-bottom: 20px;
  outline: none;
  transition: border-color 0.15s ease;
  box-sizing: border-box;
}
.modal-input:focus { border-color: var(--color-accent); }
body.dark-mode .modal-input {
  background: #1A1A1A;
  border-color: rgba(255,255,255,0.1);
  color: #FFFFFF;
}

/* Fix : carte résultats estimés invisible en mode sombre (bg-blue-100 quasi identique au fond) */
body.dark-mode .bg-blue-100 {
  background-color: rgba(96, 165, 250, 0.07) !important;
  border: 1px solid rgba(96, 165, 250, 0.35) !important;
}
body.dark-mode .bg-blue-100 .text-blue-900,
body.dark-mode .bg-blue-100 .text-blue-700 {
  color: rgba(255, 255, 255, 0.92) !important;
}

/* ============================================================
   13. SPINNER BOUTON SAUVEGARDER
   ============================================================ */
@keyframes btnSpinnerRotate {
  to { transform: rotate(360deg); }
}

.nav-manual-save-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.nav-manual-save-btn[data-state="loading"]::before {
  content: '';
  display: inline-block;
  width: 14px;
  height: 14px;
  border: 2px solid currentColor;
  border-top-color: transparent;
  border-radius: 50%;
  animation: btnSpinnerRotate 0.7s linear infinite;
  flex-shrink: 0;
}

/* ============================================================
   14. RESPONSIVE MOBILE — barre de navigation (< 600px)
   Le grid 3 colonnes de desktop est remplacé par un flex wrap :
   Ligne 1 : [Précédent | Thème]  ──────  [Suivant]
   Ligne 2 : [Sauvegarder ─────────────────────────]
   ============================================================ */
@media (max-width: 600px) {
  .nav-steps-links {
    display: flex !important;
    flex-wrap: wrap;
    gap: 8px;
  }
  .nav-steps-left       { flex: 1; }
  .nav-next             { flex-shrink: 0; margin-left: 0 !important; }
  .nav-manual-save      { order: 3; width: 100%; }
  .nav-manual-save-btn  { width: 100% !important; }

  /* Zones tactiles 44px minimum */
  .nav-prev,
  .nav-next,
  .nav-manual-save-btn  { min-height: 44px; }

  /* Boutons thème 44px minimum */
  [data-theme-switch] button[data-theme] {
    min-width: 44px;
    min-height: 44px;
  }
}
