/* ============================================================
   STAMPRESSO — marketing sajt, iteracija 2
   Krem #F0EBDC + plava #1E3BB8, Bricolage Grotesque + Space Grotesk
   GSAP + Lenis; hero telefoni su DOM (oklop .device iz iteracije 1)
   ============================================================ */

/* ---------- fontovi (self-hosted, isti kao iteracija 1) ---------- */
@font-face{
  font-family:'Bricolage Grotesque';
  src:url('/fonts/bricolage-latin.woff2') format('woff2');
  font-weight:200 800;font-display:swap;
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Bricolage Grotesque';
  src:url('/fonts/bricolage-latinext.woff2') format('woff2');
  font-weight:200 800;font-display:swap;
  unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:'Space Grotesk';
  src:url('/fonts/space-latin.woff2') format('woff2');
  font-weight:300 700;font-display:swap;
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Space Grotesk';
  src:url('/fonts/space-latinext.woff2') format('woff2');
  font-weight:300 700;font-display:swap;
  unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}

/* ---------- osnove ---------- */
:root{
  --blue:#1E3BB8;
  --blue-deep:#152C8F;
  --cream:#F0EBDC;
  --cream-deep:#E6E0CE;
  --ink:#14110C;
  --soft:#7E92E8;
  --disp:'Bricolage Grotesque',sans-serif;
  --body:'Space Grotesk',sans-serif;
  --wrap:1240px;
  --pad:clamp(20px,4vw,48px);
  --r:22px;
  --ease:cubic-bezier(.22,1,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
/* iOS Safari „text autosizing" naduvava male fontove (npr. u demo telefonima) — isključi */
html{scroll-behavior:auto;-webkit-text-size-adjust:100%;text-size-adjust:100%}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:var(--body);
  font-size:17px;line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
}
::selection{background:var(--blue);color:var(--cream)}
img,svg,canvas{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
:focus-visible{outline:3px solid var(--blue);outline-offset:3px;border-radius:4px}
.wrap{max-width:var(--wrap);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}

/* ---------- preloader ---------- */
.loader{
  position:fixed;inset:0;z-index:200;
  background:var(--blue);color:var(--cream);
  display:flex;align-items:flex-end;justify-content:space-between;
  padding:clamp(20px,4vw,44px);
}
.loader-inner{display:flex;align-items:flex-end;justify-content:space-between;width:100%}
.loader-word{font-family:var(--disp);font-weight:800;font-size:clamp(28px,5vw,54px);letter-spacing:-.02em}
.loader-count{font-family:var(--disp);font-weight:700;font-size:clamp(60px,14vw,180px);line-height:.85;letter-spacing:-.04em;font-variant-numeric:tabular-nums}
.loader.done{pointer-events:none}

/* ---------- custom cursor (samo desktop, pointer:fine) ---------- */
.cursor{display:none}
@media(pointer:fine){
  .cursor{
    display:block;position:fixed;left:0;top:0;z-index:190;pointer-events:none;
    width:14px;height:14px;margin:-7px 0 0 -7px;
  }
  .cursor-dot{
    display:block;width:100%;height:100%;border-radius:50%;
    background:var(--blue);
    transition:transform .25s var(--ease),background .25s;
  }
  .cursor.grow .cursor-dot{transform:scale(3.4);background:var(--blue);opacity:.35}
  .cursor.dark .cursor-dot{background:var(--cream)}
}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;gap:34px;
  padding:18px var(--pad);
  transition:background .35s,box-shadow .35s,padding .35s;
}
.nav.scrolled{
  background:color-mix(in srgb,var(--cream) 82%,transparent);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  box-shadow:0 1px 0 rgba(20,17,12,.08);
  padding-top:12px;padding-bottom:12px;
}
.nav-logo{font-family:var(--disp);font-weight:800;font-size:24px;letter-spacing:-.02em;margin-right:auto}
.nav-logo-dot{color:var(--blue)}
.nav-links{display:flex;gap:26px}
.nav-links a{
  font-weight:500;font-size:15.5px;position:relative;padding:4px 0;
}
.nav-links a::after{
  content:'';position:absolute;left:0;right:100%;bottom:0;height:2px;background:var(--blue);
  transition:right .3s var(--ease);
}
.nav-links a:hover::after{right:0}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--body);font-weight:600;font-size:16px;
  padding:14px 26px;border-radius:999px;
  transition:transform .25s var(--ease),background .25s,color .25s,box-shadow .25s;
  will-change:transform;
}
.btn:active{transform:scale(.97)}
.btn-nav{background:var(--blue);color:var(--cream);padding:11px 22px;font-size:15px}
.btn-nav:hover{background:var(--blue-deep)}
.btn-blue{background:var(--blue);color:var(--cream);box-shadow:0 10px 30px -12px rgba(30,59,184,.55)}
.btn-blue:hover{background:var(--blue-deep);transform:translateY(-2px)}
.btn-ghost{border:2px solid var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--cream)}
.btn-cream{background:var(--cream);color:var(--blue)}
.btn-cream:hover{background:#fff}
.btn-cream-line{border:2px solid var(--cream);color:var(--cream)}
.btn-cream-line:hover{background:var(--cream);color:var(--blue)}

/* burger */
.nav-burger{display:none;width:44px;height:44px;position:relative;z-index:120}
.nav-burger span{
  position:absolute;left:10px;right:10px;height:2.5px;background:var(--ink);border-radius:2px;
  transition:transform .35s var(--ease),top .35s var(--ease),background .35s;
}
.nav-burger span:nth-child(1){top:17px}
.nav-burger span:nth-child(2){top:25px}
/* dok je meni otvoren: nav iznad menija (da se vidi X), logo u krem */
body.menu-open .nav{z-index:120;background:transparent;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none}
body.menu-open .nav-logo{color:var(--cream)}
body.menu-open .nav-logo-dot{color:var(--cream)}
body.menu-open .nav-burger span{background:var(--cream)}
body.menu-open .nav-burger span:nth-child(1){top:21px;transform:rotate(45deg)}
body.menu-open .nav-burger span:nth-child(2){top:21px;transform:rotate(-45deg)}

/* fullscreen meni (mobilni) */
.menu{
  position:fixed;inset:0;z-index:110;background:var(--blue);color:var(--cream);
  display:flex;flex-direction:column;justify-content:center;gap:8px;
  padding:var(--pad);
  clip-path:circle(0% at calc(100% - 44px) 40px);
  visibility:hidden;
  transition:clip-path .6s var(--ease),visibility 0s .6s;
}
body.menu-open .menu{clip-path:circle(150% at calc(100% - 44px) 40px);visibility:visible;transition:clip-path .6s var(--ease)}
.menu-links{display:flex;flex-direction:column;gap:6px}
.menu-links a{
  font-family:var(--disp);font-weight:700;font-size:clamp(34px,9vw,52px);letter-spacing:-.02em;
  display:flex;align-items:baseline;gap:16px;padding:6px 0;
}
.menu-links a em{font-family:var(--body);font-style:normal;font-weight:500;font-size:14px;opacity:.6}
.menu-cta{color:var(--cream);text-decoration:underline;text-decoration-thickness:3px;text-underline-offset:8px}
.menu-foot{margin-top:40px;opacity:.7;font-size:15px}

/* ---------- hero ---------- */
.hero{
  position:relative;min-height:100svh;
  display:flex;flex-direction:column;justify-content:center;
  padding:120px var(--pad) 90px;
  overflow:clip;
}
.hero-inner{position:relative;z-index:2;max-width:var(--wrap);margin:0 auto;width:100%}
.hero-eyebrow{
  font-weight:500;font-size:clamp(13px,1.6vw,16px);letter-spacing:.14em;text-transform:uppercase;
  margin-bottom:clamp(18px,3vh,30px);color:var(--blue);
}
.hero-h{
  font-family:var(--disp);font-weight:800;
  font-size:clamp(52px,10.5vw,148px);
  line-height:.96;letter-spacing:-.035em;
}
.hero-line{display:block;overflow:hidden;padding-bottom:.06em;margin-bottom:-.06em}
.hero-line-in{display:inline-block}
.hero-gratis{font-style:italic;color:var(--blue)}
.hero-cycle-wrap{
  display:inline-block;overflow:hidden;vertical-align:bottom;
  background:var(--blue);color:var(--cream);border-radius:.18em;
  padding:0 .14em;transform:rotate(-1.6deg);
}
.hero-cycle{display:inline-block}
.hero-sub{
  max-width:560px;margin-top:clamp(22px,3.5vh,36px);
  font-size:clamp(16px,2vw,19px);color:color-mix(in srgb,var(--ink) 78%,transparent);
}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:clamp(26px,4vh,40px)}
.hero-scroll{
  position:absolute;left:var(--pad);bottom:26px;z-index:1;
  display:flex;align-items:center;gap:12px;
  font-size:12.5px;letter-spacing:.2em;text-transform:uppercase;opacity:.55;
}
.hero-scroll span{
  display:block;width:34px;height:2px;background:var(--ink);transform-origin:left;
  animation:scrollHint 1.8s var(--ease) infinite;
}
@keyframes scrollHint{0%{transform:scaleX(0)}55%{transform:scaleX(1)}100%{transform:scaleX(0);transform-origin:right}}

/* ============================================================
   TELEFON (oklop .device — preuzet iz iteracije 1)
   ============================================================ */
.device{
  /* visina EKSPLICITNO (620/300 = 2.0667), NE aspect-ratio — iOS Safari ume da
     primeni aspect-ratio na content box (uz border-box padding) pa telefon ispadne
     viši, a fitStage onda „cover" skalira sadržaj prekrupno (isečen levo/desno) */
  --w:300px;width:var(--w);height:calc(var(--w)*2.0667);position:relative;
  background:linear-gradient(145deg,#3b404d 0%,#1c1f27 52%,#0d0e13 100%);
  border-radius:46px;padding:11px;
  box-shadow:
    inset 0 1px 1px rgba(255,255,255,.18),
    inset 0 0 0 1.5px rgba(0,0,0,.5),
    0 1px 0 rgba(255,255,255,.06),
    0 42px 80px rgba(18,28,70,.34),
    0 10px 26px rgba(0,0,0,.22);
}
/* bočna dugmad */
.device .b-pwr,.device .b-vu,.device .b-vd,.device .b-sil{position:absolute;background:linear-gradient(90deg,#222530,#0c0d11);border-radius:2px}
.device .b-pwr{right:-3px;top:148px;width:3px;height:62px;border-radius:0 3px 3px 0}
.device .b-sil{left:-3px;top:120px;width:3px;height:26px;border-radius:3px 0 0 3px}
.device .b-vu{left:-3px;top:160px;width:3px;height:44px;border-radius:3px 0 0 3px}
.device .b-vd{left:-3px;top:212px;width:3px;height:44px;border-radius:3px 0 0 3px}
.device .island{position:absolute;top:14px;left:50%;transform:translateX(-50%);
  width:94px;height:25px;background:#08090c;border-radius:14px;z-index:40;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.05)}
.device .island::after{content:"";position:absolute;right:13px;top:50%;transform:translateY(-50%);
  width:7px;height:7px;border-radius:50%;background:#14161c;box-shadow:inset 0 0 0 1px rgba(120,140,232,.25)}
.dev-screen{position:relative;width:100%;height:100%;border-radius:35px;overflow:hidden;background:var(--cream)}
.dev-screen::after{content:"";position:absolute;inset:0;pointer-events:none;z-index:38;
  background:linear-gradient(118deg,rgba(255,255,255,.12) 0%,rgba(255,255,255,0) 26%,rgba(255,255,255,0) 82%,rgba(255,255,255,.05) 100%)}

/* ---------- hero: glavni telefon (kupčev tok u loop-u) ---------- */
.hero-phone-col{
  position:absolute;z-index:1;top:50%;
  right:max(var(--pad),calc((100vw - var(--wrap))/2));
  transform:translateY(-52%);
  perspective:1400px;pointer-events:none;
}
.hero-par{transform-style:preserve-3d}
.hero-device{--w:min(330px,25vw)}
.hero-float{transform:rotateY(-10deg) rotateX(3deg);animation:floaty 6s ease-in-out infinite}
@keyframes floaty{0%,100%{translate:0 -6px}50%{translate:0 8px}}

/* pozadinski telefoni (3D dubina, prate miš) */
.hero-bg-phones{position:absolute;inset:0;z-index:0;pointer-events:none}
.bg-phone{position:absolute;will-change:transform}
.bg-phone-in{transform-origin:top left;animation:floaty 7s ease-in-out infinite}
.bg-phone .device{opacity:.62}

/* ---------- ekrani u glavnom telefonu (fiksni dizajn 276×596, JS skalira stage) ---------- */
.hp-stage{position:absolute;top:0;left:0;width:276px;height:596px;transform-origin:top left}
.hp-scr{position:absolute;inset:0;opacity:0;pointer-events:none;transition:opacity .5s ease}
.hp-scr.on{opacity:1}
.ph.hp-scr{transition:opacity .5s ease,color .5s}
.hp-login,.hp-gratis{display:flex;flex-direction:column}
/* registracija (kao iteracija 1, boje prate temu preko --acc) */
.hp-login{background:var(--cream);color:var(--acc,var(--blue))}
.hp-login-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 26px 26px;text-align:center}
.hp-pw{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;opacity:.5;font-weight:500}
.hp-cafe{font-family:var(--disp);font-weight:800;font-size:42px;text-transform:uppercase;margin:6px 0 2px}
.hp-ls{font-size:13px;opacity:.7;margin-bottom:22px}
.hp-field{width:100%;text-align:left;margin-bottom:13px}
.hp-field label{font-size:11px;font-weight:600;opacity:.6;letter-spacing:.04em}
.hp-inp{margin-top:5px;border:1.5px solid var(--acc,var(--blue));border-radius:14px;background:#fff;
  padding:0 14px;font-size:15px;height:46px;display:flex;align-items:center;font-weight:500;color:var(--ink)}
.hp-caret{display:inline-block;width:2px;height:18px;background:var(--acc,var(--blue));margin-left:1px;animation:hpBlink 1s steps(1) infinite}
@keyframes hpBlink{50%{opacity:0}}
.hp-join{width:100%;background:var(--acc,var(--blue));color:var(--cream);border-radius:999px;
  padding:14px;font-family:var(--disp);font-weight:800;text-transform:uppercase;font-size:14px;margin-top:10px;transition:transform .15s}
/* gratis ekran (tema boji pozadinu, line-art iz app-a) */
.hp-gratis{background:var(--acc,var(--blue));color:var(--cream);transition:opacity .5s ease,background .5s}
.hp-gbody{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:10px 26px 26px;gap:4px}
.hp-gbig{font-family:var(--disp);font-weight:800;font-size:50px;text-transform:uppercase;line-height:1}
.hp-gratis h3{font-size:14px;font-style:italic;font-weight:600;margin-top:4px}
.hp-gart{width:112px;margin:12px 0 4px}
.hp-gart svg{width:100%;height:auto;display:block}
.hp-gart .cup-stroke{fill:none;stroke:currentColor;stroke-width:5;stroke-linecap:round;stroke-linejoin:round}
.hp-gqr{background:#fff;border-radius:16px;padding:11px;width:102px;height:102px;margin:8px 0}
.hp-gqr svg{width:100%;height:100%}
.hp-gratis p{font-size:11px;opacity:.85;max-width:200px}
/* konfete u telefonu */
.hp-confetti{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:36}
.hp-confetti i{position:absolute;top:-12px;width:7px;height:7px;animation:hpFall linear forwards}
@keyframes hpFall{to{transform:translateY(680px) rotate(720deg);opacity:0}}

/* ---------- section osnove ---------- */
.sec-label{
  display:inline-flex;align-items:center;gap:12px;
  font-weight:600;font-size:14px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--blue);margin-bottom:18px;
}
.sec-label em{
  font-style:normal;font-family:var(--disp);font-weight:800;
  background:var(--blue);color:var(--cream);border-radius:8px;padding:3px 9px;font-size:13px;
}
.sec-label-cream{color:var(--cream)}
.sec-label-cream em{background:var(--cream);color:var(--blue)}
.sec-h{
  font-family:var(--disp);font-weight:800;
  font-size:clamp(38px,6.4vw,84px);line-height:1.02;letter-spacing:-.03em;
}
.sec-h-cream{color:var(--cream)}
.sec-sub{max-width:600px;margin-top:18px;font-size:clamp(16px,2vw,19px);color:color-mix(in srgb,var(--ink) 75%,transparent)}

/* ---------- 01 kako radi — horizontalni scroll ---------- */
.kako{padding:clamp(90px,14vh,150px) 0 0}
.kako-head{margin-bottom:clamp(30px,6vh,60px)}
.hs{overflow:clip}
.hs-track{
  display:flex;gap:clamp(18px,2.5vw,30px);
  padding:0 var(--pad) clamp(70px,10vh,110px);
  width:max-content;
}
.hs-card{
  position:relative;
  width:clamp(300px,38vw,520px);
  background:#fff;
  border-radius:var(--r);
  padding:clamp(26px,3vw,40px);
  box-shadow:0 24px 60px -30px rgba(20,17,12,.25);
  display:flex;flex-direction:column;gap:14px;
}
.hs-num{
  position:absolute;top:18px;right:22px;
  font-family:var(--disp);font-weight:800;font-size:clamp(54px,6vw,88px);
  color:var(--cream-deep);line-height:1;
}
.hs-card h3{font-family:var(--disp);font-weight:700;font-size:clamp(22px,2.6vw,30px);letter-spacing:-.02em}
.hs-card p{color:color-mix(in srgb,var(--ink) 72%,transparent);font-size:clamp(15px,1.7vw,17px)}
.hs-art{
  height:clamp(120px,16vw,190px);border-radius:16px;background:var(--cream);
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
/* mini QR ilustracija */
.qr-mini{
  width:86px;height:86px;border-radius:12px;background:#fff;border:3px solid var(--blue);
  background-image:
    linear-gradient(var(--blue),var(--blue)),linear-gradient(var(--blue),var(--blue)),
    linear-gradient(var(--blue),var(--blue)),linear-gradient(var(--blue),var(--blue)),
    linear-gradient(var(--blue),var(--blue));
  background-repeat:no-repeat;
  background-size:22px 22px,22px 22px,22px 22px,14px 14px,10px 26px;
  background-position:10px 10px,calc(100% - 10px) 10px,10px calc(100% - 10px),calc(100% - 14px) calc(100% - 14px),46px 40px;
}
/* pečati */
.stamp-row{display:flex;gap:10px}
.stamp-row b{
  width:30px;height:30px;border-radius:50%;border:2.5px dashed color-mix(in srgb,var(--blue) 45%,transparent);
}
.stamp-row b.on{background:var(--blue);border:2.5px solid var(--blue)}
/* gratis bedž */
.gift-badge{
  font-family:var(--disp);font-weight:800;font-size:26px;letter-spacing:.06em;
  background:var(--blue);color:var(--cream);border-radius:14px;padding:12px 26px;
  transform:rotate(-4deg);box-shadow:0 14px 30px -12px rgba(30,59,184,.6);
}
/* statistika */
.bars{display:flex;align-items:flex-end;gap:12px;height:70%}
.bars b{width:26px;border-radius:8px 8px 4px 4px;background:var(--blue);height:calc(var(--h)*100%);opacity:.9}

/* ---------- 02 šta dobijaš — stack kartice ---------- */
.dobijas{padding:clamp(80px,12vh,140px) 0 0}
.stack{
  max-width:var(--wrap);margin:clamp(36px,7vh,70px) auto 0;
  padding:0 var(--pad) clamp(80px,12vh,140px);
  display:flex;flex-direction:column;gap:clamp(22px,4vh,40px);
}
/* nevidljivi spacer na dnu (flex item): sticky granica je CONTENT box pa
   padding-bottom ne daje karticama prostor — bez ovoga špil kreće napolje
   istog trena kad se poslednja kartica usidri (04.07.2026.) */
.stack::after{content:"";display:block;height:clamp(60px,14vh,150px)}
.stack-card{
  position:sticky;
  border-radius:calc(var(--r) + 8px);
  padding:clamp(28px,4.5vw,64px);
  min-height:clamp(380px,58vh,520px);
  display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(24px,4vw,60px);align-items:center;
  will-change:transform;
  box-shadow:0 -14px 50px -30px rgba(20,17,12,.35);
}
/* 5 kartica od 04.07.2026. (dodata „Tvoj domen") — simetrični pomaci */
.stack-card:nth-child(1){top:calc(50svh - clamp(190px,29svh,260px) - 36px)}
.stack-card:nth-child(2){top:calc(50svh - clamp(190px,29svh,260px) - 18px)}
.stack-card:nth-child(3){top:calc(50svh - clamp(190px,29svh,260px))}
.stack-card:nth-child(4){top:calc(50svh - clamp(190px,29svh,260px) + 18px)}
.stack-card:nth-child(5){top:calc(50svh - clamp(190px,29svh,260px) + 36px)}
.sc-blue{background:var(--blue);color:var(--cream)}
.sc-cream{background:#fff;color:var(--ink);border:1.5px solid var(--cream-deep)}
.sc-tag{
  display:inline-block;font-weight:600;font-size:13px;letter-spacing:.14em;text-transform:uppercase;
  border:1.5px solid currentColor;border-radius:999px;padding:6px 14px;margin-bottom:18px;opacity:.9;
}
.stack-card h3{font-family:var(--disp);font-weight:800;font-size:clamp(26px,3.6vw,46px);letter-spacing:-.025em;line-height:1.05;margin-bottom:14px}
.stack-card p{font-size:clamp(15px,1.8vw,18px);opacity:.85;max-width:52ch}
.sc-demo{display:flex;align-items:center;justify-content:center}
.sc-demo:has(.an-row){flex-direction:column;align-items:stretch;justify-content:center}
/* analitika demo */
.an-row{display:flex;align-items:baseline;gap:14px;padding:10px 0;border-bottom:1px solid color-mix(in srgb,currentColor 20%,transparent)}
.an-row:last-child{border-bottom:0}
.an-num{font-family:var(--disp);font-weight:800;font-size:clamp(38px,4.6vw,60px);min-width:2.2ch;font-variant-numeric:tabular-nums}
.an-row span{font-size:15px;opacity:.75}
/* kupon demo */
.coupon{
  background:var(--cream);color:var(--ink);border-radius:18px;padding:22px 26px;
  display:flex;flex-direction:column;align-items:center;gap:14px;
  border:2px dashed var(--blue);transform:rotate(2deg);
  box-shadow:0 20px 44px -20px rgba(20,17,12,.35);
}
.coupon-txt{font-family:var(--disp);font-weight:700;font-size:clamp(17px,2vw,21px);min-height:1.5em}
.coupon-qr{
  width:92px;height:92px;border-radius:10px;background:#fff;border:3px solid var(--blue);
  background-image:linear-gradient(var(--blue),var(--blue)),linear-gradient(var(--blue),var(--blue)),linear-gradient(var(--blue),var(--blue)),linear-gradient(var(--blue),var(--blue));
  background-repeat:no-repeat;
  background-size:24px 24px,24px 24px,24px 24px,16px 16px;
  background-position:10px 10px,calc(100% - 10px) 10px,10px calc(100% - 10px),calc(100% - 16px) calc(100% - 16px);
}
/* brend demo */
.brand-card{
  --acc:var(--cream);
  width:min(300px,100%);border-radius:20px;background:var(--cream);color:var(--ink);
  padding:24px;display:flex;flex-direction:column;gap:14px;align-items:flex-start;
  border:1.5px solid var(--cream-deep);
  box-shadow:0 20px 44px -20px rgba(20,17,12,.4);
  transition:background .5s;
}
.brand-name{font-family:var(--disp);font-weight:800;letter-spacing:.06em;font-size:15px;color:var(--acc2,var(--blue));transition:color .5s}
.brand-prod{font-size:56px;line-height:1}
.brand-dots{display:flex;gap:8px}
.brand-dots b{width:20px;height:20px;border-radius:50%;border:2px dashed color-mix(in srgb,var(--acc2,var(--blue)) 50%,transparent);transition:background .5s,border-color .5s}
.brand-dots b.on{background:var(--acc2,var(--blue));border-style:solid;border-color:var(--acc2,var(--blue))}
/* bez aplikacije demo */
.noapp{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}
.noapp-x{font-size:64px}
.noapp-line{font-size:17px;line-height:1.7;opacity:.85}
.noapp-line b{font-family:var(--disp);font-weight:800;font-size:22px;color:var(--blue)}
/* --- dodato 04.07.2026. uz /pro stranicu: link u kartici, špic-čip, mini browser --- */
.sc-link{
  display:inline-block;margin-top:18px;font-weight:600;font-size:15.5px;
  text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:5px;
  transition:opacity .25s;
}
.sc-link:hover{opacity:.75}
/* naizmenični prikaz analitike: brojevi ⟷ toplotna mapa (04.07.2026.)
   Oba prikaza dele ISTO grid polje (grid-area 1/1) pa je visina demoa
   max(brojevi, mapa) — bez absolute overlay-a koji je na tablet širinama
   preklapao tekst i sekao natpis. JS na #anFlip smenjuje .show-heat u loopu
   (samo dok je kartica u kadru). */
.an-flip{display:grid}
.an-view{grid-area:1/1;align-self:center;transition:opacity .4s ease,transform .5s ease}
/* dolazeći prikaz kreće tek kad odlazeći skoro nestane (bez mešanja preko) */
.an-flip.show-heat .an-view-heat,
.an-flip:not(.show-heat) .an-view-nums{transition-delay:.28s}
.an-view-heat{
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  opacity:0;transform:translateY(18px);pointer-events:none;
}
.an-flip.show-heat .an-view-nums{opacity:0;transform:translateY(-18px)}
.an-flip.show-heat .an-view-heat{opacity:1;transform:none}
/* mini toplotna mapa — vizuelni jezik app dashboarda, krem na plavoj kartici;
   inline promenljive po ćeliji: --p (intenzitet za color-mix), --dl (kaskadni delay) */
/* max-width drži mapu kompaktnom i na širokim jednokolonskim (tablet) karticama
   — bez toga bi Analitika kartica narasla mnogo iznad ostalih */
.an-heat{display:grid;grid-template-columns:auto repeat(12,1fr);gap:4px;width:100%;max-width:420px}
.an-heat-hour{font-size:10px;opacity:.55;text-align:center;font-variant-numeric:tabular-nums;overflow:hidden}
.an-heat-day{display:flex;align-items:center;padding-right:7px;font-size:11px;letter-spacing:.04em;opacity:.55}
.an-heat-cell{
  aspect-ratio:1;border-radius:4px;
  border:1px solid color-mix(in srgb,currentColor 18%,transparent);
  background:color-mix(in srgb,currentColor var(--p,0%),transparent);
  opacity:0;transition:opacity .45s ease var(--dl,0ms); /* ćelije se REĐAJU na svaki prikaz */
}
.an-flip.show-heat .an-heat-cell{
  opacity:1;
  /* „živa" mapa: talas blagog disanja preko celog grida dok je prikazana */
  animation:anBreathe 3.6s ease-in-out infinite;
  animation-delay:calc(var(--dl,0ms) * 6);
}
.an-heat-cell.peak{border-color:currentColor;box-shadow:0 0 0 1.5px currentColor}
.an-flip.show-heat .an-heat-cell.peak{
  animation:anBreathe 3.6s ease-in-out infinite,anPeakPulse 2.4s ease 1.2s infinite;
  animation-delay:calc(var(--dl,0ms) * 6),1.2s;
}
@keyframes anBreathe{0%,100%{filter:brightness(1)}50%{filter:brightness(1.45)}}
@keyframes anPeakPulse{
  0%,100%{box-shadow:0 0 0 1.5px currentColor}
  50%{box-shadow:0 0 0 5px color-mix(in srgb,currentColor 40%,transparent)}
}
.an-heat-cap{margin-top:14px;font-size:13px;font-style:italic;opacity:.65;text-align:center}
/* mini browser maketa (demo „Tvoj domen") */
.mini-browser{
  width:min(320px,100%);background:#fff;border-radius:16px;overflow:hidden;
  box-shadow:0 24px 54px -24px rgba(20,17,12,.45);
  color:var(--ink);
}
.mini-browser-bar{
  display:flex;align-items:center;gap:5px;
  padding:9px 12px;background:var(--cream-deep);
}
.mini-browser-bar i{width:9px;height:9px;border-radius:50%;background:rgba(20,17,12,.22)}
.mini-browser-bar span{
  flex:1;margin-left:7px;background:#fff;border-radius:999px;padding:5px 14px;
  font-size:12.5px;font-weight:600;
}
.mini-browser-body{background:var(--cream);padding:18px;display:flex;justify-content:center}
.mini-browser .brand-card{box-shadow:none;width:100%}

/* ---------- 03 za koga — redovi + telefon sa karticom iz app-a ---------- */
.zakoga{position:relative;padding:clamp(80px,12vh,140px) 0}
.zakoga > .wrap:first-child{margin-bottom:clamp(30px,6vh,56px)}
.zk-grid{
  display:grid;grid-template-columns:1.25fr .75fr;gap:clamp(24px,4vw,64px);
  align-items:center;
}
.rows{list-style:none;border-top:1.5px solid color-mix(in srgb,var(--ink) 25%,transparent)}
.row a,.row button{
  position:relative;display:flex;align-items:baseline;gap:clamp(12px,2vw,26px);
  width:100%;text-align:left;
  padding:clamp(18px,2.6vw,30px) clamp(14px,1.8vw,24px);
  border-bottom:1.5px solid color-mix(in srgb,var(--ink) 25%,transparent);
  overflow:hidden;
}
.row a::before,.row button::before{
  content:'';position:absolute;inset:0;background:var(--blue);
  transform:translateY(101%);transition:transform .45s var(--ease);
}
.row a:hover::before,.row a:focus-visible::before,
.row button:hover::before,.row button:focus-visible::before,
.row.on button::before{transform:translateY(0)}
.row-name,.row-hint,.row-arr{position:relative;z-index:1;transition:color .35s}
.row-name{
  font-family:var(--disp);font-weight:800;letter-spacing:-.03em;
  font-size:clamp(30px,4.6vw,58px);line-height:1;
}
.row-hint{font-size:clamp(13px,1.6vw,16px);opacity:.6}
.row-arr{margin-left:auto;font-size:clamp(22px,3vw,36px);transform:translateX(-10px);transition:transform .35s var(--ease),color .35s}
.row a:hover .row-name,.row a:hover .row-hint,.row a:hover .row-arr,
.row a:focus-visible .row-name,.row a:focus-visible .row-hint,.row a:focus-visible .row-arr,
.row button:hover .row-name,.row button:hover .row-hint,.row button:hover .row-arr,
.row.on .row-name,.row.on .row-hint,.row.on .row-arr{color:var(--cream)}
.row a:hover .row-hint,.row.on .row-hint{opacity:.85}
.row a:hover .row-arr,.row.on .row-arr{transform:translateX(0)}
/* svaka vertikala boji red svojom bojom (postavlja JS preko --row-acc) */
.row button::before{background:var(--row-acc,var(--blue))}

/* telefon (deli oklop .device sa hero telefonima; ovde samo širina) */
.zk-phonecol{display:flex;justify-content:center}
.zk-device{--w:min(300px,72vw)}

/* ---------- kartica kupca u telefonu (verna app-u, scope .ph) ----------
   Vrednosti prate .sr-card iz aplikacije (header/pilula/hero/loyalty-card/pečati);
   --acc = akcenat vertikale (app: --ink/--blue), --pl = boja tanjira (pasta/burger). */
.ph{
  --acc:#1E3BB8;--pl:var(--acc);
  /* fiksni dizajn 276×596 (unutrašnjost device-a 300px) — JS skalira ceo ekran transform-om */
  width:276px;height:596px;
  position:absolute;top:0;left:0;transform-origin:top left;
  display:flex;flex-direction:column;
  background:var(--cream);color:var(--acc);
  font-family:var(--body);
  transition:color .5s;
}
.ph-header{
  padding:30px 16px 12px;display:flex;align-items:center;gap:10px;
  border-bottom:1.5px solid var(--acc);flex-shrink:0;
  transition:border-color .5s;
}
.ph-avatar{
  width:38px;height:38px;border-radius:50%;border:1.5px solid var(--acc);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--disp);font-weight:800;font-size:15px;background:#fff;flex-shrink:0;
  transition:border-color .5s;
}
.ph-who{flex:1;line-height:1.2;min-width:0}
.ph-who b{font-size:13.5px;font-weight:600;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ph-who span{font-size:10.5px;opacity:.65}
.ph-pill{
  background:var(--acc);color:var(--cream);border-radius:999px;padding:7px 12px;
  font-family:var(--disp);font-weight:800;font-size:10px;letter-spacing:.08em;
  flex-shrink:0;white-space:nowrap;transition:background .5s;
}
.ph-body{flex:1;padding:14px 14px 16px;display:flex;flex-direction:column;gap:11px;overflow:hidden}
.ph-hero{
  font-family:var(--disp);font-weight:800;font-size:24px;line-height:.98;
  text-transform:uppercase;margin:0;
}
.ph-hero i{
  font-style:italic;font-weight:600;font-family:var(--body);
  text-transform:none;font-size:21px;
}
.ph-lcard{
  border:1.5px solid var(--acc);border-radius:20px;background:#fff;
  padding:13px 11px 11px;flex-shrink:0;transition:border-color .5s;
}
.ph-lc-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:9px;padding:0 2px}
.ph-lc-top .disp{font-family:var(--disp);font-weight:800;font-size:12px;text-transform:uppercase}
.ph-count{font-size:10.5px;font-weight:500;opacity:.7}
.ph-count b{font-family:var(--disp);font-weight:800;font-size:14px;opacity:1}
.ph-progress{display:flex;gap:9px;align-items:center;min-width:0}
.ph-glass{width:64px;flex-shrink:0;position:relative}
.ph-glass[data-theme='pasta'],.ph-glass[data-theme='burger']{width:80px}
.ph-glass[data-theme='pica']{width:78px}
.ph-glass svg{width:100%;height:auto;display:block;color:var(--acc)}
.ph-stamps{
  flex:1;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:5px;min-width:0;
  color:var(--acc);
}
.ph-stamp{
  aspect-ratio:1;border-radius:50%;min-width:0;border:1.5px solid var(--acc);
  background:var(--cream);display:flex;align-items:center;justify-content:center;
  font-weight:600;font-size:9px;position:relative;transition:border-color .5s;
}
.ph-stamp.gratis{font-style:italic;font-size:7.5px;border-style:dashed;background:#fff}
.ph-stamp .splat{position:absolute;inset:-2px;opacity:0;transform:scale(2.2) rotate(-30deg);color:var(--acc);width:auto;height:auto}
.ph-stamp.done{border-color:transparent;color:transparent}
.ph-stamp.done .splat{opacity:1;transform:scale(1) rotate(0);transition:transform .45s cubic-bezier(.2,1.6,.35,1),opacity .3s}
.ph-note{font-size:10px;opacity:.65;margin-top:8px;padding:0 2px}
.ph-qr{
  border:1.5px solid var(--acc);border-radius:20px;background:#fff;
  padding:11px;display:flex;gap:11px;align-items:center;transition:border-color .5s;
}
.ph-qr-box{
  width:52px;height:52px;border-radius:10px;border:2.5px solid var(--acc);flex-shrink:0;
  background:
    linear-gradient(var(--acc),var(--acc)) 6px 6px/12px 12px no-repeat,
    linear-gradient(var(--acc),var(--acc)) calc(100% - 6px) 6px/12px 12px no-repeat,
    linear-gradient(var(--acc),var(--acc)) 6px calc(100% - 6px)/12px 12px no-repeat,
    linear-gradient(var(--acc),var(--acc)) calc(100% - 8px) calc(100% - 8px)/8px 8px no-repeat,
    #fff;
  transition:border-color .5s;
}
.ph-qr-txt{line-height:1.35;min-width:0}
.ph-qr-txt b{font-family:var(--disp);font-weight:800;font-size:11.5px;text-transform:uppercase;display:block}
.ph-qr-txt span{font-size:9.5px;opacity:.65}
.ph-sig{text-align:center;font-size:9px;opacity:.5;font-weight:600;margin-top:auto}

/* ---------- 04 cene ---------- */
.cene{
  background:var(--blue);color:var(--cream);
  padding:clamp(90px,13vh,150px) 0 clamp(90px,13vh,150px);
  border-radius:clamp(24px,4vw,48px) clamp(24px,4vw,48px) 0 0;
}
.cene-badge{
  display:inline-block;margin-top:22px;
  border:1.5px dashed color-mix(in srgb,var(--cream) 65%,transparent);
  border-radius:999px;padding:9px 20px;font-size:14.5px;letter-spacing:.04em;
}
.cene-toggle{
  display:flex;width:max-content;margin-top:34px;
  border:1.5px solid color-mix(in srgb,var(--cream) 45%,transparent);
  border-radius:999px;padding:4px;gap:4px;
}
.cene-toggle button{
  color:var(--cream);border-radius:999px;padding:10px 22px;font-weight:600;font-size:15px;
  transition:background .3s,color .3s;
}
.cene-toggle button i{font-style:normal;font-size:12px;opacity:.7;margin-left:4px}
.cene-toggle button.on{background:var(--cream);color:var(--blue)}
.cene-toggle button.on i{opacity:.9}
.plans{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2.5vw,28px);
  margin-top:clamp(30px,5vh,50px);
}
.plan{
  border:1.5px solid color-mix(in srgb,var(--cream) 35%,transparent);
  border-radius:calc(var(--r) + 4px);
  padding:clamp(26px,3.4vw,44px);
  display:flex;flex-direction:column;gap:18px;
  position:relative;
  transition:transform .35s var(--ease),border-color .35s,background .35s;
}
.plan:hover{transform:translateY(-6px);border-color:color-mix(in srgb,var(--cream) 70%,transparent)}
.plan-pro{background:color-mix(in srgb,var(--cream) 8%,transparent);border-color:color-mix(in srgb,var(--cream) 60%,transparent)}
.plan-pop{
  position:absolute;top:-14px;right:26px;
  background:var(--cream);color:var(--blue);
  font-weight:700;font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;
  border-radius:999px;padding:6px 14px;
}
.plan h3{font-family:var(--disp);font-weight:800;font-size:clamp(24px,2.8vw,32px);letter-spacing:-.02em}
.plan-price{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.plan-price b{
  font-family:var(--disp);font-weight:800;font-size:clamp(44px,5.5vw,68px);letter-spacing:-.03em;line-height:1;
  font-variant-numeric:tabular-nums;
}
.plan-per{font-size:15px;opacity:.75}
.plan ul{list-style:none;display:flex;flex-direction:column;gap:10px;flex:1}
.plan ul li{
  padding-left:26px;position:relative;font-size:15.5px;opacity:.92;
}
.plan ul li::before{content:'✓';position:absolute;left:0;font-weight:700}
.plan .btn{align-self:flex-start;margin-top:6px}

/* ---------- 05 probaj — forma ---------- */
.probaj{padding:clamp(90px,13vh,150px) 0;background:var(--cream)}
.probaj-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,80px);align-items:start;position:relative;
}
.probaj-perks{list-style:none;margin-top:26px;display:flex;flex-direction:column;gap:12px}
.probaj-perks li{padding-left:30px;position:relative;font-size:16.5px}
.probaj-perks li::before{
  content:'✓';position:absolute;left:0;top:0;
  width:22px;height:22px;border-radius:50%;background:var(--blue);color:var(--cream);
  font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;
}
.form{
  background:#fff;border-radius:calc(var(--r) + 4px);
  padding:clamp(24px,3.2vw,40px);
  display:flex;flex-direction:column;gap:8px;
  box-shadow:0 30px 70px -35px rgba(20,17,12,.35);
  border:1.5px solid var(--cream-deep);
}
.form label{font-weight:600;font-size:14px;letter-spacing:.03em;margin-top:14px}
.form label:first-child{margin-top:0}
.form .opt{font-weight:400;opacity:.55}
.form input{
  font:inherit;color:var(--ink);background:transparent;
  border:0;border-bottom:2px solid var(--cream-deep);
  padding:10px 2px;outline:none;border-radius:0;
  transition:border-color .3s;width:100%;
}
.form input:focus{border-color:var(--blue)}
.form input::placeholder{color:color-mix(in srgb,var(--ink) 32%,transparent)}
.slug-line{display:flex;align-items:baseline;gap:2px}
.slug-pre{font-size:14.5px;opacity:.55;white-space:nowrap}
.slug-status{font-size:13.5px;margin-top:6px;min-height:1.4em;transition:color .3s}
.slug-status.idle{color:color-mix(in srgb,var(--ink) 50%,transparent)}
.slug-status.ok{color:#177a3e;font-weight:600}
.slug-status.bad{color:#b3261e;font-weight:600}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
.form-plan{
  display:flex;width:max-content;margin-top:20px;
  border:1.5px solid var(--cream-deep);border-radius:999px;padding:4px;gap:4px;
}
.form-plan button{border-radius:999px;padding:9px 20px;font-weight:600;font-size:14.5px;transition:background .3s,color .3s}
.form-plan button.on{background:var(--blue);color:var(--cream)}
.btn-submit{margin-top:22px;width:100%}
.btn-submit:disabled{opacity:.6;cursor:default;transform:none}
.form-msg{color:#b3261e;font-weight:600;font-size:14.5px;min-height:1.4em;margin-top:4px}
/* trust napomena (kao na originalnom sajtu): plava, ključna fraza podvučena duplom linijom */
.form-safe{
  font-size:14.5px;font-weight:600;color:var(--blue);margin-top:6px;text-align:center;
}
.form-safe em{
  font-style:normal;
  text-decoration:underline;text-decoration-style:double;
  text-decoration-thickness:1.5px;text-underline-offset:4px;
}
.form-trust{font-size:12.5px;opacity:.6;margin-top:6px;text-align:center}
.form-trust a{text-decoration:underline;text-underline-offset:3px}
.form-done{
  display:none;
  grid-column:2;
  background:var(--blue);color:var(--cream);
  border-radius:calc(var(--r) + 4px);
  padding:clamp(30px,4vw,50px);
  text-align:center;
}
.form-done.show{display:block}
.form-done-stamp{
  display:inline-flex;align-items:center;justify-content:center;
  width:64px;height:64px;border-radius:50%;background:var(--cream);color:var(--blue);
  font-size:30px;font-weight:800;margin-bottom:18px;
}
.form-done h3{font-family:var(--disp);font-weight:800;font-size:clamp(24px,3vw,34px);margin-bottom:10px}
.form-done p{opacity:.85}

/* ---------- footer ---------- */
.foot{
  background:var(--ink);color:var(--cream);
  padding:clamp(50px,8vh,90px) 0 30px;
  overflow:clip;
}
.foot-giant{
  font-family:var(--disp);font-weight:800;letter-spacing:-.04em;
  font-size:clamp(64px,14.5vw,220px);line-height:.9;text-align:center;
  color:transparent;-webkit-text-stroke:1.5px color-mix(in srgb,var(--cream) 35%,transparent);
  user-select:none;margin-bottom:clamp(40px,7vh,80px);white-space:nowrap;
}
.foot-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.foot-col{display:flex;flex-direction:column;gap:10px}
.foot-t{font-weight:700;font-size:13px;letter-spacing:.16em;text-transform:uppercase;opacity:.5;margin-bottom:6px}
.foot-col a{opacity:.85;transition:opacity .25s;width:max-content}
.foot-col a:hover{opacity:1;text-decoration:underline;text-underline-offset:4px}
.foot-c{text-align:center;font-size:13px;opacity:.4;margin-top:clamp(40px,6vh,70px)}

/* ---------- reveal default (bez JS-a sve vidljivo; JS postavlja početna stanja) ---------- */
.rev{opacity:1}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1100px){
  /* hero telefoni: pozadinski se sklanjaju, glavni ide u tok ispod teksta */
  .hero-bg-phones{display:none}
  .hero-phone-col{position:static;transform:none;margin:46px auto 0;display:flex;justify-content:center}
  .hero-device{--w:250px}
  /* manji telefon = manja skala fiksnog 276×596 dizajna, a island je u stvarnim
     pikselima — header kartice („Marko") bi se zalepio uz kameru; spusti sadržaj
     (04.07.2026.). Footer „powered by" ostaje na dnu (margin-top:auto) */
  .hero-device .ph-header{padding-top:48px}
}
@media(max-width:1024px){
  /* sadržaj na vrh: kad JS ujednači visine kartica (mobilni stack), naslov je
     na SVAKOJ kartici na istom rastojanju od vrha (= padding), a višak visine
     ostaje prazan pri dnu (05.07.2026. — ranije center pa je naslov "plutao") */
  .stack-card{grid-template-columns:1fr;min-height:0;gap:26px;align-content:start}
  .sc-demo{justify-content:flex-start}
}
@media(max-width:880px){
  .nav-links,.btn-nav{display:none}
  .nav-burger{display:block}
  /* bez pina: prirodan horizontalni swipe sa snap-om */
  .hs{overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .hs::-webkit-scrollbar{display:none}
  .hs-card{scroll-snap-align:center;width:min(78vw,420px)}
  /* telefon gore, kompaktni redovi ispod (tap na red dovede telefon u kadar) */
  .zk-grid{grid-template-columns:1fr;gap:18px}
  .zk-phonecol{order:-1}
  .zk-device{--w:min(180px,46vw);border-radius:30px;padding:7px}
  .zk-device .dev-screen{border-radius:24px}
  .zk-device .island{width:56px;height:15px;top:9px;border-radius:9px}
  .zk-device .b-pwr{top:89px;height:38px}
  .zk-device .b-sil{top:72px;height:16px}
  .zk-device .b-vu{top:96px;height:27px}
  .zk-device .b-vd{top:127px;height:27px}
  .row a,.row button{padding:14px 12px}
  .probaj-grid{grid-template-columns:1fr}
  .form-done{grid-column:1}
  .plans{grid-template-columns:1fr}
  .plan .btn{align-self:stretch}
  .foot-grid{grid-template-columns:1fr;gap:26px}
}
@media(max-width:560px){
  body{font-size:16px}
  .hero{padding-top:104px}
  .hero-cta .btn{width:100%}
  .hero-device{--w:220px}
  /* top 11px = tačno ivica ekrana (padding oklopa) → island izgledao zalepljen
     za bezel; 16px daje prirodan razmak kao na desktop verziji (04.07.2026.) */
  .hero-device .island{width:70px;height:19px;top:16px}
  /* još manja skala → još veći spust sadržaja kartice ispod island-a */
  .hero-device .ph-header{padding-top:54px}
  .hero-device .b-pwr{top:110px;height:46px}
  .hero-device .b-sil{top:88px;height:19px}
  .hero-device .b-vu{top:118px;height:32px}
  .hero-device .b-vd{top:156px;height:32px}
  .hero-phone-col{margin-top:38px}
  .hs-track{gap:14px}
  .hs-card{width:82vw}
  /* stack efekat OSTAJE i na telefonu (sticky + GSAP scale) — samo tanji padding */
  .stack-card{padding:24px}
  /* kompaktni redovi: bez strelice, hint u istom redu */
  .row .row-arr{display:none}
  .row a,.row button{padding:12px 10px;gap:10px}
  .cene-toggle{width:100%;justify-content:center}
  .cene-toggle button{flex:1;text-align:center}
}

/* ---------- reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .hero-float{animation:none}
  .bg-phone-in{animation:none}
  .loader{display:none}
  .stack-card{position:static}
  .hs{overflow-x:auto}
}

/* ---------- 05 pitanja (FAQ) ---------- */
.faq{padding:clamp(90px,13vh,150px) 0;background:var(--cream)}
.faq-grid{display:grid;grid-template-columns:1fr 1.25fr;gap:clamp(34px,5vw,80px);align-items:start}
.faq-txt{position:sticky;top:110px}
.faq-mail{color:var(--blue);font-weight:600;text-decoration:underline;text-underline-offset:4px}
.faq-list{display:flex;flex-direction:column;border-top:1px solid rgba(30,59,184,.22)}
.faq-item{border-bottom:1px solid rgba(30,59,184,.22)}
.faq-item summary{
  list-style:none;cursor:pointer;user-select:none;
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:19px 2px;
  font-weight:600;font-size:clamp(16px,1.9vw,19px);line-height:1.35;color:var(--ink);
  transition:color .25s;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover,.faq-item[open] summary{color:var(--blue)}
/* plus u krugu; otvoreno -> rotira se u x i popuni plavom */
.faq-x{
  position:relative;flex:none;width:28px;height:28px;border-radius:50%;
  border:1.5px solid var(--blue);
  transition:transform .4s var(--ease),background .25s;
}
.faq-x::before,.faq-x::after{
  content:'';position:absolute;left:50%;top:50%;width:11px;height:1.6px;
  background:var(--blue);transform:translate(-50%,-50%);transition:background .25s;
}
.faq-x::after{transform:translate(-50%,-50%) rotate(90deg)}
.faq-item[open] .faq-x{transform:rotate(45deg);background:var(--blue)}
.faq-item[open] .faq-x::before,.faq-item[open] .faq-x::after{background:var(--cream)}
/* odgovor: visinu animira JS (gsap), overflow seče tokom tvina */
.faq-a{overflow:hidden}
.faq-a p{padding:2px 46px 22px 2px;max-width:58ch;font-size:15.5px;line-height:1.65;color:color-mix(in srgb,var(--ink) 78%,transparent)}
@media(max-width:880px){
  .faq-grid{grid-template-columns:1fr;gap:26px}
  .faq-txt{position:static}
  .faq-a p{padding-right:8px}
}
