/* ==========================================================
   BASE — AstraOps Design System
   Globales Layout · Reset · Animationen · Utility-Klassen
   ========================================================== */

/* ----------------------------------------------------------
   1. RESET & BOX MODEL
   ---------------------------------------------------------- */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* ----------------------------------------------------------
   2. BODY & HINTERGRUND
   Kein overflow:hidden → Website muss scrollen!
   bg.jpg scrollt nicht mit (Parallax-Effekt via fixed)
   ---------------------------------------------------------- */
body {
  font-family: 'Outfit', sans-serif;
  font-weight: 400;
  min-height: 100vh;
  background: url('../img/bg.jpg') center / cover no-repeat fixed,
              radial-gradient(ellipse at 20% 50%, rgba(138,99,255,0.15) 0%, transparent 60%),
              radial-gradient(ellipse at 80% 20%, rgba(99,179,237,0.12) 0%, transparent 55%),
              #0d0a1e;
  background-blend-mode: normal;
  overflow-x: hidden;
  color: var(--text-primary);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ----------------------------------------------------------
   3. APP-LAYOUT (Grid für Dashboard-Seiten)
   Topbar 64px oben · Sidebar 240px links · Main rechts
   ---------------------------------------------------------- */
.app-layout {
  display: grid;
  grid-template-rows: var(--topbar-height) 1fr;
  grid-template-columns: var(--sidebar-width) 1fr;
  grid-template-areas:
    "topbar  topbar"
    "sidebar main";
  min-height: 100vh;
}

/* ----------------------------------------------------------
   4. MAIN CONTENT
   ---------------------------------------------------------- */
.main-content {
  grid-area: main;
  padding: 28px 32px;
  overflow-y: auto;
  min-height: calc(100vh - var(--topbar-height));
  animation: fadeInUp 0.7s var(--ease-smooth) both;
}

/* ----------------------------------------------------------
   5. SEITEN-HEADER
   ---------------------------------------------------------- */
.page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  margin-bottom: 28px;
}

.page-header__title {
  font-size: 1.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  background: linear-gradient(90deg, #fff 60%, rgba(138,99,255,0.8));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-shadow: none; /* kein text-shadow bei clip-text */
  filter: drop-shadow(0 0 12px rgba(138,99,255,0.4));
}

.page-header__subtitle {
  font-size: 0.88rem;
  font-weight: 400;
  color: var(--text-secondary);
  margin-top: 4px;
}

/* ----------------------------------------------------------
   6. GLASMORPHISMUS-KARTE (.glass-card)
   Zentrale Bauelement für alle Panels & Karten
   ---------------------------------------------------------- */
.glass-card {
  position: relative;
  border-radius: var(--radius-card);
  border: 1px solid rgba(255,255,255,0.1);
  background: radial-gradient(
    ellipse at 30% 20%,
    rgba(60,50,120,0.4),
    rgba(20,15,40,0.88) 70%
  );
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow:
    0 8px 40px rgba(138,99,255,0.22),
    0 4px 12px rgba(0,0,0,0.45),
    inset 0 1px 0 rgba(255,255,255,0.1);
  padding: 24px 28px;
  overflow: hidden;
}

/* Ambient-Border-Glow */
.glass-card::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(
    135deg,
    rgba(138,99,255,0.5),
    rgba(186,85,211,0.3) 40%,
    rgba(99,179,237,0.2) 70%,
    rgba(138,99,255,0.4)
  );
  -webkit-mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  animation: borderBreath 4s ease-in-out infinite;
  pointer-events: none;
}

/* Varianten */
.glass-card--teal {
  box-shadow: 0 8px 40px rgba(100,221,200,0.18), 0 4px 12px rgba(0,0,0,0.45), inset 0 1px 0 rgba(255,255,255,0.1);
}
.glass-card--blue {
  box-shadow: 0 8px 40px rgba(99,179,237,0.2), 0 4px 12px rgba(0,0,0,0.45), inset 0 1px 0 rgba(255,255,255,0.1);
}
.glass-card--danger {
  box-shadow: 0 8px 40px rgba(255,107,107,0.2), 0 4px 12px rgba(0,0,0,0.45), inset 0 1px 0 rgba(255,255,255,0.1);
}
.glass-card--success {
  box-shadow: 0 8px 40px rgba(52,211,153,0.2), 0 4px 12px rgba(0,0,0,0.45), inset 0 1px 0 rgba(255,255,255,0.1);
}

/* ----------------------------------------------------------
   7. BUTTONS
   ---------------------------------------------------------- */

/* Basis */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 22px;
  border-radius: var(--radius-btn);
  border: 1px solid transparent;
  font-family: 'Outfit', sans-serif;
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.5px;
  cursor: pointer;
  text-decoration: none;
  transition: all var(--transition-base);
  position: relative;
  overflow: hidden;
  white-space: nowrap;
}

/* Shimmer-Effekt */
.btn::after {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 60%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.12), transparent);
  transform: skewX(-20deg);
  transition: none;
}
.btn:hover::after {
  animation: shimmer 0.6s ease forwards;
}

/* Primär */
.btn-primary {
  background: linear-gradient(135deg, rgba(138,99,255,0.9), rgba(186,85,211,0.9));
  border-color: rgba(255,255,255,0.15);
  color: #fff;
  box-shadow: 0 4px 20px rgba(138,99,255,0.4);
}
.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 30px rgba(138,99,255,0.55);
  filter: brightness(1.05);
}
.btn-primary:active { transform: translateY(0) scale(0.98); }

/* Sekundär */
.btn-secondary {
  background: rgba(48,43,99,0.5);
  border-color: rgba(255,255,255,0.12);
  color: var(--text-primary);
  backdrop-filter: blur(10px);
}
.btn-secondary:hover {
  border-color: var(--border-active);
  box-shadow: 0 0 18px var(--glow-purple);
  transform: translateY(-2px);
}

/* Ghost */
.btn-ghost {
  background: transparent;
  border-color: rgba(138,99,255,0.4);
  color: var(--text-primary);
}
.btn-ghost:hover {
  background: var(--primary-purple-15);
  border-color: var(--primary-purple);
}

/* Danger */
.btn-danger {
  background: linear-gradient(135deg, rgba(255,107,107,0.9), rgba(220,60,60,0.9));
  color: #fff;
  box-shadow: 0 4px 20px rgba(255,107,107,0.35);
}

/* Icon-Button */
.btn-icon {
  width: 40px; height: 40px;
  padding: 0;
  border-radius: var(--radius-btn);
  background: var(--surface-glass);
  border: 1px solid var(--border-subtle);
  backdrop-filter: blur(10px);
  display: flex; align-items: center; justify-content: center;
}
.btn-icon:hover {
  transform: scale(1.1);
  box-shadow: 0 0 16px var(--glow-purple);
  border-color: var(--border-active);
}

/* ----------------------------------------------------------
   8. BADGES & STATUS-CHIPS
   ---------------------------------------------------------- */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  border-radius: var(--radius-badge);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  backdrop-filter: blur(6px);
  border: 1px solid;
}

.badge--active  { background: rgba(100,221,200,0.15); border-color: rgba(100,221,200,0.4); color: #64ddc8; }
.badge--planned { background: rgba(99,179,237,0.15);  border-color: rgba(99,179,237,0.4);  color: #63b3ed; }
.badge--open    { background: rgba(251,191,36,0.15);  border-color: rgba(251,191,36,0.4);  color: #fbbf24; }
.badge--missing { background: rgba(255,107,107,0.15); border-color: rgba(255,107,107,0.4); color: #ff6b6b; }
.badge--done    { background: rgba(52,211,153,0.15);  border-color: rgba(52,211,153,0.4);  color: #34d399; }

/* Status-Dot */
.status-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}
.status-dot--active  { background: var(--status-active);  animation: statusPulse 2s ease-in-out infinite; }
.status-dot--planned { background: var(--status-info); }
.status-dot--open    { background: var(--status-warning); }
.status-dot--missing { background: var(--status-danger); }

/* ----------------------------------------------------------
   9. FORMULAR-ELEMENTE
   ---------------------------------------------------------- */
.form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.form-label {
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.5px;
  color: var(--text-secondary);
}

.form-input {
  width: 100%;
  padding: 12px 16px;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-btn);
  background: var(--surface-input);
  backdrop-filter: blur(10px);
  color: #fff;
  font-family: 'Outfit', sans-serif;
  font-size: 0.95rem;
  transition: border-color 0.3s, box-shadow 0.3s;
  outline: none;
}
.form-input::placeholder { color: var(--text-muted); }
.form-input:focus {
  border-color: rgba(138,99,255,0.7);
  box-shadow: 0 0 18px rgba(138,99,255,0.3);
}
.form-input--error {
  border-color: var(--status-danger) !important;
}

.form-error {
  font-size: 0.78rem;
  color: var(--status-danger);
  animation: fadeInDown 0.3s var(--ease-smooth) both;
}

/* Select */
.form-select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.4)' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 40px;
}

/* ----------------------------------------------------------
   10. UTILITY-KLASSEN
   ---------------------------------------------------------- */
.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

.gradient-text {
  background: linear-gradient(90deg, #8A63FF, #BA55D3);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.text-muted   { color: var(--text-muted) !important; }
.text-secondary { color: var(--text-secondary) !important; }

/* ----------------------------------------------------------
   11. ANIMATIONEN
   ---------------------------------------------------------- */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeInDown {
  from { opacity: 0; transform: translateY(-16px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeInLeft {
  from { opacity: 0; transform: translateX(-24px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes fadeInRight {
  from { opacity: 0; transform: translateX(24px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes shimmer {
  0%   { left: -100%; }
  100% { left: 150%; }
}
@keyframes borderBreath {
  0%, 100% { opacity: 0.6; }
  50%       { opacity: 1; }
}
@keyframes statusPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(100,221,200,0.4); }
  50%       { box-shadow: 0 0 0 8px rgba(100,221,200,0); }
}
@keyframes notifPulse {
  0%   { transform: scale(1); }
  30%  { transform: scale(1.3); }
  60%  { transform: scale(0.9); }
  100% { transform: scale(1); }
}
@keyframes float {
  0%, 100% { transform: translateY(0px); }
  50%       { transform: translateY(-12px); }
}
@keyframes particleDrift {
  0%   { transform: translateY(0) translateX(0) scale(1);   opacity: 0.6; }
  33%  { transform: translateY(-30px) translateX(15px) scale(1.1); opacity: 1; }
  66%  { transform: translateY(-15px) translateX(-10px) scale(0.9); opacity: 0.7; }
  100% { transform: translateY(0) translateX(0) scale(1);   opacity: 0.6; }
}
@keyframes orbitSpin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes glowPulse {
  0%, 100% { opacity: 0.4; transform: scale(1); }
  50%       { opacity: 0.8; transform: scale(1.05); }
}
@keyframes spin {
  to { transform: rotate(360deg); }
}

/* ----------------------------------------------------------
   12. SCROLLBAR (Webkit)
   ---------------------------------------------------------- */
::-webkit-scrollbar       { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: rgba(20,15,40,0.5); }
::-webkit-scrollbar-thumb { background: rgba(138,99,255,0.4); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: rgba(138,99,255,0.7); }

/* ----------------------------------------------------------
   13. SELECTION
   ---------------------------------------------------------- */
::selection {
  background: rgba(138,99,255,0.35);
  color: #fff;
}
