*{box-sizing:border-box}
html{
    -webkit-text-size-adjust:100%;
    -webkit-tap-highlight-color:transparent;
}

body.no-scroll{overflow:hidden;position:fixed;width:100%;touch-action:none}

/* STORY LIST - mobil safe area + touch scroll */
.story-list{
    display:flex;
    gap:18px;
    padding:14px;
    padding-left:max(14px, env(safe-area-inset-left));
    padding-right:max(14px, env(safe-area-inset-right));
    padding-bottom:max(14px, env(safe-area-inset-bottom));
    background:#fff;
    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    -ms-overflow-style:none;
}
.story-list::-webkit-scrollbar{display:none}
.story-item{
    min-width:80px;
    min-height:44px;
    text-align:center;
    cursor:pointer;
    padding:4px 0;
    -webkit-tap-highlight-color:transparent;
    touch-action:manipulation;
    flex-shrink:0;
}
.story-item img{
    width:72px;
    height:72px;
    border-radius:50%;
    border:3px solid #ff005d;
    object-fit:cover;
    display:block;
    margin:0 auto;
}
.story-item.seen img{border-color:#bbb}
.story-item span{
    display:block;
    font-size:12px;
    margin-top:6px;
    line-height:1.3;
}

/* POPUP OVERLAY - mobil safe area */
.story-popup{
    position:fixed;
    top:0;left:0;right:0;bottom:0;
    top:env(safe-area-inset-top);
    left:env(safe-area-inset-left);
    right:env(safe-area-inset-right);
    bottom:env(safe-area-inset-bottom);
    background:#000;
    display:none;
    z-index:9999;
}

.story-popup.show{
    display:flex;
    justify-content:center;
    align-items:center;
    animation:fadeIn .18s ease-out;
}

@keyframes fadeIn{
    from{opacity:0}
    to{opacity:1}
}

/* POPUP CONTENT - Mobil: tam ekran. Desktop: 9:16 (1080x1920) kutu */
.story-inner{
    position:relative;
    width:100%;
    height:100%;
    overflow:hidden;
    background:#000;
    transform:translate(0, 0);
    transition:transform .2s ease;
    display:flex;
    flex-direction:column;
}
.story-inner.edge-drag{ transition:none; }

/* Sadece desktop'ta 9:16 oranlı kutu; mobil full ekran kalır */
@media (min-width: 768px){
    .story-inner{
        width: min(420px, 100vh * 9 / 16);
        height: min(100vh, 420px * 16 / 9);
        margin: auto;
        border-radius:16px;
        box-shadow:0 18px 40px rgba(0,0,0,.6);
    }
}

/* HEADER - mobil safe area */
.story-header{
    position:absolute;
    top:0;
    width:100%;
    padding:12px;
    padding-top:max(12px, env(safe-area-inset-top));
    padding-left:max(12px, env(safe-area-inset-left));
    padding-right:max(12px, env(safe-area-inset-right));
    z-index:20;
}
.story-header-info{
    display:flex;
    align-items:center;
    gap:10px;
    margin-top:10px;
}
.story-header-icon{
    width:34px;
    height:34px;
    border-radius:50%;
    border:2px solid #fff;
    object-fit:cover;
}
.story-header-text{
    display:flex;
    flex-direction:column;
}
.story-header-title{
    color:#fff;
    font-size:14px;
    font-weight:600;
}
.story-header-views{
    display:inline-flex;
    align-items:center;
    gap:5px;
    color:rgba(255,255,255,.85);
    font-size:11px;
    margin-top:2px;
}
.story-header-views svg{
    width:12px;
    height:12px;
    flex-shrink:0;
    opacity:0.9;
}
.progress-wrap{
    display:flex;
    gap:4px;
    margin-top:36px;
}
.progress{
    flex:1;
    height:3px;
    background:rgba(255,255,255,.3);
}
.progress span{
    display:block;
    height:100%;
    width:0;
    background:#fff;
}
.progress span.animate{
    transition:width var(--progress-duration, 3s) linear;
}

/* CLOSE - 44px+ touch target */
.story-close{
    position:absolute;
    top:max(10px, env(safe-area-inset-top));
    right:max(10px, env(safe-area-inset-right));
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:28px;
    line-height:1;
    color:#fff;
    z-index:30;
    cursor:pointer;
    -webkit-tap-highlight-color:transparent;
    touch-action:manipulation;
}

/* SLIDES - 9:16 alanı doldur, resim/video cover (1080x1920 gibi kırpılır) */
.storySwiper{
    width:100%;
    height:100%;
    flex:1;
    min-height:0;
}
.storySwiper .swiper-slide{
    position:relative;
    width:100%;
    height:100%;
}
.storySwiper .swiper-slide img,
.storySwiper .swiper-slide video{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    vertical-align:middle;
}
/* Slayt yüklenirken loader */
.slide-loader{
    position:absolute;
    inset:0;
    display:flex;
    align-items:center;
    justify-content:center;
    background:rgba(0,0,0,.5);
    z-index:5;
}
.slide-loader.hidden{
    display:none;
}
.slide-loader::after{
    content:'';
    width:44px;
    height:44px;
    border:3px solid rgba(255,255,255,.25);
    border-top-color:#fff;
    border-radius:50%;
    animation:slide-loader-spin .85s linear infinite;
}
@keyframes slide-loader-spin{
    to{ transform:rotate(360deg); }
}

/* CTA - sağ alt, safe area + 44px touch */
.story-footer{
    position:absolute;
    bottom:max(26px, env(safe-area-inset-bottom));
    right:max(18px, env(safe-area-inset-right));
    left:auto;
    width:auto;
    z-index:25;
}
.story-footer .detail-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:48px;
    height:48px;
    min-width:48px;
    min-height:48px;
    border:none;
    border-radius:50%;
    background:#ff005d;
    color:#fff;
    cursor:pointer;
    padding:0;
    -webkit-tap-highlight-color:transparent;
    touch-action:manipulation;
}
.story-footer .detail-btn svg{
    width:22px;
    height:22px;
}

/* SOUND - sol alt, safe area + 44px touch */
.sound-btn{
    position:absolute;
    bottom:max(26px, env(safe-area-inset-bottom));
    left:max(18px, env(safe-area-inset-left));
    background:rgba(0,0,0,.6);
    color:#fff;
    width:48px;
    height:48px;
    min-width:48px;
    min-height:48px;
    padding:0;
    align-items:center;
    justify-content:center;
    border-radius:50%;
    z-index:25;
    display:none;
    cursor:pointer;
    -webkit-tap-highlight-color:transparent;
    touch-action:manipulation;
}
.sound-btn.show{
    display:inline-flex;
}

/* CLICK ZONES - sol/sağ tıklama ile önceki/sonraki slayt */
.click-zone{
    position:absolute;
    top:0;
    bottom:0;
    z-index:10;
    -webkit-tap-highlight-color:transparent;
}
.zone-left,.zone-right{pointer-events:none}
.zone-center{left:25%;width:50%;touch-action:manipulation}
.zone-left{left:0;width:25%}
.zone-right{right:0;width:25%}

/* Desktop: butonlar 44px */
@media (min-width: 768px){
    .story-footer .detail-btn,
    .sound-btn{
        width:44px;
        height:44px;
        min-width:44px;
        min-height:44px;
    }
    .story-footer .detail-btn svg{width:20px;height:20px}
}

/* Mobil: küçük ekranlarda font/boşluk */
@media (max-width: 480px){
    .story-item span{font-size:11px}
    .story-header-title{font-size:13px}
}
