/*
  ============================================================
  DC Gipsy Ebern Website
  Datei: maintenance.css
  Speicherort: assets/css/pages/
  Zweck: Styles für die temporäre Coming-Soon-/Maintenance-Seite.
         Präsentiert den Website-Umbau als futuristischen
         System-Update-Screen.
  Stand: Version 2.0
  ============================================================
*/

.maintenance-page {
  position: relative;
  min-height: 100vh;
  overflow: hidden;

  display: flex;
  align-items: center;
  justify-content: center;

  padding: 42px 20px;

  background: #050505;
}

.maintenance-grid-bg {
  position: absolute;
  inset: 0;

  background-image:
    linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px);

  background-size: 58px 58px;
  mask-image: radial-gradient(circle at center, black 0%, transparent 72%);
}

.maintenance-glow {
  position: absolute;
  width: 620px;
  height: 620px;

  border-radius: 50%;

  background: rgba(179, 0, 255, 0.18);
  filter: blur(100px);

  animation: maintenanceGlow 6s ease-in-out infinite alternate;
}

.maintenance-scanline {
  position: absolute;
  inset: 0;

  pointer-events: none;

  background: linear-gradient(
    to bottom,
    transparent,
    rgba(255, 255, 255, 0.035),
    transparent
  );

  height: 160px;
  animation: scanlineMove 5s linear infinite;
}

.maintenance-panel {
  position: relative;
  z-index: 2;

  width: min(960px, 100%);
  padding: 48px;

  text-align: center;

  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 34px;

  background: rgba(255, 255, 255, 0.045);
  backdrop-filter: blur(18px);

  box-shadow:
    0 30px 90px rgba(0, 0, 0, 0.55),
    inset 0 0 40px rgba(179, 0, 255, 0.035);
}

.maintenance-logo {
  width: 116px;
  margin-bottom: 24px;

  filter: drop-shadow(0 0 32px rgba(179, 0, 255, 0.45));
  animation: logoPulse 3s ease-in-out infinite;
}

.maintenance-kicker {
  margin-bottom: 18px;

  color: var(--primary);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.maintenance-panel h1 {
  margin-bottom: 22px;

  font-family: "Orbitron", sans-serif;
  font-size: clamp(2.8rem, 8vw, 6.2rem);
  line-height: 0.95;
  letter-spacing: 0.035em;

  text-shadow: 0 0 32px rgba(179, 0, 255, 0.36);
}

.maintenance-status {
  min-height: 24px;
  margin-bottom: 18px;

  color: rgba(255, 255, 255, 0.78);
  font-family: "Orbitron", sans-serif;
  font-size: 0.85rem;
  letter-spacing: 0.12em;
}

.maintenance-progress {
  width: min(620px, 100%);
  height: 16px;
  margin: 0 auto 12px;

  overflow: hidden;

  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 999px;

  background: rgba(0, 0, 0, 0.38);
}

.maintenance-progress-bar {
  width: 78%;
  height: 100%;

  border-radius: inherit;

  background: linear-gradient(90deg, #6b2cff, #b300ff, #ffffff);
  box-shadow: 0 0 22px rgba(179, 0, 255, 0.8);

  transition: width 0.8s ease;
}

.maintenance-progress-info {
  width: min(620px, 100%);
  margin: 0 auto 30px;

  display: flex;
  justify-content: space-between;

  color: rgba(255, 255, 255, 0.65);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.14em;
}

.maintenance-text {
  max-width: 700px;
  margin: 0 auto 30px;

  font-size: 1.05rem;
  line-height: 1.8;
  opacity: 0.84;
}

.maintenance-features {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px;

  margin-bottom: 34px;
}

.maintenance-features span {
  padding: 9px 15px;

  border: 1px solid rgba(179, 0, 255, 0.26);
  border-radius: 999px;

  background: rgba(179, 0, 255, 0.08);

  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.maintenance-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;

  margin: 0 auto 34px;
  max-width: 720px;
}

.maintenance-stats div {
  padding: 18px 12px;

  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 22px;

  background: rgba(255, 255, 255, 0.04);
}

.maintenance-stats strong {
  display: block;

  margin-bottom: 6px;

  color: #fff;
  font-family: "Orbitron", sans-serif;
  font-size: 1.4rem;
}

.maintenance-stats small {
  opacity: 0.68;
}

@keyframes maintenanceGlow {
  from {
    transform: scale(0.92);
    opacity: 0.65;
  }

  to {
    transform: scale(1.08);
    opacity: 1;
  }
}

@keyframes scanlineMove {
  from {
    transform: translateY(-180px);
  }

  to {
    transform: translateY(110vh);
  }
}

@keyframes logoPulse {
  0%,
  100% {
    transform: scale(1);
    filter: drop-shadow(0 0 24px rgba(179, 0, 255, 0.38));
  }

  50% {
    transform: scale(1.04);
    filter: drop-shadow(0 0 40px rgba(179, 0, 255, 0.65));
  }
}

@media (max-width: 700px) {
  .maintenance-panel {
    padding: 34px 24px;
    border-radius: 26px;
  }

  .maintenance-logo {
    width: 92px;
  }

  .maintenance-panel h1 {
    font-size: clamp(2.2rem, 12vw, 4rem);
  }

  .maintenance-progress-info {
    gap: 12px;
    flex-direction: column;
  }

  .maintenance-stats {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 430px) {
  .maintenance-stats {
    grid-template-columns: 1fr;
  }

  .maintenance-features span {
    width: 100%;
  }
}

.staff-access {
  margin-top: 50px;
  margin-bottom: 50px;

  text-align: center;

  font-family: "Orbitron", sans-serif;
  font-size: 0.75rem;
  letter-spacing: 3px;

  opacity: 0.35;
  cursor: pointer;

  transition: all 0.3s ease;
}

.staff-access:hover {
  opacity: 1;
  color: #b300ff;

  text-shadow: 0 0 12px rgba(179, 0, 255, 0.6);
}
