/* =========================================================
YouTube – FIX для тёмного фона
========================================================= */

.ytLoader{
position: relative;
width: 100%;
margin: 18px auto;
border-radius: 18px;
overflow: hidden;
background: rgba(255,255,255,0.85);
box-shadow: 0 16px 40px rgba(0,0,0,0.15);
}

.ytLoader .cover{
display: block;
width: 100%;
height: auto;
margin: 0 !important;
}

.ytLoader{ position: relative; }

.playBtn{
position: absolute;
top: 50%;
left: 50%;
width: 104px;
height: 68px;
transform: translate(-50%, -50%);
border-radius: 18px;

background: rgba(0,0,0,0.72);
border: 2px solid rgba(255,255,255,0.50);
box-shadow:
0 22px 60px rgba(0,0,0,0.75),
0 0 0 3px rgba(0,0,0,0.35),
0 0 28px rgba(255,255,255,0.18);

backdrop-filter: blur(6px);
-webkit-backdrop-filter: blur(6px);

cursor: pointer;
z-index: 999999 !important;
}



/* белый треугольник */
.playBtn::before{
content:"";
position: absolute;
top: 50%;
left: 50%;
transform: translate(-42%, -50%);
width: 0;
height: 0;
border-left: 25px solid rgba(255,255,255,0.95);
border-top: 20px solid transparent;
border-bottom: 20px solid transparent;
}

.playBtn:hover{
background: rgba(0,0,0,0.72);
box-shadow: 0 22px 55px rgba(0,0,0,0.65);
}


/* тёмная тема */
body.dark-mode .ytLoader{
background: rgba(18,18,18,0.86) !important;
}


/* OVERLAY */
#menuOverlay{
position: fixed;
inset: 0;
background: rgba(0,0,0,0.16);
backdrop-filter: blur(14px);
-webkit-backdrop-filter: blur(14px);
opacity: 0;
pointer-events: none;
transition: opacity 0.25s ease;
z-index: 998;
}
#menuOverlay.open{ opacity: 1; pointer-events: auto; }

/* =========================================================
✅ ФИКС: МЕНЮ ВСЕГДА СВЕРХУ (МОБИЛА + ДЕСКТОП)
========================================================= */
.header_bottom.container{
position: sticky !important;
top: 0 !important;
z-index: 3000 !important;
background: transparent !important;
backdrop-filter: none !important;
-webkit-backdrop-filter: none !important;
border: none !important;
box-shadow: none !important;
padding-top: 8px;
padding-bottom: 8px;
}
.mobile-menu-wrapper,
.excursions-menu-wrapper{ z-index: 2999 !important; }

/* =========================================================
✅ КНОПКА ТЕМЫ В ЛЕВОМ НИЖНЕМ УГЛУ
========================================================= */
.theme-toggle{
position: fixed !important;
left: 12px !important;
bottom: 12px !important;
width: 64px !important;
height: 64px !important;
border-radius: 999px !important;
border: 1px solid rgba(255,255,255,0.6) !important;

background: radial-gradient(circle at 30% 20%, rgba(255,255,255,0.98) 0%, rgba(255,255,255,0.88) 42%, rgba(240,240,240,0.82) 100%) !important;
box-shadow:
0 16px 40px rgba(0,0,0,0.32),
0 0 0 1px rgba(255,255,255,0.25) inset,
0 0 24px rgba(255,255,255,0.22),
0 4px 12px rgba(0,0,0,0.15) !important;

display: inline-flex !important;
align-items: center !important;
justify-content: center !important;
cursor: pointer !important;
z-index: 5000 !important;
transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1), 
            box-shadow 0.4s cubic-bezier(0.34, 1.56, 0.64, 1), 
            background 0.4s cubic-bezier(0.34, 1.56, 0.64, 1),
            filter 0.3s ease !important;
padding: 0 !important;
line-height: 1 !important;
backdrop-filter: blur(12px) saturate(180%) !important;
-webkit-backdrop-filter: blur(12px) saturate(180%) !important;
}
.theme-toggle::before{
content:"";
position:absolute;
inset: 0;
border-radius: 999px;
background: radial-gradient(circle at 50% 50%, rgba(255,255,255,0.3) 0%, transparent 70%);
pointer-events:none;
opacity: 0;
z-index: 0;
transition: opacity 0.3s ease;
}
.theme-toggle::after{
content:"";
position:absolute;
inset: 6px;
border-radius: 999px;
border: 1px solid rgba(255,255,255,0.35);
pointer-events:none;
transition: border-color 0.3s ease, transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.theme-toggle:hover{ 
  transform: translateY(-4px) scale(1.05); 
  box-shadow:
    0 20px 50px rgba(0,0,0,0.38),
    0 0 0 1px rgba(255,255,255,0.3) inset,
    0 0 32px rgba(255,255,255,0.28),
    0 6px 16px rgba(0,0,0,0.2) !important;
  filter: brightness(1.08);
}
.theme-toggle:hover::before {
  opacity: 1;
  transition: opacity 0.4s ease !important;
}
.theme-toggle:hover::after {
  border-color: rgba(255,255,255,0.5);
  transform: scale(0.95);
  transition: border-color 0.4s ease, transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
}
body.dark-mode .theme-toggle:hover::before,
html.dark-mode .theme-toggle:hover::before {
  opacity: 0.6;
  transition: opacity 0.4s ease !important;
}
.theme-toggle:active{ 
  transform: translateY(-2px) scale(1.02); 
  transition: transform 0.15s ease;
}
.theme-toggle:focus{ outline: none; }

.theme-ic{ position: absolute; font-size: 18px; }
.theme-ic-sun{ opacity: 1; transform: scale(1); transition: opacity .18s ease, transform .18s ease; }
.theme-ic-moon{ opacity: 0; transform: scale(0.9); transition: opacity .18s ease, transform .18s ease; }
body.dark-mode .theme-ic-sun,
html.dark-mode body .theme-ic-sun{ opacity: 0; transform: scale(0.9); }
body.dark-mode .theme-ic-moon,
html.dark-mode body .theme-ic-moon{ opacity: 1; transform: scale(1); }

body.dark-mode .theme-toggle,
html.dark-mode .theme-toggle{
border-color: rgba(255,255,255,0.2) !important;
background: radial-gradient(circle at 30% 20%, rgba(70,78,92,0.96) 0%, rgba(20,24,31,0.94) 45%, rgba(10,12,16,0.98) 100%) !important;
box-shadow:
0 18px 48px rgba(0,0,0,0.68),
0 0 0 1px rgba(255,255,255,0.12) inset,
0 0 24px rgba(77,171,247,0.22),
0 4px 12px rgba(0,0,0,0.4) !important;
backdrop-filter: blur(14px) saturate(180%) !important;
-webkit-backdrop-filter: blur(14px) saturate(180%) !important;
transition: transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1), 
            box-shadow 0.5s cubic-bezier(0.34, 1.56, 0.64, 1), 
            background 0.5s cubic-bezier(0.34, 1.56, 0.64, 1),
            filter 0.4s ease,
            border-color 0.4s ease !important;
}
body.dark-mode .theme-toggle:hover,
html.dark-mode .theme-toggle:hover {
  transform: translateY(-4px) scale(1.05) !important;
  box-shadow:
    0 22px 58px rgba(0,0,0,0.75),
    0 0 0 1px rgba(255,255,255,0.18) inset,
    0 0 32px rgba(77,171,247,0.32),
    0 6px 16px rgba(0,0,0,0.5) !important;
  filter: brightness(1.12);
  transition: transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1), 
              box-shadow 0.5s cubic-bezier(0.34, 1.56, 0.64, 1), 
              filter 0.4s ease !important;
}
body.dark-mode .theme-toggle:hover::after,
html.dark-mode .theme-toggle:hover::after {
  border-color: rgba(77,171,247,0.4);
  transition: border-color 0.4s ease, transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
}
body.dark-mode .theme-toggle::after,
html.dark-mode .theme-toggle::after {
  transition: border-color 0.4s ease, transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
}

/* ✅ ЖЕЛЕЗОБЕТОН: иконка темы через ::before, не зависит от span внутри */
#themeToggle .theme-ic { display: none !important; }
#themeToggle::before{
content: "☀︎";
font-size: 24px;
line-height: 1;
color: #111;
display: block;
position: relative;
z-index: 2;
opacity: 1 !important;
transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1), 
            opacity 0.3s ease,
            filter 0.3s ease;
filter: drop-shadow(0 2px 4px rgba(0,0,0,0.2));
text-shadow: 0 1px 2px rgba(255,255,255,0.5);
}
#themeToggle:hover::before {
  transform: rotate(15deg) scale(1.1);
  filter: drop-shadow(0 3px 6px rgba(0,0,0,0.3));
}
#themeToggle[aria-pressed="true"]::before{
content: "☾";
color: #fff;
opacity: 1 !important;
filter: drop-shadow(0 2px 6px rgba(77,171,247,0.4));
text-shadow: 0 2px 4px rgba(0,0,0,0.3);
transition: transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1), 
            filter 0.4s ease !important;
}
#themeToggle[aria-pressed="true"]:hover::before {
  transform: rotate(-15deg) scale(1.1);
  filter: drop-shadow(0 3px 8px rgba(77,171,247,0.5));
  transition: transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1), 
              filter 0.4s ease !important;
}

/* ====== ТВОЙ БОЛЬШОЙ ЗАГОЛОВОК (как был) ====== */
.main-title-container { float: left; margin: 0; padding: 0; width: 50%; display: flex; align-items: center; justify-content: flex-start; }
.main-title {
font-size: 42px;
font-weight: 700;
color: #2c3e50;
margin: 0;
padding: 20px 0;
text-align: left;
position: relative;
font-family: 'Georgia', 'Times New Roman', serif;
text-transform: uppercase;
letter-spacing: 2px;
line-height: 1.1;
}
.title-text {
display: block;
background: linear-gradient(45deg, #3498db, #2c3e50);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.1);
padding-bottom: 10px;
}
.title-underline {
display: block;
width: 150px;
height: 4px;
background: linear-gradient(to right, #3498db, #2c3e50);
margin-top: 8px;
border-radius: 2px;
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}
.wave-title { position: relative; display: inline-block; background: linear-gradient(45deg, #3498db, #2c3e50); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; transition: all 0.3s ease; }
.main-title:hover .wave-title {
background: linear-gradient(90deg, #1a237e 0%, #283593 25%, #3949ab 50%, #283593 75%, #1a237e 100%);
background-size: 200% auto;
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
animation: waveText 2s linear infinite;
background-position: 0% center;
}
@keyframes waveText { 0% { background-position: 0% center; } 100% { background-position: 200% center; } }
.main-title:hover .title-underline {
background: linear-gradient(90deg, #1a237e 0%, #283593 25%, #3949ab 50%, #283593 75%, #1a237e 100%);
background-size: 200% auto;
animation: waveLine 2s linear infinite;
width: 180px;
transition: all 0.3s ease;
}
@keyframes waveLine { 0% { background-position: 0% 0; } 100% { background-position: 200% 0; } }

.article-title { font-size: 36px; color: #2c3e50; margin-bottom: 20px; position: relative; padding-bottom: 10px; }
.article-title::after { content: ''; position: absolute; bottom: 0; left: 0; width: 100px; height: 3px; background: linear-gradient(to right, #3498db, #2c3e50); }
.article-title:hover { color: #1a237e; }
.article-title:hover::after { background: linear-gradient(to right, #1a237e, #3949ab); width: 120px; transition: all 0.3s ease; }

@media (max-width: 1200px) { .main-title { font-size: 36px; } .main-title-container { width: 45%; } .article-title { font-size: 32px; } }
@media (max-width: 992px) { .main-title { font-size: 32px; padding: 15px 0; } .main-title-container { width: 40%; } .article-title { font-size: 28px; } }
@media (max-width: 768px) { .main-title { font-size: 28px; letter-spacing: 1px; padding: 10px 0; } .main-title-container { width: 35%; } .title-underline { width: 120px; height: 3px; } .article-title { font-size: 24px; } }
@media (max-width: 576px) {
.main-title { font-size: 24px; padding: 8px 0; letter-spacing: 0.5px; }
.main-title-container { width: 100%; text-align: center; justify-content: center; float: none; margin-bottom: 10px; }
.title-text { text-align: center; }
.title-underline { margin: 8px auto 0; }
.article-title { font-size: 20px; }
}
@media (max-width: 480px) {
.main-title { font-size: 20px; }
.title-underline { width: 100px; }
.article-title { font-size: 18px; }
.main-title:hover .wave-title { animation: none; background: #1a237e; -webkit-text-fill-color: #1a237e; }
}

/* Футер */
.footer_section { background: linear-gradient(135deg, #1a237e 0%, #283593 50%, #3949ab 100%); color: white; padding: 30px 0; margin-top: 50px; }

/* === ХЕДЕР ДЛЯ МОБИЛЬНОГО МЕНЮ === */
.header_bottom.container { margin-top: 4px; margin-bottom: 4px; }

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

/* Контейнер мобильного меню */
.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); }
}

/* =========================================================
НОЧНЫЙ РЕЖИМ - ЕДИНЫЙ ЧЕРНЫЙ ФОН ДЛЯ ВСЕХ УСТРОЙСТВ
========================================================= */
body.dark-mode,
html.dark-mode,
html.dark-mode body {
background: #000000 !important;
background-color: #000000 !important;
color: #f0f0f0 !important;
}

/* АГРЕССИВНЫЙ ФИКС ДЛЯ МОБИЛЬНЫХ - ЧЕРНЫЙ ФОН ВЕЗДЕ */
@media (max-width: 768px) {
body.dark-mode,
html.dark-mode,
html.dark-mode body {
background: #000000 !important;
background-color: #000000 !important;
}

/* Убираем фоны у основных контейнеров (НО НЕ У ВСЕХ * !) */
body.dark-mode .content_section,
html.dark-mode .content_section,
body.dark-mode .container,
html.dark-mode .container,
body.dark-mode .row,
html.dark-mode .row,
body.dark-mode .content,
html.dark-mode .content,
body.dark-mode .content_rubric,
html.dark-mode .content_rubric,
body.dark-mode .sidebar,
html.dark-mode .sidebar,
body.dark-mode .header_top,
html.dark-mode .header_top,
body.dark-mode .header_section,
html.dark-mode .header_section,
body.dark-mode .description,
html.dark-mode .description,
body.dark-mode .article_header,
html.dark-mode .article_header {
background: transparent !important;
background-color: transparent !important;
}

body.dark-mode .content_section.container,
html.dark-mode .content_section.container,
body.dark-mode .row,
html.dark-mode .row {
border: none !important;
box-shadow: none !important;
margin: 0 !important;
}
}

/* Заголовки в темном режиме */
body.dark-mode .main-title,
html.dark-mode .main-title,
body.dark-mode .article-title,
html.dark-mode .article-title,
body.dark-mode h1,
html.dark-mode h1,
body.dark-mode h2,
html.dark-mode h2,
body.dark-mode h3,
html.dark-mode h3,
body.dark-mode h4,
html.dark-mode h4,
body.dark-mode h5,
html.dark-mode h5,
body.dark-mode h6,
html.dark-mode h6 {
color: #f0f0f0 !important;
}

body.dark-mode .wave-title,
html.dark-mode .wave-title {
background: linear-gradient(45deg, #4dabf7, #2196f3) !important;
-webkit-background-clip: text !important;
background-clip: text !important;
-webkit-text-fill-color: transparent !important;
}

body.dark-mode .title-underline,
html.dark-mode .title-underline {
background: linear-gradient(to right, #4dabf7, #2196f3) !important;
}

/* Ссылки в темном режиме */
body.dark-mode a,
html.dark-mode a { color: #4dabf7 !important; }
body.dark-mode a:hover,
html.dark-mode a:hover { color: #64b5f6 !important; }

/* Формы в темном режиме */
body.dark-mode input,
html.dark-mode input,
body.dark-mode textarea,
html.dark-mode textarea,
body.dark-mode select,
html.dark-mode select {
background-color: #2a2a2a !important;
color: #f0f0f0 !important;
border-color: #444 !important;
}

/* УБИРАЕМ БЕЛЫЙ ФОН У КОНТЕЙНЕРОВ (точечно) */
html.dark-mode .container,
body.dark-mode .container,
html.dark-mode .row,
body.dark-mode .row,
html.dark-mode .content,
body.dark-mode .content,
html.dark-mode .content_rubric,
body.dark-mode .content_rubric,
html.dark-mode .sidebar,
body.dark-mode .sidebar,
html.dark-mode section,
body.dark-mode section,
html.dark-mode div:not(.theme-toggle):not(.btn-hamburger):not(.wrapper) {
background: transparent !important;
background-color: transparent !important;
}

/* =========================================================
ФИКС БАННЕРА/ФОТО - БЕЗ ИЗМЕНЕНИЙ
========================================================= */
.tvbox, .tvbox_article, .tvbox_article_test, .tvbox_rubric{ background: transparent !important; }

.tvbox::before, .tvbox::after,
.tvbox_article::before, .tvbox_article::after,
.tvbox_article_test::before, .tvbox_article_test::after,
.tvbox_rubric::before, .tvbox_rubric::after{
opacity: 0 !important;
background: transparent !important;
box-shadow: none !important;
filter: none !important;
pointer-events: none !important;
}
.tvbox .wrapper{
position: relative;
overflow: hidden;
border-radius: 26px;
display: block;
width: 100%;
background-position: center center !important;
background-repeat: no-repeat !important;
background-size: cover !important;
}
.tvbox .wrapper::after{
content:"";
position:absolute;
inset:0;
pointer-events:none;
background: radial-gradient(ellipse at center, rgba(0,0,0,0) 58%, rgba(0,0,0,0.22) 100%);
}
body.dark-mode .tvbox .wrapper::after,
html.dark-mode .tvbox .wrapper::after{
background: radial-gradient(ellipse at center, rgba(0,0,0,0) 55%, rgba(0,0,0,0.45) 100%);
}
body.dark-mode .tvbox .wrapper,
html.dark-mode .tvbox .wrapper{
filter: brightness(0.92) saturate(1.05) contrast(1.05) !important;
}

/* Плавные переходы */
body.dark-mode *,
html.dark-mode * {
transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease !important;
}

/* =========================================================
✅ ИСПРАВЛЕНИЕ (ГЛАВНОЕ): названия экскурсий на карточках — ЧЁРНЫЕ в dark
(УБРАЛИ конфликтующие белые правила, оставили только одно итоговое)
========================================================= */
body.dark-mode .catItemTitle a,
body.dark-mode .itemTitle a,
body.dark-mode .moduleItemTitle a,
body.dark-mode .latestItemTitle a,
html.dark-mode .catItemTitle a,
html.dark-mode .itemTitle a,
html.dark-mode .moduleItemTitle a,
html.dark-mode .latestItemTitle a{
color: #0b0b0b !important;
text-shadow: none !important;
background: rgba(255,255,255,0.85) !important;
background-color: rgba(255,255,255,0.85) !important;
padding: 7px 11px !important;
border-radius: 12px !important;
display: inline-block !important;
box-shadow: 0 10px 26px rgba(0,0,0,0.45) !important;
}

body.dark-mode .catItemTitle a:hover,
body.dark-mode .itemTitle a:hover,
body.dark-mode .moduleItemTitle a:hover,
body.dark-mode .latestItemTitle a:hover,
html.dark-mode .catItemTitle a:hover,
html.dark-mode .itemTitle a:hover,
html.dark-mode .moduleItemTitle a:hover,
html.dark-mode .latestItemTitle a:hover{
background: rgba(255,255,255,0.95) !important;
background-color: rgba(255,255,255,0.95) !important;
color: #000 !important;
}

/* Текст внутри K2 (оставляем белым и читабельным) */
body.dark-mode .content_section,
body.dark-mode .content_section .content,
html.dark-mode .content_section,
html.dark-mode .content_section .content{
color: #eaeaea !important;
opacity: 1 !important;
filter: none !important;
}
body.dark-mode .itemFullText,
body.dark-mode .itemIntroText,
body.dark-mode .itemFullText *,
body.dark-mode .itemIntroText *,
body.dark-mode .elpiadis-tour,
body.dark-mode .elpiadis-tour *,
body.dark-mode .full_text,
body.dark-mode .full_text *,
html.dark-mode .itemFullText,
html.dark-mode .itemIntroText,
html.dark-mode .itemFullText *,
html.dark-mode .itemIntroText *,
html.dark-mode .elpiadis-tour,
html.dark-mode .elpiadis-tour *,
html.dark-mode .full_text,
html.dark-mode .full_text *{
color: #eaeaea !important;
opacity: 1 !important;
filter: none !important;
}
body.dark-mode hr,
html.dark-mode hr{
border-color: rgba(255,255,255,0.14) !important;
}
