/* Фирменные стили для карточек и кнопок Excursion Booking */
.eb-btn-main {
  background-color: #774643;
  color: #fff;
  border: none;
  transition: background 0.2s;
}
.eb-btn-main:hover, .eb-btn-main:focus {
  background-color: #6e013b;
  color: #fff;
}
.eb-btn-outline {
  border: 2px solid #774643;
  color: #774643;
  background: transparent;
  transition: all 0.2s;
}
.eb-btn-outline:hover, .eb-btn-outline:focus {
  background: #6e013b;
  color: #fff;
  border-color: #6e013b;
}
.eb-card-title {
  color: #774643;
  font-weight: bold;
}
.eb-card-date {
  font-size: 0.95em;
  color: #6e013b;
}

/* Стили для улучшенных модальных окон */
.eb-modal-fullscreen {
  padding: 0 !important;
}

.eb-modal-fullscreen .modal-dialog {
  max-width: none;
  margin: 0;
  height: 100%;
}

.eb-modal-fullscreen .modal-content {
  height: 100%;
  border-radius: 0;
  border: none;
}

.eb-modal-fullscreen .modal-header {
  border-bottom: 1px solid #dee2e6;
  padding: 1rem;
  position: sticky;
  top: 0;
  background: #fff;
  z-index: 10;
}

.eb-modal-fullscreen .modal-body {
  flex: 1;
  overflow-y: auto;
  padding: 1rem;
  max-height: calc(100vh - 140px); /* Вычитаем высоту header и footer */
}

.eb-modal-fullscreen .modal-footer {
  border-top: 1px solid #dee2e6;
  padding: 1rem;
  position: sticky;
  bottom: 0;
  background: #fff;
  z-index: 10;
}

/* Адаптивность для мобильных устройств */
@media (max-width: 768px) {
  /* Все модальные окна бронирования становятся полноэкранными на мобильных */
  .modal[id^="ebBookModal"] {
    padding: 0 !important;
  }
  
  .modal[id^="ebBookModal"] .modal-dialog {
    max-width: none;
    margin: 0;
    height: 100%;
  }
  
  .modal[id^="ebBookModal"] .modal-content {
    height: 100%;
    border-radius: 0;
    border: none;
  }
  
  .modal[id^="ebBookModal"] .modal-header {
    border-bottom: 1px solid #dee2e6;
    padding: 1rem;
    position: sticky;
    top: 0;
    background: #fff;
    z-index: 10;
  }
  
  .modal[id^="ebBookModal"] .modal-body {
    flex: 1;
    overflow-y: auto;
    padding: 1rem;
    max-height: calc(100vh - 140px);
  }
  
  .modal[id^="ebBookModal"] .modal-footer {
    border-top: 1px solid #dee2e6;
    padding: 1rem;
    position: sticky;
    bottom: 0;
    background: #fff;
    z-index: 10;
  }
  
  /* Улучшения для кнопок на мобильных */
  .modal[id^="ebBookModal"] .btn {
    padding: 0.75rem 1rem;
    font-size: 1rem;
  }
  
  /* Улучшения для полей ввода на мобильных */
  .modal[id^="ebBookModal"] .form-control {
    font-size: 16px; /* Предотвращает зум на iOS */
    padding: 0.75rem;
  }
  
  /* Улучшения для кнопок выбора дат и времени */
  .modal[id^="ebBookModal"] .eb-cyclic-date-btn,
  .modal[id^="ebBookModal"] .eb-cyclic-time-btn {
    min-height: 44px; /* Минимальная высота для touch-устройств */
    margin: 0.25rem;
  }
}

/* Дополнительные улучшения для форм */
.eb-cyclic-dates-wrap,
.eb-cyclic-times-wrap {
  max-height: 200px;
  overflow-y: auto;
  border: 1px solid #dee2e6;
  border-radius: 0.375rem;
  padding: 0.5rem;
}

.eb-cyclic-date-btn.active,
.eb-cyclic-time-btn.active {
  background-color: #774643 !important;
  border-color: #774643 !important;
  color: #fff !important;
}

/* Стили для SMS-верификации */
.eb-send-sms-btn.btn-success,
.eb-verify-sms-btn.btn-success {
  background-color: #198754 !important;
  border-color: #198754 !important;
}

/* Анимации для плавного появления элементов */
.eb-cyclic-times-wrap,
.eb-cyclic-form-wrap {
  transition: all 0.3s ease-in-out;
}

/* Улучшения для скроллбара */
.eb-modal-fullscreen .modal-body::-webkit-scrollbar,
.eb-cyclic-dates-wrap::-webkit-scrollbar,
.eb-cyclic-times-wrap::-webkit-scrollbar {
  width: 6px;
}

.eb-modal-fullscreen .modal-body::-webkit-scrollbar-track,
.eb-cyclic-dates-wrap::-webkit-scrollbar-track,
.eb-cyclic-times-wrap::-webkit-scrollbar-track {
  background: #f1f1f1;
  border-radius: 3px;
}

.eb-modal-fullscreen .modal-body::-webkit-scrollbar-thumb,
.eb-cyclic-dates-wrap::-webkit-scrollbar-thumb,
.eb-cyclic-times-wrap::-webkit-scrollbar-thumb {
  background: #774643;
  border-radius: 3px;
}

.eb-modal-fullscreen .modal-body::-webkit-scrollbar-thumb:hover,
.eb-cyclic-dates-wrap::-webkit-scrollbar-thumb:hover,
.eb-cyclic-times-wrap::-webkit-scrollbar-thumb:hover {
  background: #6e013b;
}

/* Дополнительные стили для мобильного опыта */
.modal-open-mobile {
  overflow: hidden !important;
  position: fixed !important;
  width: 100% !important;
}

/* Улучшения для header при прокрутке */
.modal-header.shadow-sm {
  box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075) !important;
}

/* Улучшения для кнопок на touch-устройствах */
@media (hover: none) and (pointer: coarse) {
  .eb-cyclic-date-btn,
  .eb-cyclic-time-btn,
  .modal[id^="ebBookModal"] .btn {
    min-height: 44px;
    min-width: 44px;
    touch-action: manipulation;
  }
  
  .modal[id^="ebBookModal"] .form-control {
    min-height: 44px;
    touch-action: manipulation;
  }
}

/* Улучшения для анимаций */
.modal[id^="ebBookModal"] .modal-content {
  transition: transform 0.3s ease-out;
}

.modal[id^="ebBookModal"].fade .modal-dialog {
  transition: transform 0.3s ease-out;
}

/* Улучшения для состояний загрузки */
.btn:disabled {
  opacity: 0.65;
  cursor: not-allowed;
}

.spinner-border-sm {
  width: 1rem;
  height: 1rem;
  border-width: 0.125em;
}

/* Улучшения для фокуса на мобильных */
@media (max-width: 768px) {
  .modal[id^="ebBookModal"] .form-control:focus {
    box-shadow: 0 0 0 0.2rem rgba(119, 70, 67, 0.25);
    border-color: #774643;
  }
  
  .modal[id^="ebBookModal"] .btn:focus {
    box-shadow: 0 0 0 0.2rem rgba(119, 70, 67, 0.25);
  }
}

/* Улучшения для accessibility */
.modal[id^="ebBookModal"] .btn:focus-visible {
  outline: 2px solid #774643;
  outline-offset: 2px;
}

.modal[id^="ebBookModal"] .form-control:focus-visible {
  outline: 2px solid #774643;
  outline-offset: 2px;
}
