/* Cookie Banner Styles */
.cookie-banner {
    position: fixed;
    bottom: 2.481vh;
    left: 50%;
    transform: translateX(-50%) translateY(150%);
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(1.323vw);
    border-radius: 1.323vw;
    box-shadow: 0 0.992vh 2.481vh rgba(0, 0, 0, 0.15);
    padding: 2.481vh 2.646vw;
    max-width: 66.138vw;
    width: calc(100% - 5.291vw);
    z-index: 9999;
    opacity: 0;
    transition: transform 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55), 
                opacity 0.5s ease;
    border: 0.066vw solid rgba(90, 154, 240, 0.2);
}

.cookie-banner.is-visible {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
}

.cookie-banner__content {
    display: flex;
    align-items: center;
    gap: 2.646vw;
}

.cookie-banner__icon {
    flex-shrink: 0;
    width: 4.963vw;
    height: 9.304vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #5A9AF0 0%, #2DB182 100%);
    border-radius: 0.992vw;
}

.cookie-banner__icon svg {
    width: 2.646vw;
    height: 4.963vh;
    fill: white;
}

.cookie-banner__text {
    flex: 1;
}

.cookie-banner__title {
    font-size: 1.124vw;
    font-weight: 600;
    color: var(--color-dark);
    margin: 0 0 0.744vh 0;
    line-height: 1.4;
}

.cookie-banner__description {
    font-size: 0.926vw;
    color: var(--color-gray);
    margin: 0;
    line-height: 1.6;
}

.cookie-banner__description a {
    color: var(--color-primary);
    text-decoration: underline;
    transition: color 0.3s ease;
}

.cookie-banner__description a:hover {
    color: var(--color-secondary);
}

.cookie-banner__actions {
    display: flex;
    gap: 1.323vw;
    flex-shrink: 0;
}

.cookie-banner__button {
    padding: 1.489vh 1.984vw;
    border-radius: 0.661vw;
    font-size: 0.926vw;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.3s ease;
    border: none;
    white-space: nowrap;
}

.cookie-banner__button--accept {
    background: linear-gradient(104deg, #2DB182 0%, #2FCD96 61%, #2DB182 100%);
    color: white;
    box-shadow: 0 0.372vh 0.992vh rgba(45, 177, 130, 0.3);
}

.cookie-banner__button--accept:hover {
    transform: translateY(-0.124vh);
    box-shadow: 0 0.496vh 1.323vh rgba(45, 177, 130, 0.4);
}

.cookie-banner__button--decline {
    background: transparent;
    color: var(--color-gray);
    border: 0.066vw solid var(--color-light-gray);
}

.cookie-banner__button--decline:hover {
    background: var(--color-bg-alt);
    border-color: var(--color-primary);
    color: var(--color-dark);
}

.cookie-banner__close {
    position: absolute;
    top: 1.241vh;
    right: 1.323vw;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.496vh;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0.5;
    transition: opacity 0.3s ease;
}

.cookie-banner__close:hover {
    opacity: 1;
}

.cookie-banner__close svg {
    width: 1.323vw;
    height: 2.481vh;
    stroke: var(--color-gray);
}

/* Tablet Styles */
@media (max-width: 79.365vw) {
    .cookie-banner {
        max-width: 90%;
        padding: 2.481vh 2.646vw;
        bottom: 1.985vh;
    }

    .cookie-banner__content {
        gap: 1.984vw;
    }

    .cookie-banner__icon {
        width: 6vw;
        height: 8vh;
    }

    .cookie-banner__icon svg {
        width: 3vw;
        height: 4vh;
    }

    .cookie-banner__title {
        font-size: 1.4vw;
    }

    .cookie-banner__description {
        font-size: 1.2vw;
    }

    .cookie-banner__button {
        font-size: 1.1vw;
        padding: 1.5vh 2vw;
    }
}

/* Mobile Styles */
@media (max-width: 50.794vw) {
    .cookie-banner {
        max-width: calc(100% - 3.968vw);
        padding: 3.102vh 3.968vw;
        bottom: 1.985vh;
        border-radius: 1.984vw;
    }

    .cookie-banner__content {
        flex-direction: column;
        gap: 2.481vh;
        text-align: center;
    }

    .cookie-banner__icon {
        width: 11.905vw;
        height: 7.444vh;
        border-radius: 1.587vw;
    }

    .cookie-banner__icon svg {
        width: 5.952vw;
        height: 3.722vh;
    }

    .cookie-banner__title {
        font-size: 3.571vw;
        margin-bottom: 1.241vh;
    }

    .cookie-banner__description {
        font-size: 2.976vw;
    }

    .cookie-banner__actions {
        flex-direction: column;
        width: 100%;
        gap: 1.489vh;
    }

    .cookie-banner__button {
        width: 100%;
        font-size: 3.175vw;
        padding: 1.985vh 3.968vw;
        border-radius: 1.19vw;
    }

    .cookie-banner__close {
        top: 1.985vh;
        right: 1.984vw;
    }

    .cookie-banner__close svg {
        width: 2.381vw;
        height: 2.481vh;
    }
}

/* Small Mobile Styles */
@media (max-width: 31.746vw) {
    .cookie-banner {
        max-width: calc(100% - 2.646vw);
        padding: 2.481vh 2.646vw;
        bottom: 1.241vh;
    }

    .cookie-banner__icon {
        width: 15.873vw;
        height: 6.203vh;
    }

    .cookie-banner__icon svg {
        width: 7.937vw;
        height: 3.102vh;
    }

    .cookie-banner__title {
        font-size: 4.762vw;
    }

    .cookie-banner__description {
        font-size: 3.968vw;
    }

    .cookie-banner__button {
        font-size: 4.232vw;
        padding: 1.861vh 3.307vw;
    }
}
