/* ============================================================
   VUČNA SLUŽBA 24 · Industrijski premium
   Vanilla CSS · mobile-first · spremno za handoff
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  /* boje */
  --ink:        #0E0E10;   /* grafit, skoro crna */
  --ink-2:      #16161A;   /* tamni panel */
  --ink-3:      #202127;   /* škriljevac / borderi na tamnom */
  --slate:      #2C2E36;
  --paper:      #F7F5F1;   /* topli papir */
  --paper-2:    #FEFDFB;   /* kartica na papiru */
  --paper-line: #E5E1D8;   /* border na papiru */
  --amber:      #FFB400;   /* signalna jantarna */
  --amber-600:  #E89F00;   /* hover */
  --amber-glow: rgba(255,180,0,.16);

  /* tekst */
  --on-ink:       #F4F2EE;
  --on-ink-mut:   #9A9AA2;
  --on-ink-faint: #6A6A72;
  --on-paper:     #14140F;
  --on-paper-mut: #5A574E;

  /* tipografija */
  --f-display: "Archivo", system-ui, sans-serif;
  --f-body:    "Instrument Sans", system-ui, sans-serif;
  --f-mono:    "Space Mono", ui-monospace, monospace;

  /* sustav */
  --maxw: 1280px;
  --gut: clamp(20px, 5vw, 56px);
  --sect-y: clamp(72px, 11vw, 150px);
  --radius: 4px;
  --radius-lg: 10px;
  --ease: cubic-bezier(.22,.61,.36,1);
  --header-h: 68px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--f-body);
  background:var(--paper);
  color:var(--on-paper);
  line-height:1.55;
  font-size:clamp(16px,1.05vw,17.5px);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; cursor:pointer; border:none; background:none; }
ul{ list-style:none; }
::selection{ background:var(--amber); color:var(--ink); }

/* ---------- Helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }
.eyebrow{
  font-family:var(--f-mono);
  font-size:.72rem;
  letter-spacing:.24em;
  text-transform:uppercase;
  font-weight:700;
  display:inline-flex; align-items:center; gap:.6em;
}
.eyebrow::before{
  content:""; width:18px; height:2px; background:var(--amber); display:inline-block;
}
.amber{ color:var(--amber); }
.sect{ padding-block:var(--sect-y); }
.sect-head{ max-width:760px; margin-bottom:clamp(40px,5vw,72px); }
.sect-title{
  font-family:var(--f-display);
  font-weight:800;
  font-stretch:115%;
  line-height:.98;
  letter-spacing:-.02em;
  font-size:clamp(2.1rem,6vw,4.25rem);
  text-wrap:balance;
  margin-top:18px;
}
.sect-sub{ margin-top:18px; font-size:1.075rem; color:var(--on-paper-mut); max-width:58ch; text-wrap:pretty; }
.on-ink-sect{ background:var(--ink); color:var(--on-ink); }
.on-ink-sect .sect-sub{ color:var(--on-ink-mut); }

/* placeholder fotke */
.ph{
  position:relative; overflow:hidden;
  background:
    repeating-linear-gradient(135deg, rgba(0,0,0,.035) 0 1px, transparent 1px 11px),
    var(--paper-line);
  display:grid; place-items:center;
}
.on-ink-sect .ph, .ph.ph-dark{
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.04) 0 1px, transparent 1px 11px),
    var(--ink-2);
}
.ph-label{
  font-family:var(--f-mono); font-size:.72rem; letter-spacing:.08em;
  color:var(--on-paper-mut); text-transform:uppercase; padding:8px 12px;
  border:1px dashed currentColor; border-radius:3px; opacity:.62;
}
.ph.ph-dark .ph-label, .on-ink-sect .ph .ph-label{ color:var(--on-ink-mut); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  font-family:var(--f-body); font-weight:600; font-size:1rem;
  padding:1rem 1.5rem; border-radius:var(--radius);
  transition:transform .18s var(--ease), background .18s, box-shadow .25s, color .18s;
  white-space:nowrap; line-height:1;
}
.btn svg{ width:1.15em; height:1.15em; }
.btn-amber{ background:var(--amber); color:var(--ink); font-weight:700; box-shadow:0 0 0 0 var(--amber-glow); }
.btn-amber:hover{ background:var(--amber-600); transform:translateY(-2px); box-shadow:0 14px 34px -10px var(--amber-glow); }
.btn-ghost{ background:transparent; color:var(--on-ink); border:1.5px solid var(--ink-3); }
.btn-ghost:hover{ border-color:var(--on-ink); transform:translateY(-2px); }
.btn-dark{ background:var(--ink); color:var(--on-ink); }
.btn-dark:hover{ background:var(--slate); transform:translateY(-2px); }
.btn-lg{ padding:1.15rem 1.9rem; font-size:1.075rem; }
.btn-block{ width:100%; }

/* ============================================================
   HEADER (sticky)
   ============================================================ */
.header{
  position:fixed; inset:0 0 auto 0; z-index:60;
  height:var(--header-h);
  display:flex; align-items:center;
  transition:background .3s, border-color .3s, backdrop-filter .3s;
  border-bottom:1px solid transparent;
}
.header.scrolled{
  background:rgba(14,14,16,.82);
  backdrop-filter:blur(14px) saturate(140%);
  border-bottom-color:var(--ink-3);
}
.header .wrap{ display:flex; align-items:center; justify-content:space-between; gap:16px; }
.brand{ display:flex; align-items:center; gap:11px; color:var(--on-ink); }
.brand-mark{
  width:34px; height:34px; border-radius:6px; flex:none;
  display:grid; place-items:center; background:var(--amber); color:var(--ink);
  font-family:var(--f-display); font-weight:900; font-size:1.15rem; font-stretch:120%;
}
.brand-name{ font-family:var(--f-display); font-weight:800; font-size:1rem; letter-spacing:.02em; line-height:1; font-stretch:110%; }
.brand-tag{ font-family:var(--f-mono); font-size:.6rem; letter-spacing:.18em; color:var(--amber); text-transform:uppercase; margin-top:3px; display:block; text-align:center; }
.header-actions{ display:flex; align-items:center; gap:10px; }
.icon-btn{
  width:42px; height:42px; border-radius:var(--radius); display:grid; place-items:center;
  border:1.5px solid var(--ink-3); color:var(--on-ink);
  transition:border-color .2s, background .2s, transform .2s;
}
.icon-btn:hover{ border-color:var(--on-ink); transform:translateY(-2px); }
.icon-btn svg{ width:20px; height:20px; }
.header .btn-phone{
  display:inline-flex; align-items:center; gap:.55em;
  background:var(--amber); color:var(--ink); font-weight:700;
  padding:.7rem 1.05rem; border-radius:var(--radius); font-size:1rem; line-height:1;
  transition:background .2s, transform .2s;
}
.header .btn-phone .num{ font-variant-numeric:tabular-nums; }
.header .btn-phone:hover{ background:var(--amber-600); transform:translateY(-2px); }
.header .btn-phone .lbl{ font-family:var(--f-mono); font-size:.58rem; letter-spacing:.14em; display:block; opacity:.7; text-transform:uppercase; margin-bottom:2px; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; background:var(--ink); color:var(--on-ink);
  min-height:100svh; display:flex; align-items:flex-end;
  padding-top:calc(var(--header-h) + 40px); padding-bottom:clamp(40px,7vw,90px);
  overflow:hidden;
}
/* rotirka, suptilni amber sweep */
.hero-beacon{
  position:absolute; z-index:0; pointer-events:none;
  width:160vmax; height:160vmax; top:-60vmax; right:-50vmax;
  background:conic-gradient(from 0deg, transparent 0deg, var(--amber-glow) 18deg, transparent 60deg, transparent 180deg, var(--amber-glow) 200deg, transparent 240deg);
  filter:blur(40px); opacity:.55;
  animation:beacon 12s linear infinite;
}
@keyframes beacon{ to{ transform:rotate(360deg); } }
.hero-grid-lines{
  position:absolute; inset:0; z-index:0; pointer-events:none; opacity:.5;
  background-image:linear-gradient(90deg, var(--ink-3) 1px, transparent 1px);
  background-size:calc(100%/6) 100%;
  -webkit-mask-image:linear-gradient(to bottom, transparent, #000 30%, #000 55%, transparent 80%);
          mask-image:linear-gradient(to bottom, transparent, #000 30%, #000 55%, transparent 80%);
}
.hero .wrap{ position:relative; z-index:2; width:100%; }

.hero-eyebrow{ color:var(--amber); margin-bottom:clamp(20px,3vw,34px); }
.hero-eyebrow::before{ background:var(--amber); }

.hero h1{ font-family:var(--f-display); margin:0; }
.h1-mega{
  display:block; text-transform:uppercase; font-weight:800; font-stretch:118%;
  font-size:clamp(3rem,13.5vw,11rem); line-height:.95; letter-spacing:-.025em;
}
.h1-sub{
  display:block; font-weight:500; font-stretch:100%;
  font-size:clamp(1.25rem,3.4vw,2.4rem); line-height:1.05; letter-spacing:-.01em;
  color:var(--on-ink); margin-top:clamp(10px,1.4vw,20px); max-width:18ch;
}
.h1-sub b{ color:var(--amber); font-weight:600; }

.hero-lede{
  margin-top:clamp(22px,3vw,30px); font-size:clamp(1.05rem,1.5vw,1.3rem);
  color:var(--on-ink-mut); max-width:48ch; text-wrap:pretty; line-height:1.5;
}
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:clamp(28px,3.5vw,42px); }

/* signali povjerenja */
.trust{
  display:flex; flex-wrap:nowrap; gap:0; margin-top:clamp(34px,4.5vw,56px);
  border-top:1px solid var(--ink-3);
}
.trust li{
  display:flex; align-items:center; gap:.7em;
  padding:18px 20px 18px 0; margin-right:20px;
  font-size:.95rem; color:var(--on-ink); flex:1 1 0%;
  border-right:1px solid var(--ink-3);
}
.trust li:last-child{ border-right:none; margin-right:0; }
.trust li svg{ width:22px; height:22px; color:var(--amber); flex:none; }
.trust li .t-txt{ display:flex; flex-direction:column; line-height:1.25; }
.trust li b{ font-weight:600; font-size:.96rem; }
.trust li .t-txt span{ font-size:.78rem; color:var(--on-ink-mut); margin-top:2px; }
@media(max-width:760px){
  .trust{ display:grid; grid-template-columns:1fr 1fr; column-gap:20px; row-gap:0; }
  .trust li{ border-right:none; margin-right:0; padding:16px 0; }
  .trust li:nth-child(odd){ border-right:1px solid var(--ink-3); padding-right:20px; }
}



/* ============================================================
   USLUGE
   ============================================================ */
.services-grid{ display:grid; grid-template-columns:1fr; gap:1px; background:var(--paper-line); border:1px solid var(--paper-line); border-radius:var(--radius-lg); overflow:hidden; }
@media(min-width:620px){ .services-grid{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:980px){ .services-grid{ grid-template-columns:repeat(3,1fr); } }
.service{
  background:var(--paper-2); padding:clamp(26px,3vw,38px); position:relative;
  transition:background .25s; overflow:hidden;
}
.service::after{ content:""; position:absolute; left:0; bottom:0; height:3px; width:0; background:var(--amber); transition:width .35s var(--ease); }
.service:hover{ background:#fff; }
.service:hover::after{ width:100%; }
.service-ico{
  width:54px; height:54px; border-radius:var(--radius); display:grid; place-items:center;
  background:var(--ink); color:var(--amber); margin-bottom:22px; transition:transform .3s var(--ease);
}
.service:hover .service-ico{ transform:translateY(-3px) rotate(-3deg); }
.service-ico svg{ width:27px; height:27px; }
.service h3{ font-family:var(--f-display); font-weight:700; font-size:1.3rem; letter-spacing:-.01em; line-height:1.1; }
.service p{ margin-top:9px; color:var(--on-paper-mut); font-size:.97rem; }
.service-num{ position:absolute; top:22px; right:24px; font-family:var(--f-mono); font-size:.72rem; color:var(--paper-line); font-weight:700; }
.service:hover .service-num{ color:var(--on-paper-mut); }

/* ============================================================
   ZAŠTO MI
   ============================================================ */
.why-grid{ display:grid; grid-template-columns:1fr; gap:clamp(34px,4vw,60px) clamp(40px,5vw,80px); }
@media(min-width:780px){ .why-grid{ grid-template-columns:repeat(2,1fr); } }
.why-item{ border-top:1px solid var(--ink-3); padding-top:26px; }
.why-num{ font-family:var(--f-mono); font-size:.78rem; letter-spacing:.1em; color:var(--amber); }
.why-item h3{ font-family:var(--f-display); font-weight:700; font-stretch:108%; font-size:clamp(1.5rem,2.6vw,2.05rem); margin-top:14px; letter-spacing:-.015em; }
.why-item p{ margin-top:12px; color:var(--on-ink-mut); font-size:1.05rem; max-width:46ch; }

/* ============================================================
   STATISTIKA
   ============================================================ */
.stats{ display:grid; grid-template-columns:1fr; gap:1px; background:var(--ink-3); border-block:1px solid var(--ink-3); }
@media(min-width:720px){ .stats{ grid-template-columns:repeat(3,1fr); } }
.stat{ background:var(--ink); padding:clamp(40px,6vw,80px) clamp(24px,4vw,48px); text-align:center; }
.stat-num{ font-family:var(--f-display); font-weight:800; font-stretch:115%; font-size:clamp(3.5rem,9vw,6.5rem); line-height:.9; color:var(--amber); letter-spacing:-.03em; font-variant-numeric:tabular-nums; }
.stat-num .unit{ font-size:.32em; color:var(--on-ink); margin-left:.15em; font-family:var(--f-mono); font-weight:700; vertical-align:.55em; letter-spacing:0; }
.stat-lbl{ font-family:var(--f-mono); font-size:.8rem; letter-spacing:.16em; text-transform:uppercase; color:var(--on-ink-mut); margin-top:18px; }

/* ============================================================
   CJENIK
   ============================================================ */
.price-grid{ display:grid; grid-template-columns:1fr; gap:18px; align-items:start; }
@media(min-width:860px){ .price-grid{ grid-template-columns:repeat(3,1fr); } }
.price-card{
  background:var(--paper-2); border:1px solid var(--paper-line); border-radius:var(--radius-lg);
  padding:clamp(28px,3vw,40px); position:relative; transition:transform .25s var(--ease), box-shadow .3s;
}
.price-card:hover{ transform:translateY(-4px); box-shadow:0 26px 50px -28px rgba(0,0,0,.28); }
.price-card.featured{ background:var(--ink); color:var(--on-ink); border-color:var(--ink); }
@media(min-width:860px){ .price-card.featured{ transform:scale(1.04); } .price-card.featured:hover{ transform:scale(1.04) translateY(-4px); } }
.price-tag{
  position:absolute; top:-13px; left:clamp(28px,3vw,40px); background:var(--amber); color:var(--ink);
  font-family:var(--f-mono); font-weight:700; font-size:.66rem; letter-spacing:.14em; text-transform:uppercase;
  padding:6px 12px; border-radius:100px;
}
.price-name{ font-family:var(--f-mono); font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--on-paper-mut); }
.price-card.featured .price-name{ color:var(--amber); }
.price-amount{ font-family:var(--f-display); font-weight:800; font-stretch:112%; font-size:clamp(2.8rem,5vw,3.6rem); line-height:1; margin-top:16px; letter-spacing:-.02em; }
.price-amount .cur{ font-size:.45em; vertical-align:.5em; font-weight:700; }
.price-amount .per{ font-size:.32em; font-family:var(--f-mono); color:var(--on-paper-mut); font-weight:700; letter-spacing:.02em; }
.price-card.featured .price-amount .per{ color:var(--on-ink-mut); }
.price-desc{ margin-top:16px; color:var(--on-paper-mut); font-size:1rem; border-top:1px solid var(--paper-line); padding-top:16px; }
.price-card.featured .price-desc{ color:var(--on-ink-mut); border-top-color:var(--ink-3); }
.price-note{ margin-top:26px; font-size:.9rem; color:var(--on-paper-mut); font-family:var(--f-mono); line-height:1.6; }

/* ============================================================
   KALKULATOR
   ============================================================ */
.calc{
  background:var(--ink); color:var(--on-ink); border-radius:var(--radius-lg);
  padding:clamp(28px,4vw,56px); display:grid; grid-template-columns:1fr; gap:clamp(30px,4vw,56px);
  position:relative; overflow:hidden;
}
@media(min-width:880px){ .calc{ grid-template-columns:1fr 360px; align-items:center; } }
.calc-eyebrow{ color:var(--amber); }
.calc-eyebrow::before{ background:var(--amber); }
.calc h3{ font-family:var(--f-display); font-weight:800; font-stretch:110%; font-size:clamp(1.7rem,3vw,2.4rem); margin-top:16px; letter-spacing:-.02em; }
.calc-fields{ margin-top:26px; display:flex; flex-direction:column; gap:22px; }
.field-lbl{ font-family:var(--f-mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--on-ink-mut); margin-bottom:12px; display:block; }
.seg{ display:grid; grid-template-columns:repeat(3,1fr); gap:8px; }
.seg button{
  padding:14px 10px; border-radius:var(--radius); border:1.5px solid var(--ink-3); background:var(--ink-2);
  color:var(--on-ink-mut); font-weight:600; font-size:.92rem; transition:all .2s; text-align:center; line-height:1.2;
}
.seg button small{ display:block; font-family:var(--f-mono); font-size:.62rem; opacity:.7; margin-top:4px; letter-spacing:.04em; }
.seg button.active{ background:var(--amber); border-color:var(--amber); color:var(--ink); }
.seg button:not(.active):hover{ border-color:var(--on-ink-faint); color:var(--on-ink); }
.km-row{ display:flex; align-items:center; gap:16px; }
.km-row input[type=range]{ -webkit-appearance:none; appearance:none; flex:1; height:4px; border-radius:4px; background:var(--ink-3); outline:none; }
.km-row input[type=range]::-webkit-slider-thumb{ -webkit-appearance:none; width:22px; height:22px; border-radius:50%; background:var(--amber); cursor:pointer; border:3px solid var(--ink); box-shadow:0 0 0 1px var(--amber); }
.km-row input[type=range]::-moz-range-thumb{ width:22px; height:22px; border-radius:50%; background:var(--amber); cursor:pointer; border:3px solid var(--ink); }
.km-val{ font-family:var(--f-display); font-weight:800; font-size:1.5rem; min-width:84px; text-align:right; font-variant-numeric:tabular-nums; }
.km-val small{ font-family:var(--f-mono); font-size:.7rem; color:var(--on-ink-mut); font-weight:700; }
.calc-result{
  background:var(--ink-2); border:1px solid var(--ink-3); border-radius:var(--radius-lg);
  padding:clamp(26px,3vw,36px); text-align:center; position:relative;
}
.calc-result .rlbl{ font-family:var(--f-mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--on-ink-mut); }
.calc-result .rnum{ font-family:var(--f-display); font-weight:800; font-stretch:112%; font-size:clamp(3.4rem,7vw,4.6rem); line-height:1; color:var(--amber); margin-top:12px; letter-spacing:-.02em; font-variant-numeric:tabular-nums; }
.calc-result .rnum .cur{ font-size:.4em; vertical-align:.55em; }
.calc-result .rnote{ font-size:.8rem; color:var(--on-ink-faint); margin-top:14px; font-family:var(--f-mono); line-height:1.5; }
.calc-result .btn{ margin-top:22px; }

/* ============================================================
   GALERIJA
   ============================================================ */
.gallery{ display:grid; grid-template-columns:repeat(2,1fr); gap:12px; grid-auto-rows:1fr; }
@media(min-width:720px){ .gallery{ grid-template-columns:repeat(4,1fr); } }
.gal-item{ position:relative; overflow:hidden; border-radius:var(--radius); aspect-ratio:4/3; cursor:pointer; }
.gal-item.tall{ grid-row:span 1; }
@media(min-width:720px){ .gal-item.wide{ grid-column:span 2; aspect-ratio:auto; } }
.gal-item .ph{ position:absolute; inset:0; transition:transform .55s var(--ease); }
.gal-item:hover .ph{ transform:scale(1.07); }
.gal-item::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(14,14,16,.5), transparent 60%); opacity:0; transition:opacity .35s; }
.gal-item:hover::after{ opacity:1; }

/* ============================================================
   PODRUČJE POKRIVANJA
   ============================================================ */
.coverage{ display:grid; grid-template-columns:1fr; gap:clamp(34px,4vw,64px); align-items:center; }
@media(min-width:900px){ .coverage{ grid-template-columns:1fr 1fr; } }
.zone-list{ display:flex; flex-wrap:wrap; gap:10px; margin-top:28px; }
.zone{
  font-family:var(--f-mono); font-size:.86rem; letter-spacing:.02em;
  padding:9px 15px; border:1px solid var(--paper-line); border-radius:100px;
  background:var(--paper-2); transition:all .2s; display:inline-flex; align-items:center; gap:.5em;
}
.zone::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--amber); }
.zone:hover{ border-color:var(--ink); background:var(--ink); color:var(--on-ink); }
.map-ph{ border-radius:var(--radius-lg); overflow:hidden; max-width:600px; margin-inline:auto; }
.map-ph img{ border-radius:var(--radius-lg); }
@media(max-width:899px){ .map-ph{ max-width:100%; } }

/* ============================================================
   KONTAKT
   ============================================================ */
.contact{ text-align:left; }
.contact-phone{
  display:inline-flex; align-items:center; gap:.4em; margin-top:24px;
  font-family:var(--f-display); font-weight:800; font-stretch:115%;
  font-size:clamp(2.6rem,9vw,6rem); line-height:1; color:var(--amber); letter-spacing:-.02em;
  transition:transform .2s; font-variant-numeric:tabular-nums;
}
.contact-phone:hover{ transform:translateX(8px); }
.contact-phone svg{ width:.7em; height:.7em; }
.contact-channels{ display:flex; flex-wrap:wrap; gap:14px; margin-top:30px; }
.contact-meta{ display:grid; grid-template-columns:1fr; gap:1px; margin-top:clamp(46px,6vw,72px); background:var(--ink-3); border:1px solid var(--ink-3); border-radius:var(--radius-lg); overflow:hidden; }
@media(min-width:760px){ .contact-meta{ grid-template-columns:repeat(3,1fr); } }
.cmeta{ background:var(--ink); padding:26px clamp(22px,3vw,32px); }
.cmeta .k{ font-family:var(--f-mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--amber); }
.cmeta .v{ margin-top:10px; font-size:1.1rem; font-weight:500; }
.cmeta .v small{ display:block; color:var(--on-ink-mut); font-size:.9rem; font-weight:400; margin-top:2px; }
.contact-map-wrap{ margin-top:18px; }
.contact-map-iframe{ width:100%; height:360px; border:0; border-radius:var(--radius-lg); display:block; }
@media(max-width:760px){ .contact-map-iframe{ height:280px; } }

/* ============================================================
   PONUDA CTA
   ============================================================ */
.ponuda-sect .sect-head{ text-align:center; max-width:680px; margin-inline:auto; }
.ponuda-sect .sect-sub{ margin-inline:auto; }
.ponuda-sect .hero-cta{ justify-content:center; }

/* ============================================================
   FAQ AKORDEON
   ============================================================ */
.faq-sect{
  background:var(--ink-2); color:var(--on-ink);
  border-bottom:1px solid rgba(255,255,255,.08);
  padding-bottom:clamp(48px,7vw,80px);
}
.faq-sect .sect-sub{ color:var(--on-ink-mut); }
.faq-sect .sect-head{ text-align:center; margin-inline:auto; }
.faq-list{ max-width:760px; margin-inline:auto; }
.faq-item{ border-top:1px solid var(--ink-3); }
.faq-item:last-child{ border-bottom:1px solid var(--ink-3); }
.faq-q{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:22px 0; cursor:pointer; list-style:none;
  font-family:var(--f-display); font-weight:700; font-size:clamp(1.05rem,1.8vw,1.25rem);
  color:var(--on-ink); transition:color .2s;
}
.faq-q::-webkit-details-marker{ display:none; }
.faq-q:hover{ color:var(--amber); }
.faq-q .faq-ico{ width:20px; height:20px; flex:none; color:var(--amber); transition:transform .3s var(--ease); }
.faq-item[open] .faq-q .faq-ico{ transform:rotate(180deg); }
.faq-item[open] .faq-q{ color:var(--amber); }
.faq-a{ padding:0 0 24px; }
.faq-a p{ color:var(--on-ink-mut); font-size:1.05rem; line-height:1.6; max-width:60ch; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--ink); color:var(--on-ink-mut); border-top:1px solid var(--ink-3); padding-block:44px; }
.footer .wrap{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:18px; }
.footer .brand-name{ color:var(--on-ink); }
.footer small{ font-family:var(--f-mono); font-size:.72rem; letter-spacing:.04em; }

/* ============================================================
   MOBILNI STICKY BAR
   ============================================================ */
.mobar{
  position:fixed; z-index:65; left:0; right:0; bottom:0;
  display:none; gap:10px; padding:10px 12px calc(10px + env(safe-area-inset-bottom,0px));
  background:rgba(14,14,16,.92); backdrop-filter:blur(14px); border-top:1px solid var(--ink-3);
}
.mobar .btn{ flex:1; padding:.95rem; }
.mobar .btn-wa{ background:var(--ink-2); color:var(--on-ink); border:1.5px solid var(--ink-3); }
.mobar .btn-wa:hover{ border-color:var(--on-ink); }
@media(max-width:760px){
  .mobar{ display:flex; }
  body{ padding-bottom:74px; }
  .header-actions{ display:none; }
  .hero-cta .btn-ghost{ display:none; }
  .hero-cta .btn{ width:100%; }
}

/* ============================================================
   REVEAL
   ============================================================ */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; }
.reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; }
.reveal[data-d="4"]{ transition-delay:.32s; }
@media(prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  .hero-beacon{ animation:none; }
  html{ scroll-behavior:auto; }
}
/* fallback: ako je animacijski sat zaustavljen (throttled iframe), snimi konačno stanje već otkrivenih */
html.reveal-fallback .reveal.in{ opacity:1 !important; transform:none !important; transition:none !important; }

/* ============================================================
   LEGAL PAGE (kolacici.html)
   ============================================================ */
.legal-page{
  padding-top:calc(var(--header-h) + clamp(40px,6vw,80px));
  padding-bottom:var(--sect-y);
  background:var(--paper);
}
.legal-content{ max-width:760px; }
.legal-back{
  display:inline-flex; align-items:center; gap:.4em;
  font-family:var(--f-mono); font-size:.78rem; letter-spacing:.06em;
  color:var(--on-paper-mut); margin-bottom:clamp(28px,4vw,48px);
  transition:color .2s;
}
.legal-back svg{ width:16px; height:16px; }
.legal-back:hover{ color:var(--amber); }
.legal-content h1{
  font-family:var(--f-display); font-weight:800; font-stretch:115%;
  font-size:clamp(2rem,5vw,3.2rem); line-height:1; letter-spacing:-.02em;
  margin-bottom:clamp(20px,3vw,32px);
}
.legal-content h2{
  font-family:var(--f-display); font-weight:700; font-size:clamp(1.15rem,2vw,1.4rem);
  margin-top:clamp(28px,4vw,40px); margin-bottom:10px; letter-spacing:-.01em;
}
.legal-content p{
  color:var(--on-paper-mut); font-size:1.05rem; line-height:1.7; margin-bottom:14px;
}
.legal-content a{ color:var(--amber); text-decoration:underline; text-underline-offset:3px; }
.legal-content a:hover{ color:var(--amber-600); }
.legal-updated{
  margin-top:clamp(34px,5vw,56px); padding-top:20px; border-top:1px solid var(--paper-line);
  font-family:var(--f-mono); font-size:.8rem; color:var(--on-paper-mut); letter-spacing:.04em;
}

/* ============================================================
   COOKIE BANNER
   ============================================================ */
.cookie-banner{
  position:fixed; z-index:100; bottom:20px; right:20px;
  max-width:360px; width:calc(100% - 40px);
  background:var(--ink-2); color:var(--on-ink);
  border:1px solid var(--ink-3); border-radius:var(--radius-lg);
  padding:24px; box-shadow:0 20px 50px -12px rgba(0,0,0,.5);
  opacity:0; transform:translateY(16px);
  transition:opacity .35s var(--ease), transform .35s var(--ease);
}
.cookie-banner.visible{ opacity:1; transform:none; }
.cookie-banner.hidden{ display:none; }
.cookie-text{ font-size:.95rem; line-height:1.5; color:var(--on-ink-mut); }
.cookie-link{
  display:inline-block; margin-top:10px;
  font-family:var(--f-mono); font-size:.75rem; letter-spacing:.04em;
  color:var(--amber); text-decoration:underline; text-underline-offset:3px;
}
.cookie-link:hover{ color:var(--amber-600); }
.cookie-btns{ display:flex; gap:10px; margin-top:18px; }
.cookie-btn{ flex:1; padding:.8rem 1rem; font-size:.92rem; }
.cookie-btn-reject{
  background:transparent; color:var(--on-ink);
  border:1.5px solid var(--on-ink-faint);
  font-weight:600;
}
.cookie-btn-reject:hover{ border-color:var(--on-ink); transform:translateY(-2px); }
@media(max-width:760px){
  .cookie-banner{
    bottom:calc(74px + env(safe-area-inset-bottom,0px) + 12px);
    right:12px; left:12px; max-width:none; width:auto;
  }
}
