/* ===========================
   PixlCrafter Custom UI Kit
   =========================== */

/* --- Neon Glow Effects --- */
.neon-glow {
  box-shadow: 0 0 12px var(--color-primary),
              0 0 24px var(--color-secondary),
              inset 0 0 6px var(--color-primary);
}

.neon-border {
  border: 1px solid var(--color-primary);
  box-shadow: 0 0 8px var(--color-primary);
}

/* --- Buttons --- */
.btn {
  border: none;
  border-radius: 6px;
  font-weight: 600;
  cursor: pointer;
  transition: 0.2s;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 90px;
  height: 34px;
  font-size: 14px;
  margin: 3px;
  padding: 0 12px;
}

.btn.small { min-width: 60px; height: 28px; font-size: 12px; }

/* Color Variants */
.btn.primary   { background: var(--color-primary); color: #fff; }
.btn.secondary { background: var(--color-secondary); color: #fff; }
.btn.accent    { background: var(--color-accent); color: #fff; }
.btn.danger    { background: var(--color-danger); color: #fff; }
.btn.warning   { background: var(--color-warning); color: #000; }

/* Glow on hover */
.btn:hover {
  filter: brightness(1.1);
  box-shadow: 0 0 14px currentColor;
}

/* --- Badges --- */
.badge {
  display: inline-block;
  padding: 3px 8px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  margin: 2px;
}

.badge.success { background: var(--color-accent); color: #fff; }
.badge.error   { background: var(--color-danger); color: #fff; }
.badge.warn    { background: var(--color-warning); color: #000; }
.badge.info    { background: var(--color-secondary); color: #fff; }

/* --- Switch (Plugin Manager) --- */
.switch {
  position: relative;
  display: inline-block;
  width: 46px;
  height: 22px;
}
.switch input { display: none; }

.slider {
  position: absolute;
  cursor: pointer;
  top: 0; left: 0; right: 0; bottom: 0;
  background: #333;
  transition: .3s;
  border-radius: 22px;
}
.slider:before {
  position: absolute;
  content: "";
  height: 18px; width: 18px;
  left: 2px; bottom: 2px;
  background: #fff;
  transition: .3s;
  border-radius: 50%;
}
input:checked + .slider {
  background: var(--color-primary);
  box-shadow: 0 0 12px var(--color-primary);
}
input:checked + .slider:before {
  transform: translateX(24px);
}

/* --- Calendar Grid --- */
/* --- Calendar Grid --- */
.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 10px;
  margin-top: 20px;
  max-width: 80%;   /* z. B. */
  margin: 0 auto;     /* zentriert */
}

.calendar-day {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 10px;
  padding: 8px;
  text-align: center;
  font-size: 13px;
  transition: 0.2s;
  aspect-ratio: 1 / 1;   /* 🔥 macht die Kacheln quadratisch */
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.calendar-day:hover {
  box-shadow: 0 0 14px var(--color-primary);
  transform: translateY(-3px);
}

.calendar-day.today {
  border: 2px solid var(--color-primary);
  background: rgba(168,85,247,0.2);
  box-shadow: 0 0 18px var(--color-primary);
}

.day-label {
  font-weight: 600;
  margin-bottom: 6px;
}

.day-tasks {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

/* --- Utility --- */
.text-glow {
  color: var(--color-primary);
  text-shadow: 0 0 6px var(--color-primary);
}
.card-glow {
  box-shadow: 0 0 14px rgba(168,85,247,0.6);
}
.subtitle {
  color: #aaa;
  margin-top: 4px;
}
