/* ============================================================
 * dalividalikg22 — WP glue & overrides
 * Подключается ПОСЛЕ tokens/components/page/tours.
 * Содержит: Slick core, mobile drawer, sticky CTA-bar,
 * адаптация под 320-480px, WC-переопределения.
 * ============================================================ */


/* -- Body / page-bg -- */
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body { background: var(--bg); margin: 0; padding: 0; }
.is-locked { overflow: hidden; }
:focus-visible { outline: 3px solid var(--dv-sea); outline-offset: 2px; border-radius: 4px; }

/* Hide legacy theme bones */
.top_panel { display: none !important; }


/* ============================================================
 * SLICK CORE (минимально для работы)
 * ============================================================ */
.slick-slider { position: relative; display: block; user-select: none; touch-action: pan-y; }
.slick-list { position: relative; display: block; overflow: hidden; margin: 0; padding: 0; }
.slick-list:focus { outline: none; }
.slick-list.dragging { cursor: pointer; }
.slick-slider .slick-track,
.slick-slider .slick-list { transform: translate3d(0,0,0); }
.slick-track { position: relative; display: block; margin-left: auto; margin-right: auto; }
.slick-track::before, .slick-track::after { display: table; content: ''; }
.slick-track::after { clear: both; }
.slick-loading .slick-track { visibility: hidden; }
.slick-slide { display: none; float: left; min-height: 1px; }
.slick-slide img { display: block; }
.slick-initialized .slick-slide { display: block; }
.slick-arrow.slick-hidden { display: none; }
.slick-slider:not(.slick-initialized) > *:nth-child(n+2) { display: none !important; }

.slick-arrow {
    position: absolute; top: 50%; transform: translateY(-50%);
    width: 44px; height: 44px; border-radius: 50%;
    background: rgba(255,255,255,.95); box-shadow: var(--sh-2);
    z-index: 5; font-size: 0; padding: 0; border: 0;
    transition: var(--d-2);
}
.slick-arrow:hover { background: var(--dv-sun); }
.slick-arrow::before {
    content: ''; display: block; width: 10px; height: 10px;
    border-top: 2px solid var(--dv-night); border-right: 2px solid var(--dv-night);
    margin: 17px auto;
}
.slick-prev { left: 12px; }
.slick-prev::before { transform: rotate(-135deg); margin-left: 19px; }
.slick-next { right: 12px; }
.slick-next::before { transform: rotate(45deg); margin-left: 13px; }

.slick-dots {
    position: absolute; bottom: -32px; left: 0; right: 0;
    display: flex; gap: 8px; justify-content: center;
    list-style: none; padding: 0; margin: 0;
}
.slick-dots li button {
    width: 10px; height: 10px; padding: 0; border-radius: 50%;
    background: var(--n-300); font-size: 0; border: 0; cursor: pointer;
    transition: var(--d-2);
}
.slick-dots li.slick-active button { background: var(--dv-sea); width: 30px; border-radius: 5px; }


/* ============================================================
 * SITE NAV — burger + sticky behaviour (mobile drawer)
 * ============================================================ */
.site-nav__burger {
    display: none; padding: 0;
    width: 44px; height: 44px;
    border-radius: var(--r-pill); background: var(--n-100); border: 0;
    flex-direction: column; gap: 5px; justify-content: center; align-items: center;
}
.site-nav__burger span { display: block; width: 22px; height: 2px; background: var(--dv-night); border-radius: 2px; }
@media (max-width: 1024px) {
    .site-nav .links, .site-nav .lang { display: none; }
    .site-nav__burger { display: inline-flex; }
}

body.is-sticky .site-header-wrap {
    position: fixed; top: 0; left: 0; right: 0;
    background: rgba(255,255,255,.96); backdrop-filter: blur(10px);
    box-shadow: var(--sh-2);
    z-index: 90;
}
body.is-sticky-pad { padding-top: 80px; }


/* ---------- Mobile drawer ---------- */
.mobile-drawer {
    position: fixed; inset: 0; z-index: 1000;
    background: var(--dv-night-ink); color: #fff;
    transform: translateX(100%);
    transition: transform 280ms var(--ease-out);
    overflow-y: auto;
    visibility: hidden;
}
.mobile-drawer.is-open { transform: translateX(0); visibility: visible; }
.mobile-drawer__inner { padding: 28px 24px; max-width: 480px; }
.mobile-drawer__close {
    position: absolute; top: 18px; right: 18px;
    width: 40px; height: 40px; border: 0; background: rgba(255,255,255,.1);
    color: #fff; font-size: 24px; line-height: 1; border-radius: 50%; cursor: pointer;
}
.mobile-drawer__logo { display: block; margin-bottom: 32px; color: #fff; text-decoration: none; }
.mobile-drawer__logo img { height: 44px; width: auto; }
.mobile-menu { list-style: none; padding: 0; margin: 0 0 32px; display: flex; flex-direction: column; gap: 4px; }
.mobile-menu li > a {
    display: block; padding: 14px 12px;
    color: #fff !important; text-decoration: none; font: 500 16px/1.2 var(--font-body);
    border-radius: var(--r-md);
    transition: background var(--d-2);
}
.mobile-menu li > a:hover, .mobile-menu li.current-menu-item > a { background: rgba(255,255,255,.08); color: var(--dv-sun) !important; }
.mobile-drawer__contact { display: flex; flex-direction: column; gap: 10px; padding-top: 18px; border-top: 1px solid rgba(255,255,255,.1); }
.mobile-drawer__tel {
    color: #fff; text-decoration: none;
    padding: 14px 16px; background: rgba(255,255,255,.06); border-radius: var(--r-md);
    display: flex; flex-direction: column; gap: 4px;
}
.mobile-drawer__tel .hours { font-size: 12px; opacity: .7; }
.mobile-drawer__tel strong { font: 700 18px/1 var(--font-head); color: var(--dv-sun); }
.mobile-drawer__wa {
    display: inline-flex; align-items: center; justify-content: center; gap: 10px;
    background: #25D366; color: #fff; text-decoration: none;
    padding: 14px 20px; border-radius: var(--r-pill); font-weight: 600;
}


/* ============================================================
 * STICKY CTA BAR (mobile, single-product)
 * ============================================================ */
.mobile-cta-bar { display: none; }
@media (max-width: 1080px) {
    .single-product .mobile-cta-bar {
        display: flex; position: fixed; bottom: 0; left: 0; right: 0; z-index: 80;
        padding: 12px 16px; gap: 12px; align-items: center;
        background: #fff; border-top: 1px solid var(--border);
        box-shadow: 0 -4px 16px rgba(14,44,92,.1);
    }
    .mobile-cta-bar__price { display: flex; flex-direction: column; line-height: 1.05; }
    .mobile-cta-bar__from { font-size: 11px; color: var(--text-muted); }
    .mobile-cta-bar__amount,
    .mobile-cta-bar__amount .woocommerce-Price-amount,
    .mobile-cta-bar__amount bdi { color: var(--dv-night); font: 800 22px/1 var(--font-head); }
    .mobile-cta-bar__btn {
        flex: 1; justify-content: center; height: 48px;
        background: #25D366; color: #fff; text-decoration: none;
        font: 700 14px/1 var(--font-body); border-radius: var(--r-pill);
        display: inline-flex; align-items: center; gap: 8px; padding: 0 16px;
    }
    body.single-product { padding-bottom: 80px; }
}


/* ============================================================
 * WC overrides
 * ============================================================ */
.woocommerce-breadcrumb { display: none; } /* мы используем свой .breadcrumbs */
.woocommerce-Price-amount, .woocommerce-Price-amount bdi { color: inherit; font: inherit; }
.tour-card-2 .price .woocommerce-Price-amount,
.book-aside .price-big .woocommerce-Price-amount { color: inherit; }


/* ============================================================
 * UTILITIES (для inline-стилей если PHP-шаблоны быстро добавляют)
 * ============================================================ */
.flex100f { width: 100%; }
.row100f { width: 100%; }


/* ============================================================
 * PROSE (контент страниц через the_content)
 * ============================================================ */
.prose { line-height: 1.7; color: var(--text); max-width: 720px; }
.prose h2 { font-family: var(--font-head); margin: var(--s-7) 0 var(--s-3); font-size: var(--fs-28); line-height: 1.2; font-weight: 700; }
.prose h3 { margin: var(--s-6) 0 var(--s-3); font-family: var(--font-head); font-size: var(--fs-20); }
.prose p { margin: 0 0 var(--s-4); }
.prose ul, .prose ol { margin: 0 0 var(--s-4) var(--s-6); padding: 0; }
.prose ul li, .prose ol li { margin-bottom: var(--s-2); }
.prose img { border-radius: var(--r-md); margin: var(--s-4) 0; }
.prose a { color: var(--accent); }


/* ============================================================
 * TOUR CARD price colour
 * ============================================================ */
.tour-card-2 .price { font: 800 22px/1 var(--font-head); color: var(--text); display: inline-flex; align-items: baseline; gap: 4px; }
.tour-card-2 .price .woocommerce-Price-amount,
.tour-card-2 .price bdi { font: inherit; color: inherit; }
.tour-card-2 .price small { font-size: 13px; color: var(--text-muted); font-weight: 500; }


/* ============================================================
 * Hero (homepage) — wrapper выше TOC
 * ============================================================ */
.home-hero {
    padding: 0;
    margin-top: 0;
}


/* ============================================================
 * Контентные страницы page-* — отступы
 * ============================================================ */
.page-shell { padding: var(--s-8) 0 var(--s-10); }
.page-shell .container > .breadcrumbs { margin-bottom: var(--s-5); }


/* ============================================================
 * Адаптив 320-480 — самые маленькие
 * ============================================================ */
@media (max-width: 480px) {
    :root { --gutter: 16px; }
    .tours-hero { padding: 32px 24px; border-radius: var(--r-lg); }
    .tours-hero h1 { font-size: 32px; }
    .filter-bar { grid-template-columns: 1fr; padding: 12px; border-radius: var(--r-lg); }
    .filter-bar .fcell { border-right: none; border-bottom: 1px solid var(--border); padding: 10px 0; }
    .filter-bar .fcell:last-of-type { border-bottom: none; }
    .gallery { grid-template-columns: 1fr; aspect-ratio: auto; }
    .gallery .g.main { aspect-ratio: 4/3; }
    .gallery .g:not(.main) { display: none; }
    .gallery .g.main.has-cnt::after { content: '+12 фото →'; }
    .tour-card-2 .body { padding: 14px; }
    .ds-footer { padding: 32px 0 24px; }
    .footer-grid { gap: 24px; }
    .high-grid { grid-template-columns: 1fr; }
    .pagination button { width: 36px; height: 36px; }
    .site-nav { padding: 12px 0; }
    .site-nav .logo span { display: none; }
}


/* ============================================================
 * BIG SCREENS optimisation
 * ============================================================ */
@media (min-width: 1440px) {
    :root { --container: 1320px; }
}


/* ============================================================
 * HERO SEARCH FORM — unified custom dropdowns, date range, guest popup
 * ============================================================ */
.filter-bar .fcell { position: relative; }

.dd-trigger {
    background: transparent !important; border: 0; padding: 0; outline: 0;
    color: var(--text); font: 600 16px/1.3 var(--font-body); cursor: pointer;
    text-align: left; width: 100%; min-height: 22px;
    display: flex; align-items: center; justify-content: space-between; gap: 6px;
    appearance: none; -webkit-appearance: none;
}
.dd-trigger::after {
    content: ''; flex-shrink: 0;
    width: 10px; height: 6px;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='none' stroke='%230E2C5C' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round' d='M1 1l4 4 4-4'/></svg>") no-repeat center/contain;
    opacity: .55; transition: transform .2s ease, opacity .2s ease;
}
.dd-trigger[aria-expanded="true"]::after { transform: rotate(180deg); opacity: 1; }
.dd-trigger > span { flex: 1 1 auto; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.dd-popup {
    position: fixed; z-index: 10000;
    min-width: 240px; max-width: 92vw;
    background: #fff; color: var(--text);
    border-radius: 18px; box-shadow: 0 24px 48px rgba(14,44,92,.18), 0 2px 8px rgba(14,44,92,.08);
    padding: 10px;
    display: none;
    max-height: min(70vh, 480px); overflow-y: auto;
    opacity: 0; transform: translateY(-4px);
    transition: opacity .15s ease, transform .15s ease;
}
.dd-popup.is-open { display: block; opacity: 1; transform: translateY(0); }

.dd-opt {
    display: block; width: 100%; text-align: left;
    background: transparent; border: 0; cursor: pointer;
    padding: 11px 14px; border-radius: 10px;
    color: var(--text); font: 500 15px/1.3 var(--font-body);
    transition: background .15s ease, color .15s ease;
}
.dd-opt:hover { background: var(--n-50, #F3F5F8); }
.dd-opt.is-active {
    background: var(--dv-sea, #1B5FAE); color: #fff; font-weight: 600;
}

.dd-popup--guests { padding: 18px 20px; min-width: 320px; }
.dd-popup--guests .pax-row { padding: 14px 0; }
.dd-popup--guests .pax-row:first-child { padding-top: 0; }
.dd-popup--guests .pax-row:last-child { padding-bottom: 0; border-bottom: 0; }
.dd-popup__done {
    width: 100%; margin-top: 12px;
    height: 44px; border-radius: var(--r-pill);
    background: var(--dv-night); color: #fff; border: 0;
    font: 600 14px/1 var(--font-body); cursor: pointer;
}
.dd-popup__done:hover { background: var(--dv-night-ink); }

/* Flatpickr brand overrides */
.flatpickr-calendar {
    background: #fff; border-radius: 18px !important;
    box-shadow: 0 24px 48px rgba(14,44,92,.18), 0 2px 8px rgba(14,44,92,.08) !important;
    padding: 8px; font-family: var(--font-body);
    z-index: 10001 !important;
}
.flatpickr-day { border-radius: 10px; color: var(--text); font-weight: 500; }
.flatpickr-day:hover { background: var(--n-50, #F3F5F8); border-color: transparent; }
.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange,
.flatpickr-day.selected.startRange,
.flatpickr-day.selected.endRange {
    background: var(--dv-sea, #1B5FAE) !important;
    border-color: var(--dv-sea, #1B5FAE) !important; color: #fff !important;
    box-shadow: none !important;
}
.flatpickr-day.inRange {
    background: rgba(27,95,174,.12) !important;
    border-color: transparent !important; color: var(--dv-night, #0E2C5C) !important;
    box-shadow: none !important;
}
.flatpickr-day.today { border-color: var(--dv-sun, #FFC72C); }
.flatpickr-day.today:hover { background: var(--dv-sun, #FFC72C); color: var(--dv-night, #0E2C5C); border-color: var(--dv-sun, #FFC72C); }
.flatpickr-day.flatpickr-disabled,
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay { color: rgba(14,44,92,.3); }
.flatpickr-months .flatpickr-month { color: var(--dv-night, #0E2C5C); }
.flatpickr-current-month .flatpickr-monthDropdown-months,
.flatpickr-current-month input.cur-year { font-weight: 600; color: var(--dv-night, #0E2C5C); }
.flatpickr-weekday { color: var(--n-500, #6B7B95); font-weight: 600; font-size: 12px; }
.flatpickr-prev-month, .flatpickr-next-month { fill: var(--dv-night, #0E2C5C) !important; }
.flatpickr-prev-month:hover svg, .flatpickr-next-month:hover svg { fill: var(--dv-sea, #1B5FAE) !important; }

@media (max-width: 480px) {
    .dd-popup { left: 8px !important; right: 8px !important; width: auto !important; min-width: 0; }
    .dd-popup--guests { padding: 16px; }
}


/* ============================================================
 * INTERSECTION FADE
 * ============================================================ */
.fade-in { opacity: 0; transform: translateY(16px); transition: opacity 600ms ease, transform 600ms ease; }
.fade-in.is-visible { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) {
    .fade-in { opacity: 1; transform: none; transition: none; }
    .tour-card-2:hover, .cat-tile:hover, .card:hover { transform: none; }
}


/* ============================================================
 * FLOATING WhatsApp button on mobile (legacy callto_btns)
 * ============================================================ */
.callto_btns { display: none; }   /* убираем legacy floating buttons — заменены на header WA + mobile-cta-bar */


/* ============================================================
 * Search modal (legacy)
 * ============================================================ */
.modal_search, .overlay { display: none; }
