/* ═══════════════════════════════════════════════════════
   LOGIN MODAL  (.pr-login-*)
   ═══════════════════════════════════════════════════════ */

/* Overlay */
.pr-login-overlay {
  position: fixed; inset: 0; z-index: 1100;
  background: rgba(13, 47, 51, .55); backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  padding: 24px; animation: fadeUp .3s var(--ease-out);
}
.pr-login-overlay[hidden] { display: none; }

/* Card */
.pr-login-modal {
  background: var(--c-cream);
  border-radius: 22px;
  border: 1px solid var(--c-border-soft);
  box-shadow: 0 30px 80px rgba(0, 0, 0, .30);
  width: 100%; max-width: 440px;
  position: relative;
  animation: scaleIn .28s var(--ease-out);
}

/* Gumb zatvaranja */
.pr-login-close {
  position: absolute; top: 16px; right: 16px;
  background: transparent; border: 1px solid var(--c-border-soft);
  width: 34px; height: 34px; border-radius: 50%; cursor: pointer;
  font-size: 18px; line-height: 1; color: var(--c-text-muted);
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s; z-index: 1;
}
.pr-login-close:hover { background: var(--c-surface); color: var(--c-text); }

/* Body (svaki view) */
.pr-login-body {
  padding: 34px 32px 30px;
  display: flex; flex-direction: column; align-items: center;
  text-align: center; gap: 0;
}
.pr-login-body[hidden] { display: none; }

/* Ikona krug */
.pr-login-icon {
  width: 54px; height: 54px; border-radius: 50%;
  background: linear-gradient(135deg, var(--c-gold), #b8851f);
  border: none;
  display: flex; align-items: center; justify-content: center;
  font-size: 24px; color: #fff; margin-bottom: 16px;
  box-shadow: 0 6px 20px rgba(200,147,42,.33);
}

/* Eyebrow */
.pr-login-eyebrow {
  font-size: 11px; font-weight: 700; color: var(--c-gold);
  letter-spacing: .22em; text-transform: uppercase; margin-bottom: 6px;
}

/* Naslov */
.pr-login-title {
  font-family: var(--font-serif); font-size: 26px; font-weight: 500;
  color: var(--c-teal-dark); letter-spacing: -.02em; line-height: 1.15;
  margin: 0 0 10px;
}

/* Podnaslov */
.pr-login-sub {
  font-size: 14px; color: var(--c-text-muted); line-height: 1.55;
  margin: 0 0 18px; max-width: 300px;
}

/* Socijalni gumbi (Nextend) */
.pr-login-social {
  width: 100%; display: flex; flex-direction: column; gap: 10px; margin-bottom: 6px;
}

/* Nextend social gumbi — 1:1 s prototipom */
.pr-login-social .nsl-button {
  width: 100% !important;
  border-radius: 12px !important;
  min-height: 46px !important;
  padding: 12px 18px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  font-family: var(--font-sans) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  box-shadow: none !important;
  transition: border-color .15s, background .15s !important;
  margin: 0 !important;
}
/* Google — bijeli s borderom */
.pr-login-social .nsl-button-google,
.pr-login-social .nsl-button-default.nsl-button-google {
  background: #fff !important;
  color: var(--c-text) !important;
  border: 1.5px solid var(--c-border-soft) !important;
}
.pr-login-social .nsl-button-google:hover {
  border-color: var(--c-gold) !important;
  background: rgba(200,147,42,.03) !important;
}
/* Apple — crni */
.pr-login-social .nsl-button-apple {
  background: #111 !important;
  color: #fff !important;
  border: 1.5px solid #111 !important;
}
.pr-login-social .nsl-button-apple:hover { background: #222 !important; }

/* Nextend ikona wrapper — bez pozadine/boxa */
.pr-login-social .nsl-button .nsl-button-svg-container {
  margin: 0 8px 0 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
}

/* Apple gumb skriven po defaultu; JS dodaje .pr-is-apple na body za Apple uređaje */
.pr-login-social .nsl-button-apple,
.pr-login-apple-wrap { display: none !important; }
body.pr-is-apple .pr-login-social .nsl-button-apple,
body.pr-is-apple .pr-login-apple-wrap { display: flex !important; }

/* OR razdjelnik */
.pr-login-or {
  width: 100%; display: flex; align-items: center; gap: 12px;
  margin: 16px 0;
}
.pr-login-or::before,
.pr-login-or::after {
  content: ''; flex: 1; height: 1px; background: var(--c-border-soft);
}
.pr-login-or span {
  font-size: 11px; font-weight: 700; color: var(--c-text-faint);
  letter-spacing: .14em; text-transform: uppercase; flex-shrink: 0;
}

/* Magic link gumb */
.pr-login-magic-btn {
  width: 100%; padding: 13px 20px;
  background: var(--g-teal-btn); color: #fff;
  border: none; border-radius: 12px; cursor: pointer;
  font-size: 14px; font-weight: 700; font-family: var(--font-sans);
  display: flex; align-items: center; justify-content: center; gap: 8px;
  transition: opacity .15s, box-shadow .15s;
  box-shadow: 0 4px 14px rgba(31, 82, 86, .30);
}
.pr-login-magic-btn:hover { opacity: .9; box-shadow: 0 6px 20px rgba(31, 82, 86, .38); }
.pr-login-magic-btn span[aria-hidden] { color: var(--c-gold-light); }

/* Footer */
.pr-login-foot {
  margin-top: 20px; font-size: 12px; color: var(--c-text-muted);
}
.pr-login-activate {
  color: var(--c-gold); font-weight: 700; font-size: 12px;
  text-decoration: underline; text-underline-offset: 2px;
  transition: opacity .15s;
}
.pr-login-activate:hover { opacity: .8; }

/* ─── View e-mail ─── */

/* Input */
.pr-login-input {
  width: 100%; padding: 12px 16px;
  border: 1.5px solid var(--c-border); border-radius: 10px;
  background: var(--c-surface); font-size: 15px; font-family: var(--font-sans);
  color: var(--c-text); outline: none;
  transition: border-color .15s, box-shadow .15s;
  margin-bottom: 10px; box-sizing: border-box;
}
.pr-login-input:focus {
  border-color: var(--c-teal); box-shadow: 0 0 0 3px rgba(45, 109, 114, .12);
}

/* Greška */
.pr-login-error {
  width: 100%; font-size: 13px; color: #c0392b;
  background: #fdf0ed; border: 1px solid #f5c6c0;
  border-radius: 8px; padding: 8px 12px; text-align: left;
  margin-bottom: 10px; box-sizing: border-box;
}
.pr-login-error[hidden] { display: none; }

/* Pošalji gumb */
.pr-login-send-btn {
  width: 100%; padding: 13px 20px;
  background: var(--g-gold-btn); color: #fff;
  border: none; border-radius: 10px; cursor: pointer;
  font-size: 14px; font-weight: 600; font-family: var(--font-sans);
  transition: opacity .15s, box-shadow .15s;
  box-shadow: var(--shadow-gold); margin-bottom: 10px;
}
.pr-login-send-btn:hover { opacity: .9; box-shadow: 0 8px 24px rgba(200,147,42,.42); }

/* Natrag */
.pr-login-back {
  background: transparent; border: none; cursor: pointer;
  font-size: 13px; color: var(--c-text-muted); font-family: var(--font-sans);
  padding: 6px 0; transition: color .15s;
}
.pr-login-back:hover { color: var(--c-teal); }

/* ─── View sent ─── */
.pr-login-close-btn {
  margin-top: 8px; padding: 12px 32px;
  background: var(--g-teal-btn); color: #fff;
  border: none; border-radius: 10px; cursor: pointer;
  font-size: 14px; font-weight: 600; font-family: var(--font-sans);
  transition: opacity .15s;
}
.pr-login-close-btn:hover { opacity: .9; }

/* ─── Mobile ─── */
@media (max-width: 480px) {
  .pr-login-modal { border-radius: 16px; }
  .pr-login-body { padding: 36px 24px 28px; }
}
