/*
 * assets/css/style.css
 * Clean, Modern, Responsive Styles inspired by Tailwind CSS
 */

/* 1. CSS Reset & Box Sizing */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

/* 2. Root Variables (Color Palette & Spacing) */
:root {
    /* Colors */
    --color-primary-500: #6366f1; /* Indigo */
    --color-primary-600: #4f46e5;
    --color-primary-700: #4338ca;

    --color-success-500: #22c55e; /* Green */
    --color-success-600: #16a34a;

    --color-danger-500: #ef4444; /* Red */
    --color-danger-600: #dc2626;

    --color-warning-500: #f59e0b; /* Amber */
    --color-warning-600: #d97706;

    --color-info-500: #3b82f6; /* Blue */
    --color-info-600: #2563eb;

    --color-gray-50: #f9fafb;
    --color-gray-100: #f3f4f6; /* Used for body background */
    --color-gray-200: #e5e7eb;
    --color-gray-300: #d1d5db;
    --color-gray-400: #9ca3af;
    --color-gray-500: #6b7280;
    --color-gray-600: #4b5563;
    --color-gray-700: #374151;
    --color-gray-800: #1f2937; /* Used for main text color */
    --color-gray-900: #111827;

    /* Spacing (similar to Tailwind's default spacing scale) */
    --spacing-xs: 0.25rem; /* 4px */
    --spacing-sm: 0.5rem;  /* 8px */
    --spacing-md: 1rem;    /* 16px */
    --spacing-lg: 1.5rem;  /* 24px */
    --spacing-xl: 2rem;    /* 32px */
    --spacing-2xl: 3rem;   /* 48px */
    --spacing-3xl: 4rem;   /* 64px */

    /* Border Radius */
    --rounded-sm: 0.125rem;
    --rounded-md: 0.375rem; /* 6px */
    --rounded-lg: 0.5rem;
    --rounded-full: 9999px;

    /* Shadows */
    --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}

/* 3. Base Styles (Body, Typography) */
body {
    font-family: 'Poppins', sans-serif;
    background-color: var(--color-gray-100);
    color: var(--color-gray-800);
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
    font-weight: 600; /* Semi-bold */
    color: var(--color-gray-800);
    margin-bottom: var(--spacing-md);
}

h1 { font-size: 2.25rem; line-height: 2.5rem; } /* text-4xl */
h2 { font-size: 1.875rem; line-height: 2.25rem; } /* text-3xl */
h3 { font-size: 1.5rem; line-height: 2rem; }    /* text-2xl */
h4 { font-size: 1.25rem; line-height: 1.75rem; } /* text-xl */
h5 { font-size: 1.125rem; line-height: 1.75rem; } /* text-lg */
h6 { font-size: 1rem; line-height: 1.5rem; }     /* text-base */

a {
    color: var(--color-primary-600);
    text-decoration: none;
    transition: color 0.2s ease-in-out;
}
a:hover {
    color: var(--color-primary-700);
}

p {
    margin-bottom: var(--spacing-md);
}

/* 4. Layout & Container */
.container {
    max-width: 1280px; /* Max width, adjust as needed */
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}
@media (min-width: 640px) { /* sm breakpoint */
    .container { padding-left: var(--spacing-lg); padding-right: var(--spacing-lg); }
}
@media (min-width: 1024px) { /* lg breakpoint */
    .container { padding-left: var(--spacing-2xl); padding-right: var(--spacing-2xl); }
}

/* 5. Utility Classes (Tailwind-like) */
/* This is a subset, you can add more as needed following the pattern */

/* Flexbox */
.flex { display: flex; }
.inline-flex { display: inline-flex; }
.flex-col { flex-direction: column; }
.flex-wrap { flex-wrap: wrap; }
.justify-start { justify-content: flex-start; }
.justify-end { justify-content: flex-end; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.items-start { align-items: flex-start; }
.items-end { align-content: flex-end; }
.items-center { align-items: center; }
.self-center { align-self: center; }
.flex-grow { flex-grow: 1; }
.flex-shrink-0 { flex-shrink: 0; }
.space-y-3 > :not([hidden]) ~ :not([hidden]) { margin-top: 0.75rem; } /* 12px */
.space-y-4 > :not([hidden]) ~ :not([hidden]) { margin-top: 1rem; } /* 16px */


.gap-1 { gap: var(--spacing-xs); }
.gap-2 { gap: var(--spacing-sm); }
.gap-3 { gap: var(--spacing-md); }
.gap-4 { gap: var(--spacing-lg); }
.gap-5 { gap: var(--spacing-xl); }

/* Spacing */
.mt-0 { margin-top: 0; } .mt-1 { margin-top: var(--spacing-xs); } .mt-2 { margin-top: var(--spacing-sm); } .mt-3 { margin-top: var(--spacing-md); } .mt-4 { margin-top: var(--spacing-lg); } .mt-5 { margin-top: var(--spacing-xl); } .mt-6 { margin-top: var(--spacing-2xl); } .mt-8 { margin-top: var(--spacing-3xl); }
.mb-0 { margin-bottom: 0; } .mb-1 { margin-bottom: var(--spacing-xs); } .mb-2 { margin-bottom: var(--spacing-sm); } .mb-3 { margin-bottom: var(--spacing-md); } .mb-4 { margin-bottom: var(--spacing-lg); } .mb-5 { margin-bottom: var(--spacing-xl); } .mb-6 { margin-bottom: var(--spacing-2xl); }
.mr-0 { margin-right: 0; } .mr-1 { margin-right: var(--spacing-xs); } .mr-2 { margin-right: var(--spacing-sm); } .mr-3 { margin-right: var(--spacing-md); } .mr-4 { margin-right: var(--spacing-lg); } .mr-5 { margin-right: var(--spacing-xl); }
.ml-0 { margin-left: 0; } .ml-1 { margin-left: var(--spacing-xs); } .ml-2 { margin-left: var(--spacing-sm); } .ml-3 { margin-left: var(--spacing-md); } .ml-4 { margin-left: var(--spacing-lg); } .ml-auto { margin-left: auto; }
.mx-auto { margin-left: auto; margin-right: auto; }
.my-0 { margin-top: 0; margin-bottom: 0; } .my-1 { margin-top: var(--spacing-xs); margin-bottom: var(--spacing-xs); } .my-2 { margin-top: var(--spacing-sm); margin-bottom: var(--spacing-sm); } .my-3 { margin-top: var(--spacing-md); margin-bottom: var(--spacing-md); } .my-4 { margin-top: var(--spacing-lg); margin-bottom: var(--spacing-lg); } .my-5 { margin-top: var(--spacing-xl); margin-bottom: var(--spacing-xl); } .my-8 { margin-top: var(--spacing-3xl); bottom: var(--spacing-3xl); }

.p-3 { padding: var(--spacing-md); }
.p-4 { padding: var(--spacing-lg); }
.p-6 { padding: var(--spacing-2xl); }
.py-3 { padding-top: var(--spacing-md); padding-bottom: var(--spacing-md); } /* New utility */
.py-4 { padding-top: var(--spacing-lg); padding-bottom: var(--spacing-lg); }
.py-6 { padding-top: var(--spacing-2xl); padding-bottom: var(--spacing-2xl); }
.py-8 { padding-top: var(--spacing-3xl); padding-bottom: var(--spacing-3xl); }
.px-4 { padding-left: var(--spacing-lg); padding-right: var(--spacing-lg); }
.pb-4 { padding-bottom: var(--spacing-lg); }
.pr-1 { padding-right: var(--spacing-xs); }


/* Width & Height */
.w-full { width: 100%; }
.w-auto { width: auto; }
.h-auto { height: auto; }
.max-w-xs { max-width: 20rem; } /* 320px */
.max-w-md { max-width: 28rem; } /* 448px */
.max-w-lg { max-width: 32rem; } /* 512px */
.max-w-xl { max-width: 36rem; } /* 576px */

/* Text Alignment & Decoration */
.text-left { text-align: left; }
.text-center { text-align: center; }
.text-right { text-align: right; }
.leading-none { line-height: 1; } /* For custom close button */
.leading-tight { line-height: 1.25; } /* Tailwind's leading-tight */

/* Font Sizing & Weight */
.text-xs { font-size: 0.75rem; line-height: 1rem; }
.text-sm { font-size: 0.875rem; line-height: 1.25rem; }
.text-base { font-size: 1rem; line-height: 1.5rem; }
.text-lg { font-size: 1.125rem; line-height: 1.75rem; }
.text-xl { font-size: 1.25rem; line-height: 1.75rem; }
.text-2xl { font-size: 1.5rem; line-height: 2rem; }
.font-light { font-weight: 300; }
.font-normal { font-weight: 400; }
.font-medium { font-weight: 500; }
.font-semibold { font-weight: 600; }
.font-bold { font-weight: 700; }
.font-sans { font-family: 'Poppins', sans-serif; }

/* Colors */
.text-gray-50 { color: var(--color-gray-50); }
.text-gray-400 { color: var(--color-gray-400); }
.text-gray-500 { color: var(--color-gray-500); }
.text-gray-600 { color: var(--color-gray-600); }
.text-gray-700 { color: var(--color-gray-700); }
.text-gray-800 { color: var(--color-gray-800); }
.text-indigo-600 { color: var(--color-primary-600); }
.text-indigo-700 { color: var(--color-primary-700); }
.text-red-600 { color: var(--color-danger-500); }
.text-red-800 { color: var(--color-danger-600); }
.bg-white { background-color: #fff; }
.bg-gray-50 { background-color: var(--color-gray-50); }
.bg-gray-100 { background-color: var(--color-gray-100); }
.bg-indigo-50 { background-color: #eef2ff; } /* Light indigo */
.bg-indigo-600 { background-color: var(--color-primary-600); }
.bg-green-500 { background-color: var(--color-success-500); }
.bg-red-500 { background-color: var(--color-danger-500); }
.bg-yellow-500 { background-color: var(--color-warning-500); }
.bg-blue-600 { background-color: var(--color-info-600); } /* For blue text/icons like recurring */


/* Borders */
.border { border-width: 1px; border-style: solid; border-color: var(--color-gray-300); }
.border-gray-200 { border-color: var(--color-gray-200); }
.border-gray-300 { border-color: var(--color-gray-300); }
.border-gray-400 { border-color: var(--color-gray-400); }
.border-b { border-bottom-width: 1px; border-bottom-style: solid; }
.rounded-sm { border-radius: var(--rounded-sm); }
.rounded-md { border-radius: var(--rounded-md); }
.rounded-lg { border-radius: var(--rounded-lg); }
.rounded-full { border-radius: var(--rounded-full); }

/* Shadows */
.shadow-sm { box-shadow: var(--shadow-sm); }
.shadow-md { box-shadow: var(--shadow-md); }
.shadow-lg { box-shadow: var(--shadow-lg); }

/* Display & Visibility */
.block { display: block; }
.inline-block { display: inline-block; }
.hidden { display: none; } /* Used by JS to toggle visibility */

/* Transitions */
.transition { transition-property: all; transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); transition-duration: 150ms; } /* ease-in-out */
.duration-300 { transition-duration: 300ms; }

/* Hover States (direct application to nav-item, etc.) */
.hover\:text-indigo-600:hover { color: var(--color-primary-600); }
.hover\:border-indigo-500:hover { border-color: var(--color-primary-500); }
.hover\:bg-indigo-700:hover { background-color: var(--color-primary-700); }
.hover\:text-red-800:hover { color: var(--color-danger-600); }
.hover\:text-gray-600:hover { color: var(--color-gray-600); }
.hover\:bg-gray-100:hover { background-color: var(--color-gray-100); }


/* Responsive Utilities */
@media (min-width: 640px) { /* sm breakpoint */
    .sm\:px-6 { padding-left: var(--spacing-lg); padding-right: var(--spacing-lg); }
    .sm\:flex-row { flex-direction: row; }
    .sm\:w-auto { width: auto; }
    .sm\:justify-start { justify-content: flex-start; }
    .sm\:justify-end { justify-content: flex-end; }
    .sm\:items-center { align-items: center; }
    .sm\:gap-2 { gap: var(--spacing-sm); }
    .sm\:mt-0 { margin-top: 0; }
}
@media (min-width: 768px) { /* md breakpoint */
    .md\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .md\:inline-block { display: inline-block; }
    .md\:hidden { display: none; }
    .md\:col-span-2 { grid-column: span 2 / span 2; } /* Untuk item yang mengambil 2 kolom */
    .md\:col-span-3 { grid-column: span 3 / span 3; } /* Untuk item yang mengambil 3 kolom */
    .md\:col-span-4 { grid-column: span 4 / span 4; } /* Untuk item yang mengambil 4 kolom */
}
@media (min-width: 1024px) { /* lg breakpoint - equivalent to Tailwind's lg: */
    .lg\:flex { display: flex !important; } /* Override hidden */
    .lg\:hidden { display: none !important; }
    .lg\:inline-block { display: inline-block; }
    .lg\:w-auto { width: auto; }
    .lg\:items-center { align-items: center; }
    .lg\:mt-0 { margin-top: 0; }
    .lg\:px-8 { padding-left: var(--spacing-2xl); padding-right: var(--spacing-2xl); }
}


/* 6. Component-specific Styles (Override/Enhance existing components) */

/* Navbar */
.navbar {
    z-index: 100; /* Pastikan navbar di atas konten lain, tapi di bawah modal */
    background-color: var(--color-primary-600); /* Make entire navbar blue */
    color: white; /* White text for navbar */
}
.navbar .brand a {
    color: white; /* Brand text white */
}
.navbar .brand a:hover {
    color: var(--color-gray-200); /* Lighter white on hover */
}
.navbar #nav-toggle {
    border-color: white; /* White border for hamburger */
    color: white; /* White icon for hamburger */
}
.navbar #nav-toggle:hover {
    color: var(--color-gray-200);
    border-color: var(--color-gray-200);
}

.navbar .nav-links {
    /* Mobile styles */
    display: none; /* Default hidden on mobile */
    flex-direction: column;
    width: 100%;
    background-color:white; /* Background putih solid saat menu terbuka di mobile */
    position: absolute;
    top: 64px; /* Adjust based on navbar height, ensure it sits right below navbar header */
    left: 0;
    padding: var(--spacing-md);
    box-shadow: var(--shadow-md);
    border-top: 1px solid var(--color-gray-200);
    z-index: 99; /* Z-index ini harus lebih rendah dari modal overlay (1000) tapi di atas main content */
    background-image: none; /* Mengatasi potensi background transparan dari tempat lain */
    background-clip: padding-box; /* Pastikan background mengisi padding */
    color: var(--color-gray-700); /* Reset text color to gray for menu items */
}
/* When .hidden is removed by JS, it should become flex */
.navbar .nav-links:not(.hidden) {
    display: flex;
}

/* Nav Item Styling */
.nav-item {
    display: block; /* Default block on mobile */
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--rounded-md);
    margin-top: var(--spacing-sm); /* Spacing for mobile menu */
    text-align: left;
    color: var(--color-gray-700); /* Default text color for nav items */
    transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
}
.nav-item:hover {
    background-color: var(--color-gray-100); /* Hover background for regular items in mobile menu */
    color: var(--color-primary-600);
}
.nav-item.nav-button-logout { /* Specific style for logout button */
    padding: var(--spacing-sm) var(--spacing-lg);
    background-color: var(--color-danger-500);
    color: white;
    border-radius: var(--rounded-md);
    margin-top: var(--spacing-md); /* More space on mobile for buttons */
    text-align: center;
}
.nav-item.nav-button-logout:hover {
    background-color: var(--color-danger-600);
    color: white;
}
.nav-item.nav-button-login { /* Specific style for login button */
    padding: var(--spacing-sm) var(--spacing-lg);
    background-color: var(--color-primary-600);
    color: white;
    border-radius: var(--rounded-md);
    margin-top: var(--spacing-md);
    text-align: center;
}
.nav-item.nav-button-login:hover {
    background-color: var(--color-primary-700);
    color: white;
}


@media (min-width: 1024px) { /* lg breakpoint - Desktop styles */
    .navbar .nav-links {
        display: flex !important; /* Always show on desktop, override JS 'hidden' */
        flex-direction: row;
        position: static;
        padding: 0;
        box-shadow: none;
        border-top: none;
        background-color: transparent; /* Untuk desktop, tidak perlu putih solid */
        width: auto;
    }
    .navbar .nav-links .nav-item { /* Reset margin-top from mobile nav-item */
        margin-top: 0;
        margin-left: var(--spacing-md); /* Spacing between links on desktop */
        padding: var(--spacing-xs) var(--spacing-md); /* Smaller padding for desktop */
        text-align: center;
        color: white; /* White text for nav items on blue desktop navbar */
        background-color: transparent; /* Reset background */
    }
    .navbar .nav-links .nav-item:hover {
        background-color: var(--color-primary-700); /* Darker blue hover for desktop nav items */
        color: white;
    }
    /* Specific styles for logout/login/register links on desktop, make them look like buttons */
    .navbar .nav-links .nav-item.nav-button-logout,
    .navbar .nav-links .nav-item.nav-button-login {
        margin-left: var(--spacing-lg); /* Add more space before buttons */
        padding: var(--spacing-sm) var(--spacing-lg);
        font-weight: 500; /* Ensure button weight is consistent */
        background-color: var(--color-danger-500); /* Ensure color applied */
        color: white; /* Ensure text color applied */
    }
    .navbar .nav-links .nav-item.nav-button-login { /* Override for login button */
        background-color: var(--color-primary-600);
    }
    /* Reset hover for specific buttons on desktop to prevent background-color from changing to gray-50 */
    .navbar .nav-links .nav-item.nav-button-logout:hover { background-color: var(--color-danger-600); }
    .navbar .nav-links .nav-item.nav-button-login:hover { background-color: var(--color-primary-700); }
}


/* Flash Messages */
.flash-message {
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
    border-radius: var(--rounded-md);
    font-weight: 500;
    text-align: center;
    border-width: 1px;
    border-style: solid;
}

.flash-message-success {
    background-color: #dcfce7; /* green-100 */
    color: var(--color-success-600);
    border-color: #bbf7d0; /* green-200 */
}

.flash-message-error {
    background-color: #fee2e2; /* red-100 */
    color: var(--color-danger-600);
    border-color: #fca5a5; /* red-200 */
}

.flash-message-info {
    background-color: #dbeafe; /* blue-100 */
    color: var(--color-info-600);
    border-color: #93c5fd; /* blue-300 */
}


/* Form Container & Elements */
.form-container {
    max-width: 448px; /* max-w-md */
    background-color: var(--color-white);
    padding: var(--spacing-2xl);
    border-radius: var(--rounded-lg);
    box-shadow: var(--shadow-md);
    margin-top: var(--spacing-xl);
    margin-bottom: var(--spacing-xl);
    margin-left: auto;
    margin-right: auto;
}
.form-container h2, .form-container h3 {
    text-align: center;
    margin-bottom: var(--spacing-lg);
    color: var(--color-gray-800);
}
.form-group {
    margin-bottom: var(--spacing-md);
}
.form-group label {
    display: block;
    margin-bottom: var(--spacing-xs);
    font-weight: 500;
    color: var(--color-gray-700);
    font-size: var(--text-sm);
}
.form-group input[type="text"],
.form-group input[type="password"],
.form-group input[type="email"],
.form-group input[type="date"],
.form-group input[type="number"],
.form-group input[type="file"],
.form-group textarea,
.form-group select {
    width: 100%;
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--color-gray-300);
    border-radius: var(--rounded-md);
    font-size: var(--text-base);
    background-color: #fff;
    color: var(--color-gray-800);
    transition: border-color 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
}
.form-group input[type="checkbox"] {
    margin-right: var(--spacing-sm);
    transform: scale(1.1); /* Make checkbox slightly larger */
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
    outline: none;
    border-color: var(--color-primary-500);
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.2); /* ring-indigo-200 */
}
.form-group small {
    display: block;
    margin-top: var(--spacing-xs);
    font-size: var(--text-xs);
    color: var(--color-gray-500);
}

/* Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-sm) var(--spacing-lg);
    font-size: var(--text-base);
    font-weight: 500;
    border-radius: var(--rounded-md);
    cursor: pointer;
    border: 1px solid transparent;
    transition: all 0.2s ease-in-out;
    text-decoration: none;
    line-height: 1.25rem; /* Base for single line text */
    white-space: nowrap; /* Prevent button text from wrapping */
}
.btn-primary {
    background-color: var(--color-primary-600);
    color: white;
}
.btn-primary:hover {
    background-color: var(--color-primary-700);
}
.btn-success {
    background-color: var(--color-success-500);
    color: white;
}
.btn-success:hover {
    background-color: var(--color-success-600);
}
.btn-danger {
    background-color: var(--color-danger-500);
    color: white;
}
.btn-danger:hover {
    background-color: var(--color-danger-600);
}
.btn-warning {
    background-color: var(--color-warning-500);
    color: var(--color-gray-800);
}
.btn-warning:hover {
    background-color: var(--color-warning-600);
}
.btn-secondary {
    background-color: var(--color-gray-200);
    color: var(--color-gray-800);
}
.btn-secondary:hover {
    background-color: var(--color-gray-300);
}
.btn-sm {
    padding: var(--spacing-xs) var(--spacing-md);
    font-size: var(--text-sm);
}
/* Ensure submit buttons have primary style */
button[type="submit"] {
    /* No @apply, directly use .btn .btn-primary in HTML */
}


/* Data Table (General - still used for reports, etc.) */
.data-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: var(--spacing-lg);
    background-color: #fff;
    box-shadow: var(--shadow-sm);
    border-radius: var(--rounded-md);
    overflow: hidden; /* For rounded corners */
}
.data-table th, .data-table td {
    border: 1px solid var(--color-gray-200);
    padding: var(--spacing-md);
    text-align: left;
    font-size: var(--text-sm);
    color: var(--color-gray-700);
}
.data-table th {
    background-color: var(--color-gray-50);
    font-weight: 600;
    color: var(--color-gray-800);
    text-transform: uppercase;
    letter-spacing: 0.05em; /* tracking-wider */
}
.data-table tbody tr:nth-child(odd) {
    background-color: #fff;
}
.data-table tbody tr:nth-child(even) {
    background-color: var(--color-gray-50);
}
.data-table tbody tr:hover {
    background-color: var(--color-gray-100);
}
.data-table img {
    max-width: 100px;
    height: auto;
    border-radius: var(--rounded-sm);
    box-shadow: var(--shadow-sm);
}
/* Responsive Table - Stack columns on small screens */
@media (max-width: 768px) {
    .data-table {
        border: none;
        box-shadow: none;
    }
    .data-table thead {
        display: none; /* Hide table headers */
    }
    .data-table, .data-table tbody, .data-table tr, .data-table td {
        display: block; /* Make table elements behave as block-level */
        width: 100%;
    }
    .data-table tr {
        margin-bottom: var(--spacing-md);
        border: 1px solid var(--color-gray-200);
        border-radius: var(--rounded-md);
        box-shadow: var(--shadow-sm);
        padding: var(--spacing-sm);
    }
    .data-table td {
        text-align: right;
        padding-left: 50%; /* Space for pseudo-element label */
        position: relative;
    }
    .data-table td::before {
        content: attr(data-label); /* Use data-label attribute for content */
        position: absolute;
        left: var(--spacing-md);
        width: calc(50% - var(--spacing-md));
        padding-right: var(--spacing-md);
        white-space: nowrap;
        text-align: left;
        font-weight: 600;
        color: var(--color-gray-700);
    }
}


/* Dashboard Global Section Styling */
.card-section {
    margin-top: var(--spacing-lg);
}
.card-section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-md);
    padding: var(--spacing-sm) 0;
}
.card-section-header h3 {
    margin-bottom: 0;
    color: var(--color-gray-900);
}


/* Dashboard Summary Cards */
.summary-cards-dashboard {
    display: flex;
    flex-direction: column; /* Default stack on mobile */
    gap: var(--spacing-lg);
}
@media (min-width: 640px) { /* sm breakpoint */
    .summary-cards-dashboard {
        flex-direction: row; /* Side-by-side on larger screens */
    }
}

.donut-chart-container {
    width: 60px; /* Ukuran chart */
    height: 60px;
    position: relative;
    border-radius: var(--rounded-full);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.donut-chart {
    width: 100%;
    height: 100%;
    border-radius: var(--rounded-full);
    /* conic-gradient set via inline style in PHP */
}
.donut-chart-inner {
    position: absolute;
    width: 40px; /* Ukuran lubang */
    height: 40px;
    background-color: white;
    border-radius: var(--rounded-full);
}
.card .text-success { color: var(--color-success-600); } /* Re-using text-success */
.card .text-danger { color: var(--color-danger-600); } /* Re-using text-danger */


/* Budget Section - Specific Card Styling */
.budget-item {
    position: relative;
    display: flex;
    flex-direction: column; /* Stack vertically on mobile */
    padding: var(--spacing-lg); /* Base padding */
    /* gap: var(--spacing-sm); REMOVED: Will manage spacing manually */
}

/* Header (icon, title, % text) */
.budget-item > .flex:first-child { /* Targets the div containing icon, title, percentage */
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%; /* Take full width */
    margin-bottom: var(--spacing-sm); /* Space below header group */
}
.budget-item-title-group {
    display: flex;
    align-items: center;
    flex-grow: 1;
}
.budget-item-title-group h4 { /* Category Name */
    margin-bottom: 0; /* Override default h4 margin */
}


/* Progress bar container (the grey track) */
.progress-bar-container-budget {
    width: 100%;
    height: 8px; /* Height of the progress bar */
    background-color: var(--color-gray-200);
    border-radius: var(--rounded-full);
    overflow: hidden;
    margin-top: var(--spacing-sm); /* Space below "Terpakai / Anggaran" */
    margin-bottom: var(--spacing-md); /* Space before "Sisa" */
}
/* The actual progress bar (the colored part) */
.progress-bar {
    height: 100%;
    width: 0%; /* Default, set by inline style */
    border-radius: var(--rounded-full);
    transition: width 0.3s ease-in-out;
}
.progress-bar.bg-success { background-color: var(--color-success-500); }
.progress-bar.bg-warning { background-color: var(--color-warning-500); }
.progress-bar.bg-danger { background-color: var(--color-danger-500); }


/* Terpakai / Anggaran values */
.budget-summary-values {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    font-size: var(--text-sm);
    color: var(--color-gray-700);
    margin-bottom: var(--spacing-sm); /* Space before "Sisa" */
}
.budget-summary-values p {
    margin-bottom: 0; /* Override default p margin */
}
.budget-summary-values .font-bold {
    font-weight: 700;
}


/* Sisa (Remaining) text */
.budget-remaining-text {
    width: 100%;
    text-align: right; /* Align "Sisa" to the right */
    margin-bottom: var(--spacing-lg); /* Space before buttons */
    font-size: var(--text-base); /* Slightly larger for emphasis */
    font-weight: 600;
}
.budget-remaining-text p {
    margin-bottom: 0; /* Override default p margin */
}
.budget-remaining-text .text-success { color: var(--color-success-600); }
.budget-remaining-text .text-danger { color: var(--color-danger-600); }


/* Action buttons (Edit / Hapus) */
.budget-actions {
    display: flex;
    gap: var(--spacing-sm); /* Gap between buttons */
    width: 100%; /* Full width for buttons */
}
.budget-actions .btn {
    flex: 1; /* Buttons take equal width */
    font-size: var(--text-base); /* Larger font for buttons */
    padding: var(--spacing-sm) var(--spacing-md); /* More padding for bigger buttons */
}


@media (min-width: 640px) { /* sm breakpoint for budget item */
    .budget-item {
        padding: var(--spacing-xl); /* More padding on desktop */
    }
}


/* Icon Circles (for Budget and Transactions) */
.budget-icon-circle, .transaction-icon-circle, .category-icon-circle { /* Added category-icon-circle */
    width: 40px;
    height: 40px;
    border-radius: var(--rounded-full);
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.25rem; /* text-xl */
    box-shadow: var(--shadow-sm); /* Subtle shadow for icon */
    background-color: var(--color-gray-50); /* Default background */
    color: var(--color-gray-700); /* Default text color */
    flex-shrink: 0; /* Prevent icon from shrinking */
}


/* Progress Bar for Budgets - Dashboard version (keep separate) */
/* This general rule for progress-bar-container is mostly for dashboard, use specific for budget item */
/* .progress-bar-container { height: 8px; margin-top: var(--spacing-xs); margin-bottom: var(--spacing-xs); }
.progress-bar { padding-right: var(--spacing-xs); font-size: 0.65rem; color: white; font-weight: 500; line-height: 8px; } */


/* Reminder Section - Specific Card Styling */
.reminder-item {
    position: relative;
    display: flex;
    flex-direction: column; /* Stack vertically on mobile */
    padding: var(--spacing-lg); /* Base padding */
    gap: var(--spacing-sm); /* Gap for internal elements */
}
.reminder-item .text-warning-600 { /* For 'Belum Lunas' status */
    color: var(--color-warning-600);
}
.reminder-item .btn-sm { /* Override default btn-sm size for toggle buttons */
    padding: var(--spacing-xs) var(--spacing-xs); /* Smaller padding */
    font-size: 0.75rem; /* Smaller font */
    line-height: 1;
    height: 24px; /* Fixed height for round button look */
    width: 24px; /* Fixed width */
    border-radius: var(--rounded-md); /* Slightly rounded */
    box-shadow: var(--shadow-sm);
    border: none; /* No border for toggle */
}
.reminder-item .btn-sm.btn-success { background-color: var(--color-success-500); color: white; }
.reminder-item .btn-sm.btn-warning { background-color: var(--color-warning-500); color: var(--color-gray-800); }


/* Report Sections */
.report-section {
    background-color: var(--color-white);
    padding: var(--spacing-xl);
    margin-top: var(--spacing-lg);
    border-radius: var(--rounded-lg);
    box-shadow: var(--shadow-md);
    text-align: center;
}
.report-section h3 {
    margin-bottom: var(--spacing-lg);
    color: var(--color-gray-800);
}
.report-section p {
    font-size: var(--text-base);
    color: var(--color-gray-700);
}
.report-section strong {
    font-weight: 600;
}
.report-section canvas {
    max-width: 100%; /* Ensure responsiveness */
    height: auto;
    margin-top: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
}

/* Transaksi Section Specific Styles */
.transaction-item {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-md); /* Adjusted padding */
    transition: background-color 0.2s ease-in-out; /* Add transition for hover */
}
.transaction-item:hover {
    background-color: var(--color-gray-50); /* Subtle hover effect */
}

.transaction-indicator {
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    width: 5px; /* Lebar garis indikator */
    border-radius: var(--rounded-sm); /* Slightly rounded ends */
    /* background-color set via inline in PHP */
}
.transaction-item .text-success { color: var(--color-success-600); }
.transaction-item .text-danger { color: var(--color-danger-600); }

/* Transaction Action buttons (specific style for the action buttons inside transaction-item) */
.transaction-actions {
    margin-left: var(--spacing-md); /* Space from amount */
    flex-shrink: 0; /* Don't let buttons shrink */
}
.transaction-actions .btn-sm {
    padding: 6px 10px; /* Slightly larger small buttons for better touch target */
    font-size: 0.8em;
}


/* Floating Action Button */
.floating-action-button-container {
    position: fixed;
    bottom: var(--spacing-2xl); /* 48px from bottom */
    right: var(--spacing-xl);  /* 32px from right */
    display: flex;
    align-items: center;
    z-index: 500; /* Di atas konten tapi di bawah modal */
}
.floating-action-button {
    width: 56px; /* Ukuran FAB */
    height: 56px;
    border-radius: var(--rounded-full);
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.5rem; /* Ukuran ikon */
    box-shadow: var(--shadow-md);
    border: none;
    cursor: pointer;
    transition: all 0.2s ease-in-out;
}
.floating-action-button:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px);
}
/* Hide "Sesuaikan halaman" text on small screens */
@media (max-width: 768px) {
    .floating-action-button-container .ml-3 { /* Targeting the text next to FAB */
        display: none;
    }
}
@media (min-width: 769px) { /* md breakpoint and up */
     .floating-action-button-container .ml-3 { /* Targeting the text next to FAB */
        display: inline-block !important; /* Force display for desktop */
    }
}


/* Small adjustments for utility-like behavior not covered by direct elements */
.text-right { text-align: right; }
.text-success { color: var(--color-success-600); font-weight: 600; }
.text-danger { color: var(--color-danger-600); font-weight: 600; }
.text-blue-600 { color: var(--color-info-600); } /* For recurring icon */
.text-orange-600 { color: var(--color-warning-600); } /* For warning text */


/* Modal Styles */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.6); /* Latar belakang hitam semi-transparan */
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 1000; /* Pastikan modal di atas semua konten */
    opacity: 0; /* Mulai tersembunyi untuk transisi */
    visibility: hidden; /* Tambahkan ini untuk memastikan tidak interaktif saat opacity 0 */
    transition: opacity 0.2s ease-in-out, visibility 0.2s ease-in-out;
}
.modal-overlay:not(.hidden) {
    opacity: 1; /* Tampilkan ketika kelas hidden dihapus */
    visibility: visible;
}

.modal-content {
    background-color: white;
    padding: var(--spacing-xl);
    border-radius: var(--rounded-lg);
    box-shadow: var(--shadow-lg);
    max-width: 600px; /* Lebar maksimal modal */
    width: 90%; /* Lebar responsif */
    transform: translateY(-20px); /* Mulai sedikit ke atas untuk animasi */
    transition: transform 0.2s ease-in-out;
    opacity: 0; /* Mulai tersembunyi */
    overflow-y: auto; /* Agar modal bisa discroll jika kontennya panjang */
    max-height: 90vh; /* Maksimal tinggi modal */
}
.modal-overlay:not(.hidden) .modal-content {
    transform: translateY(0); /* Animasikan ke posisi terlihat */
    opacity: 1; /* Tampilkan konten saat modal muncul */
}

/* Styling for AI Advice Modal Content */
.modal-body h4 { /* For bold headers in AI advice */
    font-size: 1.125rem; /* text-lg */
    font-weight: 600;
    color: var(--color-gray-800);
    margin-top: var(--spacing-md);
    margin-bottom: var(--spacing-sm);
}
.modal-body p { /* For paragraphs in AI advice */
    font-size: var(--text-base);
    color: var(--color-gray-700);
    margin-bottom: var(--spacing-sm);
}
.modal-body ul, .modal-body ol { /* For lists in AI advice */
    list-style-position: inside; /* Ensure bullets/numbers are inside */
    margin-left: var(--spacing-lg); /* Indent lists */
    margin-bottom: var(--spacing-sm);
    color: var(--color-gray-700);
}
.modal-body ul li {
    list-style-type: disc; /* Bullet for unordered */
    margin-bottom: var(--spacing-xs);
}
.modal-body ol li {
    list-style-type: decimal; /* Number for ordered */
    margin-bottom: var(--spacing-xs);
}
.modal-body strong {
    font-weight: 700;
    color: var(--color-gray-900);
}


.modal-header {
    margin-bottom: var(--spacing-md);
    padding-bottom: var(--spacing-sm);
    border-bottom: 1px solid var(--color-gray-200);
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.modal-header h3 {
    margin-bottom: 0; /* Hapus margin bawah h3 di modal header */
}
.modal-header button {
    background: none;
    border: none;
    font-size: 1.5rem; /* Ukuran silang */
    cursor: pointer;
    line-height: 1;
    padding: 0 5px;
    color: var(--color-gray-500);
}
.modal-header button:hover {
    color: var(--color-gray-700);
}
.modal-body {
    /* Padding sudah diatur oleh modal-content */
}

/* Spinner CSS */
.spinner {
  border: 4px solid rgba(0, 0, 0, 0.1);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border-left-color: var(--color-primary-600); /* Blue spinner */
  animation: spin 1s ease infinite;
  margin: auto; /* Center spinner */
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* Untuk mencegah scrolling body saat modal terbuka */
body.overflow-hidden {
    overflow: hidden;
    padding-right: var(--scrollbar-width, 0px); /* Cegah "jump" layout saat scrollbar hilang */
}

/* Styling for AI Advice Modal Content */
.modal-body h4 { /* For bold headers in AI advice */
    font-size: 1.125rem; /* text-lg */
    font-weight: 600;
    color: var(--color-gray-800);
    margin-top: var(--spacing-md);
    margin-bottom: var(--spacing-sm);
}
.modal-body p { /* For paragraphs in AI advice */
    font-size: var(--text-base);
    color: var(--color-gray-700);
    margin-bottom: var(--spacing-sm);
}
.modal-body ul, .modal-body ol { /* For lists in AI advice */
    list-style-position: inside; /* Ensure bullets/numbers are inside */
    margin-left: var(--spacing-lg); /* Indent lists */
    margin-bottom: var(--spacing-sm);
    color: var(--color-gray-700);
}
.modal-body ul li {
    list-style-type: disc; /* Bullet for unordered */
    margin-bottom: var(--spacing-xs);
}
.modal-body ol li {
    list-style-type: decimal; /* Number for ordered */
    margin-bottom: var(--spacing-xs);
}
.modal-body strong {
    font-weight: 700;
    color: var(--color-gray-900);
}