    :root {
    --bs-danger-rgb: 192, 0, 0;
    --bs-primary-rgb:73, 169, 176;
    --dark-bg: #1a1a1a;
    --darker-bg: #121212;
    --card-bg: #2d2d2d;
    --text-primary: #ffffff;
    --text-secondary: #adb5bd;
    --primary-color: #00ebfca4;
    --primary-hover: #49a9b05d;
    --border-color: #444;
    --bs-btn-active-bg: #75ffe156;
    --bs-btn-active-border-color: #2a6154;
     --bs-dropdown-link-active-bg:  #6fffe073;
    
}

hr {
    height: 0.5px !important;
    opacity: 1 !important;
}

.btn {
    border-radius: 0.5rem;
    padding: 0.625rem 1.5rem;
    font-weight: 500;
    transition: all 0.2s ease;
}



.btn-primary {

    background-color: var(--primary-color);
    border-color: var(--primary-color);
    --bs-btn-color: #fff;
    --bs-btn-bg: #6fffe073;
    --bs-btn-border-color: #6fffe073;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #6fffe073;
    --bs-btn-hover-border-color: #6fffe073;
    --bs-btn-focus-shadow-rgb: 49, 132, 253;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #6fffe073;
    --bs-btn-active-border-color: #6fffe073;
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: #6fffe073;
    --bs-btn-disabled-border-color: #6fffe073;
}


  #stars-canvas {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: -1;
    pointer-events: none;
    background: transparent;
  }


.btn-primary:hover {
    background-color: var(--primary-hover);
    border-color: var(--primary-hover);
    transform: translateY(-1px);
}

.btn-outline-light {
    color: var(--text-primary);
    border-color: var(--border-color);
}

.btn-outline-light:hover {
    background-color: rgba(255,255,255,0.1);
    border-color: var(--border-color);
    color: var(--text-primary);
}

.btn-primary:active{
    background-color: #6fffe073;

}
.alert {
    border-radius: 0.5rem;
    background-color: #dc3545;
    color: white;
    border: none;
}
.btn-primary{
    border-radius: 16.36px;
    border-color:none;
}

.text-muted {
    color: #49A9B0 !important;
}

.text-primary {
    color: #49A9B0 !important;
}

     @font-face {
    font-family: 'CommuterSans';
    src: url("../../fonts/commuterssans-regular.otf") format("opentype");
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'HomeVideo-Bold';
    src: url("../../fonts/HomeVideo-Bold.otf") format("opentype");
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'HomeVideo-Regular';
    src: url("../../fonts/HomeVideo-Regular.otf") format("opentype");
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Unbounded';
    src: url("../../fonts/Unbounded-Regular.ttf") format("truetype");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Unbounded-Bold';
    src: url("../../fonts/Unbounded-Bold.ttf") format("truetype");
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Unbounded-Light';
    src: url("../../fonts/Unbounded-Light.ttf") format("truetype");
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Unbounded-ExtraLight';
    src: url("../../fonts/Unbounded-ExtraLight.ttf") format("truetype");
    font-weight: 200;
    font-style: normal;
    font-display: swap;
}

body {
    background-image: url("../../images/background.webp");
    background-size: 100%; /* чтобы заполнял весь экран */
    background-repeat: no-repeat;
    background-attachment: fixed;
    color: #fff;
    font-family: "Unbounded-ExtraLight";
    background-color: rgb(20, 20, 20);

        /* Отключение выделения текста *//
    
        -webkit-user-select: none; /* Chrome, Safari */
        -moz-user-select: none;    /* Firefox */
        -ms-user-select: none;     /* IE10+ */
        user-select: none;         /* Standard */

        /* Оптимизация для мобильных */
        -webkit-tap-highlight-color: transparent;
        -webkit-text-size-adjust: 100%;
        overscroll-behavior: none;

    }

    .small-telegram{
            transform: scale(0.3);
            display: inline-block;
            vertical-align: middle;
            margin: -3rem;
            margin-top: -2.7rem;
        }

        main {
            background-color: rgba(30, 30, 30, 0.1); /* Полупрозрачный тёмный фон */
            border: 0.5px solid rgba(255, 255, 255, 0.2); /* Полупрозрачная светлая граница для стеклянного эффекта */
            border-radius: 29.22px; /* Закругление углов */
            padding: 20px; /* Внутренние отступы */
            backdrop-filter: blur(10px); /* Размытие фона за элементом */
            -webkit-backdrop-filter: blur(10px); /* Для поддержки в WebKit-браузерах (Safari) */
            box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1); /* Легкая тень для глубины */
        }


/* Стили для меню перевода */
#languageDropdown {
    display: flex;
    align-items: center;
    transition: all 0.2s ease;
    padding:0;
}

/* Фон выпадающего меню */
.language-dropdown .dropdown-menu {
    background-color: #49a9b05d; /* Полупрозрачный бирюзовый */
    border: 1px solid rgba(255, 255, 255, 0.2);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-radius: 8px;
    overflow: hidden;
    min-width: 120px;
    font-size: 1vw;
}

/* Пункты меню */
.language-dropdown .dropdown-item {
    color: white;
    padding: 8px 15px;
    font-size: 14px;
    transition: all 0.2s ease;
}

/* Активный язык */
.language-dropdown .dropdown-item.active {
    background-color: #00ebfca4 !important; /* Полупрозрачный акцентный */
    color: white;
    font-weight: 500;
}

/* Эффект при наведении */
.language-dropdown .dropdown-item:hover:not(.active) {
    background-color: rgba(255, 255, 255, 0.1);
}

/* Разделитель */
.language-dropdown .dropdown-divider {
    border-color: rgba(255, 255, 255, 0.1);
}

/* Убираем стрелку у иконки языка */
#languageDropdown::after {
    display: none !important;
}

/* Дополнительные стили для лучшего вида */
#languageDropdown {
    padding:0;
    display: flex;
    align-items: center;
}

#languageDropdown .bi-globe {
    margin-top: 0.4vw;
    font-size: 1.2rem;
    transition: all 0.2s ease;
}

#languageDropdown:hover .bi-globe {

}

.language-dropdown .dropdown-menu {
    transform-origin: top right;
    animation: fadeIn 0.2s ease-out;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: scale(0.95) translateY(-10px);
    }
    to {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

/* Стили для переключателя языка */
.navbar .dropdown-toggle .bi-globe {
    font-size: 1.2rem;
    vertical-align: middle;
}

.navbar .language-dropdown .dropdown-menu {
    min-width: 120px;
    background-color: rgba(40, 40, 40, 0.95);
    border: 1px solid rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.navbar .language-dropdown .dropdown-item {
    color: #e0e0e0;
    padding: 8px 15px;
    font-size: 14px;
    transition: all 0.2s ease;
}

.navbar .language-dropdown .dropdown-item:hover {
    background-color: rgba(73, 169, 176, 0.2);
    color: #ffffff;
}

  .navbar-brand img{
    height: 2vw;
  }

.navbar .language-dropdown .dropdown-item.active {
    background-color: rgba(73, 169, 176, 0.3);
    color: #ffffff;
    font-weight: 500;
}
            textarea {
        min-height: 200px;
        border-radius: 0.5rem;
        padding: 1rem;
        border: 1px solid #555555;
        background-color: rgba(51, 51, 51, 0.5); /* Полупрозрачный фон */
        color: #e0e0e0;
        width: 100%;
        resize: none;
        position: relative; /* Добавляем для корректного позиционирования псевдоэлемента */
        overflow-y: scroll; /* Скрываем переполнение эффекта размытия */
    }
/* Кастомный скроллбар для всей страницы */
html {
    scrollbar-width: thin;
    scrollbar-color: #4d8e99 rgba(30, 30, 30, 0.5);
}

/* Для WebKit-браузеров */
::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

::-webkit-scrollbar-track {
    background: rgba(30, 30, 30, 0.5);
    border-radius: 5px;
}

::-webkit-scrollbar-thumb {
    background: #4d8e99;
    border-radius: 5px;
    border: 2px solid transparent;
    background-clip: content-box;
    transition: background 0.3s ease;
}

::-webkit-scrollbar-thumb:hover {
    background: #5fd6e6;
}


        /* Создаем псевдоэлемент для эффекта размытия */
        textarea::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: inherit;
            backdrop-filter: blur(10px);
            -webkit-backdrop-filter: blur(10px);
            z-index: -1; /* Помещаем под содержимое textarea */
            border-radius: inherit; /* Наследуем скругление углов */
        }
        
                /* Особый стиль для textarea */
        textarea::-webkit-scrollbar {
            width: 8px;
        }

        textarea::-webkit-scrollbar-thumb {
            background: #4d8e99;
            border-radius: 4px;
        }

        .lessson{
            border: 0.5px solid rgba(255, 255, 255, 0.0);
            background-color: rgba(30, 30, 30, 0.1); /* Полупрозрачный тёмный фон */
            backdrop-filter: blur(0px); /* Размытие фона за элементом */
                -webkit-backdrop-filter: blur(0px); /* Для поддержки в WebKit-браузерах (Safari) */
            box-shadow: 0 4px 30px rgba(0, 0, 0, 0.0); /* Легкая тень для глубины */
            max-width: 85%;
            margin: 4rem auto;
            padding: 4rem;
            padding-bottom: 8rem;
            border-radius: 30px;
            min-height: 625px;
        }



        .navbar {

            background-color: rgba(33, 37, 41, 0.0) !important; /* Тёмный фон для navbar (аналог bg-dark) */
            color:#fff;

        }

        .navbar .container-fluid {
            padding-top: 5%;
            padding-left: 6%;
            padding-right: 5%;
            max-width: 1800px; /* Можно ограничить максимальную ширину контента */
        }

        .nav-link {
            color: #ffffff !important; /* Белый цвет для текста в navbar */

            font-size: 1.1vw;
        }
        .navbar-brand{
            
            margin-right: 5%; /* Или любое другое значение */
        }
        .nav-item{
            font-family: 'Unbounded-ExtraLight';
        }

        .navbar-nav .nav-item {
            margin-right: 0; /* Или любое другое значение */
            }


        .nav-link:hover {
            color: #cccccc !important; /* Лёгкое затемнение при наведении */
        }
        



        .footer {
            background-color: rgba(33, 37, 41, 0.0) !important;
            color: #ffffff;
            font-family: 'Unbounded-Light';
            font-size: 16px;
            padding-left: 0;
            padding-right: 0; /* Убираем горизонтальные padding у футера */
        }

        .footer .container-fluid {
            max-width: 1800px; /* Можно ограничить максимальную ширину контента */
        }

        .footer h5 {
            font-size: 16px;
            margin-bottom: 1rem; /* Увеличил отступ под заголовками */
            font-family: "Unbounded";
        }

        .footer li {
            font-size: 12.45px;
            margin-bottom: 0.5rem; /* Добавил отступ между пунктами списка */
        }

        .footer p {
            font-size: 12.45px;
            margin-bottom: 1rem; /* Добавил отступ после абзаца */
        }

        .social-links a {
            transition: transform 0.2s;
            align:center;
        }

        .social-links a:hover {
            transform: translateY(-2px);
            color: #ffffff !important;
        }

        .course-card {
            background-color: rgba(40, 40, 40, 0.9); /* Тёмный фон для карточек */
            color: #e0e0e0;
            transition: transform 0.2s;
            margin-bottom: 20px;
        }
        .course-card:hover {
            transform: translateY(-5px);
            box-shadow: 0 10px 20px rgba(0, 0, 0, 0.3); /* Более тёмная тень */
        }
        .upload-status-card {
            background-color: rgba(40, 40, 40, 0.9); /* Тёмный фон для карточек загрузки */
            color: #e0e0e0;
            border-left: 5px solid #0d6efd;
            box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
            margin-bottom: 1rem;
            padding: 1rem;
            border-radius: 6px;
        }
        .upload-status-progress {
            height: 6px;
            background-color: #444444; /* Тёмный фон прогресс-бара */
            border-radius: 3px;
            overflow: hidden;
            margin-top: 0.5rem;
        }
        .upload-status-progress-bar {
            height: 100%;
            background-color: #0d6efd; /* Основной цвет прогресс-бара */
            transition: width 0.3s;
        }
        
        .alert {
            background-color: rgba(40, 40, 40, 0.9); /* Тёмный фон для уведомлений */
            color: #e0e0e0;
            border: 1px solid #555555;
        }
        .alert-success {
            background-color: rgba(40, 79, 40, 0.9); /* Тёмный зелёный для успешных уведомлений */
            border-color: #49A9B0;
        }
        .alert-danger {
            background-color: rgba(79, 40, 40, 0.9); /* Тёмный красный для ошибок */
            border-color: #d32f2f;
        }

        /* Кастомные чекбоксы в таблице */
.custom-checkbox {
    display: block;
    position: relative;
    padding-left: 25px;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    height: 20px;
}

/* Скрываем стандартный чекбокс */
.custom-checkbox input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: 0;
    width: 0;
}

/* Кастомный чекбокс */
.checkmark {
    position: absolute;
    top: 0;
    left: 0;
    height: 22px;
    width: 22px;
    background-color: #fff;
    border: 2px solid #fff;
    border-radius: 4px;
    transition: all 0.2s ease;
}

.btn-outline-light{
    border-radius: 50px;

}

/* При наведении */
.custom-checkbox:hover input ~ .checkmark {
    background-color: rgba(73, 169, 176, 0.1);
}

/* Когда чекбокс отмечен */
.custom-checkbox input:checked ~ .checkmark {
    background-color: #49A9B0;
}

/* Создаем галочку (скрыта по умолчанию) */
.checkmark:after {
    content: "";
    position: absolute;
    display: none;
}

/* Показываем галочку при выборе */
.custom-checkbox input:checked ~ .checkmark:after {
    display: block;
}

/* Стиль галочки */
.custom-checkbox .checkmark:after {
    left: 6px;
    top: 2px;
    width: 5px;
    height: 10px;
    border: solid white;
    border-width: 0 2px 2px 0;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}

/* Фокус состояние */
.custom-checkbox input:focus ~ .checkmark {
    box-shadow: 0 0 0 2px rgba(73, 169, 176, 0.3);
}
        .badge.bg-secondary {
            background-color: #555555 !important; /* Тёмный фон для badge */
        }
        .dropdown-menu {
            background-color: #2c2c2c; /* Тёмный фон для выпадающего меню */
            border: 1px solid #444444;
        }
        .dropdown-item {
            color: #e0e0e0;
        }
        .dropdown-item:hover {
            background-color: #3a3a3a;
            color: #ffffff;
        }
        .dropdown-divider {
            border-color: #555555;
        }

        .container {
            
            padding: 0px;
        }


        .form-control{
            color: #e0e0e0;
        }

        h2{
            font-family:"Unbounded-Bold";
            text-transform: uppercase;
        }

        h3{
            font-family:"Unbounded-Bold";
            text-transform: uppercase;
            font-size: 18px;
            padding-bottom: 1%;

        }

        h5{
            font-family:"HomeVideo-Regular";
            text-transform: uppercase;
        }

        a{
            color: #ffffff;
        }

        .large {
            border: 0.5px solid rgba(255, 255, 255, 0.5);
            background-color: rgba(30, 30, 30, 0.3);
            backdrop-filter: blur(5px);
            -webkit-backdrop-filter: blur(5px);
            box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
            max-width: 87vw;
            padding: 4rem;
            padding-bottom: 8rem;
            border-radius: 30px;
            min-height: 625px;
        }

        /* Цвета, гармонирующие с #49A9B0 */
    .alert-success {
        background-color: #49a9b07e;
        color: white;
    }
    
    .alert-info {
        background-color: #5bc0de7e;
        color: white;
    }
    
    .alert-warning {
        background-color: #f0ad4e7e;
        color: white;
    }
    
    .alert-danger {
        background-color: #d9534f7e;
        color: white;
    }
    
    /* Иконки для alert */
    .alert i {
        margin-right: 10px;
        font-size: 18px;
    }
    
    /* Анимации */
    @keyframes slideIn {
        from {
            transform: translateY(100%);
            opacity: 0;
        }
        to {
            transform: translateY(0);
            opacity: 1;
        }
    }
    
    @keyframes fadeOut {
        from {
            opacity: 1;
        }
        to {
            opacity: 0;
        }
    }
    
    /* Кнопка закрытия */
    .btn-close {
        filter: invert(1);
        opacity: 0.8;
        margin-left: 15px;
    }
    
    .btn-close:hover {
        opacity: 1;
    }

   /* Полный CSS с адаптацией под ноутбуки, планшеты и смартфоны */

/* ... Все твои основные стили остаются БЕЗ ИЗМЕНЕНИЙ ... */

/* === НАЧАЛО адаптивных стилей === */

/* ≤1200px: Ноутбуки и крупные планшеты */



@media (max-width: 1200px) {
  .lessson, .large {
    padding: 3rem;
    padding-bottom: 5rem;
    min-height: 500px;
  }


  .navbar .container-fluid {
    padding-top: 3%;
    padding-left: 4%;
    padding-right: 4%;
  }



  h2 {
    font-size: 2rem;
  }

  h3 {
    font-size: 1rem;
  }

  .footer {
    font-size: 14px;
  }
}

/* ≤992px: Планшеты */
@media (max-width: 992px) {
  .navbar-brand {
    margin-right: 2%;
  }

  .nav-link {
    font-size: 0.95rem;
  }
.navbar-brand img{
        height: 5vw;
    }

  .btn {
    padding: 0.5rem 1rem;
    font-size: 0.9rem;
  }

  .lessson, .large {
    padding: 2.5rem;
    padding-bottom: 4rem;
    margin: 2rem auto;
    max-width: 95%;
  }

  .footer h5,
  .footer li,
  .footer p {
    font-size: 13px;
  }

  .small-telegram {
    transform: scale(0.25);
    margin: -2rem;
  }
}

/* Стили для мобильного переключателя языка */
@media (max-width: 992px) {
    .navbar .language-dropdown .dropdown-menu {
        min-width: 150px;
        background-color: rgba(40, 40, 40, 0.98) !important;
        border: 1px solid var(--primary-color) !important;
        padding: 10px;
    }
    
    #mobileLanguageDropdown {
        opacity: 0.7;
        padding: 8px;
        display: flex;
        align-items: center;
        font-size: 4vw;
    }
    
    #mobileLanguageDropdown .bi-globe {
        margin-right: 5px;
        font-size: 3vw;
        padding: 0;
        padding-bottom: 0vw;
    }
    
    /* Для центрированного варианта */
    .navbar .mx-auto {
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
    }
}

/* Скрываем десктопный переключатель на мобильных */
@media (max-width: 992px) {
    .language-dropdown.d-none {
        display: none !important;
    }
}
/* ≤768px: Смартфоны */
@media (max-width: 768px) {
  body {
    background-size: 100%;
  }
  .navbar-brand img{
   height: 5vw;
  }
  
  main {
    padding: 15px;
    border-radius: 20px;
    margin: 10px;
  }

  h2 {
    font-size: 1.5rem;
  }

  h3 {
    font-size: 0.95rem;
    padding-bottom: 0.5rem;
  }

  h5 {
    font-size: 0.9rem;
  }

  .btn {
    font-size: 0.85rem;
    padding: 0.45rem 0.85rem;
  }

  .lessson, .large {
    padding: 1.5rem;
    padding-bottom: 3rem;
    min-height: auto;
    margin: 1.5rem auto;
  }

  .navbar .container-fluid {
    padding-top: 2%;
    padding-left: 2%;
    padding-right: 2%;
  }

    #mobileLanguageDropdown .bi-globe {
        margin-right: 5px;
        padding: 0;
        padding-bottom: 0vw;
    }

  .footer {
    text-align: center;
  }

  .footer .container-fluid {
    padding: 0 1rem;
  }

  .small-telegram {
    transform: scale(0.22);
    margin: -2rem;
  }

  .dropdown-menu {
    font-size: 14px;
  }

 .language-dropdown .dropdown-menu {
        width: 100%;
        z-index: 1000;
        background-color: rgba(40, 40, 40, 0.98) !important;
        border: 1px solid var(--primary-color) !important;
        padding: 15px;
        box-shadow: 0 0 20px rgba(0,0,0,0.5);
    }
    
    .language-dropdown .dropdown-item {
        padding: 10px 15px;
        font-size: 16px;
    }
    
    #languageDropdown {
        padding: 8px 12px;
    }
}

/* ≤480px: Очень маленькие экраны */
@media (max-width: 480px) {
  body {
    background-size: 400%;
  }
    .navbar-brand img {
        height: 6vw;
    }

    #mobileLanguageDropdown .bi-globe {
        margin-right: 5px;
        font-size: 6vw;
        padding: 0;
        padding-bottom: 0vw;
    }
    
  main {
    padding: 10px;
    border-radius: 15px;
    margin: 5px;
  }

  .container {
    padding: 10px;
  }

  .nav-link {
    font-size: 0.8rem;
  }

  .btn {
    font-size: 0.8rem;
    padding: 0.4rem 0.8rem;
  }

  .navbar-brand {
    font-size: 1rem;
  }

  h2 {
    font-size: 1.2rem;
  }

  h3 {
    font-size: 0.85rem;
  }

  .lessson, .large {
    padding: 1rem;
    padding-bottom: 2rem;
    margin: 1rem auto;
  }

  textarea {
    min-height: 150px;
    padding: 0.75rem;
    font-size: 14px;
  }

  .small-telegram {
    transform: scale(0.2);
    margin: -8.5vw;
  }
}

