/* ═══════════════════════════════════════════════
   MAGIC MANGA — AUTH SHARED STYLES
   Rang scheme: Teal/Cyan (#00BCD4, #00E5FF)
   Font: Bebas Neue + Space Grotesk
   Fon: Animated starfield + orbs
═══════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Space+Grotesk:wght@300;400;500;600;700&display=swap');

:root {
  --bg:      #060E14;
  --bg2:     #0A1520;
  --bg3:     #0F1E2C;
  --card:    rgba(10,21,32,0.92);
  --border:  rgba(0,188,212,0.18);
  --line:    rgba(0,229,255,0.22);

  --cyan:    #00E5FF;
  --teal:    #00BCD4;
  --teal2:   #00838F;
  --cyan-glow: rgba(0,229,255,0.35);
  --rose:    #FF3E8A;
  --gold:    #FFC107;
  --grn:     #00FF88;
  --red:     #FF4757;

  --txt:     #E0F7FA;
  --muted:   rgba(224,247,250,0.55);
  --dim:     rgba(224,247,250,0.28);
  --dark-txt:#B2EBF2;

  --font-d:  'Bebas Neue', sans-serif;
  --font-b:  'Space Grotesk', sans-serif;

  --r:       10px;
  --rr:      16px;
  --card-r:  18px;
}

*, *::before, *::after {
  margin: 0; padding: 0; box-sizing: border-box;
  -webkit-tap-highlight-color: transparent;
}

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-b);
  background: var(--bg);
  color: var(--txt);
  min-height: 100dvh;
  overflow-x: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 20px 16px 40px;
  position: relative;
}

a { text-decoration: none; color: inherit; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
img { display: block; }

::-webkit-scrollbar { width: 3px; }
::-webkit-scrollbar-thumb { background: rgba(0,188,212,.35); border-radius: 3px; }

/* ─── Keyframes ─── */
@keyframes fadeUp    { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:none} }
@keyframes fadeIn    { from{opacity:0} to{opacity:1} }
@keyframes twinkle   { 0%,100%{opacity:.15;transform:scale(1)} 50%{opacity:.9;transform:scale(1.4)} }
@keyframes shimmer   { 0%{background-position:-300% 0} 100%{background-position:300% 0} }
@keyframes float     { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
@keyframes orbDrift1 { 0%,100%{transform:translate(0,0)} 40%{transform:translate(35px,-25px)} 70%{transform:translate(-20px,30px)} }
@keyframes orbDrift2 { 0%,100%{transform:translate(0,0)} 35%{transform:translate(-40px,20px)} 65%{transform:translate(25px,-35px)} }
@keyframes glow      { 0%,100%{box-shadow:0 0 16px rgba(0,229,255,.28)} 50%{box-shadow:0 0 36px rgba(0,229,255,.6),0 0 60px rgba(0,229,255,.18)} }
@keyframes pulse     { 0%,100%{opacity:.5} 50%{opacity:1} }
@keyframes ripple    { from{transform:scale(0);opacity:.5} to{transform:scale(5);opacity:0} }
@keyframes spin      { to{transform:rotate(360deg)} }
@keyframes scanLine  { 0%{transform:translateY(-100vh)} 100%{transform:translateY(100vh)} }
@keyframes borderGlow{ 0%,100%{border-color:rgba(0,188,212,.18)} 50%{border-color:rgba(0,229,255,.5)} }
@keyframes shake     { 0%,100%{transform:translateX(0)} 20%,60%{transform:translateX(-7px)} 40%,80%{transform:translateX(7px)} }
@keyframes checkPop  { 0%{transform:scale(0) rotate(-20deg);opacity:0} 65%{transform:scale(1.25) rotate(5deg);opacity:1} 100%{transform:scale(1) rotate(0)} }
@keyframes logoReveal{ 0%{opacity:0;letter-spacing:.5em} 100%{opacity:1;letter-spacing:.18em} }

/* ═══════════════════════════════════════════════
   ANIMATED BACKGROUND
═══════════════════════════════════════════════ */
.bg-wrap { position:fixed; inset:0; z-index:0; pointer-events:none; overflow:hidden; }

/* Stars */
.stars-layer {
  position:absolute; inset:0;
  background-image:
    radial-gradient(1px 1px at 10% 15%, rgba(0,229,255,.7) 0%, transparent 100%),
    radial-gradient(1px 1px at 25% 42%, rgba(255,255,255,.5) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 40% 8%, rgba(0,229,255,.6) 0%, transparent 100%),
    radial-gradient(1px 1px at 55% 65%, rgba(255,255,255,.4) 0%, transparent 100%),
    radial-gradient(1px 1px at 70% 28%, rgba(0,188,212,.65) 0%, transparent 100%),
    radial-gradient(2px 2px at 82% 55%, rgba(0,229,255,.5) 0%, transparent 100%),
    radial-gradient(1px 1px at 92% 18%, rgba(255,255,255,.45) 0%, transparent 100%),
    radial-gradient(1px 1px at 15% 78%, rgba(0,229,255,.55) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 48% 88%, rgba(255,255,255,.35) 0%, transparent 100%),
    radial-gradient(1px 1px at 63% 45%, rgba(0,188,212,.5) 0%, transparent 100%),
    radial-gradient(1px 1px at 78% 82%, rgba(255,255,255,.4) 0%, transparent 100%),
    radial-gradient(1px 1px at 35% 55%, rgba(0,229,255,.45) 0%, transparent 100%),
    radial-gradient(2px 2px at 5% 35%, rgba(0,188,212,.6) 0%, transparent 100%),
    radial-gradient(1px 1px at 88% 72%, rgba(255,255,255,.35) 0%, transparent 100%),
    radial-gradient(1px 1px at 20% 92%, rgba(0,229,255,.5) 0%, transparent 100%);
}
.star {
  position:absolute; border-radius:50%;
  background:rgba(0,229,255,.7);
  animation:twinkle var(--d,3s) var(--delay,0s) ease-in-out infinite;
}

/* Orbs */
.orb {
  position:absolute; border-radius:50%;
  filter:blur(80px); opacity:.12;
}
.orb-1 { width:500px; height:500px; background:#006080; top:-15%; left:-8%; animation:orbDrift1 20s ease-in-out infinite; }
.orb-2 { width:380px; height:380px; background:#004D5C; top:40%; right:-10%; animation:orbDrift2 25s ease-in-out infinite; }
.orb-3 { width:300px; height:300px; background:#00838F; bottom:5%; left:15%; animation:orbDrift1 17s ease-in-out infinite reverse; }

/* Noise */
.bg-noise {
  position:absolute; inset:0; opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px;
}

/* Scan line */
.bg-scan {
  position:absolute; left:0; right:0; height:120px;
  background:linear-gradient(0deg,transparent,rgba(0,229,255,.018),transparent);
  animation:scanLine 10s linear infinite; pointer-events:none;
}

/* ═══════════════════════════════════════════════
   LOGO
═══════════════════════════════════════════════ */
.auth-logo {
  text-align:center; margin-bottom:28px; position:relative; z-index:1;
  animation:fadeUp .5s cubic-bezier(.4,0,.2,1) both;
}
.auth-logo-title {
  font-family:var(--font-d); font-size:clamp(28px,8vw,44px);
  letter-spacing:.18em; color:#fff;
  text-shadow:0 0 40px rgba(0,229,255,.5), 0 0 80px rgba(0,229,255,.2);
  animation:logoReveal .8s .1s cubic-bezier(.4,0,.2,1) both;
}
.auth-logo-title em {
  background:linear-gradient(90deg,var(--cyan),var(--teal));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text; font-style:normal;
}
.auth-logo-sub {
  font-family:var(--font-d); font-size:11px; letter-spacing:.32em;
  color:var(--muted); margin-top:5px;
}

/* ═══════════════════════════════════════════════
   AUTH CARD
═══════════════════════════════════════════════ */
.auth-card {
  width:100%; max-width:440px; position:relative; z-index:1;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--card-r);
  padding:28px 24px 24px;
  backdrop-filter:blur(24px) saturate(160%);
  box-shadow:0 24px 80px rgba(0,0,0,.7), 0 0 0 1px rgba(0,229,255,.04), inset 0 1px 0 rgba(0,229,255,.08);
  animation:fadeUp .5s .1s cubic-bezier(.4,0,.2,1) both;
  animation:borderGlow 4s ease-in-out infinite;
}

/* Card top glow line */
.auth-card::before {
  content:''; position:absolute; top:0; left:10%; right:10%; height:1px;
  background:linear-gradient(90deg,transparent,var(--cyan),var(--teal),var(--cyan),transparent);
  background-size:300% 100%;
  animation:shimmer 5s linear infinite; border-radius:1px;
}

/* ─── Tabs ─── */
.auth-tabs {
  display:flex; background:rgba(0,0,0,.35);
  border:1px solid rgba(0,188,212,.14);
  border-radius:10px; padding:4px; gap:4px; margin-bottom:22px;
}
.auth-tab {
  flex:1; padding:9px 6px; text-align:center;
  font-family:var(--font-d); font-size:12px; letter-spacing:.12em;
  color:var(--muted); border-radius:8px; cursor:pointer;
  transition:all .25s cubic-bezier(.4,0,.2,1); text-decoration:none;
  display:block;
}
.auth-tab.on {
  background:linear-gradient(135deg,var(--teal),var(--teal2));
  color:#fff;
  box-shadow:0 4px 18px rgba(0,188,212,.38);
}
.auth-tab:hover:not(.on) { color:var(--cyan); background:rgba(0,188,212,.08); }

/* ─── Alert ─── */
.auth-alert {
  display:flex; align-items:center; gap:10px;
  padding:11px 14px; border-radius:9px; margin-bottom:18px;
  font-size:12px; font-weight:500; line-height:1.5;
  animation:fadeUp .3s ease both;
}
.auth-alert.error   { background:rgba(255,71,87,.1);  border:1px solid rgba(255,71,87,.28);  color:#FF8A80; }
.auth-alert.success { background:rgba(0,255,136,.08); border:1px solid rgba(0,255,136,.25); color:#69FFBB; }
.auth-alert.info    { background:rgba(0,229,255,.08); border:1px solid rgba(0,229,255,.22); color:var(--cyan); }
.auth-alert i { font-size:14px; flex-shrink:0; }
.auth-alert.error i   { color:var(--red); }
.auth-alert.success i { color:var(--grn); }
.auth-alert.info i    { color:var(--cyan); }
.alert-shake { animation:shake .4s ease; }

/* ─── Form labels ─── */
.form-group { margin-bottom:16px; }
.form-label {
  display:block; margin-bottom:7px;
  font-family:var(--font-d); font-size:10px; letter-spacing:.2em;
  color:var(--muted);
}

/* ─── Inputs ─── */
.input-wrap {
  position:relative; display:flex; align-items:center;
}
.input-wrap .in-ico {
  position:absolute; left:14px;
  color:var(--teal); font-size:14px;
  pointer-events:none; transition:.25s; z-index:1;
}
.input-wrap input {
  width:100%;
  background:rgba(0,188,212,.05);
  border:1.5px solid rgba(0,188,212,.18);
  border-radius:10px;
  padding:12px 14px 12px 42px;
  color:var(--txt); font-family:var(--font-b); font-size:14px; font-weight:500;
  outline:none; transition:all .25s;
}
.input-wrap input::placeholder { color:var(--dim); }
.input-wrap input:focus {
  border-color:rgba(0,229,255,.55);
  background:rgba(0,229,255,.07);
  box-shadow:0 0 0 4px rgba(0,229,255,.06);
}
.input-wrap input:focus ~ .in-ico,
.input-wrap .in-ico:has(+ input:focus) { color:var(--cyan); }
.input-wrap input.error-field { border-color:rgba(255,71,87,.5); background:rgba(255,71,87,.05); }
.input-wrap input.success-field { border-color:rgba(0,255,136,.4); }
.input-wrap .in-ico { pointer-events:none; }
/* Fix for icon before input */
.input-wrap { flex-direction:row-reverse; }
.input-wrap .in-ico { left:14px; right:auto; order:1; position:absolute; }
.input-wrap input { order:2; }

/* Eye toggle */
.eye-btn {
  position:absolute; right:13px;
  color:var(--dim); font-size:14px; cursor:pointer;
  transition:.2s; z-index:2; padding:4px;
}
.eye-btn:hover { color:var(--cyan); }

/* Field error */
.field-err { font-size:10px; color:var(--red); margin-top:5px; font-weight:500; display:none; }
.field-err.show { display:block; animation:fadeUp .25s ease; }

/* ─── Checkbox ─── */
.check-row {
  display:flex; align-items:center; gap:10px; cursor:pointer;
  font-size:12px; font-weight:500; color:var(--muted); user-select:none;
}
.check-row input[type=checkbox] { display:none; }
.check-box {
  width:18px; height:18px; border-radius:5px; flex-shrink:0;
  border:1.5px solid rgba(0,188,212,.3);
  background:rgba(0,188,212,.05);
  display:flex; align-items:center; justify-content:center;
  transition:.25s; color:var(--cyan); font-size:9px;
}
.check-row input:checked + .check-box {
  background:linear-gradient(135deg,var(--teal),var(--teal2));
  border-color:transparent;
  box-shadow:0 0 10px rgba(0,188,212,.38);
}
.check-row input:checked + .check-box i { animation:checkPop .3s cubic-bezier(.34,1.56,.64,1); }

/* ─── Submit Button ─── */
.btn-submit {
  width:100%; padding:13px 20px; border-radius:10px;
  background:linear-gradient(135deg,var(--teal),var(--teal2));
  color:#fff; font-family:var(--font-d); font-size:14px; letter-spacing:.18em;
  border:none; cursor:pointer;
  box-shadow:0 5px 24px rgba(0,188,212,.42);
  transition:all .25s; position:relative; overflow:hidden;
  display:flex; align-items:center; justify-content:center; gap:8px;
  animation:glow 3.5s ease-in-out infinite;
}
.btn-submit::before {
  content:''; position:absolute; top:0; left:-100%; width:60%; height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.22),transparent);
  transform:skewX(-15deg); transition:left .55s;
}
.btn-submit:hover { box-shadow:0 8px 36px rgba(0,229,255,.55); transform:translateY(-1px); }
.btn-submit:hover::before { left:160%; }
.btn-submit:active { transform:scale(.96); }
.btn-submit:disabled { opacity:.55; cursor:not-allowed; transform:none; }

/* Loading state */
.btn-submit .spin { animation:spin .7s linear infinite; display:none; }
.btn-submit.loading .spin { display:inline-block; }
.btn-submit.loading .btn-txt { opacity:.7; }

/* ─── Divider ─── */
.auth-divider {
  display:flex; align-items:center; gap:10px; margin:18px 0;
}
.auth-divider::before, .auth-divider::after {
  content:''; flex:1; height:1px;
  background:linear-gradient(90deg,transparent,rgba(0,188,212,.2),transparent);
}
.auth-divider span { font-size:11px; color:var(--dim); font-weight:500; white-space:nowrap; }

/* ─── Social buttons ─── */
.social-row { display:flex; gap:8px; }
.btn-social {
  flex:1; padding:10px 6px; border-radius:9px;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
  color:var(--muted); font-size:12px; font-weight:600;
  display:flex; align-items:center; justify-content:center; gap:7px;
  transition:.22s; cursor:pointer;
}
.btn-social i { font-size:15px; }
.btn-social:hover { background:rgba(0,188,212,.1); border-color:rgba(0,188,212,.25); color:var(--cyan); transform:translateY(-1px); }
.btn-social:active { transform:scale(.94); }

/* ─── Footer links ─── */
.auth-foot {
  text-align:center; margin-top:18px; font-size:12px; color:var(--muted);
  position:relative; z-index:1; animation:fadeIn .5s .35s ease both; opacity:0;
  animation-fill-mode:both;
}
.auth-foot a { color:var(--cyan); font-weight:700; transition:.2s; }
.auth-foot a:hover { color:#fff; text-shadow:0 0 12px rgba(0,229,255,.5); }

/* ─── Password strength ─── */
.pwd-strength { margin-top:8px; }
.pwd-bars { display:flex; gap:4px; margin-bottom:4px; }
.pwd-bar {
  flex:1; height:3px; border-radius:2px;
  background:rgba(255,255,255,.08); transition:background .3s;
}
.pwd-bar.w  { background:#FF4757; }
.pwd-bar.m  { background:var(--gold); }
.pwd-bar.s  { background:var(--grn); }
.pwd-label { font-size:10px; color:var(--dim); transition:.3s; }

/* ─── OTP input ─── */
.otp-row { display:flex; gap:8px; justify-content:center; }
.otp-input {
  width:50px; height:56px; text-align:center;
  background:rgba(0,188,212,.05); border:1.5px solid rgba(0,188,212,.2);
  border-radius:10px; color:var(--txt); font-family:var(--font-d); font-size:22px;
  letter-spacing:.05em; outline:none; transition:.25s;
}
.otp-input:focus { border-color:var(--cyan); background:rgba(0,229,255,.08); box-shadow:0 0 0 4px rgba(0,229,255,.06); }
.otp-input.filled { border-color:rgba(0,255,136,.4); }

/* ─── Link back ─── */
.back-link {
  display:inline-flex; align-items:center; gap:6px;
  font-size:12px; font-weight:600; color:var(--muted);
  margin-bottom:22px; transition:.2s; position:relative; z-index:1;
}
.back-link:hover { color:var(--cyan); }
.back-link i { font-size:11px; }

/* ─── Progress steps ─── */
.steps-row { display:flex; align-items:center; justify-content:center; gap:6px; margin-bottom:24px; }
.step {
  display:flex; align-items:center; gap:6px; font-family:var(--font-d);
  font-size:10px; letter-spacing:.1em; color:var(--dim);
}
.step-dot {
  width:24px; height:24px; border-radius:50%;
  background:rgba(255,255,255,.06); border:1.5px solid rgba(0,188,212,.2);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-d); font-size:10px; transition:.3s;
}
.step.done .step-dot { background:rgba(0,255,136,.15); border-color:rgba(0,255,136,.4); color:var(--grn); }
.step.active .step-dot { background:linear-gradient(135deg,var(--teal),var(--teal2)); border-color:transparent; color:#fff; box-shadow:0 0 14px rgba(0,188,212,.4); }
.step-line { flex:1; height:1px; background:rgba(0,188,212,.12); max-width:32px; }

/* ─── Terms text ─── */
.terms-txt { font-size:10.5px; color:var(--dim); line-height:1.7; text-align:center; margin-top:14px; }
.terms-txt a { color:var(--cyan); }
.terms-txt a:hover { text-decoration:underline; }

/* ─── Toast ─── */
.mm-toast {
  position:fixed; bottom:24px; left:50%;
  transform:translateX(-50%) translateY(16px);
  background:rgba(10,21,32,.98); border:1px solid rgba(0,229,255,.28);
  border-radius:50px; padding:10px 22px;
  font-family:var(--font-b); font-size:13px; font-weight:600;
  color:var(--cyan); z-index:9999;
  display:flex; align-items:center; gap:8px;
  backdrop-filter:blur(16px);
  box-shadow:0 8px 40px rgba(0,0,0,.55), 0 0 24px rgba(0,229,255,.1);
  opacity:0; transition:all .32s cubic-bezier(.4,0,.2,1);
  white-space:nowrap; pointer-events:none;
}

/* ─── Responsive ─── */
@media(max-width:420px) {
  .auth-card { padding:22px 16px 20px; border-radius:14px; }
  .otp-input { width:42px; height:50px; font-size:20px; }
}
