/* ============================================================
   STAMPRESSO — /payments (plaćanje pretplate)
   Dodatak na css/site.css (nasleđuje :root, .nav, .btn, .form,
   .sec-*, .foot). Sve novo je pod .pay-* prefiksom.
   ============================================================ */

.pay-body{min-height:100svh;display:flex;flex-direction:column}
.pay-main{flex:1;padding:clamp(110px,16vh,150px) 0 clamp(60px,8vh,90px)}
.pay-wrap{max-width:720px;margin:0 auto;padding:0 var(--pad, 22px)}

/* ---------- koraci ---------- */
.pay-step{margin-top:clamp(38px,6vh,56px)}
.pay-step-t{
  font-family:var(--disp);font-weight:800;font-size:clamp(20px,2.6vw,26px);
  letter-spacing:-.01em;display:flex;align-items:center;gap:12px;margin-bottom:18px;
}
.pay-step-t span{
  width:34px;height:34px;flex:0 0 34px;border-radius:50%;
  background:var(--blue);color:var(--cream);
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--mono, 'Space Grotesk');font-size:16px;font-weight:700;
}

/* ---------- korak 1: pretraga ---------- */
.pay-search{position:relative}
.pay-search input{
  width:100%;padding:15px 18px;font-size:16.5px;font-family:inherit;
  background:#fff;border:2px solid color-mix(in srgb,var(--ink) 15%,transparent);
  border-radius:14px;transition:border-color .25s;
}
.pay-search input:focus{border-color:var(--blue);outline:none}
.pay-suggest{
  position:absolute;left:0;right:0;top:calc(100% + 6px);z-index:30;
  background:#fff;border:2px solid color-mix(in srgb,var(--ink) 12%,transparent);
  border-radius:14px;box-shadow:0 18px 44px -18px rgba(20,17,12,.25);
  list-style:none;margin:0;padding:6px;max-height:320px;overflow-y:auto;
}
.pay-suggest button{
  display:flex;align-items:baseline;gap:10px;width:100%;text-align:left;
  padding:11px 12px;border-radius:10px;font-size:15.5px;
}
.pay-suggest button:hover,.pay-suggest button:focus-visible{background:color-mix(in srgb,var(--blue) 9%,transparent)}
.pay-suggest .sg-name{font-weight:700}
.pay-suggest .sg-slug{font-size:13px;opacity:.55}
.pay-suggest .sg-none{padding:11px 12px;font-size:14.5px;opacity:.6}
.pay-hint{margin-top:10px;font-size:14px;min-height:1.4em;color:color-mix(in srgb,var(--ink) 60%,transparent)}
.pay-hint.bad{color:#b3261e;font-weight:600}

/* ---------- korak 2: kartica stanja ---------- */
.pay-card{
  background:#fff;border-radius:18px;padding:22px 24px;
  box-shadow:0 14px 40px -20px rgba(20,17,12,.18);
}
.pay-card-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.pay-cafe-name{font-family:var(--disp);font-weight:800;font-size:clamp(20px,2.6vw,26px);letter-spacing:-.01em}
.pay-tier{
  font-size:12.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  background:var(--blue);color:var(--cream);border-radius:999px;padding:4px 12px;
}
.pay-tier.start{background:var(--ink)}
.pay-status{margin-top:10px;font-size:16px;font-weight:600}
.pay-status.ok{color:#177a3e}
.pay-status.warn{color:#9a6200}
.pay-status.bad{color:#b3261e}
.pay-status-note{margin-top:4px;font-size:13.5px;color:color-mix(in srgb,var(--ink) 62%,transparent)}
.pay-change{
  margin-top:14px;font-size:13.5px;font-weight:600;color:var(--blue);
  text-decoration:underline;text-underline-offset:3px;
}

/* ---------- korak 2: podaci firme ---------- */
.pay-billing-ok{
  margin-top:16px;display:flex;align-items:center;gap:12px;
  background:color-mix(in srgb,#177a3e 9%,transparent);
  border-radius:14px;padding:14px 18px;font-size:15px;font-weight:600;color:#14532d;
}
.pay-ok-stamp{
  width:30px;height:30px;flex:0 0 30px;border-radius:50%;background:#177a3e;color:#fff;
  display:inline-flex;align-items:center;justify-content:center;font-size:16px;
}
/* GOTCHA (CLAUDE.md „Trajne lekcije"): .form iz site.css ima display:flex koji
   pregazi [hidden]{display:none} — isto i .pay-billing-ok. Eksplicitni override: */
.pay-billing-form[hidden],.pay-billing-ok[hidden]{display:none}
.pay-billing-form{margin-top:16px}
.pay-form-intro{font-size:14.5px;margin-bottom:6px;color:color-mix(in srgb,var(--ink) 75%,transparent)}
.pay-form-intro em{font-style:normal;font-weight:700;color:var(--blue)}

/* ---------- korak 3: paketi + plaćanje ---------- */
.pay-plans{display:flex;gap:14px;flex-wrap:wrap}
.pay-plan-group{
  display:inline-flex;gap:4px;background:#fff;border-radius:999px;padding:4px;
  border:2px solid color-mix(in srgb,var(--ink) 10%,transparent);
}
.pay-pill{
  border-radius:999px;padding:9px 22px;font-weight:600;font-size:14.5px;
  transition:background .25s,color .25s;
}
.pay-pill.on{background:var(--blue);color:var(--cream)}
.pay-plan-note{margin-top:10px;font-size:13.5px;min-height:1.4em;color:color-mix(in srgb,var(--ink) 62%,transparent)}

.pay-total{
  margin-top:18px;display:flex;align-items:baseline;justify-content:space-between;gap:14px;
  background:var(--blue);color:var(--cream);border-radius:18px;padding:18px 24px;
}
.pay-total-label{font-size:14px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;opacity:.8}
.pay-total-amount{font-family:var(--disp);font-weight:800;font-size:clamp(26px,4vw,36px);letter-spacing:-.01em}

.pay-qr-box{margin-top:18px;display:flex;justify-content:center}
/* GOTCHA (CLAUDE.md): qrcode lib zalepi inline width/height na canvas → !important */
.pay-qr-canvas{
  width:min(260px,70vw) !important;height:auto !important;
  border-radius:18px;background:#fff;padding:10px;
  box-shadow:0 14px 40px -20px rgba(20,17,12,.25);
}
.pay-qr-cap{margin-top:12px;text-align:center;font-size:14px;font-weight:600;color:color-mix(in srgb,var(--ink) 70%,transparent)}

/* ---------- uputstvo: koraci + animirani telefon ---------- */
.pay-how{
  margin-top:26px;display:grid;grid-template-columns:1fr 200px;gap:26px;align-items:center;
}
.pay-how-steps{margin:0;padding-left:22px;display:flex;flex-direction:column;gap:14px}
.pay-how-steps li{font-size:15.5px;line-height:1.55}
.pay-how-steps li::marker{font-weight:800;color:var(--blue)}

.pay-phone{display:flex;justify-content:center}
/* okvir: "kućište" (ink, sa bočnim tasterima) + "ekran" unutra (overflow hidden) */
.pp-frame{
  position:relative;width:174px;height:348px;border-radius:30px;
  background:linear-gradient(160deg,#2a2620,var(--ink) 55%);padding:6px;
  box-shadow:0 24px 50px -24px rgba(20,17,12,.45), inset 0 0 0 1.5px rgba(240,235,220,.14);
}
.pp-btn{position:absolute;background:var(--ink);border-radius:2px}
.pp-btn-vol1{left:-2.5px;top:84px;width:3px;height:24px}
.pp-btn-vol2{left:-2.5px;top:114px;width:3px;height:24px}
.pp-btn-pwr{right:-2.5px;top:98px;width:3px;height:40px}
.pp-screen{
  position:relative;width:100%;height:100%;border-radius:24px;
  background:#fff;overflow:hidden;
}
.pp-status{
  position:absolute;top:8px;left:14px;right:14px;z-index:1;
  display:flex;justify-content:space-between;align-items:center;
  font-size:8.5px;font-weight:700;letter-spacing:.02em;color:var(--ink);
}
.pp-right{display:inline-flex;align-items:center;gap:4px}
.pp-sig{display:inline-flex;align-items:flex-end;gap:1.5px}
.pp-sig i{width:2.5px;border-radius:1px;background:var(--ink)}
.pp-sig i:nth-child(1){height:3.5px}
.pp-sig i:nth-child(2){height:5.5px}
.pp-sig i:nth-child(3){height:7.5px}
.pp-batt{
  width:15px;height:7.5px;border:1.2px solid var(--ink);border-radius:2.5px;position:relative;
  background:linear-gradient(90deg,var(--ink) 70%,transparent 70%);background-clip:content-box;padding:1.2px;
}
.pp-batt::after{
  content:'';position:absolute;right:-3px;top:50%;transform:translateY(-50%);
  width:1.6px;height:3.5px;border-radius:0 1px 1px 0;background:var(--ink);
}
.pp-notch{
  position:absolute;top:7px;left:50%;transform:translateX(-50%);z-index:5;
  width:50px;height:10px;border-radius:999px;background:var(--ink);
}
.pp-home{
  position:absolute;bottom:5px;left:50%;transform:translateX(-50%);z-index:6;
  width:54px;height:4px;border-radius:999px;background:var(--ink);opacity:.85;
}
.pp-scene{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;opacity:0}

/* scena 1: početni ekran */
.pp-s1{animation:ppS1 9s infinite;padding:32px 14px 14px}
.pp-bank-head{
  align-self:stretch;text-align:center;font-family:var(--disp);font-weight:800;
  font-size:13px;color:var(--blue);padding:7px 0;border-bottom:1.5px solid var(--cream-deep);
}
.pp-tiles{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:14px;align-self:stretch}
/* > span: SAMO pločice — .pp-tap živi ugnježden u .pp-ips i ne sme da nasledi ovo */
.pp-tiles > span{
  aspect-ratio:1.15;border-radius:12px;background:var(--cream);
}
.pp-tiles .pp-ips{
  position:relative;background:var(--blue);color:var(--cream);
  display:flex;align-items:center;justify-content:center;
  text-align:center;font-size:11.5px;font-weight:700;line-height:1.25;
  animation:ppPress 9s infinite;
}
/* talasić dodira — CENTRIRAN NA SAMOJ „IPS skeniraj" pločici (živi u njoj) */
.pp-tap{
  position:absolute;top:50%;left:50%;width:36px;height:36px;margin:-18px 0 0 -18px;
  border-radius:50%;border:3px solid var(--cream);
  box-shadow:0 0 10px 1px rgba(240,235,220,.55);
  opacity:0;animation:ppTap 9s infinite;aspect-ratio:auto;background:transparent;
}

/* scena 2: kamera + QR + linija skeniranja */
.pp-s2{animation:ppS2 9s infinite;justify-content:center;gap:12px;background:var(--ink)}
.pp-cam{position:relative;width:104px;height:104px;border-radius:14px;background:#fff;display:flex;align-items:center;justify-content:center}
.pp-qr{
  position:relative;width:76px;height:76px;
  background:conic-gradient(var(--ink) 90deg,#fff 0) 0 0/12px 12px;
}
.pp-qr::before,.pp-qr::after{
  content:'';position:absolute;width:20px;height:20px;background:#fff;
  border:5px solid var(--ink);
}
.pp-qr::before{top:-2px;left:-2px}
.pp-qr::after{top:-2px;right:-2px}
.pp-scanline{
  position:absolute;left:6px;right:6px;height:3px;border-radius:2px;background:var(--blue);
  box-shadow:0 0 12px 2px rgba(30,59,184,.65);top:10%;animation:ppScan 1.4s ease-in-out infinite alternate;
}
.pp-cam-cap{font-size:11px;font-weight:600;color:var(--cream);opacity:.85}

/* scena 3: potvrda */
.pp-s3{animation:ppS3 9s infinite;justify-content:center;gap:8px}
.pp-check{
  width:52px;height:52px;border-radius:50%;background:#177a3e;color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:800;
  animation:ppPop 9s infinite;
}
.pp-amt{font-family:var(--disp);font-weight:800;font-size:20px;margin-top:4px}
.pp-to{font-size:10.5px;font-weight:600;opacity:.6;letter-spacing:.03em}
.pp-pay{
  margin-top:10px;background:var(--blue);color:var(--cream);border-radius:999px;
  padding:8px 30px;font-size:13px;font-weight:700;
}

/* smena scena: 1 (0–30%) → 2 (36–63%) → 3 (69–94%) → ispočetka */
@keyframes ppS1{0%,30%{opacity:1}36%,94%{opacity:0}100%{opacity:1}}
@keyframes ppS2{0%,30%{opacity:0}36%,63%{opacity:1}69%,100%{opacity:0}}
@keyframes ppS3{0%,63%{opacity:0}69%,94%{opacity:1}100%{opacity:0}}
@keyframes ppTap{0%,18%{opacity:0;transform:scale(.4)}24%{opacity:1;transform:scale(1)}30%,100%{opacity:0;transform:scale(1.6)}}
@keyframes ppPress{0%,21%{transform:scale(1)}25%{transform:scale(.93)}29%,100%{transform:scale(1)}}
@keyframes ppScan{from{top:10%}to{top:88%}}
@keyframes ppPop{0%,68%{transform:scale(.4)}74%{transform:scale(1.12)}78%,100%{transform:scale(1)}}

@media (prefers-reduced-motion: reduce){
  .pp-scene,.pp-tap,.pp-scanline,.pp-check,.pp-ips{animation:none}
  .pp-s2{opacity:1} /* statično: prikaži scenu skeniranja */
}

/* ---------- F9c: izbor načina plaćanja (3 dugmeta) ---------- */
.pay-methods{margin-top:24px}
.pay-methods-t{font-size:14px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;opacity:.8}
.pay-methods-btns{margin-top:12px;display:grid;gap:10px}
@media (min-width:640px){.pay-methods-btns{grid-template-columns:repeat(3,1fr)}}
.pay-method{
  display:flex;flex-direction:column;gap:4px;text-align:left;cursor:pointer;
  background:#fff;border:2px solid color-mix(in srgb,var(--ink) 10%,transparent);
  border-radius:16px;padding:15px 18px;
  transition:border-color .25s;
}
.pay-method:hover,.pay-method:focus-visible{border-color:var(--blue)}
.pay-method strong{font-size:15px;font-weight:700;line-height:1.3}
.pay-method span{font-size:12.5px;line-height:1.4;color:color-mix(in srgb,var(--ink) 60%,transparent)}
.pay-method:disabled{opacity:.55;cursor:default}
/* GOTCHA (CLAUDE.md): display na elementu koji se gasi hidden atributom → override */
.pay-method[hidden]{display:none}
.pay-method-ips{background:var(--blue);border-color:var(--blue);color:var(--cream)}
.pay-method-ips span{color:color-mix(in srgb,var(--cream) 78%,transparent)}
.pay-method-ips:hover,.pay-method-ips:focus-visible{border-color:var(--ink)}
.pay-method-ips span[hidden]{display:none}
.pay-ips[hidden]{display:none}
.pay-hint.ok{color:#177a3e;font-weight:600}

/* ---------- sklopivi podaci za ručnu uplatu ---------- */
.pay-manual{margin-top:22px}
.pay-manual summary{
  cursor:pointer;font-weight:700;font-size:15px;color:var(--blue);
  text-decoration:underline;text-underline-offset:4px;width:fit-content;
}
.pay-manual[open] summary{margin-bottom:4px}

.pay-details{margin-top:18px;background:#fff;border-radius:18px;padding:8px 24px}
.pay-details > div{
  display:flex;justify-content:space-between;gap:16px;padding:13px 0;
  border-bottom:1px solid color-mix(in srgb,var(--ink) 8%,transparent);
}
.pay-details > div:last-child{border-bottom:none}
.pay-details dt{font-size:13.5px;font-weight:600;color:color-mix(in srgb,var(--ink) 55%,transparent)}
.pay-details dd{font-size:15px;font-weight:700;text-align:right;overflow-wrap:anywhere}
.pay-fine{margin-top:16px;font-size:13.5px;line-height:1.55;color:color-mix(in srgb,var(--ink) 62%,transparent)}

/* ---------- footer (mala varijanta) ---------- */
.pay-foot{margin-top:auto}

/* ---------- mobil ---------- */
@media (max-width:560px){
  .pay-plans{flex-direction:column;align-items:flex-start}
  .pay-total{flex-direction:column;gap:4px;align-items:flex-start}
  .pay-details > div{flex-direction:column;gap:2px}
  .pay-details dd{text-align:left}
  .pay-how{grid-template-columns:1fr;gap:20px}
}
