/* Dashboard Theme Overrides - SI-PORA Badung */
:root {
    --primary-green: #00843B;
    --secondary-green: #00A650;
    --primary-orange: #F37021;
    --dark-orange: #D85D1A;
    --white: #ffffff;
}

/* Backgrounds */
.bg-primary {
    background-color: var(--primary-green) !important;
}

.bg-info {
    background-color: var(--primary-orange) !important;
}

.bg-gradient-primary {
    background-image: linear-gradient(310deg, var(--primary-green) 0%, var(--secondary-green) 100%) !important;
}

.bg-gradient-info {
    background-image: linear-gradient(310deg, var(--primary-orange) 0%, var(--dark-orange) 100%) !important;
}

/* Sidebar Active State */
.navbar-vertical .navbar-nav .nav-link.active {
    background-color: var(--white) !important;
    box-shadow: 0 20px 27px 0 rgba(0, 0, 0, 0.05) !important;
}

.navbar-vertical .navbar-nav .nav-link.active .icon {
    background-image: linear-gradient(310deg, var(--primary-green) 0%, var(--secondary-green) 100%) !important;
}

.navbar-vertical .navbar-nav .nav-link.active .nav-link-text {
    color: var(--primary-green) !important;
    font-weight: 600;
}

/* Buttons */
.btn-primary,
.btn.bg-gradient-primary {
    background-color: var(--primary-green) !important;
    border-color: var(--primary-green) !important;
    background-image: linear-gradient(310deg, var(--primary-green) 0%, var(--secondary-green) 100%) !important;
}

.btn-info,
.btn.bg-gradient-info {
    background-color: var(--primary-orange) !important;
    border-color: var(--primary-orange) !important;
    background-image: linear-gradient(310deg, var(--primary-orange) 0%, var(--dark-orange) 100%) !important;
}

.btn-primary:hover,
.btn.bg-gradient-primary:hover,
.btn-primary:focus,
.btn-primary:active,
.btn-info:hover,
.btn.bg-gradient-info:hover,
.btn-info:focus,
.btn-info:active {
    opacity: 0.85;
    transform: translateY(-1px);
    box-shadow: 0 7px 14px rgba(50, 50, 93, 0.1), 0 3px 6px rgba(0, 0, 0, 0.08) !important;
}


.btn-outline-primary {
    color: var(--primary-green) !important;
    border-color: var(--primary-green) !important;
}

.btn-outline-primary:hover {
    background-color: var(--primary-green) !important;
    color: var(--white) !important;
}

/* Link Button Rebranding */
.btn-link {
    color: var(--primary-green);
    font-weight: 600;
    text-decoration: none;
    transition: all 0.3s ease;
}

.btn-link:hover {
    color: var(--secondary-green);
    text-decoration: none;
}

.btn-link.text-dark:hover {
    color: var(--primary-green) !important;
}

.btn-link.btn-sm {
    font-size: 0.825rem;
}

/* Text Utility Overrides for Buttons/Links */
.btn.text-primary,
.btn-link.text-primary {
    color: var(--primary-green) !important;
}

.btn.text-info,
.btn-link.text-info {
    color: var(--primary-orange) !important;
}

.btn.text-success,
.btn-link.text-success {
    color: var(--secondary-green) !important;
}

.btn.text-primary:hover,
.btn-link.text-primary:hover {
    color: var(--secondary-green) !important;
}

.btn.text-info:hover,
.btn-link.text-info:hover {
    color: var(--dark-orange) !important;
}

.btn.text-dark:hover,
.btn-link.text-dark:hover,
.btn.text-secondary:hover,
.btn-link.text-secondary:hover,
.btn.text-muted:hover,
.btn-link.text-muted:hover {
    color: var(--primary-green) !important;
}

.btn.text-white:hover,
.btn-link.text-white:hover {
    opacity: 0.8;
}



/* Texts */
.text-primary,
.text-gradient.text-primary {
    color: var(--primary-green) !important;
    background-image: linear-gradient(310deg, var(--primary-green) 0%, var(--secondary-green) 100%) !important;
}

.text-info,
.text-gradient.text-info {
    color: var(--primary-orange) !important;
    background-image: linear-gradient(310deg, var(--primary-orange) 0%, var(--dark-orange) 100%) !important;
}

/* Badges */
.badge-primary {
    background-color: var(--primary-green) !important;
}

.badge-info {
    background-color: var(--primary-orange) !important;
}

/* Pagination Overrides */
.page-item.active .page-link,
.active>.page-link {
    background-color: var(--primary-green) !important;
    border-color: var(--primary-green) !important;
    color: var(--white) !important;
}

.page-link {
    color: var(--primary-green) !important;
}

.page-link:hover {
    color: var(--secondary-green) !important;
    background-color: #f8f9fa !important;
}

/* Forms & Inputs Overrides */
.form-control:focus,
.form-select:focus,
.form-control.focus {
    border-color: var(--secondary-green) !important;
    box-shadow: 0 0 0 2px rgba(0, 132, 59, 0.2) !important;
}

.form-check-input:checked {
    background-color: var(--primary-green) !important;
    border-color: var(--primary-green) !important;
}

.form-check-input:focus {
    border-color: var(--primary-green) !important;
    box-shadow: 0 0 0 2px rgba(0, 132, 59, 0.2) !important;
}

.form-switch .form-check-input:checked {
    background-color: var(--primary-green) !important;
    border-color: var(--primary-green) !important;
}

.form-switch .form-check-input:after {
    background-color: #fff;
}

/* Table Border Consistency Fixes */
.table.table-bordered {
    border: 1px solid #e9ecef !important;
}

.table-bordered th,
.table-bordered td {
    border: 1px solid #e9ecef !important;
}

.table-bordered thead th {
    border-bottom-width: 2px !important;
}

.table.align-items-center td,
.table.align-items-center th {
    vertical-align: middle !important;
}


/* Mobile Responsiveness Overrides */
@media (max-width: 768px) {

    /* Table Fixes */
    .table-responsive {
        border: 0;
    }

    .table.table-wrap td,
    .table.table-wrap th {
        white-space: normal !important;
        min-width: 120px;
    }

    /* Form Fixes */
    .card-header .row>div {
        margin-bottom: 1rem;
    }

    .card-header .text-end {
        text-align: left !important;
    }

    .btn {
        width: 100%;
        margin-left: 0 !important;
        margin-right: 0 !important;
        margin-bottom: 0.5rem !important;
    }

    /* Breadcrumb Fixes */
    .breadcrumb {
        flex-wrap: wrap;
    }

    /* Select2 Mobile Fix */
    .select2-container {
        width: 100% !important;
    }

    /* Stats Cards on Mobile */
    .card-body.p-3 .row {
        flex-direction: column;
    }

    .card-body.p-3 .row>div {
        width: 100% !important;
        max-width: 100% !important;
        margin-bottom: 1rem;
    }
}

@media (max-width: 576px) {
    .navbar-brand-img {
        max-height: 30px;
    }

    .ms-3.font-weight-bold {
        font-size: 0.9rem;
    }
}