/* WV3 Nemovitosti — Frontend styles */
/* Theme inherits container, btn, section padding from base. */

/* ============================================================
   ARCHIVE (/nemovitosti/)
   ============================================================ */

.wv3-properties-archive__hero {
	background: var(--wv3-bg-light, #f8f9fa);
	padding: var(--wv3-space-xl, 48px) 0 var(--wv3-space-lg, 32px);
}
.wv3-properties-archive__title {
	font-size: clamp(28px, 4vw, 42px);
	margin: 0 0 8px;
	font-family: var(--wv3-font-heading, inherit);
}
.wv3-properties-archive__count {
	font-size: 16px;
	color: var(--wv3-text-muted, #646970);
	margin: 0;
}

.wv3-properties-archive__filters { padding-top: var(--wv3-space-md, 24px); padding-bottom: var(--wv3-space-md, 24px); }
.wv3-properties-archive__filter-row {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	margin-bottom: 12px;
}
.wv3-properties-archive__filter-row--secondary { opacity: 0.85; }

.wv3-properties-archive__pill {
	display: inline-flex;
	align-items: center;
	padding: 8px 16px;
	border-radius: 999px;
	border: 1px solid var(--wv3-border, #dcdcde);
	background: var(--wv3-bg, #fff);
	color: var(--wv3-text, #1d2327);
	text-decoration: none;
	font-size: 14px;
	font-weight: 500;
	transition: all 0.2s;
}
.wv3-properties-archive__pill:hover {
	border-color: var(--wv3-primary, #E7A141);
	color: var(--wv3-primary, #E7A141);
}
.wv3-properties-archive__pill--active {
	background: var(--wv3-primary, #E7A141);
	color: #fff;
	border-color: var(--wv3-primary, #E7A141);
}
.wv3-properties-archive__pill--sub { font-size: 13px; padding: 6px 14px; }

.wv3-properties-archive__listings { padding-top: 0; }

.wv3-properties-archive__empty {
	text-align: center;
	padding: 60px 20px;
	color: var(--wv3-text-muted, #646970);
}

.wv3-properties-archive__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	margin-bottom: 32px;
}
@media (max-width: 900px) { .wv3-properties-archive__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .wv3-properties-archive__grid { grid-template-columns: 1fr; } }

.wv3-properties-archive__pagination {
	display: flex;
	justify-content: center;
	gap: 4px;
	margin-top: 24px;
	flex-wrap: wrap;
}
.wv3-properties-archive__pag-link {
	display: inline-block;
	padding: 8px 14px;
	border: 1px solid var(--wv3-border, #dcdcde);
	border-radius: 6px;
	text-decoration: none;
	color: var(--wv3-text, #1d2327);
	font-size: 14px;
}
.wv3-properties-archive__pag-link--active {
	background: var(--wv3-primary, #E7A141);
	color: #fff;
	border-color: var(--wv3-primary, #E7A141);
}

/* ============================================================
   PROPERTY CARD (sdílená archive + section + related)
   ============================================================ */

.wv3-property-card {
	display: flex;
	flex-direction: column;
	background: var(--wv3-bg-light, #f8f9fa);
	border: 1px solid transparent;
	border-radius: 12px;
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	transition: transform 0.2s, border-color 0.2s;
}
/* MINIMAL: archive listings section je bg-light (gray) → karta bg (white) */
.template-minimal .wv3-property-card {
	background: var(--wv3-bg, #fff);
	border-color: var(--wv3-border, #dcdcde);
}
.wv3-property-card:hover {
	transform: translateY(-2px);
	border-color: var(--wv3-primary, #E7A141);
}
.wv3-property-card--sold { opacity: 0.7; }
.wv3-property-card--sold:hover { transform: none; }

.wv3-property-card__image {
	position: relative;
	aspect-ratio: 4 / 3;
	background: var(--wv3-bg-light, #f8f9fa);
	overflow: hidden;
}
.wv3-property-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.wv3-property-card__ribbon {
	position: absolute;
	top: 14px;
	left: 14px;
	background: #c1393d;
	color: #fff;
	padding: 6px 14px;
	border-radius: 4px;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.05em;
}
.wv3-property-card__ref {
	position: absolute;
	bottom: 14px;
	right: 14px;
	background: rgba(0,0,0,0.7);
	color: #fff;
	padding: 4px 10px;
	border-radius: 4px;
	font-size: 12px;
	font-weight: 500;
}

.wv3-property-card__body { padding: 16px 18px 18px; }
.wv3-property-card__type {
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--wv3-primary, #E7A141);
	font-weight: 600;
	margin-bottom: 4px;
}
.wv3-property-card__title {
	font-size: 17px;
	margin: 0 0 8px;
	font-family: var(--wv3-font-heading, inherit);
	line-height: 1.3;
}
.wv3-property-card__meta {
	display: flex;
	gap: 12px;
	font-size: 13px;
	color: var(--wv3-text-muted, #646970);
	margin-bottom: 10px;
	flex-wrap: wrap;
}
.wv3-property-card__city { font-weight: 500; color: var(--wv3-text, #1d2327); }
.wv3-property-card__price {
	font-size: 18px;
	font-weight: 700;
	color: var(--wv3-text, #1d2327);
}

/* ============================================================
   DETAIL (/nemovitost/{slug}/) — 2-col layout sticky sidebar
   ============================================================ */

.wv3-section.wv3-property__layout-section { padding: 24px 0 var(--wv3-space-xl, 32px); }
.wv3-property__layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 360px;
	gap: 40px;
	align-items: start;
}
.wv3-property__layout-main {
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 36px;
}
.wv3-property__layout-side {
	position: sticky;
	top: 100px;
	align-self: start;
}
@media (max-width: 900px) {
	.wv3-property__layout { grid-template-columns: 1fr; gap: 24px; }
	.wv3-property__layout-side { position: static; }
}

/* Header: tight breadcrumb + title + chips. */
.wv3-property__breadcrumb { margin-bottom: 6px; }
.wv3-property__title { margin: 0 0 10px; }
.wv3-property-chips--detail { margin: 0 0 4px; }

/* Detail section titles (Vlastnosti, Popis, Lokalita, …) — left-aligned incl. underline. */
.wv3-property .wv3-section__title {
	text-align: left;
}
.wv3-property .wv3-section__title::after {
	margin-left: 0 !important;
	margin-right: auto !important;
}

/* Galerie jako horizontal slider — scroll-snap + prev/next ovládání. */
.wv3-property__gallery {
	position: relative;
	margin: 0;
}
.wv3-property__gallery-track {
	display: flex;
	gap: 8px;
	overflow-x: auto;
	overflow-y: hidden;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	border-radius: 12px;
	scrollbar-width: none;
}
.wv3-property__gallery-track::-webkit-scrollbar { display: none; }
.wv3-property__gallery-item {
	display: block;
	position: relative;
	flex: 0 0 100%;
	scroll-snap-align: start;
	aspect-ratio: 16 / 10;
	background: var(--wv3-bg-light, #f8f9fa);
	border-radius: 12px;
	overflow: hidden;
}
.wv3-property__gallery-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Prev/next buttons */
.wv3-property__gallery-nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.92);
	border: none;
	color: var(--wv3-text, #1d2327);
	font-size: 22px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 3;
	transition: background 0.2s;
}
.wv3-property__gallery-nav:hover { background: #fff; }
.wv3-property__gallery-nav--prev { left: 12px; }
.wv3-property__gallery-nav--next { right: 12px; }
.wv3-property__gallery-nav:disabled { opacity: 0.4; cursor: default; }

/* Dots */
.wv3-property__gallery-dots {
	position: absolute;
	bottom: 14px;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	gap: 6px;
	z-index: 3;
}
.wv3-property__gallery-dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.55);
	border: none;
	cursor: pointer;
	padding: 0;
	transition: background 0.2s, transform 0.2s;
}
.wv3-property__gallery-dot--active {
	background: #fff;
	transform: scale(1.3);
}

/* Counter (e.g. "1 / 12") */
.wv3-property__gallery-counter {
	position: absolute;
	top: 14px;
	right: 14px;
	background: rgba(0, 0, 0, 0.65);
	color: #fff;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 500;
	z-index: 3;
}

.wv3-property__ribbon {
	position: absolute;
	top: 20px;
	left: 20px;
	background: #c1393d;
	color: #fff;
	padding: 10px 22px;
	border-radius: 4px;
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 0.05em;
	z-index: 2;
}
.wv3-property__ribbon--reserved { background: #e5b800; color: #1d2327; }

.wv3-property__breadcrumb a { color: inherit; text-decoration: none; font-size: 13px; color: var(--wv3-text-muted, #646970); }
.wv3-property__breadcrumb { font-size: 13px; color: var(--wv3-text-muted, #646970); }
.wv3-property__breadcrumb a:hover { color: var(--wv3-primary, #E7A141); }
.wv3-property__breadcrumb .sep { margin: 0 6px; opacity: 0.5; }

.wv3-property__title {
	font-size: clamp(22px, 2.8vw, 30px);
	font-family: var(--wv3-font-heading, inherit);
	line-height: 1.25;
}
.wv3-property__ref { font-size: 14px; font-weight: 400; opacity: 0.6; margin-left: 8px; white-space: nowrap; }

/* Slightly larger chips on detail vs cards */
.wv3-property-chips--detail .wv3-property-chip {
	font-size: 13px;
	padding: 6px 14px;
}

.wv3-property__price-card {
	background: var(--wv3-bg, #fff);
	border: 1px solid var(--wv3-border, #dcdcde);
	border-radius: 12px;
	padding: 24px;
}
.wv3-property__price-main {
	font-size: clamp(24px, 3vw, 32px);
	font-weight: 700;
	color: var(--wv3-text, #1d2327);
	margin-bottom: 4px;
}
.wv3-property__price-note { font-size: 13px; color: var(--wv3-text-muted, #646970); margin-bottom: 16px; }

.wv3-property__rental-details {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 6px 12px;
	margin: 16px 0;
	font-size: 14px;
}
.wv3-property__rental-details dt { color: var(--wv3-text-muted, #646970); }
.wv3-property__rental-details dd { margin: 0; font-weight: 500; }

.wv3-property__cta {
	display: block;
	text-align: center;
	margin-top: 16px;
	width: 100%;
}
.wv3-property__sold-note {
	text-align: center;
	padding: 12px;
	background: var(--wv3-bg-light, #f8f9fa);
	border-radius: 8px;
	color: var(--wv3-text-muted, #646970);
	font-style: italic;
	margin-top: 16px;
}

/* ============================================================
   PARAMETER TABLE — the user-requested feature
   ============================================================ */

.wv3-property__params-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px;
	margin-top: 20px;
}
@media (max-width: 1200px) { .wv3-property__params-grid { grid-template-columns: 1fr; } }

.wv3-property__params-group {
	background: var(--wv3-bg, #fff);
	border: 1px solid var(--wv3-border, #dcdcde);
	border-radius: 12px;
	padding: 20px 24px;
}
.wv3-property__params-group h3 {
	font-size: 14px;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin: 0 0 12px;
	color: var(--wv3-primary, #E7A141);
	font-weight: 700;
}
.wv3-property__params-group--amenities { grid-column: 1 / -1; }

.wv3-property__params-list {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 8px 16px;
	margin: 0;
	font-size: 14px;
}
.wv3-property__params-list dt {
	color: var(--wv3-text-muted, #646970);
	font-weight: 400;
}
.wv3-property__params-list dd {
	margin: 0;
	font-weight: 500;
	color: var(--wv3-text, #1d2327);
}

.wv3-property__amenities {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.wv3-property__amenity {
	display: inline-flex;
	align-items: center;
	padding: 6px 14px;
	border-radius: 999px;
	background: var(--wv3-primary-lighter, rgba(231, 161, 65, 0.1));
	color: var(--wv3-primary, #E7A141);
	font-size: 13px;
	font-weight: 500;
}

/* ============================================================
   Popis, mapa, virtuálka, inquiry, related
   ============================================================ */

.wv3-property__description { padding-top: var(--wv3-space-lg, 32px); padding-bottom: var(--wv3-space-lg, 32px); }
.wv3-property__description-text { font-size: 15px; line-height: 1.7; max-width: 760px; }
.wv3-property__description-text p { margin-bottom: 14px; }

.wv3-property__map-section { padding-top: var(--wv3-space-lg, 32px); padding-bottom: var(--wv3-space-lg, 32px); }
.wv3-property__map-note { margin-top: 12px; font-size: 13px; color: var(--wv3-text-muted, #646970); }

.wv3-property__virtualka { padding-top: var(--wv3-space-lg, 32px); padding-bottom: var(--wv3-space-lg, 32px); }
.wv3-property__virtualka-frame {
	aspect-ratio: 16 / 9;
	border-radius: 12px;
	overflow: hidden;
}
.wv3-property__virtualka-frame iframe {
	width: 100%;
	height: 100%;
	border: none;
}

.wv3-property__inquiry {
	padding-top: var(--wv3-space-lg, 32px);
	padding-bottom: var(--wv3-space-lg, 32px);
	background: var(--wv3-bg-light, #f8f9fa);
}
.wv3-property__inquiry-form { max-width: 760px; }
.wv3-property__inquiry-row {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 12px;
	margin-bottom: 12px;
}
.wv3-property__inquiry-form label { display: block; margin-bottom: 12px; }
.wv3-property__inquiry-form label > span {
	display: block;
	font-size: 13px;
	font-weight: 500;
	margin-bottom: 4px;
}
.wv3-property__inquiry-form input,
.wv3-property__inquiry-form textarea {
	width: 100%;
	padding: 10px 14px;
	border: 1px solid var(--wv3-border, #dcdcde);
	border-radius: 6px;
	font-size: 15px;
	font-family: inherit;
}
.wv3-property__inquiry-form input:focus,
.wv3-property__inquiry-form textarea:focus {
	outline: none;
	border-color: var(--wv3-primary, #E7A141);
}
.wv3-property__inquiry-form button { margin-top: 8px; }
.wv3-property__inquiry-result {
	margin-top: 12px;
	padding: 12px 16px;
	border-radius: 6px;
	font-size: 14px;
	display: none;
}
.wv3-property__inquiry-result--success {
	display: block;
	background: #d1f4d4;
	color: #1f5828;
}
.wv3-property__inquiry-result--error {
	display: block;
	background: #f8d7da;
	color: #721c24;
}

.wv3-property__related { padding-top: var(--wv3-space-lg, 32px); padding-bottom: var(--wv3-space-lg, 32px); }
.wv3-property__related-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
	margin-top: 20px;
}
@media (max-width: 900px) { .wv3-property__related-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .wv3-property__related-grid { grid-template-columns: 1fr; } }

/* ============================================================
   Homepage section
   ============================================================ */

.wv3-properties__grid {
	display: grid;
	gap: 24px;
	margin-top: 32px;
}
.wv3-properties__grid--2 { grid-template-columns: repeat(2, 1fr); }
.wv3-properties__grid--3 { grid-template-columns: repeat(3, 1fr); }
.wv3-properties__grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) { .wv3-properties__grid { grid-template-columns: repeat(2, 1fr) !important; } }
@media (max-width: 600px) { .wv3-properties__grid { grid-template-columns: 1fr !important; } }

.wv3-properties__card {
	display: flex;
	flex-direction: column;
	background: var(--wv3-bg, #fff);
	border: 1px solid var(--wv3-border, #dcdcde);
	border-radius: 12px;
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	transition: transform 0.2s, border-color 0.2s;
}
.wv3-properties__card:hover {
	transform: translateY(-2px);
	border-color: var(--wv3-primary, #E7A141);
}
.wv3-properties__card--sold { opacity: 0.7; }
.wv3-properties__card-image {
	position: relative;
	aspect-ratio: 4 / 3;
	overflow: hidden;
}
.wv3-properties__card-image img { width: 100%; height: 100%; object-fit: cover; }
.wv3-properties__card-ribbon {
	position: absolute;
	top: 14px;
	left: 14px;
	background: #c1393d;
	color: #fff;
	padding: 6px 14px;
	border-radius: 4px;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.05em;
}
.wv3-properties__card-ref {
	position: absolute;
	bottom: 14px;
	right: 14px;
	background: rgba(0,0,0,0.7);
	color: #fff;
	padding: 4px 10px;
	border-radius: 4px;
	font-size: 12px;
}
.wv3-properties__card-body { padding: 16px 18px 18px; }
.wv3-properties__card-type {
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--wv3-primary, #E7A141);
	font-weight: 600;
	margin-bottom: 4px;
}
.wv3-properties__card-title { font-size: 17px; margin: 0 0 8px; line-height: 1.3; }
.wv3-properties__card-meta {
	display: flex;
	gap: 12px;
	font-size: 13px;
	color: var(--wv3-text-muted, #646970);
	margin-bottom: 10px;
}
.wv3-properties__card-price { font-size: 18px; font-weight: 700; }
