/* ========================================================================
   product_v12.css — стили новой карточки глэмпинга по макету v12.
   Все правила скоуплены под .pv12, чтобы не конфликтовать с текущим
   stylesheet.css. Макет-референс: docs/mockups/desktop_product_v12.html
   ======================================================================== */

/* ── u-popup (всплывающая подсказка, общая для desktop и mobile) ── */
.u-popup-trigger { position: relative; cursor: pointer; }
.u-popup { display: none; position: absolute; bottom: calc(100% + 10px); left: 50%; transform: translateX(-50%); background: #1a3a2a; color: #fff; border-radius: 10px; padding: 14px 16px; width: 260px; z-index: 220; box-shadow: 0 4px 16px rgba(0,0,0,0.25); font-weight: 400; text-align: left; font-size: 14px; line-height: 1.5; }
.u-popup.open { display: block; }
.u-popup::after { content: ''; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); border: 7px solid transparent; border-top-color: #1a3a2a; }
.u-popup.align-left { left: 0; transform: none; }
.u-popup.align-left::after { left: 30px; transform: none; }
.u-popup.align-right { left: auto; right: 0; transform: none; }
.u-popup.align-right::after { left: auto; right: 30px; transform: none; }
.u-popup-close { position: absolute; top: 8px; right: 10px; background: none; border: none; color: rgba(255,255,255,0.5); font-size: 17px; cursor: pointer; line-height: 1; padding: 0; }
.u-popup-close:hover,
.u-popup-close:active { color: #fff; }
.u-popup-title { font-size: 16px; font-weight: 700; color: #81c784; margin-bottom: 8px; padding-right: 18px; }
.u-popup-body { font-size: 14px; line-height: 1.5; color: #e8f5e9; margin-bottom: 8px; overflow-wrap: break-word; word-wrap: break-word; }
.u-popup-list { font-size: 13px; line-height: 1.6; color: #e8f5e9; margin-bottom: 8px; }
.u-popup-list-item { display: flex; align-items: flex-start; gap: 6px; padding: 3px 0; overflow-wrap: break-word; word-wrap: break-word; }
.u-popup-list-item > span:last-child { flex: 1; min-width: 0; white-space: normal; word-break: break-word; }
.u-popup-list-item .check { color: #81c784; font-weight: 700; flex-shrink: 0; }
.u-popup-link { font-size: 13px; color: #81c784; text-decoration: none; font-weight: 600; display: inline-block; }
.u-popup-link:hover,
.u-popup-link:active { opacity: 0.7; color: #81c784; }
/* На мобильном возвращаем центрирование и ограничиваем ширину по вьюпорту */
@media (max-width: 767px) {
  .u-popup { max-width: calc(100vw - 24px); }
  .u-popup.align-left,
  .u-popup.align-right { left: 50%; right: auto; transform: translateX(-50%); }
  .u-popup.align-left::after,
  .u-popup.align-right::after { left: 50%; right: auto; transform: translateX(-50%); }
}

/* pv12 видим всегда, легаси скрыт всегда */
.pv12 { color: #222; }
body { background: #f0f0f0 !important; }
.prod-baner, .prod-page, .dark-block, .map-out { display: none !important; }
@media (min-width: 768px) {
}
.pv12 * { box-sizing: border-box; }

/* ── LAYOUT ── */
.pv12 .container { max-width: 1100px; margin: 0 auto; padding: 0 24px 24px; }

/* ── TITLE BAR ── */
.pv12 .title-bar { background: #fff; border-radius: 12px; padding: 12px 20px; margin-top: 0; box-shadow: 0 1px 4px rgba(0,0,0,0.06); }
.pv12 .guarantee-row { display: flex; justify-content: flex-end; width: 100%; margin-bottom: 0; }
.pv12 .guarantee-badge { display: inline-flex; align-items: center; gap: 5px; font-size: 13px; color: #1565c0; font-weight: 600; cursor: pointer; position: relative; user-select: none; }
.pv12 .guarantee-popup { display: none; position: absolute; top: calc(100% + 8px); right: 0; z-index: 50; background: #fff; border-radius: 10px; padding: 14px 16px; box-shadow: 0 4px 24px rgba(0,0,0,0.18); width: 280px; border: 1px solid #e3f2fd; text-align: left; white-space: normal; }
.pv12 .guarantee-popup.open { display: block; }
.pv12 .gp-close { position: absolute; top: 8px; right: 10px; background: none; border: none; font-size: 17px; cursor: pointer; color: #999; line-height: 1; padding: 0; }
.pv12 .gp-title { font-size: 15px; font-weight: 700; color: #1565c0; margin-bottom: 10px; padding-right: 20px; }
.pv12 .gp-item { display: flex; align-items: flex-start; gap: 8px; font-size: 13px; color: #000; font-weight: 400; padding: 6px 0; border-bottom: 1px solid #f0f0f0; line-height: 1.4; }
.pv12 .gp-item:last-child { border-bottom: none; }
.pv12 .gp-check { color: #2E8B57; font-weight: 700; flex-shrink: 0; }
.pv12 .title-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; }
.pv12 .title-top h1 { font-size: 27px; font-weight: 700; flex: 1; margin: 0;    display: flex;
    align-items: center; }
.pv12 .title-top h1 .id-badge {     line-height: 25px; font-size: 15px; color: #999; font-weight: 400; background: #f5f5f5; padding: 2px 8px; border-radius: 6px; margin-left: 8px; }
.pv12 .title-actions { display: flex; gap: 8px; flex-shrink: 0; margin-left: 16px; position: relative; }
.pv12 .title-actions .btn-icon { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; border: 1px solid #ddd; border-radius: 50%; background: #fff; font-size: 19px; cursor: pointer; color: #555; }
.pv12 .title-actions .btn-icon:hover { background: #f5f5f5; }
/* Override legacy .buyer-favorite-btn: static pos, emoji ♡ icon */
.pv12 .title-actions .buyer-favorite-btn { position: static !important; top: auto !important; right: auto !important; left: auto !important; width: 36px !important; height: 36px !important; padding: 0 !important; margin: 0 !important; background: #fff !important; border: 1px solid #ddd !important; border-radius: 50% !important; display: inline-flex !important; align-items: center; justify-content: center; box-shadow: none !important; font-size: 19px; color: #555; line-height: 1; cursor: pointer; }
.pv12 .title-actions .buyer-favorite-btn:hover { background: #f5f5f5 !important; }
.pv12 .title-actions .buyer-favorite-btn .buyer-favorite-btn__icon { display: none !important; }
.pv12 .title-actions .buyer-favorite-btn::before { content: '♡'; font-size: 21px; line-height: 1; }
.pv12 .title-actions .buyer-favorite-btn.is-active { color: #ff5a5f !important; }
.pv12 .title-actions .buyer-favorite-btn.is-active::before { content: '♥'; }
.pv12 .share-menu { display: none; position: absolute; top: calc(100% + 6px); right: 0; background: #fff; border-radius: 10px; box-shadow: 0 4px 24px rgba(0,0,0,0.18); padding: 6px; z-index: 60; min-width: 180px; }
.pv12 .share-menu.open { display: block; }
@media (max-width: 767px) {
  .share-menu[data-pv12-share-menu] { position: fixed !important; bottom: 0; left: 0; right: 0; top: auto !important; z-index: 1000; border-radius: 18px 18px 0 0; padding: 12px; min-width: 0; width: 100%; box-shadow: 0 -4px 24px rgba(0,0,0,0.2); background: #fff; display: none; }
  .share-menu[data-pv12-share-menu].open { display: block; }
  .share-menu[data-pv12-share-menu] a,
  .share-menu[data-pv12-share-menu] button { display: flex; align-items: center; gap: 8px; width: 100%; padding: 12px 10px; font-size: 16px; color: #333; background: none; border: none; border-radius: 8px; cursor: pointer; text-align: left; text-decoration: none; }
  .share-menu[data-pv12-share-menu] a:active,
  .share-menu[data-pv12-share-menu] button:active { background: #f5f5f5; }
}
.pv12 .share-menu a, .pv12 .share-menu button { display: flex; align-items: center; gap: 8px; width: 100%; padding: 8px 10px; font-size: 14px; color: #333; background: none; border: none; border-radius: 6px; cursor: pointer; text-align: left; text-decoration: none; }
.pv12 .share-menu a:hover, .pv12 .share-menu button:hover { background: #f5f5f5; }
.pv12 .share-toast { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%); background: rgba(20,20,20,0.92); color: #fff; padding: 10px 18px; border-radius: 8px; font-size: 14px; z-index: 999; opacity: 0; transition: opacity 0.2s; pointer-events: none; }
.pv12 .share-toast.show { opacity: 1; }
.pv12 .title-meta { display: flex; align-items: flex-start; gap: 16px; padding-top: 10px; padding-bottom: 0px; }
.pv12 .title-meta .tm-left { flex: 1; min-width: 0; display: flex; flex-wrap: wrap; align-items: center; column-gap: 16px;     row-gap: 6px; align-content: space-between; }
.pv12 .title-meta .tm-right { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; flex-shrink: 0; }
.pv12 .title-meta .tm-left .title-chips { flex-basis: 100%; margin-top: 0; flex-wrap: nowrap; overflow: hidden; max-width: 100%; }
.pv12 .title-meta .tm-left .title-chips .t-chip { flex-shrink: 0; white-space: nowrap; }
.pv12 .tm-rating { display: flex; align-items: flex-end; gap: 6px; }
.pv12 .tm-rating .stars { color: #F5A623; font-size: 17px; }
.pv12 .tm-rating .score { font-size: 17px; font-weight: 800; }
.pv12 .tm-rating .reviews { font-size: 14px; color: #2E8B57; text-decoration: underline; cursor: pointer; }
.pv12 .tm-rating .tm-rating-sep { color: #bbb; font-size: 14px; padding: 0 2px; }
.pv12 .tm-rating .tm-highway { font-size: 14px; color: #666; }
@media (max-width: 767px) {
  .pv12 .tm-rating { flex-wrap: wrap; }
  .pv12 .tm-rating .tm-rating-sep { display: none; }
  .pv12 .tm-rating .tm-highway { flex-basis: 100%; }
}
.pv12 .tm-address { font-size: 15px; color: #000; line-height: 18px; }
.pv12 .tm-address a { color: #2E8B57; text-decoration: underline; cursor: pointer; }
.pv12 .tm-address .tm-address-link { color: #000; text-decoration: none; }
.pv12 .tm-address .tm-address-link:hover { text-decoration: underline; color: #2E8B57; }
.pv12 .tm-book-btn { padding: 14px 24px; background: #F5A623; color: #fff; border: none; border-radius: 12px; font-size: 18px; font-weight: 700; cursor: pointer; white-space: nowrap; min-height: 48px; transition: all 0.2s ease; }
.pv12 .tm-book-btn:hover { background: #e09518; }
.pv12 .tm-book-btn:active { background: #e09518; transform: scale(0.97); }
.pv12 .title-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
.pv12 .breadcrumbs { padding: 10px 24px;  padding-left: 0; font-size: 14px; display: flex; justify-content: space-between; align-items: center; }
/* Скрытые на desktop */
@media (min-width: 768px) {
  .pv12 .bc-actions { display: none; }
  .pv12 .ph-price-mob { display: none; }
  .pv12 .section-gap { display: none; }
}
@media (max-width: 767px) {
  .buyer-favorite-btn { position: static !important; }
}
.pv12 .t-chip { display: inline-flex; align-items: center; gap: 4px; padding: 5px 12px; background: #e8f5e9; color: #2E8B57; border-radius: 14px; font-size: 13px; font-weight: 500; cursor: pointer; }
.pv12 .t-chip:hover { background: #d4edda; }

/* ── GALLERY ── */
.pv12 .gallery { display: grid; grid-template-columns: 2fr 1fr 1fr; grid-template-rows: 170px 170px; gap: 4px; margin-top: 12px; border-radius: 12px; overflow: hidden; }
.pv12 .gallery .g-main { grid-column: 1; grid-row: 1/3; position: relative; cursor: pointer; transition: opacity 0.15s; background: #eee center/cover no-repeat; }
.pv12 .gallery .g-main:hover { opacity: 0.92; }
.pv12 .gallery .g-main .badge-hot { position: absolute; top: 12px; left: 12px; background: #ff5252; color: #fff; padding: 5px 12px; border-radius: 6px; font-size: 13px; font-weight: 700; }
.pv12 .gallery .g-main .g-main-hint { position: absolute; bottom: 12px; right: 12px; background: rgba(0,0,0,0.65); color: #fff; padding: 7px 14px; border-radius: 8px; font-size: 14px; font-weight: 600; opacity: 0; transition: opacity 0.2s; pointer-events: none; z-index: 3; }
/* Hover только по фото-плиткам (без .g-map) — используем :has() для современных браузеров + fallback-hover на .g-main */
.pv12 .gallery:has(.g-main:hover) .g-main-hint,
.pv12 .gallery:has(.g-side1:hover) .g-main-hint,
.pv12 .gallery:has(.g-side2:hover) .g-main-hint { opacity: 1; }
.pv12 .gallery .g-main:hover .g-main-hint { opacity: 1; }
.pv12 .gallery .g-side1 { grid-column: 2; grid-row: 1; cursor: pointer; transition: opacity 0.15s; background: #eee center/cover no-repeat; }
.pv12 .gallery .g-side1:hover { opacity: 0.88; }
.pv12 .gallery .g-side2 { grid-column: 2; grid-row: 2; position: relative; cursor: pointer; background: #eee center/cover no-repeat; }
.pv12 .gallery .g-side2 .g-more { position: absolute; inset: 0; background: rgba(0,0,0,0.5); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 600; font-size: 16px; }
.pv12 .gallery .g-side2:hover .g-more { background: rgba(0,0,0,0.65); }
.pv12 .gallery .g-map { grid-column: 3; grid-row: 1/3; background: linear-gradient(135deg,#e8f5e9,#c8e6c9); display: flex; flex-direction: column; align-items: center; justify-content: center; cursor: pointer; position: relative; overflow: hidden; }
.pv12 .gallery .g-map .g-map-inner { position: absolute; inset: 0; }
.pv12 .gallery .g-map:hover .g-map-overlay { opacity: 1; }
/* Оверлей "Открыть карту" — поверх всех элементов плитки (пин, подписи) */
.pv12 .g-map-overlay { position: absolute; inset: 0; background: rgba(0,0,0,0.45); display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity 0.2s; z-index: 10; pointer-events: none; }
.pv12 .gallery .g-map:hover .g-map-overlay { opacity: 1; }
.pv12 .g-map-overlay span { background: rgba(0,0,0,0.75); color: #fff; padding: 8px 16px; border-radius: 8px; font-size: 14px; font-weight: 600; }
.pv12 .g-map-tag { position: absolute; bottom: 12px; left: 50%; transform: translateX(-50%); padding: 3px 10px; background: #2E8B57; color: #fff; border-radius: 4px; font-size: 11px; font-weight: 600; z-index: 3; }
/* Пин-якорь попадает точно в центр карты (= координаты объекта), подпись висит под пином. */
.pv12 .gallery .g-map .g-map-center { position: absolute; top: 50%; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 2px; z-index: 3; pointer-events: none; }
/* Смещаем пин так, чтобы его визуальный «кончик» был точно на точке (центре карты) */
.pv12 .gallery .g-map .g-map-pin { font-size: 39px; line-height: 1; filter: drop-shadow(0 2px 4px rgba(0,0,0,0.45)); margin-top: -34px; }
.pv12 .gallery .g-map .g-map-label { margin-top: 2px; font-size: 14px; font-weight: 700; color: #2E8B57; background: #fff; padding: 4px 10px; border-radius: 14px; box-shadow: 0 2px 8px rgba(0,0,0,0.25); max-width: 90%; text-align: center; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pv12 .gallery .g-map .g-map-rating { font-size: 12px; color: #333; background: #fff; padding: 2px 8px; border-radius: 10px; box-shadow: 0 1px 4px rgba(0,0,0,0.18); }

/* GALLERY OVERLAY (Yandex-style modal: backdrop + white card, правый скролл) */
.pv12-gal-overlay { display: none; position: fixed; inset: 0; background: transparent; z-index: 1000; align-items: flex-start; justify-content: center; padding: 40px 20px; overflow: hidden; }
.pv12-gal-overlay.open { display: flex; }
.pv12-gal-overlay .gal-backdrop { position: fixed; inset: 0; background: rgba(20,20,20,0.55); z-index: 1; }
.pv12-gal-overlay .gal-modal { position: relative; z-index: 2; background: #fff; width: min(980px, 94vw); max-height: calc(100vh - 80px); border-radius: 14px; display: flex; flex-direction: column; overflow: hidden; box-shadow: 0 20px 60px rgba(0,0,0,0.35); }
.pv12-gal-overlay .gal-header { display: flex; justify-content: space-between; align-items: flex-start; padding: 16px 22px; border-bottom: 1px solid #eee; flex-shrink: 0; background: #fff; gap: 16px; }
.pv12-gal-overlay .gal-header-info { flex: 1; min-width: 0; display: block; padding: 0; }
.pv12-gal-overlay .gal-header-name { font-size: 18px; font-weight: 700; color: #111; margin-bottom: 4px; }
.pv12-gal-overlay .gal-header-rating { display: flex; align-items: center; gap: 6px; font-size: 13px; color: #555; }
.pv12-gal-overlay .gal-header-rating .stars { color: #F5A623; letter-spacing: 1px; }
.pv12-gal-overlay .gal-header-rating .value { font-weight: 700; color: #111; }
.pv12-gal-overlay .gal-header-rating .word { color: #2E8B57; font-weight: 600; }
.pv12-gal-overlay .gal-close-btn { width: 32px; height: 32px; padding: 0; background: transparent; color: #555; border: none; border-radius: 50%; cursor: pointer; font-size: 18px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.pv12-gal-overlay .gal-close-btn:hover { background: #f0f0f0; color: #111; }
.pv12-gal-overlay .gal-title,
.pv12-gal-overlay .gal-header-back { display: none; }
.pv12-gal-overlay .gal-grid-wrap { flex: 1; overflow-y: scroll; padding: 12px 14px; scrollbar-gutter: stable; }
.pv12-gal-overlay .gal-grid-wrap::-webkit-scrollbar { width: 10px; }
.pv12-gal-overlay .gal-grid-wrap::-webkit-scrollbar-track { background: #f5f5f5; border-radius: 5px; }
.pv12-gal-overlay .gal-grid-wrap::-webkit-scrollbar-thumb { background: #c8c8c8; border-radius: 5px; }
.pv12-gal-overlay .gal-grid-wrap::-webkit-scrollbar-thumb:hover { background: #a8a8a8; }
.pv12-gal-overlay .gal-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.pv12-gal-overlay .gal-tile { aspect-ratio: 4/3; border-radius: 8px; position: relative; overflow: hidden; cursor: pointer; background: #eee center/cover no-repeat; }
.pv12-gal-overlay .gal-tile-hover { position: absolute; inset: 0; background: rgba(0,0,0,0); display: flex; align-items: center; justify-content: center; transition: background 0.15s; }
.pv12-gal-overlay .gal-tile:hover .gal-tile-hover { background: rgba(0,0,0,0.25); }
.pv12-gal-overlay .gal-tile-hover span { font-size: 27px; opacity: 0; transition: opacity 0.15s; color: #fff; }
.pv12-gal-overlay .gal-tile:hover .gal-tile-hover span { opacity: 1; }

/* LIGHTBOX */
.pv12-lightbox { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.96); z-index: 1000; align-items: center; justify-content: center; }
.pv12-lightbox.open { display: flex; }
.pv12-lightbox .lb-img { width: 70vw; max-width: 1100px; height: 80vh; background: #000 center/contain no-repeat; border-radius: 10px; }
.pv12-lightbox .lb-close { position: absolute; top: 20px; right: 20px; width: 40px; height: 40px; border-radius: 50%; background: rgba(255,255,255,0.15); border: none; color: #fff; font-size: 19px; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.pv12-lightbox .lb-close:hover { background: rgba(255,255,255,0.3); }
.pv12-lightbox .lb-nav { position: absolute; top: 50%; transform: translateY(-50%); width: 48px; height: 48px; border-radius: 50%; background: rgba(255,255,255,0.18); border: none; color: #fff; font-size: 21px; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.pv12-lightbox .lb-nav:hover { background: rgba(255,255,255,0.38); }
.pv12-lightbox .lb-prev { left: 20px; }
.pv12-lightbox .lb-next { right: 20px; }
.pv12-lightbox .lb-count { position: absolute; top: 26px; left: 50%; transform: translateX(-50%); color: rgba(255,255,255,0.85); font-size: 14px; background: rgba(0,0,0,0.4); padding: 4px 14px; border-radius: 20px; }
.pv12-lightbox .lb-thumbs { position: absolute; bottom: 12px; left: 50%; transform: translateX(-50%); display: flex; gap: 6px; padding: 8px 12px; max-width: 92vw; overflow-x: auto; background: rgba(0,0,0,0.35); border-radius: 10px; scrollbar-width: thin; }
.pv12-lightbox .lb-thumbs::-webkit-scrollbar { height: 6px; }
.pv12-lightbox .lb-thumbs::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.4); border-radius: 3px; }
.pv12-lightbox .lb-thumb { width: 72px; height: 54px; border-radius: 5px; background: #333 center/cover no-repeat; cursor: pointer; flex-shrink: 0; opacity: 0.55; border: 2px solid transparent; transition: opacity 0.15s, border-color 0.15s; }
.pv12-lightbox .lb-thumb:hover { opacity: 0.85; }
.pv12-lightbox .lb-thumb.active { opacity: 1; border-color: #fff; }

/* MAP POPUP — mp-body 2-col + toolbar */
.pv12-map-popup-modal .mp-body { display: grid; grid-template-columns: 1fr 280px; flex: 1; overflow: hidden; }
.pv12-map-popup-modal .mp-map { position: relative; height: 420px; background: #e8f5e9; }
.pv12-map-popup-modal .mp-info { padding: 16px; border-left: 1px solid #f0f0f0; display: flex; flex-direction: column; gap: 12px; overflow-y: auto; }
.pv12-map-popup-modal .mp-obj-img { width: 100%; height: 110px; border-radius: 8px; background: #eee center/cover no-repeat; }
.pv12-map-popup-modal .mp-obj-name { font-size: 16px; font-weight: 700; color: #222; }
.pv12-map-popup-modal .mp-obj-rating { font-size: 13px; color: #888; margin-top: 2px; }
.pv12-map-popup-modal .mp-obj-rating .star { color: #F5A623; }
.pv12-map-popup-modal .mp-obj-addr { font-size: 13px; line-height: 15px; color: #666; margin-top: 2px; }
.pv12-map-popup-modal .mp-obj-price { font-size: 19px; font-weight: 800; color: #222; margin-top: 4px; }
.pv12-map-popup-modal .mp-obj-price span { font-size: 13px; color: #888; font-weight: 400; }
.pv12-map-popup-modal .mp-book-btn { display: block; width: 100%; padding: 11px; background: #F5A623; color: #fff; border: none; border-radius: 10px; font-size: 15px; font-weight: 700; cursor: pointer; text-align: center; margin-top: auto; }
.pv12-map-popup-modal .mp-book-btn:hover { background: #e09518; }
.pv12-map-popup-modal .mp-route { text-align: center; font-size: 13px; color: #2E8B57; cursor: pointer; }
.pv12-map-popup-modal .mp-toolbar { display: flex; gap: 8px; padding: 10px 14px; border-top: 1px solid #f0f0f0; background: #fafafa; flex-shrink: 0; }
.pv12-map-popup-modal .mp-tool-btn { display: flex; align-items: center; gap: 6px; padding: 6px 12px; border: 1px solid #ddd; border-radius: 7px; background: #fff; font-size: 13px; color: #555; cursor: pointer; }
.pv12-map-popup-modal .mp-tool-btn:hover { border-color: #2E8B57; color: #2E8B57; }

/* ── PAGE LAYOUT ── */
.pv12 .page-layout { display: grid; grid-template-columns: 1fr 290px; gap: 16px; margin-top: 12px; align-items: start; }
.pv12 .main-col { min-width: 0; }
.pv12 .sidebar-col { display: flex; flex-direction: column; gap: 12px; }
.pv12 .content-section { background: #fff; border-radius: 12px; padding: 20px; margin-bottom: 12px; box-shadow: 0 1px 4px rgba(0,0,0,0.06); }
.pv12 .content-section h2 { font-size: 19px; font-weight: 700; margin-bottom: 14px; display: flex; justify-content: flex-start; align-items: center; gap: 8px; }

/* Перенесённый .pre-accomondations внутри content-section */
.pv12 .content-section .pre-accomondations { background: transparent !important; padding: 0 !important; margin: 0 !important; box-shadow: none !important; border: none !important; }
.pv12 .content-section .pre-accomondations .accomondation,
.pv12 .content-section .pre-accomondations .pre-accomondation-title { margin-top: 0; }

/* ── SEARCH BLOCK ── */
.pv12 .search-block { background: #fff; border-radius: 12px; padding: 12px 16px; margin-bottom: 12px; box-shadow: 0 1px 4px rgba(0,0,0,0.06); position: relative; z-index: 20; }
.pv12 .search-block-title { font-size: 18px; font-weight: 700; color: #222; margin-bottom: 8px; }
.pv12 .sb-row { display: flex; gap: 8px; align-items: stretch; }
.pv12 .sb-field { flex: 1; border: 1px solid #ddd; border-radius: 8px; padding: 7px 12px; cursor: pointer; background: #fff; transition: border-color 0.15s; min-height: 46px; display: flex; flex-direction: column; justify-content: center; }
.pv12 .sb-field:hover { border-color: #F5A623; }
.pv12 .sb-field label { font-size: 12px; color: #999; display: block; pointer-events: none; }
.pv12 .sb-field .val { font-size: 15px; color: #333; margin-top: 1px; font-weight: 500; }
.pv12 .sb-field .val.ph { color: #bbb; font-weight: 400; }
.pv12 .sb-field.active { border-color: #F5A623; box-shadow: 0 0 0 3px rgba(245,166,35,0.15); }
.pv12 .sb-btn { padding: 0 22px; background: #F5A623; color: #fff; border: none; border-radius: 10px; font-size: 15px; font-weight: 700; cursor: pointer; white-space: nowrap; flex-shrink: 0; transition: background 0.15s; min-height: 46px; }
.pv12 .sb-btn:hover { background: #e09518; }

/* Перенесённая легаси-форма внутри pv12 search-block */
.pv12 .search-block .check-availability { width: 100%; }
.pv12 .search-block .check-availability form { display: flex; gap: 8px; align-items: stretch; flex-wrap: nowrap; background: transparent; padding: 0; margin: 0; }
.pv12 .search-block .check-availability .search-rooms-forms-datepicker { flex: 2; min-width: 0; border: 1px solid #ddd; border-radius: 8px; padding: 4px 12px; background: #fff; height: 46px; display: flex; flex-direction: column; justify-content: center; margin: 0; position: relative; box-sizing: border-box; }
.pv12 .search-block .check-availability .search-rooms-forms-datepicker:hover { border-color: #F5A623; }
.pv12 .search-block .check-availability .search-rooms-forms-datepicker .datepicker-icon,
.pv12 .search-block .check-availability .search-rooms-forms-datepicker .calendar { display: none; }
.pv12 .search-block .check-availability .search-rooms-forms-datepicker .search-rooms-container-text { font-size: 12px; color: #999; font-weight: 400; margin: 0; padding: 0; position: static; line-height: 16px; }
.pv12 .search-block .check-availability .search-rooms-forms-datepicker input#check-dates { border: none !important; border-radius: 0 !important; padding: 0 !important; margin: 0 !important; font-size: 15px !important; color: #333 !important; background: transparent !important; width: 100% !important; height: auto !important; line-height: 20px !important; box-shadow: none !important; font-weight: 500; cursor: pointer; }
.pv12 .search-block .check-availability .search-rooms-forms-guests { flex: 1.5; min-width: 0; margin: 0; position: relative; }
.pv12 .search-block .check-availability .search-rooms-forms-guests .guests-icon,
.pv12 .search-block .check-availability .search-rooms-forms-guests .dog,
.pv12 .search-block .check-availability .search-rooms-forms-guests .paw { display: none !important; }
.pv12 .search-block .check-availability .search-rooms-forms-guests .search-rooms-container-text.guest_text { font-size: 12px; color: #999; display: block; position: absolute; top: 7px; left: 12px; z-index: 2; background: #fff; padding: 0 4px; margin: 0; }
.pv12 .search-block .check-availability .search-rooms-forms-guests__results { font-size: 15px; }
.pv12 .search-block .check-availability .search_form_results { padding: 0 4px; }
.pv12 .search-block .check-availability .search_form_results:first-child { padding-left: 0; }
.pv12 .search-block .check-availability .result_window_container { height: 46px !important; padding: 22px 12px 6px !important; border: 1px solid #ddd !important; border-radius: 8px !important; background: #fff; }
.pv12 .search-block .check-availability .result_window_container:hover { border-color: #F5A623 !important; }
.pv12 .search-block .check-availability .send-request-holder { margin: 0 !important; flex-shrink: 0; }
.pv12 .search-block .check-availability .send-request-holder .send-request,
.pv12 .search-block .check-availability .contact-form__button.send-request { padding: 0 22px !important; background: #F5A623 !important; color: #fff !important; border: none !important; border-radius: 10px !important; font-size: 15px !important; font-weight: 700 !important; cursor: pointer !important; white-space: nowrap !important; min-height: 46px !important; height: 46px !important; line-height: 46px !important; margin: 0 !important; }
.pv12 .search-block .check-availability .send-request:hover { background: #e09518 !important; }

/* Прячем pickmeup только в search-block (не в календарях доступности) */
.pv12 .search-block .pickmeup { display: none !important; }
body.pv12-tad-active .search-block .pickmeup { display: none !important; }

/* ── TAD-dropdown ── */
.pv12-tad-dropdown { display: none; position: absolute; top: calc(100% + 6px); left: 0; width: 460px; max-width: 95vw; background: #fff; border-radius: 12px; box-shadow: 0 8px 32px rgba(0,0,0,0.18); border: 1px solid #e8e8e8; z-index: 200; overflow: hidden; }
.pv12-tad-dropdown.open { display: block; }
.pv12-tad-dropdown .tad-x-btn { position: absolute; top: 8px; right: 10px; width: 26px; height: 26px; border-radius: 50%; border: 1px solid #ddd; background: #fff; font-size: 14px; cursor: pointer; color: #777; z-index: 5; display: flex; align-items: center; justify-content: center; }
.pv12-tad-dropdown .tad-x-btn:hover { background: #f5f5f5; }
.pv12-tad-dropdown .tad-dd-body { display: flex; height: 320px; overflow: hidden; }
.pv12-tad-dropdown .tad-months-list { width: 110px; border-right: 1px solid #f0f0f0; overflow-y: auto; padding: 6px 0; flex-shrink: 0; }
.pv12-tad-dropdown .tad-month-item { padding: 7px 12px; font-size: 14px; cursor: pointer; color: #444; transition: background 0.1s; }
.pv12-tad-dropdown .tad-month-item:hover { background: #f5f5f5; }
.pv12-tad-dropdown .tad-month-item.active { color: #F5A623; font-weight: 700; background: #fffbf0; border-left: 2px solid #F5A623; }
.pv12-tad-dropdown .tad-cal-area { flex: 1; overflow-y: auto; padding: 0 14px 12px; }
.pv12-tad-dropdown .tad-day-headers { display: grid; grid-template-columns: repeat(7, 1fr); text-align: center; font-size: 12px; font-weight: 600; color: #999; padding: 8px 0 5px; position: sticky; top: 0; background: #fff; z-index: 3; border-bottom: 1px solid #f0f0f0; }
.pv12-tad-dropdown .tad-month-block { margin-bottom: 16px; }
.pv12-tad-dropdown .tad-month-name { font-size: 15px; font-weight: 700; color: #333; padding: 8px 0 6px; position: sticky; top: 28px; background: #fff; z-index: 2; }
.pv12-tad-dropdown .tad-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; text-align: center; }
.pv12-tad-dropdown .tad-cal-grid .td { height: 36px; padding: 0; font-size: 15px; border-radius: 4px; cursor: pointer; color: #222; user-select: none; display: flex; align-items: center; justify-content: center; }
.pv12-tad-dropdown .tad-cal-grid .td:hover { background: #f0f0f0; }
/* В первом месяце пустые клетки скрываем полностью; в остальных — только невидимые, чтобы сохранить выравнивание по дням недели */
.pv12-tad-dropdown .tad-cal-grid .td.empty { visibility: hidden; pointer-events: none; }
.pv12-tad-dropdown .tad-month-block:first-child .tad-cal-grid .td.empty { display: none; }
.pv12-tad-dropdown .tad-cal-grid .td.empty:hover { background: transparent; }
.pv12-tad-dropdown .tad-cal-grid .td.wk { color: #c62828; }
.pv12-tad-dropdown .tad-cal-grid .td.past { color: #ccc; cursor: default; pointer-events: none; }
.pv12-tad-dropdown .tad-cal-grid .td.past:hover { background: transparent; }
.pv12-tad-dropdown .tad-cal-grid .td.booked { background: repeating-linear-gradient(45deg,#fff0f0,#fff0f0 3px,#ffe4e4 3px,#ffe4e4 7px); color: #ccc; text-decoration: line-through; cursor: not-allowed; }
.pv12-tad-dropdown .tad-cal-grid .td.booked:hover { background: repeating-linear-gradient(45deg,#fff0f0,#fff0f0 3px,#ffe4e4 3px,#ffe4e4 7px); }
.pv12-tad-dropdown .tad-cal-grid .td.ci { background: #F5A623; color: #fff; font-weight: 700; border-radius: 50% 0 0 50%; }
.pv12-tad-dropdown .tad-cal-grid .td.co { background: #F5A623; color: #fff; font-weight: 700; border-radius: 0 50% 50% 0; }
.pv12-tad-dropdown .tad-cal-grid .td.ci.co { border-radius: 50%; } /* одиночная дата */
.pv12-tad-dropdown .tad-cal-grid .td.rng { background: rgba(245,166,35,0.18); color: #222; border-radius: 0; }
.pv12-tad-dropdown .tad-cal-grid .td.rng.wk { color: #c62828; }
/* Hint-bar с выбранными датами */
.pv12-tad-dropdown .tad-sheet-header { display: none; }
.pv12-tad-dropdown .tad-sheet-hint { display: none; }
.pv12-tad-dropdown .tad-selected-bar { padding: 6px 16px; background: #fff8e1; font-size: 14px; color: #5d4037; border-bottom: 1px solid #ffe082; display: none; }
.pv12-tad-dropdown .tad-selected-bar.show { display: block; }

/* Guests popup при .show — на десктопе над формой */
.pv12 .search-block .search-rooms-forms-guests-container { display: none; position: absolute; top: calc(100% + 6px); right: 0; left: auto; width: 380px; max-width: 90vw; background: #fff; border: 1px solid #e8e8e8; border-radius: 12px; box-shadow: 0 8px 32px rgba(0,0,0,0.18); padding: 16px; z-index: 100; }
.pv12 .search-block .search-rooms-forms-guests-container.show { display: block; }

/* ── SIDEBAR ── */
.pv12 .sidebar-card { background: #fff; border-radius: 12px; padding: 16px; box-shadow: 0 1px 4px rgba(0,0,0,0.06); }
.pv12 .sidebar-card h3 { font-size: 16px; font-weight: 700; color: #222; margin-bottom: 12px; }
.pv12 .nearby-hotel { display: flex; gap: 10px; padding: 8px 0; border-bottom: 1px solid #f5f5f5; cursor: pointer; text-decoration: none; color: inherit; }
.pv12 .nearby-hotel:last-child { border-bottom: none; padding-bottom: 0; }
.pv12 .nearby-hotel:hover .nh-name { color: #2E8B57; }
.pv12 .nh-img { width: 64px; height: 48px; border-radius: 6px; flex-shrink: 0; object-fit: cover; background: #eee; }
.pv12 .nh-info { flex: 1; min-width: 0; }
.pv12 .nh-name { font-size: 14px; font-weight: 600; color: #222; line-height: 1.3; margin-bottom: 2px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pv12 .nh-rating { font-size: 12px; color: #888; margin-bottom: 3px; }
.pv12 .nh-rating .star { color: #F5A623; }
.pv12 .nh-price .cur { font-weight: 700; color: #222; font-size: 13px; }
.pv12 .nh-price .old { color: #bbb; text-decoration: line-through; font-size: 12px; margin-left: 4px; }
.pv12 .nh-price .disc { background: #e8f5e9; color: #2e7d32; font-size: 11px; font-weight: 700; padding: 1px 5px; border-radius: 3px; margin-left: 3px; }
.pv12 .sidebar-card .show-more { text-align: center; font-size: 13px; color: #2E8B57; cursor: pointer; padding-top: 8px; margin-top: 4px; border-top: 1px solid #f5f5f5; display: block; text-decoration: none; }
.pv12 .demand-alert { background: #e8f5e9; border-radius: 10px; padding: 14px; font-size: 14px; color: #2E7D32; line-height: 1.5; }
.pv12 .demand-alert b { color: #1b5e20; }

/* ── ROOMS: loader до завершения JS-инициализации ── */
.pv12 [data-pv12-section="rooms"] .pv12-rooms-loader { display: none; text-align: center; padding: 30px 0; }
.pv12 [data-pv12-section="rooms"].pv12-rooms-loading .pv12-rooms-loader { display: block; max-height: 200px!important;}
.pv12 [data-pv12-section="rooms"].pv12-rooms-loading .pv12-rooms-loader img {  width: auto; height: auto; opacity: 0.8; }
.pv12 [data-pv12-section="rooms"].pv12-rooms-loading > *:not(h2):not(.pv12-rooms-loader) { visibility: hidden; }
.pv12-rooms-loading {
  max-height: 200px!important;
}
/* ── ROOMS: empty-dates state ── */
.pv12 .room-row-empty { display: flex; align-items: stretch; gap: 16px; padding: 14px 0; border-bottom: 1px solid #f0f0f0; }
.pv12 .room-row-empty:last-child { border-bottom: none; }
.pv12 .re-img-wrap { width: 180px; flex-shrink: 0; }
.pv12 .re-img { width: 180px; height: 125px; border-radius: 10px; position: relative; overflow: hidden; background: #eee center/cover no-repeat; }
.pv12 .pv12-room-photos-scroll { display: none; } /* скрыт на desktop */
.pv12 .re-info { flex: 1; min-width: 0; padding-top: 2px; min-height: 124px; display: flex; flex-direction: column; align-content: flex-start; flex-wrap: wrap; justify-content: flex-start; }
.pv12 .re-name { font-size: 16px; font-weight: 700; color: #2E8B57; margin-bottom: 4px; }
.pv12 .re-guests { display:none; font-size: 14px; margin-bottom: 5px; }
.pv12 .re-beds { font-size: 14px; margin-bottom: 4px; line-height: 16px;}
.pv12 .re-specs-row { display: flex; flex-wrap: wrap; gap: 8px 14px; font-size: 13px; }
.pv12 .re-specs-row .re-spec { display: inline-flex; align-items: center; gap: 4px; white-space: nowrap; }
.pv12 .re-specs-row .re-spec-icon { width: 18px; height: 18px; object-fit: contain; flex-shrink: 0; }
.pv12 .re-specs-row .re-spec-emoji { font-size: 14px; }
.pv12 .re-btn-wrap { flex-shrink: 0; align-self: flex-start; padding-top: 2px; }
.pv12 .room-row-empty > .re-btn { flex-shrink: 0; align-self: flex-start; }
.pv12 .re-btn { padding: 10px 18px; background: #F5A623; color: #fff; border: none; border-radius: 8px; font-size: 14px; font-weight: 600; cursor: pointer; white-space: nowrap; transition: background 0.15s; text-decoration: none; display: inline-block; }
.pv12 .re-btn:hover { background: #e09518; }
.pv12 .re-link-detail { font-size: 14px; color: #2E8B57; text-decoration: underline; cursor: pointer; display: block; margin-top: auto; padding-top: 6px; }

/* На десктопе: pv12-guests-compact видим, легаси-кусочки .result_window_container скрыты */
@media (min-width: 768px) {
  .pv12 .search-block .check-availability .result_window_container > .search_form_results,
  .pv12 .search-block .check-availability .result_window_container > .result_spacer { display: none !important; }
  .pv12 .search-block .check-availability .result_window_container .pv12-guests-compact { display: block !important; font-size: 15px; font-weight: 500; color: #333; line-height: 1.2; white-space: nowrap; }
  .mob-hidden { display: none !important; }
  .pv12 .room-row-empty { position: relative; }
  .pv12 .room-row-empty > .re-btn { position: absolute; right: 0; bottom: 13px; }
}
.pv12 .re-btn-wrap { position: relative; }
.pv12 .re-btn-tooltip { display: none; position: absolute; bottom: calc(100% + 8px); right: 0; background: rgba(20,20,20,0.92); color: #fff; border-radius: 8px; padding: 9px 12px; font-size: 13px; width: 214px; line-height: 1.5; pointer-events: none; z-index: 10; white-space: normal; }
.pv12 .re-btn-tooltip::after { content: ''; position: absolute; top: 100%; right: 20px; border: 6px solid transparent; border-top-color: rgba(20,20,20,0.92); }
.pv12 .re-btn-wrap:hover .re-btn-tooltip { display: block; }
.pv12 .slide-btn { position: absolute; top: 50%; transform: translateY(-50%); background: rgba(255,255,255,0.9); border: none; border-radius: 50%; width: 26px; height: 26px; cursor: pointer; font-size: 17px; display: flex; align-items: center; justify-content: center; box-shadow: 0 1px 4px rgba(0,0,0,0.25); color: #333; opacity: 0; transition: opacity 0.15s; z-index: 3; }
.pv12 .re-img:hover .slide-btn { opacity: 1; }
.pv12 .slide-btn.sl-left { left: 6px; }
.pv12 .slide-btn.sl-right { right: 6px; }
.pv12 .re-dots-mini { position: absolute; bottom: 7px; left: 50%; transform: translateX(-50%); display: flex; gap: 4px; z-index: 2; }
.pv12 .re-dots-mini span { width: 5px; height: 5px; border-radius: 50%; background: rgba(255,255,255,0.55); }
.pv12 .re-dots-mini span.active { background: #fff; }
.pv12 .re-thumbs-row { display: flex; gap: 4px; margin-top: 5px; max-width: 180px; overflow: hidden; }
.pv12 .re-thumb-sm { width: 40px; height: 30px; border-radius: 4px; cursor: pointer; border: 2px solid transparent; flex: 0 0 auto; }
.pv12 .re-thumb-sm.active { border-color: #2E8B57; }
.pv12 .re-more-sm { width: 40px; height: 30px; border-radius: 4px; background: rgba(0,0,0,0.08); display: flex; align-items: center; justify-content: center; font-size: 11px; color: #666; flex: 0 0 auto; }

/* ── ROOMS: expanded/collapsed with dates ── */
.pv12 .room-expanded { border: 1px solid #eee; border-radius: 12px; overflow: hidden; margin-bottom: 12px; }
.pv12 .rx-header { display: flex; gap: 16px; padding: 16px; background: #fafafa; border-bottom: 1px solid #f0f0f0; }
.pv12 .rx-img-block { width: 180px; flex-shrink: 0; }
.pv12 .rx-img { width: 180px; height: 125px; border-radius: 10px; position: relative; overflow: hidden; background: #eee center/cover no-repeat; }
.pv12 .rx-info { flex: 1; }
.pv12 .rx-name { font-size: 17px; font-weight: 700; color: #2E8B57; margin-bottom: 6px; }
.pv12 .rx-beds { font-size: 14px; color: #444; margin-bottom: 6px; }
.pv12 .rx-specs { display: flex; flex-wrap: wrap; gap: 8px; font-size: 13px; color: #555; margin-bottom: 8px; }
.pv12 .rx-link { font-size: 14px; color: #2E8B57; text-decoration: underline; cursor: pointer; }
.pv12 .tariff-row { display: flex; gap: 12px; padding: 14px 16px; border-bottom: 1px solid #f0f0f0; align-items: flex-start; }
.pv12 .tariff-row:last-child { border-bottom: none; }
.pv12 .tariff-left { width: 180px; flex-shrink: 0; }
.pv12 .tl-guests { font-size: 14px; color: #444; margin-bottom: 4px; }
.pv12 .tl-price { font-size: 19px; font-weight: 800; }
.pv12 .tl-nights { font-size: 13px; color: #888; }
.pv12 .tl-meal, .pv12 .tl-meal.no-meal { font-size: 13px; margin-top: 6px; color: #222; }
.pv12 .tl-cancel { font-size: 13px; color: #222; margin-top: 2px; cursor: pointer; }
.pv12 .tariff-center { flex: 1; font-size: 13px; color: #888; line-height: 1.5; }
.pv12 .tariff-center b { color: #555; }
.pv12 .tariff-right { width: 200px; flex-shrink: 0; text-align: right; }
.pv12 .tr-avail { font-size: 13px; color: #c62828; margin-bottom: 6px; }
.pv12 .tr-book-btn { display: inline-block; padding: 10px 20px; background: #F5A623; color: #fff; border: none; border-radius: 8px; font-size: 15px; font-weight: 700; cursor: pointer; transition: background 0.15s; text-decoration: none; }
.pv12 .tr-book-btn:hover { background: #e09518; }
.pv12 .tr-cashback { font-size: 13px; color: #2E8B57; margin-top: 6px; font-weight: 600; }
.pv12 .tr-guarantee { font-size: 13px; color: #1565c0; margin-top: 4px; display: flex; align-items: center; gap: 4px; justify-content: flex-end; cursor: pointer; }
.pv12 .tl-guest-mismatch { display: inline-flex; align-items: center; gap: 6px; margin-top: 6px; padding: 4px 8px; background: #FFF3E0; border: 1px solid #FFB74D; border-radius: 6px; font-size: 12px; color: #E65100; font-weight: 500; }
.pv12 .tl-guest-mismatch .gm-change { color: #1565c0; text-decoration: underline; cursor: pointer; margin-left: 2px; font-weight: 600; }
.pv12 .tariff-row.mismatch { background: #fffdf9; }
.pv12 .tariff-row.mismatch .tr-book-btn { background: #bbb; cursor: not-allowed; }

.pv12 .room-collapsed { display: flex; align-items: center; gap: 16px; padding: 12px 16px; border: 1px solid #eee; border-radius: 10px; margin-bottom: 8px; cursor: pointer; }
.pv12 .room-collapsed:hover { background: #fafafa; }
.pv12 .rc2-img { width: 80px; height: 55px; border-radius: 8px; flex-shrink: 0; object-fit: cover; background: #eee; }
.pv12 .rc2-name { font-size: 15px; font-weight: 600; color: #2E8B57; flex: 1; }
.pv12 .rc2-toggle { font-size: 13px; color: #999; }

/* ── ROOM DETAILS POPUP ── */
/* Room Details Overlay (десктоп: по центру, мобайл: bottom sheet) */
.pv12-rd-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 500; display: none; align-items: flex-start; justify-content: center; padding: 24px 20px; overflow-y: auto; }
.pv12-rd-overlay.open { display: flex; }
.pv12-rd-overlay .rd-modal { background: #fff; border-radius: 12px; width: 100%; max-width: 640px; position: relative; box-shadow: 0 16px 48px rgba(0,0,0,0.22); }
.pv12-rd-overlay .rd-header { padding: 14px 18px 0; display: flex; align-items: center; justify-content: space-between; }
.pv12-rd-overlay .rd-title { font-size: 17px; font-weight: 700; color: #2E8B57; }
.pv12-rd-overlay .rd-close { background: none; border: none; font-size: 17px; color: #aaa; cursor: pointer; padding: 2px 6px; line-height: 1; border-radius: 4px; }
.pv12-rd-overlay .rd-close:hover { background: #f0f0f0; color: #333; }
.pv12-rd-overlay .rd-body { padding: 10px 18px 20px; }
/* Описание */
.pv12-rd-overlay .rd-desc-box { background: #f9f9f9; border-radius: 8px; padding: 10px 12px; margin-bottom: 6px; font-size: 13px; color: #555; line-height: 1.65; max-height: 200px; overflow: hidden; position: relative; transition: max-height 0.25s; }
.pv12-rd-overlay .rd-desc-box.expanded { max-height: none; }
.pv12-rd-overlay .rd-desc-box:not(.expanded)::after { content: ''; position: absolute; left: 0; right: 0; bottom: 0; height: 40px; background: linear-gradient(180deg, rgba(249,249,249,0) 0%, #f9f9f9 100%); pointer-events: none; }
.pv12-rd-overlay .rd-desc-box p { margin-bottom: 5px; }
.pv12-rd-overlay .rd-desc-box p:last-child { margin-bottom: 0; }
.pv12-rd-overlay .rd-desc-wrap { margin-bottom: 12px; }
.pv12-rd-overlay .rd-desc-toggle { display: none; font-size: 13px; color: #2E8B57; text-decoration: underline; cursor: pointer; margin-top: 4px; }
/* Мобильный sheet использует те же классы — тоже ограничиваем высоту */
.pv12-room-detail-sheet .rd-desc-box { max-height: 200px; overflow: hidden; position: relative; transition: max-height 0.25s; }
.pv12-room-detail-sheet .rd-desc-box.expanded { max-height: none; }
.pv12-room-detail-sheet .rd-desc-box:not(.expanded)::after { content: ''; position: absolute; left: 0; right: 0; bottom: 0; height: 40px; background: linear-gradient(180deg, rgba(255,255,255,0) 0%, #fff 100%); pointer-events: none; }
.pv12-room-detail-sheet .rd-desc-wrap { margin-bottom: 12px; }
.pv12-room-detail-sheet .rd-desc-toggle { display: none; font-size: 13px; color: #2E8B57; text-decoration: underline; cursor: pointer; margin-top: 4px; }
/* Детальные услуги — стопкой */
.pv12-rd-overlay .rd-detailed { display: flex; flex-direction: column; gap: 6px; margin-bottom: 12px; }
.pv12-rd-overlay .rd-detailed-item { border: 1px solid #f0f0f0; border-radius: 8px; padding: 8px 10px; }
.pv12-rd-overlay .rd-am-name { display: flex; align-items: flex-start; gap: 5px; font-size: 13px; font-weight: 600; color: #222; line-height: 1.3; }
.pv12-rd-overlay .rd-am-name::before { content: '✓'; color: #2E8B57; font-weight: 800; flex-shrink: 0; }
.pv12-rd-overlay .rd-am-paid { font-size: 11px; color: #E65100; font-weight: 500; margin-top: 1px; margin-left: 16px; }
.pv12-rd-overlay .rd-am-desc { font-size: 12px; color: #666; line-height: 1.5; margin-top: 5px; margin-left: 16px; }
/* Простые удобства — 3 колонки */
.pv12-rd-overlay .rd-simple { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid #f0f0f0; padding-top: 8px; }
.pv12-rd-overlay .rd-simple-item { display: flex; align-items: center; gap: 5px; padding: 4px 0; font-size: 13px; color: #333; }
.pv12-rd-overlay .rd-simple-item::before { content: '✓'; color: #2E8B57; font-weight: 800; flex-shrink: 0; font-size: 12px; }

/* ── DESCRIPTION ── */
.pv12 .desc-text { font-size: 15px; color: #555; line-height: 1.7; }
.pv12 .desc-extra { display: none; margin-top: 8px; }
.pv12 .desc-extra.open { display: block; }
.pv12 .desc-more-link { font-size: 14px; color: #2E8B57; cursor: pointer; margin-top: 10px; display: inline-block; font-weight: 500; }
.pv12 .desc-more-link:hover { color: #256e46; }
.pv12 .desc-important { margin-top: 14px; padding: 14px 16px; background: #f9f9f9; border-radius: 10px; border-left: 3px solid #e0e0e0; }
.pv12 .desc-important-title { font-size: 14px; font-weight: 700; color: #444; margin-bottom: 12px; }
.pv12 .ci-co-row { display: flex; align-items: center; gap: 24px; margin-bottom: 10px; }
.pv12 .ci-co-item { text-align: center; }
.pv12 .ci-co-time { font-size: 25px; font-weight: 800; color: #2E8B57; display: block; line-height: 1; }
.pv12 .ci-co-label { font-size: 12px; color: #888; display: block; margin-top: 3px; }
.pv12 .ci-co-sep { font-size: 23px; color: #ddd; }
.pv12 .ci-extra { font-size: 13px; color: #666; line-height: 1.65; }

/* ── AMENITIES ── */
.pv12 .am-badge-paid { display: inline-block; padding: 1px 6px; background: #FFF3E0; color: #E65100; border-radius: 3px; font-size: 11px; font-weight: 700; margin-left: 4px; }
.pv12 .am-badge-free { display: inline-block; padding: 1px 6px; background: #e8f5e9; color: #2E8B57; border-radius: 3px; font-size: 11px; font-weight: 700; margin-left: 4px; }
.pv12 .am-pet-strip { display: flex; align-items: center; gap: 12px; padding: 10px 14px; background: #fff8e1; border: 1px solid #ffe082; border-radius: 10px; margin-bottom: 12px; }
.pv12 .am-pet-strip .pet-icon { font-size: 21px; }
.pv12 .am-pet-strip .pet-text { flex: 1; font-size: 15px; font-weight: 600; color: #333; }
.pv12 .am-pet-strip .pet-desc { font-size: 13px; color: #888; }
.pv12 .am-territory-card { border: 1px solid #eee; border-radius: 10px; padding: 14px; margin-bottom: 12px; }
.pv12 .am-territory-card .am-header { display: flex; align-items: center; gap: 6px; margin-bottom: 12px; font-size: 15px; font-weight: 600; color: #333; }
.pv12 .am-territory-card .am-header .am-header-emoji { font-size: 17px; line-height: 1; }
.pv12 .am-territory-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4px 24px; }
.pv12 .am-service { display: flex; align-items: flex-start; gap: 8px; padding: 6px 0; border-bottom: 1px solid #f8f8f8; font-size: 14px; }
.pv12 .am-service:last-child { border-bottom: none; }
.pv12 .am-service .am-emoji { font-size: 17px; flex-shrink: 0; margin-top: 1px; }
.pv12 .am-service .am-text { flex: 1; }
.pv12 .am-service .am-text .am-name { font-weight: 600; color: #333; }
.pv12 .am-service .am-text .am-desc { font-size: 12px; color: #999; margin-top: 1px; }
.pv12 .am-service .am-text .am-territory-note { font-size: 12px; color: #2E8B57; margin-top: 2px; }
.pv12 .am-service .am-photo { width: 48px; height: 48px; border-radius: 6px; flex-shrink: 0; background: linear-gradient(135deg, #c8e6c9, #a5d6a7); align-self: center; }
.pv12 .am-desc-extra { font-size: 12px; color: #666; line-height: 1.7; margin-top: 4px; display: none; }
.pv12 .am-desc-extra.open { display: block; }
.pv12 .am-expand-btn { display: inline-flex; align-items: center; gap: 3px; background: none; border: none; padding: 2px 0; font-size: 12px; color: #2E8B57; cursor: pointer; margin-top: 2px; }
.pv12 .am-expand-btn .arr { font-size: 10px; transition: transform 0.2s; display: inline-block; }
.pv12 .am-expand-btn.open .arr { transform: rotate(180deg); }
.pv12 .am-chips-card { border: 1px solid #eee; border-radius: 10px; padding: 14px; }
.pv12 .am-chips-card .am-header { display: flex; align-items: center; gap: 6px; margin-bottom: 10px; font-size: 15px; font-weight: 600; color: #333; }
.pv12 .am-mini { display: flex; flex-wrap: wrap; gap: 6px; }
.pv12 .am-mini-item { display: inline-flex; align-items: center; gap: 4px; padding: 4px 10px; background: #f5f5f5; border-radius: 6px; font-size: 13px; color: #444; }
.pv12 .am-mini-item.muted { background: #f9f9f9; color: #bbb; }

/* ── TRANSPORT / MAP / NEARBY / REVIEWS / FAQ / OBJECTS ── */
.pv12 .transport-row { display: flex; gap: 12px; }
.pv12 .transport-card { flex: 1; border: 1px solid #eee; border-radius: 10px; padding: 14px; }
.pv12 .tc-icon { font-size: 29px; margin-bottom: 6px; }
.pv12 .tc-title { font-size: 15px; font-weight: 700; margin-bottom: 4px; }
.pv12 .tc-detail { font-size: 13px; color: #666; line-height: 1.5; }
.pv12 .map-placeholder { height: 320px; background: #e8f5e9; border-radius: 10px; margin-top: 12px; cursor: pointer; position: relative; overflow: hidden; transition: box-shadow 0.2s; }
.pv12 .map-placeholder:hover { box-shadow: 0 4px 16px rgba(46,139,87,0.25); }
.pv12 .map-placeholder .mp-inline { position: absolute; inset: 0; }
.pv12 .map-placeholder .mp-inline-overlay { position: absolute; inset: 0; background: rgba(0,0,0,0); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; color: #2E8B57; font-size: 17px; font-weight: 600; pointer-events: none; z-index: 3; transition: background 0.2s; }
.pv12 .map-placeholder:hover .mp-inline-overlay { background: rgba(0,0,0,0.25); color: #fff; }
.pv12 .map-placeholder .mp-inline-overlay > span:nth-child(2) { background: rgba(255,255,255,0.92); padding: 8px 16px; border-radius: 8px; box-shadow: 0 2px 8px rgba(0,0,0,0.18); color: #2E8B57; }
.pv12 .map-placeholder:hover .mp-inline-overlay > span:nth-child(2) { background: rgba(0,0,0,0.75); color: #fff; }
.pv12 .map-placeholder .map-sub { font-size: 14px; font-weight: 400; color: #555; text-align: center; padding: 0 16px; background: rgba(255,255,255,0.85); border-radius: 6px; padding: 4px 10px; }
.pv12 .nearby-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.pv12 .nearby-cat-title { font-size: 15px; font-weight: 600; color: #333; margin-bottom: 8px; }
.pv12 .nearby-item { padding: 8px 0; border-bottom: 1px solid #f5f5f5; }
.pv12 .nearby-item:last-child { border-bottom: none; }
.pv12 .nearby-item-top { display: flex; justify-content: space-between; align-items: center; }
.pv12 .nearby-item-top .name { font-size: 14px; font-weight: 600; }
.pv12 .nearby-item-top .dist { color: #2E8B57; font-weight: 600; font-size: 14px; }
.pv12 .nearby-item-desc { font-size: 13px; color: #888; margin-top: 2px; }
.pv12 .reviews-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.pv12 .review-card { background: #f9f9f9; border-radius: 10px; padding: 14px; }
.pv12 .review-card .r-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; }
.pv12 .review-card .r-stars { color: #F5A623; font-size: 14px; }
.pv12 .review-card .r-author { font-size: 13px; color: #888; }
.pv12 .review-card .r-text { font-size: 14px; color: #444; line-height: 1.5; font-style: italic; }
.pv12 .review-card .r-photos { display: flex; gap: 6px; margin-top: 10px; flex-wrap: wrap; }
.pv12 .review-card .r-photo { width: 48px; height: 48px; border-radius: 6px; background: #eee center/cover no-repeat; cursor: pointer; display: block; flex-shrink: 0; }
.pv12 .pv12-reviews-sort { display: flex; justify-content: stretch; margin-bottom: 12px; }
.pv12 .pv12-reviews-sort .pv12-reviews-sort-select { width: 100%; }
.pv12 .pv12-reviews-sort .pv12-reviews-sort-select { font-size: 13px; padding: 6px 28px 6px 10px; border: 1px solid #ddd; border-radius: 8px; background: #fff; color: #333; cursor: pointer; appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%23555' stroke-width='1.5' fill='none' stroke-linecap='round'/></svg>"); background-repeat: no-repeat; background-position: right 10px center; }
.pv12 .reviews-all { text-align: center; padding: 12px; font-size: 15px; color: #2E8B57; cursor: pointer; display: block; text-decoration: none; }
.pv12 .faq-item { border-bottom: 1px solid #f0f0f0; padding: 12px 0; cursor: pointer; }
.pv12 .faq-item:last-child { border: none; }
.pv12 .faq-q { font-size: 15px; font-weight: 600; display: flex; justify-content: space-between; align-items: center; }
.pv12 .faq-q .arrow { color: #bbb; font-size: 13px; transition: transform 0.2s; }
.pv12 .faq-item.open .faq-q .arrow { transform: rotate(180deg); }
.pv12 .faq-a { font-size: 14px; color: #666; line-height: 1.6; margin-top: 8px; display: none; }
.pv12 .faq-item.open .faq-a { display: block; }
.pv12 .objects-row { display: flex; gap: 10px; overflow-x: auto; padding-bottom: 8px; }
.pv12 .obj-card { min-width: 160px; max-width: 160px; border-radius: 10px; overflow: hidden; border: 1px solid #eee; background: #fff; flex-shrink: 0; cursor: pointer; text-decoration: none; color: inherit; display: block; }
.pv12 .obj-card:hover { box-shadow: 0 2px 8px rgba(0,0,0,0.1); }
.pv12 .obj-card .obj-img { height: 96px; background: #eee center/cover no-repeat; }
.pv12 .obj-card .obj-body { padding: 10px; }
.pv12 .obj-card .obj-name { font-size: 14px; font-weight: 600; margin-bottom: 2px; }
.pv12 .obj-card .obj-meta { font-size: 12px; color: #888; }
.pv12 .obj-card .obj-price { font-size: 15px; font-weight: 700; margin-top: 4px; }
.pv12 .obj-card .obj-dist { font-size: 12px; color: #888; margin-top: 2px; }

/* ── MAP POPUP MODAL ── */
.pv12-map-popup-modal { display: none; position: fixed; inset: 0; z-index: 300; align-items: center; justify-content: center; }
.pv12-map-popup-modal.open { display: flex; }
.pv12-map-popup-modal .map-modal-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.5); }
.pv12-map-popup-modal .map-popup { position: relative; z-index: 1; width: 900px; max-width: 95vw; max-height: 90vh; background: #fff; border-radius: 16px; overflow: hidden; box-shadow: 0 8px 40px rgba(0,0,0,0.32); display: flex; flex-direction: column; }
.pv12-map-popup-modal .mp-header { display: flex; align-items: center; justify-content: space-between; padding: 14px 20px; border-bottom: 1px solid #f0f0f0; }
.pv12-map-popup-modal .mp-title { font-size: 17px; font-weight: 700; }
.pv12-map-popup-modal .mp-close { width: 32px; height: 32px; border-radius: 50%; border: 1px solid #ddd; background: #fff; font-size: 17px; cursor: pointer; display: flex; align-items: center; justify-content: center; color: #555; }
.pv12-map-popup-modal .mp-map { height: 70vh; max-height: 520px; position: relative; }
.pv12-map-popup-modal .map-marker-main { position: absolute; left: 50%; top: 46%; transform: translate(-50%, -100%); display: none; flex-direction: column; align-items: center; z-index: 5; pointer-events: none; }
.pv12-map-popup-modal .map-marker-main .mm-bubble { background: #F5A623; color: #fff; border-radius: 8px; padding: 4px 10px; font-size: 13px; font-weight: 700; white-space: nowrap; box-shadow: 0 2px 8px rgba(0,0,0,0.25); }
.pv12-map-popup-modal .map-marker-main .mm-pin { width: 0; height: 0; border-left: 6px solid transparent; border-right: 6px solid transparent; border-top: 8px solid #F5A623; }

/* ════════════════════════════════════════════════════════════════════
   MOBILE (≤767px) — из макета mobile_product_v12.html
   ════════════════════════════════════════════════════════════════════ */
@media (max-width: 767px) {
  /* ── Layout ── */
  .pv12 .container { padding: 0; }
  .pv12 .page-layout { display: block; }
  .pv12 .main-col, .pv12 .sidebar-col { display: block; }
  .pv12 .content-section { border-radius: 0; margin-bottom: 0; padding: 0; box-shadow: none; border-bottom: 1px solid #f0f0f0; background: #fff; }
  .pv12 .content-section:last-child { border-bottom: none; }
  .pv12 .content-section h2 { font-size: 17px; color: #222; font-weight: 700; display: flex; justify-content: flex-start; align-items: center; padding: 14px 16px; margin: 0; cursor: pointer; gap: 8px; }
  .pv12 .content-section h2 .pv12-collapse-meta { font-size: 13px; color: #999; font-weight: 400; }
  .pv12 .content-section h2 .pv12-collapse-arrow { color: #bbb; font-size: 13px; transition: transform 0.2s; flex-shrink: 0; }
  .pv12 .content-section.pv12-open h2 .pv12-collapse-arrow { transform: rotate(180deg); }
  .pv12 .content-section .pv12-collapse-body { display: none; padding: 0 16px 14px; }
  .pv12 .content-section.pv12-open .pv12-collapse-body { display: block; }
  /* Секции rooms и search — не collapsible */
  .pv12 .content-section[data-pv12-section="rooms"] h2 { cursor: default; }
  .pv12 .content-section[data-pv12-section="rooms"] .pv12-collapse-arrow { display: none; }
  .pv12 .content-section[data-pv12-section="rooms"] .pv12-collapse-body { display: block; padding: 0; }

  /* ── Breadcrumbs bar ── */
  .pv12 .breadcrumbs { padding: 8px 16px !important; background: #fff; border-bottom: 1px solid #eee; display: flex; justify-content: space-between; align-items: center; }
  .pv12 .breadcrumbs .bc-actions { display: flex; gap: 10px; }
  .pv12 .breadcrumbs .bc-act-btn { background: none; border: none; font-size: 24px; cursor: pointer; color: #555; padding: 4px; display: inline-flex; align-items: center; }
  .pv12 .breadcrumbs .bc-act-btn:active { color: #222; }

  /* ── Title bar ── */
  .pv12 .title-bar { border-radius: 0; margin-top: 0; padding: 14px 16px 12px; box-shadow: none; }
  .pv12 .title-top h1 { font-size: 23px; line-height: 1.3; display: flex; align-items: flex-start; gap: 8px; }
  .pv12 .title-top h1 .id-badge { line-height: 25px; font-size: 13px;  flex-shrink: 0; align-self: center; white-space: nowrap; }
  .pv12 .title-meta { gap: 8px; }
  .pv12 .tm-book-btn { display: none; }
  .pv12 .title-actions { display: none !important; }
  .pv12 .guarantee-row { display: none; }
  .pv12 .title-top h1 { text-transform: none; }
  .pv12 .ph-price-mob { display: none; font-size: 20px; font-weight: 800; margin-top: 4px; }
  .pv12 .ph-price-mob .unit { font-size: 13px; color: #888; font-weight: 400; }
  .pv12 .title-meta { flex-direction: column; }
  .pv12 .title-meta .tm-left { row-gap: 8px; }
  .pv12 .title-meta .tm-right { width: 100%; align-items: stretch; }
  .pv12 .title-meta .tm-left .title-chips { flex-wrap: wrap; overflow: visible; }
  .pv12 .title-chips { gap: 4px; padding-top: 10px; margin-top: 0; }
  .pv12 .t-chip { font-size: 14px; padding: 5px 10px; border-radius: 14px; }
  .pv12 .t-chip:nth-child(n+7) { display: none; }
  .pv12 .guarantee-row { margin-bottom: 0; }

  /* ── Gallery → мобильное фото ── */
  .pv12 .gallery { display: block !important; border-radius: 0; overflow: visible; margin-top: 0; flex-shrink: 0; }
  .pv12 .gallery .g-main { display: block !important; width: 100% !important; height: 260px !important; position: relative; background-size: cover !important; background-position: center !important; }
  .pv12 .gallery .g-side1, .pv12 .gallery .g-side2, .pv12 .gallery .g-map { display: none !important; }
  /* Скрытые ссылки фото для fancybox */
  .pv12 .gallery a[style*="display:none"] { display: none !important; }
  .pv12 .gallery .g-main .g-main-hint { display: none; }
  /* Показываем счётчик фото + badge на мобильном */
  .pv12 .gallery .g-main .pv12-photo-counter { display: block; position: absolute; bottom: 12px; right: 16px; background: #2E8B57; color: #fff; padding: 4px 12px; border-radius: 12px; font-size: 13px; font-weight: 600; z-index: 3; }
  .pv12 .gallery .g-main .pv12-badge-hot { display: block; position: absolute; top: 12px; left: 12px; background: #ff5252; color: #fff; padding: 5px 10px; border-radius: 6px; font-size: 12px; font-weight: 700; z-index: 3; }

  /* ── Search block → мобильный компакт ── */
  .pv12 .search-block { border-radius: 0; padding: 14px 16px; background: #fffde7; border-top: 1px solid #ffe082; border-bottom: 1px solid #ffe082; box-shadow: none; }
  .pv12 .search-block .search-block-title { font-size: 16px; margin-bottom: 8px; }
  .pv12 .search-block .search-block-title { display: none; }
  .pv12 .search-block .check-availability form { flex-wrap: wrap; gap: 6px; }
  .pv12 .search-block .check-availability .search-rooms-forms-datepicker,
  .pv12 .search-block .check-availability .search-rooms-forms-guests { flex: 1 1 0; min-width: 0; }
  .pv12 .search-block .check-availability .result_window_container { height: auto !important; min-height: 44px; }
  /* На мобильном гости: компактно «4 взр + 1 дет · 2 дома» */
  .pv12 .search-block .check-availability .result_window_container { overflow: hidden; padding: 20px 8px 4px !important; }
  .pv12 .search-block .check-availability .results_guests,
  .pv12 .search-block .check-availability .results_kids,
  .pv12 .search-block .check-availability .results_rooms,
  .pv12 .search-block .check-availability .result_spacer,
  .pv12 .search-block .check-availability .results_dsk_title,
  .pv12 .search-block .check-availability .results_mobile_title { display: none !important; }
  .pv12 .search-block .check-availability .search-rooms-container-text.guest_text { display: block !important; font-size: 12px; position: absolute; top: 4px; left: 5px; }
  .pv12 .search-block .check-availability .pv12-guests-compact { display: block; font-size: 15px; color: #333; white-space: normal; line-height: 1.3; }
  .pv12 .search-block .check-availability .search-rooms-forms-datepicker .search-rooms-container-text { font-size: 11px; }
  .pv12 .search-block .check-availability input#check-dates { font-size: 17px !important; }
  .pv12 .search-block .check-availability .result_window_container { height: 44px !important; padding: 18px 8px 4px !important; }
  .pv12 .search-block .check-availability .search-rooms-forms-guests .search-rooms-container-text.guest_text { font-size: 11px; top: 5px; left: 5px; }
  .pv12 .search-block .check-availability .send-request-holder { flex: 1 1 100%; margin-top: 4px !important; }
  .pv12 .search-block .check-availability .send-request,
  .pv12 .search-block .check-availability .contact-form__button.send-request { width: 100% !important; padding: 0px !important; height: 48px !important; font-size: 17px !important; border-radius: 10px !important; }
  /* TAD → bottom sheet на мобильном */
  .pv12-tad-dropdown { position: fixed; top: auto; left: 0; right: 0; bottom: 0; width: 100%; max-width: 100%; border-radius: 18px 18px 0 0; z-index: 1000; max-height: 85vh; display: none; flex-direction: column; }
  .pv12-tad-dropdown.open { display: flex; }
  .pv12-tad-dropdown .tad-x-btn { top: 16px; right: 16px; width: 32px; height: 32px; font-size: 17px; }
  .pv12-tad-dropdown .tad-dd-body { flex: 1; overflow: hidden; height: auto; }
  .pv12-tad-dropdown .tad-months-list { display: none; } /* скрываем sidebar месяцев */
  .pv12-tad-dropdown .tad-cal-area { padding: 0 16px 16px; }
  /* Header bottom sheet */
  .pv12-tad-dropdown .tad-sheet-header { display: flex; flex-direction: column; padding: 12px 16px 0; border-bottom: 1px solid #f0f0f0; flex-shrink: 0; }
  .pv12-tad-dropdown .tad-sheet-handle { width: 36px; height: 4px; background: #ddd; border-radius: 2px; margin: 0 auto 10px; }
  .pv12-tad-dropdown .tad-sheet-title-row { display: flex; justify-content: space-between; align-items: center; }
  .pv12-tad-dropdown .tad-sheet-title { font-size: 19px; font-weight: 700; }
  .pv12-tad-dropdown .tad-sheet-hint { font-size: 14px; color: #333; margin: 10px -16px 0; padding: 8px 16px; background: #fff8e1; border-bottom: 1px solid #ffe082; display: flex; justify-content: space-between; align-items: center; }
  .pv12-tad-dropdown .tad-sheet-reset { color: #2E8B57; font-weight: 600; cursor: pointer; font-size: 14px; background: none; border: none; padding: 0; }
  /* Убираем TAD backdrop на мобильном — добавим отдельно */

  /* Guest picker — bottom sheet (вынесен в body как .pv12-gp-sheet) */
  .pv12-gp-sheet {
    position: fixed !important; bottom: 0 !important; left: 0 !important; right: 0 !important; top: auto !important;
    width: 100% !important; max-width: 100% !important; max-height: 90vh;
    border-radius: 18px 18px 0 0 !important; z-index: 1000 !important;
    padding: 0 !important; overflow-y: auto; background: #fff;
    transform: translateY(100%); transition: transform 0.3s ease;
    box-shadow: 0 -4px 24px rgba(0,0,0,0.2);
    display: flex !important; flex-direction: column;
  }
  .pv12-gp-sheet.show { transform: translateY(0) !important; }

  /* Handle */
  .pv12-gp-sheet::before {
    content: ''; display: block; width: 36px; height: 4px; background: #ddd; border-radius: 2px; margin: 10px auto 0; flex-shrink: 0;
  }

  /* Backdrop для guest picker */
  .pv12-gp-backdrop { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.4); z-index: 999; }
  .pv12-gp-backdrop.open { display: block; }

  /* Стили элементов формы как gp-sheet */
  .pv12-gp-sheet .form-element-container { padding: 14px 16px; border-bottom: 1px solid #f0f0f0; }
  .pv12-gp-sheet .form-element-container:last-child { border-bottom: none; }
  .pv12-gp-sheet .search-rooms-forms-guests-container-number-text { font-size: 16px; font-weight: 700; color: #2E8B57; margin-bottom: 12px; }
  .pv12-gp-sheet .search-rooms-forms-guests-container-number-text > div { display: flex; justify-content: space-between; align-items: center; gap: 5px; }
  .pv12-gp-sheet .search-rooms-forms-guests-adults,
  .pv12-gp-sheet .search-rooms-forms-guests-children { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; padding: 0; position: static !important; }
  /* Убираем absolute у кнопок ±, дети */
  .pv12-gp-sheet .plus-icon, .pv12-gp-sheet .minus-icon,
  .pv12-gp-sheet .child-plus-icon, .pv12-gp-sheet .child-selected,
  .pv12-gp-sheet .search-rooms-forms-guests-children-select,
  .pv12-gp-sheet .search-rooms-forms-guests-children-results { position: static !important; }
  /* Кнопки ± в строку как gp-counter */
  .pv12-gp-sheet .search-rooms-forms-guests-adults { flex-wrap: nowrap; }
  .pv12-gp-sheet .search-rooms-forms-guests-adults .minus-icon,
  .pv12-gp-sheet .search-rooms-forms-guests-adults .plus-icon,
  .pv12-gp-sheet .search-rooms-forms-guests-adults .adults-number { order: 0; }
  .pv12-gp-sheet .search-rooms-forms-guests-adults .search-rooms-forms-guests-container-text { flex: 1; }
  .pv12-gp-sheet .search-rooms-forms-guests-adults .minus-icon { order: 1; }
  .pv12-gp-sheet .search-rooms-forms-guests-adults .adults-number { order: 2; }
  .pv12-gp-sheet .search-rooms-forms-guests-adults .plus-icon { order: 3; }
  .pv12-gp-sheet .search-rooms-forms-guests-container-text { font-size: 15px; font-weight: 600; color: #333; flex-shrink: 0; }
  .pv12-gp-sheet .minus-icon, .pv12-gp-sheet .plus-icon {
    width: 34px !important; height: 34px !important; border-radius: 50% !important; border: 1px solid #ddd !important; background: #fff !important;
    font-size: 19px !important; color: #2E8B57 !important; font-weight: 700 !important;
    display: flex !important; align-items: center; justify-content: center; cursor: pointer;
    padding: 0 !important; margin: 0 !important; min-width: 0 !important;
  }
  .pv12-gp-sheet .minus-icon:active, .pv12-gp-sheet .plus-icon:active { background: #e8f5e9 !important; }
  .pv12-gp-sheet .adults-number { border: none !important; font-size: 17px !important; font-weight: 700 !important; width: 30px !important; text-align: center !important; background: transparent !important; padding: 0 !important; -moz-appearance: textfield !important; appearance: textfield !important; }
  .pv12-gp-sheet .adults-number::-webkit-inner-spin-button,
  .pv12-gp-sheet .adults-number::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
  /* Дети — чипы + кнопка «+» в строку */
  .pv12-gp-sheet .search-rooms-forms-guests-children-results { display: flex !important; flex-wrap: wrap; gap: 6px; align-items: center; min-width: 0 !important; }
  .pv12-gp-sheet .search-rooms-forms-guests-children-selected { display: flex !important; flex-wrap: wrap; gap: 6px; align-items: center; }
  .pv12-gp-sheet .search-rooms-forms-guests-children { flex-wrap: nowrap; gap: 8px; }
  .pv12-gp-sheet .search-rooms-forms-guests-children .search-rooms-forms-guests-container-text { flex: 1; flex-shrink: 0; }
  /* child-element сообщение */
  .pv12-gp-sheet .child-element { position: static !important; font-size: 13px; color: #E65100; margin-top: 4px; padding: 6px 10px; background: #FFF3E0; border-radius: 6px; }

  /* Кнопки «Добавить домик» + «Готово» */
  .pv12-gp-sheet .search-rooms-forms-guests-submit { padding: 10px 16px 20px; border-top: 1px solid #f0f0f0; display: flex; flex-direction: column; gap: 8px; }
  .pv12-gp-sheet .search-rooms-forms-guests-add-room {
    display: block !important; width: 100%; text-align: center; padding: 12px;
    border: 1px dashed #2E8B57 !important; border-radius: 8px; color: #2E8B57; font-weight: 600; font-size: 15px; text-decoration: none; background: #fff;
  }
  .pv12-gp-sheet .search-rooms-forms-guests-submit__button {
    display: block !important; width: 100%; padding: 0px !important; height: 48px; line-height: 48px; background: #F5A623; color: #fff;
    border: none; border-radius: 10px; font-size: 17px; font-weight: 700; text-align: center; text-decoration: none; cursor: pointer;
  }
  .pv12-gp-sheet .search-rooms-forms-guests-submit__button:active { background: #e09518; }

  /* Скрываем legacy-декорацию */
  .pv12-gp-sheet .dog, .pv12-gp-sheet .paw, .pv12-gp-sheet .guests-icon,
  .pv12-gp-sheet .search-rooms-container-text.guest_text,
  .pv12-gp-sheet .search-rooms-forms-guests__results,
  .pv12-gp-sheet .result_window_container { display: none !important; }

  /* Заголовок «Гости и домики» — вставляется через ::before на handle */
  .pv12-gp-sheet .pv12-gp-header { display: flex; justify-content: space-between; align-items: flex-start; padding: 12px 16px 10px; border-bottom: 1px solid #f0f0f0; flex-shrink: 0; }
  .pv12-gp-sheet .pv12-gp-header .gp-sheet-title { font-size: 18px; font-weight: 700; color: #222; }
  .pv12-gp-sheet .pv12-gp-header .gp-sheet-summary { font-size: 14px; color: #666; margin-top: 5px; }
  .pv12-gp-sheet .pv12-gp-header .gp-sheet-close { background: none; border: none; font-size: 23px; cursor: pointer; color: #999; line-height: 1; padding: 0; }

  /* Дети чипы */
  .pv12-gp-sheet .child-selected { display: inline-flex; align-items: center; gap: 4px; padding: 5px 10px; background: #e8f5e9; border-radius: 14px; font-size: 14px; color: #2E8B57; font-weight: 500; margin: 2px; white-space: nowrap; }
  .pv12-gp-sheet .remove-adding-children { cursor: pointer; font-size: 15px; color: #2E8B57; margin-left: 2px; }
  .pv12-gp-sheet .child-plus-icon { width: 30px; height: 30px; border-radius: 50%; border: 1px dashed #2E8B57; background: #fff; color: #2E8B57; font-size: 19px; font-weight: 700; cursor: pointer; display: flex; align-items: center; justify-content: center; position: static !important; }
  .pv12-gp-sheet .search-rooms-forms-guests-children-select { display: flex !important; align-items: center; gap: 6px; position: static !important; flex-wrap: wrap; width: auto !important; }
  .pv12-gp-sheet .search-rooms-forms-guests-children-select select.child { display: none !important; }
  .pv12-gp-sheet .search-rooms-forms-guests-children-select label { display: inline-flex; }

  /* Age picker overlay */
  .pv12-age-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 1100; align-items: flex-end; justify-content: center; }
  .pv12-age-overlay.open { display: flex; }
  .pv12-age-sheet { background: #fff; border-radius: 18px 18px 0 0; width: 100%; max-width: 375px; padding: 12px 16px 24px; }
  .pv12-age-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; padding-bottom: 8px; border-bottom: 1px solid #f0f0f0; }
  .pv12-age-header span { font-size: 16px; font-weight: 700; color: #222; }
  .pv12-age-close { background: none; border: none; font-size: 23px; cursor: pointer; color: #999; padding: 0; line-height: 1; }
  .pv12-age-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
  .pv12-age-cell { padding: 12px 0; border: 1px solid #ddd; border-radius: 8px; background: #fff; cursor: pointer; font-size: 15px; font-weight: 600; color: #333; text-align: center; }
  .pv12-age-cell:active { background: #e8f5e9; border-color: #2E8B57; color: #2E8B57; }

  /* Animal checkbox row */
  .pv12-gp-sheet .animal-container { position: static !important; color: #333 !important; padding: 8px 0 0 !important; bottom: auto !important; }


  /* Секция-разделитель 8px */
  .pv12 .section-gap { display: block; height: 8px; background: #f0f0f0; }

  /* ── Rooms: без дат → мобильные карточки ── */
  .pv12 .room-row-empty { flex-direction: column; gap: 10px; padding: 12px 16px; border-bottom: 2px solid #f0f0f0; }
  .pv12 .re-img-wrap { width: calc(100% + 16px); margin-right: -16px; overflow: visible; }
  .pv12 .re-img { width: auto; height: 170px; display: none; }
  .pv12 .re-thumbs-row { display: none !important; }
  .pv12 .re-dots-mini { display: none !important; }
  .pv12 .slide-btn { display: none !important; }
  /* Горизонтальный скролл фото (1.5 фото видно) */
  .pv12 .re-img-wrap .pv12-room-photos-scroll { display: flex; gap: 4px; overflow-x: auto; -webkit-overflow-scrolling: touch; margin-bottom: 10px; }
  .pv12 .re-img-wrap .pv12-room-photos-scroll::-webkit-scrollbar { display: none; }
  .pv12 .pv12-room-photo { flex: 0 0 62%; height: 170px; border-radius: 10px; background: #eee center/cover no-repeat; position: relative; overflow: hidden; flex-shrink: 0; }
  .pv12 .pv12-room-photo + .pv12-room-photo { flex: 0 0 42%; }
  .pv12 .pv12-room-photo:last-child { border-radius: 10px 0 0 10px; }
  .pv12 .pv12-room-photo .rp-counter { position: absolute; bottom: 6px; right: 6px; background: rgba(0,0,0,0.55); color: #fff; padding: 2px 8px; border-radius: 10px; font-size: 11px; }

  /* Показать подробнее + кнопка в строку */
  .pv12 .room-row-empty .rc-bottom-row { display: flex; justify-content: space-between; align-items: center; margin-top: 8px; width: 100%; }
  .pv12 .room-row-empty .rc-bottom-row .re-btn { white-space: nowrap; font-size: 15px !important; padding: 8px 16px !important; }
  .pv12 .room-row-empty .rc-bottom-row .re-link-detail { font-size: 14px; color: #2E8B57; text-decoration: underline; cursor: pointer; }
  .pv12 .room-row-empty .re-btn-wrap { display: none; }
  .pv12 .room-row-empty .re-btn-tooltip { display: none !important; }
  .pv12 .re-btn { padding: 8px 16px; font-size: 15px; }
  .pv12 .re-btn-tooltip { display: none !important; }
  .pv12 .re-link-detail { font-size: 14px; color: #2E8B57; text-decoration: underline; cursor: pointer; }

  /* Legacy acc-name — ссылка «Показать подробнее» */
  .pv12 .pre-accomondations .acc-name.popup { color: #2E8B57 !important; }

  /* ═══════════════════════════════════════════════════════
     LEGACY TARIFF RESTYLE (pre-accomondations) — мобильный
     Макет: mobile_product_v12.html → .tariff-card-m
     ═══════════════════════════════════════════════════════ */
  .pv12 .pre-accomondations { padding: 0 !important; background: transparent !important; }
  .pv12 .pre-accomondations .pre-accomondation-title { display: none !important; }

  /* Карточка комнаты */
  .pv12 .pre-accomondations .acc-table { display: flex !important; flex-direction: column !important; width: 100% !important; }
  .pv12 .pre-accomondations .acc-row { margin: 0 0 2px !important; border: none !important; background: #fff !important; padding: 0 !important; display: flex !important; flex-direction: column !important; border-radius: 0 !important; box-shadow: none !important; width: 100% !important; }

  /* Фото + имя (верхняя часть) */
  .pv12 .pre-accomondations .acc-type { width: 100% !important; padding: 12px 16px; border: none; background: transparent; border-radius: 0; }
  .pv12 .pre-accomondations .acc-type .swiper { height: 170px !important; border-radius: 10px !important; overflow: hidden !important; }
  .pv12 .pre-accomondations .acc-type .swiper .swiper-slide { width: auto !important; margin-right: 4px !important; }
  .pv12 .pre-accomondations .acc-type .swiper .swiper-slide a { display: block; height: 170px; }
  .pv12 .pre-accomondations .acc-type .swiper .swiper-slide img { width: 100% !important; height: 170px !important; object-fit: cover !important; border-radius: 10px !important; }
  /* Прячем bullets/нав-кнопки свайпера под основным фото на мобильном */
  .pv12 .pre-accomondations .acc-type .swiper .swiper-pagination,
  .pv12 .pre-accomondations .acc-type .swiper .swiper-button-prev,
  .pv12 .pre-accomondations .acc-type .swiper .swiper-button-next { display: none !important; }
  .pv12 .pre-accomondations .acc-name { display: none !important; } /* скрыт — заменён на pv12-re-info .re-name */
  .pv12 .pre-accomondations .roomtype-beds { margin-top: 4px; font-size: 15px; }
  .pv12 .pre-accomondations .right-column-acc-type { width: 100%; }

  /* Скрыть legacy services-block, заменить на re-info стиль */
  .pv12 .pre-accomondations .services-block-services { display: none !important; }
  .pv12 .pre-accomondations .area-services { display: none !important; }
  .pv12 .pre-accomondations .roomtype-beds { display: none !important; }

  /* re-info блок внутри legacy acc-type */
  .pv12 .pre-accomondations .pv12-re-info { padding: 0; margin-top: 8px; }
  .pv12 .pre-accomondations .pv12-re-info .re-name { font-size: 18px; font-weight: 700; color: #2E8B57; margin-bottom: 4px; }
  .pv12 .pre-accomondations .pv12-re-info .re-guests { display: none; font-size: 14px; color: #666; margin-bottom: 5px; }
  .pv12 .pre-accomondations .pv12-re-info .re-specs-row { display: flex; flex-wrap: wrap; gap: 6px 12px; font-size: 13px;}
  .pv12 .pre-accomondations .pv12-re-info .re-specs-row .re-spec { padding: 0; background: none; display: inline-flex; align-items: center; gap: 4px; white-space: nowrap; }
  .pv12 .pre-accomondations .pv12-re-info .re-specs-row .re-spec-icon { width: 18px; height: 18px; object-fit: contain; flex-shrink: 0; }

  /* Показать подробнее → re-btn-wrap */
  .pv12 .pre-accomondations .show-more-btn { display: none !important; }
  .pv12 .pre-accomondations .pv12-re-btn-wrap { display: flex; justify-content: space-between; align-items: center; margin-top: 8px; padding: 0 16px 12px; }
  .pv12 .pre-accomondations .pv12-re-btn-wrap .re-link-detail { font-size: 14px; color: #2E8B57; text-decoration: underline; cursor: pointer; }

  /* Блок цен (acc-right / acc-item) → карточка-тариф */
  .pv12 .pre-accomondations .acc-right { width: 100% !important; padding: 0 !important; }
  /* .acc-options → колонка тарифов */
  .pv12 .pre-accomondations .acc-options { display: flex !important; flex-direction: column !important; padding: 15px !important; margin: 0 !important; width: 100% !important; }

  /* .acc-item → карточка-тариф (как tariff-card-m из макета) */
  .pv12 .pre-accomondations .acc-item { display: flex !important; flex-direction: column !important; border: 1px solid #eee !important; border-radius: 10px !important; margin: 0 !important; padding: 12px !important; width: auto !important; }

  /* .prices (левая часть) → верх карточки */
  .pv12 .pre-accomondations .prices { padding: 0 !important; margin: 0 !important; border: none !important; width: 100% !important; text-align: left !important; display: block !important; }

  /* Гости */
  .pv12 .pre-accomondations .people { text-align: left; font-size: 15px !important; color: #444 !important; margin-bottom: 4px !important; }
  .pv12 .pre-accomondations .people .green-icon { display: none !important; }
  .pv12 .pre-accomondations .people br { display: none !important; }
  .pv12 .pre-accomondations .price_for { display: none !important; }
  .pv12 .pre-accomondations .people .price-comment { display: none !important; }

  /* Цена + ночи inline */
  .pv12 .pre-accomondations .plan_total { text-align: left; font-size: 15px !important; font-weight: 400 !important; margin: 4px 0 !important; color: #888 !important; }
  .pv12 .pre-accomondations .plan_total_cources { font-size: 23px !important; font-weight: 800 !important; color: #222 !important; }

  /* Бейджи: питание + условия отмены → в строку */
  .pv12 .pre-accomondations .meal-conditions { display: flex !important; flex-wrap: wrap !important; gap: 8px !important; margin: 6px 0 !important; align-items: center !important; padding: 0 !important; }
  .pv12 .pre-accomondations .meal-conditions .meal-info { font-size: 13px !important; margin: 0 !important; padding: 0 !important; background: none !important; }
  .pv12 .pre-accomondations .meal-pets p { background: none !important; }
  .pv12 .pre-accomondations .meal-conditions.meal-pets { position: relative !important; top: 0 !important; }

  /* Guest mismatch */
  .pv12 .pre-accomondations .pv12-guest-mismatch { display: flex; align-items: center; gap: 6px; margin: 6px 0; padding: 6px 10px; background: #FFF3E0; border: 1px solid #FFB74D; border-radius: 8px; font-size: 12px; color: #E65100; font-weight: 500; }
  .pv12 .pre-accomondations .pv12-guest-mismatch .gm-icon { font-size: 15px; flex-shrink: 0; }
  .pv12 .pre-accomondations .pv12-guest-mismatch .gm-change { color: #1565c0; text-decoration: underline; cursor: pointer; font-weight: 600; margin-left: auto; white-space: nowrap; }
  .pv12 .pre-accomondations .book-button.pv12-disabled { background: #bbb !important; cursor: not-allowed !important; pointer-events: none !important; }
  .pv12 .pre-accomondations .roomtype-not-available_bnovo { display: none !important; }
  .pv12 .pre-accomondations hr { display: none !important; }

  /* «Нет мест» — мобильный */
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) { opacity: 0.92 !important; }
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) .acc-type .swiper { filter: grayscale(0.3) !important; }
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) .pv12-re-info .re-name { color: #888 !important; }
  .pv12 .pre-accomondations .availability-calendar { padding: 0 16px 12px !important; }
  .pv12 .pre-accomondations .availability-calendar .available-qty { font-size: 13px !important; color: #c62828 !important; display: inline-block !important; padding: 4px 10px !important; background: #fce4ec !important; border-radius: 6px !important; font-weight: 600 !important; margin-bottom: 8px !important; }
  .pv12 .pre-accomondations .availability-calendar .available-qty br { display: none !important; }
  .pv12 .pre-accomondations .availability-calendar { display: block !important; }
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) .acc-options .acc-item { display: none !important; }
  .pv12 .pre-accomondations .availability-calendar .roomtype-not-available { display: block !important; }
  .pv12 .pre-accomondations .availability-calendar .roomtype-not-available a.calendar { display: block !important; width: 100% !important; padding: 12px !important; background: #e8f5e9 !important; color: #2E8B57 !important; border: 1px solid #c8e6c9 !important; border-radius: 8px !important; font-size: 15px !important; font-weight: 600 !important; text-align: center !important; text-decoration: none !important; }
  .pv12 .pre-accomondations .availability-calendar .roomtype-not-available a.calendar img { display: none !important; }
  .pv12 .pre-accomondations .calendars.modal-filters { position: static !important; border: 1px solid #f0f0f0 !important; border-radius: 10px !important; padding: 12px !important; margin-top: 10px !important; background: #fafafa !important; }
  .pv12 .pre-accomondations .calendars .mob-close-filter { display: none !important; }
  .pv12 .pre-accomondations .calendars .legend .highlight { width: 16px !important; height: 16px !important; border-radius: 3px !important; }
  .pv12 .pre-accomondations .roomtype-not-available:not(:has(a)) { font-size: 13px !important; color: #c62828 !important; padding: 4px 10px !important; background: #fce4ec !important; border-radius: 6px !important; display: inline-block !important; margin: 4px 16px 8px !important; font-weight: 600 !important; }
  .pv12 .pre-accomondations .more-days { display: none !important; }
  .pv12 .pre-accomondations .meal-conditions .product-conditions { display: inline !important; margin: 0 !important; }
  .pv12 .pre-accomondations .meal-conditions .title-conditions { display: inline-flex !important; align-items: center !important; font-size: 13px !important; margin: 0 !important; padding: 0 !important; gap: 4px !important; }
  .pv12 .pre-accomondations .meal-conditions .title-conditions img { width: 14px !important; height: 14px !important; vertical-align: middle !important; }
  .pv12 .pre-accomondations .meal-conditions .conditions-link { text-decoration: underline !important; text-decoration-style: dotted !important; color: #222 !important; cursor: pointer !important; }

  /* .right-column → нижняя часть карточки */
  .pv12 .pre-accomondations .right-column { width: 100% !important; padding: 0 !important; margin: 0 !important; text-align: left !important; border: none !important; display: flex !important; flex-direction: column !important; align-items: stretch !important; }

  /* Доступность — перед кнопкой через order, в одну строку */
  .pv12 .pre-accomondations .available-qty { font-size: 14px !important; color: #c62828 !important; margin: 6px 0 8px !important; text-align: center !important; order: -1 !important; }
  .pv12 .pre-accomondations .available-qty br { display: none !important; }
  .pv12 .pre-accomondations .available-qty b { font-weight: 600 !important; }

  /* Кнопка «Забронировать» */
  .pv12 .pre-accomondations .book-button { width: 100% !important; display: block !important; padding: 12px !important; font-size: 17px !important; font-weight: 700 !important; text-align: center !important; border-radius: 8px !important; background: #F5A623 !important; color: #fff !important; border: none !important; text-decoration: none !important; margin: 0 !important; }
  .pv12 .pre-accomondations .book-button:active { background: #e09518 !important; }

  /* Кэшбэк */
  .pv12 .pre-accomondations .property-cashback-mini { display: flex !important; justify-content: center !important; align-items: center !important; gap: 4px !important; font-size: 14px !important; color: #2E8B57 !important; font-weight: 600 !important; margin-top: 6px !important; background: none !important; padding: 0 !important; border: none !important; }
  .pv12 .pre-accomondations .property-cashback-mini .cashback-badge-tooltip { display: none !important; }
  /* 💎 Гарантия — реальный элемент */
  .pv12 .pre-accomondations .pv12-guarantee-link { display: block !important; text-align: center; font-size: 13px; color: #1565c0; margin-top: 6px; cursor: pointer; position: relative; }
  .pv12 .pre-accomondations .pv12-guarantee-link:active { opacity: 0.7; }

  /* Legacy гарантия скрыта — используем pv12-guarantee-link */
  .pv12 .pre-accomondations .title-conditions.blue-link { display: none !important; }
  .pv12 .pre-accomondations .conditions.sale { display: none !important; }

  /* Условия отмены → тёмный popup (u-popup стиль) */
  .pv12 .pre-accomondations .conditions.modal-filters { display: none !important; }
  .pv12 .pre-accomondations .conditions-link { position: relative !important; }
  .pv12 .pre-accomondations .product-conditions { position: relative !important; }
  .pv12 .pre-accomondations .conditions.sale { display: none !important; }

  /* u-popup стиль для условий отмены и гарантии */

  /* Inline стили из legacy */
  .pv12 .pre-accomondations .roomtype-not-available_bnovo { text-align: center !important; min-width: 0 !important; }

  /* Скрываем лишнее */
  .pv12 .pre-accomondations .item-border { display: none !important; }

  /* Бейджи: питание, условия отмены */
  .pv12 .pre-accomondations .meal-conditions { display: flex; flex-wrap: wrap; gap: 8px; margin: 6px 0; align-items: center; }
  .pv12 .pre-accomondations .meal-conditions .meal-type { font-size: 13px; }
  .pv12 .pre-accomondations .product-conditions { margin-top: 0; }
  .pv12 .pre-accomondations .product-conditions .title-conditions { font-size: 13px; }
  /* Питание и условия отмены всегда чёрным (desktop) */
  .pv12 .pre-accomondations .meal-info,
  .pv12 .pre-accomondations .meal-type,
  .pv12 .pre-accomondations .title-conditions,
  .pv12 .pre-accomondations .conditions-link { color: #222 !important; }
  .pv12 .pre-accomondations .product-conditions .conditions { position: fixed !important; bottom: 0; left: 0; right: 0; top: auto; border-radius: 18px 18px 0 0; z-index: 1000; max-height: 85vh; }

  /* Доступность */
  .pv12 .pre-accomondations .available-dates-text { font-size: 14px; color: #c62828; margin: 6px 0; }

  /* Кнопка «Забронировать» */
  .pv12 .pre-accomondations .book-button { width: 100% !important; display: block !important; padding: 12px !important; font-size: 17px !important; font-weight: 700 !important; text-align: center !important; border-radius: 8px !important; background: #F5A623 !important; color: #fff !important; border: none !important; text-decoration: none !important; margin-top: 8px; }
  .pv12 .pre-accomondations .book-button:active { background: #e09518 !important; }

  /* Кэшбэк */
  .pv12 .pre-accomondations .property-cashback-mini { display: flex !important; justify-content: center; align-items: center; gap: 4px; font-size: 14px; color: #2E8B57; font-weight: 600; margin-top: 6px; }
  .pv12 .pre-accomondations .property-cashback-mini .cashback-badge-tooltip { display: none; }

  /* Гарантия — дубль legacy-блока скрыт (pv12-guarantee-link уже показывается) */
  .pv12 .pre-accomondations .title-conditions.blue-link { display: none !important; }
  .pv12 .title-conditions.mini-desc.blue-link { display: none !important; }
  /* «Без питания» → скрываем блок условий отмены */
  .pv12 .pre-accomondations .meal-conditions:has(.meal-info.red) .product-conditions { display: none !important; }
  .pv12 .pre-accomondations .conditions.sale { position: fixed !important; bottom: 0; left: 0; right: 0; top: auto; border-radius: 18px 18px 0 0; z-index: 1000; }

  /* Несоответствие гостей */
  .pv12 .pre-accomondations .not-enough-place { padding: 6px 10px; background: #FFF3E0; border: 1px solid #FFB74D; border-radius: 8px; font-size: 12px; color: #E65100; margin: 6px 0; }

  /* Скрываем лишнее */
  .pv12 .pre-accomondations .item-border { display: none; }

  /* Разделитель между комнатами */
  .pv12 .pre-accomondations .acc-row + .acc-row { border-top: 8px solid #f0f0f0; }

  /* pv12 room-expanded (если рендерится кастомно) */
  .pv12 .room-expanded { border-radius: 0; border-left: none; border-right: none; margin-bottom: 2px; }
  .pv12 .rx-header { flex-direction: column; gap: 10px; padding: 12px 16px; }
  .pv12 .rx-img-block { width: 100%; }
  .pv12 .rx-img { width: 100%; height: 200px; }
  /* Tariff cards — мобильный стиль из макета (tariff-card-m) */
  .pv12 .tariff-row { flex-direction: column; gap: 0; padding: 0; border: 1px solid #eee; border-radius: 10px; margin: 0 16px 8px; }
  .pv12 .tariff-left, .pv12 .tariff-center, .pv12 .tariff-right { width: 100%; text-align: left; padding: 0; }
  .pv12 .tariff-left { padding: 12px 12px 0; }
  .pv12 .tariff-center { padding: 0 12px; font-size: 13px; color: #999; margin-top: 4px; }
  .pv12 .tariff-right { padding: 0 12px 12px; text-align: center; }
  .pv12 .tl-guests { font-size: 15px; color: #444; margin-bottom: 4px; }
  .pv12 .tl-price { font-size: 23px; font-weight: 800; display: inline; }
  .pv12 .tl-nights { font-size: 14px; color: #888; display: inline; margin-left: 6px; }
  .pv12 .tl-meal, .pv12 .tl-cancel { display: inline; font-size: 13px; margin-right: 8px; }
  .pv12 .tl-meal, .pv12 .tl-meal.no-meal { color: #222; }
  .pv12 .tl-cancel { color: #222; cursor: pointer; text-decoration: underline; text-decoration-style: dotted; }
  .pv12 .tr-avail { font-size: 14px; color: #c62828; margin-bottom: 8px; margin-top: 6px; }
  .pv12 .tr-book-btn { width: 100%; padding: 12px; font-size: 17px; font-weight: 700; text-align: center; display: block; border-radius: 8px; }
  .pv12 .tr-cashback { font-size: 14px; color: #2E8B57; text-align: center; margin-top: 6px; font-weight: 600; }
  .pv12 .tr-guarantee { font-size: 13px; color: #1565c0; text-align: center; margin-top: 4px; justify-content: center; }

  /* ── Description ── */
  .pv12 .desc-text { font-size: 16px; line-height: 1.6; }

  /* ── Amenities ── */
  .pv12 .am-territory-grid { grid-template-columns: 1fr; }
  .pv12 .am-territory-card { padding: 12px; }

  /* ── Transport → stacked ── */
  .pv12 .transport-row { flex-direction: column; gap: 0; }
  .pv12 .transport-card { border-radius: 0; border: none; border-bottom: 1px solid #f0f0f0; padding: 10px 0; display: flex; gap: 10px; align-items: flex-start; }
  .pv12 .transport-card:last-child { border-bottom: none; }
  .pv12 .tc-icon { font-size: 23px; width: 30px; text-align: center; flex-shrink: 0; margin-bottom: 0; }

  /* ── Map ── */
  .pv12 .map-placeholder { height: 180px; border-radius: 0; margin-top: 0; }

  /* ── Nearby ── */
  .pv12 .nearby-grid { grid-template-columns: 1fr; gap: 8px; }

  /* ── Reviews ── */
  .pv12 .reviews-grid { grid-template-columns: 1fr; gap: 8px; }
  .pv12 .review-card { padding: 12px; }

  /* ── FAQ ── */
  .pv12 .faq-q { font-size: 15px; }

  /* На мобильном дубликат «Объекты рядом» в main col скрыт — есть sidebar-card */
  .pv12 .pv12-nearby-objects { display: none; }

  /* ── Objects → horizontal scroll ── */
  .pv12 .objects-row { flex-wrap: nowrap; overflow-x: auto; -webkit-overflow-scrolling: touch; padding-bottom: 6px; gap: 10px; }
  .pv12 .objects-row::-webkit-scrollbar { display: none; }
  .pv12 .obj-card { min-width: 150px; max-width: 150px; border-radius: 10px; overflow: hidden; border: 1px solid #eee; flex-shrink: 0; }
  .pv12 .obj-card .obj-img { height: 85px; }
  .pv12 .obj-card .obj-body { padding: 8px; }
  .pv12 .obj-card .obj-name { font-size: 14px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .pv12 .obj-card .obj-meta { font-size: 12px; color: #888; }
  .pv12 .obj-card .obj-price { font-size: 15px; font-weight: 700; margin-top: 3px; }

  /* Sidebar → горизонтальный скролл карточек на мобильном */
  .pv12 .sidebar-card { border-radius: 0; box-shadow: none; border-bottom: 8px solid #f0f0f0; padding: 14px 16px; background: #fff; }
  .pv12 .sidebar-card h3 { font-size: 18px; font-weight: 700; margin-bottom: 10px; }
  .pv12 .sidebar-card .nearby-hotel { display: flex; flex-direction: column; min-width: 150px; max-width: 150px; border-radius: 10px; overflow: hidden; border: 1px solid #eee; background: #fff; flex-shrink: 0; padding: 0; text-decoration: none; color: inherit; margin: 0; }
  .pv12 .sidebar-card .nearby-hotel:last-child { border-bottom: 1px solid #eee; padding-bottom: 0; }
  .pv12 .sidebar-card .nh-img { width: 100% !important; height: 85px !important; border-radius: 0 !important; }
  .pv12 .sidebar-card .nh-info { padding: 8px; }
  .pv12 .sidebar-card .nh-name { font-size: 14px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .pv12 .sidebar-card .nh-price .cur { font-size: 15px; font-weight: 700; }
  .pv12 .sidebar-card .pv12-nh-scroll { display: flex; gap: 10px; overflow-x: auto; -webkit-overflow-scrolling: touch; padding-bottom: 6px; }
  .pv12 .sidebar-card .pv12-nh-scroll::-webkit-scrollbar { display: none; }
  .pv12 .demand-alert { border-radius: 0; }

  /* ── Sidebar → после контента ── */
  .pv12 .sidebar-card { border-radius: 0; margin-bottom: 2px; box-shadow: none; }

  /* ── Modals → bottom sheets ── */
  .pv12-map-popup-modal { z-index: 1000 !important; align-items: flex-end !important; }
  .pv12-map-popup-modal .map-popup { width: 100%; max-width: 100%; max-height: 100vh; border-radius: 18px 18px 0 0; }
  .pv12-map-popup-modal .mp-body { grid-template-columns: 1fr; }
  .pv12-map-popup-modal .mp-info { border-left: none; border-top: 1px solid #f0f0f0; }
  .pv12-map-popup-modal .mp-map { height: 300px; }
  .pv12-map-popup-modal .mp-obj-img { display: none; }
  .pv12-map-popup-modal .mp-obj-price,
  .pv12-map-popup-modal .mp-book-btn,
  .pv12-map-popup-modal .mp-route { display: none; }
  .pv12-map-popup-modal .mp-obj-rating { margin-top: 4px; margin-bottom: 3px; }
  .pv12-map-popup-modal .map-marker-main { display: flex; }

  .pv12-rd-overlay { padding: 0; align-items: flex-end; z-index: 1000; }
  .pv12-rd-overlay .rd-modal { border-radius: 18px 18px 0 0; max-height: 85vh; overflow-y: auto; }

  /* Room detail sheet */
  .pv12-room-detail-sheet { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 1000; align-items: flex-end; justify-content: center; }
  .pv12-room-detail-sheet.open { display: flex; }
  .pv12-room-detail-sheet .rd-sheet { background: #fff; border-radius: 18px 18px 0 0; width: 100%; max-height: 90vh; overflow-y: auto; padding: 0; }
  .pv12-room-detail-sheet .rd-sheet-handle { width: 36px; height: 4px; background: #ddd; border-radius: 2px; margin: 10px auto 0; }
  .pv12-room-detail-sheet .rd-sheet-header { display: flex; justify-content: space-between; align-items: center; padding: 12px 16px; border-bottom: 1px solid #f0f0f0; }
  .pv12-room-detail-sheet .rd-sheet-title { font-size: 19px; font-weight: 700; color: #2E8B57; }
  .pv12-room-detail-sheet .rd-sheet-close { background: none; border: none; font-size: 23px; cursor: pointer; color: #999; padding: 0; line-height: 1; }
  .pv12-room-detail-sheet .rd-sheet-body { padding: 14px 16px 24px; }
  .pv12-room-detail-sheet .rd-desc { background: #f9f9f9; border-radius: 8px; padding: 10px 12px; margin-bottom: 12px; font-size: 14px; color: #555; line-height: 1.6; }
  .pv12-room-detail-sheet .rd-specs { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
  .pv12-room-detail-sheet .rd-spec-chip { display: inline-flex; align-items: center; gap: 4px; padding: 5px 10px; background: #f5f5f5; border-radius: 6px; font-size: 13px; color: #444; }
  .pv12-room-detail-sheet .rd-amenities-title { font-size: 15px; font-weight: 600; margin-bottom: 8px; }
  .pv12-room-detail-sheet .rd-amenities-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; }
  .pv12-room-detail-sheet .rd-amenity-row { display: flex; align-items: center; gap: 8px; padding: 5px 0; font-size: 14px; }
  .pv12-room-detail-sheet .rd-amenity-row .check { color: #2E8B57; font-weight: 700; flex-shrink: 0; }
  .pv12-room-detail-sheet .rd-amenity-paid { font-size: 11px; color: #E65100; background: #FFF3E0; padding: 1px 5px; border-radius: 3px; margin-left: 4px; font-weight: 700; }

  /* ── Mobile gallery overlay: Yandex.Travel tile view ── */
  .pv12-gal-overlay { background: #fff; overflow-y: auto; display: none; padding: 0; }
  .pv12-gal-overlay.open { display: block; }
  .pv12-gal-overlay .gal-backdrop { display: none; }
  .pv12-gal-overlay .gal-modal { position: static; width: 100%; max-height: none; border-radius: 0; display: block; box-shadow: none; overflow: visible; }
  .pv12-gal-overlay .gal-header { display: block; position: sticky; top: 0; z-index: 10; background: #fff; border-bottom: 1px solid #eee; padding: 0; }
  .pv12-gal-overlay .gal-header-back { display: flex; align-items: center; gap: 6px; padding: 12px 16px 4px; font-size: 15px; color: #2E8B57; cursor: pointer; background: none; border: none; font-weight: 500; }
  .pv12-gal-overlay .gal-header-info { display: block; padding: 0 16px 10px; }
  .pv12-gal-overlay .gal-header-name { font-size: 17px; font-weight: 700; color: #111; margin-bottom: 0; }
  .pv12-gal-overlay .gal-header-rating { font-size: 13px; color: #888; margin-top: 2px; gap: 4px; }
  .pv12-gal-overlay .gal-header-rating .star,
  .pv12-gal-overlay .gal-header-rating .stars { color: #F5A623; }
  .pv12-gal-overlay .gal-title,
  .pv12-gal-overlay .gal-close-btn { display: none; }
  .pv12-gal-overlay .gal-grid-wrap { flex: none; overflow: visible; padding: 0; }
  .pv12-gal-overlay .gal-grid-wrap::-webkit-scrollbar { display: none; }
  .pv12-gal-overlay .gal-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; padding: 4px; }
  .pv12-gal-overlay .gal-tile { aspect-ratio: 1; border-radius: 6px; overflow: hidden; cursor: pointer; position: relative; background: #f5f5f5 center/cover no-repeat; }
  .pv12-gal-overlay .gal-tile-hover { display: none; }
  .pv12-gal-overlay .gal-tile:active { opacity: 0.8; }
  .pv12-lightbox .lb-img { width: 95vw; height: 60vh; }
  .pv12-lightbox .lb-nav { width: 40px; height: 40px; }
  .pv12-lightbox .lb-prev { left: 8px; }
  .pv12-lightbox .lb-next { right: 8px; }

  /* ── Sticky CTA ── */
  .pv12 .pv12-sticky-cta { display: flex; }

  /* ── Bottom spacer для sticky CTA ── */
  .pv12 .pv12-bottom-spacer { display: block; height: 80px; }

  /* Скрываем CTA при открытом sheet — ПОСЛЕ display:flex чтобы перебить */
  body.pv12-sheet-open .pv12-sticky-cta { display: none !important; }
  body.pv12-sheet-open { overflow: hidden !important; }
}

/* Sticky CTA (скрыт на desktop, видим на mobile) */
.pv12-sticky-cta { display: none !important; }
.pv12-room-detail-sheet:not(.open) { display: none !important; }
.pv12-age-overlay:not(.open) { display: none !important; }
.pv12 .pv12-sticky-cta { justify-content: stretch; }
.pv12 .pv12-sticky-cta .price-block { display: none; }
.pv12 .pv12-sticky-cta .price-from { font-size: 12px; color: #999; }
.pv12 .pv12-sticky-cta .price { font-size: 25px; font-weight: 800; line-height: 1; }
.pv12 .pv12-sticky-cta .price-unit { font-size: 13px; color: #666; font-weight: 400; }
.pv12 .pv12-sticky-cta .btn-book { flex: 1; width: 100%; background: #F5A623; color: #fff; border: none; border-radius: 12px; padding: 16px; font-size: 18px; font-weight: 700; cursor: pointer; white-space: nowrap; min-height: 48px; }
.pv12 .pv12-sticky-cta .btn-book:active { background: #e09518; transform: scale(0.97); }
.pv12 .pv12-sticky-cta .cashback-line { display: none; }

/* Bottom spacer (скрыт на desktop) */
.pv12 .pv12-bottom-spacer { display: none; }

/* u-popup (тёмный tooltip) — глобально */
.pv12-u-popup { display: none; position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%); background: #1a3a2a; color: #fff; border-radius: 10px; padding: 14px 16px; width: 320px; max-width: 92vw; z-index: 1200; box-shadow: 0 8px 32px rgba(0,0,0,0.35); font-weight: 400; text-align: left; font-size: 14px; line-height: 1.5; }
.pv12-u-popup.open { display: block; }
.pv12-u-popup::after { display: none; }
.pv12-u-popup-backdrop { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.3); z-index: 1199; }
.pv12-u-popup-backdrop.open { display: block; }
.pv12-u-popup .u-close { position: absolute; top: 8px; right: 10px; background: none; border: none; color: rgba(255,255,255,0.5); font-size: 17px; cursor: pointer; line-height: 1; padding: 0; }
.pv12-u-popup .u-title { font-size: 16px; font-weight: 700; color: #81c784; margin-bottom: 8px; padding-right: 18px; }
.pv12-u-popup .u-list-item { display: flex; align-items: flex-start; gap: 6px; padding: 3px 0; word-break: break-word; }
.pv12-u-popup .u-list-item span { white-space: normal; }
.pv12-u-popup .u-list-item .check { color: #81c784; font-weight: 700; flex-shrink: 0; }
.pv12-u-popup .u-link { font-size: 13px; color: #81c784; text-decoration: none; font-weight: 600; display: inline-block; margin-top: 6px; }

/* Кнопка «Проверить наличие мест» — глобально */
.pv12 .pv12-check-avail-btn { display: block !important; padding: 12px !important; background: #e8f5e9 !important; color: #2E8B57 !important; border: 1px solid #c8e6c9 !important; border-radius: 8px !important; font-size: 15px !important; font-weight: 600 !important; text-decoration: none !important; cursor: pointer !important; text-align: center !important; width: 100% !important; }
.pv12 .pv12-check-avail-btn:hover { background: #c8e6c9 !important; }
.pv12 .pv12-check-avail-btn:active { background: #a5d6a7 !important; }
.pv12 .pv12-check-avail-btn img { display: none !important; }
.pv12 a.calendar.available-qty { height: auto !important; }
@media (min-width: 768px) {
  .pv12 .pv12-check-avail-btn { display: inline-block !important; width: auto !important; padding: 9px 14px !important; font-size: 13px !important; background: #fff !important; color: #555 !important; border-color: #ddd !important; }
  .pv12 .pv12-check-avail-btn:hover { border-color: #2E8B57 !important; color: #2E8B57 !important; background: #fff !important; }
}

.pv12 .pre-accomondations .mob-acc-title { display: none !important; }

/* Миниатюры под swiper фото комнат */
.pv12 .pv12-img-block { width: 180px; flex-shrink: 0; }
@media (max-width: 767px) { .pv12 .pv12-img-block { width: 100%; } }
.pv12 .pv12-thumbs { display: flex; gap: 4px; margin-top: 5px; clear: both; }
@media (max-width: 767px) { .pv12 .pv12-thumbs { display: none; } }
.pv12 .pv12-thumb { width: 33px; height: 27px; border-radius: 4px; cursor: pointer; border: 2px solid transparent; flex-shrink: 0; background-size: cover; background-position: center; }
.pv12 .pv12-thumb.active { border-color: #2E8B57; }
.pv12 .pv12-thumb-more { width: 33px; height: 27px; border-radius: 4px; background: rgba(0,0,0,0.08); display: flex; align-items: center; justify-content: center; font-size: 10px; color: #666; cursor: pointer; flex-shrink: 0; }

/* Глобально скрываем legacy блоки */
.pv12 .pre-accomondations .roomtype-not-available_bnovo { display: none !important; }

/* Legacy pickmeup в calendars скрыт — заменяем кастомным */
.pv12 .pre-accomondations .calendars .pickmeup { display: none !important; }
.pv12 .pre-accomondations .calendars .calendar-btn { display: none !important; }
.pv12 .pre-accomondations .calendars .legend { display: none !important; }
.pv12 .pre-accomondations .calendars .mob-close-filter { display: none !important; }
.pv12 .pre-accomondations .calendars.modal-filters { position: static !important; display: none; border: 1px solid #f0f0f0 !important; border-radius: 10px !important; padding: 14px !important; margin: 8px 0 0 0 !important; background: #fafafa !important; }
.pv12 .pre-accomondations .availability-calendar { padding: 0 !important; }

/* Room detail popup стили — глобально (для desktop overlay и mobile sheet) */
.rd-desc-box { background: #f9f9f9; border-radius: 8px; padding: 10px 12px; margin-bottom: 12px; font-size: 13px; color: #555; line-height: 1.65; }
.rd-desc-box p { margin-bottom: 5px; }
.rd-desc-box p:last-child { margin-bottom: 0; }
.rd-detailed { display: flex; flex-direction: column; gap: 6px; margin-bottom: 12px; }
.rd-detailed-item { border: 1px solid #f0f0f0; border-radius: 8px; padding: 8px 10px; }
.rd-am-name { display: flex; align-items: flex-start; gap: 5px; font-size: 13px; font-weight: 600; color: #222; line-height: 1.3; }
.rd-am-name::before { content: '✓'; color: #2E8B57; font-weight: 800; flex-shrink: 0; }
.rd-am-paid { font-size: 11px; color: #E65100; font-weight: 500; margin-top: 1px; margin-left: 16px; }
.rd-am-desc { font-size: 12px; color: #666; line-height: 1.5; margin-top: 5px; margin-left: 16px; white-space: pre-line; }
.rd-simple { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid #f0f0f0; padding-top: 8px; }
.rd-simple-item { display: flex; align-items: center; gap: 5px; padding: 4px 0; font-size: 13px; color: #333; }
.rd-simple-item::before { content: '✓'; color: #2E8B57; font-weight: 800; flex-shrink: 0; font-size: 12px; }
.rd-specs { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
.rd-spec-chip { display: inline-flex; align-items: center; gap: 4px; padding: 5px 10px; background: #f5f5f5; border-radius: 6px; font-size: 13px; color: #444; }
.rd-amenities-title { font-size: 15px; font-weight: 600; margin-bottom: 8px; }
.rd-amenities-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; }
@media (max-width: 767px) {
  .rd-simple { grid-template-columns: 1fr 1fr; }
}

/* Календарь доступности (avail-cal) — глобально */
.pv12 .pv12-avail-cal { margin-top: 8px; }
.pv12 .pv12-avail-cal .avail-title { font-size: 14px; color: #555; font-weight: 600; margin-bottom: 12px; }
.pv12 .pv12-avail-cal .avail-scroll-wrap { position: relative; }
.pv12 .pv12-avail-cal .avail-months-scroll { display: flex; gap: 0; overflow-x: auto; -webkit-overflow-scrolling: touch; scroll-behavior: smooth; }
.pv12 .pv12-avail-cal .avail-months-scroll::-webkit-scrollbar { height: 4px; }
.pv12 .pv12-avail-cal .avail-months-scroll::-webkit-scrollbar-thumb { background: #ddd; border-radius: 2px; }
.pv12 .pv12-avail-cal .avail-arrow { position: absolute; top: 50%; transform: translateY(-50%); width: 28px; height: 28px; border-radius: 50%; background: #fff; border: 1px solid #ddd; display: flex; align-items: center; justify-content: center; cursor: pointer; z-index: 3; font-size: 15px; color: #555; box-shadow: 0 1px 4px rgba(0,0,0,0.15); }
.pv12 .pv12-avail-cal .avail-arrow:hover { border-color: #2E8B57; color: #2E8B57; }
.pv12 .pv12-avail-cal .avail-arrow-left { left: -14px; }
.pv12 .pv12-avail-cal .avail-arrow-right { right: -14px; }
.pv12 .pv12-avail-cal .avail-month-col { flex: 0 0 50%; min-width: 200px; padding: 0 12px; }
.pv12 .pv12-avail-cal .avail-month-col:first-child { padding-left: 0; }
.pv12 .pv12-avail-cal .avail-month-col + .avail-month-col { border-left: 1px solid #eee; }
.pv12 .pv12-avail-cal .avail-month-title { font-size: 14px; font-weight: 700; color: #333; text-align: center; margin-bottom: 8px; }
.pv12 .pv12-avail-cal .cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 1px; text-align: center; }
.pv12 .pv12-avail-cal .day-header { font-size: 11px; font-weight: 600; color: #999; padding: 3px 0; }
.pv12 .pv12-avail-cal .day { height: 36px; padding: 0; font-size: 15px; border-radius: 4px; display: flex; align-items: center; justify-content: center; }
.pv12 .pv12-avail-cal .day.empty { display: none; }
.pv12 .pv12-avail-cal .day.today { font-weight: 800; color: #2E8B57; }
.pv12 .pv12-avail-cal .day.weekend { color: #c62828; }
.pv12 .pv12-avail-cal .day.booked { background: repeating-linear-gradient(45deg,#fff0f0,#fff0f0 3px,#ffe4e4 3px,#ffe4e4 7px); color: #ccc; text-decoration: line-through; }
.pv12 .pv12-avail-cal .day.free { background: #e8f5e9; color: #1b5e20; font-weight: 600; cursor: pointer; border-radius: 4px; }
.pv12 .pv12-avail-cal .day.free:hover { background: #c8e6c9; }
.pv12 .pv12-avail-cal .day.free:active { background: #a5d6a7; }
/* Выделение check-in / check-out / range — как в TAD */
.pv12 .pv12-avail-cal .day.ci { background: #F5A623 !important; color: #fff !important; font-weight: 700; border-radius: 50% 0 0 50%; }
.pv12 .pv12-avail-cal .day.co { background: #F5A623 !important; color: #fff !important; font-weight: 700; border-radius: 0 50% 50% 0; }
.pv12 .pv12-avail-cal .day.ci.co { border-radius: 50%; }
.pv12 .pv12-avail-cal .day.rng { background: rgba(245,166,35,0.18) !important; color: #222 !important; border-radius: 0; }
.pv12 .pv12-avail-cal .day.rng.weekend { color: #c62828 !important; }
.pv12 .pv12-avail-cal .day.past { color: #ccc; }
.pv12 .pv12-avail-cal .cal-hint { font-size: 13px; color: #5d4037; margin-top: 10px; padding: 8px 12px; background: #fff8e1; border-radius: 7px; border-left: 3px solid #FFB74D; }

/* Мобильный: два месяца друг под другом + кнопки скролла вверх/вниз */
@media (max-width: 767px) {
  .pv12 .pv12-avail-cal .avail-scroll-wrap { position: relative; padding: 30px 0; }
  .pv12 .pv12-avail-cal .avail-months-scroll { flex-direction: column; overflow-x: visible; overflow-y: hidden; max-height: 460px; scroll-snap-type: y mandatory; gap: 0; }
  .pv12 .pv12-avail-cal .avail-month-col { flex: 0 0 auto; width: 100%; min-width: 0; padding: 8px 0; scroll-snap-align: start; border-left: none; }
  .pv12 .pv12-avail-cal .avail-month-col:first-child { padding-top: 0; }
  .pv12 .pv12-avail-cal .avail-month-col + .avail-month-col { border-left: none; border-top: 1px solid #eee; padding-top: 12px; margin-top: 0; }
  .pv12 .pv12-avail-cal .avail-arrow { display: flex; width: 36px; height: 24px; border-radius: 12px; font-size: 13px; top: auto; left: 50%; right: auto; }
  .pv12 .pv12-avail-cal .avail-arrow-left { top: 0; bottom: auto; transform: translateX(-50%) rotate(90deg); }
  .pv12 .pv12-avail-cal .avail-arrow-right { top: auto; bottom: 0; transform: translateX(-50%) rotate(90deg); }
  .pv12 .pv12-avail-cal .day { height: 32px; font-size: 13px; }
  .pv12 .pv12-avail-cal .day.free:active { background: #81c784; }
}

/* Backdrops (TAD + guest picker) — глобально */
.pv12-tad-backdrop { display: none; position: fixed; inset: 0; background: transparent; z-index: 999; }
@media (max-width: 767px) {
  .pv12-tad-backdrop { background: rgba(0,0,0,0.4); }
}
.pv12-gp-backdrop { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.4); z-index: 999; }
.pv12-tad-backdrop.open, .pv12-gp-backdrop.open { display: block; }

/* Photo counter + badge: скрыты на desktop, видны на mobile */
@media (min-width: 768px) {
  .pv12 .gallery .g-main .pv12-photo-counter { display: none; }
  .pv12 .gallery .g-main .pv12-badge-hot { display: none; }
}

/* Toggle «Занятые варианты размещений» (desktop + mobile) */
.pv12 .pre-accomondations .pv12-occupied-wrap { margin-top: 16px !important; display: block !important; }
.pv12 .pre-accomondations .pv12-occupied-toggle { display: flex !important; align-items: center !important; justify-content: space-between !important; padding: 14px 20px !important; background: #fff !important; border: 1px solid #eee !important; border-radius: 999px !important; cursor: pointer !important; font-size: 15px !important; font-weight: 600 !important; color: #222 !important; user-select: none !important; transition: background 0.15s !important; box-sizing: border-box !important; width: 100% !important; }
.pv12 .pre-accomondations .pv12-occupied-toggle:hover { background: #fafafa !important; }
.pv12 .pre-accomondations .pv12-occupied-label { flex: 1 !important; }
.pv12 .pre-accomondations .pv12-occupied-chev { font-size: 12px !important; color: #888 !important; transition: transform 0.2s !important; margin-left: 10px !important; }
.pv12 .pre-accomondations .pv12-occupied-wrap.open .pv12-occupied-chev { transform: rotate(180deg) !important; }
.pv12 .pre-accomondations .pv12-occupied-body { display: none !important; margin-top: 10px !important; }
.pv12 .pre-accomondations .pv12-occupied-wrap.open .pv12-occupied-body { display: block !important; }
@media (max-width: 767px) { .pv12 .pre-accomondations .pv12-occupied-wrap { margin-top: 0 !important; margin-bottom: 8px !important; } }

/* ═══════════════════════════════════════════════════════
   DESKTOP LEGACY TARIFF RESTYLE (≥768px)
   Макет: desktop_product_v12.html → .room-expanded + .tariff-row
   ═══════════════════════════════════════════════════════ */
@media (min-width: 768px) {
  .pv12 .pre-accomondations { padding: 0 !important; background: transparent !important; }
  .pv12 .pre-accomondations hr { display: none !important; }
  .pv12 .pre-accomondations .pre-accomondation-title,
  .pv12 .pre-accomondations .mob-acc-title { display: none !important; }
  .pv12 .pre-accomondations .roomtype-not-available_bnovo { display: none !important; }

  /* Карточка комнаты → room-expanded */
  .pv12 .pre-accomondations .acc-table { width: 100% !important; }
  .pv12 .pre-accomondations .acc-row { border: 1px solid #eee !important; border-radius: 12px !important; overflow: hidden !important; margin-bottom: 12px !important; background: #fff !important; box-shadow: none !important; display: block !important; }

  /* Фото + инфо → rx-header */
  .pv12 .pre-accomondations .acc-type { display: flex !important; gap: 16px !important; padding: 16px !important; background: #fafafa !important; border-bottom: 1px solid #f0f0f0 !important; width: 100% !important; border-radius: 0 !important; }
  .pv12 .pre-accomondations .acc-type .swiper { width: 180px !important; height: 125px !important; flex-shrink: 0 !important; border-radius: 10px !important; overflow: hidden !important; }
  .pv12 .pre-accomondations .acc-type .swiper .swiper-slide { width: 100% !important; }
  .pv12 .pre-accomondations .acc-type .swiper .swiper-slide a { display: block !important; height: 125px !important; }
  .pv12 .pre-accomondations .acc-type .swiper .swiper-slide img { width: 100% !important; height: 125px !important; object-fit: cover !important; }
  .pv12 .pre-accomondations .right-column-acc-type { flex: 1 !important; }
  .pv12 .pre-accomondations .acc-name { display: none !important; }
  .pv12 .pre-accomondations .roomtype-beds { display: none !important; }
  .pv12 .pre-accomondations .area-services { display: none !important; }
  .pv12 .pre-accomondations .services-block-services { display: none !important; }
  .pv12 .pre-accomondations .show-more-btn { display: none !important; }

  /* pv12-re-info (имя + гости + спеки) */
  .pv12 .pre-accomondations .pv12-re-info { margin-top: 0 !important; min-height: 124px; display: flex; flex-direction: column; align-content: flex-start; flex-wrap: wrap; justify-content: flex-start; }
  .pv12 .pre-accomondations .pv12-re-info .re-name { font-size: 17px !important; font-weight: 700 !important; color: #2E8B57 !important; margin-bottom: 6px !important; }
  .pv12 .pre-accomondations .pv12-re-info .re-guests { display: none; font-size: 14px !important; color: #666 !important; margin-bottom: 5px !important; }
  .pv12 .pre-accomondations .pv12-re-info .re-specs-row { display: flex !important; flex-wrap: wrap !important; gap: 8px !important; font-size: 13px !important;  margin-bottom: 8px !important; }
  .pv12 .pre-accomondations .pv12-re-info .re-specs-row span { padding: 0 !important; background: none !important; }
  .pv12 .pre-accomondations .pv12-re-btn-wrap { padding: 0 !important; margin-top: 4px !important; display: block !important; }
  .pv12 .pre-accomondations .pv12-re-info .re-link-detail { font-size: 14px !important; color: #2E8B57 !important; text-decoration: underline !important; cursor: pointer !important; display: inline-block !important; margin-top: auto !important; }
  .pv12 .pre-accomondations .pv12-re-btn-wrap { display: none !important; }

  /* Тарифы → 3-колоночный layout */
  .pv12 .pre-accomondations .acc-options { display: block !important; width: 100% !important; padding: 15px !important; }
  .pv12 .pre-accomondations .acc-item { display: flex !important; flex-direction: row !important; gap: 12px !important; padding: 14px 16px !important; border-bottom: 1px solid #f0f0f0 !important; border-top: none !important; border-left: none !important; border-right: none !important; border-radius: 0 !important; margin: 0 !important; align-items: flex-start !important; }
  .pv12 .pre-accomondations .acc-item:last-child { border-bottom: none !important; }

  /* LEFT: prices — 180px */
  .pv12 .pre-accomondations .prices { width: 180px !important; flex-shrink: 0 !important; padding: 0 !important; display: block !important; }
  .pv12 .pre-accomondations .people { font-size: 14px !important; color: #444 !important; margin-bottom: 4px !important; }
  .pv12 .pre-accomondations .people .green-icon,
  .pv12 .pre-accomondations .people br,
  .pv12 .pre-accomondations .people .price-comment,
  .pv12 .pre-accomondations .price_for { display: none !important; }
  .pv12 .pre-accomondations .plan_total { margin: 0 !important; color: #222 !important; }
  .pv12 .pre-accomondations .plan_total_cources { font-size: 19px !important; font-weight: 800 !important; color: #222 !important; }
  /* Mismatch в left column */
  .pv12 .pre-accomondations .prices .pv12-guest-mismatch { display: inline-flex !important; align-items: center !important; gap: 6px !important; margin-top: 6px !important; padding: 4px 8px !important; background: #FFF3E0 !important; border: 1px solid #FFB74D !important; border-radius: 6px !important; font-size: 12px !important; color: #E65100 !important; font-weight: 500 !important; }
  .pv12 .pre-accomondations .pv12-guest-mismatch .gm-change { color: #1565c0 !important; text-decoration: underline !important; cursor: pointer !important; margin-left: 2px !important; font-weight: 600 !important; }
  .pv12 .pre-accomondations .pv12-guest-mismatch .gm-change:hover { color: #0d47a1 !important; }
  /* Питание и условия отмены в left column */
  .pv12 .pre-accomondations .prices .pv12-left-badges { margin-top: 6px; font-size: 13px; }
  .pv12 .pre-accomondations .prices .pv12-left-badges .pv12-badge-meal { color: #000; margin-bottom: 2px; margin-left: -2px; }
  .pv12 .pre-accomondations .prices .pv12-left-badges .pv12-badge-cancel { color: #000; cursor: pointer; text-decoration: underline dotted; }
  .pv12 .pre-accomondations .prices .pv12-left-badges .pv12-badge-cancel.pv12-badge-cancel-static { cursor: default; text-decoration: none; color: #c62828; }

  /* CENTER: тариф инфо — flex:1 */
  .pv12 .pre-accomondations .meal-conditions { flex: 1 !important; display: block !important; font-size: 13px !important; color: #888 !important; line-height: 1.5 !important; padding: 0 !important; margin: 0 !important; position: static !important; top: auto !important; }
  .pv12 .pre-accomondations .meal-conditions .meal-info,
  .pv12 .pre-accomondations .meal-conditions .product-conditions,
  .pv12 .pre-accomondations .meal-conditions .title-conditions { display: none !important; }
  .pv12 .pre-accomondations .meal-pets p { background: none !important; display: none !important; }
  .pv12 .pre-accomondations .meal-conditions.meal-pets { position: static !important; top: auto !important; }
  .pv12 .pre-accomondations .conditions.modal-filters { display: none !important; }
  /* Тариф-лейбл — добавляется JS */
  .pv12 .pre-accomondations .meal-conditions .pv12-tariff-label { display: block !important; font-size: 13px; color: #555; margin-bottom: 4px; font-weight: 600; }
  .pv12 .pre-accomondations .meal-conditions .pv12-tariff-desc { display: block !important; font-size: 13px; color: #888; line-height: 1.5; }

  /* RIGHT: кнопка + cashback + guarantee — 200px */
  .pv12 .pre-accomondations .right-column { width: 200px !important; flex-shrink: 0 !important; text-align: right !important; padding: 0 !important; display: flex !important; flex-direction: column !important; align-items: flex-end !important; border: none !important; }
  .pv12 .pre-accomondations .right-column .pv12-guest-mismatch { display: none !important; }
  .pv12 .pre-accomondations .available-qty { font-size: 13px !important; color: #c62828 !important; margin-bottom: 6px !important; text-align: right !important; order: -1 !important; }
  .pv12 .pre-accomondations .available-qty br { display: none !important; }
  .pv12 .pre-accomondations .book-button { display: inline-block !important; padding: 10px 20px !important; background: #F5A623 !important; color: #fff !important; border: none !important; border-radius: 8px !important; font-size: 15px !important; font-weight: 700 !important; text-align: center !important; text-decoration: none !important; width: auto !important; cursor: pointer !important; }
  .pv12 .pre-accomondations .book-button:hover { background: #e09518 !important; }
  .pv12 .pre-accomondations .book-button.pv12-disabled { background: #bbb !important; cursor: not-allowed !important; pointer-events: none !important; }
  .pv12 .pre-accomondations .property-cashback-mini { display: flex !important; align-items: center !important; gap: 4px !important; font-size: 13px !important; color: #2E8B57 !important; font-weight: 600 !important; margin-top: 6px !important; background: none !important; padding: 0 !important; border: none !important; justify-content: flex-end !important; }
  .pv12 .pre-accomondations .property-cashback-mini .cashback-badge-tooltip { display: none !important; }
  .pv12 .pre-accomondations .property-cashback-mini::after { content: none !important; }
  .pv12 .pre-accomondations .pv12-guarantee-link { display: block !important; text-align: right !important; font-size: 13px !important; color: #1565c0 !important; margin-top: 4px !important; cursor: pointer !important; }
  .pv12 .pre-accomondations .title-conditions.blue-link { display: none !important; }
  .pv12 .pre-accomondations .conditions.sale { display: none !important; }

  /* ── Состояние «нет мест» (room-no-avail) — десктоп ── */

  /* Компактный row: фото + инфо + кнопка */
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) { display: flex !important; flex-wrap: wrap !important; padding: 0 !important; opacity: 0.82 !important; border-radius: 10px !important; margin-bottom: 8px !important; gap: 8px 16px !important; align-items: center !important; }
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) > .acc-type { flex: 1 !important; display: flex !important; gap: 16px !important; align-items: flex-start !important; padding: 0 !important; background: transparent !important; border: none !important; }
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) .pv12-re-info { flex-direction: row !important; }
  /* Кнопка поднята на уровень acc-row через JS (.pv12-avail-btn-row) */
  .pv12 .pre-accomondations .acc-row > .pv12-avail-btn-row { flex-shrink: 0 !important; }
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) > .acc-options { flex-basis: 100% !important; width: 100% !important; }
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) .acc-type { flex: 1 !important; padding: 12px !important; background: transparent !important; border: none !important; display: flex !important; gap: 16px !important; align-items: flex-start !important; }
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) .acc-type .swiper { width: 180px !important; height: 125px !important; filter: grayscale(0.35) !important; border-radius: 10px !important; }
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) .acc-type .swiper .swiper-button-prev,
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) .acc-type .swiper .swiper-button-next,
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) .acc-type .swiper .swiper-pagination { display: none !important; }
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) .acc-type .swiper .swiper-slide img { height: 125px !important; }
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) .right-column-acc-type { flex: 1 !important; }
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) .pv12-re-info .re-name { color: #888 !important; font-size: 16px !important; margin-bottom: 3px !important; }
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) .pv12-re-info .re-guests { font-size: 14px !important; color: #aaa !important; }
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) .pv12-re-info .re-specs-row { display: none !important; }
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) .pv12-re-info .re-link-detail { display: none !important; }
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) .re-beds { display: none !important; }

  /* Бейдж «Нет мест» */
  .pv12 .pre-accomondations .availability-calendar div.available-qty { font-size: 13px !important; color: #c62828 !important; display: inline-block !important; padding: 3px 10px !important; background: #fce4ec !important; border-radius: 6px !important; font-weight: 600 !important; margin-bottom: 6px !important; }
  .pv12 .pre-accomondations .availability-calendar div.available-qty br { display: none !important; }

  /* Разделитель «Нет свободных мест» */
  .pv12 .pre-accomondations .no-avail-sep { display: flex !important; align-items: center !important; gap: 10px !important; margin: 16px 0 12px !important; color: #c62828 !important; font-size: 14px !important; font-weight: 600 !important; }
  .pv12 .pre-accomondations .no-avail-sep::before,
  .pv12 .pre-accomondations .no-avail-sep::after { content: '' !important; flex: 1 !important; height: 1px !important; background: #ffcdd2 !important; }

  /* Кнопка «Проверить наличие мест» → серая с рамкой */
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) .acc-options { flex-basis: 100% !important; width: 100% !important; }
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) .availability-calendar { padding: 0 !important; }
  .pv12 .pre-accomondations .availability-calendar .roomtype-not-available { margin: 0 !important; }
  .pv12 .pre-accomondations .availability-calendar .roomtype-not-available { display: block !important; }

  /* Скрыть acc-item внутри acc-options для нет-мест, но показать availability-calendar */
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) .acc-options .acc-item { display: none !important; }
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) .acc-options hr { display: none !important; }
  .pv12 .pre-accomondations .acc-row:has(.availability-calendar) .acc-options { border: none !important; padding: 0 !important; }

  /* Календарь доступности (room-cal-inline стиль из макета) */
  .pv12 .pre-accomondations .calendars.modal-filters { position: static !important; border: 1px solid #f0f0f0 !important; border-radius: 10px !important; padding: 14px !important; margin-top: 8px !important; background: #fafafa !important; width: 100% !important; }
  .pv12 .pre-accomondations .calendars .legend { font-size: 13px !important; color: #888 !important; margin-bottom: 8px !important; display: flex !important; align-items: center !important; gap: 6px !important; }
  .pv12 .pre-accomondations .calendars .legend .highlight { width: 16px !important; height: 16px !important; border-radius: 3px !important; background: repeating-linear-gradient(45deg,#fff0f0,#fff0f0 3px,#ffe4e4 3px,#ffe4e4 6px) !important; }
  .pv12 .pre-accomondations .calendars .mob-close-filter { display: none !important; }
  .pv12 .pre-accomondations .calendars .calendar-btn { display: none !important; }

  /* Скрываем legacy pickmeup в календаре доступности — заменяем кастомным */
  .pv12 .pre-accomondations .calendars .pickmeup { display: none !important; }
  .pv12 .pre-accomondations .calendars .calendar-btn { display: none !important; }
  .pv12 .pre-accomondations .calendars script { display: none; }

  /* Кастомный календарь доступности (2 месяца рядом) */

  /* Текст «не на выбранное кол-во» */
  .pv12 .pre-accomondations .roomtype-not-available:not(:has(a)) { font-size: 13px !important; color: #c62828 !important; padding: 3px 10px !important; background: #fce4ec !important; border-radius: 6px !important; display: inline-block !important; margin: 0 !important; font-weight: 600 !important; }

  /* Скрытые */
  .pv12 .pre-accomondations .item-border,
  .pv12 .pre-accomondations .mob-acc-title,
  .pv12 .pre-accomondations .more-days { display: none !important; }
}

/* ── RESPONSIVE tablet ── */
@media (max-width: 960px) and (min-width: 768px) {
  .pv12 .page-layout { grid-template-columns: 1fr; }
  .pv12 .gallery { grid-template-columns: 1fr 1fr; grid-template-rows: 200px 140px; }
  .pv12 .gallery .g-main { grid-column: 1/3; grid-row: 1; }
  .pv12 .gallery .g-side1 { grid-column: 1; grid-row: 2; }
  .pv12 .gallery .g-side2 { grid-column: 2; grid-row: 2; }
  .pv12 .gallery .g-map { display: none; }
  .pv12 .nearby-grid, .pv12 .reviews-grid { grid-template-columns: 1fr; }
  .pv12 .transport-row { flex-wrap: wrap; }
}
