/* Calendanse – Redirection réservation (front) */

.cd-booking {
  margin-top: 1rem;
  margin-bottom: 1rem;
}

.cd-booking--unknown,
.cd-booking--free,
.cd-booking--none {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.04);
}

.cd-booking--unknown .cd-icon,
.cd-booking--free .cd-icon,
.cd-booking--none .cd-icon {
  font-size: 1.25rem;
}

.cd-booking-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 18px;
  border-radius: 10px;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.2s ease, color 0.2s ease;
}

.cd-booking-btn__icon {
  display: inline-block;
  width: 1em;
  height: 1em;
  flex-shrink: 0;
  background: currentColor;
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'%3E%3Cpath d='M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6'/%3E%3Cpolyline points='15 3 21 3 21 9'/%3E%3Cline x1='10' y1='14' x2='21' y2='3'/%3E%3C/svg%3E");
  mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'%3E%3Cpath d='M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6'/%3E%3Cpolyline points='15 3 21 3 21 9'/%3E%3Cline x1='10' y1='14' x2='21' y2='3'/%3E%3C/svg%3E");
  -webkit-mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
}

.cd-booking-btn--external {
  background: linear-gradient(135deg, #e84a7f 0%, #c45a00 100%);
  color: #fff;
}

.cd-booking-btn--external:hover {
  background: linear-gradient(135deg, #d63d6d 0%, #b35000 100%);
}

.cd-booking-note {
  font-size: 0.8125rem;
  opacity: 0.78;
  margin-top: 10px;
  line-height: 1.45;
}

.cd-booking-organizer-empty {
  margin: 10px 0 0;
  font-size: 0.8125rem;
  opacity: 0.75;
  font-style: italic;
}

.cd-booking--contact {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 12px 16px;
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.04);
}

.cd-booking-organizer-contact {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.cd-booking-organizer-item {
  margin-bottom: 6px;
  font-size: 14px;
}

.cd-booking-organizer-item:last-child {
  margin-bottom: 0;
}

.cd-booking-organizer-label {
  display: inline-block;
  min-width: 80px;
  font-weight: 600;
  opacity: 0.85;
}

.cd-booking-organizer-item a {
  text-decoration: none;
}

.cd-booking-organizer-item a:hover {
  text-decoration: underline;
}

.cd-booking--external {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.cd-badge-external {
  display: inline-block;
  margin-top: 6px;
  padding: 3px 8px;
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  border-radius: 4px;
  background: rgba(0, 0, 0, 0.06);
  color: rgba(0, 0, 0, 0.55);
}

/* Mobile : lisibilité et touch */
@media (max-width: 640px) {
  .cd-booking {
    margin-top: 1.25rem;
    margin-bottom: 1.25rem;
  }

  .cd-booking-btn {
    padding: 14px 20px;
    min-height: 48px;
    font-size: 1rem;
  }

  .cd-booking--unknown,
  .cd-booking--free,
  .cd-booking--contact {
    padding: 14px 16px;
  }
}
