html,
body {
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    display: block;
    background-color: #7ca4ff21;
}

body {
    width: 100%;
    font-size: 16px;
    font-weight: 400;
    font-style: normal;
    line-height: 1.075;
    color: #0f0f10;
    text-align: left;
    min-width: 996px;
    min-height: 1150px;
    max-width: 974px;
    margin: 0 auto;
    /* Центрирование по ширине */
    overflow: auto;
    box-sizing: border-box;
    /* чтобы учитывать padding и border в общей ширине и высоте */
    padding-left: 10px;
    /* Внутренние отступы */
    padding-right: 10px;
    /* Внутренние отступы */
    padding-top: 10px;
}

@media screen and (max-width: 450px) {
    body {
        min-width: 767px;
        width: 450px;
        min-height: 990px;
        max-width: 670px;
        /* Установите максимальную ширину страницы */
        max-height: 990px;
        transform: scale(0.57);
        transform-origin: top left;
        /* Закрепляем по верхнему левому углу */
        padding-right: 0;
        box-sizing: content-box;
        /* Убираем box-sizing: border-box на телефонах */
        overflow-x: hidden;
        /* Убираем горизонтальную прокрутку */
        margin: 0;
        /* Убираем отступы */


    }

    #cityInput {
        min-width: 380px;
        max-width: 380px
    }

    #cityList {
        min-width: 380px;
        max-width: 380px
    }

    .mobile-only {
        display: block;
    }
}

.mobile-only {
    display: none;
}

.clickable {
    border-radius: 10px;
    cursor: pointer;
    background-color: #f4f8fb;
    padding: 5px;
    border-radius: 5px;
    margin-bottom: 20px;
    box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
    display: none;
    height: auto !important;
}


.clickable:hover {
    background-color: white;
    /* изменяем цвет при наведении */
}

.clickable:active {
    background-color: #eaeaeb;
    /* изменяем цвет при нажатии */
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
    /* увеличиваем тень при нажатии */
}

td.clickable {
    position: relative;
    /* Делаем позиционирование для псевдоэлементов */
    width: 115px;
    /* Фиксированная ширина для ячейки */
    overflow: hidden;
    /* Скрываем содержимое, которое выходит за границы ячейки */
    text-overflow: ellipsis;
    /* Отображаем многоточие для обрезанного содержимого */
    cursor: pointer;
    padding: 10px;
    /* Отступы внутри ячейки */
    box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
    /* Добавляем тень */

    /* Фоновый градиент */
    background-color: #f4f8fb;
    background: linear-gradient(to bottom, #ffffff, #f0f0f0);
    /* Градиентный фон */

    /* Плавный переход для transform */
    transition: transform 0.2s;
}

/* Псевдоэлементы для создания эффекта выгнутости */


/* Псевдоэлемент слева */
td.clickable::before {
    left: 0;
    background: linear-gradient(to right, rgba(255, 255, 255, 0.8), transparent);
    /* Градиент слева до центра */
}

/* Псевдоэлемент справа */
td.clickable::after {
    right: 0;
    background: linear-gradient(to left, rgba(255, 255, 255, 0.8), transparent);
    /* Градиент от центра до правой части */
}

/* При наведении на ячейку */
td.clickable:hover {
    transform: scale(0.95);
    /* Небольшое уменьшение при наведении */
}

/* Изменение цвета псевдоэлементов при наведении */
td.clickable:hover::before,
td.clickable:hover::after {
    background-color: rgba(255, 255, 255, 0.2);
    /* Прозрачный белый цвет для выделения эффекта */
}


.day-of-week,
td.clickable span {
    margin-bottom: 5px;
    /* Измените значение по вашему усмотрению */
}

td.clickable:active {
    background-color: #f4f8fb;
    /* изменяем цвет при нажатии */
    transform: scale(0.95);
    /* уменьшаем размер при нажатии */
}

.day-of-week {
    font-family: Helvetica, sans-serif;
    /* Устанавливаем шрифт */
    text-transform: capitalize;
    /* Делаем первую букву заглавной */
    text-align: center;
    display: block;
}

td.clickable span {
    margin-bottom: 9px;
    /* Измените значение по вашему усмотрению */
}

.red-day {
    color: red;
    font-weight: bold;
    font-size: 10px;
    display: block;
    text-align: center;
    margin-top: 5px;
    font-size: 1.7em;
    height: 20px;
}

.normal-day {
    color: navy;
    font-weight: bold;
    font-size: 10px;
    display: block;
    text-align: center;
    margin-top: 5px;
    font-size: 1.7em;
    height: 20px;
}

.with-image img {
    display: block;
    margin: 0px auto;
    height: 60px;
}

img {
    aspect-ratio: 1 / 1;
}

.description-column {
    font-family: Arial, sans-serif;
    /* Изменяем шрифт */
    color: red;
    /* Изменяем цвет текста */
}

/*        input        */
.container {
    text-align: center;
    position: relative;
    margin-top: 10px;
    /* пример отступа сверху */
}

/* input */
#cityInput {
    width: 455px;
    height: 37px;
    color: #303030;
    font-size: 23px;
    border: 1px solid #525254;
    border-radius: 12px;
    box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
}

button {
    height: 35px;
    /* задаем высоту кнопки */
    font-size: 17px;
    /* увеличиваем размер текста кнопки */
    padding: 0 10px;
    /* добавляем отступы вокруг текста кнопки */
}

.input-wrapper {
    position: relative;
    /* Устанавливаем позиционирование родительского контейнера */
}

#cityList {
    font-size: 22px;
    width: 455px;
    text-align: left;
    /* выравниваем текст по левому краю */
    margin: 10px auto 0;
    /* центрируем список по горизонтали */
    list-style-type: none;
    z-index: 1;
    /* Устанавливаем наивысший слой для списка */
    background-color: #fff;
    /* Цвет фона списка */
    max-height: 350px;
    /* Максимальная высота списка, чтобы он не выходил за пределы экрана */
    overflow-x: auto;
    position: absolute;
    left: 50%;
    /* Размещаем список в середине */
    transform: translateX(-50%);
    /* Центрируем список */
    padding: 0;
    padding-left: 5px;
    /* Добавляем отступ слева на 5px */
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}

#cityList li:hover {
    background-color: #dedede;
    /* подсвечиваем фон при наведении на элемент списка */
}

#cityList li:first-child {
    margin-top: 5px;
    /* Добавляем отступ сверху только для первого элемента списка */
}

#cityList li {
    margin-bottom: 10px;
    /* Увеличиваем отступ между элементами списка */
}

#suggestions {
    position: absolute;
    top: 100%;
    /* помещаем варианты сразу под полем ввода */
    left: 0;
    width: 100%;
    /* ширина окна вариантов равна ширине поля ввода */
    background-color: white;
    border: 1px solid #ccc;
    display: none;
    /* по умолчанию окно вариантов скрыто */
}

#suggestions.visible {
    display: block;
    /* отображаем окно вариантов при необходимости */
}

#suggestions div {
    padding: 5px;
    cursor: pointer;
}

#suggestions div:hover {
    background-color: #f0f0f0;
}

.highlight {
    background-color: #dedede;
    cursor: pointer;
}

.weather-info {
    border: none;
    /* Убираем границу */
    border-radius: 10px;
    /* Закругляем углы */
    box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
    padding: 10px;
    /* Внутренние отступы */
    margin-bottom: 10px;
    /* Отступ снизу */
    background-color: #ffffff;
    /* Цвет фона */
    width: 350px;
    /* Ширина блока */
}

.weather-current {

    background-color: f8f8f8;
    width: 380px;
    padding: 10px;

}

.weather-info span.value {
    font-weight: bold;
    /* Жирный шрифт */
    font-size: 110%;
    /* Увеличение размера шрифта на 10% */
}

.custom-button {
    background: linear-gradient(to bottom, #c1e5ff, #001f4bba);
    /* Градиентный фон */
    border: none;
    /* Убираем границу */
    color: white;
    /* Цвет текста */
    padding: 20px;
    /* Отступы внутри кнопки */
    text-align: center;
    /* Выравнивание текста по центру */
    text-decoration: none;
    display: inline-block;
    font-size: 16px;
    margin: 4px 2px;
    transition-duration: 0.2s;
    /* Длительность анимации */
    cursor: pointer;
    /* Смена курсора при наведении */
    border-radius: 12px;
    /* Радиус скругления углов */
    border: 2px solid #878787;
    /* Добавляем границу */
    /* width: 220px;*/
    white-space: pre;
    font-size: 20px;
    line-height: 0px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    /* Добавляем тень для объема */
}

.custom-button:hover {
    background: linear-gradient(to bottom, #ffffff, #073f87);
    /* Градиентный фон при наведении */
    /*color: #073f87;  Изменяем цвет текста при наведении */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    /* Усиливаем тень при наведении */
}

.custom-button:active {
    background: linear-gradient(to bottom, #073f87, #091760ba);
    /* Градиентный фон при нажатии */
    transform: scale(1.05);
    /* Применяем эффект масштабирования при нажатии */
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    /* Меняем тень при нажатии */
}

.custom-button.pressed {
    background: linear-gradient(to bottom, #0070ff, #020205ba);
    /* Градиентный фон после нажатия */
    color: white;
    /* Цвет текста после нажатия */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    /* Тень для кнопки в нажатом состоянии */
}

.custom-button {
    padding: 10px 20px;
    font-size: 16px;
    cursor: pointer;
}

#datePickerContainer {
    display: none;
    position: absolute;
    z-index: 1000;
}

#datePickerContainer .flatpickr-calendar {
    transform: scale(1.9);
    transform-origin: top left;
}

.content {
    display: flex;
    flex-direction: column;
}

.block-content {
    flex: 1;
    padding: 15px;
    border: 1px solid #ccc;
    box-shadow: 0 0 10px rgb(0 0 0 / 26%);
    background-color: #f9f9f9;
    margin-top: 20px;
}

.block-content h2 {
    margin-top: 0;
    font-size: 1.5em;
    color: #333;
}

.block-content p {
    font-size: 1.45em;
    color: #666;
}

.day-of-week-current {
    margin-left: 220px;
    text-shadow: 1px 1px 5px rgba(0, 0, 0, 0.3);
    font-size: 1.3em;
}

.temp-of-week {
    font-size: clamp(12px, 20vw, 26px);
    display: block;
    text-align: center;
}

.data-of-week {
    font-size: clamp(12px, 20vw, 35px);
    display: block;
    text-align: center;
}

.week-div {
    overflow-x: auto;
    max-width: 100%;
}

.week-table {
    width: 100%;
    table-layout: fixed;
}

.table-cell {
    min-width: 87px;
    max-width: 87px;
    width: 87px;
    text-align: center;
    background-color: rgb(255, 255, 255);
    padding-top: 10px;
}

.header-cell-with-margin {
    font-weight: bold;
    font-size: 1.8em;
    display: block;
    text-align: center;
    margin: 8px 23px;
    height: 30px;
    color: navy;
}

.header-cell-no-margin {
    font-weight: bold;
    font-size: 1.8em;
    display: block;
    text-align: center;
    height: 30px;
    color: navy;
}

.span-style {
    display: block;
    margin-bottom: 8.5px;
    padding: 5px;
    white-space: nowrap;
    min-width: 140px;
    max-width: 140px;
    overflow: hidden;
    font-size: 1.3em;
    text-overflow: ellipsis;
}

.dynamic-table {
    border: 1px solid #ccc;
    table-layout: fixed;
    width: 100%;
}

.sticky-cell {
    width: 147px;
    background-color: rgb(255, 255, 255);
    position: sticky;
    left: 0;
    z-index: 999;
}

.circle-container {
    height: 110px;
    border-radius: 10%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.icon-image {
    max-width: 100%;
    height: auto;
    /* Сохраняет пропорции */
    margin-bottom: 10px;
}
.span-style-one {
    display: block;
    font-size: 1.4em;
}

/* Настройка цвета выбранного дня */
.flatpickr-day.selected, .flatpickr-day.selected:hover {
    background: #ff7f50;
    border-color: #ff7f50;
    color: white;
}

/* Изменение шрифта заголовка */
.flatpickr-months .flatpickr-month {
    font-family: 'Arial', sans-serif;
    font-size: 1.2em;
}

/* Настройка цвета заголовка */
.flatpickr-months {
    background-color: #e1e9fd;
    color: white;
}

/* Изменение цвета дней недели */
.flatpickr-weekdays {
    background-color: #f0f0f0;
}

/* Изменение цвета навигационных стрелок */
.flatpickr-current-month .flatpickr-prev-month,
.flatpickr-current-month .flatpickr-next-month {
    color: white;
}

.flatpickr-day.weekend {
    color: red;
}

.flatpickr-day.weekend:hover {
    background-color: #ffe6e6;
}

.flatpickr-input[readonly] {
    visibility: hidden;
}