/* ==========================================================================
   KONOK — оформление витрины
   Загружается последним из css/autoload, перекрывает global.css
   Шрифты Nunito/Onest подключены <link>-ом в header.tpl (CCC режет @import)
   ========================================================================== */

:root {
    --brand: #E2640A;
    --brand-light: #F48C36;
    --brand-dark: #C25408;
    --brand-50: #FEF4EC;
    --brand-100: #FCE3CE;

    --ink: #23332B;
    --sand: #FBF8F2;
    --cream: #F2EDE3;
    --green: #2A4D3E;
    --light-green: #4A705F;
    --mint: #E7F0EA;
    --blue: #8CB8C9;
    --sky: #EAF2F5;
    --dark-blue: #1E3A5F;

    --surface: #FFFFFF;
    --muted: #F3F4F6;
    --line: var(--cream);

    --shadow-soft: 0 4px 24px -8px rgba(42, 77, 62, 0.12), 0 2px 8px -4px rgba(42, 77, 62, 0.08);
    --shadow-soft-lg: 0 18px 48px -16px rgba(42, 77, 62, 0.22), 0 6px 16px -8px rgba(42, 77, 62, 0.1);

    --r-md: 1rem;
    --r-2xl: 1.25rem;
    --r-3xl: 1.75rem;
    --r-4xl: 2.25rem;
}

/* --- Базовая типографика ------------------------------------------------- */
body {
    background: var(--sand);
    color: var(--ink);
    font-family: 'Onest', system-ui, -apple-system, 'Segoe UI', sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 15px;
    line-height: 1.55;
}

h1, h2, h3, h4, h5, h6,
.page-heading, .page-subheading {
    font-family: 'Nunito', system-ui, sans-serif;
    font-weight: 800;
    letter-spacing: -0.01em;
    color: var(--ink);
}

a { color: var(--brand-dark); }
a:hover, a:focus { color: var(--brand); text-decoration: none; }

::selection { background: var(--brand); color: #fff; }

::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: #F9F6F0; }
::-webkit-scrollbar-thumb { background: #d6cfc2; border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: #b8ae9c; }

.shadow-soft { box-shadow: var(--shadow-soft); }
.shadow-soft-lg { box-shadow: var(--shadow-soft-lg); }

@keyframes kn-ken-burns { 0% { transform: scale(1); } 100% { transform: scale(1.1); } }
@keyframes kn-float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }

/* ==========================================================================
   Кнопки
   ========================================================================== */
.btn,
.button,
.button-small,
.button-medium,
button.btn,
input[type="submit"].btn,
a.btn {
    font-family: 'Nunito', sans-serif;
    font-weight: 800;
    border-radius: 9999px;
    border: none;
    box-shadow: none;
    text-shadow: none;
    transition: all .2s ease;
    text-transform: none;
}

.btn.btn-primary,
.btn-primary,
.button.button-medium,
button.btn-primary,
button[type="submit"].btn,
input[type="submit"].btn-primary,
input.btn-primary,
#search_room_submit,
#search_room_submit.btn-primary,
.btn.button {
    background: var(--brand) !important;
    background-image: none !important;
    border-color: var(--brand) !important;
    color: #fff !important;
    box-shadow: var(--shadow-soft);
}
.btn.btn-primary:hover,
.btn-primary:hover,
.button.button-medium:hover,
button.btn-primary:hover,
button[type="submit"].btn:hover,
#search_room_submit:hover,
.btn.button:hover {
    background: var(--brand-light) !important;
    border-color: var(--brand-light) !important;
    color: #fff !important;
    box-shadow: var(--shadow-soft-lg);
}
.btn.btn-primary:active,
.btn-primary:active { transform: scale(.97); }

.btn.btn-default,
.btn-default {
    background: #fff;
    color: var(--ink);
    border: 2px solid var(--cream);
}
.btn.btn-default:hover,
.btn-default:hover { border-color: var(--brand); color: var(--brand); background: #fff; }

/* зелёная вторичная */
.btn-secondary,
.btn.btn-secondary {
    background: var(--green);
    color: #fff;
}
.btn-secondary:hover { background: var(--light-green); color: #fff; }

/* главные CTA бронирования/корзины — бренд-оранжевый (тема красит их зелёным) */
.book_now_submit,
button.book_now_submit,
.ajax_add_to_cart_button,
#add_to_cart .exclusive,
#submit_booking,
.proceed-to-checkout .btn,
.cart_navigation .button-medium {
    background: var(--brand) !important;
    background-image: none !important;
    border: none !important;
    color: #fff !important;
    border-radius: 9999px !important;
    font-family: 'Nunito', sans-serif;
    font-weight: 800;
    box-shadow: var(--shadow-soft);
}
.book_now_submit:hover,
.ajax_add_to_cart_button:hover,
#submit_booking:hover,
.proceed-to-checkout .btn:hover { background: var(--brand-light) !important; color: #fff !important; }

/* ==========================================================================
   Поля ввода
   ========================================================================== */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
input[type="number"],
input[type="search"],
textarea,
select,
.form-control {
    border-radius: var(--r-2xl);
    border: 1px solid var(--cream);
    background: #fff;
    color: var(--ink);
    box-shadow: none;
    transition: border-color .2s ease, box-shadow .2s ease;
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="tel"]:focus,
input[type="number"]:focus,
textarea:focus,
select:focus,
.form-control:focus {
    border-color: var(--brand);
    box-shadow: 0 0 0 3px var(--brand-100);
    outline: none;
}

/* ==========================================================================
   Хедер
   ========================================================================== */
#header { color: #fff; }

/* верхняя контактная полоса — прозрачная, поверх героя (как в макете) */
#header #nav-main {
    background: transparent !important;
    backdrop-filter: none !important;
    border-bottom: none !important;
    font-family: 'Onest', sans-serif;
    position: relative; z-index: 5;
}
#header #nav-main nav { display: flex; align-items: center; gap: 18px; padding: 8px 0; }
#header #nav-main .contact-item { color: rgba(255,255,255,.85); font-size: 13px; }
#header #nav-main .contact-item a { color: rgba(255,255,255,.85); }
#header #nav-main .contact-item a:hover { color: #fff; }

/* пилюли язык / валюта */
#languages-block-top .current,
#currencies-block-top .current,
#header #languages-block-top > span,
#header #currencies-block-top > span {
    background: rgba(255,255,255,.12) !important;
    border: none !important;
    border-radius: 9999px !important;
    color: #fff !important;
    font-weight: 600;
    padding: 6px 14px !important;
}
#languages-block-top .current:hover,
#currencies-block-top .current:hover { background: rgba(255,255,255,.22) !important; }

/* в макете нет e-mail/телефона в шапке — оставляем только язык/валюту справа */
#header .contact-item:has(a[href^="mailto"]),
#header .contact-item:has(a[href^="tel"]),
#header li:has(> a[href^="mailto"]),
#header li:has(> a[href^="tel"]) { display: none !important; }
#header #nav-main nav { justify-content: flex-end; }

/* логотип + меню */
#header .header-top { padding-top: 14px; }
#header #header_logo { width: auto !important; min-width: 150px; flex: 0 0 auto; }
#header #header_logo img.logo { height: 48px !important; width: auto !important; max-width: none !important; }
/* убрать дубль-ссылку «Наши объекты недвижимости», налезающую на логотип */
#header .our_properties_link { display: none !important; }

/* основное меню (HOOK_TOP) — на десктопе показываем горизонтально,
   мобильный «гамбургер»-drawer прячем */
@media (min-width: 768px) {
    /* раскладка главной строки: логотип слева, меню по центру, аккаунт/корзина справа */
    #header .header-top-menu { width: 100%; align-items: center; flex-direction: row !important; }
    #header .header-top-menu #menu_cont { order: 1; margin: 0 auto !important; }
    #header .header-top-menu .header_user_info { order: 2; }
    #header .header-top-menu #layer_cart,
    #header .header-top-menu .header-top-item:not(.header_user_info) { order: 3; }
    #header .header-top-menu > .header-top-item:empty { display: none !important; }

    .header-top-menu .nav_toggle { display: none !important; }
    .header-top-menu #menu_cont {
        position: static !important;
        left: auto !important; right: auto !important; top: auto !important;
        width: auto !important; max-width: none !important; height: auto !important;
        transform: none !important;
        visibility: visible !important; opacity: 1 !important;
        background: transparent !important;
        box-shadow: none !important;
        padding: 0 !important; margin: 0 !important;
        overflow: visible !important;
    }
    .header-top-menu #menu_cont .close_navbar { display: none !important; }
    .header-top-menu #menu_cont .row { margin: 0 !important; }
    .header-top-menu #menu_cont ul.wk-nav-style.visible-xs { display: none !important; }
    .header-top-menu #menu_cont ul.nav-pills.wk-nav-style:not(.visible-xs) {
        display: flex !important;
        align-items: center;
        gap: 4px;
        background: transparent !important;
        margin: 0; padding: 0;
        float: none;
    }
    .header-top-menu #menu_cont ul.nav-pills.wk-nav-style > li { float: none; margin: 0; border-bottom: none !important; }
    .header-top-menu #menu_cont ul.nav-pills.wk-nav-style > li > a {
        font-family: 'Nunito', sans-serif;
        font-weight: 700;
        color: #fff;
        background: transparent !important;
        padding: 8px 14px;
        border-radius: 9999px;
        white-space: nowrap;
    }
    .header-top-menu #menu_cont ul.nav-pills.wk-nav-style > li > a:hover,
    .header-top-menu #menu_cont ul.nav-pills.wk-nav-style > li.active > a {
        background: rgba(255,255,255,.15) !important;
        color: #fff;
    }
    /* в макете нет подчёркиваний под пунктами меню */
    .header-top-menu #menu_cont ul.nav-pills.wk-nav-style > li > a,
    .header-top-menu #menu_cont ul.nav-pills.wk-nav-style > li > a::after,
    .header-top-menu #menu_cont ul.nav-pills.wk-nav-style > li > a::before {
        border-bottom: none !important; text-decoration: none !important; box-shadow: none !important;
    }
    .header-top-menu #menu_cont ul.nav-pills.wk-nav-style > li > a::after { content: none !important; }
}

/* кнопка/иконка корзины и входа */
#header .header-top-menu .shopping_cart > a,
#header .header-top-menu .header-top-link,
#header .header-top-menu a.login {
    color: #fff;
    font-weight: 700;
}
#header .header-top-menu .shopping_cart .badge_style { background: var(--brand) !important; }

/* герой: заголовок и описание */
.header-desc-container .header-desc-primary { text-align: center; padding: 40px 0 24px; }
.header-desc-primary h1,
.header-desc-primary .page-heading {
    color: #fff;
    font-size: clamp(2rem, 5vw, 3.4rem);
    font-weight: 900;
    text-shadow: 0 2px 20px rgba(0,0,0,.35);
    margin-bottom: 14px;
}
.header-desc-primary p {
    color: rgba(255,255,255,.92);
    font-size: clamp(1rem, 2vw, 1.15rem);
    max-width: 720px;
    margin: 0 auto;
    text-shadow: 0 1px 12px rgba(0,0,0,.3);
}

/* ---- Hero-слайдер на главной (как в макете) ---- */
#index #header.kn-hero {
    background-size: cover !important;
    background-position: center !important;
    transition: background-image .8s ease-in-out;
}
#index .header-desc-container { display: flex; align-items: center; min-height: 56vh; }
#index .header-desc-wrapper { width: 100%; }
.kn-hero__badge {
    display: inline-block; background: var(--brand); color: #fff;
    font-family: 'Nunito', sans-serif; font-weight: 800; font-size: 14px;
    padding: 7px 18px; border-radius: 9999px; margin-bottom: 22px;
}
.kn-hero__title {
    color: #fff !important; font-family: 'Nunito', sans-serif;
    text-transform: none !important;
    font-size: clamp(2.8rem, 7vw, 5.5rem) !important; font-weight: 800 !important;
    line-height: 1.05; margin: 0 0 20px !important;
    text-shadow: 0 2px 24px rgba(0,0,0,.4); max-width: 820px; margin-left: auto !important; margin-right: auto !important;
}
.kn-hero__sub {
    color: rgba(255,255,255,.92) !important; font-size: clamp(1.05rem, 2.2vw, 1.5rem);
    max-width: 640px; margin: 0 auto !important; text-shadow: 0 1px 14px rgba(0,0,0,.35);
}
.kn-hero__dots { display: flex; justify-content: center; gap: 10px; margin-top: 32px; }
.kn-hero__dots button {
    height: 6px; width: 16px; border: none; padding: 0; border-radius: 9999px;
    background: rgba(255,255,255,.5); cursor: pointer; transition: all .4s ease;
}
.kn-hero__dots button:hover { background: rgba(255,255,255,.8); }
.kn-hero__dots button.is-active { width: 36px; background: var(--brand); }

/* затемнение фонового изображения героя для читаемости */
#header[style*="background-image"]::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(35,51,43,.45) 0%, rgba(35,51,43,.25) 40%, rgba(35,51,43,.6) 100%);
    pointer-events: none;
    z-index: 0;
}
#header[style*="background-image"] > * { position: relative; z-index: 1; }

/* ==========================================================================
   Панель поиска (плавающая карточка)
   ========================================================================== */
.header-rmsearch-container {
    background: transparent !important;
}
/* белая «пилюля» (SearchWidget.tsx: bg-white rounded-3xl p-3 shadow-soft-lg) */
.header-rmsearch-inner-wrapper {
    background: #fff;
    border-radius: var(--r-3xl);
    box-shadow: var(--shadow-soft-lg);
    border: 1px solid var(--cream);
    padding: 12px;
    margin-bottom: -40px;
}
.header-rmsearch-inner-wrapper label { display: none !important; }

/* ----- сегментированный ряд: 4 поля + кнопка (lg:grid-cols-[1fr 1fr 1.2fr 1.2fr auto]) ----- */
#search_form_fields_wrapper {
    display: grid !important;
    grid-template-columns: minmax(0,1fr) minmax(0,1fr) minmax(0,1.2fr) minmax(0,1.2fr) auto !important;
    gap: 0 !important;
    align-items: stretch;
}
#search_form_fields_wrapper > .form-group {
    grid-column: auto !important;
    position: relative;
    margin: 0 !important;
    min-height: 3.5rem;
    padding: 22px 34px 8px 46px;        /* место под лейбл сверху, иконку слева, шеврон справа */
    border-right: 1px solid var(--cream);
    border-radius: var(--r-2xl);
    display: flex; align-items: center;
    /* шеврон ChevronDown (gray-400) справа */
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") no-repeat right 14px center / 16px 16px;
}
#search_form_fields_wrapper > .form-group:hover { background-color: var(--sand); }
/* иконка поля (lucide, text-brand, 20px) */
#search_form_fields_wrapper > .form-group::before {
    content: ""; position: absolute; left: 16px; top: 50%; transform: translateY(-50%);
    width: 20px; height: 20px; background: no-repeat center / contain;
}
/* лейбл (text-xs font-bold text-gray-500 uppercase tracking-wider) */
#search_form_fields_wrapper > .form-group::after {
    position: absolute; left: 46px; top: 9px;
    font: 700 11px/1 'Onest', sans-serif; letter-spacing: .07em; text-transform: uppercase;
    color: #6b7280; white-space: nowrap;
}
/* per-segment: иконка + текст лейбла (как в Field label=) */
#search_form_fields_wrapper > .form-group:nth-child(1)::before { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23E2640A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 10c0 6-8 12-8 12s-8-6-8-12a8 8 0 0 1 16 0Z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E"); }
#search_form_fields_wrapper > .form-group:nth-child(1)::after  { content: "Расположение"; }
#search_form_fields_wrapper > .form-group:nth-child(2)::before { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23E2640A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 22V4a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v18Z'/%3E%3Cpath d='M6 12H4a2 2 0 0 0-2 2v6a2 2 0 0 0 2 2h2'/%3E%3Cpath d='M18 9h2a2 2 0 0 1 2 2v9a2 2 0 0 1-2 2h-2'/%3E%3Cpath d='M10 6h4'/%3E%3Cpath d='M10 10h4'/%3E%3Cpath d='M10 14h4'/%3E%3Cpath d='M10 18h4'/%3E%3C/svg%3E"); }
#search_form_fields_wrapper > .form-group:nth-child(2)::after  { content: "Отель"; }
#search_form_fields_wrapper > .form-group:nth-child(3)::before { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23E2640A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M8 2v4'/%3E%3Cpath d='M16 2v4'/%3E%3Crect width='18' height='18' x='3' y='4' rx='2'/%3E%3Cpath d='M3 10h18'/%3E%3C/svg%3E"); }
#search_form_fields_wrapper > .form-group:nth-child(3)::after  { content: "Заезд — Выезд"; }
#search_form_fields_wrapper > .form-group:nth-child(4)::before { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23E2640A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M16 21v-2a4 4 0 0 0-4-4H6a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='9' cy='7' r='4'/%3E%3Cpath d='M22 21v-2a4 4 0 0 0-3-3.87'/%3E%3Cpath d='M16 3.13a4 4 0 0 1 0 7.75'/%3E%3C/svg%3E"); }
#search_form_fields_wrapper > .form-group:nth-child(4)::after  { content: "Гости"; }
/* значение (block font-semibold text-nature-ink) — нейтрализуем рамки/фон полей и плагинов */
#search_form_fields_wrapper > .form-group .form-control,
#search_form_fields_wrapper > .form-group .chosen-container,
#search_form_fields_wrapper > .form-group .chosen-single,
#search_form_fields_wrapper > .form-group input[type="text"],
#search_form_fields_wrapper > .form-group .hotel-selector-wrap,
#search_form_fields_wrapper > .form-group > div {
    background: transparent !important; border: none !important; box-shadow: none !important;
    height: auto !important; min-height: 0 !important; padding: 0 !important; margin: 0 !important;
    width: 100% !important;
    font: 600 15px/1.3 'Onest', sans-serif !important; color: var(--ink) !important;
}
#search_form_fields_wrapper > .form-group .form-control::placeholder { color: #9ca3af; }
/* спрятать собственную стрелку chosen — у нас свой шеврон */
#search_form_fields_wrapper .chosen-single div { display: none !important; }
#search_form_fields_wrapper .chosen-single span { margin: 0 !important; }

/* кнопка «Найти» (Button size lg, rounded-2xl, brand, ~140px) */
#search_form_fields_wrapper > .search_room_submit_block {
    border-right: none !important; padding: 0 0 0 8px !important; background: none !important;
}
#search_form_fields_wrapper > .search_room_submit_block:hover { background: none !important; }
#search_form_fields_wrapper > .search_room_submit_block::before,
#search_form_fields_wrapper > .search_room_submit_block::after { display: none !important; }
#search_form_fields_wrapper > .search_room_submit_block #search_room_submit {
    width: 140px; height: 100%; min-height: 3.5rem;
    border-radius: var(--r-2xl) !important;
    display: flex; align-items: center; justify-content: center; gap: 8px;
    font-family: 'Nunito', sans-serif; font-weight: 800; font-size: 16px;
    text-transform: none !important; letter-spacing: 0 !important;
    white-space: nowrap;
}
/* иконка лупы (lucide Search, white) перед текстом */
#search_room_submit::before {
    content: ""; width: 20px; height: 20px; flex-shrink: 0;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E") no-repeat center / contain;
}

/* ==========================================================================
   Футер
   ========================================================================== */
.footer-container {
    background: #fff;
    border-top: 1px solid var(--cream);
    box-shadow: none;
    margin-top: 60px;
    color: #6b7280;
}
.footer-container #footer { padding-top: 50px; }
.footer-container .footer-section-heading p,
.footer-container .footer-section-heading,
.footer-container h4,
.footer-container .title_block {
    font-family: 'Nunito', sans-serif;
    font-weight: 800;
    color: var(--ink) !important;
    font-size: 17px;
    text-transform: none;
    margin-bottom: 8px;
}
/* убираем синие подчёркивания-разделители под заголовками */
.footer-container .footer-section-heading hr,
.footer-container hr { display: none; }
.footer-container a { color: #6b7280; }
.footer-container a:hover { color: var(--brand); }

/* соцсети — круглые пилюли */
#social_block a,
.footer-container #social_block li a {
    display: inline-flex; align-items: center; justify-content: center;
    width: 38px; height: 38px;
    border-radius: 9999px;
    background: var(--cream);
    color: var(--ink);
    transition: all .2s ease;
}
#social_block a:hover { background: var(--brand); color: #fff; }

/* новостная подписка */
#blocknewsletter input[type="text"],
#blocknewsletter input[type="email"],
#blocknewsletter input {
    border-radius: 9999px 0 0 9999px;
    border-right: none;
    background: #fff !important;
    color: var(--ink);
    border: 1px solid var(--cream);
}
#blocknewsletter .btn,
#blocknewsletter button {
    border-radius: 0 9999px 9999px 0;
    background: var(--brand);
    color: #fff;
}

/* ==========================================================================
   Карточки/блоки общего вида
   ========================================================================== */
.columns-container { background: var(--sand); }

/* ==========================================================================
   Секции главной (модуль konokhomeblocks)
   ========================================================================== */
.kn-container { max-width: 1200px; margin: 0 auto; padding: 0 20px; }
.kn-section { margin-top: 90px; }
.kn-stats-section { margin-top: 70px; }

.kn-heading { max-width: 640px; margin-bottom: 36px; }
.kn-heading--center { margin-left: auto; margin-right: auto; text-align: center; }
.kn-eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    color: var(--brand); font-family: 'Nunito',sans-serif; font-weight: 800;
    font-size: 13px; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 12px;
}
.kn-eyebrow::before { content: ""; width: 24px; height: 2px; background: var(--brand); border-radius: 2px; display: inline-block; }
.kn-heading--center .kn-eyebrow::before { display: none; }
.kn-title { font-family:'Nunito',sans-serif; font-weight: 800; font-size: clamp(1.7rem, 3vw, 2.4rem); color: var(--ink); margin: 0 0 12px; line-height: 1.15; }
.kn-sub { color: #5b6b63; font-size: 1.05rem; line-height: 1.6; margin: 0; }

/* статистика */
.kn-stats {
    background: #fff; border: 1px solid var(--cream); border-radius: var(--r-3xl);
    box-shadow: var(--shadow-soft);
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; padding: 36px 32px;
}
.kn-stat { text-align: center; }
.kn-stat__val { font-family:'Nunito',sans-serif; font-weight: 800; font-size: clamp(1.7rem, 3vw, 2.3rem); color: var(--brand); line-height: 1; margin-bottom: 6px; }
.kn-stat__lbl { color: #5b6b63; font-size: .92rem; }

/* направления */
.kn-cats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.kn-cat {
    position: relative; display: block; height: 280px; border-radius: var(--r-3xl);
    overflow: hidden; background-size: cover; background-position: center;
    box-shadow: var(--shadow-soft); text-decoration: none;
    transition: transform .4s ease, box-shadow .4s ease;
}
.kn-cat::after { content:""; position:absolute; inset:0; background: linear-gradient(to top, rgba(0,0,0,.72) 0%, rgba(0,0,0,.1) 45%, transparent 75%); }
.kn-cat:hover { transform: translateY(-4px); box-shadow: var(--shadow-soft-lg); }
.kn-cat__icon {
    position: absolute; top: 16px; left: 16px; z-index: 2;
    width: 44px; height: 44px; border-radius: var(--r-md);
    background: rgba(255,255,255,.9); backdrop-filter: blur(4px);
    display: flex; align-items: center; justify-content: center; color: var(--brand); font-size: 19px;
}
.kn-cat__body { position: absolute; left: 0; right: 0; bottom: 0; z-index: 2; padding: 20px; color: #fff; }
.kn-cat__title { display:block; font-family:'Nunito',sans-serif; font-weight: 800; font-size: 1.3rem; }
.kn-cat__desc { display:flex; align-items:center; gap:6px; color: rgba(255,255,255,.85); font-size: .92rem; margin-top: 2px; }
.kn-cat:hover .kn-cat__desc .fa-arrow-right { transform: translateX(2px); }
.kn-cat__desc .fa-arrow-right { transition: transform .2s ease; }

/* шаги */
.kn-steps-section { background: var(--mint); padding: 70px 0; margin-left: 0; margin-right: 0; }
.kn-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 36px; margin-top: 44px; }
.kn-step { text-align: center; }
.kn-step__icon {
    position: relative; width: 80px; height: 80px; margin: 0 auto 20px;
    border-radius: var(--r-3xl); background: #fff; box-shadow: var(--shadow-soft);
    display: flex; align-items: center; justify-content: center; color: var(--green); font-size: 30px;
}
.kn-step__num {
    position: absolute; top: -8px; right: -8px; width: 28px; height: 28px;
    border-radius: 9999px; background: var(--brand); color: #fff; font-family:'Nunito';
    font-weight: 800; font-size: 14px; display: flex; align-items: center; justify-content: center;
}
.kn-step__title { font-family:'Nunito',sans-serif; font-weight: 800; font-size: 1.25rem; color: var(--ink); margin: 0 0 8px; }
.kn-step__desc { color: #5b6b63; max-width: 280px; margin: 0 auto; }

/* ---- бейдж-«пилюля» (eyebrow chip) ---- */
.kn-chip {
    display: inline-flex; align-items: center; gap: 6px;
    background: var(--brand-50); color: var(--brand-dark);
    font-family: 'Nunito', sans-serif; font-weight: 800; font-size: 12px;
    padding: 6px 14px; border-radius: 9999px; margin-bottom: 14px;
}

/* ---- промо-баннер «Спецпредложение» (зелёный) ---- */
.kn-promo {
    position: relative; overflow: hidden;
    background: var(--green); border-radius: var(--r-4xl);
    box-shadow: var(--shadow-soft-lg);
}
.kn-promo__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: .2; mix-blend-mode: overlay; }
.kn-promo__inner {
    position: relative; z-index: 2; padding: clamp(32px, 5vw, 64px);
    display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 28px;
}
.kn-promo__text { max-width: 640px; color: #fff; }
.kn-promo .kn-chip { background: rgba(255,255,255,.2); color: #fff; }
.kn-promo__title { font-family:'Nunito'; font-weight: 800; font-size: clamp(1.7rem, 4vw, 3rem); margin: 0 0 14px; color: #fff; line-height: 1.1; }
.kn-promo__sub { color: rgba(242,237,227,.9); font-size: 1.15rem; margin: 0; }

/* ---- популярные направления (картки готелів) ---- */
.kn-hotels-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; margin-bottom: 36px; }
.kn-hotels { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.kn-hotel {
    background: #fff; border: 1px solid var(--cream); border-radius: var(--r-3xl);
    box-shadow: var(--shadow-soft); overflow: hidden; display: block; text-decoration: none;
    transition: transform .3s ease, box-shadow .3s ease;
}
.kn-hotel:hover { transform: translateY(-4px); box-shadow: var(--shadow-soft-lg); }
.kn-hotel__img { display: block; position: relative; height: 190px; overflow: hidden; }
.kn-hotel__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.kn-hotel:hover .kn-hotel__img img { transform: scale(1.1); }
.kn-hotel__body { display: block; }
.kn-hotel__region, .kn-hotel__name, .kn-hotel__loc, .kn-hotel__price { display: block; }
.kn-hotel__rating {
    position: absolute; top: 12px; right: 12px; background: rgba(255,255,255,.92); backdrop-filter: blur(4px);
    padding: 4px 10px; border-radius: 9999px; font-family:'Nunito'; font-weight: 800; font-size: .85rem;
    display: inline-flex; align-items: center; gap: 4px; color: var(--ink);
}
.kn-hotel__rating .icon-star { color: var(--brand); }
.kn-hotel__body { padding: 18px 20px; }
.kn-hotel__region { font-family:'Nunito'; font-weight: 800; color: var(--brand); font-size: 11px; text-transform: uppercase; letter-spacing: .06em; margin-bottom: 6px; }
.kn-hotel__name { font-family:'Nunito'; font-weight: 800; color: var(--ink); font-size: 1.15rem; margin: 0 0 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.kn-hotel__loc { color: #6b7280; font-size: .9rem; display: flex; align-items: center; gap: 5px; margin: 0 0 14px; }
.kn-hotel__price { padding-top: 14px; border-top: 1px solid var(--cream); color: #6b7280; font-size: .9rem; }
.kn-hotel__price b { font-family:'Nunito'; font-weight: 800; font-size: 1.15rem; color: var(--ink); }

/* ---- горящие предложения ---- */
.kn-deals { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 36px; }
.kn-deal {
    background: #fff; border: 1px solid var(--cream); border-radius: var(--r-3xl);
    box-shadow: var(--shadow-soft); overflow: hidden; transition: transform .3s ease, box-shadow .3s ease;
}
.kn-deal:hover { transform: translateY(-4px); box-shadow: var(--shadow-soft-lg); }
.kn-deal__img { position: relative; height: 200px; overflow: hidden; }
.kn-deal__img img { width: 100%; height: 100%; object-fit: cover; }
.kn-deal__badge {
    position: absolute; top: 16px; left: 16px; background: var(--brand); color: #fff;
    font-family:'Nunito'; font-weight: 800; font-size: .85rem; padding: 5px 12px; border-radius: 9999px;
    display: inline-flex; align-items: center; gap: 5px; box-shadow: var(--shadow-soft);
}
.kn-deal__body { padding: 22px 24px; }
.kn-deal__name { font-family:'Nunito'; font-weight: 800; color: var(--ink); font-size: 1.25rem; margin: 0 0 4px; }
.kn-deal__loc { color: #6b7280; font-size: .9rem; display: flex; align-items: center; gap: 5px; margin: 0 0 16px; }
.kn-deal__foot { display: flex; align-items: flex-end; justify-content: space-between; gap: 12px; }
.kn-deal__old { color: #9ca3af; text-decoration: line-through; font-size: .85rem; }
.kn-deal__new { font-family:'Nunito'; font-weight: 800; font-size: 1.5rem; color: var(--brand); }

/* ---- почему KONOK (переваги) ---- */
.kn-benefits { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-top: 44px; }
.kn-benefit {
    background: #fff; border: 1px solid var(--cream); border-radius: var(--r-3xl);
    box-shadow: var(--shadow-soft); padding: 28px; text-align: center;
    transition: transform .3s ease, box-shadow .3s ease;
}
.kn-benefit:hover { transform: translateY(-4px); box-shadow: var(--shadow-soft-lg); }
.kn-benefit__icon {
    width: 64px; height: 64px; margin: 0 auto 18px; border-radius: var(--r-2xl);
    display: flex; align-items: center; justify-content: center; font-size: 26px;
}
.kn-benefit__icon.tone-green { background: var(--mint); color: var(--green); }
.kn-benefit__icon.tone-brand { background: var(--brand-50); color: var(--brand); }
.kn-benefit__icon.tone-blue { background: var(--sky); color: var(--dark-blue); }
.kn-benefit h3 { font-family:'Nunito'; font-weight: 800; color: var(--ink); font-size: 1.1rem; margin: 0 0 8px; }
.kn-benefit p { color: #6b7280; font-size: .92rem; margin: 0; }

/* ---- отзывы гостей ---- */
.kn-reviews { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 36px; }
.kn-review {
    background: #fff; border: 1px solid var(--cream); border-radius: var(--r-3xl);
    box-shadow: var(--shadow-soft); padding: 28px; display: flex; flex-direction: column;
}
.kn-review__q { font-size: 28px; color: rgba(226,100,10,.3); line-height: 1; margin-bottom: 12px; font-family: Georgia, serif; }
.kn-review__text { color: var(--ink); line-height: 1.6; flex-grow: 1; margin: 0; }
.kn-review__stars { color: var(--brand); margin: 18px 0 14px; letter-spacing: 2px; }
.kn-review__author { display: flex; align-items: center; gap: 12px; padding-top: 16px; border-top: 1px solid var(--cream); }
.kn-review__author img { width: 44px; height: 44px; border-radius: 9999px; object-fit: cover; }
.kn-review__name { font-family:'Nunito'; font-weight: 800; color: var(--ink); }
.kn-review__city { color: #9ca3af; font-size: .85rem; }

/* ---- блок для отельеров (оранжевый) ---- */
.kn-partner {
    position: relative; overflow: hidden;
    background: var(--brand); border-radius: var(--r-4xl);
    box-shadow: var(--shadow-soft-lg);
}
.kn-partner__inner {
    position: relative; z-index: 2; display: grid; grid-template-columns: 1fr 1fr;
    gap: 36px; align-items: center; padding: clamp(32px, 4vw, 56px);
}
.kn-partner__text { color: #fff; }
.kn-partner .kn-chip { background: rgba(255,255,255,.2); color: #fff; }
.kn-partner__title { font-family:'Nunito'; font-weight: 800; font-size: clamp(1.7rem, 4vw, 3rem); margin: 0 0 14px; color: #fff; line-height: 1.1; }
.kn-partner__sub { color: rgba(255,255,255,.9); font-size: 1.1rem; margin: 0 0 24px; max-width: 460px; }
.kn-partner__feats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-bottom: 26px; }
.kn-partner__feat { display: flex; align-items: center; gap: 8px; color: #fff; font-family:'Nunito'; font-weight: 700; font-size: .85rem; }
.kn-partner__feat i { width: 36px; height: 36px; border-radius: var(--r-md); background: rgba(255,255,255,.2); display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.kn-partner__media { position: relative; min-height: 300px; }
.kn-partner__media > img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; border-radius: var(--r-3xl); box-shadow: var(--shadow-soft-lg); }
.kn-partner__badge {
    position: absolute; bottom: 24px; left: -16px; background: #fff; color: var(--ink);
    padding: 14px 18px; border-radius: var(--r-2xl); box-shadow: var(--shadow-soft-lg);
    display: flex; align-items: center; gap: 12px; z-index: 3;
}
.kn-partner__badge .kn-partner__badge-ic { width: 44px; height: 44px; border-radius: var(--r-md); background: var(--brand-50); color: var(--brand); display: flex; align-items: center; justify-content: center; font-size: 20px; }
.kn-partner__badge b { display: block; font-family:'Nunito'; font-weight: 800; color: var(--ink); }
.kn-partner__badge span { font-size: .8rem; color: #9ca3af; }
.kn-partner__bubble { position: absolute; border-radius: 9999px; background: rgba(255,255,255,.1); pointer-events: none; }
.kn-partner__bubble--1 { width: 280px; height: 280px; right: -64px; top: -64px; }
.kn-partner__bubble--2 { width: 200px; height: 200px; left: -40px; bottom: -40px; }

@media (max-width: 991px) {
    .kn-hotels { grid-template-columns: repeat(2, 1fr); }
    .kn-deals, .kn-benefits, .kn-reviews { grid-template-columns: 1fr; }
    .kn-partner__inner { grid-template-columns: 1fr; }
    .kn-partner__media { display: none; }
}
@media (max-width: 600px) {
    .kn-hotels { grid-template-columns: 1fr; }
    .kn-partner__feats { grid-template-columns: 1fr; }
}

/* финальный призыв */
.kn-cta {
    position: relative; border-radius: var(--r-4xl); overflow: hidden;
    background-color: var(--dark-blue); background-size: cover; background-position: center;
    text-align: center; padding: 80px 24px;
}
.kn-cta::before { content:""; position:absolute; inset:0; background: rgba(30,58,95,.7); }
.kn-cta__inner { position: relative; z-index: 2; max-width: 640px; margin: 0 auto; color: #fff; }
.kn-cta__spark { font-size: 34px; color: var(--brand-light); margin-bottom: 16px; display: inline-block; }
.kn-cta__title { font-family:'Nunito',sans-serif; font-weight: 800; font-size: clamp(1.8rem, 4vw, 3rem); margin: 0 0 14px; color: #fff; }
.kn-cta__text { color: rgba(255,255,255,.85); font-size: 1.1rem; margin: 0 0 28px; }

/* кнопки секций */
.kn-btn { display: inline-flex; align-items: center; gap: 8px; padding: 13px 26px; font-size: 1rem; }
.kn-btn--white { background: #fff !important; color: var(--green) !important; }
.kn-btn--white:hover { background: var(--cream) !important; }

@media (max-width: 991px) {
    .kn-cats { grid-template-columns: repeat(2, 1fr); }
    .kn-partner { grid-template-columns: 1fr; padding: 36px; }
    .kn-partner__media { min-height: 220px; }
}
@media (max-width: 767px) {
    .kn-section { margin-top: 60px; }
    .kn-stats { grid-template-columns: repeat(2, 1fr); padding: 28px 20px; }
    .kn-steps { grid-template-columns: 1fr; gap: 28px; }
}

/* ==========================================================================
   Внутренние страницы (каталог, отель, номер, кабинет, формы, CMS)
   ========================================================================== */

/* контейнер контента — внутренние страницы не на тёмном герое */
body:not(#index) .columns-container { background: var(--sand); padding-top: 24px; }
body:not(#index) #header {
    background: var(--green) !important;
    background-image: none !important;
    height: auto !important;
    min-height: 0 !important;
}
body:not(#index) #header .header-desc-container,
body:not(#index) #header .header-rmsearch-container { display: none; }
body:not(#index) #header[style*="background-image"]::before { display: none; }

/* заголовки страниц */
.page-heading,
.page-subheading,
h1.title-container,
.our-properties-header,
.title-container h1 {
    font-family: 'Nunito', sans-serif !important;
    font-weight: 800;
    color: var(--ink);
}
.page-heading {
    border: none;
    font-size: 1.9rem;
    margin-bottom: 22px;
}

/* хлебные крошки */
.breadcrumb {
    background: transparent;
    padding: 12px 0;
    margin-bottom: 10px;
    font-size: .9rem;
}
.breadcrumb a { color: var(--light-green); }
.breadcrumb a:hover { color: var(--brand); }

/* универсальная карточка-обёртка для блоков контента */
.block .block_content,
.page-content,
#center_column .box,
.cms_content,
fieldset.account_creation,
.std,
.address,
.addresses .address {
    background: #fff;
    border: 1px solid var(--cream);
    border-radius: var(--r-2xl);
    box-shadow: var(--shadow-soft);
}

/* ---- our-properties (список отелей) ---- */
.our-properties-desc { color: #5b6b63; max-width: 820px; margin: 0 auto 30px; }
.hotel-address-container {
    background: #fff;
    border: 1px solid var(--cream);
    border-radius: var(--r-3xl);
    box-shadow: var(--shadow-soft);
    overflow: hidden;
    padding: 0;
    transition: transform .25s ease, box-shadow .25s ease;
    display: flex;
}
.hotel-address-container:hover { transform: translateY(-3px); box-shadow: var(--shadow-soft-lg); }
.hotel-address-container .col-xs-5 { padding: 0; }
.hotel-address-container .col-xs-5 img { width: 100%; height: 100%; object-fit: cover; min-height: 190px; }
.hotel-address-container .col-xs-7 { padding: 22px 24px; }
.hotel-address-container .col-xs-7 p:first-child {
    font-family: 'Nunito', sans-serif; font-weight: 800; font-size: 1.25rem; color: var(--ink); margin-bottom: 8px;
}
.hotel-address-container .col-xs-7 p { color: #6b7280; font-size: .92rem; margin-bottom: 4px; }
.hotel-address-container a[href*="category"],
.hotel-address-container .btn {
    display: inline-block; margin-top: 12px;
    background: var(--brand); color: #fff !important;
    padding: 9px 18px; border-radius: 9999px; font-family: 'Nunito'; font-weight: 700; font-size: .9rem;
}
.hotel-address-container a[href*="category"]:hover { background: var(--brand-light); }

/* ---- список номеров / товаров (product_list) ---- */
.product_list .product-container,
.product_list li.ajax_block_product,
ul.product_list > li {
    background: #fff;
    border: 1px solid var(--cream) !important;
    border-radius: var(--r-3xl);
    box-shadow: var(--shadow-soft);
    overflow: hidden;
    transition: transform .25s ease, box-shadow .25s ease;
}
.product_list .product-container:hover { transform: translateY(-3px); box-shadow: var(--shadow-soft-lg); }
.product-name,
.product_list .product-name a,
s.product-name {
    font-family: 'Nunito', sans-serif !important;
    font-weight: 800;
    color: var(--ink) !important;
}
.content_price .price,
.our_price_display,
#our_price_display .price,
span.price,
.price {
    color: var(--brand);
    font-family: 'Nunito', sans-serif;
    font-weight: 800;
}

/* ---- карточка номера в отеле (room type list) ---- */
.room_type_container,
.room-type-info,
.product-room-type {
    background: #fff;
    border: 1px solid var(--cream);
    border-radius: var(--r-3xl);
    box-shadow: var(--shadow-soft);
    overflow: hidden;
}

/* ---- страница номера (product) ---- */
#product #center_column .primary_block,
#product .product-information,
.pb-center-column,
.pb-right-column {
    background: transparent;
}
#product .pb-left-column img,
#product #image-block img {
    border-radius: var(--r-3xl);
}

/* ---- формы / авторизация ---- */
.form-group label,
.form-control-label,
label.required {
    font-weight: 600;
    color: var(--ink);
}
fieldset, .account_creation, .box {
    padding: 26px;
}
#authentication #center_column .box,
.page-authentication .box {
    background: #fff;
    border: 1px solid var(--cream);
    border-radius: var(--r-3xl);
    box-shadow: var(--shadow-soft);
}

/* ---- личный кабинет ---- */
.my-account #center_column ul.footer_links,
.myaccount-link-list,
#center_column .myaccount-link-list {
    list-style: none;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 18px;
}
.myaccount-link-list li,
.my-account .links li {
    background: #fff;
    border: 1px solid var(--cream);
    border-radius: var(--r-2xl);
    box-shadow: var(--shadow-soft);
    transition: transform .2s ease, box-shadow .2s ease;
}
.myaccount-link-list li:hover,
.my-account .links li:hover { transform: translateY(-3px); box-shadow: var(--shadow-soft-lg); }
.myaccount-link-list li a,
.my-account .links li a {
    display: flex !important; align-items: center; gap: 14px;
    padding: 18px 20px !important; color: var(--ink) !important;
    font-family: 'Nunito'; font-weight: 700; border: none !important; height: auto !important;
}
.myaccount-link-list li a i {
    border: none !important; background: var(--brand-50) !important; color: var(--brand) !important;
    width: 46px !important; height: 46px !important; min-width: 46px;
    border-radius: var(--r-md) !important; display: inline-flex !important;
    align-items: center; justify-content: center; font-size: 19px; margin: 0 !important; float: none !important;
}
.myaccount-link-list li a span {
    border: none !important; background: transparent !important; color: var(--ink) !important;
    padding: 0 !important; width: auto !important; display: inline !important; text-transform: none;
}

/* ---- таблицы ---- */
table.std, table.table, .table {
    background: #fff;
    border-radius: var(--r-2xl);
    overflow: hidden;
    border: 1px solid var(--cream);
}
table.std th, table.table thead th, .table thead th {
    background: var(--mint);
    color: var(--ink);
    font-family: 'Nunito'; font-weight: 700;
    border: none;
}

/* ---- оформление заказа (order-opc) ---- */
.opc-btn-primary,
.opc-button-small.opc-btn-primary,
button.opc-btn-primary {
    background: var(--brand) !important;
    background-image: none !important;
    border: none !important;
    color: #fff !important;
    border-radius: 9999px !important;
    font-family: 'Nunito', sans-serif;
    font-weight: 800;
}
.opc-btn-primary:hover { background: var(--brand-light) !important; }
/* итоговая сумма — бренд, не синий */
.opc-summary .opc-total,
.opc-summary-total,
.cart-summary-total,
.cart_total_values,
#total_price,
#order-opc .opc-total span,
.opc-price-total { color: var(--brand) !important; font-family: 'Nunito',sans-serif; font-weight: 800; }
/* карточки секций оформления */
.opc-block, .opc-summary, .opc-coupon-block, #order_opc_summary {
    background: #fff;
    border: 1px solid var(--cream);
    border-radius: var(--r-2xl);
    box-shadow: var(--shadow-soft);
}

/* ---- корзина ---- */
#cart_summary, #order-detail-content, .cart_navigation {
    background: transparent;
}
#cart_summary {
    background: #fff;
    border: 1px solid var(--cream);
    border-radius: var(--r-2xl);
    box-shadow: var(--shadow-soft);
    overflow: hidden;
}

/* ---- CMS ---- */
#cms .rte, .cms-content, #content .rte {
    background: #fff;
    border: 1px solid var(--cream);
    border-radius: var(--r-3xl);
    box-shadow: var(--shadow-soft);
    padding: 36px 40px;
    line-height: 1.7;
}
#cms .rte h2, #cms .rte h3 { font-family: 'Nunito'; font-weight: 800; color: var(--ink); }

/* ---- контакты ---- */
#contact-form .form-group { margin-bottom: 16px; }

/* ---- 404 ---- */
#pagenotfound #center_column, .pagenotfound {
    text-align: center;
}

/* ---- CMS: аккордеон FAQ (нативный details, без JS) ---- */
.kn-cms { max-width: 820px; margin: 0 auto; }
.kn-faq details {
    background: #fff; border: 1px solid var(--cream); border-radius: var(--r-2xl);
    box-shadow: var(--shadow-soft); margin-bottom: 14px; overflow: hidden;
}
.kn-faq summary {
    list-style: none; cursor: pointer; padding: 18px 22px;
    font-family: 'Nunito', sans-serif; font-weight: 800; color: var(--ink); font-size: 1.05rem;
    display: flex; align-items: center; justify-content: space-between; gap: 16px;
}
.kn-faq summary::-webkit-details-marker { display: none; }
.kn-faq summary::after {
    content: "\f107"; font-family: 'FontAwesome'; color: var(--brand);
    background: var(--brand-50); width: 30px; height: 30px; border-radius: 9999px;
    display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; transition: transform .2s ease;
}
.kn-faq details[open] summary::after { transform: rotate(180deg); }
.kn-faq details > div, .kn-faq .kn-faq__a { padding: 0 22px 20px; color: #5b6b63; line-height: 1.65; }

/* ---- CMS: сетка преимуществ / интеграций ---- */
.kn-feature-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 30px;
}
.kn-feature-card {
    background: #fff; border: 1px solid var(--cream); border-radius: var(--r-3xl);
    box-shadow: var(--shadow-soft); padding: 26px; transition: transform .25s ease, box-shadow .25s ease;
}
.kn-feature-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-soft-lg); }
.kn-feature-card__icon {
    width: 54px; height: 54px; border-radius: var(--r-md);
    background: var(--brand-50); color: var(--brand);
    display: flex; align-items: center; justify-content: center; font-size: 22px; margin-bottom: 16px;
}
.kn-feature-card h3 { font-family: 'Nunito'; font-weight: 800; color: var(--ink); font-size: 1.15rem; margin: 0 0 8px; }
.kn-feature-card p { color: #5b6b63; font-size: .95rem; margin: 0; }

.kn-cta-card {
    background: #fff; border: 1px solid var(--cream); border-radius: var(--r-3xl);
    box-shadow: var(--shadow-soft); padding: 40px; text-align: center; max-width: 720px; margin: 40px auto 0;
}
.kn-cta-card h3 { font-family: 'Nunito'; font-weight: 800; color: var(--ink); font-size: 1.6rem; margin: 0 0 10px; }
.kn-cta-card p { color: #5b6b63; margin: 0 0 22px; }

.kn-cms-section { margin-top: 50px; }

@media (max-width: 991px) { .kn-feature-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .kn-feature-grid { grid-template-columns: 1fr; } }

/* ---- пагинация ---- */
.pagination > li > a, .pagination > li > span {
    border-radius: 9999px !important;
    margin: 0 3px;
    border: 1px solid var(--cream);
    color: var(--ink);
}
.pagination > li > a.active,
.pagination > .active > a,
.pagination > li > a:hover {
    background: var(--brand) !important;
    border-color: var(--brand) !important;
    color: #fff !important;
}

@media (max-width: 767px) {
    #header #nav-main nav { flex-wrap: wrap; gap: 10px; }
    .header-rmsearch-inner-wrapper { margin-bottom: -20px; padding: 14px; }
    /* мобильная кнопка-гамбургер — в стиле бренда, не синяя */
    .header-top-menu .nav_toggle {
        background: rgba(255,255,255,.18) !important;
        border: 1px solid rgba(255,255,255,.3) !important;
        border-radius: 12px !important;
        padding: 9px 11px !important;
    }
    .header-top-menu .nav_toggle .icon-bar { background: #fff !important; }
    /* лишняя ссылка «Наши объекты» рядом с лого — прячем на мобильном */
    #header .our_properties_link { display: none !important; }
    /* мобильное меню-drawer: оранжевые акценты вместо синих */
    #menu_cont .close_navbar { background: var(--brand) !important; }
    #menu_cont .nav-pills > li > a { color: var(--ink) !important; }
    /* секции главной — внутренние отступы поменьше */
    .kn-container { padding: 0 16px; }
    .kn-partner { padding: 28px 22px; }
    .kn-cta { padding: 56px 20px; }
}

/* ==========================================================================
   Универсальный футер KONOK (все внутренние страницы) — как в макете
   ========================================================================== */
body:not(#index) .footer-container,
body:not(#index) #facebook_block { display: none !important; }

.kn-footer {
    background: #fff;
    border-top: 1px solid var(--cream);
    margin-top: 70px;
    padding: 64px 0 32px;
    font-family: 'Onest', sans-serif;
}
.kn-footer__inner { max-width: 1200px; margin: 0 auto; padding: 0 20px; }
.kn-footer__cols {
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr 1.1fr;
    gap: 40px;
    margin-bottom: 48px;
}
.kn-footer__brand p { color: #6b7280; font-size: 14px; line-height: 1.65; margin: 0; }
.kn-footer__logo { height: 36px; width: auto; object-fit: contain; margin-bottom: 20px; display: block; }
.kn-footer__col h4 {
    font-family: 'Nunito', sans-serif; font-weight: 800;
    font-size: 18px; color: var(--ink); margin: 0 0 16px;
}
.kn-footer__col ul { list-style: none; margin: 0; padding: 0; }
.kn-footer__col li { margin-bottom: 12px; }
.kn-footer__col a { color: #6b7280; font-size: 14px; transition: color .2s ease; }
.kn-footer__col a:hover { color: var(--brand); }
.kn-footer__contacts li { color: #6b7280; font-size: 14px; }
.kn-footer__bottom {
    border-top: 1px solid var(--cream);
    padding-top: 28px;
    display: flex; align-items: center; justify-content: space-between;
    flex-wrap: wrap; gap: 16px;
}
.kn-footer__bottom p { color: #9ca3af; font-size: 14px; margin: 0; }
.kn-footer__social { display: flex; gap: 12px; }
.kn-footer__social a {
    display: inline-flex; align-items: center; justify-content: center;
    width: 36px; height: 36px; border-radius: 9999px;
    background: var(--cream); color: var(--ink); transition: all .2s ease;
}
.kn-footer__social a:hover { background: var(--brand); color: #fff; }
@media (max-width: 767px) {
    .kn-footer__cols { grid-template-columns: 1fr 1fr; gap: 28px; }
    .kn-footer__brand { grid-column: 1 / -1; }
}

/* ==========================================================================
   Хедер: язык/валюта — напівпрозорі пілюлі як у макеті (внутрішні сторінки)
   ========================================================================== */
#header #nav-main #currencies-block-top .btn.dropdown-toggle,
#header #nav-main #languages-block-top .btn.dropdown-toggle {
    background: rgba(255,255,255,.14) !important;
    background-image: none !important;
    border: none !important;
    text-shadow: none !important;
    border-radius: 9999px !important;
    color: #fff !important;
    font-family: 'Onest', sans-serif !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    padding: 6px 14px !important;
    box-shadow: none !important;
    line-height: 1.2 !important;
    min-height: 0 !important;
    transition: background .2s ease;
}
#header #nav-main #currencies-block-top .btn.dropdown-toggle:hover,
#header #nav-main #languages-block-top .btn.dropdown-toggle:hover,
#header #nav-main #currencies-block-top .btn.dropdown-toggle:focus,
#header #nav-main #languages-block-top .btn.dropdown-toggle:focus {
    background: rgba(255,255,255,.22) !important;
    color: #fff !important;
}
#header #nav-main #currencies-block-top .caret,
#header #nav-main #languages-block-top .caret { color: rgba(255,255,255,.75); }
#header #nav-main #currencies-block-top .dropdown-menu,
#header #nav-main #languages-block-top .dropdown-menu {
    border: 1px solid var(--cream); border-radius: 14px;
    box-shadow: 0 12px 30px rgba(0,0,0,.12); padding: 6px; margin-top: 8px;
}
#header #nav-main #currencies-block-top .dropdown-menu > li > a,
#header #nav-main #languages-block-top .dropdown-menu > li > a {
    color: var(--ink); border-radius: 9px; padding: 7px 12px; font-size: 13px;
}
#header #nav-main #currencies-block-top .dropdown-menu > li > a:hover,
#header #nav-main #languages-block-top .dropdown-menu > li > a:hover {
    background: var(--brand-50); color: var(--brand-dark);
}
#header #nav-main #currencies-block-top .dropdown-menu > li.disabled > a {
    background: var(--brand-50); color: var(--brand-dark); font-weight: 700;
}
/* тонка верхня смуга під пілюлі */
#header #nav-main nav { padding: 10px 0 6px; min-height: 0; }
/* акаунт-дропдаун + кошик — у тон макету */
#header .header_user_info .account,
#header .header_user_info > a,
#header .header-top-menu .header_user_info a {
    color: #fff !important; font-family: 'Nunito', sans-serif; font-weight: 700;
}

/* ==========================================================================
   Каталог отелей (our-properties) — сетка карточек как в макете
   ========================================================================== */
#googleMapWrapper, .properties-page #map { display: none !important; }
.kn-catalog-head { margin: 8px 0 28px; }
.kn-catalog-title {
    font-family: 'Nunito', sans-serif; font-weight: 800;
    font-size: clamp(1.8rem, 4vw, 2.6rem); color: var(--ink);
    margin: 0 0 8px; text-align: left; text-transform: none;
}
.kn-catalog-sub { color: #6b7280; font-size: 16px; margin: 0; }
.kn-hotels-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
.kn-hcard {
    background: #fff; border: 1px solid var(--cream); border-radius: 20px;
    overflow: hidden; display: flex; flex-direction: column;
    box-shadow: 0 4px 18px rgba(35,51,43,.05);
    transition: transform .2s ease, box-shadow .2s ease;
}
.kn-hcard:hover { transform: translateY(-4px); box-shadow: 0 14px 34px rgba(35,51,43,.12); }
.kn-hcard__imgwrap { display: block; aspect-ratio: 16/10; overflow: hidden; background: var(--mint); }
.kn-hcard__img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.kn-hcard:hover .kn-hcard__img { transform: scale(1.05); }
.kn-hcard__body { padding: 18px 20px 20px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.kn-hcard__title {
    font-family: 'Nunito', sans-serif; font-weight: 800; font-size: 19px;
    color: var(--ink); margin: 0; line-height: 1.25;
}
.kn-hcard__loc { display: flex; align-items: center; gap: 7px; color: #6b7280; font-size: 14px; margin: 0; }
.kn-pin {
    display: inline-block; width: 15px; height: 15px; flex: 0 0 15px;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='15' height='15' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 10c0 6-8 12-8 12s-8-6-8-12a8 8 0 0 1 16 0Z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E") no-repeat center/contain;
}
.kn-hcard__foot { margin-top: auto; padding-top: 12px; display: flex; align-items: center; gap: 10px; }
.kn-hcard__btn {
    flex: 1; background: var(--brand) !important; background-image: none !important;
    border: none !important; color: #fff !important; border-radius: 9999px !important;
    font-family: 'Nunito', sans-serif; font-weight: 800; padding: 11px 18px !important;
    text-align: center; transition: background .2s ease;
}
.kn-hcard__btn:hover { background: var(--brand-light) !important; color: #fff !important; }
.kn-hcard__map {
    width: 42px; height: 42px; flex: 0 0 42px; border-radius: 9999px;
    border: 1px solid var(--cream); display: inline-flex; align-items: center; justify-content: center;
    transition: border-color .2s ease, background .2s ease;
}
.kn-hcard__map:hover { border-color: var(--brand); background: var(--brand-50); }
.kn-hcard__map .kn-pin {
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23E2640A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 10c0 6-8 12-8 12s-8-6-8-12a8 8 0 0 1 16 0Z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E") no-repeat center/contain;
    width: 16px; height: 16px;
}
.empty-properties-container { padding: 60px 0; }
@media (max-width: 991px) { .kn-hotels-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .kn-hotels-grid { grid-template-columns: 1fr; } }

/* ==========================================================================
   Оформление заказа (order-opc) — строки итогов в две колонки (фикс наложения)
   ========================================================================== */
.cart_total_detail_block p,
.cart_total_detail_block .cart_total_tax,
.cart_total_detail_block .cart_final_total_block {
    display: flex !important; align-items: baseline; justify-content: space-between;
    gap: 14px; margin: 0 0 10px;
}
.cart_total_detail_block p > span:first-child { flex: 1 1 auto; min-width: 0; }
.cart_total_detail_block .cart_total_values {
    float: none !important; position: static !important;
    white-space: nowrap; text-align: right; flex: 0 0 auto; font-weight: 700;
}
.cart_total_detail_block .cart_final_total_block .cart_total_values { color: var(--brand); font-size: 22px; }

/* ==========================================================================
   Аутентификация (вход/регистрация) — ближе к макету
   ========================================================================== */
#authentication .page-heading:first-of-type {
    text-align: center; text-transform: none;
    font-family: 'Nunito', sans-serif; font-weight: 800;
    font-size: clamp(1.6rem, 3.5vw, 2.2rem); margin-bottom: 28px;
}
#authentication #center_column { max-width: 940px; margin: 0 auto; }
#authentication .box {
    background: #fff; border: 1px solid var(--cream); border-radius: 20px;
    box-shadow: 0 6px 24px rgba(35,51,43,.06); padding: 30px 28px; height: 100%;
}
#authentication .page-subheading {
    border: none !important; text-transform: none; font-family: 'Nunito', sans-serif;
    font-weight: 800; font-size: 21px; color: var(--ink); margin: 0 0 16px; padding: 0;
}
#authentication .form-group label { font-weight: 600; color: var(--ink); font-size: 14px; }
#authentication input.form-control, #authentication input.account_input {
    border-radius: 12px; border: 1px solid var(--cream); height: 46px;
    padding-left: 42px; background-repeat: no-repeat; background-position: 14px center; background-size: 18px;
}
#authentication #email, #authentication #email_create {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='20' height='16' x='2' y='4' rx='2'/%3E%3Cpath d='m22 7-8.97 5.7a1.94 1.94 0 0 1-2.06 0L2 7'/%3E%3C/svg%3E");
}
#authentication #passwd {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='18' height='11' x='3' y='11' rx='2' ry='2'/%3E%3Cpath d='M7 11V7a5 5 0 0 1 10 0v4'/%3E%3C/svg%3E");
}
#authentication .lost_password { text-align: right; }
#authentication .lost_password a { color: var(--brand); font-weight: 600; }
#authentication #SubmitLogin, #authentication #SubmitCreate {
    width: 100%; justify-content: center; border-radius: 9999px !important;
    background: var(--brand) !important; background-image: none !important; border: none !important;
    color: #fff !important; font-family: 'Nunito', sans-serif; font-weight: 800; padding: 13px 18px !important;
}
#authentication #SubmitLogin:hover, #authentication #SubmitCreate:hover { background: var(--brand-light) !important; }
#authentication #login_form::after {
    content: "Можно бронировать и оплачивать как гость — без регистрации.";
    display: block; margin-top: 18px; padding: 12px 16px; border-radius: 12px;
    background: var(--brand-50); color: var(--brand-dark); font-size: 13px; line-height: 1.5;
}

/* ==========================================================================
   Модалка «номер добавлен в корзину» (#layer_cart) — фикс наложения
   ========================================================================== */
#layer_cart .layer_cart_row {
    display: flex !important; justify-content: space-between; align-items: baseline;
    gap: 14px; margin-bottom: 8px;
}
#layer_cart .layer_cart_row strong { flex: 1 1 auto; min-width: 0; font-weight: 600; }
#layer_cart .layer_cart_row .pull-right { float: none !important; white-space: nowrap; flex: 0 0 auto; }
#layer_cart .button-container {
    display: flex; flex-wrap: wrap; gap: 12px; align-items: center;
    justify-content: flex-end; margin-top: 14px;
}
#layer_cart .button-container .continue,
#layer_cart .button-container > a { float: none !important; margin: 0 !important; }
#layer_cart .button-container .continue.btn {
    background: #fff !important; border: 2px solid var(--cream) !important; color: var(--ink) !important;
    border-radius: 9999px !important; box-shadow: none !important; padding: 11px 18px !important;
}
#layer_cart .button-container .continue.btn:hover { border-color: var(--brand) !important; color: var(--brand) !important; }
#layer_cart .button-container > a.button-medium {
    background: var(--brand) !important; background-image: none !important; border: none !important;
    color: #fff !important; border-radius: 9999px !important; padding: 12px 22px !important; font-weight: 800;
}
#layer_cart .button-container > a.button-medium:hover { background: var(--brand-light) !important; }
#layer_cart .button.exclusive-medium::before, #layer_cart .button.exclusive-medium::after,
#layer_cart .button-medium::before, #layer_cart .button-medium::after { content: none !important; border: 0 !important; background: none !important; }
#layer_cart .crossseling { clear: both; }

/* ==========================================================================
   Кастомные konok-страницы (#konok-page: contact, CMS) уже содержат свой
   футер — прячем дублирующий универсальный kn-footer на них
   ========================================================================== */
body:has(#konok-page) .kn-footer { display: none !important; }

/* ==========================================================================
   Фолбэк-дизайн KONOK для не переверстанных модульных страниц
   (оплата чеком/банковским переводом и любые module-* фронт-контроллеры).
   Скоупится на body[id^="module-"], чтобы не задеть переверстанные страницы.
   ========================================================================== */
body[id^="module-"] #columns,
body[id^="module-"] #center_column {
    float: none !important;
    width: 100% !important;
    max-width: 880px;
    margin: 0 auto !important;
    padding: 16px 16px 48px !important;
}
body[id^="module-"] .page-heading {
    text-align: left;
    margin: 0 0 22px;
}
body[id^="module-"] .box,
body[id^="module-"] .cheque-box {
    background: #fff;
    border: 1px solid var(--cream);
    border-radius: var(--r-2xl);
    box-shadow: var(--shadow-soft);
    padding: 30px 32px;
}
body[id^="module-"] .box .page-subheading {
    font-family: "Nunito", sans-serif;
    font-weight: 800;
    color: var(--ink);
    border-bottom: 1px solid var(--cream);
    padding-bottom: 14px;
    margin-bottom: 18px;
}
body[id^="module-"] .box p { color: #5b6b63; line-height: 1.7; }
body[id^="module-"] .box .price,
body[id^="module-"] .box #amount,
body[id^="module-"] .box strong.dark,
body[id^="module-"] .box b { color: var(--ink); }
body[id^="module-"] .box #amount,
body[id^="module-"] .box .price { color: var(--brand); font-weight: 800; }
body[id^="module-"] .box select.form-control {
    border: 1px solid var(--cream);
    border-radius: 10px;
    padding: 8px 12px;
    max-width: 100%;
}
body[id^="module-"] .alert { border-radius: 12px; }

/* нижняя панель кнопок */
body[id^="module-"] .cart_navigation {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-top: 26px;
    background: transparent;
}
body[id^="module-"] .cart_navigation .button-exclusive,
body[id^="module-"] .cart_navigation a.btn-default {
    background: #fff;
    border: 2px solid var(--cream);
    color: var(--ink);
    border-radius: 9999px;
    font-family: "Nunito", sans-serif;
    font-weight: 700;
    padding: 12px 22px;
    box-shadow: none;
}
body[id^="module-"] .cart_navigation .button-exclusive:hover,
body[id^="module-"] .cart_navigation a.btn-default:hover { border-color: var(--brand); color: var(--brand); }
body[id^="module-"] .cart_navigation .button-medium,
body[id^="module-"] .cart_navigation button[type="submit"] {
    float: none !important;
    background: var(--brand) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 9999px !important;
    font-family: "Nunito", sans-serif;
    font-weight: 800;
    padding: 13px 26px !important;
    box-shadow: var(--shadow-soft);
}
body[id^="module-"] .cart_navigation .button-medium:hover,
body[id^="module-"] .cart_navigation button[type="submit"]:hover { background: var(--brand-light) !important; }
/* стоковые переключатели валюты/языка не нужны на модульных страницах оплаты */
body[id^="module-"] #currencies-block-top,
body[id^="module-"] #languages-block-top { display: none !important; }

/* Webkul-страницы продавца (.container + #left_column): стоковый .container давал
   padding-top:44px поверх .columns-container(24px) и .breadcrumb(18px) → пустые полосы
   над и под крошками. Сжимаем верхние отступы. Scope — только marketplace-страницы. */
body[id^="module-marketplace"] .container { padding-top: 8px !important; padding-bottom: 32px !important; }
body[id^="module-marketplace"] .columns-container { padding-top: 12px !important; }
body[id^="module-marketplace"] .breadcrumb { padding: 4px 0 !important; margin-bottom: 8px !important; }
