/**
 * Стили страницы бронирования (Book): форма поиска, список отелей, карточки номеров
 */

.page-book {
    margin-bottom: 32px;
}

.page-book__title {
    margin-bottom: 24px;
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--color-text);
}

/* Карточка формы поиска */
.page-book__form-card {
    padding: 24px;
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
}

/* Блок текущего заказа */
.page-book__order-card {
    padding: 24px;
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
}

.page-book__order-title {
    margin: 0 0 16px;
    font-size: 1.2rem;
    font-weight: 600;
    color: var(--color-text);
}

/* Разделитель перед результатами */
.page-book__divider {
    border: none;
    border-top: 1px solid var(--color-border);
    margin: 28px 0 24px;
}

/* Сайдбар: штрафы, галерея */
.page-book__sidebar {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.page-book__sidebar .btn-gallery,
.page-book__sidebar .btn-danger {
    border-radius: var(--radius-md);
    font-weight: 500;
}

/* Контейнер страницы Book */
#book-form .form-control,
#book-form .input-group {
    border-radius: var(--radius-sm);
    border-color: var(--color-border);
    transition: border-color var(--transition), box-shadow var(--transition);
}

#book-form .form-control:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(0, 140, 74, 0.15);
}

#book-form .form-group {
    margin-bottom: 18px;
}

#book-form .form-group label.control-label {
    font-weight: 500;
    color: var(--color-text);
}

/* Группа дат: календарь */
.page-book .drp-container .input-group-addon {
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-right: none;
    border-radius: var(--radius-sm) 0 0 var(--radius-sm);
    color: var(--color-text-muted);
}

.page-book .drp-container .form-control {
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

/* Кнопка поиска на странице Book */
#book-form .btn-success {
    background: var(--color-primary);
    border: none;
    border-radius: var(--radius-md);
    padding: 10px 24px;
    font-weight: 600;
    transition: background var(--transition), transform var(--transition);
}

#book-form .btn-success:hover {
    background: var(--color-primary-hover);
    transform: translateY(-1px);
}

#book-form .btn-success:active {
    transform: translateY(0);
}

/* Блок текущего заказа на странице Book */
.col-sm-8 .btn-primary {
    background: var(--color-primary);
    border: none;
    border-radius: var(--radius-md);
    font-weight: 500;
}

.col-sm-8 .btn-primary:hover {
    background: var(--color-primary-hover);
}

/* Список отелей: карточки */
#hotels-list .thumbnail.list-tile {
    padding: 20px;
    margin-bottom: 20px;
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    cursor: pointer;
    transition: border-color var(--transition), box-shadow var(--transition);
}

#hotels-list .thumbnail.list-tile:hover {
    border-color: var(--color-primary);
    box-shadow: var(--shadow-md);
}

#hotels-list .thumbnail .hotel-title {
    font-size: 1.7rem;
    font-weight: 600;
}

#hotels-list .thumbnail .crop {
    border-radius: var(--radius-sm);
}

/* Список номеров: карточки */
#rooms-list .thumbnail.list-tile {
    padding: 18px 20px;
    margin-bottom: 16px;
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    transition: border-color var(--transition), box-shadow var(--transition);
}

#rooms-list .thumbnail.list-tile:not(.list-tile-locked):hover {
    border-color: var(--color-primary);
    box-shadow: var(--shadow-md);
}

#rooms-list .thumbnail.list-tile.list-tile-locked {
    opacity: 0.85;
    cursor: not-allowed;
}

#rooms-list .thumbnail .big-font {
    font-size: 1.7rem;
}

/* Сортировка и пагинация на странице отелей */
.page-book div#hotels-list > div.sort-title {
    font-weight: 600;
    color: var(--color-text);
    margin-right: 12px;
}

.page-book div#hotels-list > ul.sorter {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin-bottom: 20px;
}

.page-book div#hotels-list > ul.sorter a {
    color: var(--color-primary);
    text-decoration: none;
    padding: 6px 12px;
    border-radius: var(--radius-sm);
    background: var(--color-bg);
    font-size: 1.3rem;
    transition: background var(--transition);
}

.page-book div#hotels-list > ul.sorter a:hover {
    background: var(--color-primary-light);
}

.page-book #hotels-list .list-view-summary,
.page-book #hotels-list .pagination {
    margin-top: 16px;
    color: var(--color-text-muted);
    font-size: 0.95rem;
}
