@tailwind base;
@tailwind components;
@tailwind utilities;

@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:wght@400;600;700&display=swap');

/* Empêcher le scroll horizontal sur tout le site */
html, body {
  overflow-x: hidden;
  max-width: 100vw;
}

/* S'assurer que le body n'interfère pas avec le sticky */
body {
  position: relative;
  overflow-y: auto;
}

/* Préserver le comportement sticky */
header.sticky {
  position: sticky !important;
  top: 0 !important;
  z-index: 50 !important;
}

/* Règle spécifique pour la navbar de la page principale */
header.sticky.top-0 {
  position: sticky !important;
  top: 0 !important;
  z-index: 50 !important;
}

/* S'assurer que tous les conteneurs respectent la largeur de l'écran */
* {
  box-sizing: border-box;
}

/* Règles spécifiques pour mobile */
@media (max-width: 768px) {
  html, body {
    overflow-x: hidden;
    max-width: 100vw;
  }

  /* Empêcher les éléments de déborder horizontalement */
  .w-full, .w-screen {
    max-width: 100vw;
    overflow-x: hidden;
  }

  /* S'assurer que les conteneurs avec padding ne débordent pas */
  .px-4, .px-6, .px-8 {
    max-width: 100vw;
  }
}

@layer components {
  .title-gradient {
    background-image: linear-gradient(to right, #fb923c, #ea580c);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
  }
}

/* Animations d'apparition */
.fade-in-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

.fade-in-up.animate {
  opacity: 1;
  transform: translateY(0);
}

.slide-in-left {
  opacity: 0;
  transform: translateX(-50px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

.slide-in-left.animate {
  opacity: 1;
  transform: translateX(0);
}

.slide-in-right {
  opacity: 0;
  transform: translateX(50px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

.slide-in-right.animate {
  opacity: 1;
  transform: translateX(0);
}

/* Amélioration des performances */
.fade-in-up,
.slide-in-left,
.slide-in-right {
  will-change: opacity, transform;
}

/* Responsive pour les animations sur mobile */
@media (max-width: 768px) {
  .slide-in-left {
    transform: translateY(30px);
  }

  .slide-in-left.animate {
    transform: translateY(0);
  }

  .slide-in-right {
    transform: translateY(30px);
  }

  .slide-in-right.animate {
    transform: translateY(0);
  }
}

/* Styles pour la bannière de cookies */
.cookies-eu {
  font-family: 'Bricolage Grotesque', sans-serif;
  position: fixed !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 9999 !important;
}

.cookies-eu-content-holder {
  max-width: 100%;
}

.cookies-eu-button-holder {
  white-space: nowrap;
}

.cookies-eu-ok {
  cursor: pointer;
  border: none;
  outline: none;
}

.cookies-eu-decline {
  cursor: pointer;
  border: none;
  outline: none;
}

/* Animation d'apparition de la bannière */
.cookies-eu {
  animation: slideUp 0.3s ease-out;
}

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

/* Responsive pour la bannière de cookies */
@media (max-width: 640px) {
  .cookies-eu {
    padding: 1rem !important;
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
  }

  .cookies-eu-content-holder {
    text-align: center;
    margin-bottom: 1rem;
  }

  .cookies-eu-button-holder {
    justify-content: center;
    width: 100%;
  }

  /* Ajouter un padding-bottom au body pour éviter que le contenu soit caché */
  body {
    padding-bottom: 120px; /* Hauteur approximative de la bannière */
  }
}

/* S'assurer que la bannière est toujours en bas */
@media (min-width: 641px) {
  .cookies-eu {
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
  }

  /* Ajouter un padding-bottom au body pour éviter que le contenu soit caché */
  body {
    padding-bottom: 80px; /* Hauteur approximative de la bannière */
  }
}

/* Effet Parallax */
.parallax-slow {
  transition: transform 0.1s ease-out;
}

.parallax-medium {
  transition: transform 0.1s ease-out;
}

.parallax-fast {
  transition: transform 0.1s ease-out;
}

/* Amélioration de la fluidité */
.parallax-slow,
.parallax-medium,
.parallax-fast {
  will-change: transform;
}

:root {
  font-family: 'Bricolage Grotesque', sans-serif;
}

/* Styles spécifiques au questionnaire pour éviter les conflits avec la landing */
.questionnaire-container {
  /* Isoler les styles du questionnaire */
}

.questionnaire-container .rating-button {
  width: 2.5rem !important;
  height: 2.5rem !important;
  border-radius: 9999px !important;
  border-width: 2px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-weight: 600 !important;
  transition: all 0.2s ease-in-out !important;
  cursor: pointer !important;
  font-size: 0.875rem !important;
  line-height: 1.25rem !important;
}

.questionnaire-container .rating-button:not(.selected) {
  border-color: #cbd5e1 !important;
  color: #475569 !important;
  background-color: white !important;
}

.questionnaire-container .rating-button:not(.selected):hover {
  border-color: #fed7aa !important;
  background-color: #fff7ed !important;
}

.questionnaire-container .rating-button.selected {
  background-color: #f97316 !important;
  border-color: #f97316 !important;
  color: white !important;
}

/* Responsive pour mobile */
@media (max-width: 640px) {
  .questionnaire-container .rating-button {
    width: 2.25rem !important;
    height: 2.25rem !important;
    font-size: 0.875rem !important;
    font-weight: 600 !important;
  }

  .questionnaire-container .rating-scale-container {
    gap: 0.25rem !important;
  }

  .questionnaire-container .rating-scale-labels {
    font-size: 0.75rem !important;
    width: 2.8rem !important;
    flex-shrink: 0 !important;
    text-align: center !important;
  }

  /* Améliorer l'espacement global sur mobile */
  .questionnaire-container .flex.items-center.space-x-2 {
    gap: 0.25rem !important;
  }
}

/* Pour les très petits écrans */
@media (max-width: 380px) {
  .questionnaire-container .rating-button {
    width: 2rem !important;
    height: 2rem !important;
    font-size: 0.75rem !important;
    font-weight: 500 !important;
  }

  .questionnaire-container .rating-scale-container {
    gap: 0.15rem !important;
  }

  .questionnaire-container .rating-scale-labels {
    font-size: 0.7rem !important;
    width: 2.3rem !important;
    line-height: 1.1 !important;
  }

  /* Réduire l'espacement entre les éléments */
  .questionnaire-container .flex.items-center.space-x-2 {
    gap: 0.15rem !important;
  }
}

/* Pour les écrans encore plus petits */
@media (max-width: 320px) {
  .questionnaire-container .rating-button {
    width: 1.8rem !important;
    height: 1.8rem !important;
    font-size: 0.7rem !important;
  }

  .questionnaire-container .rating-scale-container {
    gap: 0.1rem !important;
  }

  .questionnaire-container .rating-scale-labels {
    font-size: 0.65rem !important;
    width: 2rem !important;
  }

  /* Réduire encore plus l'espacement entre les éléments */
  .questionnaire-container .flex.items-center.space-x-2 {
    gap: 0.1rem !important;
  }
}

/* Particules flottantes */
.particle {
  position: absolute;
  width: 4px;
  height: 4px;
  background: #9ca3af;
  border-radius: 50%;
  opacity: 0.3;
  animation: float 15s infinite linear;
}

.particle:nth-child(1) { left: 10%; animation-delay: 0s; animation-duration: 20s; }
.particle:nth-child(2) { left: 20%; animation-delay: 2s; animation-duration: 18s; }
.particle:nth-child(3) { left: 30%; animation-delay: 4s; animation-duration: 22s; }
.particle:nth-child(4) { left: 40%; animation-delay: 6s; animation-duration: 16s; }
.particle:nth-child(5) { left: 50%; animation-delay: 8s; animation-duration: 24s; }
.particle:nth-child(6) { left: 60%; animation-delay: 10s; animation-duration: 19s; }
.particle:nth-child(7) { left: 70%; animation-delay: 12s; animation-duration: 21s; }
.particle:nth-child(8) { left: 80%; animation-delay: 14s; animation-duration: 17s; }
.particle:nth-child(9) { left: 90%; animation-delay: 16s; animation-duration: 23s; }
.particle:nth-child(10) { left: 15%; animation-delay: 18s; animation-duration: 20s; }
.particle:nth-child(11) { left: 25%; animation-delay: 1s; animation-duration: 18s; }
.particle:nth-child(12) { left: 35%; animation-delay: 3s; animation-duration: 22s; }
.particle:nth-child(13) { left: 45%; animation-delay: 5s; animation-duration: 16s; }
.particle:nth-child(14) { left: 55%; animation-delay: 7s; animation-duration: 24s; }
.particle:nth-child(15) { left: 65%; animation-delay: 9s; animation-duration: 19s; }
.particle:nth-child(16) { left: 75%; animation-delay: 11s; animation-duration: 21s; }
.particle:nth-child(17) { left: 85%; animation-delay: 13s; animation-duration: 17s; }
.particle:nth-child(18) { left: 95%; animation-delay: 15s; animation-duration: 23s; }
.particle:nth-child(19) { left: 5%; animation-delay: 17s; animation-duration: 20s; }
.particle:nth-child(20) { left: 95%; animation-delay: 19s; animation-duration: 18s; }

@keyframes float {
  0% {
    transform: translateY(100vh) rotate(0deg);
    opacity: 0;
  }
  10% {
    opacity: 0.6;
  }
  90% {
    opacity: 0.6;
  }
  100% {
    transform: translateY(-100px) rotate(360deg);
    opacity: 0;
  }
}
