/* FOOC Banner Constructor - Frontend Styles */

/* CSS Variables defaults */
.fooc-banner {
    --fooc-title-color: #ffffff;
    --fooc-title-font: 'Onest', sans-serif;
    --fooc-title-transform: none;
    --fooc-text-color: #b0b0c0;
    --fooc-text-font: 'Onest', sans-serif;
    --fooc-text-transform: none;
    --fooc-btn-bg: #6366f1;
    --fooc-btn-color: #ffffff;
    --fooc-btn-font: 'Onest', sans-serif;
    --fooc-btn-transform: none;
    --fooc-btn-radius: 6px;
}

/* Base banner styles */
.fooc-banner.banner {
    width: 100%;
    background: #1a1a22;
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.4);
    overflow: hidden;
    display: flex;
    position: relative;
    box-sizing: border-box;
    text-decoration: none;
}

.fooc-banner.banner * {
    box-sizing: border-box;
}

/* Clickable banner */
a.fooc-banner.banner {
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

a.fooc-banner.banner:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 40px rgba(0,0,0,0.5);
}

/* Image position */
.fooc-banner.banner--img-right {
    flex-direction: row-reverse;
}

/* Aspect ratios with fallback for older browsers */
.fooc-banner.banner--spotlight {
    aspect-ratio: 3 / 1;
}
.fooc-banner.banner--panorama {
    aspect-ratio: 4 / 1;
}
.fooc-banner.banner--leaderboard {
    aspect-ratio: 8 / 1;
}
.fooc-banner.banner--ticker {
    aspect-ratio: 16 / 1;
}

/* Fallback для браузеров без поддержки aspect-ratio */
@supports not (aspect-ratio: 1 / 1) {
    .fooc-banner.banner--spotlight {
        height: 0;
        padding-bottom: 33.33%; /* 1/3 = 33.33% */
    }
    .fooc-banner.banner--panorama {
        height: 0;
        padding-bottom: 25%; /* 1/4 = 25% */
    }
    .fooc-banner.banner--leaderboard {
        height: 0;
        padding-bottom: 12.5%; /* 1/8 = 12.5% */
    }
    .fooc-banner.banner--ticker {
        height: 0;
        padding-bottom: 6.25%; /* 1/16 = 6.25% */
    }

    /* Контент должен быть абсолютно позиционирован в fallback режиме */
    .fooc-banner.banner .banner__content {
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
    }

    .fooc-banner.banner .banner__image {
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
    }

    .fooc-banner.banner--img-right .banner__image {
        left: auto;
        right: 0;
    }
}

/* Image */
.fooc-banner .banner__image {
    flex-shrink: 0;
    height: 100%;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    position: relative;
}

.fooc-banner .banner__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Content */
.fooc-banner .banner__content {
    flex: 1;
    min-width: 0;
    display: flex;
    overflow: hidden;
}

/* Title */
.fooc-banner .banner__title {
    font-weight: 700;
    color: var(--fooc-title-color);
    font-family: var(--fooc-title-font);
    text-transform: var(--fooc-title-transform);
    margin: 0;
    padding: 0;
}

/* Text */
.fooc-banner .banner__text {
    color: var(--fooc-text-color);
    font-family: var(--fooc-text-font);
    text-transform: var(--fooc-text-transform);
    margin: 0;
    padding: 0;
}

/* Button */
.fooc-banner .banner__button {
    background: var(--fooc-btn-bg);
    color: var(--fooc-btn-color);
    font-family: var(--fooc-btn-font);
    text-transform: var(--fooc-btn-transform);
    border-radius: var(--fooc-btn-radius);
    border: none;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s, transform 0.2s, filter 0.2s;
    white-space: nowrap;
    flex-shrink: 0;
    display: inline-block;
    text-decoration: none;
}

.fooc-banner .banner__button:hover {
    filter: brightness(1.1);
    transform: translateY(-1px);
}

/* Gradient backgrounds */
.fooc-banner.banner--gradient-blue { background: linear-gradient(135deg, #1e3a5f 0%, #0f1c2e 100%); }
.fooc-banner.banner--gradient-purple { background: linear-gradient(135deg, #2d1f4e 0%, #1a1225 100%); }
.fooc-banner.banner--gradient-green { background: linear-gradient(135deg, #1a3d2e 0%, #0f1f18 100%); }
.fooc-banner.banner--gradient-orange { background: linear-gradient(135deg, #4a2a1a 0%, #2a1810 100%); }
.fooc-banner.banner--gradient-red { background: linear-gradient(135deg, #4a1a1a 0%, #2a1010 100%); }
.fooc-banner.banner--gradient-teal { background: linear-gradient(135deg, #1a3d3d 0%, #0f1f1f 100%); }

/* Text group wrapper - created by JS */
.fooc-banner .banner__text-group,
.fooc-banner .banner__text-block {
    min-width: 0;
}

/* Measure box (hidden) */
.fooc-measure-box {
    position: absolute;
    visibility: hidden;
    height: auto;
    width: auto;
    white-space: nowrap;
}

/* Widget wrapper */
.fooc-banner-widget {
    margin-bottom: 20px;
}

.fooc-banner-widget .fooc-banner {
    margin: 0;
}
