:root {
  --ml-bg: #fff;
  --ml-fg: #111;
  --ml-accent: #4f46e5;
  --ml-border: #e5e7eb;
  --ml-error: #b91c1c;
  --ml-success: #065f46;
}

.ml-trigger {
  padding: .6rem 1rem;
  border: 1px solid var(--ml-border);
  background: #fff;
  border-radius: .6rem;
  cursor: pointer
}

.ml-modal {
  position: fixed;
  inset: 0;
  display: none
}

.ml-modal.is-open {
  display: flex
}

.ml-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, .4)
}

.ml-modal__content {
  position: relative;
  margin: 5vh auto;
  background: var(--ml-bg);
  max-width: 520px;
  border-radius: 1rem;
  padding: 1.25rem;
  box-shadow: 0 10px 30px rgba(0, 0, 0, .2)
}

.ml-modal__close {
  position: absolute;
  right: .75rem;
  top: .5rem;
  font-size: 1.5rem;
  background: transparent;
  border: none;
  cursor: pointer
}

.ml-tabs {
  display: flex;
  gap: .5rem;
  margin-bottom: 1rem
}

.ml-tab {
  flex: 1;
  padding: .5rem;
  border: 1px solid var(--ml-border);
  border-radius: .6rem;
  background: #f8fafc;
  cursor: pointer
}

.ml-tab.is-active {
  background: #eef2ff;
  border-color: var(--ml-accent)
}

.ml-panel {
  display: none
}

.ml-panel.is-active {
  display: block
}

.ml-panel form {
  display: flex;
  flex-direction: column;
  gap: .5rem
}

.ml-panel label {
  font-weight: 600
}

.ml-panel input[type=text],
.ml-panel input[type=password],
.ml-panel input[type=email] {
  border: 1px solid var(--ml-border);
  border-radius: .5rem;
  padding: .6rem
}

.ml-btn {
  background: var(--ml-accent);
  border: none;
  color: #fff;
  padding: .7rem 1rem;
  border-radius: .6rem;
  cursor: pointer
}

.ml-remember {
  display: flex;
  align-items: center;
  gap: .4rem
}

.ml-otp {
  display: flex;
  gap: .5rem
}

.ml-otp input {
  width: 2.2rem;
  text-align: center;
  padding: .5rem;
  border: 1px solid var(--ml-border);
  border-radius: .5rem
}

.ml-msg {
  min-height: 1.2rem;
  font-size: .92rem
}

.ml-msg.is-error {
  color: var(--ml-error)
}

.ml-msg.is-success {
  color: var(--ml-success)
}

.is-hidden {
  display: none !important
}

@media (max-width:560px) {
  .ml-modal__content {
    margin: 0;
    position: absolute;
    inset: auto 0 0 0;
    border-radius: .8rem .8rem 0 0;
    max-width: none
  }
}


.ml-pass-strength {
  font-size: 0.85rem;
  margin-top: -0.4rem;
  margin-bottom: 0.4rem;
}

.ml-pass-strength.is-weak {
  color: #b91c1c;
}

.ml-pass-strength.is-medium {
  color: #b45309;
}

.ml-pass-strength.is-strong {
  color: #065f46;
}

body.mana-login-modal-open {
  overflow: hidden;
}

.ml-passwrap { position: relative; }
.ml-passwrap input[type="password"],
.ml-passwrap input[type="text"] { padding-right: 2.5rem; }
.ml-eye {
  position: absolute;
  right: .5rem;
  top: 50%;
  transform: translateY(-50%);
  background: transparent;
  border: 0;
  padding: .25rem;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.ml-eye svg { width: 20px; height: 20px; fill: currentColor; opacity: .8; }
.ml-eye:hover svg { opacity: 1; }