/* RDVLIB V6.7.4.1 - Harmonisation couleur tableau de bord pro */
:root {
  --rdv-primary: #37000A;
  --rdv-bg: #f6f7fb;
  --rdv-card: #ffffff;
  --rdv-text: #1e1e1e;
  --rdv-muted: #666;
  --rdv-border: #e6e6ea;
  --rdv-soft: #faf8f8;
}

* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  background: var(--rdv-bg);
  color: var(--rdv-text);
}

a { color: inherit; text-decoration: none; }

table {
  width: 100%;
  border-collapse: collapse;
}

th, td {
  padding: 12px 10px;
  border-bottom: 1px solid var(--rdv-border);
  text-align: left;
  vertical-align: top;
}

th {
  color: var(--rdv-muted);
  font-weight: 600;
  font-size: 0.95rem;
}

.rdv-shell {
  display: grid;
  grid-template-columns: 260px 1fr;
  min-height: 100vh;
}

.rdv-sidebar {
  background: var(--rdv-primary);
  color: #fff;
  padding: 24px 18px;
}

.rdv-brand {
  font-size: 1.4rem;
  font-weight: 700;
  margin-bottom: 6px;
}

.rdv-subtitle {
  font-size: 0.95rem;
  opacity: 0.86;
  margin-bottom: 28px;
}

.rdv-menu a {
  display: block;
  padding: 12px 14px;
  border-radius: 12px;
  margin-bottom: 8px;
  background: rgba(255,255,255,0.06);
}

.rdv-menu a.active,
.rdv-menu a:hover {
  background: rgba(255,255,255,0.15);
}

.rdv-main {
  padding: 28px;
}

.rdv-topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  margin-bottom: 24px;
}

.rdv-title {
  margin: 0;
  font-size: 1.9rem;
}

.rdv-welcome {
  color: var(--rdv-muted);
  margin-top: 6px;
}

.rdv-btn {
  display: inline-block;
  background: var(--rdv-primary);
  color: #fff;
  padding: 10px 16px;
  border-radius: 12px;
  font-weight: 600;
}

.rdv-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  margin-bottom: 24px;
}

.rdv-card {
  background: var(--rdv-card);
  border: 1px solid var(--rdv-border);
  border-radius: 18px;
  padding: 18px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.04);
}

.rdv-stat-label {
  color: var(--rdv-muted);
  font-size: 0.95rem;
}

.rdv-stat-value {
  font-size: 2rem;
  font-weight: 700;
  margin-top: 8px;
}

.rdv-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 18px;
}

.rdv-section-title {
  font-size: 1.1rem;
  margin: 0 0 14px;
}

.rdv-list {
  display: grid;
  gap: 12px;
}

.rdv-item {
  border: 1px solid var(--rdv-border);
  border-radius: 14px;
  padding: 14px;
  background: var(--rdv-soft);
}

.rdv-item strong { display: block; margin-bottom: 6px; }
.rdv-empty {
  color: var(--rdv-muted);
  font-style: italic;
}

.rdv-actions {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 18px;
}

.rdv-badge {
  display: inline-block;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 0.85rem;
  font-weight: 600;
  background: rgba(55, 0, 10, 0.08);
  color: var(--rdv-primary);
}

.rdv-inline-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 8px;
  color: var(--rdv-muted);
  font-size: 0.94rem;
}

.rdv-table-wrap {
  overflow-x: auto;
}

.rdv-note {
  color: var(--rdv-muted);
  line-height: 1.5;
}

@media (max-width: 1024px) {
  .rdv-stats,
  .rdv-actions,
  .rdv-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 768px) {
  .rdv-shell {
    grid-template-columns: 1fr;
  }

  .rdv-sidebar {
    padding: 18px;
  }

  .rdv-main {
    padding: 18px;
  }

  .rdv-stats,
  .rdv-actions,
  .rdv-grid {
    grid-template-columns: 1fr;
  }

  .rdv-topbar {
    align-items: flex-start;
    flex-direction: column;
  }
}


/* Harmonisation stricte du fond des menus professionnels */
:root {
  --rdv-primary: #37000A;
}
.rdv-sidebar,
.sidebar {
  background: #37000A !important;
}
.rdv-menu a,
.nav a {
  background: rgba(255,255,255,0.08);
}
.rdv-btn,
.btn,
button.small-btn.primary {
  background: #37000A;
  border-color: #37000A;
}
.btn.secondary,
.small-btn,
button.small-btn {
  color: #37000A;
  border-color: #37000A;
}



/* RDVLIB Pack 132 - Header/footer professionnel harmonisés avec le format public FAQ */
.pro-dashboard-body {
  background: #f6f7fb;
}

.pro-site-main {
  background: #f6f7fb;
}

.pro-dashboard-body .site-header {
  background: #37000A !important;
}

.pro-dashboard-body .btn-pro,
.pro-dashboard-body .btn-pro.active,
.pro-dashboard-body .pro-system-btn {
  background: #ffffff !important;
  color: #37000A !important;
  border-color: #ffffff !important;
  min-width: 138px;
  min-height: 45px;
  padding: 0 20px;
  border-radius: 7px;
  white-space: nowrap;
}

.pro-dashboard-body .btn-pro:hover,
.pro-dashboard-body .pro-system-btn:hover {
  background: #f7eef0 !important;
  color: #37000A !important;
}

.rdv-shell {
  min-height: calc(100vh - 74px);
}

.rdv-sidebar {
  background: #37000A !important;
}

.rdv-brand {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  line-height: 1.2;
  font-size: 1.05rem;
}

.rdv-subtitle {
  font-weight: 700;
}

.rdv-menu-note {
  border-top: 1px solid rgba(255,255,255,0.18);
  padding-top: 16px;
}

@media (max-width: 920px) {
  .pro-dashboard-body .header-nav-wrap {
    z-index: 150;
  }
}

@media (max-width: 768px) {
  .rdv-shell {
    min-height: auto;
  }

  .rdv-sidebar {
    position: relative;
  }

  .rdv-brand {
    font-size: 1rem;
  }
}

/* RDVLIB pack 6.9.13 - Stabilisation du tableau de bord professionnel
   Objectif : ne pas casser le header/footer public, améliorer uniquement l'affichage pro. */
.pro-dashboard-body .rdv-shell { width: 100%; }
.pro-dashboard-body .rdv-main { min-width: 0; overflow: hidden; }
.pro-dashboard-body .rdv-page { width: 100%; min-width: 0; }
.pro-dashboard-body .rdv-card,
.pro-dashboard-body .rdv-panel,
.pro-dashboard-body .rdv-item { min-width: 0; }
.pro-dashboard-body .rdv-stats { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
.pro-dashboard-body .rdv-actions { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.pro-dashboard-body .rdv-grid,
.pro-dashboard-body .rdv-dispo-grid,
.pro-dashboard-body .rdv-prestations-grid,
.pro-dashboard-body .rdv-two-columns,
.pro-dashboard-body .rdv-client-grid,
.pro-dashboard-body .rdv-detail-grid { min-width: 0; }
.pro-dashboard-body .rdv-topbar > div:last-child,
.pro-dashboard-body .rdv-actions-row,
.pro-dashboard-body .rdv-form-actions,
.pro-dashboard-body .rdv-dispo-form-actions,
.pro-dashboard-body .rdv-inline-actions,
.pro-dashboard-body .rdv-pagination {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}
.pro-dashboard-body .rdv-btn,
.pro-dashboard-body .rdv-btn-secondary,
.pro-dashboard-body button.rdv-btn,
.pro-dashboard-body button.rdv-btn-secondary {
  border: 1px solid #37000A;
  cursor: pointer;
  line-height: 1.2;
  text-align: center;
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
.pro-dashboard-body .rdv-btn-secondary { background: #fff !important; color: #37000A !important; }
.pro-dashboard-body .rdv-btn:hover,
.pro-dashboard-body .rdv-btn-secondary:hover { filter: brightness(0.96); }
.pro-dashboard-body .rdv-table-wrap,
.pro-dashboard-body .table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.pro-dashboard-body table { min-width: 720px; }
.pro-dashboard-body input,
.pro-dashboard-body select,
.pro-dashboard-body textarea,
.pro-dashboard-body button { max-width: 100%; }
.pro-dashboard-body .rdv-badge { white-space: normal; }
@media (min-width: 769px) {
  .pro-dashboard-body .rdv-sidebar {
    position: sticky;
    top: 0;
    align-self: start;
    min-height: calc(100vh - 74px);
  }
}
@media (max-width: 920px) {
  .pro-dashboard-body .site-main.pro-site-main { padding-top: 0; }
  .pro-dashboard-body .rdv-shell { display: block; }
  .pro-dashboard-body .rdv-sidebar { border-radius: 0 0 18px 18px; padding: 16px; }
  .pro-dashboard-body .rdv-brand,
  .pro-dashboard-body .rdv-subtitle,
  .pro-dashboard-body .rdv-menu-note { text-align: left; }
  .pro-dashboard-body .rdv-subtitle { margin-bottom: 14px; }
  .pro-dashboard-body .rdv-menu {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding-bottom: 8px;
    -webkit-overflow-scrolling: touch;
  }
  .pro-dashboard-body .rdv-menu a { flex: 0 0 auto; margin-bottom: 0; white-space: nowrap; }
  .pro-dashboard-body .rdv-menu-note { display: none; }
  .pro-dashboard-body .rdv-main { padding: 16px; }
  .pro-dashboard-body .rdv-title { font-size: 1.55rem; line-height: 1.2; }
  .pro-dashboard-body .rdv-welcome { font-size: 0.96rem; }
}
@media (max-width: 640px) {
  .pro-dashboard-body .rdv-main { padding: 12px; }
  .pro-dashboard-body .rdv-panel,
  .pro-dashboard-body .rdv-card { border-radius: 16px; padding: 14px; }
  .pro-dashboard-body .rdv-topbar { gap: 12px; margin-bottom: 16px; }
  .pro-dashboard-body .rdv-topbar > div:last-child,
  .pro-dashboard-body .rdv-actions-row,
  .pro-dashboard-body .rdv-form-actions,
  .pro-dashboard-body .rdv-dispo-form-actions,
  .pro-dashboard-body .rdv-inline-actions,
  .pro-dashboard-body .rdv-pagination { width: 100%; }
  .pro-dashboard-body .rdv-btn,
  .pro-dashboard-body .rdv-btn-secondary,
  .pro-dashboard-body button.rdv-btn,
  .pro-dashboard-body button.rdv-btn-secondary { width: 100%; }
  .pro-dashboard-body .rdv-stats,
  .pro-dashboard-body .rdv-actions,
  .pro-dashboard-body .rdv-grid,
  .pro-dashboard-body .rdv-dispo-grid,
  .pro-dashboard-body .rdv-form-grid { grid-template-columns: 1fr !important; }
  .pro-dashboard-body .rdv-stat-value { font-size: 1.45rem; }
  .pro-dashboard-body .rdv-table-wrap::before,
  .pro-dashboard-body .table-wrap::before {
    content: "Faites glisser horizontalement pour voir tout le tableau";
    display: block;
    font-size: .82rem;
    color: #666;
    margin: 0 0 8px;
  }
}


/* RDVLIB pack 6.9.19 - Navigation professionnelle stable anti-saut
   Objectif : supprimer l'impression de saut lors des clics dans le tableau de bord.
   Méthode prudente : aucune animation de déplacement, largeur stable, menu gauche stable,
   transitions uniquement sur les couleurs, et support des transitions natives du navigateur quand disponible. */
html {
  overflow-y: scroll;
  scrollbar-gutter: stable;
  background: #f6f7fb;
}

body.pro-dashboard-body {
  background: #f6f7fb;
  min-height: 100vh;
}

.pro-dashboard-body .site-header,
.pro-dashboard-body .site-footer,
.pro-dashboard-body .rdv-sidebar {
  transform: none !important;
  animation: none !important;
}

.pro-dashboard-body .rdv-shell {
  align-items: stretch;
}

.pro-dashboard-body .rdv-main,
.pro-dashboard-body .rdv-page {
  transform: none !important;
  animation: none !important;
  opacity: 1 !important;
}

.pro-dashboard-body .rdv-page {
  min-height: calc(100vh - 180px);
}

.pro-dashboard-body .rdv-menu a,
.pro-dashboard-body .rdv-btn,
.pro-dashboard-body .rdv-btn-secondary,
.pro-dashboard-body .btn,
.pro-dashboard-body button,
.pro-dashboard-body .rdv-card,
.pro-dashboard-body .rdv-panel,
.pro-dashboard-body .rdv-item {
  transform: none !important;
  animation: none !important;
  transition: background-color 120ms ease, color 120ms ease, border-color 120ms ease, box-shadow 120ms ease, filter 120ms ease !important;
}

.pro-dashboard-body .rdv-menu a:hover,
.pro-dashboard-body .rdv-menu a:focus,
.pro-dashboard-body .rdv-btn:hover,
.pro-dashboard-body .rdv-btn:focus,
.pro-dashboard-body .rdv-btn-secondary:hover,
.pro-dashboard-body .rdv-btn-secondary:focus,
.pro-dashboard-body .btn:hover,
.pro-dashboard-body .btn:focus {
  transform: none !important;
}

.pro-dashboard-body .rdv-menu a:active,
.pro-dashboard-body .rdv-btn:active,
.pro-dashboard-body .rdv-btn-secondary:active,
.pro-dashboard-body .btn:active {
  transform: none !important;
  filter: brightness(.95);
}

.pro-dashboard-body img,
.pro-dashboard-body svg,
.pro-dashboard-body video,
.pro-dashboard-body canvas {
  max-width: 100%;
  height: auto;
}

@view-transition {
  navigation: auto;
}

::view-transition-old(root),
::view-transition-new(root) {
  animation-duration: 140ms;
  animation-timing-function: ease-out;
}

@media (prefers-reduced-motion: reduce) {
  ::view-transition-old(root),
  ::view-transition-new(root) {
    animation-duration: 1ms;
  }
}


/* RDVLIB Pack 132 - Format header/footer pro identique au format public */
.pro-dashboard-body .site-header .container,
.pro-dashboard-body .site-footer .container {
  width: min(calc(100% - 86px), var(--rdv-container, 1760px));
}

.pro-dashboard-body .header-inner {
  min-height: 74px;
  padding: 9px 0;
}

.pro-dashboard-body .brand img {
  width: 204px;
}

.pro-dashboard-body .main-nav a.active::after,
.pro-dashboard-body .main-nav a:hover::after,
.pro-dashboard-body .site-footer .footer-links a.active::after,
.pro-dashboard-body .site-footer .footer-links a:hover::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 3px;
  border-radius: 999px;
  background: #ffffff;
}

.pro-dashboard-body .main-nav a.active::after,
.pro-dashboard-body .main-nav a:hover::after {
  bottom: -5px;
}

.pro-dashboard-body .site-footer .footer-links a.active::after,
.pro-dashboard-body .site-footer .footer-links a:hover::after {
  bottom: -8px;
}

.pro-dashboard-body .site-footer {
  padding: 0;
}

.pro-dashboard-body .footer-links {
  min-height: 54px;
}


/* ==========================================================
   RDVLIB Pack 224 - Renforcement responsive téléphone tableaux de bord
   Objectif : éviter les débordements sur l'espace professionnel et la
   démonstration sans modifier les fonctions.
   ========================================================== */
@media (max-width: 920px) {
  html, body {
    max-width: 100% !important;
    overflow-x: hidden !important;
  }

  .rdv-shell,
  .rdv-main,
  .rdv-page,
  .rdv-card,
  .rdv-panel,
  .rdv-item {
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .rdv-main {
    overflow-x: hidden !important;
  }

  .rdv-topbar,
  .rdv-actions,
  .rdv-actions-row,
  .rdv-form-actions,
  .rdv-inline-actions {
    min-width: 0 !important;
  }

  .rdv-menu {
    max-width: 100% !important;
  }

  .rdv-menu a {
    min-height: 42px !important;
    display: inline-flex !important;
    align-items: center !important;
  }

  input,
  select,
  textarea {
    width: 100% !important;
    max-width: 100% !important;
    font-size: 16px !important;
  }

  img,
  video,
  iframe,
  canvas,
  svg {
    max-width: 100% !important;
    height: auto;
  }

  .rdv-table-wrap,
  .table-wrap {
    max-width: 100% !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
}

@media (max-width: 640px) {
  .rdv-main {
    padding: 12px !important;
  }

  .rdv-card,
  .rdv-panel,
  .rdv-item {
    padding: 14px !important;
    border-radius: 16px !important;
  }

  .rdv-title {
    font-size: 1.45rem !important;
    line-height: 1.2 !important;
    overflow-wrap: anywhere !important;
  }

  .rdv-btn,
  .rdv-btn-secondary,
  button.rdv-btn,
  button.rdv-btn-secondary {
    width: 100% !important;
  }
}
