/****************************
 * Flickity fade
 * Use CSS important to override Flickity's JS transition
****************************/
.flickity-enabled.is-fade .flickity-slider > * {
    pointer-events:none; z-index:0;
    opacity:0 !important;
    transition:opacity .45s ease;
}
.flickity-enabled.is-fade .flickity-slider > .is-selected {
    pointer-events:auto; z-index:1;
    opacity:1 !important;
}

/****************************
 * Extend: Hybrid mobile layout
 * Add class "flickity-extended-hybrid-layout" above the slider
****************************/
/* create the same selector in your code to override these variables */
.flickity-extended-hybrid-layout .flickity-enabled {
    /* total gap between each slide */
    --extend-slide-gap:var(--ifs-gap-container, 20px);

    /* width of each slide */
    --extend-slide-width:var(--slide-width, 50%);
}
/* you can change the breakpoint to fit your need, but should not change the calculation inside */
@media only screen and (min-width:320px) {
    /* remove side margins of the slider */
    .flickity-extended-hybrid-layout .flickity-enabled {margin:0 calc(-1 * var(--extend-slide-gap) / 2) !important;}

    /* slides in the middle */
    .flickity-extended-hybrid-layout .flickity-slider > * {
        padding:0 calc(var(--extend-slide-gap) / 2) !important;
        width:calc(var(--extend-slide-width) + var(--extend-slide-gap)) !important;
    }

    /* slides on two edges */
    .flickity-extended-hybrid-layout .flickity-slider > :first-child {
        padding-left:calc(var(--ifs-gap-side)) !important;
    }
    .flickity-extended-hybrid-layout .flickity-slider > :last-child {
        padding-right:calc(var(--ifs-gap-side)) !important;
    }
    .flickity-extended-hybrid-layout .flickity-slider > :first-child,
    .flickity-extended-hybrid-layout .flickity-slider > :last-child {
        width:calc(var(--ifs-gap-side) + var(--extend-slide-width) + var(--extend-slide-gap) / 2) !important;
    }
}


/****************************
 * Flickity arrows
****************************/
.flickity-button {
    --flkt-btn-size:45px;
    --flkt-icon-size:15px;
    --flkt-position:calc(-1 * var(--flkt-btn-size) - 10px);
    --flkt-border-color:#000;
    --flkt-bg:transparent;
    --flkt-bg-hover:var(--ifs-color-primary);
    --flkt-color:#000;
    --flkt-color-hover:var(--ifs-color-on-primary);
}

.txt_color_white .flickity-button {
    --flkt-bg:var(--ifs-color-black);
    --flkt-border-color:#747374;
    --flkt-color:#747374;
}

/* button > freeze (no navigation) */
.flickity-button-freeze {display:none;}

/* button */
.flickity-button:disabled,
.flickity-button:disabled:hover,
.flickity-prev-next-button,
.flickity-prev-next-button:focus {
    width:var(--flkt-btn-size); height:var(--flkt-btn-size);
    background:var(--flkt-bg); color:var(--flkt-color);
    opacity:1; border:2px solid var(--flkt-border-color);
}

/* button > hover */
.flickity-prev-next-button:hover {
    background:var(--flkt-bg-hover); color:var(--flkt-color-hover);
    border-color:var(--flkt-bg-hover);
}

/* button > position */
.flickity-prev-next-button.previous {left:var(--flkt-position);}
.flickity-prev-next-button.next {right:var(--flkt-position);}
.flickity-rtl .flickity-prev-next-button.previous {right:var(--flkt-position);}
.flickity-rtl .flickity-prev-next-button.next {left:var(--flkt-position);}

/* button > icon */
.flickity-prev-next-button svg {display:none;}
.flickity-prev-next-button:before {
    font-family:var(--ifs-font-icomoon); font-size:var(--flkt-icon-size);
    position:relative; color:inherit;
}
.flickity-prev-next-button.previous:before {content:"\e926";}
.flickity-prev-next-button.next:before {content:"\e927";}

/* button > disabled */
.flickity-button:disabled {pointer-events:auto; opacity:.5 !important;}

/* button > responsive */
@media only screen and (max-width:1400px) {
    .flickity-button {
        --flkt-btn-size:40px;
        --flkt-position:calc(-1 * var(--flkt-btn-size) + 5px);
    }
}
@media only screen and (max-width:1300px) {
    .flickity-button {
        --flkt-position:-5px;
    }
}


/****************************
 * Adaptive height transition
****************************/
.flickity-viewport {transition:height .3s ease;}

/****************************
 * Flickity Dots
****************************/
body .flickity-page-dots {position:relative; margin:0; bottom:auto; padding-top:var(--ifs-spacing-30);}
body .flickity-page-dots li {padding:0;}
body .flickity-page-dots .dot {opacity:1; margin:0 4px; background:rgba(17, 16, 16, .11);}
body .flickity-page-dots .dot:hover {background:rgba(17, 16, 16, .3);}
body .flickity-page-dots .dot.is-selected {background:var(--ifs-color-primary);}