@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap');

:root {
    --primary-green: #10B981;
    --primary-green-hover: #059669;
    --dark-green: #064E3B;
    --light-green: #D1FAE5;
    --bg-color: #F8FAFC;
    --text-main: #1E293B;
    --text-muted: #64748B;
    --card-bg: #FFFFFF;
    --border-color: #E2E8F0;
    --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);
    --radius-md: 0.75rem;
    --radius-lg: 1rem;
}

body {
    font-family: 'Plus Jakarta Sans', sans-serif;
    background-color: var(--bg-color);
    color: var(--text-main);
    -webkit-font-smoothing: antialiased;
    font-size: 1.05rem;
}

h1, h2, h3, h4, h5, h6 { font-weight: 700; color: var(--text-main); }

.sidebar { background-color: var(--card-bg); border-right: 1px solid var(--border-color); box-shadow: var(--shadow-sm); z-index: 1055 !important; }
.sidebar h4 { color: var(--primary-green) !important; font-weight: 800; letter-spacing: -0.5px; }
.sidebar .nav-link { color: var(--text-muted); font-weight: 600; border-radius: var(--radius-md); margin-bottom: 0.25rem; padding: 0.75rem 1rem; transition: all 0.2s ease; }
.sidebar .nav-link:hover, .sidebar .nav-link.active { background-color: var(--light-green); color: var(--dark-green); }
.sidebar .nav-link i { transition: transform 0.2s ease; }
.sidebar .nav-link:hover i { transform: scale(1.1); }

.main-content { flex-grow: 1; padding: 2.5rem; width: 100%; min-height: 100vh; overflow-x: hidden; background-color: var(--bg-color); }
@media (max-width: 768px) {
    .main-content { padding: 1rem; min-height: calc(100vh - 60px); }
    .sidebar.offcanvas-md { border-right: none; box-shadow: none; }
    .btn { padding: 0.85rem 1.5rem; font-size: 1.15rem; }
    .btn-sm { padding: 0.6rem 1.1rem !important; font-size: 1.05rem !important; }
}
.card { background: var(--card-bg); border: 1px solid var(--border-color); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); transition: transform 0.2s ease, box-shadow 0.2s ease; overflow: hidden; }
.card:hover { box-shadow: var(--shadow-md); }
.card-header { background-color: var(--card-bg); border-bottom: 1px solid var(--border-color); font-weight: 600; padding: 1.25rem 1.5rem; }
.card-body { padding: 1.5rem; }

.btn { font-weight: 600; border-radius: var(--radius-md); padding: 0.6rem 1.25rem; transition: all 0.2s ease; }
.btn-primary { background-color: var(--primary-green); border-color: var(--primary-green); color: white; }
.btn-primary:hover, .btn-primary:focus { background-color: var(--primary-green-hover) !important; border-color: var(--primary-green-hover) !important; transform: translateY(-1px); box-shadow: var(--shadow-md); }

.table { margin-bottom: 0; }
.table th { background-color: #F8FAFC !important; color: var(--text-muted) !important; font-weight: 700; text-transform: uppercase; font-size: 0.85rem; letter-spacing: 0.05em; padding: 1.2rem 1.5rem; border-bottom: 1px solid var(--border-color); }
.table td { padding: 1.2rem 1.5rem; vertical-align: middle; color: var(--text-main); border-bottom: 1px solid var(--border-color); font-size: 1.05rem; }

.badge { padding: 0.4em 0.8em; border-radius: 9999px; font-weight: 600; letter-spacing: 0.025em; }
.bg-success { background-color: var(--primary-green) !important; color: white !important;}
.bg-warning { background-color: #F59E0B !important; color: #FFF !important; }
.bg-danger { background-color: #EF4444 !important; color: white !important;}
.bg-primary { background-color: var(--dark-green) !important; color: white !important;}

.form-control, .form-select { border: 1px solid var(--border-color); border-radius: var(--radius-md); padding: 0.6rem 1rem; transition: all 0.2s ease; }
.form-control:focus, .form-select:focus { border-color: var(--primary-green); box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.1); }

.login-card { border: none; box-shadow: var(--shadow-lg) !important; border-radius: 1.5rem !important; overflow: hidden; }
.login-header { background: linear-gradient(135deg, var(--primary-green) 0%, var(--dark-green) 100%); color: white; padding: 2.5rem 2rem 1.5rem; text-align: center; }
