/*
 * AlifGroup custom overrides.
 * Add project-specific CSS below this line.
 *
 * Структура файла:
 *   1.  Дизайн-токены
 *   2.  База: типографика, поведение скролла
 *   3.  Глобальные компоненты F7 (кнопки, инпуты, списки, бейджи, модалки)
 *   4.  Бары: navbar / tabbar / нижние тулбары
 *   5.  Главная (home)
 *   6.  Дашборд (dashboard)
 *   7.  Меню ресторана (restaurant-menu)
 *   8.  Оформление заказа (restaurant-checkout)
 *   9.  Профиль / логин / отзыв / настройки
 *   10. Контентные страницы (terms, privacy, cookie, info)
 *   11. Выбор языка
 *   12. Доступность и reduced motion
 */

/*
|------------------------------------------------------------------------------
| 1. Дизайн-токены
|------------------------------------------------------------------------------
*/

:root {
    /* Радиусы: 18 — карточки/листы, 14 — кнопки/инпуты, 10 — мелкие элементы */
    --alg-radius-lg: 18px;
    --alg-radius-md: 14px;
    --alg-radius-sm: 10px;

    /* Мягкие двухслойные тени вместо плоских дефолтных */
    --alg-shadow-card: 0 1px 2px rgba(16, 24, 40, 0.06), 0 10px 28px -14px rgba(16, 24, 40, 0.18);
    --alg-shadow-card-pressed: 0 1px 3px rgba(16, 24, 40, 0.12);
    --alg-shadow-bar: 0 -10px 30px rgba(0, 0, 0, 0.28);

    /* Фирменный «ресторанный» аксент (тёмный teal из меню) */
    --alg-teal: #063946;
    --alg-teal-bright: #0e6e87;
    --alg-teal-gradient: linear-gradient(160deg, var(--alg-teal-bright), var(--alg-teal));
    --alg-teal-glow: 0 10px 24px -10px rgba(14, 110, 135, 0.55);

    /* Поверхности тёмных экранов (меню, чекаут) */
    --alg-surface-dark: #171717;
    --alg-card-dark: #1f1f1f;
    --alg-hairline-dark: rgba(255, 255, 255, 0.08);

    /* Пружинная кривая для микроанимаций */
    --alg-ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* Скругления F7: задаём на уровне тем, чтобы перебить ios/md дефолты */
:root,
.ios,
.md,
.aurora {
    --f7-block-inset-border-radius: var(--alg-radius-lg);
    --f7-list-inset-border-radius: var(--alg-radius-lg);
    --f7-button-border-radius: 12px;
    --f7-input-outline-border-radius: var(--alg-radius-md);
    --f7-stepper-border-radius: var(--alg-radius-sm);
    --f7-dialog-border-radius: 20px;
    --f7-toast-border-radius: var(--alg-radius-md);
    --f7-popover-border-radius: 16px;
    --f7-actions-border-radius: 16px;
    --f7-button-text-transform: none;
    --f7-button-small-text-transform: none;
    --f7-button-large-text-transform: none;
    --f7-segmented-strong-button-text-transform: none;
}

/*
|------------------------------------------------------------------------------
| 2. База
|------------------------------------------------------------------------------
*/

html,
body {
    /* Убирает «резиновый» оверскролл браузера — ощущение нативного приложения */
    overscroll-behavior: none;
}

body {
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

img {
    -webkit-user-drag: none;
}

.block-title {
    font-weight: 700;
    letter-spacing: -0.01em;
}

.block-title-medium,
.block-title-large {
    letter-spacing: -0.02em;
}

/*
|------------------------------------------------------------------------------
| 3. Глобальные компоненты F7
|------------------------------------------------------------------------------
*/

/* --- Кнопки --- */

.button {
    font-weight: 600;
    letter-spacing: 0;
    transition: transform 0.15s ease, box-shadow 0.2s ease, opacity 0.2s ease;
}

.button-large {
    --f7-button-large-height: 52px;
    --f7-button-large-font-size: 16px;
    font-weight: 700;
}

/* Тактильный отклик: лёгкое сжатие при нажатии */
.button.active-state {
    transform: scale(0.97);
}

.button-fill.button-large {
    box-shadow: 0 8px 20px -10px rgba(var(--f7-theme-color-rgb), 0.55);
}

/* --- Сегментированные контролы --- */

.segmented-strong .button {
    font-weight: 600;
}

/* --- Инпуты --- */

:root {
    --f7-input-outline-border-color: rgba(120, 130, 145, 0.28);
    --f7-input-outline-focused-border-color: var(--f7-theme-color);
}

.item-input-outline .item-input-wrap {
    transition: box-shadow 0.2s ease;
}

.item-input-outline.item-input-focused .item-input-wrap {
    box-shadow: 0 0 0 4px rgba(var(--f7-theme-color-rgb), 0.12);
}

/* --- Списки и карточки --- */

.list.inset,
.block-strong.inset {
    box-shadow: var(--alg-shadow-card);
}

.dark .list.inset,
.dark .block-strong.inset {
    box-shadow: none;
    border: 1px solid rgba(255, 255, 255, 0.06);
}

/* Карточки-плитки (главная, бизнес-листинги) */
.cards-list.inset li {
    box-shadow: var(--alg-shadow-card);
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.cards-list.inset li:active {
    transform: scale(0.985);
    box-shadow: var(--alg-shadow-card-pressed);
}

.dark .cards-list.inset li {
    box-shadow: none;
    border: 1px solid rgba(255, 255, 255, 0.06);
}

/* --- Бейджи --- */

.badge {
    font-weight: 600;
}

/* --- Пустые состояния --- */

.empty-state-title {
    font-weight: 700;
    letter-spacing: -0.01em;
}

.empty-state-text {
    line-height: 1.55;
}

.empty-state-actions {
    margin-top: 16px;
}

/* --- Прогрессбары --- */

.progressbar {
    --f7-progressbar-height: 8px;
    --f7-progressbar-border-radius: 999px;
}

/*
|------------------------------------------------------------------------------
| 4. Бары
|------------------------------------------------------------------------------
*/

/* --- Navbar --- */

.navbar .title {
    font-weight: 700;
    letter-spacing: -0.01em;
}

.navbar .title img {
    display: block;
    max-height: 26px;
    object-fit: contain;
}

.navbar .right .link + .link {
    margin-left: 4px;
}

/* --- Tabbar --- */

#tabbar {
    --f7-tabbar-label-font-size: 11px;
    box-shadow: 0 -1px 0 rgba(125, 135, 150, 0.12), 0 -8px 24px rgba(16, 24, 40, 0.06);
}

.dark #tabbar {
    box-shadow: 0 -1px 0 rgba(255, 255, 255, 0.08);
}

#tabbar .tab-link {
    transition: color 0.2s ease;
}

#tabbar .icons {
    display: inline-flex;
    transition: transform 0.25s var(--alg-ease-spring);
}

#tabbar .tab-link-active .icons {
    transform: translateY(-1px) scale(1.08);
}

#tabbar .tabbar-label {
    transition: font-weight 0.1s ease;
}

#tabbar .tab-link-active .tabbar-label {
    font-weight: 700;
}

/* --- Нижние закреплённые тулбары (корзина, чекаут) --- */

#app .restaurant-cart-bar,
#app .restaurant-checkout-bar {
    box-shadow: var(--alg-shadow-bar);
    -webkit-backdrop-filter: blur(16px);
    backdrop-filter: blur(16px);
}

/*
|------------------------------------------------------------------------------
| 5. Главная (home)
|------------------------------------------------------------------------------
*/

/* --- Баннерный слайдер --- */

#intro-swiper .swiper-slide {
    border-radius: var(--alg-radius-lg);
    transition: transform 0.4s ease, opacity 0.4s ease;
    transform: scale(0.95);
    opacity: 0.78;
}

#intro-swiper .swiper-slide-active {
    transform: scale(1);
    opacity: 1;
}

#intro-swiper .card {
    border-radius: var(--alg-radius-lg);
    overflow: hidden;
    /* Заставляет Safari клипать видео по скруглённым углам */
    transform: translateZ(0);
}

#intro-swiper .card-title {
    font-weight: 800;
    letter-spacing: -0.01em;
    text-shadow: 0 1px 12px rgba(0, 0, 0, 0.45);
}

#intro-swiper .card-subtitle {
    text-shadow: 0 1px 8px rgba(0, 0, 0, 0.45);
}

#intro-swiper .overlay-content {
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.05) 40%, rgba(0, 0, 0, 0.35));
}

#intro-swiper .button {
    font-weight: 700;
}

/* --- Быстрые действия: Доставка / С собой / Бронь --- */

#block-grid-equal-width .button {
    height: 78px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border-radius: 16px;
    font-size: 13px;
    font-weight: 600;
    text-transform: none;
    --f7-button-raised-box-shadow: var(--alg-shadow-card);
    --f7-button-raised-pressed-box-shadow: var(--alg-shadow-card-pressed);
}

#block-grid-equal-width .button .icon {
    font-size: 24px;
    margin: 0;
    line-height: 1;
}

#block-grid-equal-width .button span {
    line-height: 1;
}

/* --- Карточки заведений --- */

#shops-container .overlay-content {
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.18), rgba(0, 0, 0, 0) 45%, rgba(0, 0, 0, 0.12));
}

#shops-container .item-row.margin-vertical-half {
    padding: 4px 12px 10px;
}

/* Логотипы заведений — белые SVG: в светлой теме делаем их чёрными */
#shops-container .item-row .text-color-body img {
    filter: brightness(0);
    opacity: 0.88;
}

.dark #shops-container .item-row .text-color-body img {
    filter: none;
    opacity: 1;
}

#shops-container .badge {
    padding: 5px 10px;
    border-radius: 999px;
    font-weight: 600;
    -webkit-backdrop-filter: blur(6px);
    backdrop-filter: blur(6px);
    background-color: rgba(0, 0, 0, 0.55);
}

/*
|------------------------------------------------------------------------------
| 6. Дашборд (dashboard)
|------------------------------------------------------------------------------
*/

/* Промо-карта Delivery PRO: глубина поверх инлайнового серого фона */
.page[data-name=dashboard] .note {
    background-image: linear-gradient(135deg, #fdfbf7 0%, #f0f2f6 60%, #e7ebf1 100%);
    box-shadow: var(--alg-shadow-card);
    overflow: hidden;
}

/* Аккордеоны заказов: единый радиус и рамка (инлайн задаёт 12px) */
#app .page[data-name=dashboard] .accordion-item {
    border-radius: var(--alg-radius-lg) !important;
    overflow: hidden;
    box-shadow: var(--alg-shadow-card);
    border: 1px solid rgba(125, 135, 150, 0.08);
}

.dark #app .page[data-name=dashboard] .accordion-item {
    box-shadow: none;
    border-color: rgba(255, 255, 255, 0.07);
}

#app .page[data-name=dashboard] .accordion-item-content .bg-color-gray-100 {
    border-radius: 12px !important;
}

/* Статистические карты: белый текст и лёгкий блик на тёмных фонах */
.page[data-name=dashboard] .card[style*="blue-900"],
.page[data-name=dashboard] .card[style*="green-900"] {
    color: #fff;
    background-image: linear-gradient(150deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0) 55%);
    box-shadow: var(--alg-shadow-card);
}

.page[data-name=dashboard] #wrapped-share-container .card {
    border: 1px solid rgba(125, 135, 150, 0.12);
    border-radius: var(--alg-radius-lg);
}

.dark .page[data-name=dashboard] #wrapped-share-container .card {
    border-color: rgba(255, 255, 255, 0.08);
}

/*
|------------------------------------------------------------------------------
| 7. Меню ресторана (restaurant-menu)
|------------------------------------------------------------------------------
*/

/* --- Карточки блюд: из «голых» картинок в плитки --- */

#app .restaurant-products-grid {
    column-gap: 10px;
    row-gap: 10px;
}

#app .restaurant-product-card {
    display: flex;
    flex-direction: column;
    background: var(--alg-card-dark);
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: var(--alg-radius-lg);
    padding: 10px 10px 12px;
    transition: transform 0.15s ease;
}

#app .restaurant-product-card:active {
    transform: scale(0.97);
}

#app .restaurant-product-image {
    border-radius: 12px;
}

#app .restaurant-product-name {
    color: rgba(255, 255, 255, 0.92);
    min-height: 40px;
}

/* --- Цена / стоппер: фирменный teal с мягким свечением --- */

#app .restaurant-price-button {
    background-image: var(--alg-teal-gradient);
    box-shadow: var(--alg-teal-glow);
    border-radius: 999px;
}

#app .restaurant-product-stepper,
#app .restaurant-cart-stepper {
    --f7-stepper-border-radius: 999px;
    --f7-stepper-fill-button-bg-color: var(--alg-teal);
    --f7-stepper-fill-button-text-color: #fff;
    --f7-stepper-fill-button-pressed-bg-color: var(--alg-teal-bright);
    --f7-stepper-value-text-color: #fff;
    --f7-stepper-value-font-weight: 700;
}

/* Рамку у компактных степперов рисует тема синим — переводим в teal */
#app .restaurant-product-stepper .stepper-button-minus,
#app .restaurant-product-stepper .stepper-button-plus,
#app .restaurant-product-stepper .stepper-input-wrap,
#app .restaurant-cart-stepper .stepper-button-minus,
#app .restaurant-cart-stepper .stepper-button-plus,
#app .restaurant-cart-stepper .stepper-input-wrap {
    border-color: var(--alg-teal-bright);
}

#app .restaurant-product-stepper input,
#app .restaurant-cart-stepper input {
    color: #fff;
}

/* --- Лента категорий: скроллящиеся пилюли с fade по краям --- */

#app .page[data-name=restaurant-menu] .restaurant-categories {
    padding: 10px 16px;
    scrollbar-width: none;
    -webkit-mask-image: linear-gradient(90deg, transparent, #000 14px, #000 calc(100% - 14px), transparent);
    mask-image: linear-gradient(90deg, transparent, #000 14px, #000 calc(100% - 14px), transparent);
}

#app .page[data-name=restaurant-menu] .restaurant-categories::-webkit-scrollbar {
    display: none;
}

#app .page[data-name=restaurant-menu] .restaurant-categories .segmented {
    --f7-segmented-strong-bg-color: transparent;
    gap: 8px;
    padding: 0;
}

#app .page[data-name=restaurant-menu] .restaurant-categories .segmented-highlight {
    display: none;
}

#app .page[data-name=restaurant-menu] .restaurant-category-button {
    border-radius: 999px;
    padding: 0 16px;
    background: #232323;
    color: rgba(255, 255, 255, 0.85);
    transition: background-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

#app .page[data-name=restaurant-menu] .restaurant-category-button.button-active {
    background: var(--alg-teal-gradient);
    color: #fff;
    box-shadow: var(--alg-teal-glow);
}

/* --- Шапка ресторана --- */

#app .page[data-name=restaurant-menu] .restaurant-hero-meta {
    padding: 12px 16px 14px;
}

#app .page[data-name=restaurant-menu] .restaurant-hero-facts {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
}

#app .page[data-name=restaurant-menu] .restaurant-hero-facts div {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: rgba(255, 255, 255, 0.07);
    border-radius: 999px;
    padding: 4px 10px;
    color: rgba(255, 255, 255, 0.85);
}

#app .page[data-name=restaurant-menu] .restaurant-hero-facts .fa-star {
    color: #ffc107;
}

#app .page[data-name=restaurant-menu] .restaurant-hero-poster .responsive-content {
    /* Лёгкое затемнение низа постера, чтобы мета-блок «прирастал» к фото */
    -webkit-mask-image: linear-gradient(180deg, #000 78%, rgba(0, 0, 0, 0.92));
    mask-image: linear-gradient(180deg, #000 78%, rgba(0, 0, 0, 0.92));
}

/* --- Панель корзины --- */

#app .restaurant-cart-checkout-button {
    background-image: var(--alg-teal-gradient);
    box-shadow: var(--alg-teal-glow);
}

#app .restaurant-cart-button-badge {
    background: rgba(255, 255, 255, 0.92);
}

/* --- Попап блюда --- */

#app .restaurant-product-popup-image img {
    border-radius: var(--alg-radius-lg);
}

#app .restaurant-product-popup h2 {
    font-weight: 800;
    letter-spacing: -0.01em;
}

#app .restaurant-product-popup p {
    line-height: 1.6;
}

/*
|------------------------------------------------------------------------------
| 8. Оформление заказа (restaurant-checkout)
|------------------------------------------------------------------------------
*/

/* Тёмные формы: общие переменные для чекаута и профиля */
.page[data-name=restaurant-checkout],
.page[data-name=profile-setup] {
    --f7-input-outline-border-color: rgba(255, 255, 255, 0.14);
    --f7-input-outline-focused-border-color: rgba(124, 196, 214, 0.9);
    --f7-list-item-border-color: transparent;
}

.page[data-name=restaurant-checkout] .item-input-outline.item-input-focused .item-input-wrap,
.page[data-name=profile-setup] .item-input-outline.item-input-focused .item-input-wrap {
    box-shadow: 0 0 0 4px rgba(14, 110, 135, 0.25);
}

/* Карточки секций: единый радиус (инлайн-стиль страницы задаёт 8px) */
#app .page[data-name=restaurant-checkout] .restaurant-checkout-list ul {
    border-radius: var(--alg-radius-lg);
    overflow: hidden;
}

#app .page[data-name=restaurant-checkout] .restaurant-checkout-list img {
    border-radius: 12px;
}

/* Переключатель Доставка / С собой */
.page[data-name=restaurant-checkout] .segmented-strong {
    --f7-segmented-strong-bg-color: rgba(255, 255, 255, 0.07);
    --f7-segmented-strong-button-active-bg-color: var(--alg-teal);
    --f7-button-text-color: rgba(255, 255, 255, 0.85);
    border-radius: var(--alg-radius-md);
    padding: 4px;
}

.page[data-name=restaurant-checkout] .segmented-strong .button {
    height: 44px;
    border-radius: var(--alg-radius-sm);
}

.page[data-name=restaurant-checkout] .segmented-strong .button-active {
    color: #fff;
}

.page[data-name=restaurant-checkout] .segmented-strong .button .icon {
    font-size: 20px;
    margin-right: 6px;
}

/* Кнопка оплаты */
#app .page[data-name=restaurant-checkout] .restaurant-checkout-bar .button-fill {
    background-image: var(--alg-teal-gradient);
    box-shadow: var(--alg-teal-glow);
}

/*
|------------------------------------------------------------------------------
| 9. Профиль / логин / отзыв / настройки
|------------------------------------------------------------------------------
*/

/* --- Профиль (profile-setup) --- */

.page[data-name=profile-setup] .profile-list ul {
    border-radius: var(--alg-radius-lg);
    overflow: hidden;
}

.page[data-name=profile-setup] .shape-circle {
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.12);
}

.page[data-name=profile-setup] .segmented-strong {
    --f7-segmented-strong-bg-color: rgba(255, 255, 255, 0.07);
    --f7-segmented-strong-button-active-bg-color: rgba(var(--f7-theme-color-rgb), 0.9);
    --f7-button-text-color: rgba(255, 255, 255, 0.85);
    border-radius: var(--alg-radius-md);
    padding: 4px;
}

.page[data-name=profile-setup] .segmented-strong .button {
    height: 44px;
    border-radius: var(--alg-radius-sm);
}

.page[data-name=profile-setup] .profile-gender-button.button-active {
    color: #fff;
}

/* --- Логин --- */

.page[data-name=login] .page-content {
    background-image: radial-gradient(120% 50% at 50% -10%, rgba(var(--f7-theme-color-rgb), 0.10), transparent 60%);
}

.page[data-name=login] h2 {
    font-size: 26px;
    font-weight: 800;
    letter-spacing: -0.02em;
}

.page[data-name=login] img[height="96"] {
    filter: drop-shadow(0 12px 24px rgba(var(--f7-theme-color-rgb), 0.25));
}

/* --- Отзыв (feedback) --- */

.page[data-name=feedback] .radio-media .radio-inner {
    filter: grayscale(0.55);
}

.page[data-name=feedback] .radio-media input:checked ~ .radio-inner {
    filter: grayscale(0);
}

.page[data-name=feedback] textarea {
    line-height: 1.5;
}

/* --- Настройки (settings) --- */

.page[data-name=settings] .media-list .item-media img {
    box-shadow: 0 0 0 3px rgba(var(--f7-theme-color-rgb), 0.15);
}

.page[data-name=settings] .media-list .item-title {
    font-size: 18px;
    font-weight: 700;
}

/*
|------------------------------------------------------------------------------
| 10. Контентные страницы (terms, privacy-policy, cookie-policy, info-*)
|------------------------------------------------------------------------------
*/

.page[data-name=terms] .block-strong.inset,
.page[data-name=privacy-policy] .block-strong.inset,
.page[data-name=cookie-policy] .block-strong.inset,
.page[data-name^=info-] .block-strong.inset {
    font-size: 15px;
    line-height: 1.65;
}

.page[data-name=terms] .block-strong.inset h1,
.page[data-name=privacy-policy] .block-strong.inset h1,
.page[data-name=cookie-policy] .block-strong.inset h1,
.page[data-name^=info-] .block-strong.inset h1,
.page[data-name=terms] .block-strong.inset h2,
.page[data-name=privacy-policy] .block-strong.inset h2,
.page[data-name=cookie-policy] .block-strong.inset h2,
.page[data-name^=info-] .block-strong.inset h2,
.page[data-name=terms] .block-strong.inset h3,
.page[data-name=privacy-policy] .block-strong.inset h3,
.page[data-name=cookie-policy] .block-strong.inset h3,
.page[data-name^=info-] .block-strong.inset h3 {
    font-weight: 700;
    letter-spacing: -0.01em;
    margin: 1.4em 0 0.5em;
    line-height: 1.3;
}

.page[data-name=terms] .block-strong.inset li,
.page[data-name=privacy-policy] .block-strong.inset li,
.page[data-name=cookie-policy] .block-strong.inset li,
.page[data-name^=info-] .block-strong.inset li {
    margin-bottom: 0.4em;
}

/* info.html жёстко ставит text-color-black — в тёмной теме текст должен светлеть */
.dark .page[data-name^=info-] .block-strong.text-color-black {
    color: var(--f7-text-color) !important;
}

/*
|------------------------------------------------------------------------------
| 11. Выбор языка
|------------------------------------------------------------------------------
*/

.page[data-name=select-language] .item-media img {
    border-radius: 12px;
    box-shadow: var(--alg-shadow-card-pressed);
}

.page[data-name=select-language] .item-radio input:checked ~ .item-inner .item-title {
    font-weight: 700;
}

/*
|------------------------------------------------------------------------------
| 12. Доступность и reduced motion
|------------------------------------------------------------------------------
*/

a:focus-visible,
button:focus-visible {
    outline: 2px solid rgba(var(--f7-theme-color-rgb), 0.6);
    outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
    .button,
    .cards-list.inset li,
    #tabbar .icons,
    #intro-swiper .swiper-slide,
    #app .restaurant-product-card,
    .page[data-name=feedback] .radio-media .radio-inner {
        transition: none !important;
    }

    .button.active-state,
    .cards-list.inset li:active,
    #app .restaurant-product-card:active {
        transform: none !important;
    }
}
