/* ============================================================
   Hero Slider — Full bleed, 100vh, header overlay
   Swiper tabanlı: orta net, komşular hafif blur, uzaktakiler güçlü blur
   ============================================================ */

/* 100vw scrollbar genişliğini kapsadığı için yan tarafta yatay scroll
   oluşmasın diye body'de overflow-x clip — sticky header'ı bozmaz */
html, body {
    overflow-x: clip;
}

.hero-slider {
    position: relative;
    /* .container ve .site-content padding'inden kaç → tam ekran genişlik */
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    /* Header'ın altına çek → header üstte overlay olur.
       --header-h JS tarafından runtime'da set ediliyor; site-content top padding'ini de
       ortadan kaldırmak için ek olarak --space-6 değerini çıkarıyoruz. */
    margin-top: calc(-1 * (var(--header-h, 120px) + var(--space-6)));
    /* Tam ekran yükseklik */
    min-height: 100vh;
    /* Header altta kalmasın diye üstte boşluk */
    padding: calc(var(--header-h, 120px) + 40px) 0 90px;
    /* Full bleed olduğu için kenar yuvarlama yok */
    border-radius: 0;
    /* İçerik dikeyde ortalı */
    display: flex;
    flex-direction: column;
    justify-content: center;
    /* Renk + arka plan */
    color: #fff;
    overflow: hidden;
    background:
        radial-gradient(circle at 15% 20%, rgba(255, 255, 255, .12) 0, transparent 45%),
        radial-gradient(circle at 85% 80%, rgba(255, 255, 255, .08) 0, transparent 50%),
        linear-gradient(135deg, #ba5067 0%, #a61e4d 100%);
}

/* Admin bar açıkken WP 32px boşluk ekler → onu da kompanze et */
body.admin-bar .hero-slider {
    margin-top: calc(-1 * (var(--header-h, 120px) + var(--space-6) + 32px));
}

@media screen and (max-width: 782px) {
    body.admin-bar .hero-slider {
        margin-top: calc(-1 * (var(--header-h, 120px) + var(--space-6) + 46px));
    }
}

.hero-slider__head {
    max-width: 720px;
    margin: 0 auto 56px;
    padding: 0 var(--space-5);
    text-align: center;
}

.hero-slider__title {
    font-family: 'Swanky and Moo Moo', cursive;
    font-size: clamp(1.2rem, 5.5vw, 4.4rem);
    font-weight: 400;
    line-height: 1.15;
    letter-spacing: 0.5px;
    margin: 0 0 18px;
    color: #fff;
    min-height: 1.2em;
    text-shadow:
        0 2px 12px rgba(0, 0, 0, .25),
        0 0 40px rgba(255, 255, 255, .12);
    white-space: nowrap;
    display: flex;
    flex-direction: column;
    align-items: center;
}

/* sr-only: ekran okuyucu için görünmez tam metin */
.hero-slider__title .sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
}

/* Tek tek beliren harfler */
.hero-slider__title-char {
    display: inline-block;
    opacity: 0;
    transform: translateY(4px);
    transition: opacity 0.25s ease-out, transform 0.25s ease-out;
}

.hero-slider__title-char.vis {
    opacity: 1;
    transform: translateY(0);
}

/* Yazı imleci */
.hero-slider__title-cursor {
    display: none !important;
}

@keyframes hero-blink {
    0%, 100% { opacity: 1; }
    50%       { opacity: 0; }
}

.hero-slider__title-cursor.done {
    animation: hero-cursor-out 0.5s ease 0.3s forwards;
}

@keyframes hero-cursor-out {
    to { opacity: 0; width: 0; margin-left: 0; }
}

/* Alt çizgi — text tamamlanınca çizilir */
.hero-slider__title-underline {
    display: none !important;
}

.hero-slider__sub {
    font-size: var(--fs-base);
    line-height: 1.6;
    margin: 0;
    color: rgba(255, 255, 255, .85);
}

.hero-slider__swiper {
    position: relative;
    width: 100%;
    /* slidesPerView:3 ile birlikte ±2 slide'lar overflow:visible sayesinde
       kenarlarda peek olarak görünür. 1300px sweet spot — geniş ekranda
       referanstaki gibi tiny edge peek'ler korunur */
    max-width: 1300px;
    margin: 0 auto;
    padding: 0 var(--space-5) 60px;
    overflow: visible;
}

.hero-slider .swiper-wrapper {
    align-items: flex-start;
}

/* Slide stilleri (translateY/blur/opacity/z-index) JS'den inline yazılıyor.
   CSS sadece transition'ı veriyor → değişiklikler yumuşak animasyon ile uygulanır. */
.hero-slider__slide {
    text-align: center;
    height: auto;
    transition:
        transform 600ms cubic-bezier(.4, 0, .2, 1),
        filter 600ms cubic-bezier(.4, 0, .2, 1),
        opacity 600ms cubic-bezier(.4, 0, .2, 1);
    will-change: transform, filter, opacity;
}

/* Swiper init olmadan slide'lar kararsız görünmesin */
.hero-slider__swiper:not(.swiper-initialized) {
    opacity: 0;
}
.hero-slider__swiper {
    transition: opacity 300ms ease;
}

.hero-slider__link {
    display: block;
    color: inherit;
    text-decoration: none;
}

.hero-slider__card {
    position: relative;
    /* Slot içinde ortala — slidesPerView:3 ile slot geniş olduğu için
       kartı 320px'e sınırlıyoruz, böylece 100vh'a sığar ve cards arası
       breathing room oluşur */
    width: 100%;
    max-width: 320px;
    margin: 0 auto;
    aspect-ratio: 3 / 4;
    border-radius: 50% 50% 14px 14px / 38% 38% 14px 14px;
    overflow: hidden;
    background:
        radial-gradient(circle at 30% 25%, rgba(255, 255, 255, .35) 0, transparent 55%),
        linear-gradient(160deg, #ffd6e1 0%, #ff8db1 55%, #ba5067 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow:
        0 18px 40px rgba(0, 0, 0, .18),
        inset 0 1px 0 rgba(255, 255, 255, .25);
}

.hero-slider__card-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.hero-slider__emoji {
    font-size: clamp(60px, 8vw, 96px);
    line-height: 1;
    filter: drop-shadow(0 6px 14px rgba(0, 0, 0, .2));
}

.hero-slider__label {
    margin: 22px 0 0;
    font-size: var(--fs-sm);
    font-weight: 500;
    color: rgba(255, 255, 255, .92);
    letter-spacing: .2px;
}

/* Pagination — beyaz noktalar, aktif olan geniş pill */
.hero-slider .swiper-pagination {
    bottom: 24px;
    display: flex;
    justify-content: center;
    gap: 8px;
}

.hero-slider .swiper-pagination-bullet {
    width: 8px;
    height: 8px;
    background: #fff;
    opacity: .4;
    margin: 0 !important;
    transition: all 300ms ease;
    border-radius: 999px;
    padding: 10px;
    box-sizing: content-box;
    background-clip: content-box;
}

.hero-slider .swiper-pagination-bullet-active {
    opacity: 1;
    width: 28px;
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 1024px) {
    .hero-slider {
        padding: calc(var(--header-h, 120px) + 24px) 0 70px;
    }
}

@media (max-width: 640px) {
    .hero-slider {
        padding: calc(var(--header-h, 120px) + 16px) 0 60px;
        min-height: 100vh;
    }
    .hero-slider__head {
        margin-bottom: 36px;
    }
    /* Mobilde 1.4 slidesPerView ile zaten az slide görünüyor;
       uzaktakileri tamamen gizle, görsel sade kalsın */
    .hero-slider__slide:not(.swiper-slide-active):not(.swiper-slide-prev):not(.swiper-slide-next) {
        opacity: 0;
    }
}

/* Modern viewport unit desteği varsa daha doğru 100vh — adres çubuğu sorunu için */
@supports (height: 100svh) {
    .hero-slider {
        min-height: 100svh;
    }
}
