/* ACS layout i komponente. Hairline borderi kao primarni razdvajac, kartice-ostrva. */

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
	margin: 0;
	background: var(--acs-bg);
	color: var(--acs-text);
	font-family: var(--acs-font-body);
	font-size: var(--acs-fs-base);
	line-height: 1.6;
	/* mesta za sticky mobilni CTA da ne prekriva sadrzaj */
	padding-bottom: env(safe-area-inset-bottom);
	transition: background var(--acs-dur-ui) var(--acs-ease), color var(--acs-dur-ui) var(--acs-ease);
}

h1, h2, h3, h4 {
	font-family: var(--acs-font-display);
	line-height: 1.15;
	letter-spacing: -.01em;
	color: var(--acs-text);
	margin: 0 0 var(--acs-sp-4);
}

h1 { font-size: var(--acs-fs-2xl); font-weight: 700; }
h2 { font-size: var(--acs-fs-xl); font-weight: 600; }
h3 { font-size: var(--acs-fs-lg); font-weight: 600; }

a { color: var(--acs-link); text-decoration: none; }
a:hover { text-decoration: underline; }

img { max-width: 100%; height: auto; display: block; }

/* Cene: tabular-nums, ne animiramo ih */
.acs-price, .price, .woocommerce-Price-amount {
	font-variant-numeric: tabular-nums;
}

:focus-visible {
	outline: 2px solid var(--acs-blue);
	outline-offset: 2px;
	border-radius: 2px;
}

/* --- Layout primitivi --- */
.acs-container {
	width: 100%;
	max-width: var(--acs-container);
	margin-inline: auto;
	padding-inline: var(--acs-gutter);
}
.acs-container--wide { max-width: var(--acs-container-wide); }

.acs-section {
	position: relative;
	padding-block: var(--acs-sp-16);
}
@media (min-width: 1024px) {
	.acs-section { padding-block: var(--acs-sp-24); }
}

.acs-section__head {
	max-width: 62ch;
	margin-bottom: var(--acs-sp-8);
}
.acs-section__eyebrow {
	display: inline-block;
	font-family: var(--acs-font-display);
	font-size: var(--acs-fs-xs);
	font-weight: 600;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--acs-blue);
	margin-bottom: var(--acs-sp-2);
}
.acs-section__lead {
	font-size: var(--acs-fs-lg);
	color: var(--acs-text-soft);
}

/* ==================================================================
   Dugmad
   ================================================================== */
.acs-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--acs-sp-2);
	font-family: var(--acs-font-display);
	font-weight: 600;
	font-size: var(--acs-fs-base);
	line-height: 1;
	padding: .875rem 1.5rem;
	min-height: 48px;
	border-radius: var(--acs-r-md);
	border: 1px solid transparent;
	cursor: pointer;
	text-decoration: none;
	transition: background var(--acs-dur-hover) var(--acs-ease),
		border-color var(--acs-dur-hover) var(--acs-ease),
		color var(--acs-dur-hover) var(--acs-ease),
		transform var(--acs-dur-hover) var(--acs-ease);
}
.acs-btn:hover { text-decoration: none; }
.acs-btn:active { transform: translateY(1px); }

.acs-btn--primary {
	background: var(--acs-cta);
	color: var(--acs-cta-text);
}
.acs-btn--primary:hover {
	background: #0a5aa0;
	color: var(--acs-cta-text);
}
[data-theme="dark"] .acs-btn--primary:hover { background: #4aa3e0; }

.acs-btn--secondary {
	background: transparent;
	color: var(--acs-text);
	border-color: var(--acs-hairline);
}
.acs-btn--secondary:hover {
	border-color: var(--acs-blue);
	color: var(--acs-blue);
}

.acs-btn--ghost {
	background: transparent;
	color: var(--acs-link);
	padding-inline: .25rem;
	min-height: auto;
}

/* ==================================================================
   Traka poverenja (posle body_open)
   ================================================================== */
.acs-trust-strap {
	background: var(--acs-graphite);
	color: #EAF1F7;
	border-bottom: 1px solid rgba(255, 255, 255, .08);
}
.acs-trust-strap__track {
	max-width: var(--acs-container-wide);
	margin-inline: auto;
	padding: .5rem var(--acs-gutter);
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: .5rem;
	font-size: var(--acs-fs-xs);
	font-weight: 500;
	text-align: center;
}
.acs-trust-strap__sep { color: var(--acs-cyan); opacity: .7; }
.acs-trust-strap__item { white-space: nowrap; }
@media (max-width: 560px) {
	.acs-trust-strap__track { font-size: .75rem; gap: .375rem; }
}

/* ==================================================================
   Topbar (header NAP)
   ================================================================== */
.acs-topbar {
	background: var(--acs-bg-soft);
	border-bottom: 1px solid var(--acs-hairline);
	font-size: var(--acs-fs-sm);
}
.acs-topbar__inner {
	max-width: var(--acs-container-wide);
	margin-inline: auto;
	padding: .5rem var(--acs-gutter);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--acs-sp-4);
}
.acs-topbar__tel { color: var(--acs-text); }
.acs-topbar__tel strong { color: var(--acs-blue); }
.acs-topbar__tel:hover { text-decoration: none; }
.acs-topbar__label { color: var(--acs-text-soft); }
.acs-topbar__hours { color: var(--acs-text-soft); }
@media (max-width: 720px) {
	.acs-topbar__hours { display: none; }
	.acs-topbar__inner { justify-content: center; }
}

/* ==================================================================
   Kartice-ostrva (hairline border, plitka senka)
   ================================================================== */
.acs-card {
	background: var(--acs-surface);
	border: 1px solid var(--acs-hairline);
	border-radius: var(--acs-r-lg);
	padding: var(--acs-sp-6);
	box-shadow: var(--acs-shadow-sm);
	transition: border-color var(--acs-dur-ui) var(--acs-ease),
		box-shadow var(--acs-dur-ui) var(--acs-ease),
		transform var(--acs-dur-ui) var(--acs-ease);
}
.acs-card--link:hover {
	border-color: var(--acs-blue);
	box-shadow: var(--acs-shadow-md);
	transform: translateY(-2px);
}
.acs-card__title { margin-bottom: var(--acs-sp-2); }
.acs-card__text { color: var(--acs-text-soft); font-size: var(--acs-fs-sm); margin: 0; }

.acs-grid {
	display: grid;
	gap: var(--acs-sp-6);
	grid-template-columns: repeat(auto-fill, minmax(min(100%, 260px), 1fr));
}

/* ==================================================================
   Hero
   ================================================================== */
.acs-hero {
	position: relative;
	overflow: clip;
	background: var(--acs-bg-soft);
	border-bottom: 1px solid var(--acs-hairline);
}
.acs-hero__media {
	position: absolute;
	inset: 0;
	z-index: 0;
}
.acs-hero__poster,
#acs-hero-canvas {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.acs-hero__poster { z-index: 0; }
/* canvas sakriven dok scena nije spremna; JS skida .is-hidden i fade-uje preko postera */
#acs-hero-canvas {
	z-index: 1;
	opacity: 0;
	transition: opacity 600ms var(--acs-ease);
	pointer-events: none;
}
/* JS dodaje .is-ready na #acs-hero (ne na canvas) — canvas fade preko postera. */
#acs-hero.is-ready #acs-hero-canvas { opacity: 1; }

/* Blocksy parent override: koristimo NAS footer (acs-footer preko wp_footer),
   pa gasimo Blocksy podnozje da nema duplog footera. Header ostaje Blocksy. */
#footer.ct-footer { display: none; }
.acs-hero__scrim {
	position: absolute;
	inset: 0;
	z-index: 2;
	background: linear-gradient(180deg, rgba(10, 20, 32, .28) 0%, rgba(10, 20, 32, .62) 100%);
}
.acs-hero__inner {
	position: relative;
	z-index: 3;
	max-width: var(--acs-container);
	margin-inline: auto;
	padding: clamp(3rem, 8vh, 7rem) var(--acs-gutter);
	min-height: clamp(420px, 66vh, 640px);
	display: flex;
	flex-direction: column;
	justify-content: center;
	color: #fff;
}
.acs-hero__badge {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	align-self: flex-start;
	background: rgba(255, 255, 255, .12);
	border: 1px solid rgba(255, 255, 255, .3);
	color: #fff;
	font-size: var(--acs-fs-xs);
	font-weight: 600;
	letter-spacing: .04em;
	padding: .375rem .75rem;
	border-radius: 999px;
	margin-bottom: var(--acs-sp-4);
	backdrop-filter: saturate(1.2) blur(2px);
}
.acs-hero h1 {
	color: #fff;
	max-width: 20ch;
	text-shadow: 0 1px 2px rgba(0, 0, 0, .2);
}
.acs-hero__sub {
	max-width: 52ch;
	font-size: var(--acs-fs-lg);
	color: rgba(255, 255, 255, .92);
	margin-bottom: var(--acs-sp-8);
}
.acs-hero__cta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--acs-sp-3);
}
.acs-hero__cta .acs-btn--secondary {
	color: #fff;
	border-color: rgba(255, 255, 255, .55);
}
.acs-hero__cta .acs-btn--secondary:hover {
	background: rgba(255, 255, 255, .1);
	color: #fff;
	border-color: #fff;
}

/* ==================================================================
   Sezonski blok
   ================================================================== */
.acs-season {
	display: grid;
	gap: var(--acs-sp-6);
	grid-template-columns: 1fr;
}
@media (min-width: 860px) {
	.acs-season { grid-template-columns: 1fr 1fr; }
}
.acs-season__card {
	background: var(--acs-surface);
	border: 1px solid var(--acs-hairline);
	border-radius: var(--acs-r-lg);
	padding: var(--acs-sp-8);
	display: flex;
	flex-direction: column;
	gap: var(--acs-sp-3);
}
.acs-season__tag {
	font-family: var(--acs-font-display);
	font-size: var(--acs-fs-xs);
	font-weight: 600;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--acs-blue);
}

/* ==================================================================
   CTA band (conversion terminus)
   ================================================================== */
.acs-cta-band {
	background: var(--acs-graphite);
	color: #fff;
	border-radius: var(--acs-r-lg);
	padding: clamp(2rem, 5vw, 3.5rem);
	text-align: center;
}
.acs-cta-band h2 { color: #fff; }
.acs-cta-band__lead { color: rgba(255, 255, 255, .85); max-width: 54ch; margin: 0 auto var(--acs-sp-8); }
.acs-cta-band__actions { display: flex; flex-wrap: wrap; gap: var(--acs-sp-3); justify-content: center; }
.acs-cta-band__meta {
	margin-top: var(--acs-sp-6);
	font-size: var(--acs-fs-sm);
	color: rgba(255, 255, 255, .7);
	display: flex;
	flex-wrap: wrap;
	gap: .75rem;
	justify-content: center;
}
.acs-cta-band .acs-btn--secondary { color: #fff; border-color: rgba(255, 255, 255, .5); }
.acs-cta-band .acs-btn--secondary:hover { background: rgba(255, 255, 255, .1); color: #fff; }

/* ==================================================================
   Footer
   ================================================================== */
.acs-footer {
	background: var(--acs-bg-soft);
	border-top: 1px solid var(--acs-hairline);
	margin-top: var(--acs-sp-16);
}
.acs-footer__inner {
	max-width: var(--acs-container-wide);
	margin-inline: auto;
	padding: var(--acs-sp-12) var(--acs-gutter) var(--acs-sp-8);
	display: grid;
	gap: var(--acs-sp-8);
	grid-template-columns: 1fr;
}
@media (min-width: 720px) {
	.acs-footer__inner { grid-template-columns: 2fr 1fr 1fr; }
}
.acs-footer__name { font-family: var(--acs-font-display); font-weight: 700; font-size: var(--acs-fs-lg); }
.acs-footer__tag { color: var(--acs-text-soft); font-size: var(--acs-fs-sm); max-width: 44ch; margin-top: var(--acs-sp-3); }
.acs-footer__h { font-size: var(--acs-fs-sm); text-transform: uppercase; letter-spacing: .08em; color: var(--acs-text-mute); margin-bottom: var(--acs-sp-3); }
.acs-footer__addr { font-style: normal; line-height: 1.9; color: var(--acs-text-soft); }
.acs-footer__addr a { color: var(--acs-text); }
.acs-footer__hours { color: var(--acs-text-soft); }
.acs-footer__bar {
	border-top: 1px solid var(--acs-hairline);
	padding: var(--acs-sp-4) var(--acs-gutter);
	max-width: var(--acs-container-wide);
	margin-inline: auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--acs-sp-4);
	font-size: var(--acs-fs-sm);
	color: var(--acs-text-mute);
	flex-wrap: wrap;
}

/* ==================================================================
   Dark toggle dugme
   ================================================================== */
.acs-theme-toggle {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	background: transparent;
	border: 1px solid var(--acs-hairline);
	border-radius: 999px;
	padding: .375rem .75rem;
	font-family: var(--acs-font-body);
	font-size: var(--acs-fs-xs);
	color: var(--acs-text-soft);
	cursor: pointer;
	min-height: 36px;
	transition: border-color var(--acs-dur-hover) var(--acs-ease), color var(--acs-dur-hover) var(--acs-ease);
}
.acs-theme-toggle:hover { border-color: var(--acs-blue); color: var(--acs-text); }
.acs-theme-toggle__icon {
	width: 14px; height: 14px; border-radius: 50%;
	border: 2px solid currentColor;
	background: linear-gradient(90deg, currentColor 0 50%, transparent 50% 100%);
}
[data-theme="dark"] .acs-theme-toggle__text::after { content: none; }

/* ==================================================================
   Sticky mobilni CTA (fiksna donja traka 50/50)
   ================================================================== */
.acs-sticky-cta {
	position: fixed;
	left: 0; right: 0; bottom: 0;
	z-index: var(--acs-z-sticky-cta);
	display: grid;
	grid-template-columns: 1fr 1fr;
	background: var(--acs-surface);
	border-top: 1px solid var(--acs-hairline);
	box-shadow: 0 -2px 12px rgba(14, 27, 42, .06);
	padding-bottom: env(safe-area-inset-bottom);
}
.acs-sticky-cta__btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: .5rem;
	min-height: 52px;
	font-family: var(--acs-font-display);
	font-weight: 600;
	font-size: var(--acs-fs-sm);
	text-decoration: none;
}
.acs-sticky-cta__btn:hover { text-decoration: none; }
.acs-sticky-cta__btn--call { color: var(--acs-text); border-right: 1px solid var(--acs-hairline); }
.acs-sticky-cta__btn--inquiry { background: var(--acs-cta); color: var(--acs-cta-text); }
/* samo mobilni; od 1024px se skriva (desktop ima svoj plutajuci CTA u sekcijama) */
@media (min-width: 1024px) {
	.acs-sticky-cta { display: none; }
	body { padding-bottom: 0; }
}
@media (max-width: 1023px) {
	body { padding-bottom: 52px; }
}

/* ==================================================================
   Staging marker (nenametljiv)
   ================================================================== */
.acs-staging-marker {
	position: fixed;
	left: 8px; bottom: 8px;
	z-index: var(--acs-z-marker);
	background: rgba(14, 27, 42, .82);
	color: #fff;
	font-size: 10px;
	letter-spacing: .12em;
	padding: 3px 7px;
	border-radius: 4px;
	pointer-events: none;
	opacity: .7;
}
@media (max-width: 1023px) {
	.acs-staging-marker { bottom: 60px; }
}

/* ==================================================================
   Reveal — CSS koje SAKRIVA je gate-ovano na html.js (no-JS/robot vidi sadrzaj)
   ================================================================== */
.js .reveal {
	opacity: 0;
	transition: opacity var(--acs-dur-reveal) var(--acs-ease), transform var(--acs-dur-reveal) var(--acs-ease);
}
.js .reveal--up { transform: translateY(20px); }
.js .reveal.in { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
	.js .reveal { opacity: 1; transform: none; transition: none; }
	* { scroll-behavior: auto !important; }
}

/* Skip link */
.acs-skip {
	position: absolute;
	left: -9999px;
	top: 0;
	background: var(--acs-blue);
	color: #fff;
	padding: .75rem 1rem;
	z-index: 999;
}
.acs-skip:focus { left: 8px; top: 8px; }
