:root {
    --simpeg-navy: #083763;
    --simpeg-navy-dark: #052746;
    --simpeg-blue: #0878c9;
    --simpeg-blue-soft: #e8f4fd;
    --simpeg-green: #38a936;
    --simpeg-green-dark: #23882b;
    --simpeg-green-soft: #eaf8ea;
    --simpeg-bg: #f6f9fc;
    --simpeg-surface: #ffffff;
    --simpeg-border: #d9e6ef;
    --simpeg-text: #0f2f4f;
    --simpeg-muted: #64748b;
    --simpeg-warning: #f5b942;
    --simpeg-danger: #dc3545;
    --simpeg-info: #16a3c7;
    --simpeg-sidebar-width: 280px;
}

body {
    background: var(--simpeg-bg);
    color: var(--simpeg-text);
    font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

a {
    color: var(--simpeg-blue);
    text-decoration: none;
}

.app-logo {
    max-height: 46px;
    width: auto;
}

.simpeg-shell {
    min-height: 100vh;
    display: flex;
}

.sidebar {
    background: var(--simpeg-navy);
}

.simpeg-sidebar {
    width: var(--simpeg-sidebar-width);
    min-height: 100vh;
    position: fixed;
    inset: 0 auto 0 0;
    overflow-y: auto;
    z-index: 1040;
}

.sidebar-brand {
    min-height: 62px;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.sidebar-logo {
    width: 34px;
    height: 34px;
    object-fit: contain;
    background: #ffffff;
    border-radius: 8px;
    padding: 5px;
}

.sidebar-brand-title {
    color: #ffffff;
    font-size: 1.05rem;
    font-weight: 850;
    letter-spacing: 0;
}

.sidebar-nav {
    padding: 16px 14px 28px;
}

.sidebar-group + .sidebar-group {
    margin-top: 18px;
}

.sidebar-label {
    color: rgba(255, 255, 255, 0.48);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: uppercase;
    margin: 0 10px 8px;
}

.sidebar .nav-link {
    color: rgba(255, 255, 255, 0.82);
    border-radius: 8px;
    min-height: 42px;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 11px;
    font-weight: 600;
    font-size: 0.93rem;
}

.sidebar .nav-link i {
    width: 22px;
    font-size: 1.05rem;
    text-align: center;
}

.sidebar .nav-link:hover,
.sidebar .nav-link.active {
    background: rgba(255, 255, 255, 0.12);
    color: #ffffff;
}

.simpeg-main {
    min-width: 0;
    flex: 1;
    margin-left: var(--simpeg-sidebar-width);
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.topbar {
    background: var(--simpeg-surface);
    border-bottom: 1px solid var(--simpeg-border);
}

.simpeg-topbar {
    min-height: 78px;
    position: sticky;
    top: 0;
    z-index: 1030;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 14px 28px;
}

.simpeg-content {
    flex: 1;
    padding: 28px;
}

.simpeg-footer {
    min-height: 56px;
    padding: 16px 28px;
    border-top: 1px solid var(--simpeg-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    font-size: 0.9rem;
}

.footer-powered {
    color: var(--simpeg-muted);
    font-weight: 600;
}

.page-kicker {
    color: var(--simpeg-muted);
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0;
}

.page-title {
    margin: 0;
    font-size: 1.35rem;
    line-height: 1.2;
    font-weight: 800;
    color: var(--simpeg-navy);
}

.topbar-actions,
.toolbar-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.topbar-search,
.filter-search {
    position: relative;
    align-items: center;
}

.topbar-search i,
.filter-search i {
    position: absolute;
    left: 13px;
    color: var(--simpeg-muted);
    z-index: 2;
}

.topbar-search .form-control,
.filter-search .form-control {
    padding-left: 38px;
}

.topbar-search .form-control {
    width: 300px;
}

.btn-icon {
    --btn-icon-size: 40px;
    width: var(--btn-icon-size);
    height: var(--btn-icon-size);
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--simpeg-border);
    background: #ffffff;
    color: var(--simpeg-navy);
    border-radius: 8px;
    position: relative;
}

.btn-icon:hover {
    background: var(--simpeg-blue-soft);
    border-color: #b9d9ef;
    color: var(--simpeg-blue);
}

.notification-dot {
    position: absolute;
    top: 9px;
    right: 10px;
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: var(--simpeg-danger);
    border: 2px solid #ffffff;
}

.notification-menu {
    width: min(340px, calc(100vw - 28px));
    padding: 0;
    overflow: hidden;
}

.notification-menu-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 14px;
    border-bottom: 1px solid var(--simpeg-border);
}

.notification-menu-header span {
    color: var(--simpeg-muted);
    font-size: 0.8rem;
}

.notification-item {
    display: grid;
    gap: 3px;
    padding: 12px 14px;
    border-bottom: 1px solid var(--simpeg-border);
}

.notification-item:last-child {
    border-bottom: 0;
}

.notification-item strong {
    color: var(--simpeg-navy);
    font-size: 0.88rem;
}

.notification-item span,
.notification-item small {
    color: var(--simpeg-muted);
    font-size: 0.78rem;
}

.notification-empty {
    padding: 18px 14px;
    color: var(--simpeg-muted);
    text-align: center;
}

.user-menu {
    display: flex;
    align-items: center;
    gap: 10px;
    border: 1px solid var(--simpeg-border);
    background: #ffffff;
    border-radius: 8px;
    min-height: 44px;
    padding: 4px 9px 4px 4px;
}

.user-avatar,
.table-person > span {
    width: 34px;
    height: 34px;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--simpeg-blue-soft);
    color: var(--simpeg-blue);
    font-weight: 800;
}

.user-name,
.user-role {
    display: block;
    line-height: 1.1;
}

.user-name {
    color: var(--simpeg-text);
    font-weight: 700;
    font-size: 0.9rem;
}

.user-role {
    color: var(--simpeg-muted);
    font-size: 0.74rem;
}

.card {
    border-color: var(--simpeg-border);
    border-radius: 8px;
    box-shadow: 0 10px 28px rgba(8, 55, 99, 0.05);
}

.card-summary-primary {
    border-left: 4px solid var(--simpeg-blue);
}

.card-summary-success {
    border-left: 4px solid var(--simpeg-green);
}

.card-summary-warning {
    border-left: 4px solid var(--simpeg-warning);
}

.card-summary-info {
    border-left: 4px solid var(--simpeg-info);
}

.card-summary-danger {
    border-left: 4px solid var(--simpeg-danger);
}

.page-toolbar {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 18px;
}

.section-title {
    color: var(--simpeg-navy);
    font-size: 1.2rem;
    font-weight: 800;
    margin: 0 0 3px;
}

.section-subtitle {
    margin: 0;
    color: var(--simpeg-muted);
}

.summary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    margin-bottom: 18px;
}

.summary-card .card-body {
    display: flex;
    gap: 14px;
    align-items: center;
}

.summary-card p,
.summary-card small {
    display: block;
    margin: 0;
    color: var(--simpeg-muted);
}

.summary-card strong {
    display: block;
    color: var(--simpeg-navy);
    font-size: 1.75rem;
    line-height: 1.15;
}

.summary-icon {
    width: 46px;
    height: 46px;
    border-radius: 8px;
    color: #ffffff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    flex: 0 0 auto;
}

.content-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
    gap: 18px;
    margin-bottom: 18px;
}

.panel-card {
    margin-bottom: 18px;
}

.document-preview-frame {
    width: 100%;
    min-height: 520px;
    border: 1px solid var(--simpeg-border);
    border-radius: 8px;
    background: #f8fafc;
}

.attendance-photo-preview {
    display: block;
    width: 100%;
    max-height: 360px;
    object-fit: cover;
    border: 1px solid var(--simpeg-border);
    border-radius: 8px;
    background: #f8fafc;
}

.panel-card > .card-header {
    background: #ffffff;
    border-bottom-color: var(--simpeg-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 16px 18px;
}

.panel-card > .card-header h2 {
    margin: 0;
    color: var(--simpeg-navy);
    font-size: 1rem;
    font-weight: 800;
}

.panel-card > .card-header span {
    color: var(--simpeg-muted);
    font-size: 0.86rem;
}

.attendance-split {
    display: flex;
    align-items: center;
    gap: 24px;
}

.attendance-ring {
    width: 138px;
    height: 138px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: conic-gradient(var(--simpeg-blue) 0 62%, var(--simpeg-green) 62% 86%, #e9eef5 86% 100%);
    position: relative;
}

.attendance-ring::after {
    content: "";
    position: absolute;
    inset: 14px;
    border-radius: inherit;
    background: #ffffff;
}

.attendance-ring span {
    position: relative;
    z-index: 1;
    color: var(--simpeg-navy);
    font-size: 1.8rem;
    font-weight: 800;
}

.attendance-stats {
    flex: 1;
    display: grid;
    gap: 10px;
}

.attendance-stats div {
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--simpeg-muted);
}

.attendance-stats strong {
    margin-left: auto;
    color: var(--simpeg-navy);
}

.dot {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    display: inline-flex;
}

.dot-blue { background: var(--simpeg-blue); }
.dot-green { background: var(--simpeg-green); }
.dot-red { background: var(--simpeg-danger); }

.sync-status {
    margin-top: 18px;
    padding: 14px;
    border: 1px solid var(--simpeg-border);
    border-radius: 8px;
    display: flex;
    align-items: center;
    gap: 12px;
}

.sync-status i {
    color: var(--simpeg-blue);
    font-size: 1.35rem;
}

.sync-status div {
    flex: 1;
}

.sync-status strong,
.sync-status span {
    display: block;
}

.sync-status span {
    color: var(--simpeg-muted);
    font-size: 0.86rem;
}

.approval-list {
    display: grid;
}

.approval-item {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
    padding: 16px 18px;
    border-bottom: 1px solid var(--simpeg-border);
}

.approval-item:last-child {
    border-bottom: 0;
}

.approval-item strong,
.approval-item span {
    display: block;
}

.approval-item span {
    color: var(--simpeg-muted);
    font-size: 0.86rem;
}

.approval-icon {
    width: 40px;
    height: 40px;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--simpeg-blue-soft);
    color: var(--simpeg-blue);
}

.filter-bar {
    display: grid;
    grid-template-columns: minmax(240px, 1fr) repeat(2, minmax(170px, 220px)) auto;
    gap: 12px;
    align-items: center;
    margin-bottom: 18px;
    padding: 14px;
    border: 1px solid var(--simpeg-border);
    border-radius: 8px;
    background: #ffffff;
}

.table-person {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 220px;
}

.table-person strong,
.table-person small {
    display: block;
}

.table-person small {
    color: var(--simpeg-muted);
}

.table-actions {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.table-actions form,
.document-card .card-footer form {
    margin: 0;
}

.table-actions .btn-icon {
    --btn-icon-size: 34px;
}

.btn-soft-primary {
    background: var(--simpeg-blue-soft);
    color: var(--simpeg-blue);
    border-color: #cde5f6;
}

.btn-soft-warning {
    background: #fff7df;
    color: #946200;
    border-color: #f6dfa4;
}

.btn-soft-danger {
    background: #fdecec;
    color: #b42318;
    border-color: #f7caca;
}

.btn-soft-success {
    background: var(--simpeg-green-soft);
    color: var(--simpeg-green-dark);
    border-color: #c8eec9;
}

.table-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 18px;
    border-top: 1px solid var(--simpeg-border);
    color: var(--simpeg-muted);
    font-size: 0.9rem;
}

.kanban-status {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 18px;
}

.kanban-status div {
    border: 1px solid var(--simpeg-border);
    border-radius: 8px;
    background: #ffffff;
    padding: 16px;
}

.kanban-status strong,
.kanban-status span {
    display: block;
}

.kanban-status strong {
    color: var(--simpeg-navy);
    font-size: 1.55rem;
}

.kanban-status span {
    color: var(--simpeg-muted);
}

.segmented-control {
    display: inline-flex;
    padding: 3px;
    border-radius: 8px;
    background: #eef5fa;
    border: 1px solid var(--simpeg-border);
}

.segmented-control button {
    border: 0;
    background: transparent;
    color: var(--simpeg-muted);
    border-radius: 6px;
    padding: 6px 10px;
    font-weight: 700;
}

.segmented-control button.active {
    background: #ffffff;
    color: var(--simpeg-blue);
    box-shadow: 0 1px 4px rgba(8, 55, 99, 0.1);
}

.pipeline-list,
.document-checklist {
    padding: 18px;
    display: grid;
    gap: 14px;
}

.pipeline-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px 12px;
    align-items: center;
}

.pipeline-item span {
    color: var(--simpeg-muted);
}

.pipeline-item strong {
    color: var(--simpeg-navy);
}

.pipeline-item .progress {
    grid-column: 1 / -1;
    height: 8px;
}

.document-checklist label {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--simpeg-text);
    padding: 10px 0;
    border-bottom: 1px solid var(--simpeg-border);
}

.document-checklist label:last-child {
    border-bottom: 0;
}

.org-tree {
    padding: 20px;
    display: grid;
    gap: 18px;
}

.org-node {
    border: 1px solid var(--simpeg-border);
    border-radius: 8px;
    background: #ffffff;
    padding: 14px;
}

.org-node.root {
    background: var(--simpeg-blue-soft);
    border-color: #cde5f6;
}

.org-node strong,
.org-node span {
    display: block;
}

.org-node strong {
    color: var(--simpeg-navy);
}

.org-node span {
    color: var(--simpeg-muted);
    font-size: 0.86rem;
}

.org-branch {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.metric-list {
    padding: 18px;
    display: grid;
    gap: 12px;
}

.metric-list div {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    padding: 12px 0;
    border-bottom: 1px solid var(--simpeg-border);
}

.metric-list div:last-child {
    border-bottom: 0;
}

.metric-list span {
    color: var(--simpeg-muted);
}

.metric-list strong {
    color: var(--simpeg-navy);
}

.rank-order {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background: var(--simpeg-blue-soft);
    color: var(--simpeg-blue);
    font-weight: 800;
}

.document-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
}

.document-card {
    overflow: hidden;
}

.document-thumb {
    min-height: 130px;
    background: var(--simpeg-blue-soft);
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    padding: 16px;
}

.document-thumb i {
    color: var(--simpeg-blue);
    font-size: 2rem;
}

.document-card .card-body strong,
.document-card .card-body span {
    display: block;
}

.document-card .card-body span {
    color: var(--simpeg-muted);
    margin-top: 4px;
}

.document-meta {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    color: var(--simpeg-muted);
    margin-top: 14px;
}

.document-card .card-footer {
    background: #ffffff;
    border-top-color: var(--simpeg-border);
    display: flex;
    gap: 8px;
}

.document-actions {
    justify-content: flex-end;
    flex-wrap: wrap;
}

.btn-document-action {
    width: 30px;
    height: 30px;
    border-radius: 8px;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.86rem;
}

.report-layout,
.settings-layout {
    display: grid;
    grid-template-columns: 260px minmax(0, 1fr);
    gap: 18px;
}

.report-menu,
.settings-menu {
    padding: 8px;
    align-self: start;
}

.report-menu button,
.settings-menu button {
    width: 100%;
    border: 0;
    border-radius: 8px;
    background: transparent;
    color: var(--simpeg-text);
    min-height: 42px;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 11px;
    font-weight: 700;
    text-align: left;
}

.report-menu button:hover,
.settings-menu button:hover,
.report-menu button.active,
.settings-menu button.active {
    background: var(--simpeg-blue-soft);
    color: var(--simpeg-blue);
}

.report-form,
.settings-form {
    padding: 18px;
}

.report-preview {
    margin: 18px 0;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.report-preview div {
    border: 1px solid var(--simpeg-border);
    border-radius: 8px;
    padding: 14px;
    background: var(--simpeg-bg);
}

.report-preview span,
.report-preview strong {
    display: block;
}

.report-preview span {
    color: var(--simpeg-muted);
    font-size: 0.86rem;
}

.report-preview strong {
    color: var(--simpeg-navy);
}

.role-pill {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    border-radius: 999px;
    padding: 4px 10px;
    background: var(--simpeg-blue-soft);
    color: var(--simpeg-blue);
    font-weight: 800;
    font-size: 0.8rem;
}

.filter-search.compact .form-control {
    width: 240px;
}

.settings-switches {
    margin-top: 20px;
    display: grid;
    gap: 12px;
    border-top: 1px solid var(--simpeg-border);
    padding-top: 18px;
}

.settings-switches .form-check {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0;
    min-height: 36px;
}

.settings-switches .form-check-input {
    margin-left: 0;
}

.form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.grid-full {
    grid-column: 1 / -1;
}

.form-actions {
    background: #ffffff;
    border-top-color: var(--simpeg-border);
    display: flex;
    justify-content: flex-end;
    gap: 10px;
}

.inline-upload-form {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.inline-upload-form .form-select,
.inline-upload-form .form-control {
    width: auto;
    max-width: 190px;
}

.btn-primary {
    --bs-btn-bg: var(--simpeg-blue);
    --bs-btn-border-color: var(--simpeg-blue);
    --bs-btn-hover-bg: #066caf;
    --bs-btn-hover-border-color: #066caf;
    --bs-btn-active-bg: #055f9c;
    --bs-btn-active-border-color: #055f9c;
}

.btn-success {
    --bs-btn-bg: var(--simpeg-green);
    --bs-btn-border-color: var(--simpeg-green);
    --bs-btn-hover-bg: var(--simpeg-green-dark);
    --bs-btn-hover-border-color: var(--simpeg-green-dark);
    --bs-btn-active-bg: #1f7827;
    --bs-btn-active-border-color: #1f7827;
}

.text-primary {
    color: var(--simpeg-blue) !important;
}

.text-success {
    color: var(--simpeg-green) !important;
}

.bg-primary {
    background-color: var(--simpeg-blue) !important;
}

.bg-success {
    background-color: var(--simpeg-green) !important;
}

.badge-status-active,
.badge-status-approved,
.badge-status-verified {
    background: var(--simpeg-green-soft);
    color: var(--simpeg-green-dark);
}

.badge-status-pending,
.badge-status-process {
    background: #fff7df;
    color: #946200;
}

.badge-status-rejected,
.badge-status-inactive,
.badge-status-error {
    background: #fdecec;
    color: #b42318;
}

.table thead th {
    background: var(--simpeg-blue-soft);
    color: var(--simpeg-navy);
    border-bottom-color: var(--simpeg-border);
}

.modal-header {
    border-bottom-color: var(--simpeg-border);
}

.toast.text-bg-success {
    background-color: var(--simpeg-green) !important;
}

.toast.text-bg-primary,
.toast.text-bg-info {
    background-color: var(--simpeg-blue) !important;
    color: #ffffff !important;
}

.status-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 26px;
    padding: 4px 9px;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 800;
    white-space: nowrap;
}

.badge-status-info {
    background: var(--simpeg-blue-soft);
    color: var(--simpeg-blue);
}

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

.bg-warning {
    background-color: var(--simpeg-warning) !important;
}

.login-page {
    height: 100vh;
    height: 100svh;
    overflow: hidden;
    background: var(--simpeg-bg);
}

.login-shell {
    height: 100%;
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(380px, 0.95fr);
}

.login-panel {
    background: var(--simpeg-navy);
    color: #ffffff;
    padding: clamp(24px, 4.4vw, 56px);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 22px;
    min-height: 0;
}

.login-brand {
    display: grid;
    gap: 10px;
    max-width: 440px;
}

.login-brand img {
    width: 174px;
    background: #ffffff;
    border-radius: 8px;
    padding: 7px 9px;
}

.login-brand span,
.login-copy p {
    color: rgba(255, 255, 255, 0.78);
}

.login-copy {
    max-width: 620px;
}

.login-copy h1 {
    font-size: clamp(1.8rem, 4.2vw, 3.35rem);
    line-height: 1.03;
    letter-spacing: 0;
    font-weight: 850;
    margin-bottom: 12px;
}

.login-copy p {
    font-size: 1rem;
    margin: 0;
}

.login-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.login-metrics div {
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 8px;
    padding: 11px;
    background: rgba(255, 255, 255, 0.06);
}

.login-metrics strong,
.login-metrics span {
    display: block;
}

.login-metrics strong {
    font-size: 1.28rem;
}

.login-metrics span {
    color: rgba(255, 255, 255, 0.74);
    font-size: 0.86rem;
}

.login-card {
    align-self: center;
    justify-self: center;
    width: min(100% - 48px, 430px);
    background: #ffffff;
    border: 1px solid var(--simpeg-border);
    border-radius: 8px;
    padding: 26px;
    box-shadow: 0 22px 60px rgba(8, 55, 99, 0.12);
}

.login-card-heading {
    margin-bottom: 18px;
}

.login-icon {
    width: 58px;
    height: 58px;
    object-fit: contain;
    margin-bottom: 10px;
}

.login-card h2 {
    color: var(--simpeg-navy);
    font-size: 1.22rem;
    font-weight: 800;
}

.login-powered {
    margin-top: 16px;
    color: var(--simpeg-muted);
    font-size: 0.82rem;
    font-weight: 600;
    text-align: center;
}

@media (max-width: 1199.98px) {
    .summary-grid,
    .kanban-status {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .content-grid {
        grid-template-columns: 1fr;
    }

    .document-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .simpeg-sidebar {
        transform: translateX(-100%);
        transition: transform 0.2s ease;
    }

    .simpeg-shell.sidebar-open .simpeg-sidebar {
        transform: translateX(0);
    }

    .simpeg-main {
        margin-left: 0;
    }

    .simpeg-topbar {
        padding: 14px 18px;
    }

    .simpeg-content {
        padding: 18px;
    }

    .login-shell {
        grid-template-columns: 1fr;
        overflow: auto;
    }

    .login-panel {
        min-height: auto;
        padding: 24px;
    }

    .login-card {
        margin: 28px 0;
    }

    .report-layout,
    .settings-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .page-toolbar,
    .panel-card > .card-header,
    .table-footer {
        align-items: stretch;
        flex-direction: column;
    }

    .toolbar-actions,
    .toolbar-actions .btn,
    .toolbar-actions a {
        width: 100%;
    }

    .summary-grid,
    .kanban-status {
        grid-template-columns: 1fr;
    }

    .filter-bar {
        grid-template-columns: 1fr;
    }

    .attendance-split {
        align-items: flex-start;
        flex-direction: column;
    }

    .approval-item {
        grid-template-columns: auto minmax(0, 1fr);
    }

    .approval-item .status-badge {
        grid-column: 2;
        justify-self: start;
    }

    .login-metrics {
        grid-template-columns: 1fr;
    }

    .login-card {
        width: min(100% - 28px, 430px);
        padding: 22px;
    }

    .org-branch,
    .document-grid,
    .report-preview,
    .form-grid {
        grid-template-columns: 1fr;
    }

    .filter-search.compact .form-control {
        width: 100%;
    }
}
