/* =========================================================
? СОВРЕМЕННЫЙ ГАМБУРГЕР И МОБИЛЬНОЕ МЕНЮ - ОБНОВЛЕННЫЙ ДИЗАЙН
========================================================= */

/* Контейнер мобильного меню */
.mobile-menu-bar { display: flex; align-items: center; gap: 10px; justify-content: flex-start; flex-wrap: nowrap; }

/* 1. ГАМБУРГЕР - МИНИМАЛИСТИЧНЫЙ И ЭЛЕГАНТНЫЙ */
.btn-hamburger {
position: relative;
width: 54px;
height: 54px;
background: linear-gradient(135deg, #ff7b00 0%, #ff5500 100%);
border-radius: 16px;
box-shadow:
0 10px 30px rgba(255, 107, 58, 0.25),
inset 0 1px 1px rgba(255, 255, 255, 0.2);
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
border: 1px solid rgba(255, 255, 255, 0.25);
cursor: pointer;
outline: none;
z-index: 1001;
margin-right: 12px;
overflow: hidden;
}
.btn-hamburger::before {
content: '';
position: absolute;
inset: 0;
background: linear-gradient(135deg,
rgba(255, 255, 255, 0.1) 0%,
rgba(255, 255, 255, 0.05) 50%,
transparent 100%);
border-radius: 15px;
z-index: 1;
pointer-events: none;
}
.btn-hamburger::after {
content: '';
position: absolute;
inset: -2px;
background: linear-gradient(135deg, #ff8a00, #ff4d00);
border-radius: 18px;
z-index: -1;
opacity: 0;
transition: opacity 0.4s ease;
filter: blur(12px);
}
.btn-hamburger:hover::after { opacity: 0.7; }
.btn-hamburger:hover {
transform: translateY(-3px) scale(1.05);
box-shadow:
0 18px 40px rgba(255, 107, 58, 0.35),
inset 0 1px 2px rgba(255, 255, 255, 0.3);
}
.btn-hamburger:active {
transform: translateY(0) scale(0.98);
transition-duration: 0.1s;
box-shadow:
0 8px 20px rgba(255, 107, 58, 0.2),
inset 0 1px 1px rgba(0, 0, 0, 0.1);
}
.hamburger-line {
width: 24px;
height: 2.5px;
background: linear-gradient(to right, #ffffff 50%, #fff8f0 100%) !important;
border-radius: 3px;
margin: 3.5px 0;
transition: all 0.4s cubic-bezier(0.68, -0.55, 0.265, 1.55);
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
position: relative;
z-index: 2;
}
.btn-hamburger.open .hamburger-line:nth-child(1) {
transform: translateY(9.5px) rotate(45deg);
width: 26px;
background: linear-gradient(to right, #ffffff, #fff0e0) !important;
}
.btn-hamburger.open .hamburger-line:nth-child(2) {
opacity: 0;
transform: translateX(-20px) scale(0.5);
}
.btn-hamburger.open .hamburger-line:nth-child(3) {
transform: translateY(-9.5px) rotate(-45deg);
width: 26px;
background: linear-gradient(to right, #ffffff, #fff0e0) !important;
}

/* 2. ПЛАШКИ */
.menu-bubbles {
display: flex;
gap: 10px;
align-items: center;
flex-wrap: nowrap;
min-width: 0;
position: relative;
z-index: 1000;
}
.bubble-text {
position: relative;
padding: 12px 24px 13px;
font-size: 15px;
font-weight: 700;
color: #fff;
background: linear-gradient(135deg, var(--bubble-start, #ff8a00), var(--bubble-end, #ff4d00));
border-radius: 50px;
box-shadow:
0 10px 25px rgba(0, 0, 0, 0.2),
inset 0 1px 1px rgba(255, 255, 255, 0.15),
inset 0 -1px 1px rgba(0, 0, 0, 0.1);
max-width: 300px;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
letter-spacing: 0.02em;
display: inline-flex;
align-items: center;
justify-content: center;
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
cursor: pointer;
user-select: none;
backdrop-filter: blur(10px);
-webkit-backdrop-filter: blur(10px);
border: 1px solid rgba(255, 255, 255, 0.15);
text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}
.bubble-text::after {
content: '';
position: absolute;
inset: 0;
background: linear-gradient(45deg, transparent 30%, rgba(255, 255, 255, 0.05) 50%, transparent 70%);
border-radius: 50px;
pointer-events: none;
}
.bubble-text::before {
content: '';
position: absolute;
left: -14px;
top: 50%;
transform: translateY(-50%);
border: 14px solid transparent;
border-right-color: var(--bubble-arrow, #ff6a00);
filter: drop-shadow(-3px 0 3px rgba(0,0,0,0.15));
z-index: 1;
}
.bubble-text:hover {
transform: translateY(-2px);
box-shadow:
0 15px 35px rgba(0, 0, 0, 0.25),
inset 0 1px 2px rgba(255, 255, 255, 0.2),
inset 0 -1px 1px rgba(0, 0, 0, 0.15);
background: linear-gradient(135deg, var(--bubble-start-hover, #ff9500), var(--bubble-end-hover, #ff5c00));
border-color: rgba(255, 255, 255, 0.25);
}
.bubble-text:active { transform: translateY(0); transition-duration: 0.1s; }

.main-bubble{ animation: bubbleIntro 0.6s ease-out 0.1s both; cursor: pointer; user-select: none; }
.bubble-label{ display: inline-block; max-width: 230px; overflow: hidden; text-overflow: ellipsis; }

/* Вторая плашка */
.sub-bubble{ font-size: 12px; padding: 6px 14px 7px; background: linear-gradient(135deg, #ffb980, #ff7a3f); box-shadow: 0 4px 14px rgba(0,0,0,0.20); }
.sub-bubble::before{ display: none; }
.bubble-label-sub{ max-width: 200px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; display: inline-block; }

@keyframes bubbleIntro{
0% { opacity: 0; transform: translateY(8px) scale(0.96); }
70% { opacity: 1; transform: translateY(-2px) scale(1.02); }
100% { opacity: 1; transform: translateY(0) scale(1); }
}

/* Десктоп-меню */
.desktop-menu{ display: none; }

/* 3. ВЫПАДАЮЩИЕ МЕНЮ */
.mobile-menu-wrapper,
.excursions-menu-wrapper {
max-height: 0;
overflow: hidden;
opacity: 0;
background: rgba(255, 255, 255, 0.95);
backdrop-filter: blur(30px) saturate(180%);
-webkit-backdrop-filter: blur(30px) saturate(180%);
border-radius: 24px;
margin-top: 15px;
box-shadow:
0 25px 60px rgba(0, 0, 0, 0.15),
inset 0 1px 0 rgba(255, 255, 255, 0.3),
0 0 0 1px rgba(255, 255, 255, 0.1);
transform: translateY(-20px) scale(0.95);
transition: all 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
position: relative;
border: 1px solid rgba(255, 255, 255, 0.2);
}
.mobile-menu-wrapper.open,
.excursions-menu-wrapper.open {
max-height: 75vh;
opacity: 1;
transform: translateY(0) scale(1);
animation: menuSlideIn 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.excursions-menu-title {
padding: 18px 24px 14px;
font-weight: 800;
font-size: 17px;
color: #ff6a00;
letter-spacing: 0.05em;
text-transform: uppercase;
background: linear-gradient(to right, rgba(255, 248, 240, 0.9), rgba(255, 240, 224, 0.7));
border-bottom: 2px solid rgba(255, 106, 0, 0.1);
position: sticky;
top: 0;
z-index: 2;
backdrop-filter: blur(20px);
-webkit-backdrop-filter: blur(20px);
border-radius: 24px 24px 0 0;
}
.excursions-menu-inner{ padding: 10px 0 6px; }
.excursions-list{ list-style: none; margin: 0; padding: 0 0 6px 0; max-height: 60vh; overflow: auto; }
.excursions-list li{ margin: 0; }

.excursions-list li a {
display: flex;
align-items: center;
padding: 15px 24px;
font-size: 15.5px;
line-height: 1.4;
text-decoration: none;
background: rgba(255, 255, 255, 0.7);
color: #333 !important;
border-top: 1px solid rgba(0, 0, 0, 0.05);
transition: all 0.3s ease;
position: relative;
overflow: hidden;
}
.excursions-list li.active > a::before {
content: '';
position: absolute;
left: 0;
top: 0;
bottom: 0;
width: 4px;
background: linear-gradient(to bottom, #ff6a00, #ff8a00);
border-radius: 0 2px 2px 0;
}
.excursions-list li a:hover {
background: rgba(255, 240, 224, 0.9);
color: #ff5500 !important;
transform: translateX(5px);
padding-left: 28px;
}
.excursions-list li.active > a {
background: linear-gradient(90deg, rgba(255, 240, 224, 0.9), rgba(255, 232, 210, 0.7)) !important;
color: #ff5500 !important;
font-weight: 700;
}
.excursions-list li a:hover::after {
content: '→';
position: absolute;
right: 20px;
color: #ff6a00;
font-weight: bold;
animation: slideIn 0.3s ease;
}
@keyframes slideIn { from { transform: translateX(10px); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
.excursions-empty{ padding: 14px 16px 16px; color: #444; font-size: 14px; }

/* 4. ОБЫЧНОЕ МЕНЮ САЙТА */
.mobile-menu-wrapper ul, .mobile-menu-wrapper .nav{ list-style: none; margin: 0; padding: 6px 0; }
.mobile-menu-wrapper ul li, .mobile-menu-wrapper .nav > li{ margin: 0; }

.mobile-menu-wrapper ul li a,
.mobile-menu-wrapper .nav > li > a {
display: block;
padding: 16px 24px;
font-size: 16px;
line-height: 1.4;
color: #333 !important;
text-decoration: none;
background: rgba(255, 255, 255, 0.7);
border-bottom: 1px solid rgba(0, 0, 0, 0.05);
transition: all 0.3s ease;
position: relative;
}
.mobile-menu-wrapper ul li:last-child > a, .mobile-menu-wrapper .nav > li:last-child > a{ border-bottom: none; border-radius: 0 0 24px 24px; }
.mobile-menu-wrapper ul li:first-child > a, .mobile-menu-wrapper .nav > li:first-child > a{ border-radius: 24px 24px 0 0; }

.mobile-menu-wrapper ul li a:hover,
.mobile-menu-wrapper .nav > li > a:hover {
background: rgba(255, 240, 224, 0.9);
color: #ff5500 !important;
padding-left: 32px;
}

.mobile-menu-wrapper ul li.active > a,
.mobile-menu-wrapper .nav > li.active > a {
background: linear-gradient(90deg, rgba(255, 240, 224, 0.9), rgba(255, 232, 210, 0.7)) !important;
color: #ff5500 !important;
font-weight: 700;
}
.mobile-menu-wrapper ul li.active > a::before,
.mobile-menu-wrapper .nav > li.active > a::before {
content: '';
position: absolute;
left: 0;
top: 0;
bottom: 0;
width: 4px;
background: linear-gradient(to bottom, #ff6a00, #ff8a00);
border-radius: 0 2px 2px 0;
}

/* 5. ОВЕРЛЕЙ С ГЛУБИНОЙ */
#menuOverlay.open {
background: rgba(0, 0, 0, 0.3);
backdrop-filter: blur(20px) brightness(0.9);
-webkit-backdrop-filter: blur(20px) brightness(0.9);
}

/* 6. АДАПТИВНОСТЬ */
@media (max-width: 480px) {
.btn-hamburger { width: 50px; height: 50px; border-radius: 14px; }
.hamburger-line { width: 22px; height: 2.5px; margin: 3px 0; }
.btn-hamburger.open .hamburger-line:nth-child(1) { transform: translateY(8.5px) rotate(45deg); }
.btn-hamburger.open .hamburger-line:nth-child(3) { transform: translateY(-8.5px) rotate(-45deg); }
.bubble-text { padding: 10px 18px 11px; font-size: 14px; max-width: 220px; }
.bubble-text::before { left: -12px; border-width: 12px; }
.excursions-menu-title { padding: 16px 20px 12px; font-size: 16px; }
.excursions-list li a,
.mobile-menu-wrapper ul li a,
.mobile-menu-wrapper .nav > li > a { padding: 14px 20px; font-size: 15px; }
}

/* На десктопе */
@media (min-width: 992px){
#menuOverlay{ display: none !important; }
.mobile-menu-bar{ display: none !important; }
.mobile-menu-wrapper{ display: none !important; }
.excursions-menu-wrapper{ display: none !important; }
.desktop-menu{ display: block; }

/* Убираем скроллбары в десктопе - контент не должен обрамляться скроллбарами */
.elp-contact-scope .modal-content {
  overflow: hidden !important;
}
.excursions-list {
  overflow: visible !important;
  max-height: none !important;
}
}

/* 7. ТЕМНЫЙ РЕЖИМ ДЛЯ НОВОГО ДИЗАЙНА */
body.dark-mode .btn-hamburger,
html.dark-mode .btn-hamburger {
background: linear-gradient(135deg, #333 0%, #222 100%);
border: 1px solid rgba(255, 255, 255, 0.15);
box-shadow:
0 10px 30px rgba(0, 0, 0, 0.3),
inset 0 1px 1px rgba(255, 255, 255, 0.1);
}
body.dark-mode .btn-hamburger:hover,
html.dark-mode .btn-hamburger:hover {
box-shadow:
0 18px 40px rgba(0, 0, 0, 0.4),
inset 0 1px 2px rgba(255, 255, 255, 0.15);
}
body.dark-mode .btn-hamburger::after,
html.dark-mode .btn-hamburger::after { background: linear-gradient(135deg, #444, #222); }

body.dark-mode .hamburger-line,
html.dark-mode .hamburger-line { background: linear-gradient(to right, #ffffff, #e0e0e0) !important; }

body.dark-mode .mobile-menu-wrapper,
body.dark-mode .excursions-menu-wrapper,
html.dark-mode .mobile-menu-wrapper,
html.dark-mode .excursions-menu-wrapper {
background: rgba(30, 30, 30, 0.95);
border: 1px solid rgba(255, 255, 255, 0.1);
box-shadow:
0 25px 60px rgba(0, 0, 0, 0.3),
inset 0 1px 0 rgba(255, 255, 255, 0.05);
}
body.dark-mode .excursions-menu-title,
html.dark-mode .excursions-menu-title {
color: #4dabf7;
background: linear-gradient(to right, rgba(30, 40, 50, 0.9), rgba(40, 50, 60, 0.7));
border-bottom-color: rgba(77, 171, 247, 0.2);
}
body.dark-mode .excursions-list li a,
html.dark-mode .excursions-list li a {
background: rgba(40, 40, 40, 0.7);
color: #f0f0f0 !important;
border-top-color: rgba(255, 255, 255, 0.05);
}
body.dark-mode .excursions-list li a:hover,
html.dark-mode .excursions-list li a:hover {
background: rgba(50, 60, 70, 0.9);
color: #4dabf7 !important;
}
body.dark-mode .excursions-list li.active > a::before,
html.dark-mode .excursions-list li.active > a::before {
background: linear-gradient(to bottom, #4dabf7, #2196f3);
}

body.dark-mode .mobile-menu-wrapper ul li a,
body.dark-mode .mobile-menu-wrapper .nav > li > a,
html.dark-mode .mobile-menu-wrapper ul li a,
html.dark-mode .mobile-menu-wrapper .nav > li > a {
background: rgba(40, 40, 40, 0.7);
color: #f0f0f0 !important;
border-bottom-color: rgba(255, 255, 255, 0.05);
}
body.dark-mode .mobile-menu-wrapper ul li a:hover,
body.dark-mode .mobile-menu-wrapper .nav > li > a:hover,
html.dark-mode .mobile-menu-wrapper ul li a:hover,
html.dark-mode .mobile-menu-wrapper .nav > li > a:hover {
background: rgba(50, 60, 70, 0.9);
color: #4dabf7 !important;
}
body.dark-mode .mobile-menu-wrapper ul li.active > a::before,
body.dark-mode .mobile-menu-wrapper .nav > li.active > a::before,
html.dark-mode .mobile-menu-wrapper ul li.active > a::before,
html.dark-mode .mobile-menu-wrapper .nav > li.active > a::before {
background: linear-gradient(to bottom, #4dabf7, #2196f3);
}

body.dark-mode .bubble-text,
html.dark-mode .bubble-text{
background: linear-gradient(135deg, #333, #222) !important;
color: #f0f0f0 !important;
box-shadow: 0 6px 18px rgba(0,0,0,0.4) !important;
}
body.dark-mode .bubble-text::before,
html.dark-mode .bubble-text::before{ border-right-color: #444 !important; }
body.dark-mode .sub-bubble,
html.dark-mode .sub-bubble{ background: linear-gradient(135deg, #444, #333) !important; }

/* overlay в dark */
body.dark-mode #menuOverlay.open,
html.dark-mode #menuOverlay.open{
background: rgba(0,0,0,0.7) !important;
backdrop-filter: blur(20px) !important;
-webkit-backdrop-filter: blur(20px) !important;
}

/* 8. ПЛАВНЫЕ ПЕРЕХОДЫ */
.btn-hamburger,
.hamburger-line,
.bubble-text,
.mobile-menu-wrapper,
.excursions-menu-wrapper,
.excursions-list li a,
.mobile-menu-wrapper ul li a {
will-change: transform, opacity;
transform: translateZ(0);
backface-visibility: hidden;
}
@keyframes menuSlideIn {
from { opacity: 0; transform: translateY(-20px) scale(0.95); }
to { opacity: 1; transform: translateY(0) scale(1); }
}

