/* ═══════════════════════════════════════════
   SolutionSynergy – Nemovitosti
   Styl: petrranda.cz – zlatá, navy, levandule
   ═══════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&display=swap');

:root {
  --ss-gold:     #b8964e;
  --ss-gold-dk:  #9a7a3a;
  --ss-navy:     #1a1a2e;
  --ss-dark:     #2d2d3e;
  --ss-mid:      #6b6b80;
  --ss-light:    #9898aa;
  --ss-line:     #e8e8f0;
  --ss-bg:       #f5f5fa;
  --ss-white:    #ffffff;
  --ss-radius:   16px;
  --ss-shadow:   0 2px 24px rgba(26,26,46,.07);
  --ss-trans:    all .22s ease;
  --ss-font:     'Nunito', sans-serif;
}

/* ── GRID ─────────────────────────────────── */
.ss-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
  gap: 24px;
  margin: 28px 0;
  font-family: var(--ss-font);
}

/* ── KARTA ────────────────────────────────── */
.ss-card {
  background: var(--ss-white);
  border-radius: var(--ss-radius);
  box-shadow: var(--ss-shadow);
  border: 1px solid var(--ss-line);
  overflow: hidden;
  transition: var(--ss-trans);
  position: relative;
  display: flex;
  flex-direction: column;
}
.ss-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 40px rgba(26,26,46,.13);
  border-color: var(--ss-gold);
}

/* ── BADGE ────────────────────────────────── */
.ss-badge {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 2;
  font-family: var(--ss-font);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 5px 12px;
  border-radius: 20px;
  pointer-events: none;
}
.ss-badge--aktiv       { background: var(--ss-gold);  color: #fff; }
.ss-badge--rezervovano { background: #5b4fcf;          color: #fff; }
.ss-badge--prodano     { background: var(--ss-navy);   color: #fff; }
.ss-badge--pronajato   { background: #2e7d32;          color: #fff; }
.ss-badge--exkluzivni  {
  position: absolute;
  top: 14px; right: 14px; left: auto;
  background: rgba(255,255,255,.95);
  color: #5b4fcf;
  font-family: var(--ss-font);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 5px 12px;
  border-radius: 20px;
  z-index: 2;
}

/* ── OBRÁZEK ─────────────────────────────── */
.ss-card__img {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4/3;
  background: var(--ss-bg);
}
.ss-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .45s ease;
  display: block;
}
.ss-card:hover .ss-card__img img {
  transform: scale(1.05);
}
.ss-card__no-img {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ss-light);
  font-size: 13px;
  font-family: var(--ss-font);
}

/* ── OBSAH ────────────────────────────────── */
.ss-card__body {
  padding: 20px 22px 22px;
  flex: 1;
  display: flex;
  flex-direction: column;
  font-family: var(--ss-font);
}
.ss-card__lokace {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .07em;
  color: var(--ss-light);
  text-transform: uppercase;
  margin-bottom: 10px;
}
.ss-card__cena {
  font-size: 22px;
  font-weight: 800;
  color: var(--ss-gold);
  margin: 0 0 6px;
  line-height: 1.2;
}
.ss-card__plocha {
  font-size: 13px;
  color: var(--ss-mid);
  font-weight: 600;
  margin-bottom: 16px;
}
.ss-card__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 700;
  color: var(--ss-navy);
  text-decoration: none;
  margin-top: auto;
  transition: var(--ss-trans);
}
.ss-card__link::after { content: ' →'; }
.ss-card__link:hover  { color: var(--ss-gold); }

.ss-card__overlay-link {
  position: absolute;
  inset: 0;
  z-index: 1;
}

/* ── FILTER BAR ───────────────────────────── */
.ss-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 28px;
  align-items: center;
  font-family: var(--ss-font);
}
.ss-filter__btn {
  padding: 8px 20px;
  border: 2px solid var(--ss-line);
  border-radius: 30px;
  background: var(--ss-white);
  font-size: 13px;
  font-weight: 700;
  font-family: var(--ss-font);
  color: var(--ss-navy);
  cursor: pointer;
  transition: var(--ss-trans);
  text-decoration: none;
  display: inline-block;
}
.ss-filter__btn:hover,
.ss-filter__btn--active {
  background: var(--ss-gold);
  border-color: var(--ss-gold);
  color: #fff;
}

/* ── PRÁZDNÝ STAV ─────────────────────────── */
.ss-empty {
  text-align: center;
  padding: 60px 20px;
  color: var(--ss-light);
  font-size: 15px;
  font-family: var(--ss-font);
}

/* ── TLAČÍTKO VÍCE ────────────────────────── */
.ss-loadmore-wrap {
  text-align: center;
  margin: 36px 0 8px;
}
.ss-btn-more {
  display: inline-block;
  padding: 15px 44px;
  border: 2px solid var(--ss-navy);
  border-radius: 50px;
  font-size: 14px;
  font-weight: 800;
  font-family: var(--ss-font);
  letter-spacing: .03em;
  color: var(--ss-navy);
  text-decoration: none;
  transition: var(--ss-trans);
  background: transparent;
  cursor: pointer;
}
.ss-btn-more:hover {
  background: var(--ss-navy);
  color: #fff;
}

/* ═══════════════════════════════════════════
   DETAIL – single stránka
   ═══════════════════════════════════════════ */

.ss-single {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 20px 60px;
  font-family: var(--ss-font);
}

/* Breadcrumb */
.ss-breadcrumb {
  font-size: 12px;
  color: var(--ss-light);
  margin-bottom: 24px;
  letter-spacing: .03em;
  font-family: var(--ss-font);
}
.ss-breadcrumb a { color: var(--ss-light); text-decoration: none; }
.ss-breadcrumb a:hover { color: var(--ss-gold); }
.ss-breadcrumb span { margin: 0 6px; }

/* Header */
.ss-single__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 32px;
}
.ss-single__left { flex: 1; }
.ss-single__typ {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .08em;
  color: var(--ss-gold);
  text-transform: uppercase;
  margin-bottom: 8px;
  font-family: var(--ss-font);
}
.ss-single__title {
  font-size: 32px;
  font-weight: 900;
  color: var(--ss-navy);
  margin: 0 0 12px;
  line-height: 1.2;
  font-family: var(--ss-font);
}
.ss-single__badges { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 10px; }
.ss-single__right { text-align: right; }
.ss-single__cena {
  font-size: 34px;
  font-weight: 900;
  color: var(--ss-gold);
  line-height: 1.1;
  font-family: var(--ss-font);
}
.ss-single__cena-m2 {
  font-size: 14px;
  color: var(--ss-mid);
  margin-top: 4px;
  font-family: var(--ss-font);
}

/* Galerie */
.ss-gallery {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 6px;
  border-radius: var(--ss-radius);
  overflow: hidden;
  margin-bottom: 40px;
  max-height: 500px;
}
.ss-gallery__main { aspect-ratio: 16/10; overflow: hidden; }
.ss-gallery__side { display: grid; grid-template-rows: 1fr 1fr; gap: 6px; }
.ss-gallery__main img,
.ss-gallery__side-img img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  cursor: pointer; transition: filter .2s;
}
.ss-gallery__main img:hover,
.ss-gallery__side-img img:hover { filter: brightness(.88); }
.ss-gallery__all-btn { position: relative; }
.ss-gallery__all-btn::after {
  content: attr(data-count);
  position: absolute; inset: 0;
  background: rgba(26,26,46,.5);
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 16px; font-weight: 800;
  cursor: pointer; font-family: var(--ss-font);
}

/* Layout těla */
.ss-single__body {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 40px;
  align-items: start;
}

/* Parametry */
.ss-params {
  background: var(--ss-bg);
  border-radius: var(--ss-radius);
  padding: 28px;
  margin-bottom: 32px;
}
.ss-params__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}
.ss-params__item {
  padding: 12px 0;
  border-bottom: 1px solid var(--ss-line);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
}
.ss-params__item:last-child { border-bottom: none; }
.ss-params__label {
  font-size: 11px;
  color: var(--ss-light);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  font-family: var(--ss-font);
  flex-shrink: 0;
}
.ss-params__value {
  font-size: 14px;
  color: var(--ss-navy);
  font-weight: 700;
  text-align: right;
  font-family: var(--ss-font);
}

/* Popis */
.ss-single__desc {
  font-size: 15px;
  line-height: 1.8;
  color: var(--ss-mid);
  margin-bottom: 32px;
  font-family: var(--ss-font);
}
.ss-single__desc p { margin: 0 0 1em; }

/* Sidebar kontakt */
.ss-contact-box {
  background: var(--ss-white);
  border: 2px solid var(--ss-line);
  border-radius: var(--ss-radius);
  padding: 28px;
  position: sticky;
  top: 90px;
  font-family: var(--ss-font);
}
.ss-contact-box:hover { border-color: var(--ss-gold); }
.ss-contact-box__title {
  font-size: 13px;
  font-weight: 800;
  color: var(--ss-navy);
  text-transform: uppercase;
  letter-spacing: .07em;
  margin-bottom: 18px;
  font-family: var(--ss-font);
}
.ss-contact-box__id {
  font-size: 12px;
  color: var(--ss-light);
  margin-bottom: 20px;
}
.ss-contact-box__phone {
  display: block;
  font-size: 22px;
  font-weight: 800;
  color: var(--ss-navy);
  text-decoration: none;
  margin-bottom: 10px;
  transition: var(--ss-trans);
  font-family: var(--ss-font);
}
.ss-contact-box__phone:hover { color: var(--ss-gold); }
.ss-contact-box__email {
  display: block;
  font-size: 14px;
  color: var(--ss-gold);
  text-decoration: none;
  margin-bottom: 22px;
  font-weight: 600;
}
.ss-contact-box__btn {
  display: block;
  width: 100%;
  padding: 14px;
  background: var(--ss-gold);
  color: #fff;
  text-align: center;
  border-radius: 50px;
  font-size: 14px;
  font-weight: 800;
  font-family: var(--ss-font);
  text-decoration: none;
  transition: var(--ss-trans);
  border: 2px solid var(--ss-gold);
  cursor: pointer;
  margin-bottom: 10px;
  box-sizing: border-box;
}
.ss-contact-box__btn:hover { background: var(--ss-gold-dk); border-color: var(--ss-gold-dk); color: #fff; }
.ss-contact-box__btn--outline {
  background: transparent;
  color: var(--ss-navy);
  border: 2px solid var(--ss-line);
  margin-bottom: 0;
}
.ss-contact-box__btn--outline:hover { border-color: var(--ss-navy); background: var(--ss-bg); }

/* Mapa */
.ss-map {
  border-radius: var(--ss-radius);
  overflow: hidden;
  margin-bottom: 32px;
  height: 300px;
}
.ss-map iframe { width: 100%; height: 100%; border: 0; display: block; }

/* Video */
.ss-iframe-wrap {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  border-radius: var(--ss-radius);
  margin-bottom: 32px;
}
.ss-iframe-wrap iframe {
  position: absolute; top: 0; left: 0;
  width: 100%; height: 100%; border: 0;
}

/* Lightbox */
.ss-lightbox {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(26,26,46,.95);
  align-items: center;
  justify-content: center;
}
.ss-lightbox.is-open { display: flex; }
.ss-lightbox__img {
  max-width: 90vw;
  max-height: 90vh;
  object-fit: contain;
  border-radius: 10px;
  display: block;
}
.ss-lightbox__close,
.ss-lightbox__prev,
.ss-lightbox__next {
  position: fixed;
  background: rgba(255,255,255,.12);
  border: none;
  color: #fff;
  font-size: 22px;
  cursor: pointer;
  border-radius: 50%;
  width: 48px; height: 48px;
  display: flex; align-items: center; justify-content: center;
  transition: var(--ss-trans);
  z-index: 10000;
}
.ss-lightbox__close:hover,
.ss-lightbox__prev:hover,
.ss-lightbox__next:hover { background: var(--ss-gold); }
.ss-lightbox__close { top: 20px; right: 20px; }
.ss-lightbox__prev  { left: 20px; top: 50%; transform: translateY(-50%); }
.ss-lightbox__next  { right: 20px; top: 50%; transform: translateY(-50%); }
.ss-lightbox__counter {
  position: fixed;
  bottom: 20px; left: 50%;
  transform: translateX(-50%);
  color: rgba(255,255,255,.5);
  font-size: 13px;
  font-family: var(--ss-font);
}

/* ── ARCHIV ───────────────────────────────── */
.ss-archive {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px 60px;
  font-family: var(--ss-font);
}
.ss-archive__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 10px;
  flex-wrap: wrap;
  gap: 12px;
}
.ss-archive__title {
  font-size: 34px;
  font-weight: 900;
  color: var(--ss-navy);
  margin: 0;
  font-family: var(--ss-font);
}
.ss-archive__count {
  font-size: 13px;
  color: var(--ss-light);
  font-family: var(--ss-font);
}

/* ── RESPONSIVE ───────────────────────────── */
@media (max-width: 900px) {
  .ss-single__body { grid-template-columns: 1fr; }
  .ss-gallery { grid-template-columns: 1fr; }
  .ss-gallery__side { grid-template-rows: none; grid-template-columns: 1fr 1fr; }
  .ss-single__header { flex-direction: column; }
  .ss-single__right { text-align: left; }
}
@media (max-width: 600px) {
  .ss-grid { grid-template-columns: 1fr; }
  .ss-params__grid { grid-template-columns: 1fr; }
  .ss-gallery__side { display: none; }
  .ss-single__cena { font-size: 26px; }
  .ss-single__title { font-size: 24px; }
}
