/* Базові стилі для банера */
.banner-section {
    display: flex;
    align-items: center;
    position: relative;
    overflow: hidden;
    width: 100%;
    margin: 0; /* Прибираємо відступи для повної ширини */
}

/* Розміри банера */
.banner-small {
    min-height: 150px;
    padding: 2rem 0;
}

.banner-medium {
    min-height: 250px;
    padding: 3rem 0;
}

.banner-large {
    min-height: 500px; /* Зменшуємо висоту з 100vh */
    padding: 4rem 0;
}

/* Типи фону */
.banner-gradient {
    background: var(--gradient-main);
}

/* Варіанти градієнтів */
.banner-gradient-main {
    background: linear-gradient(135deg, var(--primary-blue), var(--primary-turquoise));
}

.banner-gradient-brands {
    background: linear-gradient(135deg, #004080, #0096a3);
}

.banner-gradient-solutions {
    background: linear-gradient(135deg, #005580, #00a896);
}

.banner-gradient-about {
    background: linear-gradient(135deg, #006699, #00b2a9);
}

.banner-gradient-contacts {
    background: linear-gradient(135deg, #006699, #00b2a9);
}

.banner-image {
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.banner-color {
    background-color: var(--primary-blue);
}

/* Оверлей для фону */
.banner-section.has-overlay::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.4);
    z-index: 1;
}

/* Контейнер контенту */
.banner-section .container {
    position: relative;
    z-index: 2;
    width: 100%;
    max-width: var(--container-max-width);
    margin: 0 auto;
    padding: 0 var(--container-padding);
}

.banner-content {
    max-width: 800px;
    margin: 0 auto;
    text-align: center;
    color: var(--white);
    padding: 2rem 0;
}

/* Заголовок */
.banner-content h1 {
    font-size: 3.5rem;
    font-weight: var(--font-weight-bold);
    margin-bottom: 1.5rem;
    line-height: 1.2;
}

/* Підзаголовок */
.banner-content .lead {
    font-size: 1.75rem;
    margin-bottom: 2rem;
    opacity: 0.9;
}

/* Кнопки */
.banner-buttons {
    display: flex;
    gap: 1rem; /* Зменшуємо відступ між кнопками */
    justify-content: center;
    margin-top: 1.5rem; /* Зменшуємо відступ зверху */
}

.banner-buttons .btn {
    min-width: 180px; /* Зменшуємо мінімальну ширину */
    padding: 0.875rem 1.5rem; /* Зменшуємо padding */
    font-size: 1rem; /* Зменшуємо розмір шрифту */
    white-space: nowrap; /* Текст в одну строку */
}

/* Адаптивність */
@media (max-width: 991.98px) {
    .banner-section {
        margin: 0 2rem 1.5rem 2rem;
    }

    .banner-large {
        min-height: calc(80vh - var(--header-height));
        padding: 3rem 0;
    }

    .banner-content h1 {
        font-size: 2.75rem;
    }

    .banner-content .lead {
        font-size: 1.5rem;
    }

    .banner-buttons .btn {
        min-width: 160px;
        padding: 0.75rem 1.25rem;
        font-size: 0.95rem;
    }
}

@media (max-width: 576px) {
    .banner-section {
        margin: 0 1rem 1rem 1rem;
    }

    .banner-large {
        min-height: calc(70vh - var(--header-height));
        padding: 2rem 0;
    }

    .banner-content h1 {
        font-size: 2.25rem;
        margin-bottom: 1rem;
    }

    .banner-content .lead {
        font-size: 1.25rem;
        margin-bottom: 1.5rem;
    }

    .banner-buttons {
        flex-direction: row; /* Змінюємо на горизонтальне розташування */
        flex-wrap: wrap; /* Дозволяємо перенос на новий рядок якщо не вміщується */
        justify-content: center;
        gap: 0.75rem;
    }

    .banner-buttons .btn {
        width: auto; /* Прибираємо фіксовану ширину */
        min-width: 140px; /* Зменшуємо мінімальну ширину для мобільних */
        max-width: none;
        margin: 0;
        padding: 0.75rem 1rem;
        font-size: 0.9rem;
    }
} 