/**
 * GA Elementor Widget - Custom Slider structural styles.
 *
 * This file contains only layout/structural CSS that should behave
 * the same across themes. Visual design (colors, typography, etc.)
 * stays in the active theme.
 */

/* Wrapper and core Swiper layout */
.custom-slider-wrapper {
    position: relative;
    width: 100%;
    overflow: visible;
}

.custom-slider-wrapper .custom-slider {
    width: 100%;
    height: 100%;
    overflow: visible;
    position: relative;
}

.custom-slider-wrapper .swiper-wrapper {
    display: flex;
    align-items: stretch;
}

.custom-slider-wrapper .swiper-slide {
    display: flex;
    align-items: stretch;
    height: auto;
    box-sizing: border-box;
    flex-shrink: 0;
}

.custom-slider-wrapper .slide-content {
    width: 100%;
    display: flex;
    flex-direction: column;
    height: 100%;
}

/* Header layout (title + arrows) */
.custom-slider-header {
    margin-bottom: 20px;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    gap: 20px;
}

.custom-slider-header-nav {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}

/* Navigation arrows: base geometry/positioning (no colors here) */
.custom-slider-wrapper .swiper-button-prev,
.custom-slider-wrapper .swiper-button-next {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.3s ease;
}

.custom-slider-wrapper .swiper-button-prev.swiper-button-disabled,
.custom-slider-wrapper .swiper-button-next.swiper-button-disabled {
    cursor: not-allowed;
    opacity: 0.6;
}

.custom-slider-wrapper .swiper-button-prev:after,
.custom-slider-wrapper .swiper-button-next:after {
    content: none;
}

.custom-slider-wrapper .swiper-button-prev .custom-slider-arrow-icon,
.custom-slider-wrapper .swiper-button-next .custom-slider-arrow-icon {
    width: 24px;
    height: 24px;
    display: block;
    object-fit: contain;
}

.custom-slider-wrapper .swiper-button-prev:hover,
.custom-slider-wrapper .swiper-button-next:hover {
    transform: scale(1.1);
}

/* Arrow position: top-right (in header) */
.custom-slider-wrapper.arrow-position-top-right .custom-slider-header-nav .swiper-button-prev,
.custom-slider-wrapper.arrow-position-top-right .custom-slider-header-nav .swiper-button-next {
    position: relative;
    margin: 0;
    top: auto;
    left: auto;
    right: auto;
}

.custom-slider-wrapper.arrow-position-top-right.no-header-title .custom-slider-header {
    justify-content: flex-end;
}

/* Arrow position: top-left (reverse header layout) */
.custom-slider-wrapper.arrow-position-top-left.has-header-title .custom-slider-header {
    flex-direction: row-reverse;
}

.custom-slider-wrapper.arrow-position-top-left .custom-slider-header-nav .swiper-button-prev,
.custom-slider-wrapper.arrow-position-top-left .custom-slider-header-nav .swiper-button-next {
    position: relative;
    margin: 0;
    top: auto;
    left: auto;
    right: auto;
}

.custom-slider-wrapper.arrow-position-top-left.no-header-title .custom-slider-header {
    justify-content: flex-start;
}

/* Arrow position: sides (default Swiper positions tweaked slightly) */
.custom-slider-wrapper.arrow-position-sides .swiper-button-prev {
    left: 10px;
    right: auto;
}

.custom-slider-wrapper.arrow-position-sides .swiper-button-next {
    right: 10px;
    left: auto;
}

/* Arrow position: bottom center */
.custom-slider-wrapper.arrow-position-bottom-center .swiper-button-prev,
.custom-slider-wrapper.arrow-position-bottom-center .swiper-button-next {
    position: absolute;
    bottom: 60px;
    top: auto;
    margin-top: 0;
    z-index: 10;
}

.custom-slider-wrapper.arrow-position-bottom-center .swiper-button-prev {
    left: calc(50% - 60px);
    right: auto;
}

.custom-slider-wrapper.arrow-position-bottom-center .swiper-button-next {
    right: calc(50% - 60px);
    left: auto;
}

/* Pagination layout (no colors) */
.custom-slider-wrapper .swiper-pagination {
    display: none;
    position: relative;
    margin-top: 20px;
    text-align: center;
}

.custom-slider-wrapper .swiper-pagination-bullet {
    width: 12px;
    height: 12px;
    margin: 0 5px;
    transition: transform 0.3s ease;
}

.custom-slider-wrapper .swiper-pagination-bullet-active {
    transform: scale(1.2);
}

@media (max-width: 1023px) {
    .custom-slider-wrapper .swiper-pagination {
        display: block;
    }
}

/* Product-slide layout helpers (styling stays in theme) */
.custom-slider-wrapper.slider-mode-products .swiper-slide {
    height: auto;
}

.custom-slider-wrapper.slider-mode-products .product-slide {
    width: 100%;
}

.custom-slider-wrapper.slider-mode-products .product-slide .product {
    margin-bottom: 0;
}

.custom-slider-wrapper.template-type-template_products {
    --ga-card-width: 27.2rem;
}

.custom-slider-wrapper.template-type-template_products .custom-slider .swiper-slide {
    width: var(--ga-card-width, 27.2rem);
}

/* Template E: compact hero icon strip */
.custom-slider-wrapper .slider-card.template-small-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    justify-content: center;
    width: 100%;
    min-height: 7.5rem;
    padding: 1.5rem 1rem;
    color: inherit;
    text-decoration: none;
}

.custom-slider-wrapper .slider-card.template-small-card:hover,
.custom-slider-wrapper .slider-card.template-small-card:focus {
    text-decoration: none;
}

.custom-slider-wrapper .template-small-card-image-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    margin-bottom: 0.75rem;
}

.custom-slider-wrapper .template-small-card-image-wrapper img,
.custom-slider-wrapper .template-small-card-image {
    width: 3rem;
    height: 3rem;
    object-fit: contain;
}

.custom-slider-wrapper .template-small-card-text {
    width: 100%;
}

.custom-slider-wrapper .template-small-card-title {
    display: block;
}

/* Apple-like rail behavior for non-product templates: fixed widths, no breakpoint jumps */
.custom-slider-wrapper:not(.template-type-template_products) .custom-slider .swiper-slide {
    width: var(--ga-card-width, 280px);
}

.custom-slider-wrapper.template-type-template_a {
    --ga-card-width: 38rem;
}

.custom-slider-wrapper.template-type-template_b {
    --ga-card-width: 20rem;
}

.custom-slider-wrapper.template-type-template_c {
    --ga-card-width: 32rem;
}

.custom-slider-wrapper.template-type-template_d {
    --ga-card-width: 32rem;
}

.custom-slider-wrapper.template-type-template_e {
    --ga-card-width: 12.5rem;
}

.custom-slider-wrapper.template-type-template_e .custom-slider {
    overflow: hidden;
}

.custom-slider-wrapper.template-type-template_f {
    --ga-card-width: 29rem;
}

.custom-slider-wrapper.template-type-template_g {
    --ga-card-width: 20rem;
}

.custom-slider-wrapper.template-type-template_h {
    --ga-card-width: 29rem;
}

.custom-slider-wrapper.template-type-template_f .custom-slider .slide-content,
.custom-slider-wrapper.template-type-template_g .custom-slider .slide-content,
.custom-slider-wrapper.template-type-template_h .custom-slider .slide-content {
    align-items: stretch;
}

.custom-slider-wrapper .custom-slider .slide-content {
    align-items: center;
}

.custom-slider-wrapper.template-type-template_products .slide-content {
    align-items: stretch;
}

@media (max-width: 1023px) {
    .custom-slider-wrapper.template-type-template_products {
        --ga-card-width: 24rem;
    }
}

@media (max-width: 767px) {
    .custom-slider-wrapper.template-type-template_products {
        --ga-card-width: 19.2rem;
    }
}

/* Template A card-level link wrapper */
.custom-slider-wrapper .template-a-card-link {
    display: block;
    width: 100%;
    height: 100%;
    color: inherit;
    text-decoration: none;
}

.custom-slider-wrapper .template-a-card-link:hover,
.custom-slider-wrapper .template-a-card-link:focus {
    text-decoration: none;
}

/* Manual template layout helpers */
.custom-slider-wrapper .template-promo-banner-card,
.custom-slider-wrapper .template-feature-tile-card,
.custom-slider-wrapper .template-editorial-card {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
    color: inherit;
    text-decoration: none;
}

.custom-slider-wrapper .template-promo-banner-card:hover,
.custom-slider-wrapper .template-promo-banner-card:focus,
.custom-slider-wrapper .template-feature-tile-card:hover,
.custom-slider-wrapper .template-feature-tile-card:focus,
.custom-slider-wrapper .template-editorial-card:hover,
.custom-slider-wrapper .template-editorial-card:focus {
    text-decoration: none;
}

.custom-slider-wrapper .template-promo-banner-card {
    position: relative;
    overflow: hidden;
}

.custom-slider-wrapper .template-promo-banner-media {
    width: 100%;
    height: 100%;
    min-height: 18rem;
}

.custom-slider-wrapper .template-promo-banner-media img,
.custom-slider-wrapper .template-promo-banner-image {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.custom-slider-wrapper .template-promo-banner-content {
    position: absolute;
    left: 1.5rem;
    right: 1.5rem;
    bottom: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    z-index: 1;
}

.custom-slider-wrapper .template-promo-banner-eyebrow,
.custom-slider-wrapper .template-promo-banner-button {
    display: inline-flex;
}

.custom-slider-wrapper .template-promo-banner-title {
    margin: 0;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    overflow: hidden;
}

.custom-slider-wrapper .template-feature-tile-card {
    justify-content: space-between;
    width: 100%;
    height: 100%;
    overflow: hidden;
    padding: 2rem;
}

.custom-slider-wrapper .template-feature-tile-content {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-bottom: 1.5rem;
}

.custom-slider-wrapper .template-feature-tile-title {
    margin: 0;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    overflow: hidden;
}

.custom-slider-wrapper .template-feature-tile-subtitle {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    overflow: hidden;
}

.custom-slider-wrapper .template-feature-tile-media {
    width: 100%;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    flex: 1 1 auto;
    min-height: 8rem;
}

.custom-slider-wrapper .template-feature-tile-media img,
.custom-slider-wrapper .template-feature-tile-image {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    display: block;
    object-fit: contain;
}

.custom-slider-wrapper .template-editorial-card {
    overflow: hidden;
}

.custom-slider-wrapper .template-editorial-card-media {
    width: 100%;
    aspect-ratio: 400 / 250;
    overflow: hidden;
}

.custom-slider-wrapper .template-editorial-card-media img,
.custom-slider-wrapper .template-editorial-card-image {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.custom-slider-wrapper .template-editorial-card-content {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    width: 100%;
    flex: 1 1 auto;
    padding: 1.5rem;
}

.custom-slider-wrapper .template-editorial-card-title {
    margin: 0;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    overflow: hidden;
}

.custom-slider-wrapper .template-editorial-card-eyebrow,
.custom-slider-wrapper .template-editorial-card-cta {
    display: inline-flex;
}

.custom-slider-wrapper .template-editorial-card-excerpt {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
    overflow: hidden;
}

.custom-slider-wrapper .template-editorial-card-cta {
    margin-top: auto;
}

/* Template: Image Only */
.custom-slider-wrapper.template-type-template_image_only {
    --ga-card-width: 672px; 
}

.custom-slider-wrapper .slider-card.template-image-only-card {
    box-shadow: 0 4px 16px 0 rgba(0, 0, 0, 0.10);
    display: block;
    width: 100%;
    aspect-ratio: 2 / 1;
    border-radius: 16px;
    overflow: hidden;
    text-decoration: none;
    padding: 0;
    /* cursor: pointer; */
}

.custom-slider-wrapper .template-image-only-card img,
.custom-slider-wrapper .template-image-only-img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Editor preview tweaks */
.elementor-editor-active .custom-slider-wrapper .slide-content {
    min-height: 200px;
}

