/* AG Hero Slider — lightweight, GPU-accelerated */
.ag-hero-slider{
    --ag-slider-height: 80vh;
    --ag-transition-duration: 800ms;
    --ag-transition-easing: cubic-bezier(.45,.05,.2,1);
    --ag-anim-easing: cubic-bezier(.22,.61,.36,1);
    /* Animation timings (overridden inline by widget). */
    --ag-title-duration: 900ms;
    --ag-title-delay: 100ms;
    --ag-subtitle-duration: 900ms;
    --ag-subtitle-delay: 350ms;
    --ag-buttons-duration: 800ms;
    --ag-buttons-delay: 600ms;
    --ag-buttons-stagger: 150ms;
    position: relative;
    width: 100%;
    height: var(--ag-slider-height);
    overflow: hidden;
    isolation: isolate;
    background: #000;
    contain: layout paint;
}

.ag-hero-slider__viewport{
    position: relative;
    width: 100%;
    height: 100%;
}

.ag-hero-slider__track{
    position: relative;
    width: 100%;
    height: 100%;
}

/* Slide base */
.ag-slide{
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    pointer-events: none;
    will-change: opacity, transform;
}

/* ---------- FADE transition (default) ---------- */
.ag-hero-slider--fade .ag-slide{
    opacity: 0;
    transition: opacity var(--ag-transition-duration) var(--ag-transition-easing);
}
.ag-hero-slider--fade .ag-slide.is-active{
    opacity: 1;
    pointer-events: auto;
    z-index: 2;
}

/* ---------- SLIDE transition ---------- */
.ag-hero-slider--slide .ag-slide{
    transform: translate3d(100%,0,0);
    transition: transform var(--ag-transition-duration) var(--ag-transition-easing);
}
.ag-hero-slider--slide .ag-slide.is-active{
    transform: translate3d(0,0,0);
    pointer-events: auto;
    z-index: 2;
}
.ag-hero-slider--slide .ag-slide.is-prev{
    transform: translate3d(-100%,0,0);
}

/* Picture wrapper fills the slide */
.ag-slide__picture{
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    display: block;
    z-index: 0;
    overflow: hidden;
}

/* Background image — base styles. Per-slide overrides (object-fit, object-position,
   width/height/inset/transform for full-height) are emitted inline in the widget render
   to bypass any external CSS file caching (Hostinger / LiteSpeed / etc.). */
.ag-slide__bg{
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    user-select: none;
    -webkit-user-drag: none;
}

/* Ken Burns effect — applied on the picture wrapper so it composes
   with full-height centering transforms on the inner img. */
.ag-hero-slider--kenburns .ag-slide__picture{
    transition: transform 8s linear;
    transform: scale(1);
}
.ag-hero-slider--kenburns .ag-slide.is-active .ag-slide__picture{
    transform: scale(1.08);
}

/* Overlay */
.ag-slide__overlay{
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
}

/* Content layout */
.ag-slide__inner{
    position: relative;
    z-index: 2;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start; /* default — overridden by content_h_position control */
    box-sizing: border-box;
}

.ag-slide__content{
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    width: 100%;
    box-sizing: border-box;
}

/* Typography defaults (overridable from Elementor Style tab).
   Selectors prefixed with .ag-hero-slider to bump specificity to 0,2,0 — beats most
   theme overrides like ".elementor-widget h2" (0,1,1) while still allowing the user's
   Style-tab settings (output by Elementor at 0,2,0 with later cascade order) to win. */
.ag-hero-slider .ag-slide__title{
    margin: 0 0 .4em;
    font-family: 'Montserrat', system-ui, -apple-system, sans-serif;
    font-weight: 800;
    font-size: clamp(2.5rem, 7vw, 5rem);
    line-height: 1.05;
    letter-spacing: -.01em;
    color: #fff;
    text-transform: uppercase;
}

.ag-hero-slider .ag-slide__subtitle{
    margin: 0 0 1.6em;
    font-family: 'Playfair Display', Georgia, serif;
    font-style: italic;
    font-weight: 400;
    font-size: clamp(1rem, 1.6vw, 1.5rem);
    line-height: 1.4;
    color: #fff;
}

/* Buttons */
.ag-slide__buttons{
    display: flex;
    flex-direction: column;
    gap: 14px;
    align-items: flex-start;
    flex-wrap: wrap;
}
.ag-hero-slider .ag-slide__btn{
    display: inline-block;
    padding: 14px 38px;
    text-align: center;
    font-family: 'Playfair Display', Georgia, serif;
    font-style: italic;
    font-size: 1rem;
    color: #fff;
    text-decoration: none;
    background: transparent;
    border: 1px solid #fff;
    border-radius: 0;
    cursor: pointer;
    transition: background-color .25s ease, color .25s ease, border-color .25s ease, transform .15s ease;
    box-sizing: border-box;
}
.ag-hero-slider .ag-slide__btn:hover,
.ag-hero-slider .ag-slide__btn:focus-visible{
    background: #fff;
    color: #000;
    outline: none;
}

/* ============================================================
   ENTRANCE ANIMATIONS
   Animations apply only to elements inside .is-active.
   When a slide loses .is-active, animation property is removed
   and element reverts to natural state — re-adding .is-active
   re-triggers the animation (autoplay-loop friendly).
   `fill-mode: both` ensures "from" state is applied during delay
   and "to" state is preserved after completion → no flicker.
   ============================================================ */

@keyframes agAnimFade {
    from { opacity: 0; }
    to   { opacity: 1; }
}
@keyframes agAnimSlideRight {
    from { opacity: 0; transform: translate3d(60px, 0, 0); }
    to   { opacity: 1; transform: translate3d(0, 0, 0); }
}
@keyframes agAnimSlideLeft {
    from { opacity: 0; transform: translate3d(-60px, 0, 0); }
    to   { opacity: 1; transform: translate3d(0, 0, 0); }
}
@keyframes agAnimSlideUp {
    from { opacity: 0; transform: translate3d(0, 40px, 0); }
    to   { opacity: 1; transform: translate3d(0, 0, 0); }
}
@keyframes agAnimSlideDown {
    from { opacity: 0; transform: translate3d(0, -40px, 0); }
    to   { opacity: 1; transform: translate3d(0, 0, 0); }
}
@keyframes agAnimZoomIn {
    from { opacity: 0; transform: scale3d(.85, .85, 1); }
    to   { opacity: 1; transform: scale3d(1, 1, 1); }
}

/* Title */
[data-title-anim="fade"]        .ag-slide.is-active .ag-slide__title{ animation: agAnimFade       var(--ag-title-duration) var(--ag-anim-easing) var(--ag-title-delay) both; }
[data-title-anim="slide-right"] .ag-slide.is-active .ag-slide__title{ animation: agAnimSlideRight var(--ag-title-duration) var(--ag-anim-easing) var(--ag-title-delay) both; }
[data-title-anim="slide-left"]  .ag-slide.is-active .ag-slide__title{ animation: agAnimSlideLeft  var(--ag-title-duration) var(--ag-anim-easing) var(--ag-title-delay) both; }
[data-title-anim="slide-up"]    .ag-slide.is-active .ag-slide__title{ animation: agAnimSlideUp    var(--ag-title-duration) var(--ag-anim-easing) var(--ag-title-delay) both; }
[data-title-anim="slide-down"]  .ag-slide.is-active .ag-slide__title{ animation: agAnimSlideDown  var(--ag-title-duration) var(--ag-anim-easing) var(--ag-title-delay) both; }
[data-title-anim="zoom-in"]     .ag-slide.is-active .ag-slide__title{ animation: agAnimZoomIn     var(--ag-title-duration) var(--ag-anim-easing) var(--ag-title-delay) both; }

/* Subtitle */
[data-subtitle-anim="fade"]        .ag-slide.is-active .ag-slide__subtitle{ animation: agAnimFade       var(--ag-subtitle-duration) var(--ag-anim-easing) var(--ag-subtitle-delay) both; }
[data-subtitle-anim="slide-right"] .ag-slide.is-active .ag-slide__subtitle{ animation: agAnimSlideRight var(--ag-subtitle-duration) var(--ag-anim-easing) var(--ag-subtitle-delay) both; }
[data-subtitle-anim="slide-left"]  .ag-slide.is-active .ag-slide__subtitle{ animation: agAnimSlideLeft  var(--ag-subtitle-duration) var(--ag-anim-easing) var(--ag-subtitle-delay) both; }
[data-subtitle-anim="slide-up"]    .ag-slide.is-active .ag-slide__subtitle{ animation: agAnimSlideUp    var(--ag-subtitle-duration) var(--ag-anim-easing) var(--ag-subtitle-delay) both; }
[data-subtitle-anim="slide-down"]  .ag-slide.is-active .ag-slide__subtitle{ animation: agAnimSlideDown  var(--ag-subtitle-duration) var(--ag-anim-easing) var(--ag-subtitle-delay) both; }
[data-subtitle-anim="zoom-in"]     .ag-slide.is-active .ag-slide__subtitle{ animation: agAnimZoomIn     var(--ag-subtitle-duration) var(--ag-anim-easing) var(--ag-subtitle-delay) both; }

/* Buttons — btn--1 uses base delay, btn--2 uses base + stagger */
[data-buttons-anim="fade"]        .ag-slide.is-active .ag-slide__btn--1{ animation: agAnimFade       var(--ag-buttons-duration) var(--ag-anim-easing) var(--ag-buttons-delay) both; }
[data-buttons-anim="slide-right"] .ag-slide.is-active .ag-slide__btn--1{ animation: agAnimSlideRight var(--ag-buttons-duration) var(--ag-anim-easing) var(--ag-buttons-delay) both; }
[data-buttons-anim="slide-left"]  .ag-slide.is-active .ag-slide__btn--1{ animation: agAnimSlideLeft  var(--ag-buttons-duration) var(--ag-anim-easing) var(--ag-buttons-delay) both; }
[data-buttons-anim="slide-up"]    .ag-slide.is-active .ag-slide__btn--1{ animation: agAnimSlideUp    var(--ag-buttons-duration) var(--ag-anim-easing) var(--ag-buttons-delay) both; }
[data-buttons-anim="slide-down"]  .ag-slide.is-active .ag-slide__btn--1{ animation: agAnimSlideDown  var(--ag-buttons-duration) var(--ag-anim-easing) var(--ag-buttons-delay) both; }
[data-buttons-anim="zoom-in"]     .ag-slide.is-active .ag-slide__btn--1{ animation: agAnimZoomIn     var(--ag-buttons-duration) var(--ag-anim-easing) var(--ag-buttons-delay) both; }

[data-buttons-anim="fade"]        .ag-slide.is-active .ag-slide__btn--2{ animation: agAnimFade       var(--ag-buttons-duration) var(--ag-anim-easing) calc(var(--ag-buttons-delay) + var(--ag-buttons-stagger)) both; }
[data-buttons-anim="slide-right"] .ag-slide.is-active .ag-slide__btn--2{ animation: agAnimSlideRight var(--ag-buttons-duration) var(--ag-anim-easing) calc(var(--ag-buttons-delay) + var(--ag-buttons-stagger)) both; }
[data-buttons-anim="slide-left"]  .ag-slide.is-active .ag-slide__btn--2{ animation: agAnimSlideLeft  var(--ag-buttons-duration) var(--ag-anim-easing) calc(var(--ag-buttons-delay) + var(--ag-buttons-stagger)) both; }
[data-buttons-anim="slide-up"]    .ag-slide.is-active .ag-slide__btn--2{ animation: agAnimSlideUp    var(--ag-buttons-duration) var(--ag-anim-easing) calc(var(--ag-buttons-delay) + var(--ag-buttons-stagger)) both; }
[data-buttons-anim="slide-down"]  .ag-slide.is-active .ag-slide__btn--2{ animation: agAnimSlideDown  var(--ag-buttons-duration) var(--ag-anim-easing) calc(var(--ag-buttons-delay) + var(--ag-buttons-stagger)) both; }
[data-buttons-anim="zoom-in"]     .ag-slide.is-active .ag-slide__btn--2{ animation: agAnimZoomIn     var(--ag-buttons-duration) var(--ag-anim-easing) calc(var(--ag-buttons-delay) + var(--ag-buttons-stagger)) both; }

/* ---------- ARROWS ---------- */
.ag-arrow{
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 5;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    padding: 0;
    background: transparent;
    border: 0;
    color: #fff;
    cursor: pointer;
    border-radius: 50%;
    opacity: .85;
    transition: opacity .25s ease, background-color .25s ease, transform .25s ease;
}
.ag-arrow:hover,
.ag-arrow:focus-visible{
    opacity: 1;
    outline: none;
}
.ag-arrow svg{
    width: 32px;
    height: 32px;
    display: block;
    pointer-events: none;
}
.ag-arrow--prev{ left: 12px; }
.ag-arrow--next{ right: 12px; }

@media (min-width: 768px){
    .ag-arrow--prev{ left: 24px; }
    .ag-arrow--next{ right: 24px; }
}

@media (max-width: 600px){
    .ag-arrow{ display: none; }
}

/* ---------- DOTS ---------- */
.ag-dots{
    position: absolute;
    left: 50%;
    bottom: 24px;
    transform: translateX(-50%);
    z-index: 5;
    display: flex;
    gap: 10px;
    padding: 0;
}
.ag-dot{
    width: 12px;
    height: 12px;
    padding: 0;
    border: 0;
    border-radius: 2px;
    background: rgba(255,255,255,.5);
    cursor: pointer;
    transition: background-color .25s ease, transform .25s ease;
}
.ag-dot:hover{ transform: scale(1.15); }
.ag-dot.is-active{
    background: #fff;
    transform: scale(1.1);
}
.ag-dot:focus-visible{
    outline: 2px solid #fff;
    outline-offset: 3px;
}

/* ---------- ACCESSIBILITY ---------- */
@media (prefers-reduced-motion: reduce){
    .ag-hero-slider--fade .ag-slide,
    .ag-hero-slider--slide .ag-slide,
    .ag-hero-slider--kenburns .ag-slide__bg{
        transition: none !important;
    }
    .ag-hero-slider .ag-slide__title,
    .ag-hero-slider .ag-slide__subtitle,
    .ag-hero-slider .ag-slide__btn{
        animation: none !important;
        opacity: 1 !important;
        transform: none !important;
    }
}

.elementor-editor-active .ag-hero-slider{
    pointer-events: auto;
}
