.mag-no-scroll { overflow: hidden; }

.mag-shell {
  max-width: 760px;
  margin: 32px auto;
  padding: 0 16px;
}

.mag-card {
  background: linear-gradient(180deg, rgba(7,12,24,.96), rgba(8,10,18,.96));
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 24px;
  box-shadow: 0 24px 80px rgba(0,0,0,.28);
  color: #edf1ff;
  padding: 28px;
}

.mag-card--hero {
  background:
    radial-gradient(circle at top center, rgba(87,117,255,.22), transparent 34%),
    linear-gradient(180deg, rgba(8,12,24,.98), rgba(7,10,18,.98));
}

.mag-eyebrow,
.mag-modal__eyebrow {
  margin: 0 0 8px;
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(237,241,255,.62);
  font-weight: 700;
}

.mag-title {
  margin: 0 0 10px;
  font-size: clamp(28px, 4vw, 38px);
  line-height: 1.08;
  color: #fff;
}

.mag-subtitle,
.mag-modal__desc {
  margin: 0 0 20px;
  color: rgba(237,241,255,.78);
  line-height: 1.7;
}

.mag-form,
.mag-login-form {
  display: grid;
  gap: 14px;
}

.mag-field {
  display: grid;
  gap: 8px;
}

.mag-field span,
.mag-checkbox span,
.mag-links-row a,
.mag-modal__link {
  color: rgba(237,241,255,.84);
}

.mag-field input {
  width: 100%;
  min-height: 50px;
  padding: 0 16px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: #fff;
  outline: none;
}

.mag-field input:focus {
  border-color: rgba(116,149,255,.6);
  box-shadow: 0 0 0 4px rgba(116,149,255,.12);
}

.mag-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, #111d3a, #0c1222);
  color: #fff !important;
  text-decoration: none !important;
  font-weight: 700;
  box-shadow: 0 14px 36px rgba(13, 25, 62, .38);
  cursor: pointer;
}

.mag-button:hover { transform: translateY(-1px); }
.mag-button-full { width: 100%; }

.mag-button-secondary {
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.12);
  box-shadow: none;
}

.mag-checkbox {
  display: inline-flex;
  gap: 8px;
  align-items: center;
}

.mag-links-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 18px;
  margin-top: 14px;
}

.mag-alert {
  margin: 0 0 16px;
  border-radius: 14px;
  padding: 12px 14px;
  font-size: 14px;
  border: 1px solid transparent;
}

.mag-alert.success {
  background: rgba(28, 165, 110, .12);
  border-color: rgba(28, 165, 110, .25);
  color: #b8f5d8;
}

.mag-alert.error {
  background: rgba(255, 88, 88, .12);
  border-color: rgba(255, 88, 88, .24);
  color: #ffd0d0;
}

.mag-feature-grid,
.mag-account-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  margin: 18px 0 22px;
}

.mag-feature-box,
.mag-account-item {
  padding: 16px;
  border-radius: 18px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  color: rgba(237,241,255,.92);
}

.mag-account-item {
  display: grid;
  gap: 6px;
}

.mag-account-item strong {
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(237,241,255,.6);
}

.mag-modal {
  position: fixed;
  inset: 0;
  z-index: 999999;
  display: none;
}

.mag-modal.is-open { display: block; }

.mag-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(4, 7, 14, .72);
  backdrop-filter: blur(5px);
}

.mag-modal__dialog {
  position: relative;
  width: min(100% - 24px, 480px);
  margin: 8vh auto 0;
  background:
    radial-gradient(circle at top center, rgba(87,117,255,.22), transparent 34%),
    linear-gradient(180deg, rgba(8,12,24,.98), rgba(7,10,18,.98));
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 28px;
  box-shadow: 0 24px 70px rgba(0,0,0,.44);
  overflow: hidden;
}

.mag-modal__content { padding: 28px; }

.mag-modal__close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 40px;
  height: 40px;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.05);
  color: #fff;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
}

.mag-modal__actions {
  display: grid;
  gap: 12px;
  margin-top: 16px;
}

.mag-modal__link {
  text-align: center;
  text-decoration: none;
}

.mag-menu-item--outline > a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 14px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
}

.mag-menu-item--outline > a::after {
  display: none !important;
}


@media (max-width: 768px) {
  .mag-card,
  .mag-modal__content { padding: 22px; }
  .mag-modal__dialog {
    width: min(100% - 14px, 480px);
    margin-top: 4vh;
  }
}


.account-favorites{
  margin-top:34px;
  padding-top:24px;
  border-top:1px solid var(--line);
}

.account-favorites__title{
  margin:0 0 16px;
  font-size:24px;
  line-height:1.1;
}

.account-favorites__grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(180px, 1fr));
  gap:16px;
}

.account-favorite-card{
  position:relative;
  overflow:hidden;
  border:1px solid var(--line);
  background:var(--surface);
  border-radius:18px;
}

.account-favorite-card__link{
  display:block;
}

.account-favorite-card__thumb{
  aspect-ratio:4 / 5;
  overflow:hidden;
  background:#111;
}

.account-favorite-card__thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.account-favorite-card__body{
  padding:12px 14px 14px;
}

.account-favorite-card__title{
  margin:0;
  font-size:15px;
  line-height:1.35;
}

.account-favorites__empty{
  padding:16px 18px;
  border-radius:16px;
  border:1px solid var(--line);
  background:var(--surface);
  color:var(--muted);
}

.account-favorite-card .msp-favorite-btn--card{
  top:10px;
  right:10px;
}

@media (max-width: 767px){
  .account-favorites__grid{
    grid-template-columns:repeat(2, minmax(0,1fr));
    gap:12px;
  }
}