/**
 * Novogradnja public landing page — scoped styles (D-06).
 *
 * Everything lives under the .ir-novogradnja-* namespace. This sheet CONSUMES the
 * global design tokens declared in assets/css/ir-components.css (--ir-space-*,
 * --ir-radius-*, --ir-success/-warning/-danger, --ir-gray-*, --ir-font-weight-*,
 * --ir-font-family) and NEVER redefines them. The only custom properties declared
 * here are the scoped Heroldo brand values, set on the .ir-novogradnja-landing
 * wrapper by the composer template (single-ir_novogradnja.php).
 *
 * Owned by Plan 04-03; consumed by every later landing partial (04-04/05/06).
 *
 * @package IntelliRealty
 */

/* -------------------------------------------------------------------------
 * Scoped brand custom properties — declared on the wrapper (inline by the
 * composer) with sensible fallbacks here so the sheet is self-sufficient even
 * if the inline style is stripped.
 * ------------------------------------------------------------------------- */
.ir-novogradnja-landing {
	--ir-novogradnja-primary: #00629D;
	--ir-novogradnja-accent: #F37021;
	--ir-novogradnja-link: #0089CF;
	--ir-novogradnja-surface: #FFFFFF;
	--ir-novogradnja-surface-alt: var(--ir-gray-50);

	background: var(--ir-novogradnja-surface);
	color: var(--ir-gray-900);
	font-family: var(--ir-font-family);
	font-weight: var(--ir-font-weight-normal);
	font-size: 16px;
	line-height: 1.5;
}

/* -------------------------------------------------------------------------
 * Section rhythm contract (UI-SPEC §Spacing): mobile 48px, desktop 64px.
 * ------------------------------------------------------------------------- */
.ir-novogradnja-section {
	padding-block: var(--ir-space-6);
	padding-inline: var(--ir-space-3);
}

@media (min-width: 768px) {
	.ir-novogradnja-section {
		padding-block: var(--ir-space-7);
	}
}

.ir-novogradnja-landing :where(*) {
	box-sizing: border-box;
}

/* -------------------------------------------------------------------------
 * Typography roles — exactly 4 sizes / 2 weights (UI-SPEC §Typography).
 * ------------------------------------------------------------------------- */
.ir-novogradnja-display {
	font-size: 28px;
	font-weight: var(--ir-font-weight-semibold);
	line-height: 1.2;
}

.ir-novogradnja-heading {
	font-size: 20px;
	font-weight: var(--ir-font-weight-semibold);
	line-height: 1.2;
	color: var(--ir-gray-900);
}

.ir-novogradnja-label {
	font-size: 14px;
	font-weight: var(--ir-font-weight-semibold);
	line-height: 1.4;
}

.ir-novogradnja-body {
	font-size: 16px;
	font-weight: var(--ir-font-weight-normal);
	line-height: 1.5;
}

.ir-novogradnja-muted {
	color: var(--ir-gray-600);
}

.ir-novogradnja-link,
.ir-novogradnja-landing a {
	color: var(--ir-novogradnja-link);
}

/* -------------------------------------------------------------------------
 * Status badge pills (LAND-07). Pill, uppercase, 14/600. rezervisano uses dark
 * text on amber (yellow-on-white fails contrast — UI-SPEC mandate).
 * ------------------------------------------------------------------------- */
.ir-novogradnja-badge {
	display: inline-block;
	padding: var(--ir-space-1) var(--ir-space-2);
	border-radius: var(--ir-radius-full);
	font-size: 14px;
	font-weight: var(--ir-font-weight-semibold);
	line-height: 1.4;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	white-space: nowrap;
}

.ir-novogradnja-badge--dostupno {
	background: var(--ir-success-light);
	color: var(--ir-success);
}

.ir-novogradnja-badge--rezervisano {
	background: var(--ir-warning);
	color: var(--ir-gray-900);
}

.ir-novogradnja-badge--prodato {
	background: var(--ir-danger-light);
	color: var(--ir-danger);
}

/* -------------------------------------------------------------------------
 * Accent reserved-list buttons (UI-SPEC §Color accent list). Orange is reserved;
 * do NOT apply --ir-novogradnja-accent outside these classes.
 * ------------------------------------------------------------------------- */
.ir-novogradnja-btn-accent {
	display: inline-block;
	padding: var(--ir-space-2) var(--ir-space-4);
	border: none;
	border-radius: var(--ir-radius-md);
	background: var(--ir-novogradnja-accent);
	color: #ffffff;
	font-size: 14px;
	font-weight: var(--ir-font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	text-decoration: none;
	cursor: pointer;
}

/* Reset control (accent reserved-list item #3) — outline variant. */
.ir-novogradnja-btn-reset {
	display: inline-block;
	padding: var(--ir-space-2) var(--ir-space-4);
	border: 1px solid var(--ir-novogradnja-accent);
	border-radius: var(--ir-radius-md);
	background: transparent;
	color: var(--ir-novogradnja-accent);
	font-size: 14px;
	font-weight: var(--ir-font-weight-semibold);
	cursor: pointer;
}

/* -------------------------------------------------------------------------
 * Units table (LAND-05/06). Horizontal scroll container on mobile — do not
 * break columns (UI-SPEC §Responsive).
 * ------------------------------------------------------------------------- */
.ir-novogradnja-units {
	display: block;
}

.ir-novogradnja-units-controls {
	display: flex;
	flex-wrap: wrap;
	gap: var(--ir-space-3);
	align-items: center;
	margin-bottom: var(--ir-space-4);
}

.ir-novogradnja-units-controls select {
	padding: var(--ir-space-2) var(--ir-space-3);
	border: 1px solid var(--ir-gray-300);
	border-radius: var(--ir-radius-md);
	font-family: var(--ir-font-family);
	font-size: 16px;
	color: var(--ir-gray-900);
	background: var(--ir-novogradnja-surface);
}

.ir-novogradnja-units-count {
	font-size: 14px;
	font-weight: var(--ir-font-weight-semibold);
	color: var(--ir-gray-600);
	margin-left: auto;
}

.ir-novogradnja-table-scroll {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.ir-novogradnja-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 16px;
}

.ir-novogradnja-table thead th {
	padding: var(--ir-space-3);
	text-align: left;
	font-size: 14px;
	font-weight: var(--ir-font-weight-semibold);
	color: #ffffff;
	background: var(--ir-novogradnja-primary);
	white-space: nowrap;
}

.ir-novogradnja-table tbody td {
	padding: var(--ir-space-3);
	border-bottom: 1px solid var(--ir-gray-200);
	vertical-align: middle;
}

.ir-novogradnja-table tbody tr[hidden] {
	display: none;
}

.ir-novogradnja-table a {
	color: var(--ir-novogradnja-link);
	text-decoration: none;
}

.ir-novogradnja-table a:hover {
	text-decoration: underline;
}

.ir-novogradnja-filter-empty {
	padding: var(--ir-space-4);
	text-align: center;
	color: var(--ir-gray-600);
}

/* -------------------------------------------------------------------------
 * Empty state (the one visible empty state — UI-SPEC). #stanovi must resolve.
 * ------------------------------------------------------------------------- */
.ir-novogradnja-empty {
	text-align: center;
	padding-block: var(--ir-space-5);
}

.ir-novogradnja-empty .ir-novogradnja-heading {
	margin-bottom: var(--ir-space-3);
}

.ir-novogradnja-empty .ir-novogradnja-body {
	color: var(--ir-gray-600);
	max-width: 42rem;
	margin-inline: auto;
}

/* -------------------------------------------------------------------------
 * Floor-plan / 360 modal (D-07). Markup emitted once via wp_footer; opened by JS.
 * ------------------------------------------------------------------------- */
.ir-novogradnja-modal {
	position: fixed;
	inset: 0;
	z-index: 99999;
	display: none;
	align-items: center;
	justify-content: center;
	padding: var(--ir-space-3);
	background: rgba(0, 0, 0, 0.6);
}

.ir-novogradnja-modal[aria-hidden="false"] {
	display: flex;
}

.ir-novogradnja-modal-content {
	background: var(--ir-novogradnja-surface);
	border-radius: var(--ir-radius-lg);
	max-width: 900px;
	width: 100%;
	max-height: 90vh;
	overflow: auto;
	padding: var(--ir-space-4);
}

.ir-novogradnja-modal-tabs {
	display: flex;
	flex-wrap: wrap;
	gap: var(--ir-space-2);
	margin-bottom: var(--ir-space-3);
	border-bottom: 1px solid var(--ir-gray-200);
}

.ir-novogradnja-modal-tab {
	padding: var(--ir-space-2) var(--ir-space-3);
	border: none;
	background: transparent;
	font-size: 14px;
	font-weight: var(--ir-font-weight-semibold);
	color: var(--ir-gray-600);
	cursor: pointer;
}

.ir-novogradnja-modal-tab[aria-selected="true"] {
	color: var(--ir-novogradnja-primary);
	border-bottom: 2px solid var(--ir-novogradnja-primary);
}

.ir-novogradnja-modal-panel[hidden] {
	display: none;
}

.ir-novogradnja-modal-panel img,
.ir-novogradnja-modal-panel iframe {
	max-width: 100%;
	width: 100%;
	border: 0;
}

.ir-novogradnja-modal-panel iframe {
	aspect-ratio: 16 / 9;
	min-height: 320px;
}

.ir-novogradnja-modal-close {
	float: right;
	border: none;
	background: transparent;
	font-size: 24px;
	line-height: 1;
	cursor: pointer;
	color: var(--ir-gray-600);
}

/* -------------------------------------------------------------------------
 * Contact form (D-11) — scoped fields + honeypot (visually hidden, never seen).
 * ------------------------------------------------------------------------- */
.ir-novogradnja-form {
	display: grid;
	gap: var(--ir-space-3);
	max-width: 640px;
	margin-inline: auto;
}

.ir-novogradnja-form label {
	display: block;
	font-size: 16px;
	margin-bottom: var(--ir-space-1);
}

.ir-novogradnja-form input[type="text"],
.ir-novogradnja-form input[type="email"],
.ir-novogradnja-form input[type="tel"],
.ir-novogradnja-form select,
.ir-novogradnja-form textarea {
	width: 100%;
	padding: var(--ir-space-2) var(--ir-space-3);
	border: 1px solid var(--ir-gray-300);
	border-radius: var(--ir-radius-md);
	font-family: var(--ir-font-family);
	font-size: 16px;
	color: var(--ir-gray-900);
}

.ir-novogradnja-form-consent {
	display: flex;
	align-items: flex-start;
	gap: var(--ir-space-2);
	font-size: 14px;
}

/* Honeypot: off-screen, never tab-reachable, never announced. */
.ir-novogradnja-hp {
	position: absolute;
	left: -9999px;
	top: auto;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

/* =========================================================================
 * Plan 04-04 — upper content sections (hero / stats / benefits / gallery /
 * description-media). Scoped under .ir-novogradnja-*; consumes the global
 * tokens + the scoped brand props declared by the composer wrapper.
 * ========================================================================= */

/* Smooth anchor-scroll for the hero CTAs (#stanovi / #kontakt) — CSS only. */
.ir-novogradnja-landing {
	scroll-behavior: smooth;
}

/* -------------------------------------------------------------------------
 * Hero (LAND-02). Primary visual; logo + headline + two accent CTAs.
 * ------------------------------------------------------------------------- */
.ir-novogradnja-hero {
	text-align: center;
	background: var(--ir-novogradnja-surface-alt);
}

.ir-novogradnja-hero-inner {
	max-width: 48rem;
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--ir-space-4);
}

.ir-novogradnja-hero-logo {
	max-width: 200px;
	max-height: 96px;
	width: auto;
	height: auto;
	object-fit: contain;
}

.ir-novogradnja-hero-headline {
	margin: 0;
	color: var(--ir-novogradnja-primary);
}

.ir-novogradnja-hero-cta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--ir-space-3);
	justify-content: center;
}

/* Outline variant of the accent button (secondary hero CTA). */
.ir-novogradnja-btn-accent--outline {
	background: transparent;
	color: var(--ir-novogradnja-accent);
	border: 1px solid var(--ir-novogradnja-accent);
}

/* -------------------------------------------------------------------------
 * Stats strip (LAND-03). Responsive tile grid; empties already filtered in PHP.
 * ------------------------------------------------------------------------- */
.ir-novogradnja-stats-grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--ir-space-3);
}

@media (min-width: 640px) {
	.ir-novogradnja-stats-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 960px) {
	.ir-novogradnja-stats-grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

.ir-novogradnja-stat {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--ir-space-1);
	padding: var(--ir-space-4) var(--ir-space-3);
	background: var(--ir-novogradnja-surface);
	border: 1px solid var(--ir-gray-200);
	border-radius: var(--ir-radius-lg);
	text-align: center;
}

.ir-novogradnja-stat-icon {
	width: 32px;
	height: 32px;
	margin-bottom: var(--ir-space-1);
}

.ir-novogradnja-stat-value {
	color: var(--ir-novogradnja-primary);
}

.ir-novogradnja-stat-caption {
	color: var(--ir-gray-600);
}

/* -------------------------------------------------------------------------
 * Benefit pillars (LAND-04). Icon + title + description cards.
 * ------------------------------------------------------------------------- */
.ir-novogradnja-benefits-grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--ir-space-4);
}

@media (min-width: 640px) {
	.ir-novogradnja-benefits-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 960px) {
	.ir-novogradnja-benefits-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.ir-novogradnja-benefit-card {
	padding: var(--ir-space-4);
	background: var(--ir-novogradnja-surface);
	border: 1px solid var(--ir-gray-200);
	border-radius: var(--ir-radius-lg);
}

.ir-novogradnja-benefit-icon {
	width: 40px;
	height: 40px;
	margin-bottom: var(--ir-space-3);
}

.ir-novogradnja-benefit-title {
	margin: 0 0 var(--ir-space-2);
}

.ir-novogradnja-benefit-desc {
	margin: 0;
	color: var(--ir-gray-600);
}

/* -------------------------------------------------------------------------
 * Gallery (LAND-08). Thumbnail grid; each item is a button trigger.
 * ------------------------------------------------------------------------- */
.ir-novogradnja-gallery-section .ir-novogradnja-heading {
	margin-bottom: var(--ir-space-4);
}

.ir-novogradnja-gallery {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--ir-space-2);
}

@media (min-width: 640px) {
	.ir-novogradnja-gallery {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 960px) {
	.ir-novogradnja-gallery {
		grid-template-columns: repeat(4, 1fr);
	}
}

.ir-novogradnja-gallery-item {
	display: block;
	padding: 0;
	margin: 0;
	border: none;
	background: none;
	cursor: pointer;
	border-radius: var(--ir-radius-md);
	overflow: hidden;
	aspect-ratio: 4 / 3;
}

.ir-novogradnja-gallery-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.2s ease;
}

.ir-novogradnja-gallery-item:hover img,
.ir-novogradnja-gallery-item:focus-visible img {
	transform: scale(1.04);
}

/* -------------------------------------------------------------------------
 * Gallery lightbox modal (scoped — D-06). Single shared node built by JS.
 * ------------------------------------------------------------------------- */
.ir-novogradnja-gallery-modal {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 99999;
}

.ir-novogradnja-gallery-modal[aria-hidden="false"] {
	display: block;
}

.ir-novogradnja-gallery-modal-overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.92);
}

.ir-novogradnja-gallery-modal-content {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	max-width: 92vw;
	max-height: 92vh;
	z-index: 1;
}

.ir-novogradnja-gallery-modal-img {
	max-width: 92vw;
	max-height: 88vh;
	object-fit: contain;
	display: block;
}

.ir-novogradnja-gallery-modal-close {
	position: absolute;
	top: -48px;
	right: 0;
	width: 44px;
	height: 44px;
	border: none;
	background: transparent;
	color: #ffffff;
	font-size: 36px;
	line-height: 1;
	cursor: pointer;
}

.ir-novogradnja-gallery-modal-arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 56px;
	height: 56px;
	border: none;
	border-radius: var(--ir-radius-full);
	background: rgba(0, 0, 0, 0.5);
	color: #ffffff;
	font-size: 32px;
	line-height: 1;
	cursor: pointer;
}

.ir-novogradnja-gallery-modal-prev {
	left: -68px;
}

.ir-novogradnja-gallery-modal-next {
	right: -68px;
}

@media (max-width: 768px) {
	.ir-novogradnja-gallery-modal-prev {
		left: var(--ir-space-2);
	}
	.ir-novogradnja-gallery-modal-next {
		right: var(--ir-space-2);
	}
}

/* -------------------------------------------------------------------------
 * Description + media (LAND-09). Rich text + responsive 16:9 media frame.
 * ------------------------------------------------------------------------- */
.ir-novogradnja-description-text {
	max-width: 52rem;
	margin-inline: auto;
}

.ir-novogradnja-description-text > :first-child {
	margin-top: 0;
}

.ir-novogradnja-media {
	display: grid;
	gap: var(--ir-space-4);
	max-width: 52rem;
	margin-inline: auto;
	margin-top: var(--ir-space-4);
}

.ir-novogradnja-media-frame {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 9;
	border-radius: var(--ir-radius-lg);
	overflow: hidden;
}

.ir-novogradnja-media-frame iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
}

.ir-novogradnja-media-link {
	margin: 0;
	text-align: center;
}

/* =========================================================================
 * Plan 04-05 — mid/lower content sections (standards / payment / process /
 * agent / faq). Scoped under .ir-novogradnja-*; consumes the global tokens +
 * the scoped brand props declared by the composer wrapper. Brand orange is
 * confined to the accent reserved-list: the payment discount label (#5), the
 * process step number (#4), and the open FAQ underline (#6).
 * ========================================================================= */

/* -------------------------------------------------------------------------
 * Standards grid (LAND-12). Icon + label (+ optional value) tiles.
 * ------------------------------------------------------------------------- */
.ir-novogradnja-standards-title,
.ir-novogradnja-payment-title,
.ir-novogradnja-process-title {
	margin: 0 0 var(--ir-space-4);
	color: var(--ir-novogradnja-primary);
	text-align: center;
}

.ir-novogradnja-standards-grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--ir-space-3);
}

@media (min-width: 640px) {
	.ir-novogradnja-standards-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 960px) {
	.ir-novogradnja-standards-grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

.ir-novogradnja-standard {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--ir-space-1);
	padding: var(--ir-space-4) var(--ir-space-3);
	background: var(--ir-novogradnja-surface);
	border: 1px solid var(--ir-gray-200);
	border-radius: var(--ir-radius-lg);
	text-align: center;
}

.ir-novogradnja-standard-icon {
	width: 32px;
	height: 32px;
	margin-bottom: var(--ir-space-1);
}

.ir-novogradnja-standard-label {
	color: var(--ir-gray-900);
}

.ir-novogradnja-standard-value {
	color: var(--ir-gray-600);
}

/* -------------------------------------------------------------------------
 * Payment models (LAND-13). 3-col cards on >=768px, stacked below. The orange
 * discount label is accent reserved-list item #5.
 * ------------------------------------------------------------------------- */
.ir-novogradnja-payment-grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--ir-space-4);
}

@media (min-width: 768px) {
	.ir-novogradnja-payment-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.ir-novogradnja-payment-card {
	position: relative;
	padding: var(--ir-space-4);
	background: var(--ir-novogradnja-surface);
	border: 1px solid var(--ir-gray-200);
	border-radius: var(--ir-radius-lg);
}

.ir-novogradnja-discount {
	display: inline-block;
	margin-bottom: var(--ir-space-2);
	padding: var(--ir-space-1) var(--ir-space-2);
	border-radius: var(--ir-radius-full);
	background: var(--ir-novogradnja-accent);
	color: #ffffff;
	font-size: 14px;
	font-weight: var(--ir-font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.ir-novogradnja-payment-card-title {
	margin: 0 0 var(--ir-space-2);
}

.ir-novogradnja-payment-card-desc {
	margin: 0;
	color: var(--ir-gray-600);
}

/* -------------------------------------------------------------------------
 * Purchase process (LAND-14). Numbered step flow; the orange step number is
 * accent reserved-list item #4.
 * ------------------------------------------------------------------------- */
.ir-novogradnja-process-list {
	list-style: none;
	margin: 0;
	padding: 0;
	max-width: 48rem;
	margin-inline: auto;
	display: grid;
	gap: var(--ir-space-4);
}

.ir-novogradnja-step {
	display: flex;
	align-items: flex-start;
	gap: var(--ir-space-3);
}

.ir-novogradnja-step__num {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: var(--ir-radius-full);
	background: var(--ir-novogradnja-accent);
	color: #ffffff;
	font-size: 20px;
	font-weight: var(--ir-font-weight-semibold);
	line-height: 1;
}

.ir-novogradnja-step__body {
	flex: 1 1 auto;
}

.ir-novogradnja-step__title {
	margin: 0 0 var(--ir-space-1);
}

.ir-novogradnja-step__desc {
	margin: 0;
	color: var(--ir-gray-600);
}

/* -------------------------------------------------------------------------
 * Agent card (LAND-15). Photo + name/role/bio + contact deep-links. Action
 * links are >=44px tap targets (UI-SPEC); the links use the brand LINK blue
 * (not accent orange — orange stays on the reserved-list only).
 * ------------------------------------------------------------------------- */
.ir-novogradnja-agent-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--ir-space-3);
	max-width: 40rem;
	margin-inline: auto;
	padding: var(--ir-space-5) var(--ir-space-4);
	background: var(--ir-novogradnja-surface-alt);
	border: 1px solid var(--ir-gray-200);
	border-radius: var(--ir-radius-lg);
	text-align: center;
}

@media (min-width: 640px) {
	.ir-novogradnja-agent-card {
		flex-direction: row;
		align-items: flex-start;
		text-align: left;
	}
}

.ir-novogradnja-agent-photo {
	width: 96px;
	height: 96px;
	border-radius: var(--ir-radius-full);
	object-fit: cover;
	flex: 0 0 auto;
}

.ir-novogradnja-agent-body {
	flex: 1 1 auto;
}

.ir-novogradnja-agent-name {
	margin: 0 0 var(--ir-space-1);
	color: var(--ir-novogradnja-primary);
}

.ir-novogradnja-agent-role {
	margin: 0 0 var(--ir-space-2);
	color: var(--ir-gray-600);
}

.ir-novogradnja-agent-bio {
	margin: 0 0 var(--ir-space-3);
}

.ir-novogradnja-agent-actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--ir-space-2);
	justify-content: center;
}

@media (min-width: 640px) {
	.ir-novogradnja-agent-actions {
		justify-content: flex-start;
	}
}

.ir-novogradnja-agent-action {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	min-width: 44px;
	padding: var(--ir-space-2) var(--ir-space-4);
	border: 1px solid var(--ir-novogradnja-link);
	border-radius: var(--ir-radius-md);
	background: var(--ir-novogradnja-surface);
	color: var(--ir-novogradnja-link);
	font-size: 14px;
	font-weight: var(--ir-font-weight-semibold);
	text-decoration: none;
}

.ir-novogradnja-agent-action:hover,
.ir-novogradnja-agent-action:focus-visible {
	background: var(--ir-novogradnja-link);
	color: #ffffff;
}

/* -------------------------------------------------------------------------
 * FAQ accordion (LAND-16). One panel open at a time (JS-driven). The open
 * trigger's orange underline is accent reserved-list item #6.
 * ------------------------------------------------------------------------- */
.ir-novogradnja-faq-title {
	margin: 0 0 var(--ir-space-4);
	color: var(--ir-novogradnja-primary);
	text-align: center;
}

.ir-novogradnja-faq {
	max-width: 48rem;
	margin-inline: auto;
}

.ir-novogradnja-faq-item {
	border-bottom: 1px solid var(--ir-gray-200);
}

.ir-novogradnja-faq-question {
	margin: 0;
}

.ir-novogradnja-faq-trigger {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--ir-space-3);
	width: 100%;
	min-height: 44px;
	padding: var(--ir-space-3) 0;
	border: none;
	background: transparent;
	color: var(--ir-gray-900);
	font-family: var(--ir-font-family);
	font-size: 20px;
	font-weight: var(--ir-font-weight-semibold);
	line-height: 1.2;
	text-align: left;
	cursor: pointer;
}

/* Accent reserved-list #6: the open question gets an orange underline. */
.ir-novogradnja-faq-trigger[aria-expanded="true"] {
	color: var(--ir-novogradnja-primary);
	box-shadow: inset 0 -2px 0 0 var(--ir-novogradnja-accent);
}

.ir-novogradnja-faq-trigger-icon {
	flex: 0 0 auto;
	width: 16px;
	height: 16px;
	position: relative;
}

.ir-novogradnja-faq-trigger-icon::before,
.ir-novogradnja-faq-trigger-icon::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 0;
	width: 16px;
	height: 2px;
	background: currentColor;
	transform: translateY(-50%);
	transition: transform 0.2s ease;
}

.ir-novogradnja-faq-trigger-icon::after {
	transform: translateY(-50%) rotate(90deg);
}

.ir-novogradnja-faq-trigger[aria-expanded="true"] .ir-novogradnja-faq-trigger-icon::after {
	transform: translateY(-50%) rotate(0deg);
}

.ir-novogradnja-faq-panel {
	padding: 0 0 var(--ir-space-3);
}

.ir-novogradnja-faq-panel[hidden] {
	display: none;
}

.ir-novogradnja-faq-answer {
	margin: 0;
	color: var(--ir-gray-600);
}

/* -------------------------------------------------------------------------
 * Proximity legend intro (LAND-10, Plan 04-06). The legend itself ships inside
 * the map render (maps-leaflet, ir-leaflet-* chrome); this is the labelled lede
 * section that anchors it. No carousel (D-01).
 * ------------------------------------------------------------------------- */
.ir-novogradnja-proximity-title {
	margin: 0 0 var(--ir-space-2);
	color: var(--ir-novogradnja-primary);
}

.ir-novogradnja-proximity-lede {
	margin: 0;
	max-width: 48rem;
	color: var(--ir-gray-600);
}

/* -------------------------------------------------------------------------
 * Location map (LAND-11, Plan 04-06). The .ir-novogradnja-map-surface holds the
 * inert <template> until the IntersectionObserver injects the maps-leaflet render
 * on scroll-into-view (Positron tiles, D-02). The surface must constrain the
 * injected map so it never drives horizontal overflow.
 * ------------------------------------------------------------------------- */
.ir-novogradnja-map-title {
	margin: 0 0 var(--ir-space-3);
	color: var(--ir-novogradnja-primary);
}

.ir-novogradnja-map-surface {
	max-width: 100%;
	overflow: hidden;
	border-radius: var(--ir-radius-md, 8px);
}

.ir-novogradnja-map-surface .ir-leaflet-map-container,
.ir-novogradnja-map-surface .ir-leaflet-map {
	max-width: 100%;
}

/* -------------------------------------------------------------------------
 * Footer chrome (Plan 04-06). The closing brand band on the deep-blue primary,
 * below the footer contact form.
 * ------------------------------------------------------------------------- */
.ir-novogradnja-footer-chrome {
	background: var(--ir-novogradnja-primary);
	color: #fff;
	padding: var(--ir-space-5) var(--ir-space-3);
	margin-top: var(--ir-space-5);
}

.ir-novogradnja-footer-inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--ir-space-2);
	text-align: center;
	max-width: 52rem;
	margin-inline: auto;
}

.ir-novogradnja-footer-logo {
	max-width: 200px;
	height: auto;
	max-height: 64px;
}

.ir-novogradnja-footer-wordmark {
	font-size: 28px;
	font-weight: var(--ir-font-weight-semibold);
}

.ir-novogradnja-footer-copy {
	margin: 0;
	font-size: 14px;
	opacity: 0.85;
}

/* -------------------------------------------------------------------------
 * Responsive sweep (LAND-18, Plan 04-06). Contract: a single 768px breakpoint;
 * NO horizontal overflow at 360 / 768 / 1280px. The landing wrapper clips any
 * stray horizontal bleed, all media is width-constrained, and the units table
 * already scrolls horizontally on mobile via .ir-novogradnja-table-scroll. No new
 * size/space tokens are introduced — only the global --ir-space-* scale.
 * ------------------------------------------------------------------------- */
.ir-novogradnja-landing {
	max-width: 100%;
	overflow-x: hidden;
}

.ir-novogradnja-landing img,
.ir-novogradnja-landing iframe,
.ir-novogradnja-landing video,
.ir-novogradnja-landing svg {
	max-width: 100%;
}

.ir-novogradnja-landing img {
	height: auto;
}

/* Belt-and-braces: the units table never reflows its columns — it scrolls. */
.ir-novogradnja-table-scroll {
	max-width: 100%;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

/* Single 768px contract: payment cards stack below, 3-col at/above. */
@media (max-width: 767.98px) {
	.ir-novogradnja-payment-grid {
		grid-template-columns: 1fr;
	}
}

/* =========================================================================
 * Unit detail page (Phase 5, Plan 01) — scoped under .ir-novogradnja-unit.
 *
 * Reuses the existing token system only: --ir-space-* for spacing, the scoped
 * --ir-novogradnja-* brand tokens (set on the wrapper), --ir-success/-warning/
 * -danger via the shared .ir-novogradnja-badge--* classes, and the existing
 * 4-size/2-weight type ramp. No new custom property, no new hex, no font-family.
 * Header band, spec strip, and plans row mirror the landing container rhythm.
 * No horizontal overflow at 360 / 768 / 1280 (LAND-18 carried forward).
 * ========================================================================= */

/* Page wrapper — centered max content width (mirrors the landing container). */
.ir-novogradnja-unit {
	max-width: 960px;
	margin-inline: auto;
}

/* --- Header band: breadcrumb + H1 + back-link (surface-alt) ------------- */
.ir-novogradnja-unit-header {
	background: var(--ir-novogradnja-surface-alt);
	margin-bottom: var(--ir-space-6);
}

.ir-novogradnja-breadcrumb {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--ir-space-2);
	font-size: 14px;
	font-weight: var(--ir-font-weight-semibold);
	line-height: 1.4;
	margin-bottom: var(--ir-space-3);
}

.ir-novogradnja-breadcrumb a {
	color: var(--ir-novogradnja-link);
	text-decoration: none;
}

.ir-novogradnja-breadcrumb a:hover,
.ir-novogradnja-breadcrumb a:focus-visible {
	text-decoration: underline;
}

.ir-novogradnja-breadcrumb-sep {
	color: var(--ir-gray-500);
}

.ir-novogradnja-breadcrumb-current {
	color: var(--ir-novogradnja-primary);
}

.ir-novogradnja-unit-header .ir-novogradnja-display {
	color: var(--ir-novogradnja-primary);
	margin: 0 0 var(--ir-space-3);
}

/* Back-link — link-blue, never accent; ≥44px hit area via the button padding. */
.ir-novogradnja-back {
	display: inline-block;
	padding: var(--ir-space-2) var(--ir-space-4);
	color: var(--ir-novogradnja-link);
	font-size: 14px;
	font-weight: var(--ir-font-weight-semibold);
	text-decoration: none;
	min-height: 44px;
	line-height: 28px;
}

.ir-novogradnja-back:hover,
.ir-novogradnja-back:focus-visible {
	text-decoration: underline;
}

/* --- Spec strip: horizontal cells on surface-alt ----------------------- */
.ir-novogradnja-unit-spec {
	display: flex;
	flex-wrap: wrap;
	gap: var(--ir-space-3);
	align-items: center;
	padding: var(--ir-space-4);
	background: var(--ir-novogradnja-surface-alt);
	border-radius: var(--ir-radius-md);
}

.ir-novogradnja-unit-spec-cell {
	display: flex;
	align-items: center;
	gap: var(--ir-space-1);
	padding: var(--ir-space-1) var(--ir-space-3);
}

.ir-novogradnja-unit-spec-value {
	font-size: 16px;
	font-weight: var(--ir-font-weight-normal);
	line-height: 1.5;
	color: var(--ir-gray-900);
}

.ir-novogradnja-unit-spec-price .ir-novogradnja-unit-spec-value {
	font-weight: var(--ir-font-weight-semibold);
	color: var(--ir-novogradnja-primary);
}

.ir-novogradnja-unit-spec-icon {
	flex: 0 0 auto;
}

/* Stack to fewer-per-row on the narrowest screens; single row at ≥768px. */
@media (max-width: 767.98px) {
	.ir-novogradnja-unit-spec {
		gap: var(--ir-space-2);
	}

	.ir-novogradnja-unit-spec-cell {
		flex: 1 1 45%;
	}
}

/* --- Plans row + 360° tour --------------------------------------------- */
.ir-novogradnja-unit-plans .ir-novogradnja-heading {
	margin-bottom: var(--ir-space-3);
}

.ir-novogradnja-unit-plans-row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--ir-space-2);
	margin-bottom: var(--ir-space-4);
}

/* Neutral download button — link-blue outline, NOT accent; ≥44px hit area. */
.ir-novogradnja-btn {
	display: inline-flex;
	align-items: center;
	padding: var(--ir-space-2) var(--ir-space-4);
	min-height: 44px;
	border: 1px solid var(--ir-novogradnja-primary);
	border-radius: var(--ir-radius-md);
	background: var(--ir-novogradnja-surface);
	color: var(--ir-novogradnja-primary);
	font-size: 14px;
	font-weight: var(--ir-font-weight-semibold);
	text-decoration: none;
	cursor: pointer;
}

.ir-novogradnja-btn:hover,
.ir-novogradnja-btn:focus-visible {
	background: var(--ir-novogradnja-surface-alt);
}

/* 360° iframe — responsive 16:9, full-width, never overflows. */
.ir-novogradnja-unit-tour {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 9;
	border-radius: var(--ir-radius-md);
	overflow: hidden;
}

.ir-novogradnja-unit-tour iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
}

.ir-novogradnja-unit-tour-link a {
	color: var(--ir-novogradnja-link);
	font-weight: var(--ir-font-weight-semibold);
}

/* --- Contact unit-ref chip --------------------------------------------- */
.ir-novogradnja-form-unitref {
	margin-bottom: var(--ir-space-3);
}

/* Read-only chip — neutral surface, NOT accent. */
.ir-novogradnja-chip {
	display: inline-block;
	padding: var(--ir-space-1) var(--ir-space-3);
	border-radius: var(--ir-radius-full);
	background: var(--ir-novogradnja-surface-alt);
	color: var(--ir-gray-900);
	font-size: 14px;
	font-weight: var(--ir-font-weight-semibold);
	line-height: 1.4;
}

/* =======================================================================
 * /novogradnja/ ARCHIVE (Plan 05-02, NAV-03) — responsive building-card grid.
 *
 * Scoped under .ir-novogradnja-archive. CONSUMES the global --ir-space-*,
 * --ir-radius-*, --ir-gray-* tokens and the scoped --ir-novogradnja-* brand
 * properties — declares NO new token, NO new hex, NO font-family. The brand
 * fallbacks below mirror the .ir-novogradnja-landing block so the sheet is
 * self-sufficient even if the wrapper's inline style is stripped.
 * Grid: 1 / 2 / 3 columns at 360 / 768 / 1280; no horizontal overflow.
 * ======================================================================= */
.ir-novogradnja-archive {
	--ir-novogradnja-primary: #00629D;
	--ir-novogradnja-accent: #F37021;
	--ir-novogradnja-link: #0089CF;
	--ir-novogradnja-surface: #FFFFFF;
	--ir-novogradnja-surface-alt: var(--ir-gray-50);

	box-sizing: border-box;
	max-width: 1200px;
	margin-inline: auto;
	padding-block: var(--ir-space-7);
	padding-inline: var(--ir-space-3);
	background: var(--ir-novogradnja-surface);
	color: var(--ir-gray-900);
	font-family: var(--ir-font-family);
	font-weight: var(--ir-font-weight-normal);
	font-size: 16px;
	line-height: 1.5;
}

.ir-novogradnja-archive :where(*) {
	box-sizing: border-box;
}

.ir-novogradnja-archive-h1 {
	font-size: 28px;
	font-weight: var(--ir-font-weight-semibold);
	line-height: 1.2;
	color: var(--ir-novogradnja-primary);
	margin-bottom: var(--ir-space-5);
}

/* Grid — 1 column on mobile; widens at the 768 / 1280 breakpoints. */
.ir-novogradnja-archive-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--ir-space-4);
}

@media (min-width: 768px) {
	.ir-novogradnja-archive-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1280px) {
	.ir-novogradnja-archive-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* --- Building card ------------------------------------------------------ */
.ir-novogradnja-card {
	display: flex;
	flex-direction: column;
	background: var(--ir-novogradnja-surface);
	border: 1px solid var(--ir-gray-200);
	border-radius: var(--ir-radius-lg);
	overflow: hidden;
	transition: background-color 0.15s ease, box-shadow 0.15s ease;
}

.ir-novogradnja-card:hover,
.ir-novogradnja-card:focus-within {
	background: var(--ir-novogradnja-surface-alt);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

/* Cover — fixed aspect to avoid layout shift; full-width responsive. */
.ir-novogradnja-card-cover {
	display: block;
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
}

.ir-novogradnja-card-cover--placeholder {
	background: var(--ir-gray-100);
}

.ir-novogradnja-card-body {
	display: flex;
	flex-direction: column;
	gap: var(--ir-space-2);
	padding: var(--ir-space-4);
}

.ir-novogradnja-card-title {
	font-size: 20px;
	font-weight: var(--ir-font-weight-semibold);
	line-height: 1.2;
	color: var(--ir-novogradnja-primary);
	margin: 0;
}

.ir-novogradnja-card-loc {
	font-size: 16px;
	font-weight: var(--ir-font-weight-normal);
	line-height: 1.5;
	color: var(--ir-gray-600);
	margin: 0;
}

.ir-novogradnja-card-units {
	font-size: 14px;
	font-weight: var(--ir-font-weight-semibold);
	line-height: 1.4;
	color: var(--ir-gray-700);
	margin: 0;
}

/* The ONE accent action per card — filled accent CTA, ≥44px hit area.
 * .ir-novogradnja-btn (shared) supplies layout/padding; this modifier swaps the
 * neutral outline for the accent fill. */
.ir-novogradnja-card .ir-novogradnja-btn {
	margin-top: var(--ir-space-2);
	justify-content: center;
}

.ir-novogradnja-btn--accent {
	border-color: var(--ir-novogradnja-accent);
	background: var(--ir-novogradnja-accent);
	color: var(--ir-novogradnja-surface);
}

.ir-novogradnja-btn--accent:hover,
.ir-novogradnja-btn--accent:focus-visible {
	background: var(--ir-novogradnja-accent);
	filter: brightness(0.94);
}

/* --- Empty state -------------------------------------------------------- */
.ir-novogradnja-archive-empty {
	text-align: center;
	padding: var(--ir-space-6);
	color: var(--ir-gray-700);
}

.ir-novogradnja-archive-empty h2 {
	font-size: 20px;
	font-weight: var(--ir-font-weight-semibold);
	line-height: 1.2;
	color: var(--ir-novogradnja-primary);
	margin-bottom: var(--ir-space-3);
}

.ir-novogradnja-archive-empty p {
	font-size: 16px;
	font-weight: var(--ir-font-weight-normal);
	line-height: 1.5;
	margin: 0;
}

/* ============================================================================
 * Phase 5 (NAV-01 / NAV-02 / D-08): self-populating nav dropdown.
 *
 * Scoped to the synthetic children injected by IR_Novogradnja_Nav under a
 * menu item carrying `.novogradnja-dropdown`. The dropdown open/close is
 * THEME-DRIVEN — we own no transitions/JS here (D-08). We only style the row
 * chrome: a 40px lazy thumbnail, link-blue title, and an optional location
 * label. Uses only existing tokens (no new token/hex/font-family).
 * ============================================================================ */

.ir-novogradnja-nav-item {
	display: flex;
}

.ir-novogradnja-nav-item > a {
	display: flex;
	align-items: center;
	gap: var(--ir-space-2);
	padding: var(--ir-space-2) var(--ir-space-3);
	min-height: 44px; /* comfortable touch hit area */
	color: var(--ir-novogradnja-link); /* link blue, NOT accent (UI-SPEC / D-08) */
	background: var(--ir-novogradnja-surface);
	text-decoration: none;
}

.ir-novogradnja-nav-item > a:hover,
.ir-novogradnja-nav-item > a:focus {
	background: var(--ir-novogradnja-surface-alt);
}

.ir-novogradnja-nav-thumb {
	flex: 0 0 auto;
	width: 40px;
	height: 40px;
	object-fit: cover;
	border-radius: var(--ir-radius-sm);
	margin-right: var(--ir-space-2);
}

.ir-novogradnja-nav-location {
	display: block;
	margin-left: var(--ir-space-2);
	font-size: 13px;
	font-weight: var(--ir-font-weight-normal);
	line-height: 1.3;
	color: var(--ir-gray-500);
}
