/* ════════════════════════════════════════════════════════
   RODZINNY SEJF — NOWY EKRAN LOGOWANIA (HYBRID)
   Zamek mechaniczny + Holo HUD + Particles + Liquid + Quantum
   ════════════════════════════════════════════════════════ */

/* OVERRIDE — ukryj stare elementy w #loginScreen */
#loginScreen.ms-mode .ls-bg,
#loginScreen.ms-mode .ls-orb,
#loginScreen.ms-mode .ls-aurora,
#loginScreen.ms-mode .ls-halo,
#loginScreen.ms-mode .ls-grid,
#loginScreen.ms-mode .l-orbit,
#loginScreen.ms-mode #loginCanvas,
#loginScreen.ms-mode .lc-glow,
#loginScreen.ms-mode .lshine,
#loginScreen.ms-mode .lambient,
#loginScreen.ms-mode::before,
#loginScreen.ms-mode::after { display:none !important; }

/* === ROOT === */
#loginScreen.ms-mode {
  background:
    radial-gradient(ellipse at 50% 100%, rgba(34,211,238,0.14), transparent 55%),
    radial-gradient(ellipse at 30% 20%, rgba(99,102,241,0.18), transparent 50%),
    radial-gradient(ellipse at 70% 30%, rgba(167,139,250,0.12), transparent 50%),
    linear-gradient(180deg, #050714 0%, #07091a 50%, #04050f 100%) !important;
  overflow:hidden;
  font-family:'Plus Jakarta Sans', sans-serif;
}

/* === BACKGROUND LAYERS === */
.ms-canvas {
  position:absolute; inset:0;
  width:100%; height:100%;
  z-index:0;
  pointer-events:none;
}

.ms-floor {
  position:absolute; inset:0;
  perspective:600px;
  pointer-events:none;
  overflow:hidden;
  z-index:0;
  opacity:0.6;
}
.ms-floor-grid {
  position:absolute;
  bottom:-40%; left:-50%;
  width:200%; height:90%;
  background-image:
    linear-gradient(rgba(34,211,238,0.16) 1px, transparent 1px),
    linear-gradient(90deg, rgba(34,211,238,0.16) 1px, transparent 1px);
  background-size:54px 54px;
  transform: rotateX(70deg);
  transform-origin: center top;
  animation: msGridMove 8s linear infinite;
  mask-image: linear-gradient(to bottom, transparent, #000 30%, transparent 100%);
  -webkit-mask-image: linear-gradient(to bottom, transparent, #000 30%, transparent 100%);
}
@keyframes msGridMove {
  from { background-position: 0 0; }
  to { background-position: 0 54px; }
}

.ms-scanlines {
  position:absolute; inset:0;
  background: repeating-linear-gradient(
    0deg,
    transparent 0,
    transparent 3px,
    rgba(34,211,238,0.04) 3px,
    rgba(34,211,238,0.04) 4px
  );
  pointer-events:none;
  z-index:1;
  mix-blend-mode: screen;
}
.ms-scanlines::after {
  content:''; position:absolute; left:0; right:0; height:80px; top:-80px;
  background: linear-gradient(180deg, transparent, rgba(34,211,238,0.12), transparent);
  animation: msScanSweep 6s linear infinite;
}
@keyframes msScanSweep {
  from { top:-80px; }
  to { top:100%; }
}

/* Glowing orbs */
.ms-orb {
  position:absolute;
  border-radius:50%;
  filter: blur(70px);
  pointer-events:none;
  z-index:0;
  animation: msOrbFloat 14s ease-in-out infinite;
}
.ms-orb-1 {
  width:480px; height:480px;
  top:-160px; left:-120px;
  background: radial-gradient(circle, rgba(34,211,238,0.35), transparent 65%);
  animation-duration: 16s;
}
.ms-orb-2 {
  width:420px; height:420px;
  bottom:-120px; right:-80px;
  background: radial-gradient(circle, rgba(167,139,250,0.32), transparent 65%);
  animation-duration: 19s;
  animation-delay:-3s;
}
.ms-orb-3 {
  width:340px; height:340px;
  top:50%; left:50%;
  transform:translate(-50%,-50%);
  background: radial-gradient(circle, rgba(99,102,241,0.22), transparent 65%);
  animation: msOrbFloat3 11s ease-in-out infinite;
}
@keyframes msOrbFloat {
  0%,100% { transform:translate(0,0) scale(1); }
  50% { transform:translate(40px,-50px) scale(1.1); }
}
@keyframes msOrbFloat3 {
  0%,100% { transform:translate(-50%,-50%) scale(1); }
  50% { transform:translate(-50%,-52%) scale(1.12); }
}

/* === HUD CORNERS === */
.ms-hud {
  position:fixed;
  inset:24px;
  pointer-events:none;
  z-index:5;
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.16em;
}
.ms-hud > div {
  position:absolute;
  border:1px solid rgba(34,211,238,0.28);
  background:rgba(7,11,26,0.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  padding:9px 13px;
  min-width:130px;
  border-radius:14px;
  color:#7dd3fc;
  animation: msHudIn 0.8s cubic-bezier(0.2,0.7,0.1,1) backwards;
}
.ms-hud-tl { top:0; left:0; animation-delay:0.1s; }
.ms-hud-tr { top:0; right:0; text-align:right; animation-delay:0.2s; }
.ms-hud-bl { bottom:0; left:0; animation-delay:0.3s; }
.ms-hud-br { bottom:0; right:0; text-align:right; animation-delay:0.4s; }
@keyframes msHudIn {
  from { opacity:0; transform:translateY(-8px); }
  to { opacity:1; transform:translateY(0); }
}
.ms-hud-label { color:#475569; font-size:8px; }
.ms-hud-val { color:#67e8f9; font-size:11px; font-weight:700; margin-top:3px; }
.ms-hud-mono { font-family:'JetBrains Mono', monospace; }
.ms-hud-unit { font-size:9px; color:#7dd3fc; margin-left:2px; }
.ms-hud-ok { color:#34d399 !important; }
.ms-hud-bar {
  height:3px; background:rgba(34,211,238,0.12);
  margin-top:6px; overflow:hidden;
  border-radius:2px;
}
.ms-hud-bar > span {
  display:block; height:100%; width:78%;
  background: linear-gradient(90deg, #34d399, #67e8f9);
  animation: msBarPulse 3s ease-in-out infinite;
  border-radius:2px;
}
@keyframes msBarPulse {
  0%,100% { opacity:1; transform:translateX(0); }
  50% { opacity:0.7; transform:translateX(2px); }
}
.ms-hud-graph {
  display:flex; gap:2px; align-items:flex-end;
  height:22px; margin-top:5px;
  justify-content:flex-end;
}
.ms-hud-graph span {
  width:3px;
  background: linear-gradient(180deg, #67e8f9, #3b82f6);
  animation: msGraph 1.6s ease-in-out infinite;
  border-radius:1.5px;
}
.ms-hud-graph span:nth-child(odd) { animation-delay:0.2s; }
.ms-hud-graph span:nth-child(3n) { animation-delay:0.4s; }
@keyframes msGraph {
  0%,100% { opacity:0.6; transform:scaleY(0.7); }
  50% { opacity:1; transform:scaleY(1); }
}
.ms-hud-blink {
  display:inline-block;
  width:6px; height:6px; border-radius:50%;
  background:#34d399;
  box-shadow:0 0 8px #34d399;
  margin-right:6px;
  animation: msBlink 1.6s ease-in-out infinite;
}
@keyframes msBlink {
  0%,100% { opacity:1; transform:scale(1); }
  50% { opacity:0.4; transform:scale(0.85); }
}

/* Hide HUD on small screens */
@media (max-width:720px) {
  .ms-hud { display:none; }
}

/* === MAIN CARD WRAPPER === */
.ms-card {
  position:relative;
  z-index:3;
  width:min(460px, calc(100vw - 32px));
  background: linear-gradient(180deg, rgba(15,18,32,0.9), rgba(8,10,22,0.96));
  border:1px solid rgba(255,255,255,0.1);
  border-radius:28px;
  padding:30px 32px 24px;
  backdrop-filter: blur(24px) saturate(160%);
  -webkit-backdrop-filter: blur(24px) saturate(160%);
  box-shadow:
    0 40px 100px rgba(0,0,0,0.7),
    0 0 0 1px rgba(99,102,241,0.06),
    0 0 80px rgba(34,211,238,0.1),
    inset 0 1px 0 rgba(255,255,255,0.08);
  animation: msCardEnter 0.8s cubic-bezier(0.2,0.7,0.1,1);
  transition: border-color 0.4s, box-shadow 0.4s;
}
.ms-card.ms-success {
  border-color: rgba(52,211,153,0.4);
  box-shadow:
    0 40px 100px rgba(0,0,0,0.7),
    0 0 80px rgba(52,211,153,0.25);
}
.ms-card.ms-shake { animation: msShake 0.5s; }
@keyframes msCardEnter {
  from { opacity:0; transform:translateY(28px) scale(0.96); filter:blur(8px); }
  to { opacity:1; transform:translateY(0) scale(1); filter:blur(0); }
}
@keyframes msShake {
  0%,100% { transform:translateX(0); }
  20% { transform:translateX(-6px); }
  40% { transform:translateX(6px); }
  60% { transform:translateX(-4px); }
  80% { transform:translateX(4px); }
}

/* Animated gradient border (conic) */
.ms-card::before {
  content:'';
  position:absolute; inset:-2px;
  border-radius:30px;
  background: conic-gradient(
    from var(--ms-angle, 0deg),
    transparent 0deg,
    rgba(34,211,238,0.6) 80deg,
    rgba(99,102,241,0.6) 160deg,
    rgba(167,139,250,0.6) 220deg,
    transparent 320deg
  );
  z-index:-1;
  filter: blur(8px);
  opacity:0.55;
  animation: msRotateBorder 6s linear infinite;
}
@property --ms-angle { syntax:'<angle>'; initial-value:0deg; inherits:false; }
@keyframes msRotateBorder { to { --ms-angle: 360deg; } }

/* Edge highlights */
.ms-edge {
  position:absolute;
  background: linear-gradient(90deg, transparent, #22d3ee, transparent);
  pointer-events:none;
  border-radius:2px;
}
.ms-edge-t {
  top:-1px; left:20%; right:20%;
  height:1px;
  box-shadow: 0 0 12px #22d3ee;
}

/* === STEP TRACK === */
.ms-step-track {
  display:flex; align-items:center; gap:8px;
  margin-bottom:18px;
  font-family:'JetBrains Mono', monospace;
  font-size:9px; letter-spacing:0.18em;
}
.ms-step {
  display:flex; align-items:center; gap:6px;
  color:#475569;
  transition: color 0.4s;
}
.ms-step.active { color:#67e8f9; }
.ms-step.done { color:#34d399; }
.ms-step-num {
  font-weight:700;
  background:rgba(255,255,255,0.04);
  padding:3px 7px;
  border:1px solid rgba(255,255,255,0.08);
  border-radius:6px;
  transition: all 0.3s;
}
.ms-step.active .ms-step-num {
  background:rgba(34,211,238,0.12);
  border-color:rgba(34,211,238,0.45);
  box-shadow: 0 0 10px rgba(34,211,238,0.25);
}
.ms-step.done .ms-step-num {
  background:rgba(52,211,153,0.12);
  border-color:rgba(52,211,153,0.45);
}
.ms-step-line {
  flex:1; height:1px; background:rgba(255,255,255,0.08);
  position:relative; overflow:hidden;
}
.ms-step-line-fill {
  display:block; height:100%; width:0%;
  background: linear-gradient(90deg, #34d399, #67e8f9);
  transition: width 0.7s cubic-bezier(0.2,0.7,0.1,1);
  box-shadow: 0 0 8px rgba(103,232,249,0.5);
}
.ms-step.done ~ .ms-step-line .ms-step-line-fill,
.ms-step-line.fill .ms-step-line-fill { width:100%; }

/* === VAULT MECHANISM === */
.ms-vault {
  display:flex; flex-direction:column; align-items:center;
  margin: 4px 0 18px;
}
.ms-vm { position:relative; }
.ms-vm-svg { width:130px; height:130px; }

.ms-vm-ring-1 { transform-origin:110px 110px; animation: msVmSpin1 60s linear infinite; }
.ms-vm-ring-2 { transform-origin:110px 110px; animation: msVmSpin2 40s linear infinite reverse; }
.ms-vm-ring-3 { transform-origin:110px 110px; animation: msVmSpin3 80s linear infinite; }
@keyframes msVmSpin1 { to { transform: rotate(360deg); } }
@keyframes msVmSpin2 { to { transform: rotate(-360deg); } }
@keyframes msVmSpin3 { to { transform: rotate(360deg); } }

.ms-vm.spinning .ms-vm-ring-1 { animation-duration: 2s; }
.ms-vm.spinning .ms-vm-ring-2 { animation-duration: 1.4s; }
.ms-vm.spinning .ms-vm-ring-3 { animation-duration: 3s; }

.ms-vm-pulse {
  transform-origin:110px 110px;
  animation: msVmPulse 2s ease-in-out infinite;
}
@keyframes msVmPulse {
  0%,100% { transform:scale(1); opacity:1; }
  50% { transform:scale(1.6); opacity:0.4; }
}

.ms-vm-sweep { transform-origin:110px 110px; opacity:0; }
.ms-vm.spinning .ms-vm-sweep {
  opacity:1;
  animation: msVmSweep 1.2s linear infinite;
}
@keyframes msVmSweep {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.ms-vm-shackle {
  transition: transform 0.5s cubic-bezier(0.2,0.7,0.1,1), stroke 0.3s;
  transform-origin: 102px 106px;
}
.ms-vm.open .ms-vm-shackle {
  transform: rotate(-30deg) translateX(-2px);
  stroke:#34d399;
}
.ms-vm.open .ms-vm-lock-icon rect,
.ms-vm.open .ms-vm-lock-icon circle {
  stroke:#34d399;
  transition: stroke 0.3s;
}
.ms-vm.open .ms-vm-core-circle {
  stroke:#34d399;
  transition: stroke 0.5s;
}

.ms-vm-indicator {
  transform-origin:110px 110px;
  animation: msVmInd 1.6s ease-in-out infinite;
  opacity:0.4;
}
.ms-vm-ind-0 { animation-delay:0s; }
.ms-vm-ind-1 { animation-delay:0.4s; }
.ms-vm-ind-2 { animation-delay:0.8s; }
.ms-vm-ind-3 { animation-delay:1.2s; }
@keyframes msVmInd {
  0%,100% { opacity:0.3; r:2; }
  50% { opacity:1; r:4; }
}

/* === BRAND === */
.ms-brand {
  text-align:center;
  margin-bottom:6px;
}
.ms-brand-eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  font-family:'JetBrains Mono', monospace;
  font-size:10px; letter-spacing:0.22em;
  color:#7dd3fc;
  margin-bottom:10px;
}
.ms-brand-pip {
  width:6px; height:6px; border-radius:50%;
  background: linear-gradient(135deg, #22d3ee, #a78bfa);
  box-shadow: 0 0 12px #67e8f9;
  animation: msBlink 2s ease-in-out infinite;
}
.ms-brand-name {
  font-family:'Plus Jakarta Sans', sans-serif;
  font-size:36px;
  font-weight:800;
  letter-spacing:0.04em;
  line-height:1;
  background: linear-gradient(135deg, #fff 0%, #bae6fd 30%, #c4b5fd 65%, #67e8f9 100%);
  background-size: 200% 200%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: msBrandShine 6s ease-in-out infinite;
  text-shadow: 0 0 40px rgba(125,211,252,0.3);
}
@keyframes msBrandShine {
  0%,100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}
.ms-brand-sub {
  margin-top:8px;
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.18em;
  color:#64748b;
}
.ms-brand-mark {
  color:#22d3ee;
  font-size:11px;
  margin: 0 8px;
}

/* === FORM === */
.ms-form {
  display:flex; flex-direction:column;
  gap:14px;
  margin-top:22px;
}

.ms-field {
  display:flex; flex-direction:column;
  gap:6px;
}
.ms-field-label {
  font-family:'JetBrains Mono', monospace;
  font-size:9px;
  font-weight:700;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:#64748b;
  transition: color 0.2s;
  display:flex; align-items:center; gap:6px;
}
.ms-field.focused .ms-field-label { color:#a78bfa; }
.ms-field.valid .ms-field-label { color:#34d399; }

.ms-field-box {
  position:relative;
  display:flex; align-items:center;
  gap:10px;
  padding:14px 16px;
  background: rgba(8,12,24,0.7);
  border:1.5px solid rgba(255,255,255,0.08);
  border-radius:16px;
  transition: all 0.3s cubic-bezier(0.2,0.7,0.1,1);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.03);
}
.ms-field.focused .ms-field-box {
  border-color: rgba(167,139,250,0.6);
  background: rgba(167,139,250,0.06);
  box-shadow:
    0 0 0 4px rgba(167,139,250,0.12),
    0 0 24px rgba(167,139,250,0.18),
    inset 0 1px 0 rgba(255,255,255,0.05);
  transform: translateY(-1px);
}
.ms-field.valid .ms-field-box { border-color: rgba(52,211,153,0.4); }
.ms-field.valid.focused .ms-field-box {
  border-color: rgba(52,211,153,0.7);
  box-shadow:
    0 0 0 4px rgba(52,211,153,0.12),
    0 0 24px rgba(52,211,153,0.18);
}

.ms-field-icon {
  color:#64748b;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
  transition: color 0.2s;
}
.ms-field.focused .ms-field-icon { color:#a78bfa; }
.ms-field.valid .ms-field-icon { color:#34d399; }

.ms-input {
  flex:1;
  background:transparent !important;
  border:none !important;
  outline:none !important;
  color:#f1f5f9 !important;
  font-size:14px !important;
  font-family:'JetBrains Mono', monospace !important;
  padding:0 !important;
  margin:0 !important;
  letter-spacing:0.02em;
  width:100%;
  box-shadow: none !important;
}
.ms-input::placeholder { color:#475569; }

.ms-field-trail {
  display:flex; align-items:center; gap:8px;
  color:#64748b;
  flex-shrink:0;
}
.ms-field-check {
  color:#34d399;
  display:flex; align-items:center;
  animation: msCheckPop 0.3s cubic-bezier(0.2,0.7,0.1,1);
}
@keyframes msCheckPop {
  0% { transform:scale(0); opacity:0; }
  60% { transform:scale(1.3); }
  100% { transform:scale(1); opacity:1; }
}
.ms-eye-btn {
  background:transparent;
  border:none; cursor:pointer;
  color:#64748b;
  padding:2px;
  display:flex; align-items:center; justify-content:center;
  transition: color 0.2s;
  border-radius:6px;
}
.ms-eye-btn:hover { color:#a78bfa; }

/* Strength */
.ms-strength {
  display:flex; align-items:center; gap:10px;
  padding-top:2px;
  animation: msSlideIn 0.3s ease-out;
}
@keyframes msSlideIn { from { opacity:0; transform:translateY(-3px); } to { opacity:1; transform:translateY(0); } }
.ms-strength-track {
  display:flex; gap:4px; flex:1;
}
.ms-strength-pip {
  flex:1; height:3px;
  background:rgba(255,255,255,0.06);
  border-radius:1.5px;
  transition: all 0.4s cubic-bezier(0.2,0.7,0.1,1);
}
.ms-strength-pip.active.s-0 { background:#f87171; box-shadow:0 0 8px rgba(248,113,113,0.4); }
.ms-strength-pip.active.s-1 { background:#fbbf24; box-shadow:0 0 8px rgba(251,191,36,0.4); }
.ms-strength-pip.active.s-2 { background:#a3e635; box-shadow:0 0 8px rgba(163,230,53,0.4); }
.ms-strength-pip.active.s-3 { background:#34d399; box-shadow:0 0 10px rgba(52,211,153,0.6); }
.ms-strength-label {
  font-family:'JetBrains Mono', monospace;
  font-size:9px; font-weight:700;
  letter-spacing:0.16em;
  min-width:50px; text-align:right;
}
.ms-strength-label.s-0 { color:#f87171; }
.ms-strength-label.s-1 { color:#fbbf24; }
.ms-strength-label.s-2 { color:#a3e635; }
.ms-strength-label.s-3 { color:#34d399; }

.ms-caps {
  font-size:10px;
  color:#fbbf24;
  font-family:'JetBrains Mono', monospace;
  letter-spacing:0.1em;
  display:flex; align-items:center; gap:6px;
  animation: msSlideIn 0.3s ease-out;
}

/* Row: remember me / forgot */
.ms-row {
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-top:2px;
}
.ms-check {
  display:flex; align-items:center; gap:8px;
  cursor:pointer;
  font-size:12px; color:#94a3b8;
  font-weight:500;
}
.ms-check input { display:none; }
.ms-check-box {
  width:16px; height:16px;
  border-radius:6px;
  border:1.5px solid rgba(255,255,255,0.15);
  background:rgba(8,12,24,0.7);
  display:flex; align-items:center; justify-content:center;
  transition: all 0.2s;
  flex-shrink:0;
}
.ms-check-box span {
  width:8px; height:8px; border-radius:3px;
  background: linear-gradient(135deg, #a78bfa, #67e8f9);
  transform:scale(0);
  transition: transform 0.2s cubic-bezier(0.2,0.7,0.1,1);
}
.ms-check input:checked + .ms-check-box {
  border-color:rgba(167,139,250,0.6);
  background:rgba(167,139,250,0.1);
  box-shadow: 0 0 12px rgba(167,139,250,0.2);
}
.ms-check input:checked + .ms-check-box span { transform:scale(1); }
.ms-check:hover { color:#cbd5e1; }
.ms-forgot {
  font-size:12px;
  color:#7dd3fc;
  text-decoration:none;
  font-weight:500;
  cursor:pointer;
  transition: color 0.2s;
  background:none; border:none; padding:0;
  font-family:inherit;
}
.ms-forgot:hover { color:#a78bfa; text-decoration:underline; }

/* === BUTTON === */
.ms-btn {
  position:relative;
  overflow:hidden;
  margin-top:8px;
  padding:16px 22px;
  background: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #06b6d4 100%);
  background-size: 200% 200%;
  border:none;
  border-radius:18px;
  color:#fff;
  font-family:'Plus Jakarta Sans', sans-serif;
  font-size:14px;
  font-weight:700;
  letter-spacing:0.04em;
  cursor:pointer;
  transition: transform 0.25s, box-shadow 0.25s;
  animation: msBtnGrad 6s ease-in-out infinite;
  box-shadow:
    0 12px 32px rgba(99,102,241,0.4),
    0 0 0 1px rgba(255,255,255,0.06) inset;
  width:100%;
}
@keyframes msBtnGrad {
  0%,100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}
.ms-btn::before {
  content:'';
  position:absolute; inset:0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
  transform: translateX(-100%);
  animation: msBtnShine 3s ease-in-out infinite;
}
@keyframes msBtnShine {
  0% { transform: translateX(-100%); }
  60%,100% { transform: translateX(140%); }
}
.ms-btn-content {
  position:relative; z-index:1;
  display:flex; align-items:center; justify-content:center; gap:10px;
}
.ms-btn-arrow { transition: transform 0.25s; display:inline-block; }
.ms-btn:not(:disabled):hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 44px rgba(99,102,241,0.55);
}
.ms-btn:not(:disabled):hover .ms-btn-arrow { transform: translateX(5px); }
.ms-btn:not(:disabled):active { transform: translateY(-1px); }
.ms-btn:disabled {
  opacity:0.55;
  cursor:not-allowed;
  transform:none;
}
.ms-btn.loading {
  background: linear-gradient(135deg, #6366f1, #8b5cf6);
  animation: msBtnPulse 1.4s ease-in-out infinite;
}
@keyframes msBtnPulse {
  0%,100% { box-shadow: 0 12px 32px rgba(99,102,241,0.4); }
  50% { box-shadow: 0 16px 48px rgba(99,102,241,0.7), 0 0 60px rgba(167,139,250,0.4); }
}
.ms-btn.success {
  background: linear-gradient(135deg, #10b981, #059669);
  animation:none;
  box-shadow: 0 14px 40px rgba(16,185,129,0.5);
}
.ms-spinner {
  width:14px; height:14px;
  border-radius:50%;
  border:2px solid rgba(255,255,255,0.25);
  border-top-color:#fff;
  animation: msSpin 0.8s linear infinite;
}
@keyframes msSpin { to { transform:rotate(360deg); } }

/* === DIVIDER + ALTS === */
.ms-divider {
  display:flex; align-items:center; gap:10px;
  margin:6px 0 2px;
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  color:#475569;
  letter-spacing:0.16em;
  text-transform:uppercase;
}
.ms-divider::before, .ms-divider::after {
  content:''; flex:1; height:1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.12), transparent);
}

.ms-alts {
  display:flex; gap:10px;
}
.ms-alt {
  flex:1;
  display:flex; align-items:center; gap:10px;
  padding:11px 13px;
  background: rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:14px;
  color:#cbd5e1;
  cursor:pointer;
  transition: all 0.25s cubic-bezier(0.2,0.7,0.1,1);
  text-align:left;
  font-family:inherit;
}
.ms-alt > svg { color:#a78bfa; flex-shrink:0; }
.ms-alt:hover {
  background: rgba(167,139,250,0.08);
  border-color: rgba(167,139,250,0.4);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(167,139,250,0.18);
}
.ms-alt-title {
  font-size:12px; font-weight:700;
  color:#fff;
  font-family:'Plus Jakarta Sans', sans-serif;
}
.ms-alt-sub {
  font-size:10px;
  color:#64748b;
  margin-top:1px;
}

/* === MESSAGE === */
.ms-msg {
  text-align:center;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.06em;
  min-height:18px;
  margin-top:4px;
  line-height:1.6;
}
.ms-msg.err { color:#f87171; }
.ms-msg.ok { color:#34d399; }

/* === FOOT === */
.ms-foot {
  display:flex; justify-content:space-between; align-items:center;
  margin-top:18px;
  padding-top:14px;
  border-top:1px solid rgba(255,255,255,0.06);
  font-family:'JetBrains Mono', monospace;
  font-size:9px;
  color:#475569;
  letter-spacing:0.12em;
  flex-wrap:wrap;
  gap:8px;
}
.ms-foot-l { display:flex; align-items:center; gap:6px; }
.ms-foot-dot {
  width:6px; height:6px; border-radius:50%;
}
.ms-foot-dot.ok {
  background:#34d399;
  box-shadow:0 0 8px #34d399;
  animation: msBlink 2s ease-in-out infinite;
}

/* === OTP CELLS (2FA) === */
.ms-otp-wrap {
  display:flex; flex-direction:column;
  gap:14px; align-items:center;
  margin-top:8px;
}
.ms-otp-label {
  font-size:12px;
  color:#94a3b8;
  text-align:center;
  line-height:1.55;
  max-width:340px;
}
.ms-otp-row {
  display:flex; gap:8px;
}
.ms-otp-cell {
  width:46px; height:58px;
  background: rgba(7,11,26,0.85);
  border:1.5px solid rgba(34,211,238,0.3);
  color:#67e8f9;
  font-family:'JetBrains Mono', monospace;
  font-size:24px; font-weight:700;
  text-align:center;
  outline:none;
  border-radius:14px;
  transition: all 0.25s cubic-bezier(0.2,0.7,0.1,1);
  -webkit-appearance:none;
  appearance:none;
  caret-color:#22d3ee;
  color-scheme:dark;
  /* Blokuj białe tło przeglądarki */
  -webkit-box-shadow: 0 0 0 1000px rgba(7,11,26,0.85) inset !important;
  -webkit-text-fill-color: #67e8f9;
}
.ms-otp-cell:-webkit-autofill,
.ms-otp-cell:-webkit-autofill:hover,
.ms-otp-cell:-webkit-autofill:focus {
  -webkit-box-shadow: 0 0 0 1000px rgba(7,11,26,0.85) inset !important;
  -webkit-text-fill-color: #67e8f9 !important;
  background: rgba(7,11,26,0.85) !important;
}
  caret-color:#67e8f9;
}
.ms-otp-cell:focus {
  border-color:#22d3ee;
  background: rgba(7,11,26,0.85);
  box-shadow:
    0 0 0 1000px rgba(7,11,26,0.88) inset,
    0 0 0 4px rgba(34,211,238,0.14),
    0 0 24px rgba(34,211,238,0.3);
  transform: translateY(-2px);
  -webkit-text-fill-color: #67e8f9;
}
.ms-otp-cell.filled {
  color:#e2e8f0;
  -webkit-text-fill-color: #e2e8f0;
  border-color: rgba(167,139,250,0.55);
  background: rgba(14,9,30,0.9);
  box-shadow:
    0 0 0 1000px rgba(14,9,30,0.9) inset,
    0 0 16px rgba(167,139,250,0.2);
}
.ms-otp-cell.filled:focus {
  -webkit-text-fill-color: #e2e8f0;
  box-shadow:
    0 0 0 1000px rgba(14,9,30,0.9) inset,
    0 0 0 4px rgba(167,139,250,0.2),
    0 0 20px rgba(167,139,250,0.25);
}
.ms-otp-cell.ok {
  border-color:#34d399 !important;
  color:#34d399 !important;
  background:rgba(52,211,153,0.1) !important;
  box-shadow: 0 0 20px rgba(52,211,153,0.35) !important;
  animation: msOtpOk 0.5s ease-out;
}
@keyframes msOtpOk {
  0% { transform: scale(1); }
  40% { transform: scale(1.12); }
  100% { transform: scale(1); }
}

.ms-otp-status {
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.1em;
  color:#64748b;
  text-align:center;
}
.ms-otp-resend {
  background:none; border:none;
  color:#7dd3fc;
  cursor:pointer;
  font-family:inherit;
  font-size:inherit;
  text-decoration:none;
  transition: color 0.2s;
  padding:0;
}
.ms-otp-resend:hover { color:#a78bfa; text-decoration:underline; }

/* Mobile */
@media (max-width:520px) {
  .ms-card { padding:24px 22px 20px; border-radius:24px; }
  .ms-brand-name { font-size:28px; }
  .ms-vm-svg { width:110px; height:110px; }
  .ms-otp-cell { width:40px; height:52px; font-size:20px; }
  .ms-alts { flex-direction:column; }
  .ms-row { flex-wrap:wrap; gap:8px; }
}
@media (max-width:380px) {
  .ms-otp-cell { width:36px; height:48px; font-size:18px; gap:6px; }
  .ms-otp-row { gap:6px; }
}

@media (prefers-reduced-motion: reduce) {
  .ms-card, .ms-card::before, .ms-vm-ring-1, .ms-vm-ring-2, .ms-vm-ring-3,
  .ms-orb, .ms-floor-grid, .ms-scanlines::after, .ms-btn, .ms-btn::before,
  .ms-brand-name, .ms-vm-pulse, .ms-vm-indicator, .ms-brand-pip,
  .ms-foot-dot.ok, .ms-hud-blink, .ms-hud-bar > span, .ms-hud-graph span {
    animation: none !important;
  }
}

/* Override existing .lwrap nested inside ms-mode (for recScreen reuse) */
