/* ============================================================
   Actinium — main.css
   Tokeni i sekcije iz design-reference/actinium-preview-v4.html.
   ============================================================ */

:root {
	--bg: #fbfcfe;
	--ink: #0d1728;
	--navy: #0f1d33;
	--blue: #2e86d6;
	--sky: #39b9ee;
	--wash: #eaf4fc;
	--gray: #5d6b7e;
	--line: rgba(13, 23, 40, .09);
	--line-d: rgba(255, 255, 255, .12);
	--grad: linear-gradient(135deg, #2e86d6, #39b9ee);
	--max: 1260px;
	--r: 20px;
	--sh: 0 24px 70px rgba(13, 23, 40, .10);
}

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
	background: var(--bg);
	color: var(--ink);
	font-family: 'Onest', system-ui, sans-serif;
	font-size: 17px;
	line-height: 1.65;
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden;
}

::selection { background: var(--sky); color: #fff; }

.wrap { max-width: var(--max); margin: 0 auto; padding: 0 32px; }

a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
ul, ol { list-style-position: inside; }

h1, h2, h3 {
	font-family: 'Schibsted Grotesk', sans-serif;
	letter-spacing: -.03em;
	line-height: 1.04;
	text-wrap: balance;
}
h1 { font-weight: 900; font-size: clamp(44px, 6.4vw, 86px); }
h2 { font-weight: 800; font-size: clamp(32px, 4.4vw, 58px); }

.grad-t {
	background: var(--grad);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}
.sky-t { color: var(--sky); }

.lead { color: var(--gray); font-size: 18.5px; max-width: 56ch; }

/* Kvadrat iz logoa — marker sekcija */
.sq {
	display: inline-block;
	width: 11px;
	height: 11px;
	background: var(--grad);
	border-radius: 2.5px;
}
.kick {
	display: inline-flex;
	align-items: center;
	gap: 11px;
	font-weight: 700;
	font-size: 13.5px;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--blue);
	margin-bottom: 22px;
}
.kick--sky { color: var(--sky); }

/* Dugmad */
.btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-weight: 700;
	font-size: 15.5px;
	padding: 17px 30px;
	border-radius: 14px;
	transition: transform .25s, box-shadow .25s;
}
.btn:hover { transform: translateY(-3px); }
.btn.grad { background: var(--grad); color: #fff; box-shadow: 0 12px 30px rgba(46, 134, 214, .30); }
.btn.grad:hover { box-shadow: 0 18px 44px rgba(46, 134, 214, .40); }
.btn.line { border: 1.5px solid var(--line); background: #fff; }
.btn.line:hover { border-color: var(--blue); color: var(--blue); }
.btn--white { background: #fff; color: var(--blue); position: relative; z-index: 2; }

/* ===== Header ===== */
.site-header { position: fixed; inset: 0 0 auto; z-index: 90; transition: .35s; }
.site-header.on {
	background: rgba(251, 252, 254, .85);
	backdrop-filter: blur(16px);
	box-shadow: 0 1px 0 var(--line);
}
.nav {
	display: flex;
	justify-content: space-between;
	align-items: center;
	height: 82px;
	max-width: var(--max);
	margin: 0 auto;
	padding: 0 32px;
}
.nav-logo img { height: 44px; width: auto; }
.nav-l { display: flex; align-items: center; gap: 34px; }
.nav-l li { display: contents; }
.nav-l a { font-size: 14.5px; font-weight: 600; color: var(--gray); transition: .2s; }
.nav-l a:hover { color: var(--ink); }
.nav-l a.btn { padding: 12px 22px; font-size: 14px; color: #fff; }

/* ===== Sekcije (zajedničko) ===== */
.section--services, .section--process, .section--products, .section--faq, .section--cta, .section--aiproto { padding: 120px 0; }
.section--tight { padding-top: 0; }
.sec-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 40px; margin-bottom: 62px; flex-wrap: wrap; }
.sec-head > p { color: var(--gray); max-width: 44ch; }
.sec-head--center { justify-content: center; text-align: center; }
.sec-head--center > div { margin: 0 auto; }

/* ===== Hero ===== */
.hero { padding: 170px 0 70px; position: relative; overflow: hidden; }
.hero::before {
	content: '';
	position: absolute;
	inset: 0;
	pointer-events: none;
	background:
		radial-gradient(ellipse 46% 50% at 88% 8%, rgba(57, 185, 238, .13), transparent 65%),
		radial-gradient(ellipse 40% 44% at 4% 88%, rgba(46, 134, 214, .09), transparent 65%);
}
.hero-grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: 70px; align-items: center; position: relative; }
.badge {
	display: inline-flex;
	align-items: center;
	gap: 9px;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: 99px;
	padding: 9px 18px;
	font-size: 13.5px;
	font-weight: 600;
	color: var(--gray);
	box-shadow: 0 6px 18px rgba(13, 23, 40, .06);
	margin-bottom: 30px;
}
.badge b { color: var(--ink); }
.badge .star { color: #f4a62b; }
.hero p.lead { margin-top: 28px; }
.hero-ctas { display: flex; gap: 14px; margin-top: 40px; flex-wrap: wrap; }
.hero-mini { display: flex; gap: 30px; margin-top: 48px; flex-wrap: wrap; }
.hero-mini div b { font-family: 'Schibsted Grotesk', sans-serif; font-weight: 800; font-size: 26px; display: block; }
.hero-mini div span { font-size: 13px; color: var(--gray); }

.hero-vis { position: relative; min-height: 480px; }
.shot {
	position: absolute;
	right: 0;
	top: 30px;
	width: 88%;
	border-radius: var(--r);
	overflow: hidden;
	box-shadow: var(--sh);
	border: 1px solid var(--line);
	background: #fff;
	transform: rotate(2.2deg);
}
.shot .bar { display: flex; gap: 6px; padding: 12px 16px; background: #f2f5f9; border-bottom: 1px solid var(--line); }
.shot .bar i { width: 9px; height: 9px; border-radius: 50%; background: #d7dee7; }
.shot .bar i:first-child { background: var(--sky); }
.shot img { width: 100%; }
.float-card {
	position: absolute;
	left: -6px;
	bottom: 46px;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: 16px;
	padding: 18px 22px;
	box-shadow: var(--sh);
	max-width: 240px;
}
.float-card .mini { font-size: 12.5px; color: var(--gray); }
.float-card b { font-family: 'Schibsted Grotesk', sans-serif; font-size: 24px; font-weight: 800; }
.float-card b span { color: var(--blue); }
.sq-cluster { position: absolute; z-index: 2; left: 8%; top: -8px; }
.sq-cluster i { position: absolute; background: var(--grad); border-radius: 4px; opacity: 0; }
.sq-cluster i:nth-child(1) { width: 40px; height: 40px; left: 0; top: 34px; }
.sq-cluster i:nth-child(2) { width: 22px; height: 22px; left: 52px; top: 0; }
.sq-cluster i:nth-child(3) { width: 58px; height: 58px; left: 62px; top: 34px; }
.sq-cluster i:nth-child(4) { width: 26px; height: 26px; left: 48px; top: 104px; }
.sq-cluster i:nth-child(5) { width: 13px; height: 13px; left: 18px; top: 6px; }

/* ===== Marquee ===== */
.imq { padding: 34px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); overflow: hidden; background: #fff; }
.imq .track { display: inline-flex; align-items: center; gap: 26px; white-space: nowrap; animation: mq 30s linear infinite; will-change: transform; padding-right: 26px; }
.imq span { font-family: 'Schibsted Grotesk', sans-serif; font-weight: 800; font-size: clamp(22px, 3vw, 34px); letter-spacing: -.02em; }
.imq .th { width: 92px; height: 58px; border-radius: 14px; overflow: hidden; flex-shrink: 0; border: 1px solid var(--line); }
.imq .th img { width: 100%; height: 100%; object-fit: cover; }
.imq em { font-style: normal; color: var(--blue); }
@keyframes mq { to { transform: translateX(-50%); } }

/* ===== Capabilities (What we do) ===== */
.caps-layout { display: grid; grid-template-columns: .82fr 1.18fr; gap: 64px; align-items: start; }
.caps-intro { position: relative; }
.caps-intro__inner { position: sticky; top: 104px; }
.caps-intro h2 { margin-top: 16px; }
.caps-intro p { color: var(--gray); font-size: 16px; margin-top: 18px; max-width: 40ch; }
.caps-progress { display: flex; align-items: center; gap: 16px; margin-top: 36px; }
.caps-progress__count { font-family: 'Schibsted Grotesk', sans-serif; font-weight: 800; font-size: 15px; letter-spacing: .04em; }
.caps-progress__count span { color: #9aa5b2; font-weight: 700; }
.caps-progress__track { position: relative; flex: 1; max-width: 160px; height: 3px; border-radius: 99px; background: var(--line); overflow: hidden; }
.caps-progress__track i { position: absolute; inset: 0; transform-origin: left; transform: scaleX(.333); background: var(--grad); border-radius: 99px; transition: transform .55s cubic-bezier(.22, .61, .36, 1); }

.caps { display: flex; flex-direction: column; gap: 26px; }
.cap {
	position: relative;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r);
	overflow: hidden;
	transition: box-shadow .5s ease, border-color .5s ease, filter .5s ease, transform .3s ease;
}
.cap__media { height: 240px; overflow: hidden; position: relative; }
.cap__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s ease; }
.cap__media::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 40%, rgba(13, 23, 40, .35)); }
.cap__num { position: absolute; top: 16px; right: 22px; z-index: 1; font-family: 'Schibsted Grotesk', sans-serif; font-weight: 900; font-size: 40px; line-height: 1; color: #fff; opacity: .92; text-shadow: 0 6px 24px rgba(13, 23, 40, .45); }
.cap__bd { padding: 42px 34px 34px; position: relative; }
.cap__ic { position: absolute; top: -28px; left: 34px; width: 56px; height: 56px; border-radius: 16px; background: var(--grad); display: grid; place-items: center; box-shadow: 0 10px 24px rgba(46, 134, 214, .35); }
.cap__ic svg { width: 26px; height: 26px; stroke: #fff; fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.cap h3 { font-size: 25px; font-weight: 800; letter-spacing: -.01em; }
.cap p { color: #45556a; font-size: 16.5px; line-height: 1.65; margin-top: 13px; max-width: 54ch; }
.cap .chips { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 20px; }
.cap .chips span { font-size: 12px; font-weight: 600; background: var(--wash); color: var(--blue); border-radius: 99px; padding: 6px 13px; transition: opacity .4s ease, transform .4s ease; }
.cap__cta { display: inline-flex; align-items: center; gap: 8px; margin-top: 22px; font-weight: 700; font-size: 14.5px; color: var(--blue); }
.cap__cta span { transition: transform .3s ease; }
.cap:hover .cap__cta span { transform: translateX(4px); }
.cap:hover .cap__media img { transform: scale(1.05); }

/* Scroll-driven active state (JS dodaje .is-enhanced) */
.caps.is-enhanced .cap { filter: opacity(.4) saturate(.9); }
.caps.is-enhanced .cap.is-active { filter: none; box-shadow: var(--sh); border-color: rgba(46, 134, 214, .4); }
.caps.is-enhanced .cap.is-active .cap__media img { transform: scale(1.05); }
.caps.is-enhanced .cap .chips span { opacity: 0; transform: translateY(8px); }
.caps.is-enhanced .cap.is-active .chips span { opacity: 1; transform: none; }
.caps.is-enhanced .cap.is-active .chips span:nth-child(2) { transition-delay: .06s; }
.caps.is-enhanced .cap.is-active .chips span:nth-child(3) { transition-delay: .12s; }
.caps.is-enhanced .cap.is-active .chips span:nth-child(4) { transition-delay: .18s; }
.caps.is-enhanced .cap.is-active .chips span:nth-child(5) { transition-delay: .24s; }

/* Support band + bridge */
.caps-extra { margin-top: 30px; }
.caps-support { display: flex; align-items: center; gap: 22px; background: var(--wash); border: 1px solid var(--line); border-radius: var(--r); padding: 24px 30px; }
.caps-support__ic { width: 48px; height: 48px; border-radius: 14px; background: #fff; display: grid; place-items: center; flex-shrink: 0; }
.caps-support__ic svg { width: 24px; height: 24px; stroke: var(--blue); fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.caps-support__bd { flex: 1; }
.caps-support__bd b { display: block; font-size: 16px; font-weight: 800; }
.caps-support__bd span { color: var(--gray); font-size: 14.5px; }
.caps-support .cap__cta { margin-top: 0; flex-shrink: 0; }
.caps-bridge { display: flex; align-items: center; justify-content: center; gap: 13px; text-align: center; margin-top: 50px; font-family: 'Schibsted Grotesk', sans-serif; font-weight: 700; font-size: clamp(18px, 2.4vw, 25px); letter-spacing: -.01em; }
.caps-bridge .sq { width: 13px; height: 13px; border-radius: 3px; background: var(--grad); flex-shrink: 0; }

/* ===== Before/after ===== */
.ba-sec { padding: 120px 0; background: #fff; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.ba { position: relative; border-radius: var(--r); overflow: hidden; user-select: none; box-shadow: var(--sh); border: 1px solid var(--line); }
.ba img { width: 100%; pointer-events: none; }
.ba .after-wrap { position: absolute; inset: 0; overflow: hidden; width: 50%; }
.ba .after-wrap img { width: 100%; height: 100%; object-fit: cover; object-position: left top; }
.ba .handle { position: absolute; top: 0; bottom: 0; left: 50%; width: 3px; background: var(--grad); cursor: ew-resize; }
.ba .handle::after {
	content: '⟷';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 54px;
	height: 54px;
	border-radius: 50%;
	background: var(--grad);
	color: #fff;
	display: grid;
	place-items: center;
	font-size: 19px;
	box-shadow: 0 10px 28px rgba(46, 134, 214, .45);
}
.ba .tag { position: absolute; top: 18px; font-size: 12px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: 8px 15px; border-radius: 99px; }
.ba .tag.before { left: 18px; background: rgba(13, 23, 40, .72); color: #fff; backdrop-filter: blur(6px); }
.ba .tag.after { right: 18px; background: var(--grad); color: #fff; }
.ba-cap { display: flex; justify-content: space-between; gap: 22px; margin-top: 20px; color: var(--gray); font-size: 14.5px; flex-wrap: wrap; }

/* ===== Proof (tamna navy) ===== */
.proof { padding: 120px 0; background: var(--navy); color: #fff; position: relative; overflow: hidden; }
.proof::before {
	content: '';
	position: absolute;
	inset: 0;
	pointer-events: none;
	opacity: .5;
	background: radial-gradient(ellipse 50% 60% at 85% 10%, rgba(57, 185, 238, .18), transparent 65%);
}
.proof h2 { color: #fff; }
.proof .lead { color: rgba(255, 255, 255, .6); }
.proof .grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 70px; align-items: start; position: relative; }
.score {
	background: rgba(255, 255, 255, .05);
	border: 1px solid var(--line-d);
	border-radius: var(--r);
	padding: 40px 38px;
	backdrop-filter: blur(6px);
}
.score .big { font-family: 'Schibsted Grotesk', sans-serif; font-weight: 900; font-size: 88px; line-height: 1; letter-spacing: -.04em; }
.score .stars { color: #f4a62b; font-size: 20px; letter-spacing: 3px; margin: 8px 0 4px; }
.score .src { font-size: 14px; color: rgba(255, 255, 255, .55); }
.score .tags { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 24px; }
.score .tags span { font-size: 12px; font-weight: 600; border: 1px solid var(--line-d); border-radius: 99px; padding: 6px 13px; color: rgba(255, 255, 255, .75); }
.pstats { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--line-d); border: 1px solid var(--line-d); border-radius: var(--r); overflow: hidden; margin-top: 26px; }
.pstat { background: var(--navy); padding: 30px 28px; }
.pstat b { font-family: 'Schibsted Grotesk', sans-serif; font-weight: 800; font-size: 34px; display: block; }
.pstat b i { font-style: normal; color: var(--sky); }
.pstat span { font-size: 12.5px; color: rgba(255, 255, 255, .55); }
.rev { border-left: 3px solid var(--sky); padding: 6px 0 6px 26px; margin-bottom: 34px; }
.rev p { font-size: 17.5px; line-height: 1.6; color: rgba(255, 255, 255, .92); }
.rev footer { margin-top: 14px; font-size: 13.5px; color: rgba(255, 255, 255, .5); }
.rev footer b { color: #fff; display: block; font-size: 14.5px; }
.rev .vtag { display: inline-flex; align-items: center; gap: 6px; font-size: 11.5px; font-weight: 700; color: var(--sky); margin-top: 10px; text-transform: uppercase; letter-spacing: .08em; }

/* ===== Process ===== */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 26px; counter-reset: step; }
.step { position: relative; background: #fff; border: 1px solid var(--line); border-radius: var(--r); padding: 34px 28px; transition: transform .3s, box-shadow .3s; }
.step:hover { transform: translateY(-6px); box-shadow: var(--sh); }
.step::before {
	counter-increment: step;
	content: "0" counter(step);
	position: absolute;
	top: 24px;
	right: 24px;
	font-family: 'Schibsted Grotesk', sans-serif;
	font-weight: 900;
	font-size: 44px;
	background: var(--grad);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	opacity: .28;
}
.step .ic { width: 54px; height: 54px; border-radius: 15px; background: var(--wash); display: grid; place-items: center; margin-bottom: 22px; }
.step .ic svg { width: 25px; height: 25px; stroke: var(--blue); fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.step h3 { font-size: 19px; font-weight: 800; }
.step p { font-size: 14px; color: var(--gray); margin-top: 9px; }

/* ===== Products ===== */
.prods { display: grid; grid-template-columns: 1fr 1fr; gap: 26px; }
.prodc {
	border-radius: var(--r);
	padding: 40px 40px 44px;
	color: #fff;
	position: relative;
	overflow: hidden;
	background: var(--navy);
	border: 1px solid var(--line-d);
	transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
	display: block;
}
.prodc:hover { transform: translateY(-6px); box-shadow: 0 30px 80px rgba(13, 23, 40, .35); border-color: rgba(57, 185, 238, .35); }
.prodc::before { content: ''; position: absolute; inset: 0; z-index: 0; background: radial-gradient(ellipse 70% 80% at 90% 0%, rgba(57, 185, 238, .22), transparent 60%); transition: opacity .35s ease; }
.prodc.alt::before { background: radial-gradient(ellipse 70% 80% at 90% 0%, rgba(46, 134, 214, .28), transparent 60%); }
.prodc::after { content: ''; position: absolute; inset: -45%; z-index: 0; pointer-events: none; opacity: .65; background: radial-gradient(circle at 50% 50%, rgba(57, 185, 238, .16), transparent 55%); transition: opacity .35s ease; }
.prodc.alt::after { background: radial-gradient(circle at 50% 50%, rgba(46, 134, 214, .2), transparent 55%); }
.prodc:hover::after { opacity: 1; }
@media (prefers-reduced-motion: no-preference) {
	.prodc::after { animation: prodGlow 16s ease-in-out infinite alternate; }
}
@keyframes prodGlow { from { transform: translate(-12%, -8%); } to { transform: translate(13%, 9%); } }
.prodc > * { position: relative; z-index: 1; }
.prodc__badge { display: inline-flex; align-items: center; gap: 8px; font-size: 10.5px; font-weight: 700; letter-spacing: .09em; text-transform: uppercase; color: rgba(255, 255, 255, .82); background: rgba(255, 255, 255, .07); border: 1px solid var(--line-d); border-radius: 99px; padding: 6px 13px; margin-bottom: 24px; }
.prodc__badge .sq { width: 9px; height: 9px; border-radius: 2px; background: var(--grad); }
.prodc .mini { display: block; font-size: 12px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--sky); }
.prodc h3 { font-size: 27px; font-weight: 800; margin-top: 12px; }
.prodc p { color: rgba(255, 255, 255, .65); font-size: 15px; margin-top: 12px; max-width: 46ch; }
.prodc .link { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; font-size: 14.5px; color: var(--sky); margin-top: 24px; }
.prodc .link span { transition: transform .3s ease; }
.prodc:hover .link span { transform: translateX(4px); }

/* ===== AI Prototype (coming soon) ===== */
.aiproto {
	border-radius: 26px;
	background: var(--navy);
	color: #fff;
	padding: 64px 64px;
	position: relative;
	overflow: hidden;
	display: grid;
	grid-template-columns: 1.25fr .75fr;
	gap: 56px;
	align-items: center;
}
.aiproto::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 60% 90% at 92% 0%, rgba(57, 185, 238, .28), transparent 60%); }
.aiproto > * { position: relative; z-index: 1; }
.aiproto__pill { display: inline-flex; align-items: center; gap: 9px; font-size: 12px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--sky); }
.aiproto__pill .sq { width: 9px; height: 9px; border-radius: 3px; background: var(--grad); display: inline-block; }
.aiproto h2 { margin-top: 16px; color: #fff; }
.aiproto__sub { color: rgba(255, 255, 255, .78); font-size: 16.5px; margin-top: 16px; max-width: 52ch; }
.aiproto__note { color: rgba(255, 255, 255, .55); font-size: 14px; margin-top: 12px; max-width: 52ch; }
.aiproto__act { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; margin-top: 30px; }
.aiproto__meta { font-size: 13px; color: rgba(255, 255, 255, .6); }
.aiproto__vis { display: grid; place-items: center; }
.aiproto__card {
	width: 100%;
	max-width: 290px;
	background: rgba(255, 255, 255, .05);
	border: 1px solid var(--line-d);
	border-radius: 16px;
	padding: 22px;
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.aiproto__dots { display: flex; gap: 6px; margin-bottom: 6px; }
.aiproto__dots i { width: 9px; height: 9px; border-radius: 50%; background: rgba(255, 255, 255, .22); }
.aiproto__line { height: 11px; border-radius: 6px; background: rgba(255, 255, 255, .12); }
.aiproto__line--lg { height: 26px; width: 70%; background: var(--grad); }
.aiproto__line--sm { width: 45%; }
.aiproto__chip { align-self: flex-start; margin-top: 6px; font-size: 11.5px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--sky); background: rgba(57, 185, 238, .12); border-radius: 99px; padding: 6px 13px; }

/* ===== FAQ ===== */
.faq { max-width: 820px; margin: 0 auto; }
.q { border: 1px solid var(--line); border-radius: 16px; background: #fff; margin-bottom: 14px; overflow: hidden; }
.q button {
	all: unset;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 20px;
	width: 100%;
	padding: 24px 28px;
	cursor: pointer;
	font-weight: 700;
	font-size: 17px;
	font-family: 'Schibsted Grotesk', sans-serif;
	letter-spacing: -.01em;
	box-sizing: border-box;
}
.q button .pl { width: 30px; height: 30px; border-radius: 9px; background: var(--wash); color: var(--blue); display: grid; place-items: center; font-size: 18px; flex-shrink: 0; transition: transform .3s; }
.q.open button .pl { transform: rotate(45deg); }
.q .a { max-height: 0; overflow: hidden; transition: max-height .4s ease; }
.q .a p { padding: 0 28px 26px; color: var(--gray); font-size: 15.5px; }

/* ===== CTA ===== */
.cta-band {
	border-radius: 26px;
	background: var(--grad);
	color: #fff;
	padding: 80px 70px;
	position: relative;
	overflow: hidden;
	display: grid;
	grid-template-columns: 1.2fr .8fr;
	gap: 60px;
	align-items: center;
}
.cta-band::before {
	content: '';
	position: absolute;
	right: -60px;
	top: -60px;
	width: 280px;
	height: 280px;
	background: rgba(255, 255, 255, .10);
	border-radius: 40px;
	transform: rotate(18deg);
}
.cta-band::after {
	content: '';
	position: absolute;
	right: 140px;
	bottom: -80px;
	width: 190px;
	height: 190px;
	background: rgba(255, 255, 255, .08);
	border-radius: 32px;
	transform: rotate(-12deg);
}
.cta-band h2 { color: #fff; position: relative; }
.cta-band p { color: rgba(255, 255, 255, .85); margin-top: 18px; position: relative; max-width: 46ch; }
.cta-act { text-align: right; position: relative; z-index: 2; }
.cta-mail { margin-top: 16px; font-size: 13.5px; }
.cta-mail a { color: rgba(255, 255, 255, .85); }

/* ===== Footer ===== */
.site-footer { padding: 90px 0 0; background: #fff; border-top: 1px solid var(--line); overflow: hidden; }
.f-top { display: flex; justify-content: space-between; gap: 60px; flex-wrap: wrap; padding-bottom: 70px; }
.f-top .col h5 { font-size: 12.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: #9aa5b2; margin-bottom: 16px; }
.f-top .col a, .f-top .col .f-loc { display: block; font-size: 15px; color: var(--gray); padding: 5px 0; transition: .2s; }
.f-top .col li { display: contents; }
.f-top .col a:hover { color: var(--blue); }
.f-brand { max-width: 330px; }
.f-brand img { height: 30px; width: auto; margin-bottom: 18px; }
.f-brand p { font-size: 14.5px; color: var(--gray); }
.f-logo { border-top: 1px solid var(--line); padding: 50px 0 30px; }
.f-logo img { width: 100%; max-width: 1080px; margin: 0 auto; }
.f-bottom { display: flex; justify-content: space-between; gap: 18px; padding: 26px 0; color: #9aa5b2; font-size: 13px; flex-wrap: wrap; }
.f-bottom a:hover { color: var(--blue); }

/* ===== Custom cursor ===== */
.cursor {
	position: fixed;
	left: 0;
	top: 0;
	z-index: 9999;
	pointer-events: none;
	width: 12px;
	height: 12px;
	border-radius: 99px;
	background: var(--blue);
	transform: translate(-50%, -50%);
	display: grid;
	place-items: center;
	transition: width .3s, height .3s, background .3s;
}
.cursor .cursor-label {
	font-family: 'Schibsted Grotesk', sans-serif;
	font-weight: 700;
	font-size: 14px;
	color: #fff;
	white-space: nowrap;
	opacity: 0;
	transition: opacity .2s;
}
.cursor.is-open { width: 84px; height: 84px; background: var(--grad); box-shadow: 0 10px 28px rgba(46, 134, 214, .45); }
.cursor.is-open .cursor-label { opacity: 1; }
@media (hover: none), (pointer: coarse) {
	.cursor { display: none; }
}

/* ===== Unutrašnje strane ===== */
.page-hero { padding: 170px 0 70px; }
.page-hero--tight { padding: 124px 0 50px; }
.page-hero__cta { display: flex; align-items: center; gap: 22px; flex-wrap: wrap; margin-top: 30px; }
.page-hero__note { font-size: 14px; color: var(--gray); max-width: 34ch; }
.entry-content { max-width: 760px; padding-bottom: 90px; }
.entry-content > * + * { margin-top: 1.2em; }
.entry-content h2, .entry-content h3 { margin-top: 1.6em; }
.entry-content img { border-radius: var(--r); }
.post-meta { color: var(--gray); font-size: 14px; margin-top: 16px; }
.post-thumb { margin-bottom: 40px; }
.post-thumb img { border-radius: var(--r); }

.post-grid, .case-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 26px; padding-bottom: 90px; }
.post-card, .case-card { background: #fff; border: 1px solid var(--line); border-radius: var(--r); overflow: hidden; transition: transform .3s, box-shadow .3s; }
.post-card:hover, .case-card:hover { transform: translateY(-6px); box-shadow: var(--sh); }
.post-card h2, .case-card__title { font-size: 22px; padding: 20px 24px; }
.post-card > p { padding: 0 24px 24px; color: var(--gray); font-size: 15px; }
.case-card__media { overflow: hidden; }
.case-card__media img { transition: transform .6s ease; }
.case-card:hover .case-card__media img { transform: scale(1.05); }

/* ===== Motion ===== */
.gs { opacity: 0; }
.no-js .gs { opacity: 1; }

@media (prefers-reduced-motion: reduce) {
	.gs, .sq-cluster i { opacity: 1 !important; transform: none !important; }
	.imq .track { animation: none; }
	.cursor { display: none; }
	*, *::before, *::after {
		animation-duration: .01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: .01ms !important;
		scroll-behavior: auto !important;
	}
}

/* ===== Responsive ===== */
@media (max-width: 1020px) {
	.hero-grid { grid-template-columns: 1fr; gap: 50px; }
	.hero-vis { min-height: 380px; }
	.caps-layout { grid-template-columns: 1fr; gap: 36px; }
	.caps-intro__inner { position: static; }
	.caps-intro p { max-width: none; }
	.caps-progress { display: none; }
	.caps.is-enhanced .cap { filter: none; }
	.caps.is-enhanced .cap.is-active { box-shadow: none; border-color: var(--line); }
	.caps.is-enhanced .cap.is-active .cap__media img { transform: none; }
	.caps.is-enhanced .cap .chips span { opacity: 1; transform: none; }
	.caps-support { flex-direction: column; align-items: flex-start; gap: 16px; }
	.proof .grid { grid-template-columns: 1fr; gap: 50px; }
	.steps { grid-template-columns: 1fr 1fr; }
	.prods { grid-template-columns: 1fr; }
	.cta-band { grid-template-columns: 1fr; padding: 54px 34px; }
	.cta-act { text-align: left; }
	.aiproto { grid-template-columns: 1fr; padding: 48px 34px; gap: 40px; }
	.aiproto__vis { display: none; }
	.nav-l a:not(.btn) { display: none; }
	.section--services, .section--process, .section--products, .section--faq, .section--cta, .section--aiproto, .ba-sec, .proof { padding: 90px 0; }
	.section--tight { padding-top: 0; }
	.post-grid, .case-grid { grid-template-columns: 1fr; }
}
@media (max-width: 620px) {
	.steps { grid-template-columns: 1fr; }
	.wrap { padding: 0 20px; }
	.nav-logo img { height: 36px; }
}

/* ============================================================
   Faza 5 — unutrašnje stranice
   ============================================================ */

/* Case study */
.case-subtitle { font-size: 20px; font-weight: 600; color: var(--gray); margin-top: 18px; }
.case-layout { display: grid; grid-template-columns: 1.5fr .9fr; gap: 60px; align-items: start; padding-bottom: 70px; }
.case-intro { max-width: none; }
.case-meta { position: sticky; top: 110px; }
.case-meta__card { background: #fff; border: 1px solid var(--line); border-radius: var(--r); padding: 30px 28px; box-shadow: var(--sh); }
.case-meta__row { display: flex; flex-direction: column; gap: 2px; padding: 12px 0; border-bottom: 1px solid var(--line); }
.case-meta__row:first-child { padding-top: 0; }
.case-meta__label { font-size: 11.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: #9aa5b2; }
.case-meta__value { font-size: 14.5px; font-weight: 600; }
.case-meta__btn { margin-top: 22px; width: 100%; justify-content: center; }
.case-banner img { width: 100%; border-radius: var(--r); box-shadow: var(--sh); }

.case-section { padding: 90px 0 0; }
.case-section--alt { background: #fff; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 90px 0; margin-top: 90px; }
.case-section--alt + .case-section { padding-top: 90px; }
.case-section--cta { padding: 110px 0 0; }

.case-list { list-style: none; margin-top: 26px; max-width: 760px; }
.case-list li { position: relative; padding: 10px 0 10px 30px; color: var(--gray); }
.case-list li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 19px;
	width: 11px;
	height: 11px;
	border-radius: 2.5px;
	background: var(--grad);
}

.case-steps { display: grid; grid-template-columns: repeat(2, 1fr); gap: 26px; margin-top: 40px; }
.case-step { position: relative; background: var(--bg); border: 1px solid var(--line); border-radius: var(--r); padding: 34px 28px; }
.case-step__num {
	font-family: 'Schibsted Grotesk', sans-serif;
	font-weight: 900;
	font-size: 40px;
	background: var(--grad);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	opacity: .35;
	display: block;
	margin-bottom: 14px;
}
.case-step h3 { font-size: 20px; }
.case-step p { color: var(--gray); font-size: 14.5px; margin-top: 8px; }

.case-deliv { display: grid; grid-template-columns: repeat(2, 1fr); gap: 26px; margin-top: 40px; }
.case-deliv__group { background: #fff; border: 1px solid var(--line); border-radius: var(--r); padding: 30px 28px; }
.case-deliv__group h3 { font-size: 19px; margin-bottom: 6px; }
.case-deliv__group .case-list { margin-top: 10px; }
.case-deliv__group .case-list li { padding: 7px 0 7px 26px; font-size: 14.5px; }
.case-deliv__group .case-list li::before { top: 14px; width: 9px; height: 9px; }

.case-gallery { display: grid; grid-template-columns: repeat(2, 1fr); gap: 26px; margin-top: 40px; }
.case-gallery figure:first-child { grid-column: 1 / -1; }
.case-gallery img { width: 100%; border-radius: var(--r); border: 1px solid var(--line); box-shadow: var(--sh); }
.case-gallery figcaption { margin-top: 12px; font-size: 13.5px; color: var(--gray); }

.case-results { background: var(--navy); color: #fff; padding: 90px 0; margin-top: 90px; }
.case-results .lead { color: rgba(255, 255, 255, .6); }
.case-results .case-list li { color: rgba(255, 255, 255, .75); }
.case-metrics { display: grid; grid-template-columns: repeat(4, 1fr); gap: 26px; margin-top: 50px; }
.case-metric b { font-family: 'Schibsted Grotesk', sans-serif; font-weight: 800; font-size: 44px; color: var(--sky); display: block; }
.case-metric__label { font-size: 13px; color: rgba(255, 255, 255, .55); }

.case-quote { border-left: 3px solid var(--sky); padding: 6px 0 6px 30px; max-width: 760px; }
.case-quote p { font-size: 21px; line-height: 1.6; font-weight: 500; }
.case-quote footer { margin-top: 16px; color: var(--gray); font-size: 14px; }
.case-quote footer b { display: block; color: var(--ink); }

.case-nav { display: flex; justify-content: space-between; gap: 20px; padding-top: 70px; padding-bottom: 90px; }
.case-nav__link { font-weight: 700; font-family: 'Schibsted Grotesk', sans-serif; transition: color .2s; }
.case-nav__link:hover { color: var(--blue); }

/* Case kartice (Work) */
.case-card__body { padding: 22px 24px 26px; }
.case-card__industry { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--blue); }
.case-card__title { font-size: 24px; padding: 6px 0 0; }
.case-card__body .chips { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 14px; }
.case-card__body .chips span { font-size: 12px; font-weight: 600; background: var(--wash); color: var(--blue); border-radius: 99px; padding: 6px 13px; }
.case-card__media { aspect-ratio: 4 / 3; }
.case-card__media img { width: 100%; height: 100%; object-fit: cover; }

/* Kontakt + audit raspored */
.contact-layout, .audit-layout { display: grid; grid-template-columns: 1.4fr .9fr; gap: 60px; align-items: start; padding-bottom: 110px; }
.audit-layout { grid-template-columns: .9fr 1.4fr; }
.contact-direct { background: #fff; border: 1px solid var(--line); border-radius: var(--r); padding: 30px 28px; box-shadow: var(--sh); position: sticky; top: 110px; }
.contact-direct h3 { font-size: 19px; margin-bottom: 14px; }
.contact-direct__row { display: block; padding: 8px 0; color: var(--gray); border-bottom: 1px solid var(--line); }
.contact-direct__row:last-child { border-bottom: 0; }
a.contact-direct__row:hover { color: var(--blue); }
.audit-points { display: flex; flex-direction: column; gap: 26px; }
.audit-point { display: flex; gap: 16px; align-items: flex-start; background: #fff; border: 1px solid var(--line); border-radius: var(--r); padding: 26px; }
.audit-point .sq { margin-top: 8px; flex-shrink: 0; }
.audit-point h3 { font-size: 18px; }
.audit-point p { color: var(--gray); font-size: 14.5px; margin-top: 6px; }

/* CF7 forme */
.ac-form__row { margin-bottom: 20px; }
.ac-form__row label { display: block; font-weight: 600; font-size: 14.5px; margin-bottom: 8px; }
.ac-form input[type="text"],
.ac-form input[type="email"],
.ac-form input[type="url"],
.ac-form input[type="tel"],
.ac-form select,
.ac-form textarea {
	width: 100%;
	padding: 14px 16px;
	border: 1.5px solid var(--line);
	border-radius: 12px;
	background: #fff;
	font: inherit;
	font-size: 15px;
	color: var(--ink);
	transition: border-color .2s;
}
.ac-form textarea { min-height: 140px; resize: vertical; }
.ac-form input:focus, .ac-form select:focus, .ac-form textarea:focus { outline: none; border-color: var(--blue); }
.ac-form input.btn { width: auto; border: 0; cursor: pointer; }
.wpcf7-not-valid-tip { color: #d6452e; font-size: 13px; margin-top: 6px; display: block; }
.wpcf7 form .wpcf7-response-output { border-radius: 12px; padding: 14px 18px; margin: 20px 0 0; }
.sap-form { padding-bottom: 110px; }

/* Servisne stranice */
.benefit-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 26px; margin-top: 40px; }
.benefit { background: #fff; border: 1px solid var(--line); border-radius: var(--r); padding: 30px 28px; }
.benefit .sq { margin-bottom: 16px; }
.benefit h3 { font-size: 19px; }
.benefit p { color: var(--gray); font-size: 14.5px; margin-top: 8px; }

@media (max-width: 1020px) {
	.case-layout, .contact-layout, .audit-layout { grid-template-columns: 1fr; gap: 40px; }
	.case-meta, .contact-direct { position: static; }
	.case-steps, .case-deliv, .case-gallery, .benefit-grid { grid-template-columns: 1fr; }
	.case-metrics { grid-template-columns: repeat(2, 1fr); }
	.audit-layout { display: flex; flex-direction: column-reverse; }
}

/* ============================================================
   Faza 7 — storytelling: story sekcija, hero canvas, word reveal
   ============================================================ */

/* Hero canvas — 3D polje brand kvadrata iza sadržaja */
.hero-canvas { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; }
.hero-grid { z-index: 1; }

/* Story — tri poglavlja */
.story { padding: 120px 0 110px; position: relative; overflow: hidden; }
.story .chapters { display: flex; flex-direction: column; gap: 96px; margin-top: 10px; }
.chapter { display: grid; grid-template-columns: 1fr 1fr; gap: 70px; align-items: center; }
.chapter--flip .chapter-media { order: 2; }
.chapter-media { position: relative; border-radius: var(--r); overflow: hidden; border: 1px solid var(--line); box-shadow: var(--sh); height: 430px; }
.chapter-media img { width: 100%; height: calc(100% + 70px); object-fit: cover; will-change: transform; }
.chapter-body .num {
	font-family: 'Schibsted Grotesk', sans-serif;
	font-weight: 900;
	font-size: 86px;
	line-height: 1;
	background: var(--grad);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	opacity: .22;
	display: block;
	margin-bottom: 10px;
}
.chapter-body .kick { margin-bottom: 16px; }
.chapter-body h3 { font-size: clamp(26px, 3vw, 38px); font-weight: 800; letter-spacing: -.02em; }
.chapter-body p { color: var(--gray); margin-top: 16px; max-width: 52ch; }
.story-end { margin-top: 100px; text-align: center; }
.story-end p {
	font-family: 'Schibsted Grotesk', sans-serif;
	font-weight: 800;
	font-size: clamp(24px, 2.8vw, 34px);
	letter-spacing: -.02em;
	max-width: 24ch;
	margin: 0 auto;
}
.story-end .btn { margin-top: 30px; }

/* Word reveal — reči naslova klize iz maske */
.w { display: inline-block; overflow: hidden; vertical-align: top; }
.wi { display: inline-block; will-change: transform; }

@media (max-width: 1020px) {
	.story { padding: 90px 0 80px; }
	.story .chapters { gap: 60px; }
	.chapter { grid-template-columns: 1fr; gap: 28px; }
	.chapter--flip .chapter-media { order: 0; }
	.chapter-media { height: 300px; }
	.chapter-body .num { font-size: 64px; }
	.story-end { margin-top: 70px; }
}
@media (prefers-reduced-motion: reduce) {
	.hero-canvas { display: none; }
	.wi { transform: none !important; }
}

/* Gradient naslovi podeljeni na reči — svaka reč nosi svoj clip */
.grad-t .wi {
	background: var(--grad);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}
