/* ==========================================================================
   TEMA: Crna pozadina, plavi naglasci, bijeli kontrast
   Ovo je kompletna zamjena za postojeći styles.css
   ========================================================================== */

/* ========== 1) ROOT & TEMA (boje, tipografija, fokus) ==================== */
:root{
  /* Tema */
  --bg:#0a0a0b;           /* CRNA / gotovo crna pozadina */
  --surface:#0f1115;      /* tamna površina (header/surface) */
  --card:#12161d;         /* kartice/panels */
  --line:#1a2230;         /* obrubi/linije */
  --text:#e8ecf1;         /* osnovni tekst (bijeli kontrast) */
  --muted:#9aa7b5;        /* prigušen tekst */
  --accent:#3b82f6;       /* PLAVI naglasak (primarni) */
  --accent-weak:#60a5fa;  /* svjetliji plavi za hover/efekte */

  /* Radius i brzine */
  --r-xs:10px;
  --r-sm:12px;
  --r-md:14px;
  --r-lg:16px;

  --tr-fast:160ms;
  --tr-mid:240ms;
}

*{ box-sizing:border-box }

html,body{
  margin:0; padding:0;
  background:var(--bg);
  color:var(--text);
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Noto Sans",Cantarell,"Helvetica Neue",Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

a{
  color:var(--accent);
  text-decoration:none;
  transition:color var(--tr-fast) ease, opacity var(--tr-fast) ease;
}
a:hover{ color:var(--accent-weak); }

img{ max-width:100%; display:block; }

.container{ max-width:1100px; margin:0 auto; padding:24px; }

/* Vidljivi fokus za pristupačnost */
:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:2px;
  border-radius:6px;
}

/* ========== 2) HEADER / NAVIGACIJA ======================================= */

:root{
  --header-base-h: 60px;  /* visina “prije” (LP) */
  --header-shrink-h: 40px; /* visina “poslije” (LP) */
  --header-pb: 12px;       /* vertikalni padding (LP) */
}

/* Fixed header s blur pozadinom (LP) */
header{
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 100;
  --header-h: var(--header-base-h);
  background: linear-gradient(180deg, rgba(10,10,11,.92), rgba(10,10,11,.82));
  backdrop-filter: blur(8px);
  border-bottom: none; /* crta je pseudo-element ispod */
}

/* Unutarnji layout: visina=header-h + 2*padding; centrirano po visini */
header .container.nav{
  height: calc(var(--header-h) + (var(--header-pb) * 2));
  padding-block: var(--header-pb);
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  transition: height var(--tr-mid) ease, padding var(--tr-mid) ease;
}

/* Donja PLAVA linija (LP je bio narančast; ovdje je var(--accent)) */
header::after{
  content:"";
  position:absolute; left:0; right:0; bottom:0;
  height: 2px;
  background: var(--accent);
  box-shadow: 0 0 12px rgba(59,130,246,.4);
  opacity: .95;
  transition: opacity var(--tr-mid) ease;
}

/* Brand: logo skalarno prati visinu headera (LP: “veliki logo” → “mali”) */
header .brand{ display:flex; align-items:center; gap:12px; }
header .brand .logo{
  width: var(--header-h);
  height: var(--header-h);
  border-radius: 14px;
  background: conic-gradient(from 210deg at 50% 50%, #0f172a 0deg, #1e3a8a 160deg, #3b82f6 260deg, #60a5fa 360deg);
  box-shadow: 0 0 0 1px rgba(255,255,255,.06) inset, 0 0 24px rgba(59,130,246,.25);
  transition: width var(--tr-mid) ease, height var(--tr-mid) ease, border-radius var(--tr-mid) ease, box-shadow var(--tr-mid) ease;
}

/* Nav linkovi: klik-zona je cijela visina headera (LP) */
header nav{ display:flex; align-items:center; gap:10px; }
header nav a{
  display:inline-flex; align-items:center; line-height:1;
  height: var(--header-h);     /* vertikalno centrirani, velika klik-zona */
  padding: 0 6px;              /* vodoravni padding; “isti feeling” kao LP */
}

/* Shrink na scroll (LP) */
header.is-shrink{ --header-h: var(--header-shrink-h); }
header.is-shrink::after{ opacity: 1; }

/* Spacer visina = base visina + 2*padding (LP) */
.header-spacer{ height: calc(var(--header-base-h) + (var(--header-pb) * 2)); }

/* Ako želiš 60/40 varijantu kasnije, promijeni samo varijable gore,
   ostali kod ostaje identičan. */

/* ========== 3) HERO SEKCIJA ============================================== */
.hero{
  padding:80px 0 40px; text-align:center;
}
h1{
  font-size:clamp(28px,4vw,44px);
  line-height:1.08; margin:0 0 12px;
  color:#ffffff;
}
.subtitle,.hero .lead{
  color:var(--muted);
  max-width:64ch; margin:12px auto 24px; opacity:.95;
}

/* CTA red u hero-u */
.cta-row{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

/* Dugmad (primarno plavo, ghost tamni obrub s plavim hoverom) */
.btn-primary{
  background:var(--accent); color:#fff;
  border:1px solid var(--accent);
  padding:10px 14px; border-radius:var(--r-sm);
  transition:filter var(--tr-fast) ease, transform var(--tr-fast) ease, background var(--tr-fast) ease;
}
.btn-primary:hover{
  filter:brightness(1.05);
  background:var(--accent-weak);
  transform:translateY(-1px);
}

.btn-ghost{
  color:var(--text);
  background:transparent;
  border:1px solid rgba(148,163,184,.3);
  padding:10px 14px; border-radius:var(--r-sm);
  transition:border-color var(--tr-fast) ease, background var(--tr-fast) ease, transform var(--tr-fast) ease;
}
.btn-ghost:hover{
  border-color:var(--accent);
  background:rgba(59,130,246,.10);
  transform:translateY(-1px);
}

/* Hero kartica (ako postoji) */
.hero-card{
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  border:1px solid var(--line);
  padding:18px 16px; border-radius:var(--r-lg);
}

/* ========== 4) GRID & SEKCIJE (generičko) ================================ */
.section{ padding:28px 0; }
.section h2{
  font-size:clamp(22px,3vw,32px); margin:0 0 16px; color:#fff;
}
.muted{ color:var(--muted); }

.grid{ display:grid; gap:20px; }
@media (min-width:820px){
  .grid-2{ grid-template-columns:1.2fr .8fr; }
}

/* ========== Zašto NFK (selling points ================================= */
/* ============================================================
   ZAŠTO NFK — 3×2 USP grid (dark/blue, glassy, a11y)
   ============================================================ */
.why-grid h2{ margin-bottom: 12px; }

.usp-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
}
@media (max-width: 980px){
  .usp-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 620px){
  .usp-grid{ grid-template-columns: 1fr; }
}

.usp{
  border: 1px solid var(--line);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  padding: 16px 16px 18px;
  transition: border-color 220ms ease, box-shadow 220ms ease, transform 220ms ease, opacity 220ms ease;
  opacity: .96;
}
.usp:hover{
  border-color: rgba(59,130,246,.35);
  box-shadow: 0 12px 32px rgba(0,0,0,.32);
  transform: translateY(-2px);
}

.usp .icon{
  width: 44px; height: 44px;
  display:grid; place-items:center;
  border-radius: 12px;
  background: rgba(59,130,246,.10);
  border: 1px solid rgba(59,130,246,.35);
  box-shadow: 0 0 0 1px rgba(59,130,246,.10) inset, 0 8px 24px rgba(0,0,0,.30);
  margin-bottom: 10px;
  color: #cfe1ff; /* boja stroke-a (currentColor) */
}
.usp .icon svg{ width: 26px; height: 26px; display:block; }

.usp h3{ margin: 0 0 6px; color:#fff; font-size: 1.05rem; }
.usp p{ margin: 0; }

/* Scroll-reveal (IO dodaje .reveal) */
.usp{ transform: translateY(6px); opacity: 0; }
.usp.reveal{ transform: translateY(0); opacity: 1; }

@media (prefers-reduced-motion: reduce){
  .usp, .usp:hover{ transition:none; transform:none; }
  .usp{ opacity:1; }
}

/* ZAŠTO NFK grid — lagani "lift" jedne kartice na hover/focus */
.usp-grid .usp{
  transform: translateY(0);
  will-change: transform, box-shadow, border-color;
  transition:
    transform 220ms cubic-bezier(.22,.61,.36,1),
    box-shadow 220ms ease,
    border-color 220ms ease,
    opacity 180ms ease;
}

/* podigni baš onu na kojoj je kursor ili fokus */
.usp-grid .usp:hover,
.usp-grid .usp:focus-within{
  transform: translateY(-6px);
  border-color: rgba(59,130,246,.45);
  box-shadow: 0 14px 36px rgba(0,0,0,.36);
  opacity: 1;
}

/* ostale su mrvu tiše dok jedna "lebdi" */
@media (hover:hover){
  .usp-grid:hover .usp:not(:hover){
    opacity: .88;
  }
}

/* tipkovnica: da se ponaša kao hover kad je fokus u kartici */
.usp-grid .usp:focus-within { outline: none; }
.usp-grid .usp:focus-visible { outline: 2px solid rgba(59,130,246,.6); outline-offset: 2px; }

/* respect reduced motion */
@media (prefers-reduced-motion: reduce){
  .usp-grid .usp{ transition: none; transform: none; }
  .usp-grid .usp:hover,
  .usp-grid .usp:focus-within{ transform: none; }
}


/* ========== Problem-->Rješenje ================================= */

/* Kartica sa SLA barom */
.sla-card{
  border:1px solid var(--line);
  border-radius:16px;
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  padding:18px 18px 20px;
  box-shadow: 0 8px 30px rgba(0,0,0,.28);
  margin-top: 12px;
}
.sla-head{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:10px; }
.sla-badges{ display:flex; flex-wrap:wrap; gap:8px; }
.badge{
  display:inline-flex; align-items:center; gap:8px;
  border:1px solid var(--line);
  border-radius:999px; padding:6px 10px; font-size:.86rem;
}
.badge.pos{ color:#d7e7ff; border-color: rgba(59,130,246,.35); background: rgba(59,130,246,.10); }
.badge.ghost{ color:#e6edf7; background: rgba(255,255,255,.04); }

/* Skala u sekundama: data-max (npr. 300s), data-value (npr. 60s) */
.sla-scale{
  --max: 300;    /* fallback ako nema data- */
  --value: 60;
  position: relative;
  border-radius: 12px;
  padding: 12px 10px 24px;
  background: rgba(255,255,255,.02);
  border: 1px solid var(--line);
  overflow: hidden;
}
.sla-scale .track{
  height: 10px; border-radius: 999px;
  background: rgba(148,163,184,.18);
}
.sla-scale .fill{
  position: absolute; left: 10px; right: 10px; top: 12px; height: 10px;
  border-radius: 999px; width: 0%;
  background: linear-gradient(90deg, rgba(59,130,246,.9), rgba(96,165,250,.9));
  box-shadow: 0 0 18px rgba(59,130,246,.45);
  transform-origin: left center;
}

/* tick markeri */
.sla-scale .tick{
  position: absolute; top: 32px; transform: translateX(-50%);
}
.sla-scale .tick span{
  display:inline-block; margin-top: 8px;
  color: var(--muted); font-size:.86rem; white-space:nowrap;
  background: rgba(255,255,255,.02);
  border:1px solid var(--line); border-radius: 8px; padding: 4px 6px;
}
.sla-scale .tick-exp::before,
.sla-scale .tick-nfk::before{
  content:""; position:absolute; bottom: 16px; left: 50%; transform: translateX(-50%);
  width: 2px; height: 14px; background: var(--accent);
  box-shadow: 0 0 10px rgba(59,130,246,.45);
}

/* Meta ispod skale */
.sla-meta ul{ margin: 10px 0 0; padding-left: 18px; }
.sla-meta li{ margin: 6px 0; color: var(--text); }

/* Grid za timeline (prije/poslije) */
.ps-grid{
  display: grid; gap: 14px; margin-top: 16px;
}
@media (min-width: 900px){
  .ps-grid{ grid-template-columns: 1fr 1fr; }
}
.ps-col{
  border:1px solid var(--line);
  border-radius:16px;
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  padding:18px 18px 20px;
  box-shadow: 0 8px 30px rgba(0,0,0,.22);
}
.ps-col h3{ margin:0 0 8px; color:#fff; }
.steps{
  counter-reset: step;
  margin:0; padding-left: 0; list-style:none;
}
.steps li{
  position:relative;
  display:flex; align-items:flex-start; gap:10px;
  padding-left: 2px; margin:8px 0;
  opacity:0; transform: translateY(8px);
  transition: opacity 260ms ease, transform 260ms ease;
  transition-delay: calc(var(--i, 0) * 80ms);
}
.steps li.reveal{ opacity:1; transform: translateY(0); }
.steps .dot{
  width:10px; height:10px; border-radius:999px; margin-top: 7px;
  background: rgba(59,130,246,.85);
  box-shadow: 0 0 12px rgba(59,130,246,.45);
}

/* Pristupačnost: smanji pokret ako korisnik to želi */
@media (prefers-reduced-motion: reduce){
  .steps li{ opacity:1; transform:none; transition:none; }
  .sla-scale .fill{ transition:none; }
}

/* Osiguraj da anchor skok ne upadne ispod sticky headera */
.ps-v2 [id]{ scroll-margin-top: calc(var(--header-shrink-h, 40px) + 20px); }
/* (Best-practice za fixed header offset) */

/* ============================================================
   PREVIŠE UPITA — SLA bar stage UI + fine animacije
   ============================================================ */

/* Stage “heading” iznad skale (JS ga ubaci) */
.sla-stage{
  display:flex; align-items: baseline; gap:10px;
  margin: 2px 0 8px;
}
.sla-stage .stage-pill{
  display:inline-flex; align-items:center;
  border:1px solid rgba(59,130,246,.40);
  background: rgba(59,130,246,.12);
  color:#eaf2ff;
  border-radius:999px; padding:6px 10px;
  font-size:.86rem; letter-spacing:.02em;
}
.sla-stage .stage-copy{
  margin:0; color: var(--muted);
}

/* mali fade kad se mijenja stage text */
.sla-stage.swapping{ opacity:.45; transition: opacity 140ms ease; }

/* glađe punjenje — kad scroll handler mijenja width često */
.sla-scale .fill{
  transition: width 160ms cubic-bezier(.22,.61,.36,1);
}

/* Ako želiš skroz sakriti stare badgeve iznad skale (ostavi zakomentirano ako ih želiš zadržati) */
/*
.ps-v2 .sla-head{ display:none; }
*/

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  .sla-stage.swapping{ transition: none; opacity:1; }
  .sla-scale .fill{ transition: none; }
}

/* ============================================================
   PREVIŠE UPITA — fade kod izmjene donjeg teksta (bullets)
   ============================================================ */
.sla-meta ul.swapping{ opacity:.45; transition: opacity 140ms ease; }
@media (prefers-reduced-motion: reduce){
  .sla-meta ul.swapping{ transition:none; opacity:1; }
}


/* ========== 5) KARTICE (features/cijene) ================================= */
.cards{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px,1fr));
  gap:16px; margin-top:10px;
}
.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:18px;
  padding:18px;
  display:flex; flex-direction:column; gap:14px;
  transition:transform var(--tr-fast) ease, border-color var(--tr-fast) ease, box-shadow var(--tr-fast) ease;
}
.card:hover{
  transform:translateY(-2px);
  border-color:rgba(59,130,246,.35);
  box-shadow:0 10px 30px rgba(0,0,0,.35);
}
.card h3{ margin:0; font-size:18px; color:#ffffff; }
.price{ font-size:24px; font-weight:700; color:#fff; }

.tag{
  display:inline-block; font-size:12px;
  color:var(--muted);
  border:1px solid var(--line);
  padding:4px 8px; border-radius:999px;
}

.card ul{ margin:0; padding-left:18px; color:var(--muted); }

.card .btn{
  margin-top:auto;
  border:1px solid rgba(59,130,246,.6);
  color:#fff; background:transparent;
  padding:10px 12px; border-radius:var(--r-sm);
  text-align:center;
  transition:background var(--tr-fast) ease, border-color var(--tr-fast) ease, transform var(--tr-fast) ease;
}
.card .btn:hover{
  background:rgba(59,130,246,.12);
  border-color:var(--accent);
  transform:translateY(-1px);
}

/* ========== 6) TABLICE =================================================== */
/* ===== Tablica: okvir + sticky header + scroll shadows ===== */
.table-wrap{
  position: relative;
  overflow: auto;            /* horizontala i/ili vertikala */
  border: 1px solid var(--line);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  box-shadow: 0 8px 30px rgba(0,0,0,.22);
}

/* Scroll shadows (pokazuju da ima još sadržaja) */
.table-wrap::before,
.table-wrap::after{
  content:""; position: sticky; top: 0; bottom: 0; width: 16px;
  pointer-events: none; z-index: 2;
}
.table-wrap::before{
  left: 0;
  background: linear-gradient(90deg, rgba(0,0,0,.0), rgba(0,0,0,.35));
  opacity: 0;
}
.table-wrap::after{
  right: 0;
  background: linear-gradient(270deg, rgba(0,0,0,.0), rgba(0,0,0,.35));
  opacity: 1;
}
.table-wrap.at-start::before{ opacity: 0; }
.table-wrap.at-start::after{ opacity: 1; }
.table-wrap.at-end::after{ opacity: 0; }
.table-wrap.at-end::before{ opacity: 1; }

/* Tablica “glass” stil */
.table-compare{
  width: 100%;
  border-spacing: 0; /* ne koristimo collapse radi sticky headera */
  min-width: 640px;  /* lagani “guard” protiv lomljenja kolona */
}
.table-compare thead th{
  position: sticky; top: 0; z-index: 1;
  background: rgba(8,12,20,.65);
  backdrop-filter: blur(6px);
  border-bottom: 1px solid var(--line);
  text-align: left;
  color: #eaf2ff;
  font-weight: 600;
}
.table-compare th, .table-compare td{
  padding: 12px 14px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  vertical-align: top;
}

/* Zebra + hover reda */
.table-compare tbody tr:nth-child(odd) td{ background: rgba(255,255,255,.02); }
.table-compare tbody tr:hover td{ background: rgba(59,130,246,.06); }

/* Column highlight (JS postavlja data-col na .table-wrap) */
.table-wrap[data-col="1"] td:nth-child(1),
.table-wrap[data-col="1"] th:nth-child(1),
.table-wrap[data-col="2"] td:nth-child(2),
.table-wrap[data-col="2"] th:nth-child(2),
.table-wrap[data-col="3"] td:nth-child(3),
.table-wrap[data-col="3"] th:nth-child(3),
.table-wrap[data-col="4"] td:nth-child(4),
.table-wrap[data-col="4"] th:nth-child(4){
  background: rgba(59,130,246,.10);
}

/* Sitne tipografske finese */
.table-compare td:first-child{ font-weight: 600; color:#fff; }
.table-compare td:last-child{ color:#dbe7ff; }

/* Skriveni caption za a11y */
.visually-hidden{
  position:absolute !important; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0;
}

/* Mobile: okvir dobiva “hint” da je skrolabilno */
@media (max-width: 720px){
  .table-compare{ min-width: 520px; }
}

/* Usluge: razmak između price grida (.cards) i tablice ispod */
.cards + .table-wrap{
  margin-top: clamp(20px, 3vw, 44px); /* fino skalira od mobitela do desktopa */
}

/* (Opcionalno) malo zraka i ispod tablice */
.table-wrap{
  margin-bottom: clamp(16px, 2vw, 28px);
}


/* ========== 7) PROCES (koraci) ========================================== */
/* ============================================================
   KAKO RADIMO — Vertikalni timeline (focus on active step)
   ============================================================ */

.timeline{ 
  position: relative;
  list-style: none;
  margin: 12px 0 0;
  padding: 0;
}

/* vertikalna “tračnica” */
.timeline::before{
  content:"";
  position:absolute; left: 26px; top: 0; bottom: 0;
  width: 2px; 
  background: rgba(148,163,184,.22);
}

/* jedan korak */
.timeline .step{
  position: relative;
  display: grid;
  grid-template-columns: 52px 1fr;
  gap: 12px;
  align-items: start;
  padding: 12px 0;
  scroll-margin-top: calc(var(--header-shrink-h, 40px) + 18px); /* da anchor ne upadne ispod headera */
}

/* kružni čvor + broj */
.timeline .node{
  position: relative; width: 52px; height: 100%;
  display:grid; place-items:center;
}
.timeline .node::before{
  content:""; 
  position: absolute; 
  width: 14px; height: 14px; 
  border-radius: 999px;
  background: rgba(59,130,246,.9);
  border: 2px solid rgba(59,130,246,.45);
  box-shadow: 0 0 14px rgba(59,130,246,.45);
}
.timeline .node span{
  position: relative; z-index:1;
  font-size:.82rem; color:#cfe1ff;
}

/* kartica sadržaja */
.timeline .content{
  border: 1px solid var(--line);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  padding: 14px 16px;
  transition: 
    filter 200ms ease,
    opacity 200ms ease,
    transform 200ms ease,
    border-color 220ms ease,
    box-shadow 220ms ease;
}
.timeline .content h3{ margin: 0 0 6px; color:#fff; }

/* FOCUS MODE: kad postoji aktivni, drugi su “mute/blur” */
.timeline.has-active .step .content{
  filter: blur(2px) saturate(.9);
  opacity: .55;
  transform: scale(.985);
}
.timeline .step.is-active .content{
  filter: none; opacity: 1; transform: translateX(0) scale(1);
  border-color: rgba(59,130,246,.35);
  box-shadow: 0 10px 28px rgba(0,0,0,.35);
}
.timeline .step.is-active .node::before{
  background: #fff; border-color: #7fb4ff; 
  box-shadow: 0 0 0 3px rgba(59,130,246,.22), 0 0 18px rgba(59,130,246,.55);
}

/* Hover (na desktopu) */
@media (hover:hover){
  .timeline .step:hover .content{ border-color: rgba(255,255,255,.2); }
}

/* Poštuj „reduce motion” */
@media (prefers-reduced-motion: reduce){
  .timeline .content{ transition: none; }
  .timeline.has-active .step .content{ filter: none; opacity: 1; transform: none; }
}

/* Malo zraka ispod sekcije */
.timeline-section{ padding-bottom: 8px; }

/* Timeline: sakrij brojeve unutar krugova */
.timeline .node span{ display:none !important; }


/* ========== 8) FAQ ======================================================= */
.faq details{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:14px; padding:12px 14px;
}
.faq details+details{ margin-top:10px; }
.faq summary{ cursor:pointer; font-weight:600; color:#fff; }
.faq p{ color:var(--muted); }

/* ========== 9) FOOTER ==================================================== */
/* =========================
   FOOTER — 3 kolone (grid)
   ========================= */
.site-footer{
  margin-top: clamp(24px, 5vw, 56px);
  border-top: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01));
}
.site-footer .container{ padding-top: 18px; padding-bottom: 14px; }

/* Grid 3x1 (kolone), skala na 2/1 na manjim širinama */
.footer-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: clamp(12px, 2.5vw, 20px);
  align-items: start;
}
@media (max-width: 920px){
  .footer-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .footer-cta{ grid-column: 1 / -1; } /* CTA u puni red kad su 2 kolone */
}
@media (max-width: 600px){
  .footer-grid{ grid-template-columns: 1fr; }
}

/* Naslovi i vertikalni ritam */
.footer-title{
  margin: 0 0 8px;
  color: #fff;
  font-size: 1rem;
  font-weight: 600;
}

/* Jedinstveni “body spacing” za sve liste u footeru */
.footer-list{
  list-style: none;
  margin: 0; padding: 0;
  display: grid;
  gap: 8px; /* ⟵ UNIFIKACIJA razmaka između redaka teksta */
}

.footer-list a{
  color: var(--muted);
  text-decoration: none;
  transition: color 200ms ease;
}
.footer-list a:hover{ color:#fff; }

/* Kontakt stavke s ikonom u istoj liniji */
.contact-item{
  display: inline-flex; align-items: center; gap: 8px;
  color: #e6edf7; text-decoration: none;
  border: 1px solid var(--line);
  border-radius: 999px; padding: 6px 10px;
  background: rgba(255,255,255,.03);
  transition: border-color 220ms ease, background 220ms ease, transform 180ms ease;
}
.contact-item:hover{
  border-color: rgba(59,130,246,.35);
  background: rgba(59,130,246,.10);
  transform: translateY(-1px);
}
.contact-item svg{ width: 16px; height: 16px; display:block; color:#cfe1ff; }

/* CTA kolona */
.footer-cta .cta-link{
  display: inline-flex; width: 100%;
  align-items: center; justify-content: center; gap: 10px;
  border: 1px solid rgba(59,130,246,.45);
  border-radius: 12px;
  padding: 12px 16px;
  color: #eaf2ff; text-decoration: none;
  background: linear-gradient(180deg, rgba(59,130,246,.16), rgba(59,130,246,.10));
  box-shadow: 0 8px 26px rgba(0,0,0,.28), inset 0 0 0 1px rgba(59,130,246,.10);
  transition: transform 220ms cubic-bezier(.22,.61,.36,1), box-shadow 220ms ease, border-color 220ms ease;
}
.footer-cta .cta-link:hover{
  transform: translateY(-2px);
  box-shadow: 0 12px 34px rgba(0,0,0,.34);
  border-color: rgba(59,130,246,.55);
}
.footer-cta .cta-link svg{ width: 18px; height: 18px; }

/* Donja linija */
.footer-bottom{
  margin-top: clamp(12px, 2vw, 18px);
  color: var(--muted);
  font-size: .95rem;
  border-top: 1px solid rgba(255,255,255,.06);
  padding-top: 10px;
}

/* Focus ring */
.footer-list a:focus-visible,
.contact-item:focus-visible,
.footer-cta .cta-link:focus-visible{
  outline: 2px solid rgba(59,130,246,.6);
  outline-offset: 2px;
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  .contact-item, .footer-cta .cta-link{ transition: none; transform: none; }
}

/* ========== 10) CHAT WIDGET (plutajući demo) ============================= */
.chat-launch{
  position:fixed; right:18px; bottom:18px;
  background:#111827;  /* tamna ploha */
  border:1px solid var(--line);
  color:#fff; border-radius:999px;
  padding:12px 14px; font-weight:600;
  box-shadow:0 6px 30px rgba(0,0,0,.35);
  transition:border-color var(--tr-fast) ease, transform var(--tr-fast) ease, background var(--tr-fast) ease;
}
.chat-launch:hover{
  border-color:var(--accent);
  background:#0e1625;
  transform:translateY(-1px);
}

.chat-panel{
  position:fixed; right:18px; bottom:76px;
  width:340px; max-height:68vh;
  background:var(--card);
  border:1px solid var(--line);
  border-radius:16px;
  display:none; flex-direction:column; overflow:hidden;
  box-shadow:0 18px 60px rgba(0,0,0,.45);
}

.chat-head{
  padding:12px 14px;
  border-bottom:1px solid var(--line);
  display:flex; align-items:center; justify-content:space-between;
}

.chat-body{
  padding:12px 12px 8px;
  overflow:auto; display:flex; flex-direction:column; gap:8px;
}

.msg{ display:flex; gap:8px; align-items:flex-start; }

.bubble{
  padding:10px 12px; border-radius:14px;
  max-width:80%;
  border:1px solid var(--line);
}

/* Boje mjehurića: bot tamniji, user malo svjetliji */
.msg .b{ background:#0e1320; }
.msg .u{ background:#121a2a; }

.chat-foot{
  padding:10px;
  border-top:1px solid var(--line);
  display:flex; gap:8px;
}
.chat-foot input{
  flex:1;
  background:#0b1220;
  border:1px solid var(--line);
  border-radius:10px;
  padding:10px 12px; color:#fff;
}
.chat-foot input::placeholder{ color:#7f8ea1; }

.chat-foot button{
  border:1px solid rgba(59,130,246,.65);
  background:transparent; color:#fff;
  border-radius:10px; padding:10px 12px;
  transition:background var(--tr-fast) ease, border-color var(--tr-fast) ease, transform var(--tr-fast) ease;
}
.chat-foot button:hover{
  background:rgba(59,130,246,.12);
  border-color:var(--accent);
  transform:translateY(-1px);
}

.notice{ font-size:12px; color:var(--muted); }

/* ========== 11) POMOĆNE KLASe =========================================== */
.hide{ display:none !important; }
.center{ text-align:center; }
.narrow{ max-width:880px; margin:0 auto; text-align:center; }

/* ============================================================
   HERO AURORA + GLASS + SPLIT LAYOUT — v2 (ZAMJENA BLOKA)
   - Širi "glass" box (više "zraka"), ali ostaje 100% vidljiv na prvom loadu
   - Showcase veći proporcionalno
   - Tipkanje: caret stilovi + mala poboljšanja čitljivosti
   ============================================================ */

/* --- Layout: malo niži padding da sve stane u 1 viewport --- */
.hero-aurora{
  position: relative;
  overflow: clip;
  padding: 20px 0 24px; /* bilo 90px — smanjeno da kartica stane bez scrolla */
}

/* Dvostupac: lijevo šire, desno također malo veće */
.hero-grid{
  display: grid;
  gap: 28px;
}
@media (min-width: 900px){
  .hero-grid{
    /* lijevo široko, desno veće — proporcionalno */
    grid-template-columns: minmax(560px, 1.35fr) minmax(520px, 1.10fr);
    align-items: center;
  }
}

/* --- Glass kartica s više "zraka", ali kontrolirane visine --- */
.hero-copy.glass{
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 36px 32px;             /* više unutarnjeg prostora */
  backdrop-filter: blur(8px);
  box-shadow: 0 20px 60px rgba(0,0,0,.34);

  /* Kartica mora stati u prvi viewport — zadrži marginu za header */
  max-height: calc(100svh - 140px);
  min-height: min(64vh, 680px);   /* dovoljno visoka da izgleda "hero" */
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 10px;
}

/* Tipografija u hero-u */
.hero-aurora h1{ font-size: clamp(32px, 4.5vw, 56px); line-height:1.08; }
.hero-copy .lead{ max-width: 62ch; margin-bottom: 24px; }

/* Metrics / selling points */
.metrics{
  display:flex; flex-wrap:wrap; gap:8px 12px;
  margin: 16px 0 0; padding:0; list-style:none;
}
.metrics li{
  border:1px solid var(--line);
  border-radius:999px;
  padding:6px 10px;
  color: var(--muted);
  font-size:.92rem;
}

/* --- Showcase (terminal) veći i prozračniji --- */
.hero-visual{ display:grid; place-items:center; }
.terminal{
  width: clamp(450px, 52vw, 600px);  /* VEĆE: raste s viewportom */
  background: #0b1220;
  border:1px solid rgba(59,130,246,.35);
  border-radius:16px;
  box-shadow: 0 30px 80px rgba(0,0,0,.45), 0 0 0 1px rgba(59,130,246,.08) inset;
  overflow:hidden;
}
.term-head{
  display:flex; gap:8px; align-items:center;
  padding:10px 12px; border-bottom:1px solid var(--line);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
}
.term-head span{
  width:10px; height:10px; border-radius:999px; display:inline-block;
  background: rgba(255,255,255,.16);
}
.term-body{
  margin:0; padding:18px 16px 22px; color:#dbe7ff;
  font: 14.5px/1.6 ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  white-space:pre-wrap;
  max-height: calc(100svh - 190px);  /* ne prelazi prvi viewport */
  overflow:auto;
}

/* Tipkajući kursor (JS dodaje .caret span) */
.caret{
  display:inline-block;
  width: 0.6ch;
  border-left: 2px solid #cfe1ff;
  margin-left: 2px;
  animation: caretBlink 1s steps(1) infinite;
}
@keyframes caretBlink{ 50% { border-color: transparent; } }

/* --- Aurora pozadina (radijalni gradijenti koji "dišu") --- */
.aurora{
  position:absolute; inset:-20% -10% -10% -10%;
  z-index:-1;
  filter: blur(30px) saturate(120%);
  opacity:.9;
  background:
    radial-gradient(40% 35% at 20% 20%, rgba(61,130,246,.80), transparent 60%),
    radial-gradient(35% 30% at 80% 30%, rgba(12,115,255,.55), transparent 65%),
    radial-gradient(55% 45% at 50% 85%, rgba(96,165,250,.45), transparent 70%);
  animation: auroraMove 18s ease-in-out infinite alternate;
}
@keyframes auroraMove{
  0%   { transform: translate3d(0px, -10px, 0) scale(1);    filter: blur(30px) saturate(120%); }
  50%  { transform: translate3d(0px, 10px, 0)  scale(1.06); filter: blur(34px) saturate(125%); }
  100% { transform: translate3d(0px, -6px, 0)  scale(1.03); filter: blur(32px) saturate(122%); }
}

/* Poštivanje korisničke preferencije za manje pokreta */
@media (prefers-reduced-motion: reduce){
  .aurora{ animation: none; }
}


/* Global smooth scroll (respektiraj prefers-reduced-motion) */
html{ scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
}

/* Anchor offset za sticky header (ako već nemaš globalno) */
.section[id]{ scroll-margin-top: calc(var(--header-shrink-h, 40px) + 20px); }

/* Aktivni link – suptilan underline kao “ink” */
.nav a{
  position: relative;
  transition: color 220ms ease;
}
.nav a::after{
  content:""; position:absolute; left:0; right:0; bottom:-8px; height:2px;
  background: linear-gradient(90deg, rgba(59,130,246,.9), rgba(96,165,250,.9));
  transform: scaleX(0); transform-origin: center;
  opacity: 0;
  transition: transform 280ms cubic-bezier(.22,.61,.36,1), opacity 180ms ease;
}
.nav a.is-active{ color:#fff; }
.nav a.is-active::after{
  opacity: 1; transform: scaleX(1);
}


/* Razdjelnik u navu */
.nav .dot{ opacity:.35; margin:0 10px; }

/* Hamburger gumb: desktop sakrij */
.nav-toggle{
  display:none; background:transparent; border:1px solid var(--line);
  color:#eaf2ff; border-radius:10px; padding:8px 10px; line-height:0;
}
.nav-toggle .icon-close{ display:none; }

/* Mobilni stilovi */
@media (max-width: 900px){
  /* pokaži hamburger, sakrij inline točke na mobu */
  .nav-toggle{ display:inline-flex; align-items:center; gap:8px; }
  .nav .dot{ display:none; }
  
  /* nav kao “panel” ispod headera */
  #primaryNav{
    position: fixed;
    left: 12px; right: 12px;
    top: var(--nav-top, calc(var(--header-shrink-h, 40px) + 10px));
    z-index: 1000;
    display: grid; gap: 10px;
    padding: 12px;
    border:1px solid var(--line);
    border-radius: 14px;
    background: rgba(8,12,20,.92);
    backdrop-filter: blur(8px);
    transform: translateY(-8px) scale(.98);
    opacity: 0; pointer-events: none;
    transition: transform 220ms cubic-bezier(.22,.61,.36,1), opacity 160ms ease;
  }
  #primaryNav a{ display:block; padding:8px 8px; }
  #primaryNav .cta{
    text-align:center; border-radius: 10px;
  }

  /* overlay iza menija */
  .nav-overlay{
    position: fixed; inset: 0; z-index: 999;
    background: rgba(0,0,0,.4);
    opacity: 0; pointer-events: none;
    transition: opacity 180ms ease;
  }

  /* otvoren meni */
  header.is-open #primaryNav{
    transform: translateY(0) scale(1); opacity: 1; pointer-events: auto;
  }
  header.is-open .nav-overlay{
    opacity: 1; pointer-events: auto;
  }

  /* promjena ikone */
  header.is-open .nav-toggle .icon-bars{ display:none; }
  header.is-open .nav-toggle .icon-close{ display:block; }

  /* zaključaj body skrol kad je meni otvoren */
  body.nav-open{ overflow:hidden; }
}

/* Smooth scroll i aktivni underline (ako već nemaš) */
html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
.section[id]{ scroll-margin-top: calc(var(--header-shrink-h, 40px) + 20px); }

.nav a{ position:relative; transition:color 220ms ease; }
.nav a::after{
  content:""; position:absolute; left:0; right:0; bottom:-8px; height:2px;
  background: linear-gradient(90deg, rgba(59,130,246,.9), rgba(96,165,250,.9));
  transform: scaleX(0); transform-origin:center; opacity:0;
  transition: transform 280ms cubic-bezier(.22,.61,.36,1), opacity 180ms ease;
}
.nav a.is-active{ color:#fff; }
.nav a.is-active::after{ opacity:1; transform: scaleX(1); }


/* =========================
   HERO — MOBILE FIX PAKET
   ========================= */

/* 1) Spriječi da grid djeca šire layout (često uz <pre> i dugačke riječi) */
.hero-copy, .hero-visual { min-width: 0; }

/* 2) Terminal/code neka se prelama umjesto da širi stranicu */
.terminal, .term-body, .terminal pre, .terminal code {
  max-width: 100%;
  white-space: pre-wrap;       /* pre-wrap ključ */
  word-break: break-word;
  overflow-wrap: anywhere;
}

/* 3) Sigurnosno pravilo — nema horizontalnog skrola na cijeloj stranici */
html, body { overflow-x: hidden; }

/* 4) Reflow hero grida u jednu kolonu na manjim širinama */
@media (max-width: 900px){
  .hero { 
    padding-top: clamp(14px, 5vh, 24px);
    padding-bottom: clamp(12px, 5vh, 22px);
  }
  .hero .container.hero-grid{
    display: grid;
    grid-template-columns: 1fr;   /* stack: copy iznad, vizual ispod */
    gap: 12px;
    align-items: start;
  }
  .hero-copy{ order: 1; }
  .hero-visual{ order: 2; }

  /* stakleni box neka stane u ekran i ima zraka */
  .hero-copy.glass{
    padding: clamp(12px, 3vw, 18px) clamp(12px, 4vw, 20px);
    margin: 0; 
  }

  /* terminal kao kartica, centriran i bez “rezanja” */
  .hero-visual .terminal{
    margin: 0 auto;
    width: 100%;
    border-radius: 12px;
  }

  /* metrice neka se prelome u redove */
  .hero-copy .metrics{ gap: 8px 10px; }
}

/* 5) Tipografija u hero-u da ljepše stane na mob */
@media (max-width: 600px){
  .hero-copy h1{
    font-size: clamp(22px, 7vw, 30px);
    line-height: 1.14;
  }
  .hero-copy .lead{ font-size: 0.98rem; }
}

/* 6) Generic osigurač za medije u hero-u */
.hero img, .hero video{ max-width: 100%; height: auto; display: block; }

/* HERO VIDEO — osiguraj da se sadržaj vidi i ne reže na mobu */
@media (max-width: 900px){
  .hero-video-wrap{ min-height: clamp(420px, 72vh, 720px); }
  .hero-overlay{ min-height: clamp(420px, 72vh, 720px); padding: 16px 0 14px; }
}
