/**
 * Custom Elegant & Responsive Styles for SIMANSA v3
 * Modern, clean UI with refined color palette
 */

/* ===============================================
   CSS CUSTOM PROPERTIES - ELEGANT COLOR PALETTE
   =============================================== */

:root {
    --primary: #4f46e5;       /* Indigo */
    --primary-light: #6366f1;
    --primary-dark: #4338ca;
    --secondary: #64748b;     /* Slate */
    --accent: #06b6d4;        /* Cyan/Teal */
    --accent-light: #22d3ee;
    --success: #10b981;       /* Emerald */
    --success-light: #34d399;
    --warning: #f59e0b;       /* Amber */
    --warning-light: #fbbf24;
    --danger: #ef4444;        /* Red */
    --danger-light: #f87171;
    --info: #3b82f6;          /* Blue */
    --info-light: #60a5fa;

    --bg-body: #f1f5f9;       /* Slate-100 */
    --bg-card: #ffffff;
    --bg-sidebar: linear-gradient(180deg, #312e81 0%, #3730a3 40%, #4338ca 100%);
    --text-primary: #1e293b;  /* Slate-800 */
    --text-secondary: #64748b;/* Slate-500 */
    --text-muted: #94a3b8;    /* Slate-400 */
    --border-color: #e2e8f0;  /* Slate-200 */
    --shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
    --shadow-md: 0 4px 6px -1px rgba(0,0,0,0.07), 0 2px 4px -2px rgba(0,0,0,0.05);
    --shadow-lg: 0 10px 15px -3px rgba(0,0,0,0.08), 0 4px 6px -4px rgba(0,0,0,0.04);
    --radius: 0.5rem;
    --radius-lg: 0.75rem;
    --transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ===============================================
   GLOBAL STYLES
   =============================================== */

html {
    font-size: 14px !important;
    scroll-behavior: smooth;
}

body,
body.text-sm {
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
    color: var(--text-primary) !important;
    background-color: var(--bg-body) !important;
    font-family: 'Inter', 'Figtree', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Headings - Clean hierarchy */
.content-header h1 {
    font-size: 1.4rem !important;
    font-weight: 700 !important;
    color: var(--text-primary) !important;
    letter-spacing: -0.01em;
}

h2, .h2 { font-size: 1.25rem !important; font-weight: 600 !important; }
h3, .h3 { font-size: 1.1rem !important; font-weight: 600 !important; }
h4, .h4 { font-size: 0.95rem !important; font-weight: 600 !important; }
h5, .h5 { font-size: 0.875rem !important; font-weight: 600 !important; }
h6, .h6 { font-size: 0.875rem !important; font-weight: 600 !important; }

/* ===============================================
   CARD COMPONENTS - MODERN ELEVATED STYLE
   =============================================== */

.card {
    margin-bottom: 1rem !important;
    border: 1px solid var(--border-color) !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: var(--shadow-sm) !important;
    transition: var(--transition) !important;
    overflow: hidden;
    background: var(--bg-card) !important;
}

.card:hover {
    box-shadow: var(--shadow-md) !important;
}

/* Card Headers - Elegant border-bottom accent */
.card-header {
    padding: 0.75rem 1rem !important;
    background: transparent !important;
    border-bottom: 1px solid var(--border-color) !important;
}

.card-title {
    font-size: 0.95rem !important;
    margin-bottom: 0 !important;
    font-weight: 600 !important;
    color: var(--text-primary) !important;
}

.card-title i {
    font-size: 0.875rem !important;
    color: var(--primary) !important;
    margin-right: 0.35rem;
}

/* Card Body */
.card-body {
    padding: 1rem !important;
}

/* Card Footer */
.card-footer {
    padding: 0.5rem 1rem !important;
    background: rgba(241, 245, 249, 0.5) !important;
    border-top: 1px solid var(--border-color) !important;
}

/* Card Tools */
.card-tools .btn {
    padding: 0.25rem 0.5rem !important;
    font-size: 0.8125rem !important;
}

/* ===============================================
   BUTTONS - REFINED LOOK
   =============================================== */

.btn {
    padding: 0.4rem 0.85rem !important;
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
    border-radius: var(--radius) !important;
    font-weight: 500 !important;
    transition: var(--transition) !important;
    letter-spacing: 0.01em;
}

.btn:hover {
    transform: translateY(-1px);
}

.btn:active {
    transform: translateY(0);
}

/* Primary Button - Indigo */
.btn-primary {
    background: var(--primary) !important;
    border-color: var(--primary) !important;
}
.btn-primary:hover, .btn-primary:focus {
    background: var(--primary-dark) !important;
    border-color: var(--primary-dark) !important;
    box-shadow: 0 4px 12px rgba(79, 70, 229, 0.3) !important;
}

/* Info Button - Blue */
.btn-info {
    background: var(--info) !important;
    border-color: var(--info) !important;
}
.btn-info:hover, .btn-info:focus {
    background: #2563eb !important;
    border-color: #2563eb !important;
    box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3) !important;
}

/* Success Button */
.btn-success {
    background: var(--success) !important;
    border-color: var(--success) !important;
}
.btn-success:hover, .btn-success:focus {
    background: #059669 !important;
    border-color: #059669 !important;
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3) !important;
}

/* Warning Button */
.btn-warning {
    background: var(--warning) !important;
    border-color: var(--warning) !important;
    color: #fff !important;
}
.btn-warning:hover, .btn-warning:focus {
    background: #d97706 !important;
    border-color: #d97706 !important;
    color: #fff !important;
    box-shadow: 0 4px 12px rgba(245, 158, 11, 0.3) !important;
}

/* Danger Button */
.btn-danger {
    background: var(--danger) !important;
    border-color: var(--danger) !important;
}
.btn-danger:hover, .btn-danger:focus {
    background: #dc2626 !important;
    border-color: #dc2626 !important;
    box-shadow: 0 4px 12px rgba(239, 68, 68, 0.3) !important;
}

.btn-sm {
    padding: 0.25rem 0.5rem !important;
    font-size: 0.8125rem !important;
    border-radius: 0.375rem !important;
}

.btn-lg {
    padding: 0.5rem 1rem !important;
    font-size: 0.95rem !important;
}

.btn-xs {
    padding: 0.125rem 0.25rem !important;
    font-size: 0.75rem !important;
}

/* Button Icons */
.btn i {
    font-size: 0.875rem !important;
}

.btn-sm i {
    font-size: 0.75rem !important;
}

/* ===============================================
   FORMS - CLEAN & MODERN
   =============================================== */

.form-control,
.form-select,
select.form-control {
    padding: 0.4rem 0.75rem !important;
    font-size: 0.875rem !important;
    height: auto !important;
    line-height: 1.5 !important;
    border-radius: var(--radius) !important;
    border: 1px solid var(--border-color) !important;
    transition: var(--transition) !important;
    background-color: #fff !important;
    color: var(--text-primary) !important;
}

.form-control:focus,
.form-select:focus,
select.form-control:focus {
    border-color: var(--primary-light) !important;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15) !important;
    outline: none !important;
}

.form-control-sm {
    padding: 0.25rem 0.5rem !important;
    font-size: 0.8125rem !important;
}

/* Form Labels */
.form-label,
label {
    font-size: 0.875rem !important;
    margin-bottom: 0.35rem !important;
    font-weight: 500 !important;
    color: var(--text-primary) !important;
}

/* Form Groups */
.form-group {
    margin-bottom: 0.85rem !important;
}

/* Input Groups */
.input-group-text {
    padding: 0.4rem 0.75rem !important;
    font-size: 0.875rem !important;
    border-color: var(--border-color) !important;
    background-color: #f8fafc !important;
    border-radius: var(--radius) !important;
}

/* ===============================================
   TABLES - CLEAN STRIPED DESIGN
   =============================================== */

.table {
    font-size: 0.875rem !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
}

.table thead th {
    padding: 0.65rem 0.75rem !important;
    font-size: 0.75rem !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
    color: var(--text-secondary) !important;
    background-color: #f8fafc !important;
    border-bottom: 2px solid var(--border-color) !important;
    border-top: none !important;
    white-space: nowrap;
}

.table tbody td {
    padding: 0.55rem 0.75rem !important;
    font-size: 0.8125rem !important;
    line-height: 1.5 !important;
    border-bottom: 1px solid #f1f5f9 !important;
    border-top: none !important;
    vertical-align: middle !important;
    color: var(--text-primary) !important;
}

/* ===============================================
   SIMANSA THEME FOUNDATION
   =============================================== */

:root {
    --simansa-hero-start: #3359d4;
    --simansa-hero-end: #2a8b93;
    --simansa-hero-text: #ffffff;
    --simansa-card-border: #d9e3f2;
    --simansa-card-muted: #eef4fb;
    --simansa-sidebar-surface: rgba(255, 255, 255, 0.08);
    --simansa-sidebar-active: rgba(255, 255, 255, 0.2);
    --simansa-sidebar-text: rgba(255, 255, 255, 0.88);
    --simansa-sidebar-heading: rgba(255, 255, 255, 0.6);
}

body:not(.layout-top-nav) .content-wrapper,
.content-wrapper,
.content {
    background:
        radial-gradient(circle at top right, rgba(59, 130, 246, 0.08), transparent 24%),
        linear-gradient(180deg, #eef4fb 0%, #f6f9fd 32%, #f8fafc 100%) !important;
}

.main-header.navbar {
    background: linear-gradient(135deg, var(--simansa-hero-start), var(--simansa-hero-end)) !important;
    border-bottom: 0 !important;
    box-shadow: 0 12px 30px rgba(37, 99, 235, 0.18) !important;
}

.main-header.navbar .nav-link,
.main-header.navbar .navbar-nav .nav-link,
.main-header.navbar .navbar-nav .nav-link i,
.main-header.navbar .navbar-nav .dropdown-toggle,
.main-header.navbar .navbar-nav .user-menu > .nav-link {
    color: rgba(255, 255, 255, 0.92) !important;
}

.main-header.navbar .nav-link:hover,
.main-header.navbar .navbar-nav .nav-link:hover {
    color: #ffffff !important;
    background: rgba(255, 255, 255, 0.08) !important;
    border-radius: 0.75rem;
}

.main-header.navbar .navbar-nav > .user-menu > .dropdown-menu {
    margin-top: 0.7rem;
    border-radius: 1rem;
    border: 1px solid var(--simansa-card-border);
    box-shadow: var(--shadow-lg);
}

.main-sidebar {
    background: linear-gradient(180deg, #2343b6 0%, #264eb5 30%, #246788 100%) !important;
    border-right: 0 !important;
    box-shadow: inset -1px 0 0 rgba(255, 255, 255, 0.06);
}

.brand-link {
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    background: rgba(255, 255, 255, 0.04);
}

.brand-link .brand-text,
.brand-link,
.brand-link:hover {
    color: #ffffff !important;
}

.sidebar .nav-header {
    color: var(--simansa-sidebar-heading) !important;
    font-size: 0.72rem !important;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 700;
    padding-top: 1rem !important;
}

.nav-sidebar > .nav-item > .nav-link,
.nav-sidebar .nav-treeview > .nav-item > .nav-link {
    color: var(--simansa-sidebar-text) !important;
    border-radius: 0.9rem !important;
    margin: 0.18rem 0.55rem !important;
    padding: 0.72rem 0.9rem !important;
    transition: all 0.2s ease !important;
}

.nav-sidebar > .nav-item > .nav-link:hover,
.nav-sidebar .nav-treeview > .nav-item > .nav-link:hover {
    background: var(--simansa-sidebar-surface) !important;
    color: #ffffff !important;
}

.nav-sidebar > .nav-item > .nav-link.active,
.nav-sidebar .nav-treeview > .nav-item > .nav-link.active {
    background: var(--simansa-sidebar-active) !important;
    color: #ffffff !important;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.nav-sidebar .menu-open > .nav-link {
    background: rgba(255, 255, 255, 0.12) !important;
    color: #ffffff !important;
}

.content-header {
    padding: 1.15rem 0 0.55rem !important;
}

.simansa-page-hero {
    position: relative;
    overflow: hidden;
    border-radius: 1.45rem;
    background: linear-gradient(135deg, var(--simansa-hero-start), var(--simansa-hero-end));
    box-shadow: 0 20px 38px rgba(51, 89, 212, 0.18);
    border: 1px solid rgba(255, 255, 255, 0.35);
}

.simansa-page-hero::before {
    content: "";
    position: absolute;
    inset: auto -10% -45% auto;
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.18) 0%, transparent 62%);
    pointer-events: none;
}

.simansa-page-hero__body {
    position: relative;
    z-index: 1;
    padding: 1.15rem 1.35rem;
    color: #ffffff !important;
}

.simansa-page-hero .text-muted,
.simansa-page-hero p,
.simansa-page-hero small,
.simansa-page-hero .breadcrumb-item,
.simansa-page-hero .breadcrumb-item a,
.simansa-page-hero .breadcrumb-item.active,
.simansa-page-hero .breadcrumb-item + .breadcrumb-item::before {
    color: rgba(255, 255, 255, 0.82) !important;
}

.simansa-page-hero h1,
.simansa-page-hero h2,
.simansa-page-hero h3,
.simansa-page-hero .h1,
.simansa-page-hero .h2,
.simansa-page-hero .h3,
.content-header .simansa-page-hero h1,
.content-header .simansa-page-hero h2,
.content-header .simansa-page-hero h3,
.content-header .simansa-page-hero__body h1 {
    color: #ffffff !important;
    margin-bottom: 0.3rem;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.18);
    font-weight: 700;
}

.simansa-page-hero h1 i,
.simansa-page-hero h1 .fas,
.simansa-page-hero h1 .far,
.simansa-page-hero h1 .fab,
.simansa-page-hero h1 .text-warning,
.simansa-page-hero h1 .text-primary,
.simansa-page-hero h1 .text-info,
.simansa-page-hero h1 .text-success,
.simansa-page-hero h1 .text-danger,
.simansa-page-hero__body .text-warning,
.simansa-page-hero__body .text-primary,
.simansa-page-hero__body .text-info,
.simansa-page-hero__body .text-success,
.simansa-page-hero__body .text-danger {
    color: rgba(255, 255, 255, 0.92) !important;
}

.simansa-page-hero .btn {
    box-shadow: none !important;
}

.card,
.info-box,
.small-box,
.modal-content {
    border-radius: 1.25rem !important;
    border-color: var(--simansa-card-border) !important;
}

.card {
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.06) !important;
}

.card-header {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.95)) !important;
}

.card.card-outline {
    border-top-width: 0 !important;
    position: relative;
}

.card.card-outline::before {
    content: "";
    position: absolute;
    left: 1.1rem;
    right: 1.1rem;
    top: 0;
    height: 4px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--simansa-hero-start), var(--simansa-hero-end));
}

.info-box,
.small-box {
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.65) !important;
    box-shadow: 0 16px 30px rgba(37, 99, 235, 0.08) !important;
}

.info-box {
    min-height: 110px;
    background: linear-gradient(135deg, rgba(255,255,255,0.95), rgba(241,245,249,0.95)) !important;
}

.info-box .info-box-icon {
    color: #fff !important;
    border-radius: 1rem !important;
    margin: 0.85rem 0 0.85rem 0.85rem !important;
    min-width: 68px !important;
    width: 68px !important;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.18);
}

.info-box.bg-info .info-box-icon,
.small-box.bg-info {
    background: linear-gradient(135deg, #2f6fed, #3fa2ff) !important;
}

.info-box.bg-success .info-box-icon,
.small-box.bg-success {
    background: linear-gradient(135deg, #0f9f7f, #23c483) !important;
}

.info-box.bg-warning .info-box-icon,
.small-box.bg-warning {
    background: linear-gradient(135deg, #e8a317, #facc15) !important;
}

.info-box.bg-danger .info-box-icon,
.small-box.bg-danger {
    background: linear-gradient(135deg, #e24b55, #fb7185) !important;
}

.info-box.bg-primary .info-box-icon,
.small-box.bg-primary {
    background: linear-gradient(135deg, #3957d8, #4f7cff) !important;
}

.info-box.bg-secondary .info-box-icon,
.small-box.bg-secondary {
    background: linear-gradient(135deg, #64748b, #94a3b8) !important;
}

.info-box.bg-dark .info-box-icon,
.small-box.bg-dark {
    background: linear-gradient(135deg, #0f172a, #334155) !important;
}

.info-box.bg-teal .info-box-icon,
.small-box.bg-teal {
    background: linear-gradient(135deg, #0f766e, #14b8a6) !important;
}

.info-box .info-box-content {
    color: #0f172a !important;
    padding: 1rem 1rem 1rem 0.9rem !important;
}

.info-box .info-box-text {
    font-size: 0.78rem !important;
    font-weight: 700 !important;
    color: #64748b !important;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.info-box .info-box-number {
    font-size: 1.45rem !important;
    font-weight: 800 !important;
}

.small-box {
    color: #fff !important;
    padding: 0.2rem 0.15rem;
}

.small-box .inner {
    padding: 1.1rem 1.15rem 0.75rem !important;
}

.small-box h3 {
    font-size: 1.85rem !important;
    font-weight: 800 !important;
    margin-bottom: 0.25rem !important;
    color: #fff !important;
}

.small-box p {
    font-size: 0.95rem !important;
    color: rgba(255,255,255,0.9) !important;
}

.small-box .icon {
    top: 0.8rem !important;
    right: 0.85rem !important;
    color: rgba(255,255,255,0.18) !important;
}

.small-box .small-box-footer {
    background: rgba(15, 23, 42, 0.16) !important;
    color: rgba(255,255,255,0.94) !important;
    padding: 0.7rem 1rem !important;
}

.table-responsive {
    border-radius: 1rem;
}

.table-bordered {
    border: 1px solid var(--simansa-card-border) !important;
}

.badge {
    border-radius: 999px !important;
    padding: 0.42rem 0.7rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.02em;
}

.pagination .page-link {
    border-radius: 0.95rem !important;
    margin: 0 0.18rem;
    min-width: 2.45rem;
    min-height: 2.45rem;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    padding: 0.48rem 0.9rem !important;
    border: 1px solid rgba(203, 213, 225, 0.95) !important;
    background: rgba(255, 255, 255, 0.96) !important;
    color: #334155 !important;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06) !important;
    transition: all 0.2s ease !important;
}

.pagination .page-link:hover,
.pagination .page-link:focus {
    background: linear-gradient(135deg, rgba(79, 70, 229, 0.12), rgba(6, 182, 212, 0.1)) !important;
    border-color: rgba(99, 102, 241, 0.35) !important;
    color: #312e81 !important;
    box-shadow: 0 14px 28px rgba(79, 70, 229, 0.12) !important;
    transform: translateY(-1px);
}

.pagination .page-item.active .page-link {
    background: linear-gradient(135deg, var(--simansa-hero-start), var(--simansa-hero-end)) !important;
    border-color: transparent !important;
    color: #fff !important;
    box-shadow: 0 16px 32px rgba(49, 46, 129, 0.22) !important;
}

.pagination .page-item.disabled .page-link {
    background: rgba(241, 245, 249, 0.82) !important;
    color: #94a3b8 !important;
    border-color: rgba(226, 232, 240, 0.95) !important;
    box-shadow: none !important;
}

.modal-content .modal-header {
    background: linear-gradient(135deg, #f8fbff, #eef4fb) !important;
    border-bottom: 1px solid var(--simansa-card-border) !important;
}

.swal2-popup {
    border-radius: 1.25rem !important;
}

@media (max-width: 991.98px) {
    .simansa-page-hero__body {
        padding: 1rem 1rem 0.95rem;
    }

    .content-header {
        padding-top: 0.9rem !important;
    }
}

.simansa-footer {
    border-top: 1px solid rgba(216, 227, 244, 0.95) !important;
    background: linear-gradient(180deg, rgba(255,255,255,0.92), rgba(241,246,252,0.95)) !important;
    color: #475569 !important;
    padding: 0.9rem 1.25rem !important;
    font-size: 0.88rem !important;
}

.simansa-footer__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.simansa-footer__brand {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.simansa-footer__brand strong {
    color: #1e3a8a;
    font-weight: 800;
    letter-spacing: 0.04em;
}

.simansa-footer__brand span,
.simansa-footer__meta span {
    color: #64748b;
}

.simansa-footer__extra {
    margin-top: 0.55rem;
    padding-top: 0.55rem;
    border-top: 1px solid rgba(216, 227, 244, 0.8);
}

@media (max-width: 767.98px) {
    .simansa-footer {
        padding: 0.9rem 1rem !important;
    }

    .simansa-footer__inner {
        flex-direction: column;
        align-items: flex-start;
    }
}

.table-striped tbody tr:nth-of-type(odd) {
    background-color: rgba(248, 250, 252, 0.5) !important;
}

.table tbody tr:hover {
    background-color: rgba(99, 102, 241, 0.03) !important;
}

.table-sm thead th,
.table-sm tbody td {
    padding: 0.35rem 0.5rem !important;
}

/* DataTables specific */
.dataTables_wrapper .dataTables_length,
.dataTables_wrapper .dataTables_filter,
.dataTables_wrapper .dataTables_info,
.dataTables_wrapper .dataTables_paginate {
    font-size: 0.875rem !important;
    padding: 0.5rem 0 !important;
}

.dataTables_wrapper .dataTables_length select,
.dataTables_wrapper .dataTables_filter input {
    padding: 0.3rem 0.6rem !important;
    font-size: 0.875rem !important;
    border-radius: var(--radius) !important;
    border: 1px solid var(--border-color) !important;
}

.dataTables_wrapper .dataTables_filter input:focus {
    border-color: var(--primary-light) !important;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15) !important;
    outline: none !important;
}

/* Pagination - Modern pill style */
.pagination {
    font-size: 0.875rem !important;
    gap: 0.15rem;
    align-items: center;
    flex-wrap: wrap;
}

.page-link {
    padding: 0.48rem 0.9rem !important;
    font-size: 0.875rem !important;
    font-weight: 600 !important;
    border-radius: 0.95rem !important;
    border: 1px solid rgba(203, 213, 225, 0.95) !important;
    color: #334155 !important;
    transition: var(--transition) !important;
    background: rgba(255, 255, 255, 0.96) !important;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06) !important;
}

.page-link:hover {
    background: linear-gradient(135deg, rgba(79, 70, 229, 0.12), rgba(6, 182, 212, 0.1)) !important;
    border-color: rgba(99, 102, 241, 0.35) !important;
    color: #312e81 !important;
}

.page-item.active .page-link {
    background: linear-gradient(135deg, var(--simansa-hero-start), var(--simansa-hero-end)) !important;
    border-color: transparent !important;
    color: #fff !important;
}

.page-item.disabled .page-link {
    background: rgba(241, 245, 249, 0.82) !important;
    color: #94a3b8 !important;
    border-color: rgba(226, 232, 240, 0.95) !important;
    box-shadow: none !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button {
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button:hover,
.dataTables_wrapper .dataTables_paginate .paginate_button:focus {
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

/* Dark header table variant — used for ranking, etc. */
.table-dark-header thead th {
    background: linear-gradient(135deg, #1e293b, #0f172a) !important;
    color: #f1f5f9 !important;
    border-bottom: 2px solid #334155 !important;
    border-color: #334155 !important;
    font-size: 0.72rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.05em !important;
    padding: 0.55rem 0.6rem !important;
    vertical-align: middle !important;
}
.table-dark-header thead th.col-highlight {
    background: linear-gradient(135deg, #1d4ed8, #1e40af) !important;
    color: #ffffff !important;
}
.table-dark-header thead th small {
    color: rgba(148, 163, 184, 0.9);
    font-weight: 500;
}
.table-dark-header tbody td {
    font-size: 0.8rem !important;
    padding: 0.5rem 0.6rem !important;
    vertical-align: middle !important;
}
.table-dark-header tbody tr:hover {
    background-color: rgba(59, 130, 246, 0.06) !important;
}
.table-dark-header tbody tr.table-success {
    background-color: rgba(34, 197, 94, 0.08) !important;
}
.table-dark-header tbody tr.table-warning {
    background-color: rgba(234, 179, 8, 0.08) !important;
}
.table-dark-header tbody tr.table-danger {
    background-color: rgba(239, 68, 68, 0.08) !important;
}

/* ===============================================
   BADGES - SOFT MODERN STYLE
   =============================================== */

.badge {
    padding: 0.3em 0.6em !important;
    font-size: 0.75rem !important;
    font-weight: 500 !important;
    border-radius: 9999px !important;
    letter-spacing: 0.01em;
}

/* ===============================================
   ALERTS - SOFT ACCENT BORDERS
   =============================================== */

.alert {
    padding: 0.75rem 1rem !important;
    font-size: 0.875rem !important;
    border-radius: var(--radius) !important;
    border: none !important;
    border-left: 4px solid transparent !important;
}

.alert-success {
    background-color: rgba(16, 185, 129, 0.08) !important;
    border-left-color: var(--success) !important;
    color: #065f46 !important;
}

.alert-info {
    background-color: rgba(59, 130, 246, 0.08) !important;
    border-left-color: var(--info) !important;
    color: #1e40af !important;
}

.alert-warning {
    background-color: rgba(245, 158, 11, 0.08) !important;
    border-left-color: var(--warning) !important;
    color: #92400e !important;
}

.alert-danger {
    background-color: rgba(239, 68, 68, 0.08) !important;
    border-left-color: var(--danger) !important;
    color: #991b1b !important;
}

.alert i {
    font-size: 1rem !important;
}

/* ===============================================
   BREADCRUMB - MINIMAL
   =============================================== */

.breadcrumb {
    font-size: 0.8125rem !important;
    padding: 0.5rem 0 !important;
    background: transparent !important;
}

.breadcrumb-item {
    font-size: 0.8125rem !important;
    color: var(--text-secondary) !important;
}

.breadcrumb-item.active {
    color: var(--text-primary) !important;
    font-weight: 500;
}

.breadcrumb-item + .breadcrumb-item::before {
    color: var(--text-muted) !important;
}

/* ===============================================
   MODALS - CLEAN OVERLAY
   =============================================== */

.modal-content {
    border: none !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: var(--shadow-lg) !important;
    overflow: hidden;
}

.modal-header {
    padding: 1rem 1.25rem !important;
    border-bottom: 1px solid var(--border-color) !important;
    background: transparent !important;
}

.modal-title {
    font-size: 1.1rem !important;
    font-weight: 600 !important;
    color: var(--text-primary) !important;
}

.modal-body {
    padding: 1rem 1.25rem !important;
}

.modal-footer {
    padding: 0.75rem 1.25rem !important;
    border-top: 1px solid var(--border-color) !important;
    background: rgba(241, 245, 249, 0.3) !important;
}

.modal-backdrop.show {
    opacity: 0.4 !important;
}

/* ===============================================
   SIDEBAR - ELEGANT GRADIENT
   =============================================== */

/* Sidebar background - Deep indigo gradient */
.main-sidebar {
    background: linear-gradient(180deg, #312e81 0%, #3730a3 50%, #4338ca 100%) !important;
    border-right: none !important;
    box-shadow: 2px 0 8px rgba(49, 46, 129, 0.15) !important;
}

/* Ensure inner sidebar doesn't override gradient */
.sidebar-dark-indigo {
    background: linear-gradient(180deg, #312e81 0%, #3730a3 50%, #4338ca 100%) !important;
}

.sidebar-dark-indigo .sidebar {
    background: inherit !important;
}

/* Sidebar Navigation */
.nav-sidebar .nav-link {
    padding: 0.5rem 0.75rem 0.5rem 1rem !important;
    font-size: 0.875rem !important;
    border-radius: 0.5rem !important;
    margin: 1px 0.5rem !important;
    color: rgba(255, 255, 255, 0.9) !important;
    transition: var(--transition) !important;
}

.nav-sidebar .nav-link:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    color: #fff !important;
}

.nav-sidebar .nav-link i {
    font-size: 0.875rem !important;
    margin-right: 0.5rem !important;
    width: 1.25rem !important;
    text-align: center;
    color: rgba(255, 255, 255, 0.85) !important;
}

.nav-sidebar .nav-link:hover i {
    color: #fff !important;
}

.nav-sidebar .nav-treeview .nav-link {
    padding: 0.4rem 0.75rem 0.4rem 2.5rem !important;
    font-size: 0.8125rem !important;
}

.nav-sidebar .nav-header {
    font-size: 0.7rem !important;
    padding: 0.75rem 1rem 0.25rem !important;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: rgba(255, 255, 255, 0.6) !important;
    font-weight: 600;
}

/* Sidebar Brand */
.brand-link {
    padding: 0.85rem 0.75rem !important;
    font-size: 1rem !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
    background: rgba(0, 0, 0, 0.1) !important;
}

.brand-image {
    max-height: 30px !important;
}

.brand-text {
    font-size: 1rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.02em;
}

/* ===============================================
   NAVBAR - CLEAN WHITE WITH SUBTLE SHADOW
   =============================================== */

.main-header {
    border-bottom: none !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06) !important;
}

.main-header .navbar {
    min-height: 52px !important;
    padding: 0 1rem !important;
    background: #fff !important;
}

.navbar-nav .nav-link {
    padding: 0.5rem 0.85rem !important;
    font-size: 0.875rem !important;
    color: var(--text-secondary) !important;
    transition: var(--transition) !important;
    border-radius: var(--radius) !important;
}

.navbar-nav .nav-link:hover {
    color: var(--primary) !important;
    background: rgba(79, 70, 229, 0.05) !important;
}

.navbar-nav .nav-link i {
    font-size: 1rem !important;
}
}

.navbar-nav .nav-link i {
    font-size: 1rem !important; /* Standard */
}

/* User Menu */
.user-panel {
    padding: 0.6rem 0.75rem !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.user-panel .info {
    font-size: 0.875rem !important;
    line-height: 1.4 !important;
    color: rgba(255, 255, 255, 0.9) !important;
}

.user-panel .image {
    padding-left: 0.6rem !important;
}

/* ===============================================
   SMALL BOX (Dashboard Widgets) - SOFT GRADIENT
   =============================================== */

.small-box {
    border-radius: var(--radius-lg) !important;
    overflow: hidden !important;
    box-shadow: var(--shadow-md) !important;
    transition: var(--transition) !important;
    border: none !important;
}

.small-box:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--shadow-lg) !important;
}

.small-box .inner h3 {
    font-size: 1.75rem !important;
    font-weight: 700 !important;
}

.small-box .inner p {
    font-size: 0.8125rem !important;
    opacity: 0.85;
}

.small-box .icon i {
    font-size: 60px !important;
    opacity: 0.15;
}

.small-box .small-box-footer {
    background: rgba(0, 0, 0, 0.08) !important;
    border-radius: 0 !important;
    padding: 0.4rem 0.75rem !important;
    font-size: 0.8125rem !important;
}

/* Softer gradient backgrounds for small boxes */
.small-box.bg-info {
    background: linear-gradient(135deg, #6366f1 0%, #818cf8 100%) !important;
}
.small-box.bg-success {
    background: linear-gradient(135deg, #10b981 0%, #34d399 100%) !important;
}
.small-box.bg-warning {
    background: linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%) !important;
}
.small-box.bg-danger {
    background: linear-gradient(135deg, #f87171 0%, #fca5a5 100%) !important;
}

/* ===============================================
   INFO BOX - ELEGANT WHITE CARD WITH COLOR ACCENT
   =============================================== */

.info-box {
    min-height: 80px !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: var(--shadow-sm) !important;
    border: 1px solid var(--border-color) !important;
    transition: var(--transition) !important;
    background: #fff !important;
    overflow: hidden !important;
}

.info-box:hover {
    box-shadow: var(--shadow-md) !important;
    transform: translateY(-1px) !important;
}

/* Override AdminLTE colored info-boxes to white cards with left accent */
.info-box.bg-info,
.info-box.bg-primary,
.info-box.bg-success,
.info-box.bg-warning,
.info-box.bg-danger {
    background: #fff !important;
    color: var(--text-primary) !important;
    border-left: 4px solid transparent !important;
    border-top: 1px solid var(--border-color) !important;
    border-right: 1px solid var(--border-color) !important;
    border-bottom: 1px solid var(--border-color) !important;
}

.info-box.bg-info {
    border-left-color: var(--info) !important;
}
.info-box.bg-primary {
    border-left-color: var(--primary) !important;
}
.info-box.bg-success {
    border-left-color: var(--success) !important;
}
.info-box.bg-warning {
    border-left-color: var(--warning) !important;
}
.info-box.bg-danger {
    border-left-color: var(--danger) !important;
}

/* Icon area - soft colored circle */
.info-box-icon {
    width: 70px !important;
    border-radius: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.info-box.bg-info .info-box-icon,
.info-box.bg-primary .info-box-icon,
.info-box.bg-success .info-box-icon,
.info-box.bg-warning .info-box-icon,
.info-box.bg-danger .info-box-icon {
    background: transparent !important;
}

.info-box.bg-info .info-box-icon i { color: var(--info) !important; }
.info-box.bg-primary .info-box-icon i { color: var(--primary) !important; }
.info-box.bg-success .info-box-icon i { color: var(--success) !important; }
.info-box.bg-warning .info-box-icon i { color: var(--warning) !important; }
.info-box.bg-danger .info-box-icon i { color: var(--danger) !important; }

.info-box-icon i {
    font-size: 1.75rem !important;
}

.info-box-content {
    padding: 10px 14px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
}

.info-box.bg-info .info-box-text,
.info-box.bg-primary .info-box-text,
.info-box.bg-success .info-box-text,
.info-box.bg-warning .info-box-text,
.info-box.bg-danger .info-box-text {
    color: var(--text-secondary) !important;
    font-size: 0.75rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    font-weight: 600 !important;
}

.info-box.bg-info .info-box-number,
.info-box.bg-primary .info-box-number,
.info-box.bg-success .info-box-number,
.info-box.bg-warning .info-box-number,
.info-box.bg-danger .info-box-number {
    color: var(--text-primary) !important;
    font-size: 1.35rem !important;
    font-weight: 700 !important;
}

.info-box-text {
    font-size: 0.75rem !important;
    color: var(--text-secondary) !important;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 600;
}

.info-box-number {
    font-size: 1.35rem !important;
    font-weight: 700 !important;
    color: var(--text-primary) !important;
}

/* ===============================================
   TIMELINE
   =============================================== */

.timeline > div > .timeline-item {
    font-size: 0.875rem !important;
}

.timeline > div > .timeline-item > .timeline-header {
    font-size: 0.875rem !important;
    padding: 0.5rem !important;
}

.timeline > div > .timeline-item > .timeline-body {
    padding: 0.5rem !important;
    font-size: 0.875rem !important;
}

/* ===============================================
   CUSTOM ADJUSTMENTS
   =============================================== */

/* Content Header */
.content-header {
    padding: 0.75rem 1rem !important;
    margin-bottom: 0 !important;
}

.content {
    padding: 0 1rem 1rem !important;
}

/* Balanced row spacing */
.row {
    margin-right: -0.5rem;
    margin-left: -0.5rem;
}

.col,
[class*="col-"] {
    padding-right: 0.5rem;
    padding-left: 0.5rem;
}

/* Content wrapper */
.content-wrapper {
    padding: 0 !important;
    background-color: var(--bg-body) !important;
}

/* Text muted refinement */
.text-muted {
    color: var(--text-secondary) !important;
}

/* ===============================================
   FILTER / BG-LIGHT CARDS - SUBTLE STYLE
   =============================================== */

.card.bg-light,
.bg-light {
    background-color: #f8fafc !important;
    border: 1px solid var(--border-color) !important;
    border-radius: var(--radius) !important;
}

.card.bg-light .card-body {
    padding: 0.75rem !important;
}

/* Filter form inline spacing */
.form-inline .form-group {
    margin-bottom: 0.25rem !important;
}

/* ===============================================
   STATUS BADGES - SOFT COLORED
   =============================================== */

.badge-success, .badge.bg-success:not(.small-box):not(.info-box) {
    background-color: rgba(16, 185, 129, 0.12) !important;
    color: #059669 !important;
    font-weight: 500 !important;
}

.badge-danger, .badge.bg-danger:not(.small-box):not(.info-box) {
    background-color: rgba(239, 68, 68, 0.1) !important;
    color: #dc2626 !important;
    font-weight: 500 !important;
}

.badge-info, .badge.bg-info:not(.small-box):not(.info-box) {
    background-color: rgba(59, 130, 246, 0.1) !important;
    color: #2563eb !important;
    font-weight: 500 !important;
}

.badge-warning, .badge.bg-warning:not(.small-box):not(.info-box) {
    background-color: rgba(245, 158, 11, 0.1) !important;
    color: #b45309 !important;
    font-weight: 500 !important;
}

.badge-primary, .badge.bg-primary:not(.small-box):not(.info-box) {
    background-color: rgba(79, 70, 229, 0.1) !important;
    color: #4338ca !important;
    font-weight: 500 !important;
}

/* ===============================================
   CARD HEADER TOOLS - REFINED BUTTONS
   =============================================== */

.card-tools .btn-success,
.card-tools .btn-info,
.card-tools .btn-primary {
    font-size: 0.8rem !important;
    padding: 0.35rem 0.75rem !important;
    border-radius: var(--radius) !important;
    font-weight: 500 !important;
}

/* ===============================================
   TABLE-RESPONSIVE WRAPPER
   =============================================== */

.table-responsive {
    border-radius: var(--radius) !important;
    border: none !important;
}

/* ===============================================
   LINKS - SUBTLE COLORS
   =============================================== */

a:not(.btn):not(.nav-link):not(.brand-link):not(.small-box-footer) {
    color: var(--primary) !important;
}

a:not(.btn):not(.nav-link):not(.brand-link):not(.small-box-footer):hover {
    color: var(--primary-dark) !important;
}

/* ===============================================
   CONTENT HEADER REFINEMENT
   =============================================== */

.content-header h1 {
    font-size: 1.35rem !important;
    font-weight: 600 !important;
    color: var(--text-primary) !important;
}

/* ===============================================
   SELECT2
   =============================================== */

.select2-container--default .select2-selection--single {
    height: auto !important;
    border-radius: var(--radius) !important;
    border: 1px solid var(--border-color) !important;
    padding: 0.35rem 0.5rem !important;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: 1.5 !important;
    font-size: 0.875rem !important;
    color: var(--text-primary) !important;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 100% !important;
}

.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--open .select2-selection--single {
    border-color: var(--primary-light) !important;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15) !important;
}

.select2-dropdown {
    border-radius: var(--radius) !important;
    border: 1px solid var(--border-color) !important;
    box-shadow: var(--shadow-lg) !important;
}

.select2-results__option--highlighted {
    background-color: var(--primary) !important;
}

/* ===============================================
   SWEETALERT2
   =============================================== */

.swal2-popup {
    font-size: 0.875rem !important;
    border-radius: var(--radius-lg) !important;
}

.swal2-title {
    font-size: 1.3rem !important;
    font-weight: 600 !important;
    color: var(--text-primary) !important;
}

.swal2-html-container {
    font-size: 0.875rem !important;
    color: var(--text-secondary) !important;
}

.swal2-confirm {
    border-radius: var(--radius) !important;
}

.swal2-cancel {
    border-radius: var(--radius) !important;
}

/* ===============================================
   RESPONSIVE ADJUSTMENTS - COMPREHENSIVE
   =============================================== */

/* Tablets and below */
@media (max-width: 991.98px) {
    .content-header h1 {
        font-size: 1.25rem !important;
    }

    .content {
        padding: 0 0.75rem 0.75rem !important;
    }

    .card-body {
        padding: 0.75rem !important;
    }

    .small-box .inner h3 {
        font-size: 1.75rem !important;
    }

    /* Stack stat cards properly */
    .col-lg-3.col-6 {
        flex: 0 0 50% !important;
        max-width: 50% !important;
    }

    /* Better table scroll on tablets */
    .table-responsive {
        border-radius: var(--radius) !important;
        border: 1px solid var(--border-color) !important;
    }
}

/* Mobile phones */
@media (max-width: 767.98px) {
    html {
        font-size: 13px !important;
    }

    .content-header h1 {
        font-size: 1.15rem !important;
    }

    .content-header {
        padding: 0.6rem 0.75rem !important;
    }

    .content {
        padding: 0 0.5rem 0.5rem !important;
    }

    .card-body {
        padding: 0.6rem !important;
    }

    .card-header {
        padding: 0.5rem 0.75rem !important;
    }

    .btn {
        padding: 0.3rem 0.6rem !important;
        font-size: 0.8125rem !important;
    }

    /* Stack stat cards to full width on small phones */
    .col-lg-3.col-6 {
        flex: 0 0 50% !important;
        max-width: 50% !important;
    }

    .small-box .inner h3 {
        font-size: 1.5rem !important;
    }

    .small-box .inner p {
        font-size: 0.75rem !important;
    }

    .small-box .icon i {
        font-size: 50px !important;
    }

    /* Table improvements on mobile */
    .table thead th {
        font-size: 0.75rem !important;
        padding: 0.4rem 0.5rem !important;
        letter-spacing: 0.03em !important;
    }

    .table tbody td {
        padding: 0.4rem 0.5rem !important;
        font-size: 0.8125rem !important;
    }

    /* Better modal on mobile */
    .modal-dialog {
        margin: 0.5rem !important;
    }

    .modal-body {
        padding: 0.75rem !important;
    }

    /* Form adjustments */
    .form-group {
        margin-bottom: 0.6rem !important;
    }

    /* Info boxes stack */
    .info-box {
        min-height: 60px !important;
    }

    .info-box-icon {
        width: 60px !important;
    }

    /* Navbar compact on mobile */
    .main-header .navbar {
        min-height: 46px !important;
    }
}

/* Extra small phones */
@media (max-width: 575.98px) {
    .col-lg-3.col-6 {
        flex: 0 0 100% !important;
        max-width: 100% !important;
    }

    .small-box {
        margin-bottom: 0.5rem !important;
    }

    /* Action buttons wrap on very small screens */
    .action-btns {
        flex-wrap: wrap !important;
        gap: 2px !important;
    }

    /* DataTables compact */
    .dataTables_wrapper .dataTables_length,
    .dataTables_wrapper .dataTables_filter {
        display: block !important;
        width: 100% !important;
        text-align: left !important;
        margin-bottom: 0.5rem !important;
    }

    .dataTables_wrapper .dataTables_info,
    .dataTables_wrapper .dataTables_paginate {
        display: block !important;
        width: 100% !important;
        text-align: center !important;
    }

    .page-link {
        padding: 0.34rem 0.62rem !important;
        min-width: 2.1rem;
        min-height: 2.1rem;
        font-size: 0.8125rem !important;
        border-radius: 0.8rem !important;
    }
}

/* Large screens - utilize space */
@media (min-width: 1400px) {
    .content {
        padding: 0 1.5rem 1.5rem !important;
    }

    .card-body {
        padding: 1.25rem !important;
    }
}

/* ===============================================
   PRINT ADJUSTMENTS
   =============================================== */

@media print {
    body.text-sm {
        font-size: 10pt !important;
    }
    
    .table {
        font-size: 9pt !important;
    }
}

/* ===============================================
   COLLAPSIBLE MENU STYLING - ELEGANT
   =============================================== */

/* Parent menu items with submenu */
.nav-sidebar > .nav-item.menu-open > .nav-link,
.nav-sidebar > .nav-item:hover > .nav-link {
    background-color: rgba(255, 255, 255, 0.08) !important;
}

/* Active parent menu */
.nav-sidebar > .nav-item > .nav-link.active {
    background: rgba(255, 255, 255, 0.12) !important;
    color: #fff !important;
    font-weight: 600 !important;
}

/* Submenu background */
.nav-sidebar .nav-treeview {
    background-color: rgba(0, 0, 0, 0.12) !important;
    padding: 0.25rem 0 !important;
    border-radius: 0 0 0.5rem 0.5rem !important;
}

/* Submenu items */
.nav-sidebar .nav-treeview > .nav-item > .nav-link {
    border-left: 3px solid transparent !important;
    transition: var(--transition) !important;
    color: rgba(255, 255, 255, 0.85) !important;
    border-radius: 0 0.375rem 0.375rem 0 !important;
    margin: 1px 0.5rem 1px 0 !important;
}

.nav-sidebar .nav-treeview > .nav-item > .nav-link:hover {
    border-left-color: rgba(255, 255, 255, 0.4) !important;
    background-color: rgba(255, 255, 255, 0.06) !important;
    color: #fff !important;
}

/* Active submenu - Cyan/Teal accent */
.nav-sidebar .nav-treeview > .nav-item > .nav-link.active {
    border-left-color: var(--accent) !important;
    background-color: rgba(6, 182, 212, 0.15) !important;
    color: #fff !important;
    font-weight: 600 !important;
    box-shadow: none !important;
}

/* Active submenu icon */
.nav-sidebar .nav-treeview > .nav-item > .nav-link.active > .nav-icon {
    color: var(--accent-light) !important;
}

/* Arrow indicator untuk collapsible */
.nav-sidebar .nav-link > .right {
    transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.nav-sidebar .menu-open > .nav-link > .right {
    transform: rotate(-90deg) !important;
}

/* Icon spacing untuk parent menu */
.nav-sidebar > .nav-item > .nav-link > .nav-icon {
    margin-right: 0.5rem !important;
    width: 1.25rem !important;
    text-align: center !important;
}

/* Smooth animation for expand/collapse */
.nav-treeview {
    animation: slideDown 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Hover effect untuk parent menu */
.nav-sidebar > .nav-item > .nav-link {
    transition: var(--transition) !important;
    color: rgba(255, 255, 255, 0.9) !important;
}

.nav-sidebar > .nav-item > .nav-link:hover {
    color: #fff !important;
    background: rgba(255, 255, 255, 0.08) !important;
}

/* Badge positioning di submenu */
.nav-treeview .nav-link .badge {
    margin-left: auto !important;
}

/* Highlight for active parent when submenu is active */
.nav-sidebar > .nav-item.menu-is-opening > .nav-link,
.nav-sidebar > .nav-item.menu-open > .nav-link {
    background-color: rgba(255, 255, 255, 0.08) !important;
    color: #fff !important;
}

/* Single menu (non-collapsible) when active - Cyan accent */
.nav-sidebar > .nav-item > .nav-link.active:not(.has-treeview) {
    background: linear-gradient(90deg, rgba(6, 182, 212, 0.25) 0%, rgba(6, 182, 212, 0.08) 100%) !important;
    border-left: 3px solid var(--accent) !important;
    color: #fff !important;
    font-weight: 600 !important;
    padding-left: calc(1rem - 3px) !important;
}

/* Single menu icon when active */
.nav-sidebar > .nav-item > .nav-link.active:not(.has-treeview) > .nav-icon {
    color: var(--accent-light) !important;
}

/* ===============================================
   LOGIN PAGE - ELEGANT
   =============================================== */

.login-page,
.register-page {
    background: linear-gradient(135deg, #312e81 0%, #4338ca 50%, #6366f1 100%) !important;
}

.login-box .card,
.register-box .card {
    border-radius: var(--radius-lg) !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2) !important;
    border: none !important;
}

.login-logo a,
.register-logo a {
    color: #fff !important;
    font-weight: 700;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.card-outline.card-primary {
    border-top: 3px solid var(--primary) !important;
}

/* ===============================================
   CUSTOM SCROLLBAR
   =============================================== */

::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

::-webkit-scrollbar-track {
    background: transparent;
}

::-webkit-scrollbar-thumb {
    background: rgba(100, 116, 139, 0.3);
    border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
    background: rgba(100, 116, 139, 0.5);
}

/* Sidebar scrollbar */
.main-sidebar ::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.15);
}

.main-sidebar ::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.25);
}

/* ===============================================
   UTILITY - SMOOTH TRANSITIONS
   =============================================== */

a {
    transition: color 0.15s ease !important;
}

.card, .btn, .form-control, .nav-link, .table tbody tr {
    transition: var(--transition) !important;
}

/* ===============================================
   PRINT ADJUSTMENTS
   =============================================== */

@media print {
    body.text-sm {
        font-size: 10pt !important;
    }
    
    .table {
        font-size: 9pt !important;
    }

    .card {
        box-shadow: none !important;
        border: 1px solid #ddd !important;
    }

    .main-sidebar, .main-header, .main-footer {
        display: none !important;
    }
}

/* ===============================================
   SIMANSA DESIGN SYSTEM — GENERIK (dipakai di semua halaman)
   class: .simansa-hero, .simansa-stat-card, .simansa-management-card,
          .simansa-filter-panel, .simansa-hero-chip
   =============================================== */

/* ── Hero (page header) ── */
.simansa-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(260px, .8fr);
    gap: .7rem;
    align-items: stretch;
    margin-bottom: .65rem;
}

.simansa-hero__main {
    background: linear-gradient(135deg, rgba(37, 99, 235, .92), rgba(13, 148, 136, .84));
    border: 1px solid rgba(255, 255, 255, .15);
    border-radius: 20px;
    padding: .95rem 1.05rem;
    box-shadow: 0 12px 24px rgba(15, 23, 42, .08);
}

.simansa-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    color: rgba(255, 255, 255, .86);
    font-size: .76rem;
    font-weight: 700;
    letter-spacing: .05em;
    text-transform: uppercase;
    margin-bottom: .35rem;
}

.simansa-hero__title {
    font-size: 1.4rem !important;
    font-weight: 800 !important;
    color: #fff !important;
    line-height: 1.1;
    margin: 0 0 .25rem 0;
}

.simansa-hero__subtitle {
    color: rgba(255, 255, 255, .9) !important;
    font-size: .84rem;
    line-height: 1.45;
    margin: 0;
    max-width: 780px;
}

.simansa-hero__side {
    display: grid;
    gap: .9rem;
}

/* ── Hero chip (stat inside hero) ── */
.simansa-hero-chip {
    background: rgba(255, 255, 255, .92);
    border: 1px solid rgba(148, 163, 184, .18);
    border-radius: 14px;
    padding: .62rem .82rem;
    box-shadow: 0 8px 18px rgba(15, 23, 42, .06);
}

.simansa-hero-chip__label {
    display: block;
    color: #64748b;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    margin-bottom: .2rem;
}

.simansa-hero-chip__value {
    display: block;
    color: #0f172a;
    font-size: 1.06rem;
    font-weight: 800;
    line-height: 1.2;
}

/* ── Stat cards (row di bawah hero) ── */
.simansa-stat-card {
    position: relative;
    overflow: hidden;
    min-height: 132px;
    border: 0;
    border-radius: 16px !important;
    padding: .86rem .86rem .8rem;
    color: #fff;
    box-shadow: 0 12px 24px rgba(15, 23, 42, .10);
    display: flex;
    align-items: flex-start;
    gap: .75rem;
}

.simansa-stat-card::after {
    content: "";
    position: absolute;
    right: -30px;
    bottom: -36px;
    width: 144px;
    height: 144px;
    border-radius: 999px;
    background: rgba(255, 255, 255, .12);
}

/* Color variants */
.simansa-stat-card--blue    { background: linear-gradient(135deg, #4f46e5, #6366f1); }
.simansa-stat-card--indigo  { background: linear-gradient(135deg, #4338ca, #6366f1); }
.simansa-stat-card--cyan    { background: linear-gradient(135deg, #0ea5e9, #22d3ee); }
.simansa-stat-card--teal    { background: linear-gradient(135deg, #0d9488, #2dd4bf); }
.simansa-stat-card--rose    { background: linear-gradient(135deg, #fb7185, #f43f5e); }
.simansa-stat-card--red     { background: linear-gradient(135deg, #ef4444, #f87171); }
.simansa-stat-card--green   { background: linear-gradient(135deg, #10b981, #34d399); }
.simansa-stat-card--emerald { background: linear-gradient(135deg, #059669, #10b981); }
.simansa-stat-card--orange  { background: linear-gradient(135deg, #f97316, #fb923c); }
.simansa-stat-card--amber   { background: linear-gradient(135deg, #d97706, #f59e0b); }
.simansa-stat-card--purple  { background: linear-gradient(135deg, #7c3aed, #a78bfa); }
.simansa-stat-card--slate   { background: linear-gradient(135deg, #475569, #64748b); }

.simansa-stat-card__icon {
    width: 42px;
    height: 42px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, .16);
    font-size: .92rem;
    position: relative;
    z-index: 1;
    flex: 0 0 42px;
    color: #fff;
}

.simansa-stat-card__body {
    position: relative;
    z-index: 1;
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
    min-width: 0;
}

.simansa-stat-card__label {
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    opacity: .9;
    margin-bottom: .25rem;
    color: #fff;
}

.simansa-stat-card__value {
    font-size: 1.48rem;
    font-weight: 800;
    line-height: 1;
    margin-bottom: .35rem;
    color: #fff;
}

.simansa-stat-card__desc {
    opacity: .92;
    line-height: 1.28;
    font-size: .78rem;
    color: #fff;
}

/* ── Management card (tabel utama) ── */
.simansa-management-card {
    border: 0 !important;
    border-radius: 18px !important;
    box-shadow: 0 14px 30px rgba(15, 23, 42, .08) !important;
    overflow: hidden;
}

.simansa-management-card > .card-header {
    background: linear-gradient(135deg, rgba(37, 99, 235, .98), rgba(13, 148, 136, .9)) !important;
    /* NO color here — prevents color inheritance to child buttons */
    border-bottom: 0 !important;
    padding: .8rem 1rem !important;
}

/* Only the title and icon tools get white text explicitly */
.simansa-management-card > .card-header .card-title,
.simansa-management-card > .card-header .card-title i,
.simansa-management-card > .card-header .btn-tool,
.simansa-management-card > .card-header .btn-tool i {
    color: #fff !important;
}

/* ── Filter panel ── */
.simansa-filter-panel {
    background: linear-gradient(180deg, rgba(248, 250, 252, .96), rgba(255, 255, 255, .98));
    border: 1px solid rgba(148, 163, 184, .18);
    border-radius: 20px;
    padding: 1rem 1rem .35rem;
    margin-bottom: 1rem;
}

.simansa-filter-label {
    display: block;
    font-size: .82rem;
    font-weight: 700;
    color: #475569;
    margin-bottom: .4rem;
}

/* ── Responsive ── */
@media (max-width: 991.98px) {
    .simansa-hero {
        grid-template-columns: 1fr;
    }
    .simansa-hero__side {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .simansa-hero__title { font-size: 1.2rem !important; }
    .simansa-hero__side { grid-template-columns: 1fr; }
    .simansa-stat-card {
        flex-direction: column;
        gap: .9rem;
    }
    .simansa-stat-card__body { width: 100%; }
}
