/* ===================== Login – Liquid Glass (scoped body.login-page) ===================== */

/* ── Background pagina ── */
body.login-page {
  margin: 0;
  background:
    radial-gradient(1100px 560px at 10% 0%, rgba(56,122,210,0.34), transparent 68%),
    radial-gradient(940px 480px at 94% 10%, rgba(39,165,216,0.24), transparent 70%),
    linear-gradient(180deg, #0a101c 0%, #08111c 46%, #070b12 100%);
  min-height: 100vh;
  color: #eef4ff;
}

/* ── Sezione centrata verticalmente ── */
body.login-page .auth-apple {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: calc(100vh - 62px);
  padding: 24px 16px;
  background: transparent;
}

body.login-page .auth-wrap {
  width: 100%;
  max-width: 480px;
  padding: 6px;
  animation: authFadeUp .45s cubic-bezier(.22,1,.36,1) both;
}

/* ── Card stile identico alla registrazione ── */
body.login-page .auth-card {
  position: relative;
  overflow: hidden;
  border-radius: 30px;
  border: 1px solid rgba(171,220,255,0.24);
  background: linear-gradient(165deg, rgba(13,22,37,0.92), rgba(8,17,30,0.86));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.18),
    inset 0 -1px 0 rgba(0,0,0,0.20),
    0 28px 72px rgba(0,0,0,0.50),
    0 8px 26px rgba(0,60,180,0.16);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  padding: clamp(32px, 4vw, 46px) clamp(28px, 3.5vw, 42px);
  color: #f0f4ff;
}

/* riflesso superiore */
body.login-page .auth-card::before {
  content: "";
  position: absolute;
  inset: -40% 18% auto -18%;
  height: 70%;
  background: radial-gradient(circle at center, rgba(255,255,255,0.18), transparent 62%);
  pointer-events: none;
}

/* ── Titolo gradiente ── */
body.login-page .auth-title {
  position: relative;
  z-index: 1;
  margin: 0 0 26px 0;
  text-align: center;
  font-size: clamp(2rem, 3.8vw, 2.8rem);
  font-weight: 800;
  letter-spacing: -0.025em;
  background: linear-gradient(155deg, #ffffff 30%, #a8c8ff 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── Form ── */
body.login-page .login-form {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

body.login-page .login-form label {
  font-size: clamp(0.86rem, 0.22vw + 0.82rem, 0.94rem);
  color: #c2ccdf;
  font-weight: 500;
  letter-spacing: 0.01em;
}

/* override specifico: sovrascrive styles.css width:80% e border:#ccc */
body.login-page .login-form input[type="email"],
body.login-page .login-form input[type="password"] {
  width: 100%;
  box-sizing: border-box;
  padding: clamp(12px, 0.8vw, 15px) clamp(16px, 1.2vw, 20px);
  font-size: clamp(0.96rem, 0.24vw + 0.9rem, 1.02rem);
  border: 1px solid rgba(171,219,255,0.30);
  border-radius: 50px;
  background: rgba(255,255,255,0.07);
  color: #f4f8ff;
  outline: none;
  transition: border .2s ease, background .2s ease, box-shadow .2s ease;
}
body.login-page .login-form input::placeholder { color: #6a7788; }
body.login-page .login-form input:focus {
  border-color: rgba(132,201,255,0.72);
  background: rgba(255,255,255,0.11);
  box-shadow:
    0 0 0 3px rgba(87,171,255,0.24),
    inset 0 1px 0 rgba(255,255,255,0.10);
}

/* ── CTA ── */
body.login-page .login-form .apple-button.btn-filled {
  margin-top: 10px;
  width: 100%;
  padding: clamp(14px, 1.1vw, 16px) 28px;
  min-height: 50px;
  font-size: clamp(1rem, 0.24vw + 0.94rem, 1.06rem);
  font-weight: 700;
  letter-spacing: 0.012em;
  border-radius: 50px;
  border: 1px solid rgba(188,224,255,0.40);
  background: linear-gradient(140deg, #1a8cff, #0d67d8);
  color: #fff;
  box-shadow: 0 12px 30px rgba(9,101,206,0.44), inset 0 1px 0 rgba(255,255,255,0.18);
  cursor: pointer;
  transition: transform .14s ease, box-shadow .22s ease, background .2s ease;
}
body.login-page .login-form .apple-button.btn-filled:hover {
  transform: translateY(-2px);
  background: linear-gradient(140deg, #2d98ff, #1174ea);
  box-shadow: 0 16px 40px rgba(9,101,206,0.54), inset 0 1px 0 rgba(255,255,255,0.22);
}
body.login-page .login-form .apple-button.btn-filled:active {
  transform: translateY(0);
  box-shadow: 0 6px 18px rgba(9,101,206,0.30);
}

/* ── Link sotto ── */
body.login-page .auth-meta {
  position: relative;
  z-index: 1;
  margin: 20px 0 4px;
  text-align: center;
  font-size: 0.93rem;
  color: #9aacc0;
}
body.login-page .auth-meta a {
  color: #7fc4ff;
  text-decoration: none;
  font-weight: 600;
  transition: color .15s ease, text-shadow .15s ease;
}
body.login-page .auth-meta a:hover {
  color: #fff;
  text-shadow: 0 0 14px rgba(90,190,255,0.42);
}

/* ── Animazione entrata ── */
@keyframes authFadeUp {
  from { opacity: 0; transform: translateY(16px) scale(0.985); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* ── Responsive ── */
@media (max-width: 430px) {
  body.login-page .auth-card {
    border-radius: 22px;
    padding: 26px 18px;
  }
  body.login-page .auth-title { font-size: 1.75rem; }
}

@media (prefers-reduced-motion: reduce) {
  body.login-page .auth-wrap { animation: none; }
  body.login-page .login-form .apple-button.btn-filled:hover,
  body.login-page .login-form .apple-button.btn-filled:active { transform: none; }
}

/* Modal account bloccato + form riattivazione */
.blocked-modal { position: fixed; inset: 0; z-index: 9999; display: flex; align-items: center; justify-content: center; }
.blocked-modal[hidden] { display: none; }
.blocked-modal-backdrop { position: absolute; inset: 0; background: rgba(3,8,16,0.85); backdrop-filter: blur(6px); }
.blocked-modal-panel {
  position: relative; z-index: 1;
  width: min(520px, calc(100vw - 32px));
  max-height: calc(100vh - 64px); overflow: auto;
  background: #0f172a; color: #e5e7eb;
  border: 1px solid rgba(148,163,184,0.25);
  border-radius: 18px; padding: 24px 26px;
  box-shadow: 0 24px 60px rgba(0,0,0,0.45);
}
.blocked-modal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.blocked-modal-head h2 { margin: 0; font-size: 1.15rem; color: #fca5a5; }
.blocked-modal-close { background: none; border: 0; color: #94a3b8; font-size: 1.6rem; line-height: 1; cursor: pointer; padding: 0 4px; }
.blocked-modal-close:hover { color: #e5e7eb; }
.blocked-modal-msg { font-size: 14px; line-height: 1.55; color: #cbd5e1; margin: 6px 0 16px; }
.blocked-modal-form label { display: block; font-size: 12px; font-weight: 600; color: #cbd5e1; margin: 10px 0 4px; }
.blocked-modal-form input[type=email],
.blocked-modal-form textarea {
  width: 100%;
  background: rgba(15,23,42,0.6);
  color: #e5e7eb;
  border: 1px solid rgba(148,163,184,0.25);
  border-radius: 10px;
  padding: 10px 12px;
  font-size: 14px;
  font-family: inherit;
  box-sizing: border-box;
}
.blocked-modal-form textarea { resize: vertical; }
.blocked-modal-actions { display: flex; gap: 10px; justify-content: stretch; margin-top: 14px; flex-wrap: wrap; }
.blocked-modal-actions button { flex: 1; min-width: 120px; }
.blocked-modal-status { margin: 10px 0 0; font-size: 13px; min-height: 1.2em; }
.blocked-modal-status.ok { color: #86efac; }
.blocked-modal-status.err { color: #fca5a5; }

/* Success view dopo invio richiesta riattivazione */
.blocked-modal-success { text-align: center; padding: 8px 4px 4px; }
.blocked-modal-success-icon { font-size: 42px; line-height: 1; margin-bottom: 10px; }
.blocked-modal-success-title { margin: 0 0 8px; font-size: 1.1rem; color: #86efac; }
.blocked-modal-success-msg { font-size: 14px; line-height: 1.55; color: #cbd5e1; margin: 0 0 14px; }
