:root{--red:#E11D48;--red-hover:#BE123C;--red-soft:#FFF1F2;--text:#0f172a;--muted:#64748b;--bg:#f8fafc;--border:#e5e7eb}*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,sans-serif;background:var(--bg);color:var(--text)}a{text-decoration:none;color:inherit}.wrap{width:min(1180px,calc(100% - 24px));margin:auto}.site-header{position:sticky;top:0;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);z-index:10}.nav{height:66px;display:flex;align-items:center;justify-content:space-between}.logo{font-weight:900;font-size:19px}.top-nav{display:flex;align-items:center;gap:18px;font-weight:800;font-size:14px}.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:12px 18px;border:0;font-weight:900;cursor:pointer}.btn-primary{background:var(--red);color:#fff}.btn-primary:hover{background:var(--red-hover)}.btn-ghost{background:#fff;border:1px solid var(--border)}.hero{padding:58px 0 36px;display:grid;grid-template-columns:1.08fr .92fr;gap:38px;align-items:center}h1{font-family:'Plus Jakarta Sans',Inter,sans-serif;font-size:clamp(38px,6vw,64px);line-height:1.05;margin:0;letter-spacing:-1.6px}h1 span{color:var(--red)}.lead{font-size:18px;line-height:1.6;color:var(--muted);max-width:640px}.search-box{margin-top:24px;background:#fff;border:1px solid var(--border);border-radius:22px;padding:10px;display:grid;grid-template-columns:1fr 160px auto;gap:10px;box-shadow:0 14px 36px rgba(15,23,42,.06)}input,select,textarea{font:inherit}.field{border:0;background:#f8fafc;border-radius:16px;padding:14px 16px;outline:none;width:100%}.hero-actions{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}.trust{display:flex;gap:10px;margin-top:15px;flex-wrap:wrap}.trust span{background:#fff;border:1px solid var(--border);padding:8px 12px;border-radius:999px;font-size:13px;font-weight:800;color:#334155}.game-card{background:linear-gradient(135deg,var(--red-soft),#ffe4e6);border-radius:30px;padding:28px;box-shadow:0 18px 46px rgba(225,29,72,.12)}.game-card h2{font-size:42px;margin:4px 0}.label{text-transform:uppercase;font-size:13px;font-weight:900;color:#9f1239;letter-spacing:.7px}.progress{height:10px;background:#fee2e2;border-radius:999px;margin:15px 0}.progress span{display:block;height:100%;width:76%;background:var(--red);border-radius:999px;animation:grow 1.4s ease}@keyframes grow{from{width:0}}.live{background:#fff;border-radius:18px;padding:14px;margin-top:16px;display:grid;gap:8px;font-size:14px;color:#475569}.section{padding:28px 0}.section-head{display:flex;align-items:end;justify-content:space-between;gap:16px;margin-bottom:16px}.section h2{font-family:'Plus Jakarta Sans';font-size:30px;margin:0}.muted{color:var(--muted)}.category-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.category-card{background:#fff;border:1px solid var(--border);border-radius:24px;padding:14px;box-shadow:0 10px 28px rgba(15,23,42,.05);transition:.2s}.category-card:hover{transform:translateY(-3px);box-shadow:0 16px 38px rgba(15,23,42,.08);border-color:#fecdd3}.category-main{display:flex;align-items:center;gap:12px}.category-icon{width:42px;height:42px;border-radius:16px;background:var(--red-soft);display:flex;align-items:center;justify-content:center;font-size:22px;flex:0 0 auto}.category-main strong{display:block;font-size:16px;font-weight:900}.category-main small{display:block;margin-top:3px;color:var(--muted);font-size:12px;font-weight:800}.category-sublist{display:flex;flex-wrap:wrap;gap:7px;margin-top:14px}.category-sublist a{background:#f8fafc;border:1px solid #eef2f7;border-radius:999px;padding:7px 10px;font-size:12px;font-weight:800;color:#334155}.category-sublist a:hover{background:var(--red-soft);border-color:#fecdd3;color:var(--red)}.category-sublist .category-more{background:#fff;color:var(--red);border-color:#fecdd3}.listings{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.listing{background:#fff;border:1px solid var(--border);border-radius:24px;overflow:hidden;box-shadow:0 10px 28px rgba(15,23,42,.05)}.listing-photo{position:relative;height:180px;background:#e2e8f0;display:flex;align-items:center;justify-content:center;color:#64748b;font-weight:900}.listing-body{padding:16px}.listing-title{font-weight:900;font-size:18px}.price{color:var(--red);font-size:24px;font-weight:900;margin-top:4px}.meta{display:flex;justify-content:space-between;margin-top:10px;color:var(--muted);font-size:14px}.form-card{margin:34px auto;max-width:760px;background:#fff;border:1px solid var(--border);border-radius:28px;padding:24px;box-shadow:0 14px 36px rgba(15,23,42,.06)}.form-grid{display:grid;gap:14px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}label strong{display:block;margin-bottom:7px}.alert{padding:14px 16px;border-radius:16px;margin-bottom:16px;font-weight:800}.alert-error{background:#fff1f2;color:#9f1239;border:1px solid #fecdd3}.alert-success{background:#ecfdf5;color:#166534;border:1px solid #bbf7d0}.footer{text-align:center;padding:34px;color:var(--muted)}.sticky-add{display:none;position:fixed;left:14px;right:14px;bottom:14px;z-index:20}.sticky-add a{display:block;text-align:center;background:var(--red);color:#fff;border-radius:999px;padding:16px;font-weight:900;box-shadow:0 10px 30px rgba(225,29,72,.25)}@media(max-width:900px){.hero{grid-template-columns:1fr}.search-box{grid-template-columns:1fr}.category-grid{grid-template-columns:repeat(2,1fr)}.listings{grid-template-columns:repeat(2,1fr)}}@media(max-width:620px){.top-nav a:not(.btn){display:none}.category-grid,.listings{grid-template-columns:1fr}.category-card{padding:16px}.category-sublist{display:grid;grid-template-columns:1fr 1fr}.form-row{grid-template-columns:1fr}.hero{padding-top:34px}.lead{font-size:16px}.sticky-add{display:block}.footer{padding-bottom:90px}}@media(max-width:440px){.listings{grid-template-columns:1fr}.category-sublist{grid-template-columns:1fr}.game-card{padding:22px}}

/* Detail inzerátu */
.breadcrumb{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin:26px 0 14px;color:var(--muted);font-size:14px;font-weight:800}.breadcrumb a{color:#334155}.breadcrumb a:hover{color:var(--red)}.breadcrumb strong{color:var(--text)}
.detail-layout{display:grid;grid-template-columns:minmax(0,1fr)360px;gap:22px;align-items:start;margin-bottom:26px}.detail-main{display:grid;gap:18px}.detail-photo{height:430px;background:linear-gradient(135deg,#e2e8f0,#f8fafc);border:1px solid var(--border);border-radius:30px;display:flex;align-items:center;justify-content:center;color:#64748b;font-weight:900;box-shadow:0 14px 36px rgba(15,23,42,.05)}.detail-card,.seller-card{background:#fff;border:1px solid var(--border);border-radius:28px;padding:24px;box-shadow:0 14px 36px rgba(15,23,42,.06)}.detail-header{display:flex;align-items:flex-start;justify-content:space-between;gap:20px}.detail-category{display:inline-flex;align-items:center;gap:7px;border:1px solid #fecdd3;background:var(--red-soft);color:#9f1239;border-radius:999px;padding:8px 12px;font-size:13px;font-weight:900;margin-bottom:12px}.detail-card h1{font-size:clamp(30px,4vw,46px);letter-spacing:-1.2px;margin:0}.detail-price{font-size:34px;font-weight:900;color:var(--red);white-space:nowrap}.detail-meta{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px;color:var(--muted);font-size:14px;font-weight:800}.soft-line{border:0;border-top:1px solid var(--border);margin:22px 0}.detail-card h2{font-family:'Plus Jakarta Sans',Inter,sans-serif;font-size:24px;margin:0 0 12px}.detail-description{line-height:1.75;color:#334155}.seller-card{position:sticky;top:88px}.seller-label{text-transform:uppercase;color:#9f1239;letter-spacing:.7px;font-size:12px;font-weight:900}.seller-card h2{font-family:'Plus Jakarta Sans',Inter,sans-serif;margin:6px 0 8px;font-size:28px}.verified{display:inline-flex;background:#ecfdf5;color:#166534;border:1px solid #bbf7d0;border-radius:999px;padding:7px 10px;font-size:13px;font-weight:900;margin-bottom:14px}.muted-verified{background:#f8fafc;color:#64748b;border-color:#e5e7eb}.contact-button{display:flex;align-items:center;justify-content:center;width:100%;border-radius:18px;padding:14px 16px;background:var(--red);color:#fff;font-weight:900;margin-top:10px}.contact-button.secondary{background:#fff;color:var(--text);border:1px solid var(--border)}.safe-box{margin-top:16px;background:#f8fafc;border:1px solid var(--border);border-radius:20px;padding:14px;color:#475569;font-size:14px;line-height:1.55}.safe-box strong{display:block;color:var(--text);margin-bottom:4px}.safe-box p{margin:0}.listing{display:block;transition:.2s}.listing:hover{transform:translateY(-3px);box-shadow:0 16px 38px rgba(15,23,42,.08);border-color:#fecdd3}.listing-link{margin-top:12px;color:var(--red);font-size:13px;font-weight:900}
@media(max-width:900px){.detail-layout{grid-template-columns:1fr}.seller-card{position:static}.detail-photo{height:320px}.detail-header{display:block}.detail-price{margin-top:14px}}
@media(max-width:620px){.breadcrumb{margin-top:18px}.detail-card,.seller-card{padding:18px;border-radius:24px}.detail-photo{height:240px;border-radius:24px}.detail-meta{display:grid;gap:8px}.detail-price{font-size:30px}.contact-button{padding:15px 14px}}


/* Oprava karet inzerátů na hlavní stránce */
.listings {
    align-items: stretch;
}

.listing {
    display: flex;
    flex-direction: column;
    min-width: 0;
    height: 100%;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 10px 28px rgba(15,23,42,.05);
    transition: .2s;
}

.listing:hover {
    transform: translateY(-3px);
    box-shadow: 0 16px 38px rgba(15,23,42,.08);
    border-color: #fecdd3;
}

.listing-photo {
    position: relative;
    width: 100%;
    aspect-ratio: 4 / 3;
    height: auto;
    min-height: 0;
    overflow: hidden;
    background: linear-gradient(135deg,#e2e8f0,#f8fafc);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #64748b;
    font-weight: 900;
    flex: 0 0 auto;
}

.listing-photo img {
    display: block;
    width: 100%;
    height: 100%;
    max-width: 100%;
    object-fit: cover;
    object-position: center;
}

.listing-body {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-width: 0;
    padding: 16px;
}

.listing-title {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: 44px;
    font-weight: 900;
    font-size: 18px;
    line-height: 1.22;
}

.price {
    color: var(--red);
    font-size: 24px;
    font-weight: 900;
    margin-top: 8px;
    line-height: 1.15;
}

.meta {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    margin-top: 12px;
    color: var(--muted);
    font-size: 14px;
}

.meta span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.listing-link {
    margin-top: auto;
    padding-top: 12px;
    color: var(--red);
    font-size: 13px;
    font-weight: 900;
}

.detail-photo {
    overflow: hidden;
}

.detail-photo img {
    display: block;
    width: 100%;
    height: 100%;
    max-width: 100%;
    object-fit: contain;
    object-position: center;
}

.detail-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

@media(max-width:900px) {
    .listing-photo {
        aspect-ratio: 16 / 11;
    }
}

@media(max-width:620px) {
    .listing-photo {
        aspect-ratio: 16 / 10;
    }

    .listing-body {
        padding: 15px;
    }

    .listing-title {
        min-height: auto;
    }
}

/* Decentní sdílení v detailu inzerátu */
.share-mini {
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid var(--border);
}

.share-mini-label {
    color: var(--muted);
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .6px;
    margin-bottom: 9px;
}

.share-mini-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.share-mini-btn {
    appearance: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0 11px;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: #fff;
    color: #334155;
    font: inherit;
    font-size: 12px;
    font-weight: 900;
    cursor: pointer;
    transition: .18s;
}

.share-mini-btn:hover {
    border-color: #fecdd3;
    background: var(--red-soft);
    color: var(--red);
}

.share-mini-note {
    min-height: 18px;
    margin-top: 8px;
    color: #166534;
    font-size: 12px;
    font-weight: 800;
}

@media(max-width:620px) {
    .share-mini-actions {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr;
    }

    .share-mini-btn {
        padding: 0 8px;
    }
}

.detail-thumbs {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
    gap: 10px;
    margin-top: 12px;
}

.detail-thumb {
    border-radius: 12px;
    overflow: hidden;
    border: 2px solid transparent;
    cursor: pointer;
    transition: .2s;
}

.detail-thumb.active {
    border-color: var(--red);
}

.detail-thumb img {
    width: 100%;
    height: 80px;
    object-fit: cover;
    display: block;
}
/* === DETAIL INZERÁTU – PRO UPGRADE === */
.detail-photo {
    aspect-ratio: 16 / 10;
    height: auto;
    max-height: 520px;
}

.detail-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover !important;
}

.detail-info-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 10px;
    margin: 18px 0 4px;
}

.detail-info-box {
    background: #f8fafc;
    border: 1px solid var(--border);
    border-radius: 18px;
    padding: 12px;
}

.detail-info-box small {
    display: block;
    color: var(--muted);
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
    margin-bottom: 4px;
}

.detail-info-box strong {
    display: block;
    font-size: 14px;
    font-weight: 950;
}

.seller-trust {
    display: grid;
    gap: 8px;
    margin: 14px 0;
}

.seller-trust span {
    background: #f8fafc;
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 10px 12px;
    font-size: 13px;
    font-weight: 850;
    color: #334155;
}

.detail-mobile-actions {
    display: none;
}

.similar-section {
    margin-top: 28px;
}

.similar-section h2 {
    font-family: 'Plus Jakarta Sans', Inter, sans-serif;
    font-size: 28px;
    margin: 0 0 14px;
}

@media (max-width: 900px) {
    .detail-info-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .detail-photo {
        max-height: none;
    }
}

@media (max-width: 620px) {
    .detail-info-grid {
        grid-template-columns: 1fr;
    }

    .detail-mobile-actions {
        position: fixed;
        left: 10px;
        right: 10px;
        bottom: 10px;
        z-index: 50;
        display: grid;
        grid-template-columns: 1fr 1fr 48px;
        gap: 8px;
        padding: 8px;
        background: rgba(255,255,255,.94);
        border: 1px solid var(--border);
        border-radius: 22px;
        box-shadow: 0 18px 45px rgba(15,23,42,.22);
        backdrop-filter: blur(14px);
    }

    .detail-mobile-actions a,
    .detail-mobile-actions button {
        min-height: 46px;
        border-radius: 16px;
        font-size: 13px;
    }

    body {
        padding-bottom: 78px;
    }
}

.logo {
  font-family: 'Plus Jakarta Sans', Inter, sans-serif;
  font-weight: 900;
  font-size: 22px;
  letter-spacing: -0.8px;
  display: inline-flex;
  align-items: baseline;
  line-height: 1;
}

.logo-red {
  color: var(--red);
}

.logo-black {
  color: #111827;
  margin-left: 1px;
  font-weight: 800;
}

.logo:hover .logo-red {
  color: var(--red-hover);
}

/* =========================================================
   FIX: MAPA + OBLÍBENÉ + ZPRÁVY + DETAIL POLISH
   ========================================================= */
.fav-nav-link{display:inline-flex;align-items:center;gap:5px}.fav-nav-link [data-fav-count]:not(:empty){display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:var(--red);color:#fff;font-size:11px;font-weight:950}
.listing-card{position:relative;min-width:0;height:100%;display:flex}.listing-card>.listing{width:100%;height:100%}.favorite-btn{position:absolute;top:10px;right:10px;z-index:4;display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 11px;border:1px solid rgba(255,255,255,.65);border-radius:999px;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);color:#0f172a;font:inherit;font-size:22px;font-weight:950;line-height:1;box-shadow:0 10px 24px rgba(15,23,42,.14);cursor:pointer;transition:.18s}.favorite-btn:hover{transform:translateY(-1px);background:#fff;color:var(--red)}.favorite-btn.is-active{background:var(--red);border-color:var(--red);color:#fff}.favorite-detail{position:static;min-height:38px;height:38px;padding:0 13px;border-radius:999px;font-size:12px;gap:6px}
.market-map-card{margin:0 0 18px;background:#fff;border:1px solid var(--border);border-radius:28px;box-shadow:0 14px 36px rgba(15,23,42,.06);overflow:hidden}.market-map-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border)}.market-map-head strong,.market-map-head span{display:block}.market-map-head strong{font-size:17px;font-weight:950}.market-map-head span{margin-top:2px;color:var(--muted);font-size:13px;font-weight:800}.market-map{height:430px;width:100%;background:#e2e8f0}.map-popup{display:grid;grid-template-columns:72px minmax(0,1fr);gap:10px;min-width:220px;max-width:280px}.map-popup img,.map-popup-img{width:72px;height:72px;object-fit:cover;border-radius:12px;background:#f1f5f9}.map-popup strong{display:block;color:#0f172a;font-size:14px;line-height:1.25}.map-popup .map-price{margin-top:4px;color:var(--red);font-weight:950}.map-popup .map-city{margin-top:3px;color:#64748b;font-size:12px;font-weight:800}.map-popup a{display:inline-flex;margin-top:7px;color:var(--red);font-weight:950;font-size:12px}
.detail-mini-map-card{margin-top:16px;padding:14px;background:#fff;border:1px solid var(--border);border-radius:20px}.detail-mini-map-card strong{display:block;margin-bottom:10px}.detail-mini-map{height:190px;border-radius:16px;overflow:hidden;background:#e2e8f0}
.favorites-page h1{font-size:clamp(34px,5vw,52px);letter-spacing:-1.3px}.favorites-empty{grid-column:1/-1;display:grid;place-items:center;text-align:center;gap:10px;min-height:260px;padding:28px;background:#fff;border:1px dashed #cbd5e1;border-radius:28px;color:var(--muted)}.favorites-empty strong{color:var(--text);font-size:23px}.favorites-empty p{margin:0}.favorites-empty[hidden],[data-favorite-listing][hidden]{display:none!important}

/* Detail clean */
.detail-photo{aspect-ratio:16/10;height:auto!important;max-height:520px;overflow:hidden;background:#fff}.detail-photo img{display:block;width:100%;height:100%;max-width:none;object-fit:cover!important;object-position:center}.detail-card{padding:26px}.detail-card h1{line-height:1.08}.detail-actions{display:grid;justify-items:end;gap:9px;min-width:150px}.detail-price{line-height:1;font-size:clamp(30px,3.5vw,38px)}.detail-info-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin:16px 0 2px}.detail-info-box{min-width:0;padding:11px 12px;border-radius:16px;background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid #e2e8f0}.detail-info-box small{display:block;color:#64748b;font-size:10px;font-weight:950;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.detail-info-box strong{display:block;color:var(--text);font-size:13px;font-weight:950;line-height:1.25;overflow:hidden;text-overflow:ellipsis}
.seller-card{padding:26px}.seller-card h2{line-height:1.1;margin:0 0 10px}.seller-trust{display:grid;gap:11px;margin:16px 0 18px}.seller-trust span{display:grid;grid-template-columns:22px minmax(0,1fr);gap:9px;align-items:start;padding:0;background:transparent;border:0;border-radius:0;color:#334155;font-size:14px;font-weight:750;line-height:1.35}.seller-trust span b{display:inline-flex;align-items:center;justify-content:center;width:22px;line-height:1.2;font-weight:900}.seller-trust span strong{display:block;color:var(--text);font-size:13px;font-weight:950;line-height:1.2}.seller-trust span small{display:block;margin-top:2px;color:var(--muted);font-size:13px;font-weight:800;line-height:1.25}.contact-button{min-height:54px;border-radius:18px;font-size:15px;box-shadow:0 12px 24px rgba(225,29,72,.18)}.contact-button.secondary{box-shadow:none;background:#fff}.safe-box{margin-top:18px;background:#f8fafc;border-color:#e2e8f0;border-radius:18px;padding:15px}

/* Zprávy */
.message-page,.conversation-page{padding-bottom:42px}.message-layout,.conversation-layout{display:grid;grid-template-columns:minmax(0,1fr)340px;gap:22px;align-items:start;margin:20px 0 34px}.message-card,.conversation-card,.message-side-card{background:#fff;border:1px solid var(--border);border-radius:28px;box-shadow:0 14px 36px rgba(15,23,42,.06)}.message-card,.conversation-card{padding:24px}.message-card-head{margin-bottom:18px}.message-card-head h1,.conversation-head h1{font-family:'Plus Jakarta Sans',Inter,sans-serif;font-size:clamp(32px,4vw,46px);line-height:1.05;letter-spacing:-1.2px;margin:10px 0 8px}.message-form{display:grid;gap:14px}.message-form textarea.field,.reply-form textarea.field{min-height:150px;resize:vertical;border:1px solid #eef2f7}.hp-field{position:absolute;left:-9999px;opacity:0}.quick-replies{display:flex;flex-wrap:wrap;gap:8px}.quick-replies button{appearance:none;border:1px solid #fecdd3;background:var(--red-soft);color:#9f1239;border-radius:999px;padding:9px 12px;font:inherit;font-size:12px;font-weight:950;cursor:pointer}.message-submit{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.message-side-card{position:sticky;top:88px;padding:20px}.message-side-card h2{font-family:'Plus Jakarta Sans',Inter,sans-serif;font-size:24px;line-height:1.1;margin:8px 0}.message-side-meta{display:grid;gap:8px;margin:14px 0;color:#334155;font-size:14px;font-weight:850}.conversation-listing-img{display:block;width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:18px;margin-bottom:14px;background:#f1f5f9}.conversation-head{display:flex;justify-content:space-between;gap:16px;padding-bottom:18px;border-bottom:1px solid var(--border)}.chat-thread{display:grid;gap:12px;padding:20px 0}.chat-message{display:flex}.chat-message.is-mine{justify-content:flex-end}.chat-bubble{max-width:min(680px,86%);padding:13px 14px;border-radius:20px;background:#f8fafc;border:1px solid var(--border)}.chat-message.is-mine .chat-bubble{background:var(--red);color:#fff;border-color:var(--red)}.chat-meta{display:flex;gap:10px;align-items:baseline;justify-content:space-between;margin-bottom:7px;font-size:12px}.chat-meta strong{font-weight:950}.chat-meta span{color:var(--muted);font-weight:800}.chat-message.is-mine .chat-meta span{color:rgba(255,255,255,.76)}.chat-body{line-height:1.6;font-size:15px}.reply-form{display:grid;gap:12px;padding-top:16px;border-top:1px solid var(--border)}

@media(max-width:900px){.market-map{height:360px}.detail-actions{justify-items:start;margin-top:16px}.detail-info-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.message-layout,.conversation-layout{grid-template-columns:1fr}.message-side-card{position:static}.favorite-btn:hover{transform:none}}
@media(max-width:620px){.market-map-card{border-radius:22px;margin-left:-2px;margin-right:-2px}.market-map-head{align-items:flex-start;flex-direction:column}.market-map-head .mini-btn{width:100%}.market-map{height:320px}.favorite-btn{top:8px;right:8px;min-width:38px;height:38px;font-size:20px}.favorite-detail{width:100%;height:48px}.detail-mini-map{height:170px}.map-popup{grid-template-columns:58px minmax(0,1fr);min-width:190px}.map-popup img,.map-popup-img{width:58px;height:58px}.detail-card,.seller-card,.message-card,.conversation-card,.message-side-card{padding:20px;border-radius:24px}.detail-photo{aspect-ratio:4/3;border-radius:24px}.detail-card h1{font-size:clamp(28px,9vw,38px)}.detail-price{font-size:30px}.detail-info-grid{grid-template-columns:1fr 1fr}.seller-trust span{font-size:13px}.message-submit{display:grid}.message-submit .btn{width:100%}.chat-bubble{max-width:94%}.quick-replies{display:grid;grid-template-columns:1fr}}
@media(max-width:420px){.detail-info-grid{grid-template-columns:1fr}}


/* Klikací zvětšení fotky v detailu */
.detail-photo.is-zoomable {
    position: relative;
}

.photo-open-btn {
    appearance: none;
    width: 100%;
    height: 100%;
    padding: 0;
    border: 0;
    background: transparent;
    cursor: zoom-in;
    display: block;
    position: relative;
}

.photo-open-btn img {
    pointer-events: none;
}

.photo-zoom-hint {
    position: absolute;
    right: 14px;
    bottom: 14px;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: 0 13px;
    border-radius: 999px;
    background: rgba(15,23,42,.76);
    color: #fff;
    font-size: 13px;
    font-weight: 950;
    box-shadow: 0 12px 28px rgba(15,23,42,.22);
    backdrop-filter: blur(10px);
}

.photo-lightbox {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 22px;
}

.photo-lightbox.is-open {
    display: flex;
}

.photo-lightbox-backdrop {
    position: absolute;
    inset: 0;
    border: 0;
    background: rgba(2,6,23,.88);
    cursor: zoom-out;
}

.photo-lightbox-inner {
    position: relative;
    z-index: 2;
    width: min(1180px, 100%);
    height: min(82vh, 760px);
    display: flex;
    align-items: center;
    justify-content: center;
}

.photo-lightbox-inner img {
    display: block;
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 24px 70px rgba(0,0,0,.45);
}

.photo-lightbox-close {
    position: fixed;
    top: 14px;
    right: 14px;
    z-index: 3;
    width: 46px;
    height: 46px;
    border: 1px solid rgba(255,255,255,.22);
    border-radius: 999px;
    background: rgba(255,255,255,.12);
    color: #fff;
    font-size: 34px;
    line-height: 1;
    cursor: pointer;
    backdrop-filter: blur(10px);
}

body.lightbox-open {
    overflow: hidden;
}

@media(max-width:620px) {
    .photo-zoom-hint {
        left: 12px;
        right: 12px;
        bottom: 12px;
        min-height: 42px;
        font-size: 13px;
    }

    .photo-lightbox {
        padding: 10px;
    }

    .photo-lightbox-inner {
        width: 100%;
        height: 86vh;
    }

    .photo-lightbox-inner img {
        border-radius: 14px;
    }

    .photo-lightbox-close {
        top: 10px;
        right: 10px;
        width: 44px;
        height: 44px;
    }
}

/* =========================================================
   FIX: Filtry na hlavní stránce / výsledky inzerátů
   ========================================================= */
.marketplace-results {
    scroll-margin-top: 86px;
}

.results-head {
    align-items: center;
}

.filters-wrap {
    margin: 0 0 18px;
    padding: 16px;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 28px;
    box-shadow: 0 14px 36px rgba(15,23,42,.06);
}

.filters-grid {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: 12px;
    align-items: end;
}

.filter-field {
    display: grid;
    gap: 7px;
    grid-column: span 2;
    min-width: 0;
}

.filter-field strong {
    display: block;
    color: #334155;
    font-size: 12px;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: .45px;
}

.filter-field .field {
    min-height: 48px;
    border: 1px solid #eef2f7;
    background: #f8fafc;
}

.filter-field .field:focus {
    border-color: #fecdd3;
    background: #fff;
    box-shadow: 0 0 0 4px rgba(225,29,72,.08);
}

.filter-xl {
    grid-column: span 3;
}

.filter-lg {
    grid-column: span 2;
}

.filter-buttons {
    grid-column: span 3;
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: end;
}

.filter-buttons .btn {
    min-height: 48px;
    padding: 0 15px;
    white-space: nowrap;
}

.active-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: -4px 0 18px;
}

.active-filters a,
.radius-note,
.distance-badge,
.mini-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-weight: 900;
}

.active-filters a {
    min-height: 34px;
    padding: 0 12px;
    background: var(--red-soft);
    border: 1px solid #fecdd3;
    color: #9f1239;
    font-size: 12px;
}

.radius-note {
    justify-content: flex-start;
    width: 100%;
    margin: 0 0 14px;
    padding: 12px 14px;
    border: 1px solid #fde68a;
    background: #fffbeb;
    color: #92400e;
    font-size: 13px;
    line-height: 1.45;
}

.empty-results {
    grid-column: 1 / -1;
    display: grid;
    place-items: center;
    text-align: center;
    gap: 10px;
    min-height: 240px;
    padding: 28px;
    background: #fff;
    border: 1px dashed #cbd5e1;
    border-radius: 28px;
    color: var(--muted);
}

.empty-results strong {
    color: var(--text);
    font-size: 24px;
}

.empty-results p {
    margin: 0;
}

.distance-badge {
    justify-content: flex-start;
    width: fit-content;
    margin-top: 10px;
    padding: 7px 10px;
    background: #ecfdf5;
    border: 1px solid #bbf7d0;
    color: #166534;
    font-size: 12px;
}

.mini-btn {
    min-height: 38px;
    padding: 0 13px;
    border: 1px solid var(--border);
    background: #fff;
    color: #334155;
    font: inherit;
    font-size: 12px;
    cursor: pointer;
}

.mini-btn:hover {
    border-color: #fecdd3;
    background: var(--red-soft);
    color: var(--red);
}

@media(max-width:1100px) {
    .filters-grid {
        grid-template-columns: repeat(6, minmax(0, 1fr));
    }

    .filter-xl,
    .filter-lg,
    .filter-field {
        grid-column: span 2;
    }

    .filter-buttons {
        grid-column: 1 / -1;
        justify-content: flex-start;
    }
}

@media(max-width:700px) {
    .results-head {
        display: grid;
        align-items: start;
    }

    .results-head .btn {
        width: 100%;
    }

    .filters-wrap {
        padding: 12px;
        border-radius: 24px;
    }

    .filters-grid {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .filter-xl,
    .filter-lg,
    .filter-field,
    .filter-buttons {
        grid-column: 1 / -1;
    }

    .filter-buttons {
        display: grid;
        grid-template-columns: 1fr;
    }

    .filter-buttons .btn {
        width: 100%;
    }
}

/* =========================================================
   PŘIDAT INZERÁT – FORMULÁŘ + UPLOAD FOTEK
   ========================================================= */

.add-listing-page {
    padding-bottom: 42px;
}

.marketplace-add-hero {
    margin: 28px 0 20px;
    padding: 30px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 22px;
    align-items: center;
    background: linear-gradient(135deg, #fff, var(--red-soft));
    border: 1px solid #fecdd3;
    border-radius: 32px;
    box-shadow: 0 14px 36px rgba(15,23,42,.06);
}

.eyebrow {
    display: inline-flex;
    margin-bottom: 10px;
    color: #9f1239;
    font-size: 13px;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: .7px;
}

.marketplace-add-hero h1 {
    font-size: clamp(34px, 5vw, 54px);
    margin: 0;
}

.marketplace-add-hero p {
    max-width: 700px;
    margin: 14px 0 0;
    color: var(--muted);
    font-size: 17px;
    line-height: 1.6;
}

.hero-checklist {
    display: grid;
    gap: 10px;
}

.hero-checklist span {
    display: flex;
    align-items: center;
    min-height: 48px;
    padding: 12px 14px;
    background: #fff;
    border: 1px solid #fecdd3;
    border-radius: 18px;
    color: #334155;
    font-size: 14px;
    font-weight: 900;
    box-shadow: 0 10px 22px rgba(15,23,42,.05);
}

.marketplace-form-card {
    max-width: 980px;
    padding: 0;
    overflow: hidden;
}

.marketplace-form-head {
    padding: 24px 26px 20px;
    border-bottom: 1px solid var(--border);
    background: #fff;
}

.marketplace-form-head h2 {
    font-family: 'Plus Jakarta Sans', Inter, sans-serif;
    font-size: 32px;
    margin: 8px 0 6px;
}

.step-pill {
    display: inline-flex;
    min-height: 32px;
    align-items: center;
    padding: 0 12px;
    border-radius: 999px;
    background: var(--red-soft);
    border: 1px solid #fecdd3;
    color: #9f1239;
    font-size: 12px;
    font-weight: 950;
}

.marketplace-form {
    padding: 22px;
    gap: 18px;
}

.form-panel {
    display: grid;
    gap: 16px;
    padding: 20px;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 24px;
}

.panel-title {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--border);
}

.panel-title > span {
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    flex: 0 0 auto;
    background: var(--red-soft);
    border-radius: 16px;
    font-size: 21px;
}

.panel-title strong {
    display: block;
    font-size: 17px;
    font-weight: 950;
}

.panel-title small {
    display: block;
    margin-top: 3px;
    color: var(--muted);
    font-size: 13px;
    font-weight: 750;
}

.marketplace-form label {
    display: grid;
    gap: 7px;
}

.marketplace-form label strong {
    color: #334155;
    font-size: 13px;
    font-weight: 950;
}

.marketplace-form .field {
    min-height: 50px;
    border: 1px solid #eef2f7;
    background: #f8fafc;
}

.marketplace-form textarea.field {
    min-height: 150px;
    resize: vertical;
}

.marketplace-form .field:focus {
    border-color: #fecdd3;
    background: #fff;
    box-shadow: 0 0 0 4px rgba(225,29,72,.08);
}

.geo-helper {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 14px;
    border-radius: 18px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
}

.geo-helper strong {
    display: block;
    font-size: 14px;
    font-weight: 950;
}

.geo-helper span {
    display: block;
    margin-top: 3px;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.45;
}

.photo-panel {
    background: linear-gradient(180deg, #fff, #fff7f8);
}

.pro-upload-block {
    display: grid;
    gap: 14px;
}

.pro-dropzone {
    position: relative;
    display: grid !important;
    place-items: center;
    text-align: center;
    gap: 7px;
    min-height: 210px;
    padding: 24px;
    border: 2px dashed #fecdd3;
    border-radius: 24px;
    background: #fff;
    cursor: pointer;
    transition: .18s;
}

.pro-dropzone:hover,
.pro-dropzone.is-dragover {
    border-color: var(--red);
    background: var(--red-soft);
}

.pro-dropzone input {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
}

.upload-icon {
    font-size: 42px;
    line-height: 1;
}

.upload-title {
    display: block;
    font-size: 20px;
    font-weight: 950;
}

.upload-subtitle {
    display: block;
    color: #334155;
    font-size: 14px;
    font-weight: 800;
}

.upload-limit {
    display: inline-flex;
    margin-top: 4px;
    padding: 7px 11px;
    border-radius: 999px;
    background: #f8fafc;
    color: var(--muted);
    font-size: 12px;
    font-weight: 900;
}

.upload-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.upload-toolbar strong {
    font-size: 15px;
    font-weight: 950;
}

.pro-preview {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(135px, 1fr));
    gap: 12px;
    min-height: 120px;
}

.preview-empty {
    grid-column: 1 / -1;
    min-height: 150px;
    display: grid;
    place-items: center;
    text-align: center;
    gap: 5px;
    padding: 20px;
    border: 1px dashed #cbd5e1;
    border-radius: 22px;
    background: #fff;
    color: var(--muted);
}

.preview-empty span {
    font-size: 34px;
}

.preview-empty strong {
    color: var(--text);
    font-size: 17px;
}

.preview-empty small {
    font-size: 13px;
    font-weight: 750;
}

.preview-card {
    position: relative;
    overflow: hidden;
    border-radius: 18px;
    background: #fff;
    border: 1px solid var(--border);
    box-shadow: 0 10px 24px rgba(15,23,42,.06);
    cursor: pointer;
    transition: .18s;
}

.preview-card:hover {
    transform: translateY(-2px);
    border-color: #fecdd3;
    box-shadow: 0 14px 30px rgba(15,23,42,.09);
}

.preview-card.is-main {
    border-color: var(--red);
    box-shadow: 0 14px 32px rgba(225,29,72,.14);
}

.preview-img-wrap {
    position: relative;
    aspect-ratio: 4 / 3;
    background: #f1f5f9;
    overflow: hidden;
}

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

.main-photo-badge,
.photo-number {
    position: absolute;
    left: 8px;
    top: 8px;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 24px;
    padding: 0 8px;
    border-radius: 999px;
    color: #fff;
    font-size: 11px;
    font-weight: 950;
    box-shadow: 0 8px 18px rgba(15,23,42,.22);
}

.main-photo-badge {
    background: var(--red);
}

.photo-number {
    background: rgba(15,23,42,.78);
}

.preview-remove {
    position: absolute;
    right: 8px;
    top: 8px;
    z-index: 4;
    width: 30px;
    height: 30px;
    border: 1px solid rgba(255,255,255,.55);
    border-radius: 999px;
    background: rgba(15,23,42,.76);
    color: #fff;
    font-size: 22px;
    line-height: 1;
    cursor: pointer;
    backdrop-filter: blur(8px);
}

.preview-remove:hover {
    background: var(--red);
}

.preview-meta {
    display: grid;
    gap: 3px;
    padding: 10px;
}

.preview-meta strong {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--text);
    font-size: 12px;
    font-weight: 950;
}

.preview-meta small {
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
}

.submit-panel {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px;
    border-radius: 24px;
    background: #fff;
    border: 1px solid var(--border);
    box-shadow: 0 12px 30px rgba(15,23,42,.05);
}

.submit-panel strong {
    display: block;
    font-size: 17px;
    font-weight: 950;
}

.submit-panel span {
    display: block;
    margin-top: 3px;
    color: var(--muted);
    font-size: 13px;
    font-weight: 800;
}

.form-submit {
    min-height: 52px;
    white-space: nowrap;
}

@media(max-width:900px) {
    .marketplace-add-hero {
        grid-template-columns: 1fr;
    }

    .hero-checklist {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media(max-width:620px) {
    .marketplace-add-hero {
        margin-top: 18px;
        padding: 22px;
        border-radius: 26px;
    }

    .hero-checklist {
        grid-template-columns: 1fr;
    }

    .marketplace-form-head {
        padding: 20px;
    }

    .marketplace-form-head h2 {
        font-size: 28px;
    }

    .marketplace-form {
        padding: 14px;
    }

    .form-panel {
        padding: 16px;
        border-radius: 22px;
    }

    .geo-helper {
        display: grid;
    }

    .geo-helper .mini-btn {
        width: 100%;
    }

    .pro-dropzone {
        min-height: 190px;
        padding: 18px;
    }

    .pro-preview {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .upload-toolbar {
        align-items: stretch;
        flex-direction: column;
    }

    .upload-toolbar .mini-btn {
        width: 100%;
    }

    .submit-panel {
        display: grid;
        padding: 16px;
    }

    .form-submit {
        width: 100%;
    }
}

@media(max-width:420px) {
    .pro-preview {
        grid-template-columns: 1fr;
    }
}

/* =========================================================
   MODERNÍ FILTR INZERÁTŮ
   ========================================================= */

.smart-filter-wrap {
    margin: 0 0 22px;
}

.smart-filter {
    padding: 14px;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 30px;
    box-shadow: 0 18px 46px rgba(15,23,42,.07);
}

.smart-filter-main {
    display: grid;
    grid-template-columns: minmax(260px, 1.4fr) minmax(180px, .9fr) minmax(190px, .9fr) auto;
    gap: 10px;
    align-items: end;
}

.smart-filter label {
    display: grid;
    gap: 7px;
    min-width: 0;
}

.smart-filter label span {
    color: #334155;
    font-size: 12px;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: .45px;
}

.smart-filter .field {
    min-height: 52px;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 18px;
}

.smart-filter .field:focus {
    border-color: #fecdd3;
    box-shadow: 0 0 0 4px rgba(225,29,72,.08);
}

.smart-submit {
    min-height: 52px;
    padding-inline: 28px;
    font-size: 15px;
}

.smart-more {
    margin-top: 10px;
}

.smart-more summary {
    width: fit-content;
    cursor: pointer;
    list-style: none;
    color: var(--red);
    font-size: 13px;
    font-weight: 950;
    padding: 9px 12px;
    border-radius: 999px;
    background: var(--red-soft);
    border: 1px solid #fecdd3;
}

.smart-more summary::-webkit-details-marker {
    display: none;
}

.smart-more summary::after {
    content: " ↓";
}

.smart-more[open] summary::after {
    content: " ↑";
}

.smart-more-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--border);
}

.smart-filter-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 12px;
}

.smart-reset {
    color: var(--muted);
    font-size: 13px;
    font-weight: 900;
}

.smart-reset:hover {
    color: var(--red);
}

@media(max-width: 980px) {
    .smart-filter-main {
        grid-template-columns: 1fr 1fr;
    }

    .smart-search {
        grid-column: 1 / -1;
    }

    .smart-submit {
        width: 100%;
    }

    .smart-more-grid {
        grid-template-columns: 1fr 1fr;
    }
}

@media(max-width: 620px) {
    .smart-filter {
        padding: 12px;
        border-radius: 24px;
    }

    .smart-filter-main,
    .smart-more-grid {
        grid-template-columns: 1fr;
    }

    .smart-submit {
        min-height: 54px;
        font-size: 16px;
    }

    .smart-more summary {
        width: 100%;
        text-align: center;
    }

    .smart-filter-actions {
        display: grid;
    }

    .smart-filter-actions .mini-btn,
    .smart-reset {
        width: 100%;
        text-align: center;
    }
}


/* FIX náhledů fotek při přidání inzerátu */
.pro-preview {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(145px, 1fr));
    gap: 12px;
    align-items: start;
}

.preview-card {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border-radius: 18px;
}

.preview-img-wrap {
    width: 100%;
    aspect-ratio: 4 / 3;
    height: auto;
    max-height: 150px;
    overflow: hidden;
    background: #f1f5f9;
}

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

.preview-meta {
    min-width: 0;
    padding: 9px 10px;
    background: #fff;
}

.preview-meta strong,
.preview-meta small {
    display: block;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.preview-card.is-main::after {
    content: "Hlavní fotka";
    position: absolute;
    left: 8px;
    bottom: 42px;
    z-index: 5;
    padding: 5px 9px;
    border-radius: 999px;
    background: var(--red);
    color: #fff;
    font-size: 11px;
    font-weight: 950;
}
/* =========================================================
   HARD FIX: malé jednotné náhledy fotek v přidání inzerátu
   ========================================================= */
.photo-panel .pro-preview,
.pro-upload-block .pro-preview[data-upload-preview] {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, 118px) !important;
    gap: 12px !important;
    align-items: start !important;
    justify-content: start !important;
    width: 100% !important;
    min-height: 0 !important;
    max-height: 380px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding: 2px 2px 8px !important;
}

.photo-panel .preview-card,
.pro-upload-block .preview-card {
    position: relative !important;
    display: block !important;
    width: 118px !important;
    height: 154px !important;
    min-width: 118px !important;
    max-width: 118px !important;
    overflow: hidden !important;
    border-radius: 16px !important;
    background: #fff !important;
    border: 1px solid var(--border) !important;
    box-shadow: 0 8px 18px rgba(15,23,42,.06) !important;
}

.photo-panel .preview-img-wrap,
.pro-upload-block .preview-img-wrap {
    position: relative !important;
    display: block !important;
    width: 118px !important;
    height: 96px !important;
    min-height: 96px !important;
    max-height: 96px !important;
    aspect-ratio: auto !important;
    overflow: hidden !important;
    background: #f1f5f9 !important;
}

.photo-panel .preview-img-wrap img,
.pro-upload-block .preview-img-wrap img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    max-width: none !important;
    max-height: none !important;
    object-fit: cover !important;
    object-position: center !important;
}

.photo-panel .preview-meta,
.pro-upload-block .preview-meta {
    display: grid !important;
    gap: 2px !important;
    width: 100% !important;
    min-width: 0 !important;
    height: 58px !important;
    padding: 7px 8px !important;
    background: #fff !important;
}

.photo-panel .preview-meta strong,
.photo-panel .preview-meta small,
.pro-upload-block .preview-meta strong,
.pro-upload-block .preview-meta small {
    display: block !important;
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    line-height: 1.2 !important;
}

.photo-panel .preview-meta strong,
.pro-upload-block .preview-meta strong {
    color: var(--text) !important;
    font-size: 11px !important;
    font-weight: 950 !important;
}

.photo-panel .preview-meta small,
.pro-upload-block .preview-meta small {
    color: var(--muted) !important;
    font-size: 10px !important;
    font-weight: 800 !important;
}

.photo-panel .preview-remove,
.pro-upload-block .preview-remove {
    right: 6px !important;
    top: 6px !important;
    width: 26px !important;
    height: 26px !important;
    font-size: 19px !important;
}

.photo-panel .main-photo-badge,
.photo-panel .photo-number,
.pro-upload-block .main-photo-badge,
.pro-upload-block .photo-number {
    left: 6px !important;
    top: 6px !important;
    min-height: 21px !important;
    padding: 0 7px !important;
    font-size: 10px !important;
}

.photo-panel .preview-card.is-main::after,
.pro-upload-block .preview-card.is-main::after {
    display: none !important;
    content: none !important;
}

.photo-panel .preview-empty,
.pro-upload-block .preview-empty {
    grid-column: 1 / -1 !important;
    min-height: 130px !important;
}

@media(max-width: 620px) {
    .photo-panel .pro-preview,
    .pro-upload-block .pro-preview[data-upload-preview] {
        grid-template-columns: repeat(auto-fill, minmax(104px, 1fr)) !important;
        max-height: 360px !important;
    }

    .photo-panel .preview-card,
    .pro-upload-block .preview-card {
        width: 100% !important;
        min-width: 0 !important;
        max-width: none !important;
        height: 148px !important;
    }

    .photo-panel .preview-img-wrap,
    .pro-upload-block .preview-img-wrap {
        width: 100% !important;
        height: 92px !important;
        min-height: 92px !important;
        max-height: 92px !important;
    }

    .photo-panel .preview-meta,
    .pro-upload-block .preview-meta {
        height: 56px !important;
    }
}

/* =========================================================
   FINAL FIX: pevná mřížka náhledů fotek při přidání inzerátu
   ========================================================= */
.photo-panel .pro-upload-block > .pro-preview[data-upload-preview] {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, 126px) !important;
    grid-auto-rows: 158px !important;
    gap: 12px !important;
    align-items: start !important;
    justify-content: start !important;
    width: 100% !important;
    min-height: 0 !important;
    max-height: 360px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding: 2px 2px 10px !important;
    contain: layout paint !important;
}

.photo-panel .pro-upload-block > .pro-preview[data-upload-preview] > .preview-card {
    position: relative !important;
    display: block !important;
    float: none !important;
    width: 126px !important;
    height: 158px !important;
    min-width: 126px !important;
    max-width: 126px !important;
    min-height: 158px !important;
    max-height: 158px !important;
    overflow: hidden !important;
    border-radius: 16px !important;
    background: #fff !important;
    border: 1px solid var(--border) !important;
    box-shadow: 0 8px 18px rgba(15,23,42,.06) !important;
    transform: none !important;
}

.photo-panel .pro-upload-block > .pro-preview[data-upload-preview] > .preview-card:hover {
    transform: translateY(-1px) !important;
}

.photo-panel .pro-upload-block > .pro-preview[data-upload-preview] > .preview-card > .preview-img-wrap {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    height: 96px !important;
    min-height: 96px !important;
    max-height: 96px !important;
    aspect-ratio: auto !important;
    overflow: hidden !important;
    background: #f1f5f9 !important;
}

.photo-panel .pro-upload-block > .pro-preview[data-upload-preview] > .preview-card > .preview-img-wrap > img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    min-width: 100% !important;
    max-width: none !important;
    min-height: 100% !important;
    max-height: none !important;
    object-fit: cover !important;
    object-position: center !important;
}

.photo-panel .pro-upload-block > .pro-preview[data-upload-preview] > .preview-card > .preview-meta {
    display: grid !important;
    gap: 2px !important;
    width: 100% !important;
    height: 62px !important;
    min-height: 62px !important;
    max-height: 62px !important;
    padding: 7px 8px !important;
    background: #fff !important;
}

.photo-panel .pro-upload-block > .pro-preview[data-upload-preview] > .preview-card > .preview-meta strong,
.photo-panel .pro-upload-block > .pro-preview[data-upload-preview] > .preview-card > .preview-meta small {
    display: block !important;
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    line-height: 1.2 !important;
}

.photo-panel .pro-upload-block > .pro-preview[data-upload-preview] > .preview-card > .preview-meta strong {
    font-size: 11px !important;
    font-weight: 950 !important;
}

.photo-panel .pro-upload-block > .pro-preview[data-upload-preview] > .preview-card > .preview-meta small {
    color: var(--muted) !important;
    font-size: 10px !important;
    font-weight: 800 !important;
}

@media(max-width: 620px) {
    .photo-panel .pro-upload-block > .pro-preview[data-upload-preview] {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        grid-auto-rows: 150px !important;
        max-height: 340px !important;
    }

    .photo-panel .pro-upload-block > .pro-preview[data-upload-preview] > .preview-card {
        width: 100% !important;
        min-width: 0 !important;
        max-width: none !important;
        height: 150px !important;
        min-height: 150px !important;
        max-height: 150px !important;
    }

    .photo-panel .pro-upload-block > .pro-preview[data-upload-preview] > .preview-card > .preview-img-wrap {
        height: 92px !important;
        min-height: 92px !important;
        max-height: 92px !important;
    }

    .photo-panel .pro-upload-block > .pro-preview[data-upload-preview] > .preview-card > .preview-meta {
        height: 58px !important;
        min-height: 58px !important;
        max-height: 58px !important;
    }
}

/* =========================================================
   NOVÝ PHOTO PICKER – sjednocené malé náhledy fotek
   ========================================================= */
.photo-picker-panel .photo-picker {
    display: grid;
    gap: 16px;
}

.photo-picker-panel .photo-dropzone {
    position: relative;
    display: grid !important;
    place-items: center;
    text-align: center;
    gap: 7px;
    min-height: 190px;
    padding: 24px;
    border: 2px dashed #fecdd3;
    border-radius: 24px;
    background: #fff;
    cursor: pointer;
    transition: .18s;
}

.photo-picker-panel .photo-dropzone:hover,
.photo-picker-panel .photo-dropzone.is-dragover {
    border-color: var(--red);
    background: var(--red-soft);
}

.photo-picker-panel .photo-dropzone input {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
}

.photo-dropzone-icon {
    font-size: 40px;
    line-height: 1;
}

.photo-dropzone-title {
    display: block;
    font-size: 20px;
    font-weight: 950;
}

.photo-dropzone-text {
    display: block;
    color: #334155;
    font-size: 14px;
    font-weight: 850;
}

.photo-dropzone-limit {
    display: inline-flex;
    margin-top: 4px;
    padding: 7px 11px;
    border-radius: 999px;
    background: #f8fafc;
    color: var(--muted);
    font-size: 12px;
    font-weight: 900;
}

.photo-preview-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.photo-preview-head strong {
    display: block;
    font-size: 16px;
    font-weight: 950;
}

.photo-preview-head small {
    display: block;
    margin-top: 2px;
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
}

.photo-picker-panel .photo-preview-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(118px, 118px)) !important;
    grid-auto-rows: 150px !important;
    gap: 12px !important;
    align-items: start !important;
    justify-content: start !important;
    width: 100% !important;
    max-height: 340px !important;
    overflow: auto !important;
    padding: 2px 2px 10px !important;
}

.photo-picker-panel .photo-preview-card {
    position: relative !important;
    display: grid !important;
    grid-template-rows: 96px 54px !important;
    width: 118px !important;
    height: 150px !important;
    min-width: 118px !important;
    max-width: 118px !important;
    min-height: 150px !important;
    max-height: 150px !important;
    overflow: hidden !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 16px !important;
    background: #fff !important;
    box-shadow: 0 8px 18px rgba(15,23,42,.06) !important;
    cursor: pointer !important;
    transition: .18s;
}

.photo-picker-panel .photo-preview-card:hover {
    transform: translateY(-1px);
    border-color: #fecdd3 !important;
    box-shadow: 0 12px 24px rgba(15,23,42,.09) !important;
}

.photo-picker-panel .photo-preview-card.is-main {
    border-color: var(--red) !important;
    box-shadow: 0 12px 26px rgba(225,29,72,.14) !important;
}

.photo-preview-image {
    position: relative;
    width: 100%;
    height: 96px;
    overflow: hidden;
    background: #f1f5f9;
}

.photo-picker-panel .photo-preview-card img {
    display: block !important;
    width: 100% !important;
    height: 96px !important;
    max-width: none !important;
    max-height: none !important;
    object-fit: cover !important;
    object-position: center !important;
}

.photo-preview-badge {
    position: absolute;
    left: 6px;
    top: 6px;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 21px;
    padding: 0 7px;
    border-radius: 999px;
    background: rgba(15,23,42,.78);
    color: #fff;
    font-size: 10px;
    font-weight: 950;
    box-shadow: 0 8px 18px rgba(15,23,42,.22);
}

.photo-preview-card.is-main .photo-preview-badge {
    background: var(--red);
}

.photo-preview-remove {
    position: absolute;
    right: 6px;
    top: 6px;
    z-index: 4;
    width: 26px;
    height: 26px;
    border: 1px solid rgba(255,255,255,.55);
    border-radius: 999px;
    background: rgba(15,23,42,.76);
    color: #fff;
    font-size: 19px;
    line-height: 1;
    cursor: pointer;
    backdrop-filter: blur(8px);
}

.photo-preview-remove:hover {
    background: var(--red);
}

.photo-preview-info {
    display: grid;
    gap: 2px;
    width: 100%;
    min-width: 0;
    height: 54px;
    padding: 7px 8px;
    background: #fff;
}

.photo-preview-name,
.photo-preview-size {
    display: block;
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 1.2;
}

.photo-preview-name {
    color: var(--text);
    font-size: 11px;
    font-weight: 950;
}

.photo-preview-size {
    color: var(--muted);
    font-size: 10px;
    font-weight: 800;
}

.photo-preview-empty {
    grid-column: 1 / -1;
    min-height: 130px;
    display: grid;
    place-items: center;
    text-align: center;
    gap: 5px;
    padding: 20px;
    border: 1px dashed #cbd5e1;
    border-radius: 22px;
    background: #fff;
    color: var(--muted);
}

.photo-preview-empty span {
    font-size: 34px;
}

.photo-preview-empty strong {
    color: var(--text);
    font-size: 17px;
}

.photo-preview-empty small {
    font-size: 13px;
    font-weight: 750;
}

@media(max-width: 620px) {
    .photo-picker-panel .photo-dropzone {
        min-height: 175px;
        padding: 18px;
    }

    .photo-preview-head {
        align-items: stretch;
        flex-direction: column;
    }

    .photo-preview-head .mini-btn {
        width: 100%;
    }

    .photo-picker-panel .photo-preview-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        grid-auto-rows: 148px !important;
        max-height: 330px !important;
    }

    .photo-picker-panel .photo-preview-card {
        width: 100% !important;
        min-width: 0 !important;
        max-width: none !important;
        height: 148px !important;
        min-height: 148px !important;
        max-height: 148px !important;
    }

    .photo-picker-panel .photo-preview-card img,
    .photo-preview-image {
        height: 94px !important;
    }

    .photo-preview-info {
        height: 54px;
    }
}


/* =========================================================
   FINAL FIX: Fotky při přidání inzerátu — sjednocené náhledy
   ========================================================= */
[data-photo-picker] [data-upload-preview] {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, 116px) !important;
    grid-auto-rows: 154px !important;
    gap: 12px !important;
    align-items: start !important;
    justify-content: start !important;
    width: 100% !important;
    max-width: 100% !important;
    max-height: 350px !important;
    overflow: auto !important;
    padding: 2px 2px 12px !important;
    contain: layout paint !important;
}

[data-photo-picker] [data-upload-preview] > *:not(.photo-preview-empty) {
    position: relative !important;
    display: block !important;
    width: 116px !important;
    height: 154px !important;
    min-width: 116px !important;
    max-width: 116px !important;
    min-height: 154px !important;
    max-height: 154px !important;
    overflow: hidden !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 16px !important;
    background: #fff !important;
    box-shadow: 0 8px 18px rgba(15,23,42,.06) !important;
}

[data-photo-picker] .photo-preview-image {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    height: 98px !important;
    overflow: hidden !important;
    background: #f1f5f9 !important;
}

[data-photo-picker] [data-upload-preview] img,
[data-photo-picker] .photo-preview-image img {
    display: block !important;
    width: 100% !important;
    height: 98px !important;
    min-width: 100% !important;
    max-width: 100% !important;
    min-height: 98px !important;
    max-height: 98px !important;
    object-fit: cover !important;
    object-position: center !important;
}

[data-photo-picker] .photo-preview-info {
    display: grid !important;
    gap: 2px !important;
    width: 100% !important;
    height: 56px !important;
    min-height: 56px !important;
    max-height: 56px !important;
    padding: 7px 8px !important;
    overflow: hidden !important;
    background: #fff !important;
}

[data-photo-picker] .photo-preview-name,
[data-photo-picker] .photo-preview-size {
    display: block !important;
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    line-height: 1.2 !important;
}

[data-photo-picker] .photo-preview-name {
    color: var(--text) !important;
    font-size: 11px !important;
    font-weight: 950 !important;
}

[data-photo-picker] .photo-preview-size {
    color: var(--muted) !important;
    font-size: 10px !important;
    font-weight: 800 !important;
}

@media(max-width: 620px) {
    [data-photo-picker] [data-upload-preview] {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        grid-auto-rows: 150px !important;
        max-height: 330px !important;
    }

    [data-photo-picker] [data-upload-preview] > *:not(.photo-preview-empty) {
        width: 100% !important;
        min-width: 0 !important;
        max-width: none !important;
        height: 150px !important;
        min-height: 150px !important;
        max-height: 150px !important;
    }

    [data-photo-picker] .photo-preview-image,
    [data-photo-picker] [data-upload-preview] img,
    [data-photo-picker] .photo-preview-image img {
        height: 94px !important;
        min-height: 94px !important;
        max-height: 94px !important;
    }
}

/* =========================================================
   FOTO UPLOAD: tlačítko pro nastavení hlavní fotky
   ========================================================= */
.photo-preview-card.is-main {
    border-color: var(--red) !important;
    box-shadow: 0 10px 24px rgba(225,29,72,.16) !important;
}

.photo-set-main,
.photo-main-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 24px;
    margin-top: 2px;
    border-radius: 999px;
    font: inherit;
    font-size: 10px;
    font-weight: 950;
    line-height: 1;
}

.photo-set-main {
    border: 1px solid #fecdd3;
    background: var(--red-soft);
    color: #9f1239;
    cursor: pointer;
}

.photo-set-main:hover {
    background: var(--red);
    border-color: var(--red);
    color: #fff;
}

.photo-main-status {
    border: 1px solid #bbf7d0;
    background: #ecfdf5;
    color: #166534;
}

/* =========================================================
   FTP FINAL: Přidání inzerátu – pevné náhledy fotek 150×150
   Tento blok je záměrně úplně na konci, aby přebil starší varianty.
   ========================================================= */
[data-photo-picker] .photo-preview-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, 150px) !important;
    gap: 10px !important;
    align-items: start !important;
    justify-content: start !important;
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: auto !important;
    overflow-y: visible !important;
    padding: 4px 4px 10px !important;
}

[data-photo-picker] .photo-preview-card {
    position: relative !important;
    display: block !important;
    width: 150px !important;
    height: 150px !important;
    min-width: 150px !important;
    max-width: 150px !important;
    min-height: 150px !important;
    max-height: 150px !important;
    overflow: hidden !important;
    border: 2px solid transparent !important;
    border-radius: 14px !important;
    background: #f1f5f9 !important;
    box-shadow: 0 8px 20px rgba(15,23,42,.08) !important;
    cursor: pointer !important;
}

[data-photo-picker] .photo-preview-card.is-main {
    border-color: var(--red) !important;
    box-shadow: 0 12px 28px rgba(225,29,72,.18) !important;
}

[data-photo-picker] .photo-preview-image,
[data-photo-picker] .photo-preview-image img {
    display: block !important;
    width: 150px !important;
    height: 150px !important;
    min-width: 150px !important;
    min-height: 150px !important;
    max-width: 150px !important;
    max-height: 150px !important;
}

[data-photo-picker] .photo-preview-image {
    position: relative !important;
    overflow: hidden !important;
    background: #f1f5f9 !important;
}

[data-photo-picker] .photo-preview-image img {
    object-fit: cover !important;
    object-position: center !important;
}

[data-photo-picker] .photo-preview-badge {
    position: absolute !important;
    left: 7px !important;
    top: 7px !important;
    z-index: 4 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 24px !important;
    padding: 0 8px !important;
    border-radius: 999px !important;
    background: rgba(15,23,42,.78) !important;
    color: #fff !important;
    font-size: 11px !important;
    font-weight: 950 !important;
}

[data-photo-picker] .photo-preview-card.is-main .photo-preview-badge {
    background: var(--red) !important;
}

[data-photo-picker] .photo-preview-remove {
    position: absolute !important;
    top: 7px !important;
    right: 7px !important;
    z-index: 4 !important;
    width: 28px !important;
    height: 28px !important;
    border: 1px solid rgba(255,255,255,.55) !important;
    border-radius: 999px !important;
    background: rgba(15,23,42,.76) !important;
    color: #fff !important;
    font-size: 20px !important;
    line-height: 1 !important;
    cursor: pointer !important;
}

[data-photo-picker] .photo-set-main {
    position: absolute !important;
    left: 7px !important;
    right: 7px !important;
    bottom: 7px !important;
    z-index: 4 !important;
    min-height: 28px !important;
    border: 1px solid rgba(255,255,255,.78) !important;
    border-radius: 999px !important;
    background: rgba(255,255,255,.94) !important;
    color: #9f1239 !important;
    font: inherit !important;
    font-size: 11px !important;
    font-weight: 950 !important;
    cursor: pointer !important;
}

[data-photo-picker] .photo-set-main:hover,
[data-photo-picker] .photo-preview-card.is-main .photo-set-main {
    background: var(--red) !important;
    border-color: var(--red) !important;
    color: #fff !important;
}

@media(max-width: 760px) {
    [data-photo-picker] .photo-preview-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        overflow-x: visible !important;
    }

    [data-photo-picker] .photo-preview-card,
    [data-photo-picker] .photo-preview-image,
    [data-photo-picker] .photo-preview-image img {
        width: 100% !important;
        min-width: 0 !important;
        max-width: none !important;
    }
}

/* =========================================================
   FTP FIX 2026-05: Foto upload – klikání hlavní fotky
   ========================================================= */
[data-photo-picker] .photo-preview-card {
    pointer-events: auto !important;
}
[data-photo-picker] .photo-preview-card img {
    pointer-events: none !important;
    user-select: none !important;
}
[data-photo-picker] .photo-preview-remove,
[data-photo-picker] .photo-set-main {
    pointer-events: auto !important;
    z-index: 20 !important;
}
[data-photo-picker] .photo-set-main {
    position: absolute !important;
    left: 7px !important;
    right: 7px !important;
    bottom: 7px !important;
    width: auto !important;
}

/* =========================================================
   NEJLEVNEJSI.cz — FOTO UPLOAD v3
   Jedinečné třídy np-* kvůli starým konfliktům ve style.css.
   ========================================================= */
.np-photo-panel {
  background: linear-gradient(180deg, #fff, #fff7f8) !important;
}

.np-photo-picker {
  display: grid !important;
  gap: 16px !important;
}

.np-photo-dropzone {
  position: relative !important;
  display: grid !important;
  place-items: center !important;
  text-align: center !important;
  gap: 7px !important;
  min-height: 190px !important;
  padding: 24px !important;
  border: 2px dashed #fecdd3 !important;
  border-radius: 24px !important;
  background: #fff !important;
  cursor: pointer !important;
  transition: .18s !important;
}

.np-photo-dropzone:hover,
.np-photo-dropzone.is-dragover {
  border-color: var(--red) !important;
  background: var(--red-soft) !important;
}

.np-photo-dropzone input[type="file"] {
  position: absolute !important;
  inset: 0 !important;
  opacity: 0 !important;
  cursor: pointer !important;
}

.np-photo-dropzone-icon { font-size: 40px !important; line-height: 1 !important; }
.np-photo-dropzone-title { display: block !important; font-size: 20px !important; font-weight: 950 !important; }
.np-photo-dropzone-text { display: block !important; color: #334155 !important; font-size: 14px !important; font-weight: 850 !important; }
.np-photo-dropzone-limit { display: inline-flex !important; margin-top: 4px !important; padding: 7px 11px !important; border-radius: 999px !important; background: #f8fafc !important; color: var(--muted) !important; font-size: 12px !important; font-weight: 900 !important; }

.np-photo-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
}

.np-photo-head strong { display:block !important; font-size:16px !important; font-weight:950 !important; }
.np-photo-head small { display:block !important; margin-top:2px !important; color:var(--muted) !important; font-size:12px !important; font-weight:800 !important; }

.np-photo-grid {
  display: grid !important;
  grid-template-columns: repeat(8, 150px) !important;
  gap: 10px !important;
  align-items: start !important;
  justify-content: start !important;
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  padding: 4px 4px 12px !important;
  -webkit-overflow-scrolling: touch !important;
}

.np-photo-card {
  position: relative !important;
  display: block !important;
  width: 150px !important;
  height: 150px !important;
  min-width: 150px !important;
  max-width: 150px !important;
  min-height: 150px !important;
  max-height: 150px !important;
  overflow: hidden !important;
  border: 2px solid #e2e8f0 !important;
  border-radius: 14px !important;
  background: #f1f5f9 !important;
  box-shadow: 0 8px 20px rgba(15,23,42,.08) !important;
}

.np-photo-card.is-main {
  border-color: var(--red) !important;
  box-shadow: 0 12px 28px rgba(225,29,72,.18) !important;
}

.np-photo-img,
.np-photo-img img {
  display: block !important;
  width: 150px !important;
  height: 150px !important;
  min-width: 150px !important;
  min-height: 150px !important;
  max-width: 150px !important;
  max-height: 150px !important;
}

.np-photo-img img {
  object-fit: cover !important;
  object-position: center !important;
  user-select: none !important;
  -webkit-user-drag: none !important;
}

.np-photo-badge {
  position: absolute !important;
  left: 7px !important;
  top: 7px !important;
  z-index: 3 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 24px !important;
  padding: 0 8px !important;
  border-radius: 999px !important;
  background: rgba(15,23,42,.78) !important;
  color: #fff !important;
  font-size: 11px !important;
  font-weight: 950 !important;
  box-shadow: 0 8px 18px rgba(15,23,42,.22) !important;
}

.np-photo-card.is-main .np-photo-badge { background: var(--red) !important; }

.np-photo-remove {
  position: absolute !important;
  top: 7px !important;
  right: 7px !important;
  z-index: 5 !important;
  width: 28px !important;
  height: 28px !important;
  border: 1px solid rgba(255,255,255,.55) !important;
  border-radius: 999px !important;
  background: rgba(15,23,42,.78) !important;
  color: #fff !important;
  font: inherit !important;
  font-size: 20px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  cursor: pointer !important;
}

.np-photo-remove:hover { background: var(--red) !important; }

.np-photo-main-btn {
  position: absolute !important;
  left: 7px !important;
  right: 7px !important;
  bottom: 7px !important;
  z-index: 4 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 32px !important;
  padding: 0 8px !important;
  border: 1px solid rgba(255,255,255,.85) !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.96) !important;
  color: #9f1239 !important;
  font: inherit !important;
  font-size: 11px !important;
  font-weight: 950 !important;
  cursor: pointer !important;
  box-shadow: 0 8px 18px rgba(15,23,42,.20) !important;
  backdrop-filter: blur(8px) !important;
}

.np-photo-main-btn:hover,
.np-photo-card.is-main .np-photo-main-btn {
  background: var(--red) !important;
  border-color: var(--red) !important;
  color: #fff !important;
}

.np-photo-name {
  position: absolute !important;
  left: 7px !important;
  right: 7px !important;
  bottom: 43px !important;
  z-index: 2 !important;
  display: block !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  padding: 4px 7px !important;
  border-radius: 999px !important;
  background: rgba(15,23,42,.56) !important;
  color: #fff !important;
  font-size: 10px !important;
  font-weight: 850 !important;
}

.np-photo-empty {
  grid-column: 1 / -1 !important;
  min-height: 140px !important;
  display: grid !important;
  place-items: center !important;
  text-align: center !important;
  gap: 5px !important;
  padding: 20px !important;
  border: 1px dashed #cbd5e1 !important;
  border-radius: 22px !important;
  background: #fff !important;
  color: var(--muted) !important;
}

@media(max-width: 760px) {
  .np-photo-head { align-items: stretch !important; flex-direction: column !important; }
  .np-photo-head .mini-btn { width: 100% !important; }
  .np-photo-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    overflow-x: visible !important;
  }
  .np-photo-card,
  .np-photo-img,
  .np-photo-img img {
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
  }
}

/* FIX kontakt na prodejce - ikonky a text na jednom řádku */
.seller-meta {
    display: grid;
    gap: 11px;
    margin: 16px 0 18px;
}

.seller-meta-item {
    display: flex;
    align-items: flex-start;
    gap: 9px;
    color: #334155;
    font-size: 14px;
    line-height: 1.35;
}

.seller-meta-icon {
    flex: 0 0 22px;
    width: 22px;
    line-height: 1.2;
    text-align: center;
}

.seller-meta-text {
    min-width: 0;
}

.seller-meta-text small {
    display: inline;
    color: var(--muted);
    font-size: 14px;
    font-weight: 750;
    margin-right: 4px;
}

.seller-meta-text strong {
    display: inline;
    color: var(--text);
    font-size: 14px;
    font-weight: 950;
}

.modal {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.6);
    justify-content: center;
    align-items: center;
    z-index: 9999;
}

.modal-content {
    background: #fff;
    padding: 20px;
    border-radius: 12px;
    width: 100%;
    max-width: 400px;
}

.modal-content select,
.modal-content textarea,
.modal-content input {
    width: 100%;
    margin-bottom: 10px;
}

.report-btn {
    appearance: none;
    width: 100%;
    margin-top: 12px;
    min-height: 44px;
    border: 1px solid #fecdd3;
    border-radius: 999px;
    background: #fff1f2;
    color: #9f1239;
    font: inherit;
    font-size: 13px;
    font-weight: 950;
    cursor: pointer;
}

.report-modal {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 10000;
    align-items: center;
    justify-content: center;
    padding: 18px;
    background: rgba(15,23,42,.72);
    backdrop-filter: blur(8px);
}

.report-modal.is-open {
    display: flex;
}

.report-modal-card {
    width: min(460px, 100%);
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 28px;
    padding: 24px;
    box-shadow: 0 24px 80px rgba(0,0,0,.28);
}

.report-modal-card h3 {
    margin: 0 0 8px;
    font-family: 'Plus Jakarta Sans', Inter, sans-serif;
    font-size: 26px;
}

.report-modal-card p {
    margin: 0 0 16px;
    color: var(--muted);
    line-height: 1.5;
}

.report-form {
    display: grid;
    gap: 12px;
}

.report-form textarea.field {
    min-height: 110px;
    resize: vertical;
}

.report-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.report-actions .btn {
    min-height: 46px;
}

.badge-top{
    position:absolute;
    left:10px;
    top:10px;
    z-index:3;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:28px;
    padding:0 10px;
    border-radius:999px;
    background:var(--red);
    color:#fff;
    font-size:12px;
    font-weight:950;
    box-shadow:0 10px 22px rgba(225,29,72,.25);
}
/* =========================================================
   DETAIL INZERÁTU — telefon za kliknutí + inline formulář
   ========================================================= */
.seller-contact-actions {
    display: grid;
    gap: 10px;
    margin-top: 12px;
}

.inline-contact-card {
    margin-top: 16px;
    padding: 16px;
    background: linear-gradient(180deg, #fff, #fff7f8);
    border: 1px solid #fecdd3;
    border-radius: 22px;
}

.inline-contact-card h3 {
    margin: 0 0 6px;
    font-family: 'Plus Jakarta Sans', Inter, sans-serif;
    font-size: 21px;
    line-height: 1.15;
}

.inline-contact-card p {
    margin: 0 0 13px;
    color: var(--muted);
    font-size: 13px;
    font-weight: 800;
    line-height: 1.5;
}

.inline-contact-form {
    display: grid;
    gap: 11px;
}

.inline-contact-form label {
    display: grid;
    gap: 6px;
}

.inline-contact-form label strong {
    color: #334155;
    font-size: 12px;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: .35px;
}

.inline-contact-form label small {
    color: var(--muted);
    font-size: 11px;
    font-weight: 850;
    text-transform: none;
    letter-spacing: 0;
}

.inline-contact-form .field {
    min-height: 46px;
    border: 1px solid #eef2f7;
    background: #fff;
    border-radius: 15px;
}

.inline-contact-form textarea.field {
    min-height: 118px;
    resize: vertical;
}

.inline-contact-form .field:focus {
    border-color: #fecdd3;
    box-shadow: 0 0 0 4px rgba(225,29,72,.08);
}

.inline-contact-form .btn {
    min-height: 48px;
    width: 100%;
}

[data-phone-visible="1"] {
    word-break: break-word;
}

@media(max-width: 620px) {
    .inline-contact-card {
        border-radius: 20px;
        padding: 14px;
    }
}

/* =========================================================
   DETAIL INZERÁTU — stav, SEO/edit token a správa
   ========================================================= */
.detail-top-row {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 12px;
}

.listing-status-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 950;
    border: 1px solid var(--border);
    background: #fff;
    color: #334155;
}

.listing-status-badge.is-active {
    border-color: #bbf7d0;
    background: #ecfdf5;
    color: #166534;
}

.listing-status-badge.is-reserved {
    border-color: #fde68a;
    background: #fffbeb;
    color: #92400e;
}

.listing-status-badge.is-sold {
    border-color: #fecdd3;
    background: var(--red-soft);
    color: #9f1239;
}

.listing-status-note,
.sold-contact-note,
.edit-token-box {
    margin-top: 12px;
    padding: 13px 14px;
    border-radius: 18px;
    font-size: 14px;
    font-weight: 850;
    line-height: 1.5;
}

.listing-status-note.is-reserved {
    border: 1px solid #fde68a;
    background: #fffbeb;
    color: #92400e;
}

.listing-status-note.is-sold,
.sold-contact-note {
    border: 1px solid #fecdd3;
    background: var(--red-soft);
    color: #9f1239;
}

.edit-token-box {
    display: grid;
    gap: 5px;
    margin-top: 16px;
    border: 1px dashed #cbd5e1;
    background: #f8fafc;
    color: #334155;
}

.edit-token-box strong {
    color: var(--text);
    font-weight: 950;
}

.edit-token-box span {
    color: var(--muted);
    font-size: 13px;
    font-weight: 800;
}

.edit-token-box a {
    width: fit-content;
    color: var(--red);
    font-size: 13px;
    font-weight: 950;
}

.inline-contact-card.is-disabled {
    opacity: .82;
}

.edit-listing-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 330px;
    gap: 22px;
    align-items: start;
    margin-bottom: 38px;
}

.edit-listing-card,
.edit-help-card {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 28px;
    padding: 24px;
    box-shadow: 0 14px 36px rgba(15,23,42,.06);
}

.edit-listing-card {
    display: grid;
    gap: 15px;
}

.edit-listing-card label {
    display: grid;
    gap: 7px;
}

.edit-listing-card label strong {
    color: #334155;
    font-size: 13px;
    font-weight: 950;
}

.edit-listing-card .field {
    min-height: 50px;
    border: 1px solid #eef2f7;
    background: #f8fafc;
}

.edit-listing-card textarea.field {
    min-height: 180px;
    resize: vertical;
}

.edit-listing-card .field:focus {
    border-color: #fecdd3;
    background: #fff;
    box-shadow: 0 0 0 4px rgba(225,29,72,.08);
}

.edit-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: center;
    padding-top: 4px;
}

.edit-help-card {
    position: sticky;
    top: 88px;
}

.edit-help-card h2 {
    font-family: 'Plus Jakarta Sans', Inter, sans-serif;
    margin: 0 0 10px;
    font-size: 26px;
}

.edit-help-card p {
    color: #334155;
    line-height: 1.65;
    margin: 0 0 12px;
}

@media(max-width: 900px) {
    .edit-listing-layout {
        grid-template-columns: 1fr;
    }

    .edit-help-card {
        position: static;
    }
}

@media(max-width: 620px) {
    .listing-status-badge {
        width: 100%;
    }

    .edit-listing-card,
    .edit-help-card {
        padding: 20px;
        border-radius: 24px;
    }

    .edit-actions {
        display: grid;
    }

    .edit-actions .btn {
        width: 100%;
    }
}

/* =========================================================
   NEJLEVNEJSI.cz — Moje inzeráty bez registrace
   ========================================================= */
.my-listings-page .page-hero-card {
    margin-bottom: 22px;
}

.my-listings-request-card,
.my-listings-toolbar,
.my-listing-card {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 28px;
    box-shadow: 0 14px 36px rgba(15,23,42,.06);
}

.my-listings-request-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 340px;
    gap: 22px;
    align-items: center;
    padding: 24px;
    margin-bottom: 36px;
}

.my-listings-request-form {
    display: grid;
    gap: 14px;
}

.my-listings-request-form label {
    display: grid;
    gap: 7px;
}

.my-listings-request-form label strong {
    color: #334155;
    font-size: 13px;
    font-weight: 950;
}

.my-listings-request-form .field {
    min-height: 52px;
    border: 1px solid #eef2f7;
    background: #f8fafc;
}

.my-listings-request-form .field:focus {
    border-color: #fecdd3;
    background: #fff;
    box-shadow: 0 0 0 4px rgba(225,29,72,.08);
}

.my-listings-request-form .btn {
    min-height: 52px;
    width: fit-content;
}

.my-listings-help {
    padding: 18px;
    border-radius: 22px;
    background: var(--red-soft);
    border: 1px solid #fecdd3;
}

.my-listings-help h2,
.my-listings-toolbar h2,
.my-listing-card h2 {
    font-family: 'Plus Jakarta Sans', Inter, sans-serif;
    margin: 0 0 8px;
    line-height: 1.15;
}

.my-listings-help h2 { font-size: 24px; }
.my-listings-toolbar h2 { font-size: 26px; }
.my-listing-card h2 { font-size: 20px; }

.my-listings-help p,
.my-listings-toolbar p,
.my-listing-card p {
    margin: 0;
    color: #334155;
    line-height: 1.6;
}

.my-listings-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 22px;
    margin-bottom: 18px;
}

.my-listings-resend {
    margin: 0;
}

.my-listings-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    margin-bottom: 38px;
}

.my-listing-card {
    display: grid;
    grid-template-columns: 170px minmax(0, 1fr);
    overflow: hidden;
}

.my-listing-photo {
    display: grid;
    place-items: center;
    min-height: 170px;
    background: linear-gradient(135deg,#e2e8f0,#f8fafc);
    color: #64748b;
    font-weight: 950;
}

.my-listing-photo img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.my-listing-body {
    display: grid;
    align-content: start;
    gap: 10px;
    padding: 18px;
    min-width: 0;
}

.my-listing-body h2 {
    overflow: hidden;
    text-overflow: ellipsis;
}

.my-listing-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 4px;
}

.listing-status-badge.is-pending {
    background: #fefce8;
    color: #854d0e;
    border-color: #fde68a;
}

@media(max-width: 980px) {
    .my-listings-request-card,
    .my-listings-grid {
        grid-template-columns: 1fr;
    }

    .my-listings-request-form .btn {
        width: 100%;
    }
}

@media(max-width: 700px) {
    .my-listings-toolbar {
        display: grid;
    }

    .my-listings-toolbar .btn {
        width: 100%;
    }

    .my-listing-card {
        grid-template-columns: 1fr;
    }

    .my-listing-photo {
        min-height: 210px;
    }
}

@media(max-width: 620px) {
    .my-listings-request-card,
    .my-listings-toolbar,
    .my-listing-card {
        border-radius: 24px;
    }

    .my-listings-request-card {
        padding: 20px;
    }

    .my-listing-actions {
        display: grid;
    }

    .my-listing-actions .btn {
        width: 100%;
    }
}

/* =========================================================
   FOOTER — NEJLEVNEJSI.cz
   ========================================================= */

.site-footer {
    margin-top: 60px;
    background: #0f172a;
    color: #cbd5f5;
    border-top: 1px solid #1e293b;
}

.site-footer-inner {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr 1fr;
    gap: 28px;
    padding: 48px 0 32px;
}

.site-footer a {
    color: #cbd5f5;
    font-size: 14px;
    font-weight: 800;
    transition: .18s;
}

.site-footer a:hover {
    color: #fff;
}

.site-footer h2 {
    font-size: 14px;
    font-weight: 900;
    margin-bottom: 12px;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: .6px;
}

/* Brand */
.site-footer-brand p {
    margin: 12px 0 16px;
    color: #94a3b8;
    font-size: 14px;
    line-height: 1.6;
}

.footer-logo {
    font-size: 22px;
}

/* Trust badges */
.footer-trust {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.footer-trust span {
    background: #1e293b;
    border: 1px solid #334155;
    padding: 7px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 900;
    color: #e2e8f0;
}

/* Sloupce */
.footer-col {
    display: grid;
    gap: 8px;
}

/* Spodní řádek */
.site-footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    padding: 18px 0 26px;
    border-top: 1px solid #1e293b;
    font-size: 13px;
    color: #64748b;
}

/* Responsive */
@media(max-width: 900px) {
    .site-footer-inner {
        grid-template-columns: 1fr 1fr;
    }
}

@media(max-width: 620px) {
    .site-footer-inner {
        grid-template-columns: 1fr;
        gap: 22px;
    }

    .site-footer-bottom {
        flex-direction: column;
        text-align: center;
    }
}