@import url("theme-vars.css");

/* ===== MODALS V2 — Auth + Portal ===== */

/* ── Base Modal ── */
.mz-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
  z-index: 2000;
}

.mz-modal.mz-is-open {
  display: flex;
}

.mz-modal-backdrop {
  position: absolute;
  inset: 0;
  background: color-mix(in srgb, var(--mz-color-bg-dark) 70%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.mz-modal-panel {
  position: relative;
  width: min(560px, 96vw);
  border-radius: 24px;
  border: 1px solid var(--mz-color-border-soft);
  background: linear-gradient(155deg, var(--mz-color-surface-3), var(--mz-color-surface-2));
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--mz-color-accent) 8%, transparent),
    var(--mz-shadow-lg);
  overflow: hidden;
  max-height: 92vh;
  overflow-y: auto;
}

.mz-modal-panel::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg,
    transparent,
    color-mix(in srgb, var(--mz-color-accent) 60%, transparent),
    color-mix(in srgb, var(--mz-color-accent) 85%, transparent),
    color-mix(in srgb, var(--mz-color-accent) 60%, transparent),
    transparent
  );
  pointer-events: none;
}

/* Scroll bar styling */
.mz-modal-panel::-webkit-scrollbar { width: 4px; }
.mz-modal-panel::-webkit-scrollbar-track { background: transparent; }
.mz-modal-panel::-webkit-scrollbar-thumb {
  background: color-mix(in srgb, var(--mz-color-accent) 25%, transparent);
  border-radius: 2px;
}

.mz-auth-panel { padding: 26px; }
.mz-portal-panel { padding: 26px; }

/* Modal head */
.mz-modal-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 20px;
}

.mz-modal-title {
  font-family: var(--mz-font-display);
  font-size: 22px;
  font-weight: 700;
  color: var(--mz-color-accent);
  line-height: 1.2;
}

.mz-modal-sub {
  margin-top: 4px;
  color: var(--mz-color-text-muted);
  font-size: 13px;
  line-height: 1.50;
}

.mz-modal-close {
  flex: 0 0 auto;
  width: 36px; height: 36px;
  border-radius: 10px;
  border: 1px solid var(--mz-color-border-soft);
  background: color-mix(in srgb, var(--mz-color-accent) 6%, transparent);
  color: color-mix(in srgb, var(--mz-color-text-muted) 65%, transparent);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: .18s ease;
}

.mz-modal-close:hover {
  background: color-mix(in srgb, var(--mz-color-error) 14%, transparent);
  border-color: color-mix(in srgb, var(--mz-color-error) 40%, transparent);
  color: var(--mz-color-error);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   AUTH MODAL
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* Tabs */
.mz-auth-tabs {
  display: flex;
  gap: 4px;
  padding: 4px;
  border-radius: 12px;
  background: color-mix(in srgb, var(--mz-color-bg-dark) 45%, transparent);
  border: 1px solid var(--mz-color-border-faint);
  margin-bottom: 20px;
}

.mz-auth-tab {
  flex: 1;
  padding: 8px;
  border-radius: 9px;
  border: 1px solid transparent;
  background: transparent;
  color: color-mix(in srgb, var(--mz-color-text-muted) 60%, transparent);
  font-family: var(--mz-font-body);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: .18s ease;
  letter-spacing: 0.03em;
}

.mz-auth-tab:hover {
  color: color-mix(in srgb, var(--mz-color-accent) 85%, transparent);
}

.mz-auth-tab--active {
  background: color-mix(in srgb, var(--mz-color-accent-dark) 25%, transparent);
  border-color: color-mix(in srgb, var(--mz-color-accent) 40%, transparent);
  color: var(--mz-color-accent-light);
}

/* Panes */
.mz-auth-pane { }
.mz-auth-pane--hidden { display: none; }

/* Actions */
.mz-auth-actions {
  margin-top: 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.mz-auth-submit { flex: 1; justify-content: center; }

.mz-auth-note {
  margin-top: 12px;
  color: color-mix(in srgb, var(--mz-color-text-muted) 45%, transparent);
  font-size: 11px;
  line-height: 1.50;
}

/* ── Registration: Division checkboxes ── */
.mz-reg-divisions-label {
  margin-top: 18px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--mz-color-accent) 65%, transparent);
  margin-bottom: 4px;
}

.mz-reg-divisions-hint,
.mz-rec-hint {
  color: color-mix(in srgb, var(--mz-color-text-muted) 55%, transparent);
  font-size: 12px;
  line-height: 1.50;
  margin-bottom: 12px;
}

/* ── FIX: دائماً 3 أعمدة على desktop/laptop ── */
.mz-reg-divisions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.mz-reg-div-item {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 8px 9px;
  min-height: 48px;
  border-radius: var(--mz-radius-sm);
  border: 1px solid var(--mz-color-border-faint);
  background: color-mix(in srgb, var(--mz-color-bg-dark) 35%, transparent);
  cursor: pointer;
  transition: .18s ease;
  position: relative;
}

.mz-reg-div-item:hover {
  border-color: color-mix(in srgb, var(--mz-color-accent) 38%, transparent);
  background: color-mix(in srgb, var(--mz-color-accent) 6%, transparent);
}

.mz-reg-div-item input[type=checkbox] {
  position: absolute;
  opacity: 0;
  width: 0; height: 0;
}

.mz-reg-div-check {
  flex: 0 0 auto;
  width: 16px; height: 16px;
  border-radius: 4px;
  border: 1px solid color-mix(in srgb, var(--mz-color-accent) 30%, transparent);
  background: color-mix(in srgb, var(--mz-color-bg-dark) 45%, transparent);
  display: flex; align-items: center; justify-content: center;
  transition: .15s ease;
}

.mz-reg-div-item input:checked ~ .mz-reg-div-check {
  background: color-mix(in srgb, var(--mz-color-accent-dark) 50%, transparent);
  border-color: color-mix(in srgb, var(--mz-color-accent) 70%, transparent);
}

.mz-reg-div-item input:checked ~ .mz-reg-div-check::after {
  content: '';
  display: block;
  width: 8px; height: 5px;
  border-left: 1.5px solid var(--mz-color-accent-light);
  border-bottom: 1.5px solid var(--mz-color-accent-light);
  transform: rotate(-45deg) translate(1px, -1px);
}

.mz-reg-div-item:has(input:checked) {
  border-color: color-mix(in srgb, var(--mz-color-accent) 45%, transparent);
  background: color-mix(in srgb, var(--mz-color-accent-dark) 12%, transparent);
}

.mz-reg-div-icon {
  width: 22px; height: 22px;
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mz-reg-div-icon img {
  width: 100%; height: 100%;
  object-fit: contain;
  filter: brightness(2) sepia(1) hue-rotate(10deg) saturate(0.7);
  opacity: 0.75;
}

.mz-reg-div-name {
  font-size: 11px;
  font-weight: 700;
  color: var(--mz-color-text);
  line-height: 1.25;
}

.mz-reg-div-item:has(input:checked) .mz-reg-div-name {
  color: var(--mz-color-accent-light);
}

/* ── Responsive: صفين على الهاتف فقط ── */
@media (max-width: 540px) {
  .mz-reg-divisions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Step */
.mz-reg-step { }
.mz-reg-step--hidden { display: none; }

/* ── Primary Selection ── */
.mz-reg-primary-label {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--mz-color-accent) 65%, transparent);
  margin-bottom: 6px;
}

.mz-reg-primary-hint {
  color: color-mix(in srgb, var(--mz-color-text-muted) 55%, transparent);
  font-size: 12px;
  line-height: 1.55;
  margin-bottom: 14px;
}

.mz-reg-primary-list {
  display: grid;
  gap: 8px;
  margin-bottom: 4px;
}

.mz-primary-option {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 13px 14px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--mz-color-accent) 18%, transparent);
  background: color-mix(in srgb, var(--mz-color-bg-dark) 35%, transparent);
  color: color-mix(in srgb, var(--mz-color-text) 78%, transparent);
  font-family: var(--mz-font-body);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: .18s ease;
  text-align: left;
}

[dir="rtl"] .mz-primary-option { text-align: right; }

.mz-primary-option:hover {
  border-color: color-mix(in srgb, var(--mz-color-accent) 38%, transparent);
  background: color-mix(in srgb, var(--mz-color-accent) 6%, transparent);
}

.mz-primary-option--selected {
  border-color: color-mix(in srgb, var(--mz-color-accent) 60%, transparent);
  background: color-mix(in srgb, var(--mz-color-accent-dark) 20%, transparent);
  color: var(--mz-color-accent-light);
}

.mz-primary-option-icon {
  width: 34px; height: 34px;
  flex: 0 0 auto;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--mz-color-accent) 20%, transparent);
  background: color-mix(in srgb, var(--mz-color-bg-dark) 40%, transparent);
  display: flex; align-items: center; justify-content: center;
  padding: 7px;
}

.mz-primary-option-icon img {
  width: 100%; height: 100%;
  object-fit: contain;
  filter: brightness(2) sepia(1) hue-rotate(10deg) saturate(0.7);
  opacity: 0.75;
}

.mz-primary-option--selected .mz-primary-option-icon {
  border-color: color-mix(in srgb, var(--mz-color-accent) 50%, transparent);
  background: color-mix(in srgb, var(--mz-color-accent-dark) 25%, transparent);
}

.mz-primary-option-name { flex: 1; }

.mz-primary-option-check {
  flex: 0 0 auto;
  width: 20px; height: 20px;
  border-radius: 50%;
  border: 1px solid color-mix(in srgb, var(--mz-color-accent) 20%, transparent);
  background: color-mix(in srgb, var(--mz-color-bg-dark) 35%, transparent);
  display: flex; align-items: center; justify-content: center;
  color: transparent;
  transition: .18s ease;
}

.mz-primary-option--selected .mz-primary-option-check {
  border-color: color-mix(in srgb, var(--mz-color-accent) 65%, transparent);
  background: color-mix(in srgb, var(--mz-color-accent-dark) 40%, transparent);
  color: var(--mz-color-accent-light);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   PORTAL MODAL
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.mz-portal-meta {
  margin-top: 4px;
  display: grid;
  gap: 8px;
  margin-bottom: 16px;
}

.mz-portal-meta-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--mz-color-accent) 14%, transparent);
  background: color-mix(in srgb, var(--mz-color-bg-dark) 30%, transparent);
  font-size: 13px;
}

.mz-portal-meta-row span:first-child {
  color: color-mix(in srgb, var(--mz-color-text-muted) 60%, transparent);
  font-weight: 500;
  font-size: 12px;
  flex: 0 0 auto;
}

.mz-portal-meta-row strong {
  color: var(--mz-color-text);
  font-weight: 600;
  text-align: right;
}

[dir="rtl"] .mz-portal-meta-row strong { text-align: left; }

.mz-portal-meta-row code {
  color: color-mix(in srgb, var(--mz-color-accent) 70%, transparent);
  font-size: 11px;
  font-family: 'Courier New', monospace;
  letter-spacing: 0.04em;
}

.mz-portal-status-badge {
  padding: 3px 9px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--mz-color-accent) 30%, transparent);
  background: color-mix(in srgb, var(--mz-color-accent) 8%, transparent);
  color: var(--mz-color-accent-light);
  font-size: 11px;
  font-weight: 600;
}

/* Other Divisions Widget */
.mz-portal-other-divs {
  margin-bottom: 14px;
  padding: 14px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--mz-color-accent) 14%, transparent);
  background: color-mix(in srgb, var(--mz-color-bg-dark) 25%, transparent);
}

.mz-portal-other-label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--mz-color-text-muted) 55%, transparent);
  margin-bottom: 10px;
}

.mz-portal-other-list {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.mz-other-div-chip {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--mz-color-accent) 22%, transparent);
  background: color-mix(in srgb, var(--mz-color-accent) 6%, transparent);
  color: color-mix(in srgb, var(--mz-color-text) 75%, transparent);
  font-family: var(--mz-font-body);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: .18s ease;
}

.mz-other-div-chip:hover {
  border-color: color-mix(in srgb, var(--mz-color-accent) 48%, transparent);
  background: color-mix(in srgb, var(--mz-color-accent) 12%, transparent);
  color: var(--mz-color-accent-light);
  transform: translateY(-1px);
}

.mz-other-div-icon {
  width: 14px; height: 14px;
  object-fit: contain;
  filter: brightness(2) sepia(1) hue-rotate(10deg) saturate(0.6);
  opacity: 0.70;
}

/* Portal note */
.mz-portal-note {
  color: color-mix(in srgb, var(--mz-color-text-muted) 50%, transparent);
  font-size: 12px;
  line-height: 1.55;
  margin-bottom: 14px;
}

/* Portal actions */
.mz-portal-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.mz-portal-actions .mz-btn-primary {
  flex: 1;
  justify-content: center;
}


/* ===================================================
   AUTH PAGE — صفحة تسجيل الدخول المستقلة
   =================================================== */

body.mz-auth-page {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding: 0;
  margin: 0;
  background:
    radial-gradient(ellipse 900px 600px at 20% -10%, color-mix(in srgb, var(--mz-color-accent-hover) 18%, transparent), transparent 60%),
    radial-gradient(ellipse 700px 500px at 85% 10%,  color-mix(in srgb, var(--mz-color-accent-hover) 10%, transparent), transparent 60%),
    radial-gradient(ellipse 600px 400px at 50% 90%,  color-mix(in srgb, var(--mz-color-accent-dark)  7%, transparent), transparent 60%),
    linear-gradient(180deg, var(--mz-color-bg-dark) 0%, var(--mz-color-bg) 100%);
  overflow-x: hidden;
}

.mz-auth-back {
  position: fixed;
  top: 20px;
  left: 24px;
  display: flex;
  align-items: center;
  gap: 6px;
  color: color-mix(in srgb, var(--mz-color-accent) 65%, transparent);
  font-size: 13px;
  font-weight: 500;
  text-decoration: none;
  z-index: 100;
  transition: color .2s;
  letter-spacing: 0.02em;
}

[dir="rtl"] .mz-auth-back { left: auto; right: 24px; }
.mz-auth-back:hover { color: var(--mz-color-accent); }
.mz-auth-back svg { transition: transform .2s; }
.mz-auth-back:hover svg { transform: translateX(-3px); }
[dir="rtl"] .mz-auth-back:hover svg { transform: translateX(3px) scaleX(-1); }

.mz-auth-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 56px;
  margin-bottom: 28px;
  z-index: 10;
  position: relative;
}

.mz-auth-brand img { height: 34px; width: auto; }

.mz-auth-brand-name {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--mz-color-text);
  text-transform: uppercase;
}

/* Modal في وضع صفحة Auth */
#mz101AuthModal.mz-auth-page-open {
  position: relative !important;
  inset: auto !important;
  display: flex !important;
  align-items: flex-start;
  justify-content: center;
  padding: 0 20px 60px;
  z-index: auto !important;
  width: 100%;
  box-sizing: border-box;
}

#mz101AuthModal.mz-auth-page-open .mz-modal-backdrop {
  display: none !important;
}

#mz101AuthModal.mz-auth-page-open .mz-modal-panel {
  position: relative;
  width: min(520px, 100%);
  max-height: none;
  overflow-y: visible;
  border: 1px solid var(--mz-color-border-soft);
  background: linear-gradient(155deg, var(--mz-color-surface) 0%, var(--mz-color-surface-2) 60%, var(--mz-color-bg-dark) 100%);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--mz-color-accent) 6%, transparent),
    var(--mz-shadow-lg);
}

#mz101AuthModal.mz-auth-page-open .mz-modal-close {
  display: none !important;
}

/* Reset Password */
.mz-auth-reset-wrapper {
  width: min(520px, 100%);
  margin: 0 20px 60px;
  padding: 32px;
  border-radius: 20px;
  border: 1px solid var(--mz-color-border-soft);
  background: linear-gradient(155deg, var(--mz-color-surface) 0%, var(--mz-color-surface-2) 60%, var(--mz-color-bg-dark) 100%);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--mz-color-accent) 6%, transparent),
    var(--mz-shadow-lg);
  position: relative;
  box-sizing: border-box;
}

.mz-auth-reset-wrapper::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1.5px;
  background: linear-gradient(90deg,
    transparent,
    color-mix(in srgb, var(--mz-color-accent) 60%, transparent),
    color-mix(in srgb, var(--mz-color-accent) 90%, transparent),
    color-mix(in srgb, var(--mz-color-accent) 60%, transparent),
    transparent
  );
  border-radius: 20px 20px 0 0;
  pointer-events: none;
}

.mz-auth-reset-wrapper h2 {
  color: var(--mz-color-accent-pale);
  font-size: 20px;
  font-weight: 700;
  margin: 0 0 24px;
  text-align: center;
}

[dir="rtl"] .mz-auth-reset-wrapper h2 { text-align: right; }

.mz-auth-reset-wrapper input[type="password"] {
  width: 100%;
  box-sizing: border-box;
  background: color-mix(in srgb, var(--mz-color-accent) 4%, transparent);
  border: 1px solid color-mix(in srgb, var(--mz-color-accent) 18%, transparent);
  color: var(--mz-color-text);
  border-radius: 10px;
  padding: 12px 16px;
  font-size: 15px;
  margin-bottom: 12px;
  outline: none;
  transition: border-color .2s, background .2s;
  direction: ltr;
}

.mz-auth-reset-wrapper input[type="password"]:focus {
  background: color-mix(in srgb, var(--mz-color-accent) 6%, transparent);
  border-color: color-mix(in srgb, var(--mz-color-accent) 45%, transparent);
}

.mz-auth-reset-wrapper button[type="submit"] {
  width: 100%;
  background: linear-gradient(135deg, var(--mz-color-accent), var(--mz-color-accent-hover));
  color: var(--mz-color-text-dark);
  border: none;
  border-radius: 10px;
  padding: 13px;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  margin-top: 8px;
  transition: opacity .2s, transform .15s;
  letter-spacing: 0.02em;
}

.mz-auth-reset-wrapper button[type="submit"]:hover {
  opacity: 0.88;
  transform: translateY(-1px);
}

/* براند داخل الـ modal — صفحة Auth فقط */
.mz-auth-panel-brand {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 20px 26px 0;
  margin-bottom: -4px;
}

.mz-auth-panel-brand img {
  height: 28px;
  width: auto;
}

.mz-auth-panel-brand-name {
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--mz-color-text);
  text-transform: uppercase;
}

/* إخفاء البراند الخارجي في صفحة Auth */
body.mz-auth-page .mz-auth-brand {
  display: none;
}

/* =========================================================
   AUTH EXPERIENCE V17 — Professional MA-ZAL Gateway UI
   This block intentionally overrides the older auth modal layout.
   ========================================================= */

.mz-modal .mz-auth-panel--pro {
  width: min(1080px, 96vw);
  max-height: 92vh;
  padding: 0;
  display: grid;
  grid-template-columns: minmax(320px, .92fr) minmax(390px, 1.08fr);
  overflow: hidden;
  border-radius: 28px;
  background:
    linear-gradient(140deg, color-mix(in srgb, var(--mz-color-surface-3) 96%, #000 4%), color-mix(in srgb, var(--mz-color-surface-2) 92%, #000 8%));
}

.mz-auth-panel--pro .mz-auth-hero,
.mz-auth-panel--pro .mz-auth-main {
  min-width: 0;
}

.mz-auth-hero {
  position: relative;
  padding: 34px;
  overflow: hidden;
  isolation: isolate;
  background:
    radial-gradient(circle at 16% 12%, color-mix(in srgb, var(--mz-color-accent) 25%, transparent), transparent 28%),
    radial-gradient(circle at 82% 78%, color-mix(in srgb, var(--mz-color-accent-dark) 22%, transparent), transparent 34%),
    linear-gradient(155deg, color-mix(in srgb, var(--mz-color-bg-dark) 72%, transparent), color-mix(in srgb, var(--mz-color-surface-3) 82%, transparent));
  border-inline-end: 1px solid color-mix(in srgb, var(--mz-color-accent) 14%, transparent);
}

.mz-auth-hero::before {
  content: "";
  position: absolute;
  inset: 16px;
  border: 1px solid color-mix(in srgb, var(--mz-color-accent) 14%, transparent);
  border-radius: 22px;
  pointer-events: none;
  z-index: -1;
}

.mz-auth-hero-glow {
  position: absolute;
  width: 260px;
  height: 260px;
  border-radius: 999px;
  inset-inline-start: -80px;
  bottom: -90px;
  background: color-mix(in srgb, var(--mz-color-accent) 18%, transparent);
  filter: blur(28px);
  opacity: .72;
  pointer-events: none;
}

.mz-auth-hero-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 46px;
}

.mz-auth-hero-brand img {
  width: 58px;
  height: 58px;
  object-fit: contain;
  filter: drop-shadow(0 14px 22px rgba(0,0,0,.26));
}

.mz-auth-hero-brand strong {
  display: block;
  color: var(--mz-color-text);
  font-size: 19px;
  line-height: 1;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.mz-auth-hero-kicker,
.mz-modal-kicker {
  display: block;
  margin-bottom: 8px;
  color: color-mix(in srgb, var(--mz-color-accent) 72%, transparent);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.mz-auth-hero-copy h2 {
  margin: 0;
  color: var(--mz-color-text);
  font-family: var(--mz-font-display);
  font-size: clamp(30px, 4vw, 48px);
  font-weight: 730;
  line-height: .98;
  letter-spacing: -.04em;
}

.mz-auth-hero-copy p {
  max-width: 35em;
  margin: 18px 0 0;
  color: color-mix(in srgb, var(--mz-color-text-muted) 70%, transparent);
  font-size: 14px;
  line-height: 1.75;
}

.mz-auth-hero-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 24px;
}

.mz-auth-hero-pills span {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 13px;
  border-radius: 999px;
  color: color-mix(in srgb, var(--mz-color-accent-light) 86%, transparent);
  background: color-mix(in srgb, var(--mz-color-accent) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--mz-color-accent) 18%, transparent);
  font-size: 12px;
  font-weight: 750;
}

.mz-auth-hero-stack {
  display: grid;
  gap: 10px;
  margin-top: 34px;
}

.mz-auth-hero-card {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 14px;
  border-radius: 18px;
  background: rgba(255,255,255,.045);
  border: 1px solid color-mix(in srgb, var(--mz-color-accent) 14%, transparent);
  box-shadow: 0 14px 28px rgba(0,0,0,.10);
}

.mz-auth-hero-card-icon {
  width: 38px;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  color: var(--mz-color-accent-light);
  background: color-mix(in srgb, var(--mz-color-accent) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--mz-color-accent) 20%, transparent);
  font-size: 12px;
  font-weight: 900;
}

.mz-auth-hero-card strong {
  display: block;
  color: var(--mz-color-text);
  font-size: 13px;
  font-weight: 800;
  line-height: 1.25;
}

.mz-auth-hero-card p {
  margin: 3px 0 0;
  color: color-mix(in srgb, var(--mz-color-text-muted) 62%, transparent);
  font-size: 11px;
  line-height: 1.45;
}

.mz-auth-main {
  padding: 32px;
  overflow: auto;
  max-height: 92vh;
}

.mz-auth-main::-webkit-scrollbar { width: 5px; }
.mz-auth-main::-webkit-scrollbar-track { background: transparent; }
.mz-auth-main::-webkit-scrollbar-thumb {
  background: color-mix(in srgb, var(--mz-color-accent) 25%, transparent);
  border-radius: 20px;
}

.mz-auth-panel--pro .mz-modal-head {
  margin-bottom: 18px;
}

.mz-auth-panel--pro .mz-modal-title {
  color: var(--mz-color-text);
  font-size: clamp(27px, 3vw, 38px);
  letter-spacing: -.035em;
}

.mz-auth-panel--pro .mz-modal-sub {
  max-width: 34em;
  margin-top: 8px;
  font-size: 13px;
  line-height: 1.65;
}

.mz-auth-panel--pro .mz-auth-tabs {
  padding: 6px;
  gap: 6px;
  border-radius: 18px;
  margin-bottom: 24px;
  background: color-mix(in srgb, var(--mz-color-bg-dark) 52%, transparent);
}

.mz-auth-panel--pro .mz-auth-tab {
  min-height: 42px;
  border-radius: 14px;
  font-weight: 800;
}

.mz-auth-panel--pro .mz-auth-tab--active {
  background: linear-gradient(135deg, color-mix(in srgb, var(--mz-color-accent) 26%, transparent), color-mix(in srgb, var(--mz-color-accent-dark) 22%, transparent));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--mz-color-accent) 25%, transparent);
}

.mz101-field {
  margin-bottom: 14px;
}

.mz101-field label {
  display: block;
  margin-bottom: 8px;
  color: color-mix(in srgb, var(--mz-color-text-muted) 72%, transparent);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .07em;
  text-transform: uppercase;
}

.mz101-field input,
.mz101-field select,
.mz101-field textarea {
  width: 100%;
  box-sizing: border-box;
  min-height: 48px;
  border-radius: 15px;
  border: 1px solid color-mix(in srgb, var(--mz-color-accent) 18%, transparent);
  background: color-mix(in srgb, var(--mz-color-bg-dark) 48%, transparent);
  color: var(--mz-color-text);
  padding: 0 15px;
  outline: none;
  transition: border-color .18s ease, background .18s ease, box-shadow .18s ease;
}

.mz101-field input:focus,
.mz101-field select:focus,
.mz101-field textarea:focus {
  border-color: color-mix(in srgb, var(--mz-color-accent) 55%, transparent);
  background: color-mix(in srgb, var(--mz-color-bg-dark) 36%, transparent);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--mz-color-accent) 10%, transparent);
}

.mz-auth-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.mz-auth-remember {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  margin: -2px 0 10px;
  color: color-mix(in srgb, var(--mz-color-text-muted) 70%, transparent);
  font-size: 13px;
  cursor: pointer;
}

.mz-auth-remember input {
  width: 16px;
  height: 16px;
  accent-color: var(--mz-color-accent);
}

.mz-auth-panel--pro .mz-auth-actions {
  margin-top: 18px;
  gap: 12px;
}

.mz-auth-panel--pro .mz-btn-primary,
.mz-auth-panel--pro .mz-auth-submit {
  min-height: 48px;
  border-radius: 15px;
  font-weight: 900;
  letter-spacing: .02em;
}

.mz101-btn-link {
  flex: 0 0 auto;
  min-height: 48px;
  padding: 0 12px;
  border: 0;
  background: transparent;
  color: color-mix(in srgb, var(--mz-color-accent-light) 78%, transparent);
  font-weight: 800;
  cursor: pointer;
}

.mz-auth-under-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 14px;
  color: color-mix(in srgb, var(--mz-color-text-muted) 65%, transparent);
  font-size: 12px;
}

.mz-auth-under-actions button {
  border: 0;
  padding: 0;
  background: transparent;
  color: var(--mz-color-accent-light);
  font-weight: 900;
  cursor: pointer;
}

.mz-reg-divisions-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
  margin-top: 4px;
}

.mz-reg-interests-note {
  flex: 0 0 auto;
  margin-bottom: 10px;
  padding: 7px 10px;
  border-radius: 999px;
  color: color-mix(in srgb, var(--mz-color-accent-light) 82%, transparent);
  background: color-mix(in srgb, var(--mz-color-accent) 9%, transparent);
  border: 1px solid color-mix(in srgb, var(--mz-color-accent) 18%, transparent);
  font-size: 11px;
  font-weight: 850;
  white-space: nowrap;
}

.mz-auth-panel--pro .mz-reg-divisions {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.mz-auth-panel--pro .mz-reg-div-item {
  align-items: flex-start;
  min-height: 86px;
  padding: 13px;
  gap: 10px;
  border-radius: 18px;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--mz-color-bg-dark) 44%, transparent), color-mix(in srgb, var(--mz-color-surface-3) 72%, transparent));
}

.mz-auth-panel--pro .mz-reg-div-check {
  margin-top: 4px;
  border-radius: 999px;
}

.mz-auth-panel--pro .mz-reg-div-icon {
  width: 34px;
  height: 34px;
  padding: 7px;
  border-radius: 13px;
  background: color-mix(in srgb, var(--mz-color-accent) 7%, transparent);
  border: 1px solid color-mix(in srgb, var(--mz-color-accent) 14%, transparent);
}

.mz-reg-div-copy {
  display: block;
  min-width: 0;
  flex: 1;
}

.mz-reg-div-copy small {
  display: block;
  margin-top: 4px;
  color: color-mix(in srgb, var(--mz-color-text-muted) 58%, transparent);
  font-size: 10.5px;
  line-height: 1.35;
  font-weight: 600;
}

.mz-auth-panel--pro .mz-reg-div-name {
  font-size: 12px;
  font-weight: 900;
}

.mz-auth-panel--pro .mz-reg-div-item:has(input:checked) {
  transform: translateY(-1px);
  box-shadow: 0 16px 36px rgba(0,0,0,.14);
}

.mz-auth-panel--pro .mz-primary-option {
  border-radius: 18px;
  padding: 14px;
}

.mz-auth-error {
  margin: 0 0 14px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--mz-color-error) 36%, transparent);
  background: color-mix(in srgb, var(--mz-color-error) 10%, transparent);
  color: color-mix(in srgb, var(--mz-color-error) 85%, #fff 15%);
  font-size: 12px;
  font-weight: 750;
  line-height: 1.5;
}

body.mz-auth-page #mz101AuthModal.mz-auth-page-open {
  padding: 34px 20px 70px;
}

#mz101AuthModal.mz-auth-page-open .mz-modal-panel.mz-auth-panel--pro {
  width: min(1080px, 100%);
  box-shadow: 0 26px 90px rgba(0,0,0,.26);
}

@media (max-width: 920px) {
  .mz-modal .mz-auth-panel--pro {
    grid-template-columns: 1fr;
    width: min(620px, 96vw);
  }

  .mz-auth-hero {
    padding: 24px;
    border-inline-end: 0;
    border-bottom: 1px solid color-mix(in srgb, var(--mz-color-accent) 14%, transparent);
  }

  .mz-auth-hero-brand { margin-bottom: 24px; }
  .mz-auth-hero-copy h2 { font-size: 31px; }
  .mz-auth-hero-stack { grid-template-columns: 1fr; margin-top: 20px; }
  .mz-auth-main { max-height: none; padding: 24px; }
}

@media (max-width: 560px) {
  .mz-modal { padding: 12px; }
  .mz-modal .mz-auth-panel--pro { max-height: 96vh; border-radius: 22px; }
  .mz-auth-hero { display: none; }
  .mz-auth-main { padding: 20px; }
  .mz-auth-form-grid { grid-template-columns: 1fr; gap: 0; }
  .mz-auth-panel--pro .mz-reg-divisions { grid-template-columns: 1fr; }
  .mz-reg-divisions-head { display: block; }
  .mz-reg-interests-note { display: inline-flex; margin: 0 0 10px; }
  .mz-auth-panel--pro .mz-auth-actions { flex-direction: column; align-items: stretch; }
  .mz101-btn-link { min-height: 36px; }
}

/* PWA auth modal: keep register/recover panels scrollable inside the installed app. */
html.mz101-pwa-app .mz-modal.mz-is-open {
  z-index: 2147483020;
  align-items: stretch;
  justify-content: center;
  padding: max(12px, env(safe-area-inset-top)) 12px max(82px, env(safe-area-inset-bottom));
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

html.mz101-pwa-app .mz-modal.mz-is-open .mz-modal-panel {
  width: min(620px, 100%);
  max-height: calc(100dvh - 104px - env(safe-area-inset-bottom));
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}

html.mz101-pwa-app .mz-modal.mz-is-open .mz-auth-main {
  max-height: none;
  overflow: visible;
}

html.mz101-pwa-app .mz-modal.mz-is-open .mz-auth-hero {
  display: none;
}

html.mz101-pwa-app .mz-modal.mz-is-open .mz-auth-panel--pro {
  display: block;
}
