/**
 * Styles pour le composant PreviewDisplay
 * Architecture responsive : sticky desktop → floating tablette → bottom sheet mobile
 */

/* ============================================================================
   VARIABLES CSS
   ============================================================================ */

:root {
  /* Dimensions desktop (sticky) */
  --preview-sticky-top: 20px;
  --preview-max-height-desktop: calc(100vh - 100px);

  /* Dimensions tablette (floating panel) */
  --preview-floating-bottom: 20px;
  --preview-floating-right: 20px;
  --preview-floating-width: 350px;
  --preview-floating-max-height: 70vh;

  /* Dimensions mobile (bottom sheet) */
  --preview-bottomsheet-max-height: 60vh;

  /* Bouton toggle */
  --preview-toggle-size: 32px;
  --preview-toggle-font-size: 1.2em;
  --preview-toggle-border-radius: 50%;

  /* État collapsed */
  --preview-collapsed-height: 48px;
  --preview-collapsed-width: 48px;

  /* Animations */
  --preview-transition-duration: 0.3s;
  --preview-transition-timing: cubic-bezier(0.4, 0, 0.2, 1);
  --preview-transition-delay: 0.15s; /* Délai entre expansion horizontale et verticale */

  /* Z-index */
  --preview-z-index: 100;

  /* Espacement */
  --preview-padding: 20px;
  --preview-gap: 12px;

  /* Ombres */
  --preview-shadow-desktop: 0 2px 8px rgba(0, 0, 0, 0.1);
  --preview-shadow-floating: 0 8px 32px rgba(0, 0, 0, 0.2);
  --preview-shadow-bottomsheet: 0 -4px 16px rgba(0, 0, 0, 0.15);
}

/* ============================================================================
   STYLES DE BASE (réutilisés de styles.css existant)
   ============================================================================ */

.calculation-preview {
  position: relative; /* Nécessaire pour position: absolute du bouton toggle */
  background: linear-gradient(135deg, #e8f5e9 0%, #c8e6c9 100%);
  padding: var(--preview-padding);
  border-radius: 10px;
  border-left: 5px solid #43a047;
  max-height: 2000px; /* Valeur très grande pour permettre la transition */

  /* Transition pour l'ouverture : border-radius d'abord (0ms), puis width + left (150ms), puis max-height (300ms) */
  transition:
    max-height var(--preview-transition-duration) var(--preview-transition-timing) calc(var(--preview-transition-delay) * 2),
    height var(--preview-transition-duration) var(--preview-transition-timing) calc(var(--preview-transition-delay) * 2),
    width var(--preview-transition-duration) var(--preview-transition-timing) var(--preview-transition-delay),
    left var(--preview-transition-duration) var(--preview-transition-timing) var(--preview-transition-delay),
    border-radius var(--preview-transition-duration) var(--preview-transition-timing) 0ms,
    border var(--preview-transition-duration) var(--preview-transition-timing) 0ms,
    background var(--preview-transition-duration) var(--preview-transition-timing) 0ms,
    padding var(--preview-transition-duration) var(--preview-transition-timing) 0ms,
    opacity var(--preview-transition-duration) var(--preview-transition-timing) 0ms;

  box-shadow: var(--preview-shadow-desktop);
}

.calculation-preview.invalid {
  background: linear-gradient(135deg, #ffebee 0%, #ffcdd2 100%);
  border-left-color: #d32f2f;
}

/* ============================================================================
   BOUTON TOGGLE (nouveau)
   ============================================================================ */

.preview-toggle {
  position: absolute;
  top: calc(var(--preview-padding) / 2);
  right: calc(var(--preview-padding) / 2);
  width: var(--preview-toggle-size);
  height: var(--preview-toggle-size);
  border-radius: var(--preview-toggle-border-radius);
  border: 2px solid #43a047;
  background: white;
  color: #43a047;
  font-size: var(--preview-toggle-font-size);
  font-weight: bold;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  /* Animer le déplacement du bouton (transform retiré pour éviter conflit avec hover scale) */
  transition: top var(--preview-transition-duration) var(--preview-transition-timing),
              left var(--preview-transition-duration) var(--preview-transition-timing),
              right var(--preview-transition-duration) var(--preview-transition-timing),
              background 0.2s ease,
              color 0.2s ease;
  z-index: 10; /* Au-dessus du contenu */
  padding: 0;
  line-height: 1;
}

.preview-toggle:hover {
  background: #43a047;
  color: white;
  transform: scale(1.1);
}

.preview-toggle:focus {
  outline: 2px solid #43a047;
  outline-offset: 2px;
}

.calculation-preview.invalid .preview-toggle {
  border-color: #d32f2f;
  color: #d32f2f;
}

.calculation-preview.invalid .preview-toggle:hover {
  background: #d32f2f;
  color: white;
}

/* ============================================================================
   ZONE DE CONTENU
   ============================================================================ */

.preview-content {
  margin-top: var(--preview-gap);
  max-height: 2000px; /* Valeur très grande pour permettre la transition */
  transition: opacity var(--preview-transition-duration) var(--preview-transition-timing),
              max-height var(--preview-transition-duration) var(--preview-transition-timing);
}

/* ============================================================================
   ÉTAT COLLAPSED
   ============================================================================ */

.calculation-preview.collapsed {
  max-height: var(--preview-collapsed-height);
  overflow: hidden;
  padding-bottom: calc(var(--preview-padding) / 2);

  /* Transition avec delays séquentiels pour la fermeture */
  /* max-height + height d'abord (0ms), puis width + left (150ms), puis border-radius (300ms) */
  transition:
    max-height var(--preview-transition-duration) var(--preview-transition-timing) 0ms,
    height var(--preview-transition-duration) var(--preview-transition-timing) 0ms,
    width var(--preview-transition-duration) var(--preview-transition-timing) var(--preview-transition-delay),
    left var(--preview-transition-duration) var(--preview-transition-timing) var(--preview-transition-delay),
    border-radius var(--preview-transition-duration) var(--preview-transition-timing) calc(var(--preview-transition-delay) * 2),
    border var(--preview-transition-duration) var(--preview-transition-timing) calc(var(--preview-transition-delay) * 2),
    background var(--preview-transition-duration) var(--preview-transition-timing) calc(var(--preview-transition-delay) * 2),
    padding var(--preview-transition-duration) var(--preview-transition-timing) 0ms,
    opacity var(--preview-transition-duration) var(--preview-transition-timing) 0ms;
}

.calculation-preview.collapsed .preview-content {
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  pointer-events: none;
}

.calculation-preview.collapsed .preview-toggle {
  /* Le bouton reste à sa position normale (haut droite) */
}

/* ============================================================================
   RESPONSIVE - DESKTOP (> 1200px)
   ============================================================================ */

@media (min-width: 1201px) {
  .calculation-preview {
    position: sticky;
    top: var(--preview-sticky-top);
    left: calc(100vw - 400px - var(--preview-sticky-top)); /* Ancré à droite - expansion vers gauche */
    max-height: var(--preview-max-height-desktop);
    width: 400px; /* Largeur fixe pour permettre l'animation vers le carré */
    overflow-y: auto;
  }

  .calculation-preview.collapsed {
    position: sticky;
    left: calc(100vw - var(--preview-collapsed-width) - var(--preview-sticky-top)); /* Reste ancré à droite */
    width: var(--preview-collapsed-width); /* Réduit à 48px pour former un carré */
    min-height: var(--preview-collapsed-height); /* Empêche le contenu de forcer une autre hauteur */
    padding: 0; /* Retire le padding pour avoir exactement 48x48 */
    border-radius: 50%; /* Devient un cercle */
    border: none; /* Retire toutes les bordures pour le cercle */
    background: radial-gradient(circle, #e8f5e9 0%, #c8e6c9 100%); /* Gradient radial centré pour le cercle */
    box-sizing: border-box; /* Inclut border dans les dimensions */
  }

  /* Centrer le bouton dans le cercle collapsed (48px container, 32px bouton = 8px de marge) */
  .calculation-preview.collapsed .preview-toggle {
    top: 8px;
    right: 8px;
  }
}

/* ============================================================================
   RESPONSIVE - TABLETTE (769px à 1200px) - Floating Panel
   ============================================================================ */

@media (max-width: 1200px) and (min-width: 769px) {
  .calculation-preview {
    position: fixed;
    bottom: var(--preview-floating-bottom);
    right: var(--preview-floating-right);
    width: var(--preview-floating-width);
    max-height: var(--preview-floating-max-height);
    overflow-y: auto;
    z-index: var(--preview-z-index);
    box-shadow: var(--preview-shadow-floating);
    border-radius: 12px;
  }

  .calculation-preview.collapsed {
    /* max-height héritée de la règle générale */
  }
}

/* ============================================================================
   RESPONSIVE - MOBILE (≤ 768px) - Bottom Sheet
   ============================================================================ */

@media (max-width: 768px) {
  .calculation-preview {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    max-height: var(--preview-bottomsheet-max-height);
    overflow-y: auto;
    z-index: var(--preview-z-index);
    box-shadow: var(--preview-shadow-bottomsheet);
    border-radius: 20px 20px 0 0;
    border-left: none;
    border-top: 5px solid #43a047;
  }

  .calculation-preview.invalid {
    border-top-color: #d32f2f;
  }

  .calculation-preview.collapsed {
    /* max-height héritée de la règle générale */
  }

  /* Ajuster le padding pour mobile */
  .calculation-preview {
    padding: calc(var(--preview-padding) * 0.8);
  }
}

/* ============================================================================
   TRÈS PETIT MOBILE (≤ 600px) - Bottom Sheet compact
   ============================================================================ */

@media (max-width: 600px) {
  .calculation-preview {
    max-height: 50vh; /* Plus compact sur très petits écrans */
  }

  .preview-toggle {
    width: 28px;
    height: 28px;
    font-size: 1em;
  }
}

/* ============================================================================
   THÈME SOMBRE (si data-theme="dark")
   ============================================================================ */

[data-theme="dark"] .calculation-preview {
  background: linear-gradient(135deg, #1e3a28 0%, #2d4a34 100%);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4);
}

[data-theme="dark"] .calculation-preview.invalid {
  background: linear-gradient(135deg, #3d1f1f 0%, #4a2d2d 100%);
}

[data-theme="dark"] .preview-toggle {
  background: #2d4a34;
  border-color: #66bb6a;
  color: #66bb6a;
}

[data-theme="dark"] .preview-toggle:hover {
  background: #66bb6a;
  color: #1e3a28;
}

[data-theme="dark"] .calculation-preview.invalid .preview-toggle {
  border-color: #ef5350;
  color: #ef5350;
}

[data-theme="dark"] .calculation-preview.invalid .preview-toggle:hover {
  background: #ef5350;
  color: #3d1f1f;
}

/* ============================================================================
   AUTRES THÈMES
   ============================================================================ */

/* Thème Ocean */
[data-theme="ocean"] .calculation-preview {
  background: linear-gradient(135deg, #e0f2f7 0%, #b2dfdb 100%);
  border-left-color: #0097a7;
}

[data-theme="ocean"] .preview-toggle {
  border-color: #0097a7;
  color: #0097a7;
}

[data-theme="ocean"] .preview-toggle:hover {
  background: #0097a7;
  color: white;
}

/* Thème Sunset */
[data-theme="sunset"] .calculation-preview {
  background: linear-gradient(135deg, #fff3e0 0%, #ffe0b2 100%);
  border-left-color: #f57c00;
}

[data-theme="sunset"] .preview-toggle {
  border-color: #f57c00;
  color: #f57c00;
}

[data-theme="sunset"] .preview-toggle:hover {
  background: #f57c00;
  color: white;
}

/* ============================================================================
   ACCESSIBILITÉ - Mode réduit motion
   ============================================================================ */

@media (prefers-reduced-motion: reduce) {
  .calculation-preview,
  .preview-toggle,
  .preview-content {
    transition: none;
  }
}

/* ============================================================================
   PRINT - Masquer le bouton toggle en impression
   ============================================================================ */

@media print {
  .preview-toggle {
    display: none;
  }

  .calculation-preview.collapsed {
    height: auto;
    max-height: none;
  }

  .calculation-preview.collapsed .preview-content {
    opacity: 1;
    max-height: none;
  }
}
