/* SLA Hero Block Styles */
.sla-hero {
    position: relative;
    width: 95%;
    margin: 0 auto;
    border-radius: var(--sla-radius-2xl);
    overflow: hidden;
    display: flex;
    align-items: center;
}

.sla-hero__bg {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-size: cover;
    background-position: center;
    animation: sla-zoom 25s ease-out forwards;
    transform: scale(1.1);
}

@keyframes sla-zoom {
    to { 
        transform: scale(1); 
    }
}

.sla-hero__overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(to right, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.5) 60%, rgba(0,0,0,0.3) 100%);
}

.sla-hero__content {
    position: relative;
    z-index: var(--sla-z-dropdown);
    padding: var(--sla-spacing-2xl);
    /* Uitlijnen met container: (100vw - container) / 2 - (100vw - 95vw) / 2 */
    /* Widescreen 60%: 20vw - 2.5vw = 17.5vw */
    padding-left: 17.5vw;
    max-width: 60vw;
}

/* Zeer breed (>1850px) - container bereikt max-width 1100px */
@media (min-width: 1850px) {
    .sla-hero__content {
        /* Container start: (100vw - 1100px) / 2, Hero start: 2.5vw */
        padding-left: calc(50vw - 550px - 2.5vw);
    }
}

.sla-hero__title {
    font-family: var(--sla-font-family-heading);
    font-size: clamp(var(--sla-font-size-3xl), 4vw, var(--sla-font-size-5xl));
    font-weight: var(--sla-font-weight-bold);
    color: var(--sla-color-white);
    line-height: var(--sla-line-height-tight);
    margin: 0 0 var(--sla-spacing-md) 0;
}

/* Wave animation voor woorden */
.sla-hero__title .sla-word {
    display: inline-block;
    opacity: 0;
    transform: translateY(50px);
    filter: blur(8px);
    animation: sla-wave-word 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes sla-wave-word {
    to {
        opacity: 1;
        transform: translateY(0);
        filter: blur(0);
    }
}

.sla-hero__title em {
    font-style: italic;
    position: relative;
    text-decoration: none;
    display: inline-block;
}

.sla-hero__title em::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 2px;
    width: 100%;
    height: 4px;
    background: #fff;
    border-radius: 2px;
    transform: scaleX(0);
    transform-origin: left;
    animation: sla-underline-draw 0.8s cubic-bezier(0.16, 1, 0.3, 1) 1s forwards;
}

@keyframes sla-underline-draw {
    to {
        transform: scaleX(1);
    }
}

.sla-hero__subtitle {
    font-family: var(--sla-font-family);
    font-size: clamp(var(--sla-font-size-sm), 1.5vw, var(--sla-font-size-lg));
    color: rgba(255,255,255,0.8);
    line-height: var(--sla-line-height-relaxed);
    margin: 0 0 var(--sla-spacing-xl) 0;
    opacity: 0;
    transform: translateY(30px);
    animation: sla-hero-subtitle 0.8s cubic-bezier(0.16, 1, 0.3, 1) 0.8s forwards;
}

@keyframes sla-hero-subtitle {
    0% {
        opacity: 0;
        transform: translateY(30px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Buttons container */
.sla-hero__buttons {
    display: flex;
    gap: var(--sla-spacing-md);
    flex-wrap: wrap;
}

.sla-hero__btn {
    display: inline-flex;
    align-items: center;
    gap: var(--sla-spacing-sm);
    padding: var(--sla-btn-padding-y) var(--sla-btn-padding-x);
    background: var(--sla-btn-bg);
    color: var(--sla-color-white);
    font-size: var(--sla-btn-font-size);
    font-weight: var(--sla-font-weight-medium);
    text-decoration: none;
    border-radius: var(--sla-btn-radius);
    border: var(--sla-btn-border);
    opacity: 0;
    transform: translateY(20px);
    animation: sla-hero-btn 0.7s cubic-bezier(0.16, 1, 0.3, 1) 1.1s forwards;
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    position: relative;
    overflow: hidden;
}

/* Secondary button - glassmorphism style */
.sla-hero__btn--secondary {
    background: rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.15);
    animation-delay: 1.25s;
}

.sla-hero__btn--secondary:hover {
    background: rgba(255, 255, 255, 0.15);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
}

.sla-hero__btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
    transition: left 0.5s ease;
}

.sla-hero__btn:hover::before {
    left: 100%;
}

.sla-hero__btn:hover {
    background: var(--sla-btn-bg-hover);
    transform: translateX(4px);
    color: var(--sla-color-white);
    box-shadow: 0 10px 30px rgba(59, 130, 246, 0.3);
}

@keyframes sla-hero-btn {
    0% {
        opacity: 0;
        transform: translateY(20px) scale(0.95);
    }
    100% {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

/* Desktop (1100-1400px) - container 70% → padding 12.5vw */
@media (max-width: 1400px) {
    .sla-hero__content {
        padding-left: 12.5vw;
    }
}

/* Tablet (768-1100px) - container 80% → padding 7.5vw */
@media (max-width: 1100px) {
    .sla-hero__content {
        padding-left: 7.5vw;
    }
}

/* Mobile */
@media (max-width: 768px) {
    .sla-hero {
        width: 100%;
        max-width: 100vw;
        border-radius: 0;
        overflow: hidden;
    }
    
    .sla-hero__content {
        padding: var(--sla-spacing-xl) var(--sla-spacing-md);
        text-align: center;
        max-width: 100%;
        box-sizing: border-box;
    }
    
    .sla-hero__title em::after {
        height: 3px;
    }
    
    .sla-hero__buttons {
        flex-direction: column;
        width: 100%;
        gap: var(--sla-spacing-sm);
    }
    
    .sla-hero__btn {
        width: 100%;
        max-width: 100%;
        justify-content: center;
        box-sizing: border-box;
        padding: var(--sla-spacing-md) var(--sla-spacing-lg);
        font-size: var(--sla-font-size-base);
    }
}

/* Editor specifiek */
.editor-styles-wrapper .sla-hero {
    min-height: 500px;
}

.editor-styles-wrapper .sla-hero__title,
.editor-styles-wrapper .sla-hero__subtitle {
    animation: none;
    opacity: 1;
    transform: none;
    filter: none;
}

.editor-styles-wrapper .sla-hero__title .sla-word {
    animation: none;
    opacity: 1;
    transform: none;
    filter: none;
}

.editor-styles-wrapper .sla-hero__title em::after {
    animation: none;
    transform: scaleX(1);
}

.editor-styles-wrapper .sla-hero__btn {
    animation: none;
    opacity: 1;
    transform: none;
    cursor: default;
}

.editor-styles-wrapper .sla-hero__buttons {
    display: flex;
    gap: var(--sla-spacing-md);
    flex-wrap: wrap;
}

.editor-styles-wrapper .sla-hero__title:focus,
.editor-styles-wrapper .sla-hero__subtitle:focus {
    outline: 2px dashed rgba(255,255,255,0.5);
    outline-offset: 4px;
}

.editor-styles-wrapper .sla-hero__bg:empty {
    background: linear-gradient(135deg, var(--sla-color-primary) 0%, var(--sla-color-primary-light) 100%);
}
