/* ════════════════════════════════════════════════════════
   MALEK SEJF — PREVIEW.HTML DESIGN (cyan vault aesthetic)
   ════════════════════════════════════════════════════════ */

/* === BACKGROUND ROOT === */
#loginScreen.ms-mode,
#twoFaScreen {
  background:
    radial-gradient(circle at 50% 52%, rgba(42,202,255,.20), transparent 18%),
    radial-gradient(circle at 72% 14%, rgba(118,237,255,.14), transparent 24%),
    radial-gradient(circle at 14% 84%, rgba(0,95,255,.18), transparent 28%),
    linear-gradient(135deg,#01040a 0%,#061524 48%,#020713 100%) !important;
  overflow:hidden;
  font-family:'Plus Jakarta Sans','Inter',sans-serif;
}

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

/* === FLOOR GRID (perspective grid from preview) === */
.ms-floor {
  position:absolute; inset:0;
  perspective:600px; pointer-events:none;
  overflow:hidden; z-index:0; opacity:.23;
}
.ms-floor-grid {
  position:fixed;
  inset:-20%;
  background-image:
    linear-gradient(rgba(64,219,255,.18) 1px, transparent 1px),
    linear-gradient(90deg, rgba(64,219,255,.18) 1px, transparent 1px);
  background-size:48px 48px;
  transform:perspective(720px) rotateX(62deg) scale(1.2);
  animation:msGridMove 13s linear infinite;
  transform-origin:center bottom;
}
@keyframes msGridMove { to { background-position: 0 96px, 96px 0; } }

/* === SCANLINES === */
.ms-scanlines {
  position:absolute; inset:0; z-index:1;
  pointer-events:none; mix-blend-mode:screen;
  background: repeating-linear-gradient(
    0deg,transparent 0,transparent 3px,
    rgba(64,219,255,.045) 3px,rgba(64,219,255,.045) 4px
  );
}
.ms-scanlines::after {
  content:'';position:absolute;left:0;right:0;
  height:160px;top:-160px;
  background:linear-gradient(180deg,transparent,rgba(109,236,255,.09),transparent);
  animation:msScanSweep 4.8s ease-in-out infinite;
}
@keyframes msScanSweep { 0%,100%{top:-160px} 50%{top:100%} }

/* === VIGNETTE === */
.ms-vignette {
  position:fixed;inset:0;z-index:8;pointer-events:none;
  background:radial-gradient(circle at center,transparent 42%,rgba(0,0,0,.72) 100%);
}

/* === GLOWING ORBS === */
.ms-orb {
  position:absolute; border-radius:50%;
  filter:blur(70px); pointer-events:none; z-index:0;
}
.ms-orb-1 {
  width:500px;height:500px;top:-160px;left:-120px;
  background:radial-gradient(circle,rgba(47,202,255,.28),transparent 65%);
  animation:msOrbA 16s ease-in-out infinite;
}
.ms-orb-2 {
  width:420px;height:420px;bottom:-120px;right:-80px;
  background:radial-gradient(circle,rgba(10,124,255,.30),transparent 65%);
  animation:msOrbA 19s ease-in-out infinite reverse;
  animation-delay:-3s;
}
.ms-orb-3 {
  width:320px;height:320px;top:50%;left:50%;
  transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(155,245,255,.18),transparent 65%);
  animation:msOrbB 11s ease-in-out infinite;
}
@keyframes msOrbA {
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(40px,-50px) scale(1.1)}
}
@keyframes msOrbB {
  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:.16em;
}
.ms-hud > div {
  position:absolute;
  border:1px solid rgba(71,229,255,.28);
  background:rgba(2,7,19,.72);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  padding:9px 13px; min-width:130px;
  border-radius:14px; color:#7dd3fc;
  animation:msHudIn .8s cubic-bezier(.2,.7,.1,1) backwards;
}
.ms-hud-tl{top:0;left:0;animation-delay:.1s}
.ms-hud-tr{top:0;right:0;text-align:right;animation-delay:.2s}
.ms-hud-bl{bottom:0;left:0;animation-delay:.3s}
.ms-hud-br{bottom:0;right:0;text-align:right;animation-delay:.4s}
@keyframes msHudIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.ms-hud-label{color:rgba(71,229,255,.35);font-size:8px}
.ms-hud-val{color:#47e5ff;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:#47e5ff !important}
.ms-hud-bar{height:3px;background:rgba(71,229,255,.12);margin-top:6px;overflow:hidden;border-radius:2px}
.ms-hud-bar > span{
  display:block;height:100%;width:78%;
  background:linear-gradient(90deg,#47e5ff,#9bf5ff);
  animation:msBarPulse 3s ease-in-out infinite;border-radius:2px;
}
@keyframes msBarPulse{0%,100%{opacity:1}50%{opacity:.6}}
.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,#47e5ff,#0a7cff);
  animation:msGraph 1.6s ease-in-out infinite;border-radius:1.5px;
}
.ms-hud-graph span:nth-child(odd){animation-delay:.2s}
.ms-hud-graph span:nth-child(3n){animation-delay:.4s}
@keyframes msGraph{0%,100%{opacity:.6;transform:scaleY(.7)}50%{opacity:1;transform:scaleY(1)}}
.ms-hud-blink{
  display:inline-block;width:6px;height:6px;border-radius:50%;
  background:#47e5ff;box-shadow:0 0 8px #47e5ff;margin-right:6px;
  animation:msBlink 1.6s ease-in-out infinite;
}
@keyframes msBlink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.85)}}
@media(max-width:720px){.ms-hud{display:none}}

/* === CARD === */
.ms-card {
  position:relative; z-index:3;
  width:min(460px,calc(100vw - 32px));
  background:linear-gradient(180deg,rgba(6,25,45,.72),rgba(3,10,20,.50));
  border:1px solid rgba(118,236,255,.30);
  border-radius:32px;
  padding:30px 32px 24px;
  backdrop-filter:blur(20px) saturate(140%);
  -webkit-backdrop-filter:blur(20px) saturate(140%);
  box-shadow:
    0 0 70px rgba(41,197,255,.22),
    inset 0 0 42px rgba(83,229,255,.08),
    0 40px 80px rgba(0,0,0,.65);
  animation:msCardEnter .8s cubic-bezier(.2,.7,.1,1);
  overflow:hidden;
}
.ms-card.ms-success{border-color:rgba(71,229,255,.5);box-shadow:0 0 80px rgba(71,229,255,.35)}
.ms-card.ms-shake{animation:msShake .5s}
@keyframes msCardEnter{from{opacity:0;transform:translateY(28px) scale(.96);filter:blur(8px)}to{opacity:1;transform:none;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)}}
/* rotating conic border */
.ms-card::before {
  content:'';position:absolute;inset:-2px;border-radius:32px;
  background:conic-gradient(
    from 90deg,
    transparent,rgba(69,229,255,.55),transparent 32%,
    rgba(10,124,255,.38),transparent 63%,
    rgba(155,245,255,.48),transparent
  );
  animation:msBorderSpin 9s linear infinite;
  z-index:-1;filter:blur(8px);
}
@keyframes msBorderSpin{to{transform:rotate(360deg)}}
/* top edge glow */
.ms-edge{position:absolute;background:linear-gradient(90deg,transparent,#47e5ff,transparent);pointer-events:none;border-radius:2px}
.ms-edge-t{top:0;left:15%;right:15%;height:1px;box-shadow:0 0 12px #47e5ff}

/* noise texture */
.ms-card-noise {
  position:absolute;inset:0;pointer-events:none;z-index:0;opacity:.07;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='.75'/%3E%3C/svg%3E");
}

/* === 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:.18em;
  position:relative;z-index:2;
}
.ms-step{display:flex;align-items:center;gap:6px;color:rgba(71,229,255,.3);transition:color .4s}
.ms-step.active{color:#47e5ff}
.ms-step.done{color:rgba(71,229,255,.65)}
.ms-step-num{
  font-weight:700;padding:3px 7px;
  border:1px solid rgba(71,229,255,.15);
  background:rgba(2,13,26,.5);
  border-radius:6px;transition:all .3s;
}
.ms-step.active .ms-step-num{
  background:rgba(71,229,255,.12);
  border-color:rgba(71,229,255,.6);
  box-shadow:0 0 10px rgba(71,229,255,.3);
}
.ms-step.done .ms-step-num{background:rgba(71,229,255,.1);border-color:rgba(71,229,255,.4)}
.ms-step-line{flex:1;height:1px;background:rgba(71,229,255,.1);position:relative;overflow:hidden}
.ms-step-line-fill{display:block;height:100%;width:0%;background:linear-gradient(90deg,#47e5ff,#9bf5ff);transition:width .7s cubic-bezier(.2,.7,.1,1);box-shadow:0 0 8px rgba(71,229,255,.5)}
.ms-step-line.fill .ms-step-line-fill{width:100%}

/* === PREVIEW-STYLE VAULT === */
.ms-vault{
  display:flex;flex-direction:column;align-items:center;
  margin:4px 0 18px;
  position:relative;z-index:2;
}
/* The preview.html vault wrapper */
.ms-pv-vault {
  position:relative;
  width:240px;height:240px;
  display:grid;place-items:center;
  filter:drop-shadow(0 0 32px rgba(61,218,255,.35));
}
/* Rings */
.ms-pv-ring {
  position:absolute;border-radius:50%;
  border:1px solid rgba(113,236,255,.34);
  box-shadow:inset 0 0 28px rgba(57,213,255,.13),0 0 18px rgba(57,213,255,.13);
}
.ms-pv-ring.r1{
  inset:0;animation:pvSpin 18s linear infinite;
  background:repeating-conic-gradient(from 0deg,rgba(89,229,255,.22) 0deg 1.5deg,transparent 1.5deg 6deg);
}
.ms-pv-ring.r2{
  inset:20px;animation:pvSpin 13s linear infinite reverse;
  background:repeating-conic-gradient(from 30deg,transparent 0deg 5deg,rgba(115,239,255,.18) 5deg 7deg);
}
.ms-pv-ring.r3{
  inset:42px;animation:pvSpin 9s linear infinite;
  background:radial-gradient(circle,transparent 58%,rgba(96,229,255,.13) 59%,transparent 66%),
    repeating-conic-gradient(rgba(137,244,255,.21) 0deg 2deg,transparent 2deg 9deg);
}
.ms-pv-ring.r4{
  inset:64px;animation:pvSpin 21s linear infinite reverse;
  background:conic-gradient(from 220deg,rgba(42,214,255,.06),rgba(114,242,255,.30),rgba(42,214,255,.06),transparent,rgba(8,124,255,.25),transparent);
}
@keyframes pvSpin{to{transform:rotate(360deg)}}
@keyframes pvSpinR{to{transform:rotate(-360deg)}}

/* Orbit text rings */
.ms-pv-alpha,.ms-pv-orbit,.ms-pv-numbers{
  position:absolute;border-radius:50%;pointer-events:none;
  text-shadow:0 0 9px rgba(88,230,255,.9);
}
.ms-pv-alpha{
  inset:-14px;animation:pvSpinR 72s linear infinite;
  color:rgba(118,226,255,.5);font-size:9px;letter-spacing:.18em;text-transform:uppercase;
}
.ms-pv-orbit{
  inset:8px;animation:pvSpinR 32s linear infinite;
  color:rgba(159,245,255,.72);font-size:8px;letter-spacing:.2em;
}
.ms-pv-numbers{
  inset:50px;animation:pvSpin 18s linear infinite;
  color:rgba(210,254,255,.92);font-size:10px;font-weight:700;letter-spacing:.12em;
  text-shadow:0 0 12px rgba(120,244,255,.95),0 0 26px rgba(18,136,255,.55);
}
.ms-pv-alpha span,.ms-pv-orbit span,.ms-pv-numbers span{
  position:absolute;left:50%;top:50%;transform-origin:0 0;white-space:pre;
}

/* Dial (inner mechanism) */
.ms-pv-dial {
  position:absolute;
  width:108px;height:108px;border-radius:50%;
  background:
    radial-gradient(circle at 50% 50%,rgba(218,255,255,.34) 0 7%,transparent 8%),
    radial-gradient(circle at 50% 45%,rgba(155,249,255,.26),rgba(10,41,70,.90) 42%,rgba(3,12,24,.98) 74%);
  border:1px solid rgba(171,247,255,.62);
  box-shadow:0 0 38px rgba(80,226,255,.38),inset 0 0 32px rgba(98,229,255,.21);
}
.ms-pv-dial::before {
  content:'';position:absolute;inset:13px;border-radius:50%;
  border:1px solid rgba(165,246,255,.38);
  background:
    radial-gradient(circle,transparent 0 42%,rgba(83,229,255,.12) 43% 46%,transparent 47%),
    repeating-conic-gradient(rgba(175,248,255,.50) 0 2deg,transparent 2deg 11deg);
  animation:pvSpin 7.5s linear infinite;
}
.ms-pv-dial::after {
  content:'';position:absolute;inset:30px;border-radius:50%;
  border:1px solid rgba(192,252,255,.72);
  background:
    radial-gradient(circle at 50% 50%,rgba(214,255,255,.95) 0 9%,rgba(67,227,255,.28) 10% 18%,transparent 19%),
    repeating-conic-gradient(from 18deg,rgba(126,241,255,.82) 0 4deg,transparent 4deg 16deg);
  box-shadow:0 0 20px rgba(96,239,255,.85),inset 0 0 18px rgba(96,239,255,.38);
  animation:pvSpinR 5.8s linear infinite;
}

/* MicroDial (center) */
.ms-pv-micro {
  position:absolute;
  width:52px;height:52px;border-radius:50%;
  border:1px solid rgba(213,255,255,.85);
  background:
    radial-gradient(circle at center,rgba(231,255,255,.96) 0 5%,rgba(80,232,255,.54) 6% 13%,transparent 14%),
    repeating-conic-gradient(from 0deg,rgba(210,255,255,.95) 0 3deg,transparent 3deg 12deg),
    radial-gradient(circle,rgba(17,72,112,.76),rgba(3,13,27,.96));
  box-shadow:0 0 26px rgba(107,238,255,.92),inset 0 0 18px rgba(102,231,255,.42);
  animation:pvMicroPulse 2.8s ease-in-out infinite;
  display:flex;align-items:center;justify-content:center;
}
.ms-pv-micro::before {
  content:'';position:absolute;inset:7px;border-radius:50%;
  border:1px dashed rgba(205,255,255,.78);
  animation:pvSpin 4.4s linear infinite;
}
.ms-pv-micro::after {
  content:'PROTECT';
  font-size:6px;font-weight:800;letter-spacing:.14em;
  color:#e8ffff;text-shadow:0 0 10px #65eaff;
  position:absolute;
}
@keyframes pvMicroPulse{50%{transform:scale(.94);filter:brightness(1.35)}}

/* Spinning state (when logging in) */
.ms-vm.spinning .ms-pv-ring.r1{animation-duration:1.5s}
.ms-vm.spinning .ms-pv-ring.r2{animation-duration:1s}
.ms-vm.spinning .ms-pv-ring.r3{animation-duration:.7s}
.ms-vm.spinning .ms-pv-ring.r4{animation-duration:1.8s}
/* Open state */
.ms-vm.open .ms-pv-micro{
  background:radial-gradient(circle at center,rgba(71,229,255,.95) 0 12%,rgba(47,202,255,.4) 13% 22%,transparent 23%),
    radial-gradient(circle,rgba(17,72,112,.76),rgba(3,13,27,.96));
  box-shadow:0 0 40px rgba(71,229,255,1),inset 0 0 18px rgba(102,231,255,.6);
}

/* Keep the old SVG hidden (login-init.js may reference it) */
.ms-vm-svg{display:none !important}
.ms-vm{position:relative}

/* === BRAND === */
.ms-brand{text-align:center;margin-bottom:6px;position:relative;z-index:2}
.ms-brand-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'JetBrains Mono',monospace;
  font-size:10px;letter-spacing:.22em;
  color:rgba(184,249,255,.7);margin-bottom:10px;
}
.ms-brand-pip{
  width:6px;height:6px;border-radius:50%;
  background:#47e5ff;box-shadow:0 0 12px #47e5ff;
  animation:msBlink 2s ease-in-out infinite;
}
.ms-brand-name{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:34px;font-weight:700;
  letter-spacing:.04em;line-height:1;
  color:#dffaff;
  text-shadow:0 0 18px rgba(73,229,255,.65);
}
.ms-brand-mark{color:#47e5ff;font-size:11px;margin:0 8px}
.ms-brand-sub{
  margin-top:8px;
  font-family:'JetBrains Mono',monospace;
  font-size:10px;letter-spacing:.18em;
  color:rgba(71,229,255,.45);
}

/* === FORM === */
.ms-form{
  display:flex;flex-direction:column;gap:13px;
  margin-top:16px;position:relative;z-index:2;
}
.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:.22em;
  text-transform:uppercase;color:rgba(164,241,255,.62);
  display:flex;align-items:center;gap:6px;
}
.ms-field-box{
  position:relative;display:flex;align-items:center;gap:10px;
  height:52px;padding:0 16px;
  background:rgba(2,13,26,.54);
  border:1px solid rgba(116,232,255,.22);
  border-radius:16px;
  box-shadow:inset 0 0 16px rgba(70,214,255,.06);
  transition:all .3s;
  color:rgba(227,252,255,.82);
}
.ms-field.focused .ms-field-box{
  border-color:rgba(71,229,255,.55);
  background:rgba(2,13,26,.7);
  box-shadow:0 0 0 3px rgba(71,229,255,.1),inset 0 0 16px rgba(70,214,255,.08);
}
.ms-field-icon{color:rgba(71,229,255,.55);display:flex;align-items:center;flex-shrink:0;transition:color .2s}
.ms-field.focused .ms-field-icon{color:#47e5ff}
.ms-field-trail{display:flex;align-items:center;gap:8px;color:rgba(71,229,255,.45);flex-shrink:0}
.ms-field-check{color:#47e5ff;display:flex;align-items:center;animation:msCheckPop .3s cubic-bezier(.2,.7,.1,1)}
@keyframes msCheckPop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.3)}100%{transform:scale(1);opacity:1}}
.ms-input{
  flex:1;background:transparent !important;border:none !important;outline:none !important;
  color:rgba(227,252,255,.88) !important;font-size:15px !important;
  font-family:'JetBrains Mono',monospace !important;
  padding:0 !important;margin:0 !important;
  letter-spacing:.08em;width:100%;box-shadow:none !important;
}
.ms-input::placeholder{color:rgba(71,229,255,.28)}

.ms-eye-btn{
  background:transparent;border:none;cursor:pointer;
  color:rgba(71,229,255,.45);padding:2px;
  display:flex;align-items:center;justify-content:center;
  transition:color .2s;border-radius:6px;
}
.ms-eye-btn:hover{color:#47e5ff}

/* Strength */
.ms-strength{display:flex;align-items:center;gap:10px;padding-top:2px;animation:msSlideIn .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(71,229,255,.08);border-radius:1.5px;transition:all .4s}
.ms-strength-pip.active.s-0{background:#f87171;box-shadow:0 0 8px rgba(248,113,113,.4)}
.ms-strength-pip.active.s-1{background:#fbbf24;box-shadow:0 0 8px rgba(251,191,36,.4)}
.ms-strength-pip.active.s-2{background:#a3e635;box-shadow:0 0 8px rgba(163,230,53,.4)}
.ms-strength-pip.active.s-3{background:#47e5ff;box-shadow:0 0 10px rgba(71,229,255,.6)}
.ms-strength-label{font-family:'JetBrains Mono',monospace;font-size:9px;font-weight:700;letter-spacing:.16em;min-width:50px;text-align:right}
.ms-strength-label.s-3{color:#47e5ff}
.ms-strength-label.s-2{color:#a3e635}
.ms-strength-label.s-1{color:#fbbf24}
.ms-strength-label.s-0{color:#f87171}
.ms-caps{font-size:10px;color:#fbbf24;font-family:'JetBrains Mono',monospace;letter-spacing:.1em;display:flex;align-items:center;gap:6px;animation:msSlideIn .3s ease-out}

/* Remember me / forgot */
.ms-row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.ms-check{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:12px;color:rgba(186,245,255,.75);font-weight:500}
.ms-check input{display:none}
.ms-check-box{
  width:16px;height:16px;border-radius:6px;
  border:1.5px solid rgba(71,229,255,.35);
  background:rgba(2,13,26,.7);
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;flex-shrink:0;
}
.ms-check-box span{
  width:8px;height:8px;border-radius:3px;
  background:linear-gradient(135deg,#47e5ff,#9bf5ff);
  transform:scale(0);transition:transform .2s cubic-bezier(.2,.7,.1,1);
}
.ms-check input:checked + .ms-check-box{border-color:#47e5ff;background:rgba(71,229,255,.15);box-shadow:0 0 12px rgba(71,229,255,.2)}
.ms-check input:checked + .ms-check-box span{transform:scale(1)}
.ms-check:hover{color:#9bf5ff}
.ms-forgot{font-size:12px;color:rgba(71,229,255,.55);text-decoration:none;font-weight:500;cursor:pointer;transition:color .2s;background:none;border:none;padding:0;font-family:inherit}
.ms-forgot:hover{color:#47e5ff}

/* === BUTTON === */
.ms-btn{
  position:relative;overflow:hidden;margin-top:4px;
  height:54px;border:0;border-radius:17px;
  background:linear-gradient(90deg,#00a3ff,#59edff,#0b7cff);
  color:#001523;font-weight:800;letter-spacing:.22em;text-transform:uppercase;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;
  box-shadow:0 0 28px rgba(52,219,255,.46);
  cursor:pointer;width:100%;
  transition:transform .25s,box-shadow .25s;
}
.ms-btn::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(110deg,transparent 0 32%,rgba(255,255,255,.62) 47%,transparent 62%);
  transform:translateX(-110%);
  animation:msBtnShine 3.8s ease-in-out infinite;
}
@keyframes msBtnShine{60%,100%{transform:translateX(110%)}}
.ms-btn-content{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;gap:10px}
.ms-btn-arrow{transition:transform .25s;display:inline-block;color:#001523}
.ms-btn:not(:disabled):hover{transform:translateY(-3px);box-shadow:0 0 44px rgba(52,219,255,.7)}
.ms-btn:not(:disabled):hover .ms-btn-arrow{transform:translateX(5px)}
.ms-btn:not(:disabled):active{transform:translateY(-1px)}
.ms-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}
.ms-btn.loading{animation:msBtnPulse 1.4s ease-in-out infinite}
@keyframes msBtnPulse{0%,100%{box-shadow:0 0 28px rgba(52,219,255,.46)}50%{box-shadow:0 0 50px rgba(52,219,255,.8),0 0 80px rgba(71,229,255,.3)}}
.ms-btn.success{background:linear-gradient(90deg,#00d4aa,#47e5ff);animation:none;box-shadow:0 14px 40px rgba(71,229,255,.4)}
.ms-spinner{width:14px;height:14px;border-radius:50%;border:2px solid rgba(0,21,35,.3);border-top-color:#001523;animation:msSpin .8s linear infinite}
@keyframes msSpin{to{transform:rotate(360deg)}}

/* === MESSAGE === */
.ms-msg{
  text-align:center;font-family:'JetBrains Mono',monospace;
  font-size:11px;letter-spacing:.06em;min-height:18px;
  margin-top:4px;line-height:1.6;color:rgba(71,229,255,.75);
  position:relative;z-index:2;
}
.ms-msg.lerr{color:rgba(248,113,113,.9)}
.ms-msg.lok{color:rgba(71,229,255,.95)}

/* === FOOT === */
.ms-foot{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:18px;padding-top:14px;
  border-top:1px solid rgba(71,229,255,.1);
  font-family:'JetBrains Mono',monospace;font-size:9px;
  color:rgba(71,229,255,.35);letter-spacing:.12em;
  flex-wrap:wrap;gap:8px;position:relative;z-index:2;
}
.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:#47e5ff;box-shadow:0 0 8px #47e5ff;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;position:relative;z-index:2}
.ms-otp-label{font-size:12px;color:rgba(184,249,255,.65);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,.85);
  border:1.5px solid rgba(71,229,255,.3);
  color:#67e8f9;
  font-family:'JetBrains Mono',monospace;
  font-size:24px;font-weight:700;text-align:center;
  outline:none;border-radius:14px;
  transition:all .25s;-webkit-appearance:none;appearance:none;
  caret-color:#47e5ff;color-scheme:dark;
  -webkit-box-shadow:0 0 0 1000px rgba(7,11,26,.85) inset !important;
  -webkit-text-fill-color:#67e8f9;
}
.ms-otp-cell:focus{
  border-color:#47e5ff;
  box-shadow:0 0 0 1000px rgba(7,11,26,.88) inset,0 0 0 4px rgba(71,229,255,.14),0 0 24px rgba(71,229,255,.3);
  transform:translateY(-2px);
  -webkit-text-fill-color:#9bf5ff;
}
.ms-otp-cell.filled{
  -webkit-text-fill-color:#dffaff;border-color:rgba(71,229,255,.55);
  background:rgba(2,13,26,.9);
  box-shadow:0 0 0 1000px rgba(2,13,26,.9) inset,0 0 16px rgba(71,229,255,.2);
}
.ms-otp-cell.ok{
  border-color:#47e5ff !important;-webkit-text-fill-color:#47e5ff !important;
  box-shadow:0 0 20px rgba(71,229,255,.5) !important;
  animation:msOtpOk .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:.1em;color:rgba(71,229,255,.4);text-align:center}
.ms-otp-resend{background:none;border:none;color:rgba(71,229,255,.6);cursor:pointer;font-family:inherit;font-size:inherit;text-decoration:none;transition:color .2s;padding:0}
.ms-otp-resend:hover{color:#47e5ff}

/* === MOBILE === */
@media(max-width:520px){
  .ms-card{padding:24px 20px 20px;border-radius:24px}
  .ms-brand-name{font-size:28px}
  .ms-pv-vault{width:200px;height:200px}
  .ms-pv-dial{width:92px;height:92px}
  .ms-pv-micro{width:44px;height:44px}
  .ms-otp-cell{width:40px;height:52px;font-size:20px}
  .ms-row{flex-wrap:wrap;gap:8px}
}
@media(max-width:380px){
  .ms-otp-cell{width:36px;height:48px;font-size:18px}
  .ms-otp-row{gap:6px}
}
@media(prefers-reduced-motion:reduce){
  .ms-card,.ms-card::before,.ms-pv-ring,
  .ms-orb,.ms-floor-grid,.ms-scanlines::after,
  .ms-btn,.ms-btn::before,.ms-pv-dial,.ms-pv-micro,
  .ms-brand-pip,.ms-foot-dot.ok,.ms-hud-blink{animation:none !important}
}
