/* css/style.css */

/*
  Definisi Variabel Tema (Theme Variables)
  Meniru palet warna default "Slate" dari shadcn/ui.
*/
:root {
  --background: 210 40% 98%; /* abu-abu sangat muda */
  --foreground: 222.2 84% 4.9%; /* setara dengan `slate-950` */

  --card: 0 0% 100%;
  --card-foreground: 222.2 84% 4.9%;

  --popover: 0 0% 100%;
  --popover-foreground: 222.2 84% 4.9%;

  --primary: 222.2 84% 4.9%;
  --primary-foreground: 210 40% 98%; /* setara dengan `slate-50` */

  --secondary: 210 40% 96.1%; /* setara dengan `slate-100` */
  --secondary-foreground: 222.2 47.4% 11.2%; /* setara dengan `slate-900` */

  --muted: 210 40% 96.1%;
  --muted-foreground: 215.4 16.3% 46.9%; /* setara dengan `slate-500` */

  --border: 214.3 31.8% 91.4%; /* setara dengan `slate-200` */
  --input: 214.3 31.8% 91.4%;
  --ring: 222.2 84% 4.9%;

  --radius: 0.5rem; /* setara dengan `rounded-lg` */
}

/* BARU: Definisi warna untuk mode gelap */
.dark {
  --background: 222.2 84% 4.9%;
  --foreground: 210 40% 98%;
  --card: 222.2 84% 4.9%;
  --card-foreground: 210 40% 98%;
  --popover: 222.2 84% 4.9%;
  --popover-foreground: 210 40% 98%;
  --primary: 210 40% 98%;
  --primary-foreground: 222.2 47.4% 11.2%;
  --secondary: 217.2 32.6% 17.5%;
  --secondary-foreground: 210 40% 98%;
  --muted: 217.2 32.6% 17.5%;
  --muted-foreground: 215 20.2% 65.1%;
  --border: 217.2 32.6% 17.5%;
  --input: 217.2 32.6% 17.5%;
  --ring: 212.7 26.8% 83.9%;
}

/* Aturan dasar untuk body */
body {
  font-family: "Inter", sans-serif;
  background-color: hsl(var(--background));
  color: hsl(var(--foreground));
  /* Menjadikan body sebagai kontainer flex vertikal */
  display: flex;
  flex-direction: column;
  /* Memastikan body memiliki tinggi minimal setinggi layar */
  min-height: 100vh;
}

/* Animasi untuk spinner loading */
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

.loading-spinner {
  width: 20px;
  height: 20px;
  border: 2px solid transparent;
  border-top-color: hsl(var(--primary-foreground));
  border-radius: 50%;
  animation: spin 1s linear infinite;
}
/* === TOAST NOTIFICATION STYLES (Pojok Kanan Atas dengan Tombol Close) === */

#toast-container {
  position: fixed;
  /* REVISI: Diubah ke pojok kanan atas */
  top: 20px;
  right: 20px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.toast {
  display: flex;
  align-items: center;
  justify-content: space-between; /* Membuat jarak antara teks dan tombol */
  gap: 15px; /* Jarak antara teks dan tombol */
  padding: 14px 20px;
  border-radius: 10px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  font-size: 14px;
  font-weight: 500;
  color: hsl(var(--foreground));
  background-color: hsl(var(--background));
  border: 1px solid hsl(var(--border));
  /* REVISI: Animasi dari kanan */
  animation: slideInRight 0.4s cubic-bezier(0.21, 1.02, 0.73, 1), fadeOutRight 0.5s ease-in 3.5s forwards;
  min-width: 300px;
}

.toast-success {
  background-color: #f0fff4; /* green-50 */
  border-left: 4px solid #38a169; /* green-600 */
  color: #2f855a; /* green-800 */
}

/* Varian untuk notifikasi error */
.toast-error {
  background-color: #fff5f5; /* Merah muda */
  border-left: 4px solid #e53e3e; /* Merah */
  color: #c53030;
}

/* Tombol Close di dalam Toast */
.toast-close-btn {
  background: none;
  border: none;
  color: hsl(var(--muted-foreground));
  cursor: pointer;
  padding: 0;
  opacity: 0.6;
  transition: opacity 0.2s;
}

.toast-close-btn:hover {
  opacity: 1;
}

/* Animasi baru dari kanan */
@keyframes slideInRight {
  from {
    opacity: 0;
    transform: translateX(100%);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes fadeOutRight {
  from {
    opacity: 1;
    transform: translateX(0);
  }
  to {
    opacity: 0;
    transform: translateX(100%);
  }
}

main {
  /* Membuat area konten utama tumbuh dan mengisi ruang kosong */
  flex-grow: 1;
}
