/* ═══════════════════════════════════════════════════════════════════════════
   LIGHTBOX
   ═══════════════════════════════════════════════════════════════════════════ */
.esf-lb {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.96);
    z-index: 999999;
    display: flex;
    flex-direction: column;
}

/* Üst bar */
.esf-lb-bar {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 20px;
    background: rgba(0,0,0,.4);
    gap: 12px;
}
.esf-lb-counter {
    color: rgba(255,255,255,.7);
    font-size: 14px;
    font-weight: 500;
    letter-spacing: .4px;
    flex: 1;
}
/* Autoplay butonu */
.esf-lb-autoplay {
    width: 44px; height: 44px;
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.2);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; color: white;
    font-size: 0; /* Unicode karakterleri gizle */
    transition: background .15s, border-color .15s;
    flex-shrink: 0;
    position: relative;
}
.esf-lb-autoplay:hover    { background: rgba(255,255,255,.2); }
.esf-lb-autoplay.playing  { background: var(--esf-orange); border-color: var(--esf-orange); }

/* ▶ Play ikonu — CSS üçgeni */
.esf-lb-autoplay:not(.playing)::before {
    content: '';
    display: block;
    width: 0; height: 0;
    border-style: solid;
    border-width: 6px 0 6px 11px;
    border-color: transparent transparent transparent white;
    margin-left: 2px; /* optik hizalama */
}
/* ⏸ Pause ikonu — iki çubuk */
.esf-lb-autoplay.playing::before,
.esf-lb-autoplay.playing::after {
    content: '';
    display: block;
    width: 3px; height: 13px;
    background: white;
    border-radius: 1px;
    position: absolute;
    top: 50%; transform: translateY(-50%);
}
.esf-lb-autoplay.playing::before { left: calc(50% - 5px); }
.esf-lb-autoplay.playing::after  { left: calc(50% + 2px); }

/* Progress bar */
.esf-lb-progress {
    flex-shrink: 0;
    height: 3px;
    background: rgba(255,255,255,.1);
    width: 100%;
    overflow: hidden;
}
.esf-lb-progress-bar {
    height: 100%;
    width: 0%;
    background: var(--esf-orange);
}
.esf-lb-close {
    width: 44px; height: 44px;
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.2);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    transition: background .15s;
    position: relative; overflow: hidden; flex-shrink: 0;
}
.esf-lb-close:hover { background: var(--esf-orange); border-color: var(--esf-orange); }
/* CSS ile çizilmiş X */
.esf-lb-close::before,
.esf-lb-close::after {
    content: '';
    position: absolute;
    width: 18px; height: 2.5px;
    background: white; border-radius: 2px;
    top: 50%; left: 50%;
}
.esf-lb-close::before { transform: translate(-50%, -50%) rotate(45deg); }
.esf-lb-close::after  { transform: translate(-50%, -50%) rotate(-45deg); }

/* Ana stage */
.esf-lb-stage {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    padding: 0 70px;
    overflow: hidden;
}
.esf-lb-img-wrap {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.esf-lb-img {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
    display: block;
    border-radius: 4px;
    box-shadow: 0 20px 80px rgba(0,0,0,.8);
    transition: opacity .2s ease;
}

/* Ok butonları */
.esf-lb-nav {
    position: absolute;
    top: 50%; transform: translateY(-50%);
    background: rgba(255,255,255,.15);
    border: 1px solid rgba(255,255,255,.25);
    border-radius: 50%;
    width: 54px; height: 54px;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; z-index: 2;
    transition: background .15s, transform .15s;
    font-size: 22px;
    color: white;
    line-height: 1;
    font-weight: 300;
}
.esf-lb-nav:hover { background: var(--esf-orange); border-color: var(--esf-orange); transform: translateY(-50%) scale(1.06); }
.esf-lb-prev { left: 12px; top: 50%; }
.esf-lb-next { right: 12px; top: 50%; }
.esf-lb-prev::before { content: '❮'; }
.esf-lb-next::before { content: '❯'; }

/* Thumbnail şeridi */
.esf-lb-strip {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 20px 16px;
    background: rgba(0,0,0,.6);
    border-top: 1px solid rgba(255,255,255,.07);
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: thin;
    scrollbar-color: rgba(255,255,255,.2) transparent;
    justify-content: center;
}
.esf-lb-strip::-webkit-scrollbar { height: 3px; }
.esf-lb-strip::-webkit-scrollbar-track { background: transparent; }
.esf-lb-strip::-webkit-scrollbar-thumb { background: rgba(255,255,255,.25); border-radius: 2px; }

.esf-lb-sthumb {
    flex: 0 0 80px;
    height: 54px;
    border-radius: 6px;
    cursor: pointer;
    border: 2px solid rgba(255,255,255,.15);
    opacity: .45;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-color: #222;
    transition: border-color .15s, opacity .15s, transform .15s;
}
.esf-lb-sthumb.active {
    border-color: var(--esf-orange);
    opacity: 1;
    transform: translateY(-3px);
}
.esf-lb-sthumb:hover:not(.active) {
    border-color: rgba(255,255,255,.45);
    opacity: .75;
}

@media (max-width: 600px) {
    .esf-lb-stage  { padding: 0 48px; }
    .esf-lb-nav    { width: 42px; height: 42px; }
    .esf-lb-prev   { left: 4px; }
    .esf-lb-next   { right: 4px; }
    .esf-lb-sthumb { flex: 0 0 60px; height: 42px; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   EstateFlow — Single Listing
   ═══════════════════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=DM+Sans:wght@300;400;500;600&display=swap');

:root {
    --esf-navy:      #0D1B2A;
    --esf-orange:    #F97316;
    --esf-gold:      #C9A84C;
    --esf-white:     #FFFFFF;
    --esf-border:    #E8E2D9;
    --esf-cream:     #F7F4EF;
    --esf-muted:     #9A9189;
    --esf-text:      #2C2419;
    --esf-green:     #2D6A4F;
    --esf-radius:    12px;
    --esf-shadow:    0 2px 16px rgba(13,27,42,.07);
    --esf-shadow-lg: 0 10px 40px rgba(13,27,42,.13);
}

.esf-sl-wrap *, .esf-sl-wrap *::before, .esf-sl-wrap *::after {
    box-sizing: border-box; margin: 0; padding: 0;
}
.esf-single-listing-page .site-content,
.esf-single-listing-page #content,
.esf-single-listing-page .entry-content,
.esf-single-listing-page .post-content { padding: 0 !important; margin: 0 !important; }
html, body { max-width: 100%; overflow-x: clip; }

.esf-sl-wrap {
    background: #ffffff;
    min-height: 100vh;
    width: 100%;
    overflow-x: clip;
    font-family: 'DM Sans', -apple-system, sans-serif;
    color: var(--esf-text);
    -webkit-font-smoothing: antialiased;
}

/* ── Container — sıfır yatay padding, tam genişlik ── */
.esf-sl-container {
    max-width: 100%;
    width: 100%;
    margin: 0;
    padding: 0;
}

/* ── Breadcrumb ── */
.esf-sl-breadcrumb { background: var(--esf-white); padding: 12px 20px; }
.esf-sl-breadcrumb-inner { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--esf-muted); flex-wrap: wrap; }
.esf-sl-breadcrumb a { color: var(--esf-muted); text-decoration: none; transition: color .15s; }
.esf-sl-breadcrumb a:hover { color: var(--esf-orange); }
.esf-sl-bc-sep { color: var(--esf-border); font-size: 16px; line-height: 1; }
.esf-sl-bc-current { color: var(--esf-navy); font-weight: 500; max-width: 280px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ── Page Layout ── */
.esf-sl-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 0;
    padding: 0;
    align-items: start;
}

.esf-sl-main {
    min-width: 0;
    padding: 20px 20px 60px 20px;
}

/* ── Gallery ── */
.esf-sl-gallery { width: 100%; margin-bottom: 16px; }

.esf-sl-gallery-main {
    position: relative;
    border-radius: var(--esf-radius);
    overflow: hidden;
    background: #111;
    width: 100%;
    /* Yükseklik JS ile fotoğrafa göre ayarlanır, fallback: */
    min-height: 200px;
    max-height: 600px;
    cursor: zoom-in;
    box-shadow: var(--esf-shadow);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: height .25s ease;
}

.esf-sl-main-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    transition: opacity .22s ease;
}

/* Status overlay */
.esf-sl-status-overlay {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    font-size: 26px; font-weight: 800; letter-spacing: 4px;
    color: white; background: rgba(13,27,42,.45); text-transform: uppercase;
    pointer-events: none;
}

/* Fullscreen button */
.esf-sl-gallery-fullscreen {
    position: absolute; top: 12px; right: 12px;
    background: rgba(0,0,0,.55); border: none; border-radius: 8px;
    color: white; width: 38px; height: 38px;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; z-index: 3; font-size: 18px; line-height: 1;
    transition: background .15s;
}
.esf-sl-gallery-fullscreen:hover { background: var(--esf-orange); }

/* Image counter */
.esf-sl-gallery-counter {
    position: absolute; bottom: 12px; right: 12px;
    background: rgba(0,0,0,.6); color: white; font-size: 12px; font-weight: 600;
    border-radius: 6px; padding: 4px 10px; display: flex; align-items: center; gap: 5px; z-index: 2;
}

/* Nav arrows */
.esf-sl-nav {
    position: absolute; top: 50%; transform: translateY(-50%);
    background: rgba(255,255,255,.9); border: none; border-radius: 50%;
    width: 42px; height: 42px;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; z-index: 3; color: var(--esf-navy);
    box-shadow: 0 2px 10px rgba(0,0,0,.2);
    font-size: 20px; line-height: 1; font-weight: 700;
    transition: background .15s, transform .15s, color .15s;
}
.esf-sl-nav:hover { background: var(--esf-orange); color: white; transform: translateY(-50%) scale(1.07); }
.esf-sl-nav-prev { left: 12px; }
.esf-sl-nav-next { right: 12px; }

/* Thumbnails */
.esf-sl-thumbs {
    display: flex; gap: 6px; margin-top: 8px;
    overflow-x: auto; padding-bottom: 4px;
    scrollbar-width: none;
}
.esf-sl-thumbs::-webkit-scrollbar { display: none; }

.esf-sl-thumb {
    flex: 0 0 80px;
    height: 54px;
    border-radius: 6px; cursor: pointer;
    border: 2.5px solid transparent; opacity: .62;
    transition: border-color .15s, opacity .15s, transform .15s;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-color: #e8e2d9;
}
.esf-sl-thumb.active, .esf-sl-thumb:hover { border-color: var(--esf-orange); opacity: 1; transform: translateY(-1px); }

.esf-sl-gallery-placeholder {
    background: linear-gradient(135deg, #e8e2d9, #d4cec4);
    border-radius: var(--esf-radius); height: 400px;
    display: flex; align-items: center; justify-content: center; font-size: 64px;
}

/* ── Header Card ── */
.esf-sl-header {
    background: var(--esf-white); border: 1px solid var(--esf-border);
    border-radius: var(--esf-radius); padding: 24px 28px;
    margin-bottom: 16px; box-shadow: var(--esf-shadow);
}
.esf-sl-badges { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; }
.esf-sl-badge {
    font-size: 11px; font-weight: 600; text-transform: uppercase;
    letter-spacing: .7px; border-radius: 5px; padding: 4px 10px; line-height: 1.6;
}
.esf-sl-badge-cat  { background: rgba(201,168,76,.14); color: #8B6914; border: 1px solid rgba(201,168,76,.3); }
.esf-sl-badge-type { background: rgba(45,106,79,.1); color: #1a5c35; border: 1px solid rgba(45,106,79,.25); }
.esf-type-kiralık.esf-sl-badge-type { background: rgba(29,78,216,.1); color: #1d4ed8; border-color: rgba(29,78,216,.25); }
.esf-type-satılık.esf-sl-badge-type { background: rgba(45,106,79,.1); color: #1a5c35; border-color: rgba(45,106,79,.25); }
.esf-sl-badge-feat { background: rgba(232,101,26,.1); color: #c54c00; border: 1px solid rgba(232,101,26,.25); }

.esf-sl-title {
    font-family: 'Cormorant Garamond', Georgia, serif; font-size: 26px; font-weight: 700;
    color: var(--esf-navy); line-height: 1.25; margin-bottom: 12px;
}
.esf-sl-price {
    font-size: 28px; font-weight: 700; color: var(--esf-orange);
    margin-bottom: 10px; letter-spacing: -.4px; line-height: 1;
}
.esf-sl-location { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--esf-muted); margin-bottom: 14px; }
.esf-sl-meta-row {
    display: flex; align-items: center; flex-wrap: wrap; gap: 14px;
    font-size: 12px; color: #B5ADA3; padding-top: 14px; border-top: 1px solid var(--esf-border);
}
.esf-sl-meta-row span { display: flex; align-items: center; gap: 4px; }
.esf-sl-share-inline { display: flex; gap: 6px; margin-left: auto; }
.esf-share-btn {
    width: 30px; height: 30px; border-radius: 6px;
    display: flex; align-items: center; justify-content: center;
    text-decoration: none; border: none; cursor: pointer;
    transition: transform .12s, filter .12s; color: white;
}
.esf-share-btn:hover { transform: translateY(-2px); filter: brightness(1.12); }
.esf-share-fb { background: #1877F2; }
.esf-share-wa { background: #25D366; }
.esf-share-tw { background: #111; }
.esf-share-copy { background: #64748B; }

/* ── Stats Bar ── */
.esf-sl-stats-bar {
    background: var(--esf-white); border: 1px solid var(--esf-border);
    border-radius: var(--esf-radius); padding: 0;
    display: flex; margin-bottom: 16px; box-shadow: var(--esf-shadow); overflow: hidden;
}
.esf-sl-stat {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 4px; flex: 1; min-width: 0; padding: 18px 10px;
    border-right: 1px solid var(--esf-border); transition: background .15s;
}
.esf-sl-stat:last-child { border-right: none; }
.esf-sl-stat:hover { background: var(--esf-cream); }
.esf-sl-stat-icon {
    width: 32px; height: 32px; background: rgba(232,101,26,.08);
    border-radius: 50%; display: flex; align-items: center; justify-content: center; margin-bottom: 2px;
}
.esf-sl-stat-val { font-size: 14px; font-weight: 700; color: var(--esf-navy); white-space: nowrap; }
.esf-sl-stat-lbl { font-size: 10px; color: var(--esf-muted); text-transform: uppercase; letter-spacing: .6px; white-space: nowrap; }

/* ── Content Sections ── */
.esf-sl-section {
    background: var(--esf-white); border: 1px solid var(--esf-border);
    border-radius: var(--esf-radius); padding: 22px 26px;
    margin-bottom: 16px; box-shadow: var(--esf-shadow);
}
.esf-sl-section-title {
    display: flex; align-items: center; gap: 10px;
    font-family: 'Cormorant Garamond', Georgia, serif; font-size: 18px; font-weight: 700;
    color: var(--esf-navy); margin-bottom: 18px; padding-bottom: 12px;
    border-bottom: 1.5px solid var(--esf-border);
}
.esf-sl-section-title svg { flex-shrink: 0; }
.esf-sl-content { font-size: 14px; line-height: 1.85; color: #4A433A; }
.esf-sl-content p { margin-bottom: 12px; }
.esf-sl-content p:last-child { margin-bottom: 0; }

.esf-sl-features { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 8px; }
.esf-sl-feature-tag {
    display: flex; align-items: center; gap: 7px;
    background: #F0FBF5; border: 1px solid #BBF7D0; color: var(--esf-green);
    border-radius: 7px; padding: 8px 12px; font-size: 13px; font-weight: 500;
}

.esf-sl-details-table { display: flex; flex-direction: column; }
.esf-sl-detail-row {
    display: flex; justify-content: space-between; align-items: center;
    padding: 10px 0; border-bottom: 1px solid var(--esf-border);
    font-size: 13.5px; gap: 12px;
}
.esf-sl-detail-row:first-child { padding-top: 0; }
.esf-sl-detail-row:last-child { border-bottom: none; padding-bottom: 0; }
.esf-sl-detail-key { color: var(--esf-muted); font-weight: 400; flex-shrink: 0; }
.esf-sl-detail-val { color: var(--esf-navy); font-weight: 600; text-align: right; }

.esf-sl-map { height: 300px; border-radius: 8px; overflow: hidden; z-index: 1; border: 1px solid var(--esf-border); }

.esf-sl-similar-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.esf-sl-sim-card {
    text-decoration: none; color: inherit; border: 1px solid var(--esf-border);
    border-radius: 10px; overflow: hidden; transition: box-shadow .2s, transform .2s;
    background: var(--esf-white); display: block;
}
.esf-sl-sim-card:hover { box-shadow: var(--esf-shadow-lg); transform: translateY(-3px); }
.esf-sl-sim-img {
    position: relative;
    width: 100%;
    padding-top: 66%; /* 3/4 oranı = %66 yükseklik */
    overflow: hidden;
    background: #ffffff;
}
.esf-sl-sim-thumb {
    position: absolute;
    inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .4s ease;
}
.esf-sl-sim-card:hover .esf-sl-sim-thumb { transform: scale(1.04); }
.esf-sl-sim-no-img { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-size: 32px; }
.esf-sl-sim-badge { position: absolute; top: 8px; left: 8px; font-size: 10px; font-weight: 700; color: white; padding: 3px 8px; border-radius: 4px; text-transform: uppercase; }
.esf-type-satılık { background: #22C55E; }
.esf-type-kiralık  { background: #3B82F6; }
.esf-sl-sim-body { padding: 11px 13px; }
.esf-sl-sim-price { font-size: 14px; font-weight: 700; color: var(--esf-orange); margin-bottom: 4px; }
.esf-sl-sim-title { font-size: 12px; font-weight: 600; color: var(--esf-navy); line-height: 1.4; margin-bottom: 6px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.esf-sl-sim-loc { font-size: 11px; color: var(--esf-muted); display: flex; align-items: center; gap: 3px; margin-bottom: 4px; }
.esf-sl-sim-meta { font-size: 11px; color: #BDB6AE; display: flex; gap: 8px; }

/* ── Sidebar ── */
.esf-sl-sidebar {
    position: sticky;
    top: 20px;
    align-self: start;
    display: flex;
    flex-direction: column;
    gap: 0;
    background: #ffffff;
    border-left: 1px solid var(--esf-border);
    padding: 20px 16px 30px 16px;
}

.esf-sl-contact-card {
    background: var(--esf-white); border: 1px solid var(--esf-border);
    border-radius: var(--esf-radius); padding: 20px;
    box-shadow: var(--esf-shadow); overflow: hidden; position: relative;
    margin-bottom: 14px;
}
.esf-sl-contact-card::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(90deg, var(--esf-orange), var(--esf-gold));
}
.esf-sl-contact-title {
    font-family: 'Cormorant Garamond', Georgia, serif; font-size: 17px; font-weight: 700;
    color: var(--esf-navy); margin-bottom: 16px; padding-top: 4px;
}
.esf-sl-contact-phone {
    display: flex; align-items: center; gap: 10px;
    background: #FFF5EE; border: 1.5px solid rgba(232,101,26,.35); border-radius: 9px;
    padding: 13px 16px; font-size: 15px; font-weight: 700; color: var(--esf-orange);
    text-decoration: none; margin-bottom: 9px; transition: background .15s, color .15s;
}
.esf-sl-contact-phone:hover { background: var(--esf-orange); color: white; border-color: var(--esf-orange); }
.esf-sl-contact-wa {
    display: flex; align-items: center; gap: 10px; background: #25D366;
    border-radius: 9px; padding: 13px 16px; font-size: 14px; font-weight: 700;
    color: white; text-decoration: none; transition: filter .15s;
}
.esf-sl-contact-wa:hover { filter: brightness(1.08); }
.esf-sl-ilan-no { font-size: 11px; color: #C5BDB5; text-align: center; margin-top: 12px; }

.esf-sl-share-card {
    background: var(--esf-white); border: 1px solid var(--esf-border);
    border-radius: var(--esf-radius); padding: 20px; box-shadow: var(--esf-shadow);
}
.esf-sl-share-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 7px; margin-bottom: 9px; }
.esf-sl-share-big {
    display: flex; align-items: center; justify-content: center; gap: 6px;
    padding: 10px 6px; border-radius: 7px; font-size: 12px; font-weight: 700;
    color: white; text-decoration: none; transition: filter .15s, transform .1s;
}
.esf-sl-share-big:hover { filter: brightness(1.1); transform: translateY(-1px); }
.esf-share-bg-fb { background: #1877F2; }
.esf-share-bg-wa { background: #25D366; }
.esf-share-bg-tw { background: #111; }
.esf-share-bg-ig { background: linear-gradient(135deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888); }
.esf-sl-copy-btn {
    width: 100%; padding: 10px; border: 1.5px solid var(--esf-border); border-radius: 7px;
    background: var(--esf-white); color: #6B6460; font-size: 12.5px; font-weight: 600; cursor: pointer;
    display: flex; align-items: center; justify-content: center; gap: 6px;
    transition: border-color .15s, color .15s; font-family: 'DM Sans', sans-serif;
}
.esf-sl-copy-btn:hover { border-color: var(--esf-orange); color: var(--esf-orange); }
.esf-sl-copy-btn.copied { border-color: #22C55E; color: #16a34a; }

/* Lightbox kaldırıldı — native Fullscreen API kullanılıyor */




/* ── Entry Animations ── */
@keyframes esf-fade-up {
    from { opacity: 0; transform: translateY(14px); }
    to   { opacity: 1; transform: translateY(0); }
}
.esf-sl-gallery   { animation: esf-fade-up .35s ease both; }
.esf-sl-header    { animation: esf-fade-up .35s .06s ease both; }
.esf-sl-stats-bar { animation: esf-fade-up .35s .1s ease both; }
.esf-sl-section   { animation: esf-fade-up .35s .14s ease both; }
.esf-sl-sidebar   { animation: esf-fade-up .35s .18s ease both; }

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 1100px) {
    .esf-sl-layout { grid-template-columns: minmax(0, 1fr) 300px; }
}

@media (max-width: 860px) {
    .esf-sl-layout { grid-template-columns: 1fr; }
    .esf-sl-sidebar {
        position: sticky;
        top: 20px;
        align-self: start;
        border-left: none; border-top: 1px solid var(--esf-border);
        display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
        padding: 20px; background: #ffffff;
    }
    .esf-sl-contact-card, .esf-sl-share-card { margin-bottom: 0; }
}

@media (max-width: 600px) {
    .esf-sl-main { padding: 14px 12px 40px; }
    .esf-sl-sidebar { grid-template-columns: 1fr; padding: 14px 12px 30px; }
    .esf-sl-header { padding: 16px 18px; }
    .esf-sl-section { padding: 16px 18px; }
    .esf-sl-title { font-size: 21px; }
    .esf-sl-price { font-size: 23px; }
    .esf-sl-stats-bar { flex-wrap: nowrap; overflow-x: auto; }
    .esf-sl-stat { min-width: 72px; }
    .esf-sl-similar-grid { gap: 8px; }
    .esf-sl-share-inline { display: none; }
}

@media (max-width: 400px) {
    .esf-sl-main { padding: 10px 8px 32px; }
    .esf-sl-title { font-size: 19px; }
    .esf-sl-price { font-size: 20px; }
    .esf-sl-similar-grid { grid-template-columns: 1fr; }
}
