/* ELCT dashboard refinements. Loaded after the vendor theme so all dashboard pages inherit it. */
:root {
    --elct-dashboard-bg: #f5f7fb;
    --elct-card-border: #e6eaf0;
    --elct-card-shadow: 0 10px 28px rgba(15, 23, 42, 0.06);
    --elct-card-shadow-hover: 0 14px 34px rgba(15, 23, 42, 0.09);
    --elct-card-radius: 6px;
    --elct-primary: #0f3e68;
}

body {
    background: var(--elct-dashboard-bg);
    color: #1f2937;
}

.page-wrapper.compact-wrapper .page-body-wrapper .page-body {
    background: var(--elct-dashboard-bg);
}

.page-wrapper .page-body-wrapper .page-title {
    margin-bottom: 14px;
    padding: 12px 0 0;
}

.page-wrapper .page-body-wrapper .page-title h3 {
    color: #111827;
    font-size: 20px;
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.25;
    margin-bottom: 4px;
}

.page-wrapper .page-body-wrapper .page-title p {
    color: #64748b !important;
    font-size: 13px;
    line-height: 1.45;
    margin-bottom: 0;
    max-width: 720px;
}

.page-wrapper .page-body-wrapper .page-title .row {
    align-items: center;
    row-gap: 8px;
}

.page-wrapper .page-body-wrapper .breadcrumb {
    align-items: center;
    background: transparent;
    border: 0;
    box-shadow: none;
    display: flex;
    justify-content: flex-end;
    margin: 0;
    padding: 0;
}

.page-wrapper .page-body-wrapper .card {
    background: #ffffff;
    border: 1px solid var(--elct-card-border) !important;
    border-radius: var(--elct-card-radius) !important;
    box-shadow: var(--elct-card-shadow);
    overflow: hidden;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.page-wrapper .page-body-wrapper .card:hover {
    border-color: #d4dae4 !important;
    box-shadow: var(--elct-card-shadow-hover);
}

.page-wrapper .page-body-wrapper .card .card-header {
    background: linear-gradient(180deg, #ffffff 0%, #fbfcfe 100%);
    border-bottom: 1px solid var(--elct-card-border);
    border-radius: var(--elct-card-radius) var(--elct-card-radius) 0 0 !important;
    padding: 18px 20px;
}

.page-wrapper .page-body-wrapper .card .card-header h4,
.page-wrapper .page-body-wrapper .card .card-header h5,
.page-wrapper .page-body-wrapper .card .card-title {
    color: #111827;
    font-weight: 700;
    letter-spacing: -0.01em;
}

.page-wrapper .page-body-wrapper .card .card-body {
    padding: 20px;
}

.page-wrapper .page-body-wrapper .card .card-footer {
    background: #fbfcfe;
    border-top: 1px solid var(--elct-card-border);
    border-radius: 0 0 var(--elct-card-radius) var(--elct-card-radius) !important;
}

.page-wrapper .page-body-wrapper .card.border-2 {
    border-width: 1px !important;
}

.page-wrapper .page-body-wrapper .card-img,
.page-wrapper .page-body-wrapper .card-img-top {
    border-radius: var(--elct-card-radius) var(--elct-card-radius) 0 0;
}

.page-wrapper .page-body-wrapper .project-list .card {
    box-shadow: var(--elct-card-shadow);
}

.page-wrapper .page-body-wrapper .nav-tabs.border-tab {
    border-bottom: 0;
}

.page-wrapper .page-body-wrapper .nav-tabs.border-tab .nav-link {
    border-radius: var(--elct-card-radius);
    color: #475569;
    font-weight: 600;
}

.page-wrapper .page-body-wrapper .nav-tabs.border-tab .nav-link.active {
    background: rgba(15, 62, 104, 0.08);
    color: var(--elct-primary);
}

.page-wrapper .page-body-wrapper .btn {
    border-radius: 5px;
    font-weight: 600;
}

.page-wrapper .page-body-wrapper .btn-primary {
    background: var(--elct-primary) !important;
    border-color: var(--elct-primary) !important;
}

.page-wrapper .page-body-wrapper .table {
    color: #334155;
}

.page-wrapper .page-body-wrapper .table thead th {
    background: #f8fafc;
    color: #475569;
    font-weight: 700;
    border-bottom: 1px solid var(--elct-card-border);
}

.page-wrapper .page-body-wrapper .form-control,
.page-wrapper .page-body-wrapper .form-select {
    border-color: #dbe2ea;
    border-radius: 5px;
}

.page-wrapper .page-body-wrapper .form-control:focus,
.page-wrapper .page-body-wrapper .form-select:focus {
    border-color: var(--elct-primary);
    box-shadow: 0 0 0 0.2rem rgba(15, 62, 104, 0.12);
}

.page-wrapper .page-header {
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.05);
}

.page-wrapper .footer {
    background: transparent;
    color: #64748b;
}

.dashboard-back-btn {
    align-items: center;
    background: #ffffff;
    border: 1px solid var(--elct-card-border);
    border-radius: 6px;
    color: #334155;
    display: inline-flex;
    font-weight: 700;
    gap: 8px;
    padding: 8px 12px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

.dashboard-back-btn:hover {
    border-color: #cbd5e1;
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.06);
    color: var(--elct-primary);
}

.dashboard-back-btn svg {
    height: 16px;
    width: 16px;
}

.dashboard-header-crumb {
    align-items: center;
    color: #64748b;
    display: flex;
    flex-wrap: wrap;
    font-size: 13px;
    font-weight: 600;
    gap: 7px;
}

.dashboard-header-crumb a {
    color: var(--elct-primary);
    font-weight: 800;
}

.dashboard-header-crumb strong {
    color: #334155;
    font-weight: 700;
}

body:not(.dashboard-show-context-back) .page-wrapper .page-body-wrapper .page-title .breadcrumb {
    display: none;
}

.dashboard-show-context-back .page-wrapper .page-body-wrapper .page-title .breadcrumb .breadcrumb-item {
    display: none;
}

.dashboard-show-context-back .page-wrapper .page-body-wrapper .page-title .breadcrumb::before {
    align-items: center;
    background: #ffffff;
    border: 1px solid var(--elct-card-border);
    border-radius: 6px;
    color: #334155;
    content: "← Back";
    cursor: pointer;
    display: inline-flex;
    font-weight: 700;
    gap: 8px;
    padding: 8px 12px;
}

.dashboard-show-context-back .page-wrapper .page-body-wrapper .page-title .breadcrumb:hover::before {
    border-color: #cbd5e1;
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.06);
    color: var(--elct-primary);
}

.elct-confirm-modal {
    border: 1px solid var(--elct-card-border);
    border-radius: 10px;
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.18);
}

.elct-confirm-modal .modal-header {
    padding: 20px 20px 0;
}

.elct-confirm-modal .modal-body {
    padding: 8px 20px 12px;
}

.elct-confirm-modal .modal-footer {
    gap: 8px;
    padding: 0 20px 20px;
}

.elct-confirm-icon {
    align-items: center;
    background: #fef3c7;
    border-radius: 10px;
    color: #b45309;
    display: inline-flex;
    height: 44px;
    justify-content: center;
    width: 44px;
}

.elct-confirm-modal .modal-title {
    color: #0f172a;
    font-size: 18px;
    font-weight: 700;
}
