/* Custom Properties - Version 2.1 - Charte Bordeaux - FORÇAGE COMPLET */
:root {
  --primary-color: #73100C;
  --primary-hover-color: #FF0000;
  --text-dark: #1f2937; /* gray-800 */
  --border-radius-elegant: 0.75rem; /* 12px - for cards, popups */
  --border-radius-btn: 0.5rem; /* 8px - for buttons */
}

/* Global Styles & Fonts */
body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Button Styles - High End - FORÇAGE TOTAL */
.btn-primary, 
.btn-outline,
a.btn-primary,
a.btn-outline,
button.btn-primary,
button.btn-outline {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.5rem !important;
  padding: 0.6rem 1.2rem !important;
  font-weight: 600 !important;
  border-radius: var(--border-radius-btn) !important;
  transition: all 0.3s ease-in-out !important;
  border: 2px solid transparent !important;
  cursor: pointer !important;
  text-decoration: none !important;
  font-size: 0.9rem !important;
  text-align: center !important;
}

@media (min-width: 1024px) {
  .btn-primary, 
  .btn-outline,
  a.btn-primary,
  a.btn-outline,
  button.btn-primary,
  button.btn-outline {
      padding: 0.75rem 1.5rem !important;
      font-size: 1rem !important;
  }
}

/* BTN PRIMARY - BORDEAUX */
.btn-primary,
a.btn-primary,
button.btn-primary {
  background-color: #73100C !important;
  background: #73100C !important;
  color: white !important;
  border-color: #73100C !important;
  box-shadow: 0 2px 8px rgba(115, 16, 12, 0.2) !important;
}

.btn-primary:hover,
.btn-primary:focus,
a.btn-primary:hover,
a.btn-primary:focus,
button.btn-primary:hover,
button.btn-primary:focus {
  background-color: #FF0000 !important;
  background: #FF0000 !important;
  border-color: #FF0000 !important;
  color: white !important;
  box-shadow: 0 4px 12px rgba(255, 0, 0, 0.3) !important;
  transform: translateY(-1px) !important;
}

/* BTN OUTLINE - BORDEAUX */
.btn-outline,
a.btn-outline,
button.btn-outline {
  background-color: transparent !important;
  background: transparent !important;
  color: #73100C !important;
  border: 2px solid #73100C !important;
  border-color: #73100C !important;
}

.btn-outline:hover,
.btn-outline:focus,
a.btn-outline:hover,
a.btn-outline:focus,
button.btn-outline:hover,
button.btn-outline:focus {
  background-color: #73100C !important;
  background: #73100C !important;
  color: white !important;
  border-color: #73100C !important;
  box-shadow: 0 4px 12px rgba(115, 16, 12, 0.2) !important;
  transform: translateY(-1px) !important;
}

/* Card & Popup Styles */
.card-elegant, .popup-elegant {
  border-radius: var(--border-radius-elegant);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
  transition: box-shadow 0.3s ease;
}

.card-elegant:hover {
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}

/* Animation Smoothness */
* {
  transition-timing-function: ease-in-out;
}

/* Logo desktop - Grand logo avec header très compact */
@media (min-width: 768px) {
  .logo img {
    height: 7rem !important; /* 112px - Logo bien visible mais plus compact */
  }
  
  /* Suppression quasi-totale des paddings verticaux */
  header .container > div > div {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  
  /* Réduction de l'espace entre les deux lignes du header */
  header .hidden.md\\:flex.flex-col {
    gap: 0 !important;
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
  }
  
  /* Compacter toutes les lignes du header */
  header .flex.justify-between.items-center,
  header .flex.justify-end.items-center {
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
    min-height: auto !important;
  }
  
  /* Réduire l'espacement des boutons */
  header .space-x-3 {
    gap: 0.5rem !important;
  }
}
