/* ── LIGHTBOX ─────────────────────────── */
/* ── LIGHTBOX BASE ── */
.pig-lb {
    position: fixed; inset: 0; z-index: 99999;
    display: none; flex-direction: column;
    align-items: center; justify-content: center;
}
.pig-lb-bg {
    position: absolute; inset: 0;
    background: rgba(0,0,0,.93);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}
.pig-lb-x {
    position: absolute; top: 16px; right: 18px; z-index: 10;
    background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.2);
    color: #fff; font-size: 18px; width: 40px; height: 40px; border-radius: 50%;
    cursor: pointer; display: flex; align-items: center; justify-content: center; transition: .2s;
}
.pig-lb-x:hover { background: rgba(255,255,255,.28); transform: scale(1.1); }
.pig-lb-stage {
    position: relative; z-index: 5;
    display: flex; align-items: center; justify-content: center;
    max-width: 90vw; max-height: 82vh;
}

.pig-lb-img {
    display: block; max-width: 88vw; max-height: 80vh;
    object-fit: contain; transition: opacity .18s;
    user-select: none; vertical-align: top;
}
.pig-lb-img.out { opacity: 0; }
.pig-lb-cap {
    position: absolute; bottom: 0; left: 0; right: 0;
    padding: 36px 14px 12px;
    background: linear-gradient(to top, rgba(0,0,0,.75), transparent);
    display: flex; flex-direction: column; gap: 3px;
    pointer-events: none; line-height: 1.3;
    /* Border radius ile uyumlu — köşe taşmasını önle */
    border-bottom-left-radius: var(--lb-img-radius, 4px);
    border-bottom-right-radius: var(--lb-img-radius, 4px);
    /* Border kalınlığı kadar içeri al */
    bottom: 0; left: 0; right: 0;
}
.pig-lb-b1 { font-size: 15px; font-weight: 600; color: #fff; text-shadow: 0 1px 3px rgba(0,0,0,.5); }
.pig-lb-b2 { font-size: 12px; color: rgba(255,255,255,.72); text-shadow: 0 1px 2px rgba(0,0,0,.4); }
.pig-lb{
    position:fixed; inset:0; z-index:99999;
    display:flex; flex-direction:column;
    align-items:center; justify-content:center;
    padding:16px 16px 80px; box-sizing:border-box;
}
/* Pan zoom aktifken caption/nav/bg gizle */
.pig-lb.pig-zoom-active .pig-lb-cap { opacity:0; pointer-events:none; transition:opacity .2s; }
.pig-lb.pig-zoom-active .pig-lb-nav { opacity:0; pointer-events:none; transition:opacity .25s; }
.pig-lb.pig-zoom-active .pig-lb-bg  { transition:background .3s; }
/* Zoom cursor sınıfları */
.pig-lb-img.pz-zoomin  { cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32'%3E%3Ccircle cx='13' cy='13' r='9' fill='none' stroke='white' stroke-width='2'/%3E%3Ccircle cx='13' cy='13' r='9' fill='none' stroke='black' stroke-width='3.5' opacity='0.4'/%3E%3Cline x1='10' y1='13' x2='16' y2='13' stroke='white' stroke-width='2'/%3E%3Cline x1='13' y1='10' x2='13' y2='16' stroke='white' stroke-width='2'/%3E%3Cline x1='19' y1='19' x2='28' y2='28' stroke='white' stroke-width='2.5' stroke-linecap='round'/%3E%3Cline x1='19' y1='19' x2='28' y2='28' stroke='black' stroke-width='4' opacity='0.4' stroke-linecap='round'/%3E%3C/svg%3E") 13 13, zoom-in !important; }
.pig-lb-img.pz-zoomout { cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32'%3E%3Ccircle cx='13' cy='13' r='9' fill='none' stroke='white' stroke-width='2'/%3E%3Ccircle cx='13' cy='13' r='9' fill='none' stroke='black' stroke-width='3.5' opacity='0.4'/%3E%3Cline x1='10' y1='13' x2='16' y2='13' stroke='white' stroke-width='2'/%3E%3Cline x1='19' y1='19' x2='28' y2='28' stroke='white' stroke-width='2.5' stroke-linecap='round'/%3E%3Cline x1='19' y1='19' x2='28' y2='28' stroke='black' stroke-width='4' opacity='0.4' stroke-linecap='round'/%3E%3C/svg%3E") 13 13, zoom-out; }
.pig-lb-img.pz-grab    { cursor:grab !important; }
.pig-lb-img.pz-grabbing{ cursor:grabbing !important; }
.pig-lb-bg{position:absolute;inset:0;background:var(--lb-bg,rgba(0,0,0,.93));backdrop-filter:blur(var(--lb-blur,8px));-webkit-backdrop-filter:blur(var(--lb-blur,8px));}
.pig-lb-x{
    position:fixed; top:14px; right:16px; z-index:100001;
    width:40px; height:40px; border-radius:50%;
    cursor:pointer; display:flex; align-items:center; justify-content:center;
    transition:.2s; font-size:18px;
    background:#fff;
    color:#000;
    border:none;
    mix-blend-mode:difference;
}
/* Siyah dış border */
.pig-lb-x::before {
    content:'';
    position:absolute; inset:-3px;
    border-radius:50%;
    border:2px solid rgba(0,0,0,.55);
    pointer-events:none;
    mix-blend-mode:normal;
}
/* Beyaz iç border */
.pig-lb-x::after {
    content:'';
    position:absolute; inset:-1px;
    border-radius:50%;
    border:1.5px solid rgba(255,255,255,.7);
    pointer-events:none;
    mix-blend-mode:normal;
}
.pig-lb-x:hover{transform:scale(1.1);}

/* Sol panel — fullscreen (masaüstü) */
.pig-lb-left-controls {
    position: fixed;
    top: 14px; left: 16px;
    z-index: 100001;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
}
.pig-lb-ctrl-btn {
    position: relative;
    width: 36px; height: 36px;
    border-radius: 50%;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    font-size: 15px;
    background: #fff;
    color: #000;
    border: none;
    mix-blend-mode: difference;
    transition: .18s;
    flex-shrink: 0;
}
.pig-lb-ctrl-btn::before {
    content: '';
    position: absolute; inset: -3px;
    border-radius: 50%;
    border: 2px solid rgba(0,0,0,.55);
    pointer-events: none;
}
.pig-lb-ctrl-btn::after {
    content: '';
    position: absolute; inset: -1px;
    border-radius: 50%;
    border: 1.5px solid rgba(255,255,255,.7);
    pointer-events: none;
}
.pig-lb-ctrl-btn:hover { transform: scale(1.1); }

/* Stage — görselin etrafı, flex içinde doğal akar */
.pig-lb-stage{
    position:relative; z-index:5;
    display:flex; align-items:center; justify-content:center;
    max-width:min(90vw, 1200px);
    flex-shrink:1; min-height:0;
}
/* Dış wrap — hiyerarşik radius + border */
.pig-lb-wrap{
    position:relative;
    display:block;
    box-sizing:border-box;
    max-width:100%;
    border-radius:var(--lb-wrap-radius,7px);
    box-shadow:0 8px 48px rgba(0,0,0,.7);
    border-width:var(--lb-img-border,3px);
    border-style:var(--lb-img-border-style,solid);
    border-color:var(--lb-img-border-color,#ffffff);
    overflow:hidden;
    line-height:0;
}
/* İç görsel */
.pig-lb-wrap .pig-lb-img{
    display:block;
    max-width:min(88vw, 1200px);
    max-height:calc(100dvh - 120px);
    width:auto; height:auto;
    object-fit:contain;
    border-radius:var(--lb-img-radius,4px);
    transition:opacity .18s;
    user-select:none;
    vertical-align:top;
}
.pig-lb-img{display:block;max-width:min(88vw,1200px);max-height:calc(100dvh - 120px);object-fit:contain;transition:opacity .18s;user-select:none;vertical-align:top;}
.pig-lb-img.out{opacity:0;}
/* Caption — görsel içinde, alt köşe radius'u takip eder */
.pig-lb-cap{
    position:absolute;
    /* Border kalınlığı kadar içeri al — border üstüne taşmasın */
    bottom:0; left:0; right:0;
    /* Padding: yatay ve alt border kadar içeri */
    padding:36px calc(14px + var(--lb-img-border,3px)) calc(12px + var(--lb-img-border,3px)) calc(14px + var(--lb-img-border,3px));
    background:linear-gradient(to top,rgba(0,0,0,.75),transparent);
    display:flex; flex-direction:column; gap:3px;
    pointer-events:none; line-height:1.3;
    border-bottom-left-radius:var(--lb-img-radius,4px);
    border-bottom-right-radius:var(--lb-img-radius,4px);
    box-sizing:border-box;
}
.pig-lb-b1{font-size:15px;font-weight:600;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5);}
.pig-lb-b2{font-size:12px;color:rgba(255,255,255,.72);text-shadow:0 1px 2px rgba(0,0,0,.4);}
/* Nav — fixed konumlu pill, görsel boyutundan bağımsız */
.pig-lb-nav{
    position:fixed;
    bottom:24px;
    left:50%;
    transform:translateX(-50%);
    z-index:100000;
    display:flex;
    align-items:center;
    background:rgba(20,20,20,.82);
    backdrop-filter:blur(16px);
    -webkit-backdrop-filter:blur(16px);
    border-radius:100px;
    padding:5px;
    gap:0;
    box-shadow:0 4px 24px rgba(0,0,0,.45);
    border:1px solid rgba(255,255,255,.08);
    user-select:none;
}
.pig-lb-prev,.pig-lb-next{
    background:rgba(255,255,255,.1);
    border:none;
    color:#fff;
    font-size:18px;
    width:44px; height:44px;
    border-radius:50%;
    cursor:pointer;
    display:flex; align-items:center; justify-content:center;
    transition:.18s;
    flex-shrink:0;
}
.pig-lb-prev:hover,.pig-lb-next:hover{ background:rgba(255,255,255,.22); }
.pig-lb-prev:disabled,.pig-lb-next:disabled{ opacity:.25; cursor:default; }
.pig-lb-cnt{
    font-size:13px; font-weight:600;
    color:rgba(255,255,255,.9);
    min-width:54px; text-align:center;
    letter-spacing:.02em;
    padding:0 4px;
}
/* Filmstrip: nav ortasında küçük thumbnail */
.pig-lb-filmstrip .pig-lb-cnt {
    min-width:auto;
    padding:0 2px;
}
.pig-lb-nav-thumb {
    width:52px; height:36px;
    object-fit:cover;
    border-radius:5px;
    display:block;
    border:1.5px solid rgba(255,255,255,.3);
    transition:opacity .18s;
}
/* nav fixed — pig-lb padding-bottom zaten 80px */
@media(max-width:600px){
    .pig-lb{ padding:8px 8px 72px; gap:0; overflow:hidden; }
    .pig-lb-wrap{ max-width:calc(100vw - 16px); box-sizing:border-box; }
    .pig-lb-wrap .pig-lb-img,.pig-lb-img{ max-width:100%; max-height:calc(100dvh - 90px); }
    .pig-lb-stage{ max-width:calc(100vw - 16px); }
    .pig-lb-nav{ bottom:16px; }
    .pig-lb-prev,.pig-lb-next{ width:38px; height:38px; font-size:15px; }
    .pig-lb-cnt{ min-width:44px; font-size:12px; }
}
@media(max-width:600px){.pig-lb-img{max-width:96vw;max-height:65vh;}.pig-lb-prev,.pig-lb-next{width:38px;height:38px;font-size:16px;}}

/* ══════════════════════════════════════
   LIGHTBOX STYLES
══════════════════════════════════════ */

/* ── A: MINIMAL (default) — mevcut stil ── */
/* zaten tanımlı */

/* ── B: FILM STRIP ── */
.pig-lb-filmstrip { padding-bottom: 82px !important; }
.pig-lb-filmstrip .pig-lb-stage {
    flex: 1;
    max-height: calc(82vh - 80px);
}
.pig-lb-filmstrip .pig-lb-nav { display:none !important; }
.pig-lb-strip {
    position: fixed;
    bottom: 0;
    left: 0; right: 0;
    height: 76px;
    background: rgba(10,10,10,.72);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-top: 1px solid rgba(255,255,255,.08);
    display: flex;
    align-items: center;
    overflow: hidden;
    z-index: 99998;
}
/* Sol alan — thumblar sağa dayalı, overflow hidden */
.pig-strip-left {
    flex: 1;
    min-width: 0;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 5px;
    overflow: hidden;
    padding-left: 10px;
}
/* Sağ alan — thumblar sola dayalı, overflow hidden */
.pig-strip-right {
    flex: 1;
    min-width: 0;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 5px;
    overflow: hidden;
    padding-right: 10px;
}
/* Merkez bölge — kesinlikle sabit, shrink yok */
.pig-strip-center {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
    z-index: 1;
}
.pig-lb-strip::-webkit-scrollbar { display: none; }

/* Strip içi: inline prev/next butonlar */
.pig-strip-nav-btn {
    flex-shrink: 0;
    width: 42px; height: 58px;
    background: rgba(10,10,10,.92);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 8px;
    color: #fff;
    font-size: 18px;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: .18s;
    user-select: none;
}
.pig-strip-nav-btn:hover { background: rgba(40,40,40,.98); border-color:rgba(255,255,255,.25); }
.pig-strip-nav-btn:disabled { opacity: .22; cursor: default; }

/* Strip içi: aktif thumbnail kutusu */
.pig-strip-active-thumb {
    flex-shrink: 0;
    width: 80px; height: 58px;
    object-fit: cover;
    border-radius: 6px;
    border: 2px solid rgba(255,255,255,.85);
    box-shadow: 0 2px 12px rgba(0,0,0,.5);
    transform-origin: center center;
    transition:
        transform .42s cubic-bezier(.25,.1,.25,1),
        opacity   .38s cubic-bezier(.25,.1,.25,1),
        filter    .38s ease;
    will-change: transform, opacity;
}
/* Sola kayarak çıkar (sonraki görsele geçince) */
.pig-strip-active-thumb.thumb-exit-left {
    transform: translateX(-28px) scale(.88);
    opacity: 0;
    filter: blur(2px);
}
/* Sağa kayarak çıkar (önceki görsele geçince) */
.pig-strip-active-thumb.thumb-exit-right {
    transform: translateX(28px) scale(.88);
    opacity: 0;
    filter: blur(2px);
}
/* Sağdan girer */
.pig-strip-active-thumb.thumb-enter-left {
    transform: translateX(28px) scale(.88);
    opacity: 0;
    filter: blur(2px);
}
/* Soldan girer */
.pig-strip-active-thumb.thumb-enter-right {
    transform: translateX(-28px) scale(.88);
    opacity: 0;
    filter: blur(2px);
}
.pig-strip-active-thumb.thumb-visible {
    transform: translateX(0) scale(1);
    opacity: 1;
    filter: blur(0);
}
/* Yan thumblar — merkeze yakınlığa göre opaklık */
.pig-strip-left .pig-strip-thumb { opacity:.55; transition:opacity .2s; }
.pig-strip-right .pig-strip-thumb { opacity:.55; transition:opacity .2s; }
.pig-strip-left .pig-strip-thumb:last-child,
.pig-strip-right .pig-strip-thumb:first-child { opacity:.75; }
.pig-strip-thumb {
    width: 52px;
    height: 52px;
    flex-shrink: 0;
    border-radius: 3px;
    overflow: hidden;
    border: 2px solid transparent;
    cursor: pointer;
    opacity: .55;
    transition: opacity .2s, border-color .2s;
}
.pig-strip-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pig-strip-thumb:hover { opacity: .85; }
.pig-strip-thumb.active { border-color: #fff; opacity: 1; }

/* ── C: SIDEBAR ── */
.pig-lb-sidebar .pig-lb-stage { max-width: calc(90vw - 220px); }
.pig-lb-sidebar .pig-lb-nav { display: none !important; } /* sidebar kendi side-panel nav'ını kullanır */
.pig-lb-sidebar-panel {
    position: absolute;
    right: 0; top: 0; bottom: 0;
    width: 200px;
    background: rgba(20,20,20,.95);
    border-left: 1px solid rgba(255,255,255,.08);
    z-index: 6;
    display: flex;
    flex-direction: column;
    padding: 60px 18px 18px;
    gap: 12px;
}
.pig-lb-sidebar-panel .pig-lb-b1 { font-size: 14px; font-weight: 600; color: #fff; line-height: 1.4; }
.pig-lb-sidebar-panel .pig-lb-b2 { font-size: 12px; color: rgba(255,255,255,.5); }
.pig-lb-sidebar-panel .pig-lb-cnt { font-size: 12px; color: rgba(255,255,255,.35); margin-top: auto; }
.pig-lb-sidebar .pig-lb-cap { display: none; }
.pig-lb-sidebar .pig-lb-stage { margin-right: 200px; }

/* ── D: FULLSCREEN ── */
.pig-lb-fullscreen .pig-lb-bg { background: #000; backdrop-filter: none; }
.pig-lb-fullscreen .pig-lb-stage { max-width: 100vw; max-height: 100vh; }
.pig-lb-fullscreen .pig-lb-img { max-width: 100vw; max-height: 100vh; }
.pig-lb-fullscreen .pig-lb-prev,
.pig-lb-fullscreen .pig-lb-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(255,255,255,.06);
    border: none;
    width: 52px; height: 52px;
    border-radius: 0;
}
.pig-lb-fullscreen .pig-lb-prev { left: 0; border-radius: 0 4px 4px 0; }
.pig-lb-fullscreen .pig-lb-next { right: 0; border-radius: 4px 0 0 4px; }
.pig-lb-fullscreen .pig-lb-nav {
    bottom: 16px;
    gap: 12px;
}
.pig-lb-fullscreen .pig-lb-cnt { display: none; }
/* Dot gösterge */
.pig-lb-dots {
    display: none;
    gap: 6px;
    align-items: center;
}
.pig-lb-fullscreen .pig-lb-dots { display: flex; }
.pig-lb-dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: rgba(255,255,255,.25);
    cursor: pointer;
    transition: background .2s, transform .2s;
    flex-shrink: 0;
}
.pig-lb-dot.active { background: #fff; transform: scale(1.3); }
.pig-lb-fullscreen .pig-lb-cap {
    border-radius: 0;
}

/* ── CAPTION ────────────────────────── */
.pig-item { position: relative; overflow: hidden; }
.pig-caption {
    position: absolute; bottom: 0; left: 0; right: 0;
    padding: 24px 12px 10px;
    background: linear-gradient(transparent, rgba(0,0,0,.65));
    opacity: 0; transition: opacity .2s;
    display: flex; flex-direction: column; gap: 2px;
}
.pig-item:hover .pig-caption { opacity: 1; }
.pig-caption-title {
    color: #fff; font-size: 13px; font-weight: 600;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.pig-caption-desc {
    color: rgba(255,255,255,.75); font-size: 11px;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
/* Always show caption style */
.pig-gallery[data-effect="always"] .pig-caption { opacity: 1; }
