:root {
    --rp-bg: #f5f7fb;
    --rp-surface: #ffffff;
    --rp-surface-muted: #f8fafc;
    --rp-border: #e2e8f0;
    --rp-text: #172033;
    --rp-muted: #64748b;
    --rp-sidebar: #101828;
    --rp-sidebar-soft: #1d2939;
    --rp-accent: #0e9384;
    --rp-accent-strong: #0b746b;
    --rp-info: #2563eb;
    --rp-danger: #d92d20;
    --rp-warning: #dc6803;
    --rp-purple: #7c3aed;
    --rp-shadow: 0 16px 38px rgba(15, 23, 42, .07);
    --rp-soft-shadow: 0 6px 18px rgba(15, 23, 42, .05);
}

html,
body {
    color: var(--rp-text);
    font-family: "Source Sans Pro", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    letter-spacing: 0;
}

body:not(.login-page) {
    background: var(--rp-bg);
}

.rp-app-shell .content-wrapper {
    background: var(--rp-bg);
}

.rp-app-shell .main-header {
    min-height: 64px;
    border-bottom: 1px solid var(--rp-border);
    background: rgba(255, 255, 255, .96);
    box-shadow: var(--rp-soft-shadow);
}

.rp-app-shell .main-header .nav-link {
    color: var(--rp-text);
}

.rp-app-shell .main-header .nav-link:hover {
    color: var(--rp-accent);
}

.rp-topbar-title {
    flex-direction: column;
    justify-content: center;
    margin-left: 10px;
    line-height: 1.12;
}

.rp-topbar-title strong {
    color: var(--rp-text);
    font-size: .98rem;
}

.rp-topbar-eyebrow {
    color: var(--rp-muted);
    font-size: .75rem;
    font-weight: 700;
    text-transform: uppercase;
}

.rp-user-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 36px;
    margin-right: 10px;
    padding: 0 12px;
    border: 1px solid var(--rp-border);
    border-radius: 999px;
    background: #fff;
    color: var(--rp-text);
    font-size: .9rem;
    font-weight: 700;
}

.rp-user-chip i {
    color: var(--rp-accent);
}

.rp-topbar-action {
    border-radius: 999px !important;
    padding: .42rem .8rem;
}

.rp-app-shell .main-sidebar {
    background: var(--rp-sidebar);
    box-shadow: 10px 0 28px rgba(15, 23, 42, .16);
}

.rp-brand-link {
    display: flex;
    align-items: center;
    min-height: 64px;
    padding: 12px 16px;
    border-bottom: 1px solid rgba(255, 255, 255, .09);
    color: #fff;
    text-decoration: none;
}

.rp-brand-link:hover {
    color: #fff;
    text-decoration: none;
}

.rp-brand-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    margin-right: 10px;
    border-radius: 10px;
    background: #ffffff;
    color: var(--rp-accent-strong);
    font-weight: 800;
    letter-spacing: 0;
}

.rp-brand-text {
    display: flex;
    flex-direction: column;
    line-height: 1.1;
}

.rp-brand-title {
    font-size: 1rem;
    font-weight: 700;
}

.rp-brand-subtitle {
    margin-top: 3px;
    color: rgba(255, 255, 255, .66);
    font-size: .76rem;
}

.rp-app-shell .sidebar {
    padding: 0 10px 12px;
}

.rp-app-shell .user-panel {
    align-items: center;
    margin: 12px 2px 14px;
    padding: 12px;
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 10px;
    background: rgba(255, 255, 255, .05);
}

.rp-app-shell .user-panel .image img {
    width: 38px;
    height: 38px;
    object-fit: cover;
    box-shadow: none !important;
}

.rp-app-shell .user-panel .info {
    padding-left: 10px;
    overflow: hidden;
}

.rp-app-shell .user-panel .info a:first-child {
    color: #fff;
    font-weight: 700;
}

.rp-app-shell .user-panel .info a:last-child {
    color: rgba(255, 255, 255, .68);
    font-size: .85rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.rp-app-shell .nav-sidebar .nav-link {
    min-height: 42px;
    margin: 3px 0;
    border-radius: 10px;
    color: rgba(255, 255, 255, .78);
}

.rp-app-shell .nav-sidebar .nav-link p {
    font-weight: 600;
}

.rp-app-shell .nav-sidebar .nav-icon {
    color: rgba(255, 255, 255, .7);
}

.rp-app-shell .nav-sidebar .nav-link:hover,
.rp-app-shell .nav-sidebar .nav-link.active {
    background: rgba(255, 255, 255, .09);
    color: #fff;
}

.rp-app-shell .nav-sidebar .nav-link:hover .nav-icon,
.rp-app-shell .nav-sidebar .nav-link.active .nav-icon {
    color: #fff;
}

.rp-app-shell .content-header {
    padding: 22px 1rem 10px;
}

.rp-app-shell .content-header h1 {
    color: var(--rp-text) !important;
    font-size: 1.55rem;
    font-weight: 800;
}

.rp-app-shell .breadcrumb {
    padding: 0;
    background: transparent;
    font-size: .9rem;
}

.rp-app-shell .content {
    padding-bottom: 28px;
}

.rp-page-header {
    padding-bottom: 16px !important;
}

.rp-hero-panel {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    min-height: 132px;
    padding: 28px;
    border: 1px solid rgba(14, 147, 132, .18);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(14, 147, 132, .12), rgba(37, 99, 235, .08)),
        #ffffff;
    box-shadow: var(--rp-shadow);
}

.rp-hero-panel h1 {
    margin-bottom: 8px !important;
    color: var(--rp-text) !important;
    font-size: 1.65rem;
    font-weight: 900;
}

.rp-hero-panel p {
    color: var(--rp-muted);
    font-size: .98rem;
}

.rp-hero-kicker {
    display: inline-flex;
    align-items: center;
    margin-bottom: 8px;
    color: var(--rp-accent-strong);
    font-size: .78rem;
    font-weight: 800;
    text-transform: uppercase;
}

.rp-hero-meta {
    display: flex;
    min-width: 180px;
    flex-direction: column;
    align-items: flex-end;
    padding: 12px 14px;
    border: 1px solid var(--rp-border);
    border-radius: 8px;
    background: rgba(255, 255, 255, .78);
}

.rp-hero-meta span {
    color: var(--rp-muted);
    font-size: .82rem;
    font-weight: 700;
}

.rp-hero-meta strong {
    color: var(--rp-text);
    font-size: 1.05rem;
}

.rp-metric-grid {
    margin-bottom: 8px;
}

.rp-metric-grid > [class*="col-"] {
    margin-bottom: 16px;
}

.rp-metric-card {
    display: flex;
    align-items: center;
    gap: 14px;
    min-height: 126px;
    height: 100%;
    padding: 18px;
    border: 1px solid var(--rp-border);
    border-radius: 8px;
    background: var(--rp-surface);
    box-shadow: var(--rp-shadow);
}

.rp-metric-card span {
    display: block;
    color: var(--rp-muted);
    font-size: .82rem;
    font-weight: 800;
    text-transform: uppercase;
}

.rp-metric-card strong {
    display: block;
    margin-top: 4px;
    color: var(--rp-text);
    font-size: 1.45rem;
    font-weight: 900;
    line-height: 1.15;
}

.rp-metric-card small {
    display: block;
    margin-top: 5px;
    color: var(--rp-muted);
    font-size: .84rem;
}

.rp-metric-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    flex: 0 0 48px;
    border-radius: 8px;
    color: #fff;
    font-size: 1.05rem;
}

.rp-metric-icon-danger {
    background: linear-gradient(135deg, #f04438, #b42318);
}

.rp-metric-icon-warning {
    background: linear-gradient(135deg, #f79009, #b54708);
}

.rp-metric-icon-info {
    background: linear-gradient(135deg, #3b82f6, #1d4ed8);
}

.rp-metric-icon-success {
    background: linear-gradient(135deg, #12b76a, #047857);
}

.rp-section {
    margin-top: 18px;
}

.rp-section-heading {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 12px;
}

.rp-section-heading span:first-child {
    display: inline-block;
    margin-bottom: 3px;
    color: var(--rp-muted);
    font-size: .78rem;
    font-weight: 800;
    text-transform: uppercase;
}

.rp-section-heading h2 {
    margin: 0;
    color: var(--rp-text);
    font-size: 1.16rem;
    font-weight: 900;
}

.rp-section-card .card-body {
    padding: 0;
}

.rp-section-card .table-responsive {
    border-radius: 8px;
}

.rp-data-table {
    margin-bottom: 0 !important;
}

.rp-table-action {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.rp-filter-card {
    margin-bottom: 16px;
}

.rp-filter-card label {
    color: var(--rp-muted);
    font-size: .82rem;
    font-weight: 800;
    text-transform: uppercase;
}

.rp-filter-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 10px;
}

.rp-filter-actions .btn {
    min-height: 42px;
    min-width: 104px;
}

.rp-filter-note {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 14px;
    padding: 8px 11px;
    border-radius: 999px;
    background: #eef7f6;
    color: var(--rp-accent-strong);
    font-size: .88rem;
    font-weight: 800;
}

.rp-report-chip {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    max-width: 100%;
    padding: 4px 9px;
    border-radius: 999px;
    background: #eef7f6;
    color: var(--rp-accent-strong);
    font-size: .85rem;
    font-weight: 800;
}

.rp-system-stack {
    display: grid;
    gap: 7px;
    min-width: 240px;
}

.rp-system-line {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    min-height: 34px;
    padding: 6px 10px;
    border: 1px solid var(--rp-border);
    border-radius: 8px;
    background: #fff;
}

.rp-system-line span {
    color: var(--rp-text);
    font-weight: 700;
}

.rp-system-line strong {
    white-space: nowrap;
}

.rp-serial,
.rp-deadline {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 4px 9px;
    border-radius: 999px;
    background: #f1f5f9;
    color: #334155;
    font-size: .85rem;
    font-weight: 700;
}

.rp-app-shell .card {
    border: 1px solid var(--rp-border);
    border-radius: 8px;
    box-shadow: var(--rp-shadow);
}

.rp-app-shell .card-header {
    border-bottom: 1px solid var(--rp-border);
    background: var(--rp-surface);
}

.rp-app-shell .card-title {
    color: var(--rp-text);
    font-weight: 800;
}

.rp-app-shell .card-body {
    border-radius: 8px;
}

.rp-app-shell h4 {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin: 20px 0 12px;
    color: var(--rp-text);
    font-size: 1.1rem;
    font-weight: 800;
}

.rp-app-shell .badge {
    border-radius: 999px;
    padding: .38rem .6rem;
    font-weight: 700;
}

.rp-app-shell .badge-success {
    background: var(--rp-accent);
}

.rp-app-shell .badge-danger {
    background: var(--rp-danger);
}

.rp-app-shell .badge-warning {
    background: #f59e0b;
    color: #1f2937;
}

.rp-app-shell .btn {
    border-radius: 8px;
    font-weight: 700;
}

.rp-app-shell .btn-flat {
    border-radius: 8px;
}

.rp-app-shell .btn-primary {
    border-color: var(--rp-accent);
    background: var(--rp-accent);
}

.rp-app-shell .btn-primary:hover,
.rp-app-shell .btn-primary:focus {
    border-color: var(--rp-accent-strong);
    background: var(--rp-accent-strong);
}

.rp-app-shell .btn-outline-info {
    border-color: var(--rp-info);
    color: var(--rp-info);
}

.rp-app-shell .btn-outline-info:hover {
    background: var(--rp-info);
    color: #fff;
}

.rp-app-shell .btn-outline-success {
    border-color: var(--rp-accent);
    color: var(--rp-accent);
}

.rp-app-shell .btn-outline-success:hover {
    background: var(--rp-accent);
    color: #fff;
}

.rp-app-shell .form-control,
.rp-app-shell .custom-select,
.rp-app-shell .select2-container--bootstrap4 .select2-selection {
    min-height: 42px;
    border-color: var(--rp-border);
    border-radius: 8px;
}

.rp-app-shell .form-control:focus,
.rp-app-shell .custom-select:focus,
.rp-app-shell .select2-container--bootstrap4.select2-container--focus .select2-selection {
    border-color: var(--rp-accent);
    box-shadow: 0 0 0 .2rem rgba(15, 118, 110, .14);
}

.rp-app-shell .table {
    color: var(--rp-text);
}

.rp-app-shell .table-bordered,
.rp-app-shell .table-bordered td,
.rp-app-shell .table-bordered th {
    border-color: var(--rp-border);
}

.rp-app-shell .table thead th,
.rp-app-shell .table tfoot th {
    border-bottom-width: 1px;
    background: #f8fafc;
    color: #334155;
    font-size: .82rem;
    letter-spacing: 0;
    text-transform: uppercase;
    vertical-align: middle;
}

.rp-app-shell .table-striped tbody tr:nth-of-type(odd) {
    background: #fbfdff;
}

.rp-app-shell .table tbody td {
    padding: .86rem .75rem;
    vertical-align: middle;
}

.rp-app-shell .table tbody tr:hover {
    background: #f8fbfd;
}

.rp-app-shell .dataTables_wrapper .dataTables_filter input,
.rp-app-shell .dataTables_wrapper .dataTables_length select {
    border: 1px solid var(--rp-border);
    border-radius: 8px;
}

.rp-app-shell .page-item.active .page-link {
    border-color: var(--rp-accent);
    background: var(--rp-accent);
}

.rp-app-shell .main-footer {
    border-top: 1px solid var(--rp-border);
    background: #fff;
    color: var(--rp-muted);
}

.login-page {
    min-height: 100vh;
    background:
        linear-gradient(120deg, rgba(15, 118, 110, .08), rgba(37, 99, 235, .07)),
        var(--rp-bg);
}

.login-page .login-box {
    width: min(92vw, 420px);
}

.login-page .login-logo {
    margin-bottom: 18px;
}

.login-page .login-logo img {
    width: min(230px, 58vw) !important;
    height: auto;
    max-height: none;
    object-fit: contain;
    filter: drop-shadow(0 16px 24px rgba(15, 23, 42, .13));
}

.login-page .login-logo .rp-login-logo {
    display: block;
    margin: 0 auto;
}

.login-page .card {
    overflow: hidden;
    border: 1px solid rgba(220, 227, 234, .92);
    border-radius: 8px;
    background: rgba(255, 255, 255, .96);
    box-shadow: 0 22px 48px rgba(15, 23, 42, .12);
}

.login-page .login-card-body {
    padding: 34px;
    border-radius: 8px;
    background: transparent;
}

.login-page .login-box-msg {
    margin-bottom: 24px;
    color: var(--rp-muted);
    font-size: 1rem;
    font-weight: 600;
}

.login-page .input-group {
    margin-bottom: 16px !important;
}

.login-page .form-control {
    height: 46px;
    border-color: var(--rp-border);
    border-right: 0;
    border-radius: 8px 0 0 8px;
    color: var(--rp-text);
}

.login-page .form-control:focus {
    border-color: var(--rp-accent);
    box-shadow: none;
}

.login-page .input-group-text {
    min-width: 46px;
    justify-content: center;
    border-color: var(--rp-border);
    border-left: 0;
    border-radius: 0 8px 8px 0;
    background: #fff;
    color: var(--rp-muted);
}

.login-page .form-control:focus + .input-group-append .input-group-text {
    border-color: var(--rp-accent);
    color: var(--rp-accent);
}

.login-page .btn-primary {
    height: 46px;
    border-color: var(--rp-accent);
    border-radius: 8px;
    background: var(--rp-accent);
    font-weight: 800;
    box-shadow: 0 12px 20px rgba(15, 118, 110, .18);
}

.login-page .btn-primary:hover,
.login-page .btn-primary:focus {
    border-color: var(--rp-accent-strong);
    background: var(--rp-accent-strong);
}

.login-page .alert {
    border: 0;
    border-radius: 8px;
    box-shadow: var(--rp-shadow);
}

.login-page .rp-login-version {
    margin-top: 12px;
    color: var(--rp-muted);
    font-size: .88rem;
    font-weight: 700;
    text-align: center;
}

@media (max-width: 767.98px) {
    .rp-app-shell .content-header {
        padding-top: 16px;
    }

    .rp-app-shell .content-header h1 {
        font-size: 1.3rem;
    }

    .rp-hero-panel {
        align-items: flex-start;
        flex-direction: column;
        min-height: auto;
        padding: 20px;
    }

    .rp-hero-panel h1 {
        font-size: 1.35rem;
    }

    .rp-hero-meta {
        width: 100%;
        align-items: flex-start;
    }

    .rp-section-heading {
        align-items: flex-start;
        flex-direction: column;
    }

    .rp-metric-card {
        min-height: 112px;
    }

    .rp-table-action {
        align-items: flex-start;
        flex-direction: column;
    }

    .rp-filter-actions {
        justify-content: flex-start;
        margin-top: 8px;
    }

    .rp-filter-actions .btn {
        flex: 1;
    }

    .rp-system-stack {
        min-width: 0;
    }

    .rp-system-line {
        align-items: flex-start;
        flex-direction: column;
        gap: 2px;
    }

    .rp-app-shell .card-body {
        padding: 1rem;
    }

    .rp-section-card .card-body {
        padding: 0;
    }

    .rp-app-shell .btn-block {
        white-space: normal;
    }

    .login-page .login-card-body {
        padding: 26px;
    }
}
