/* ShiftX Admin - Modern (Corporate Grey) */

:root,
[data-bs-theme="light"] {
    --sx-bg: #f5f6f8;
    --sx-surface: #ffffff;
    --sx-surface-2: #f1f3f6;
    --sx-text: #111827;
    --sx-text-muted: #6b7280;
    --sx-muted: var(--sx-text-muted);
    --sx-border: rgba(17, 24, 39, 0.12);
    --sx-shadow: 0 1px 2px rgba(0,0,0,.06), 0 10px 28px rgba(0,0,0,.08);
    --sx-radius: 14px;

    /* Sidebar */
    --sx-sidebar-bg: #111418;
    --sx-sidebar-bg-2: #0d0f12;
    --sx-sidebar-border: rgba(255,255,255,.08);
    --sx-sidebar-text: rgba(255,255,255,.78);
    --sx-sidebar-text-strong: rgba(255,255,255,.92);
    --sx-sidebar-hover: rgba(255,255,255,.08);
    --sx-sidebar-active: rgba(255,255,255,.14);

    /* Accent (Corporate Grey) */
    --sx-accent: #4b5563;
    --sx-accent-rgb: 75, 85, 99;
    --sx-accent-strong: #374151;

    /* Topbar */
    --sx-topbar-bg: rgba(255,255,255,.72);
}

[data-bs-theme="dark"] {
    --sx-bg: #0b0d10;
    --sx-surface: #12161d;
    --sx-surface-2: #0f131a;
    --sx-text: #e5e7eb;
    --sx-text-muted: #9ca3af;
    --sx-border: rgba(229, 231, 235, 0.10);
    --sx-shadow: 0 1px 2px rgba(0,0,0,.55), 0 14px 36px rgba(0,0,0,.35);

    --sx-sidebar-bg: #0f1115;
    --sx-sidebar-bg-2: #0b0d10;
    --sx-sidebar-border: rgba(255,255,255,.08);
    --sx-sidebar-text: rgba(255,255,255,.80);
    --sx-sidebar-text-strong: rgba(255,255,255,.94);
    --sx-sidebar-hover: rgba(255,255,255,.08);
    --sx-sidebar-active: rgba(255,255,255,.14);

    --sx-accent: #9ca3af;
    --sx-accent-rgb: 156, 163, 175;
    --sx-accent-strong: #d1d5db;

    --sx-topbar-bg: rgba(18,22,29,.72);
}

html, body {
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;
}

body {
    background: var(--sx-bg);
    color: var(--sx-text);
}

/* Bootstrap tokens override */
:root,
[data-bs-theme="light"],
[data-bs-theme="dark"] {
    --bs-primary: var(--sx-accent);
    --bs-primary-rgb: var(--sx-accent-rgb);
    --bs-link-color: var(--sx-accent);
    --bs-link-hover-color: var(--sx-accent-strong);
    --bs-border-color: var(--sx-border);
    --bs-border-radius: 0.85rem;
    --bs-border-radius-lg: 1rem;
    --bs-border-radius-xl: 1.2rem;
    --bs-body-bg: var(--sx-bg);
    --bs-body-color: var(--sx-text);
    --bs-secondary-color: var(--sx-text-muted);
}

a, .btn-link {
    color: var(--sx-accent);
}

/* Cards / surfaces */
.card,
.modal-content,
.dropdown-menu,
.toast,
.table {
    border-color: var(--sx-border);
}

.card,
.modal-content {
    border-radius: var(--sx-radius);
    box-shadow: var(--sx-shadow);
}

/* Inputs */
.form-control,
.form-select {
    border-color: var(--sx-border);
    border-radius: 0.85rem;
}

.form-control:focus,
.form-select:focus,
.btn:focus,
.btn:active:focus,
.btn-link.nav-link:focus,
.form-check-input:focus {
    box-shadow: 0 0 0 .25rem rgba(var(--sx-accent-rgb), .18);
    border-color: rgba(var(--sx-accent-rgb), .55);
}

/* Table polish */
.table {
    --bs-table-bg: var(--sx-surface);
}

.table > :not(caption) > * > * {
    padding: .75rem .85rem;
}

.table thead th {
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--sx-text-muted);
}

.table tbody tr:hover {
    background: rgba(var(--sx-accent-rgb), .06);
}

/* Subtle page content spacing */
.content {
    padding-top: 1.1rem;
    padding-bottom: 2rem;
}

/* Utility: icon button (topbar) */
.sx-icon-btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .45rem .65rem;
    border-radius: 999px;
    border: 1px solid var(--sx-border);
    background: var(--sx-surface);
    color: var(--sx-text);
}

[data-bs-theme="dark"] .sx-icon-btn {
    background: var(--sx-surface);
}

.sx-icon-btn:hover {
    background: var(--sx-surface-2);
}

.sx-theme-icon {
    display: inline-flex;
    width: 18px;
    height: 18px;
    color: var(--sx-accent-strong);
}

.sx-user-pill {
    display: inline-flex;
    align-items: center;
    padding: .45rem .75rem;
    border-radius: 999px;
    background: var(--sx-surface);
    border: 1px solid var(--sx-border);
    color: var(--sx-text);
    font-size: .875rem;
}

/* Validation + Blazor defaults kept */
.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50000;
}

.validation-message {
    color: #e50000;
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

.blazor-error-boundary::after {
    content: "An error has occurred.";
}

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}

.form-floating > .form-control-plaintext::placeholder,
.form-floating > .form-control::placeholder {
    color: var(--bs-secondary-color);
    text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder,
.form-floating > .form-control:focus::placeholder {
    text-align: start;
}



/* ---------- Page layout polish ---------- */
.sx-page{
    padding: 18px;
}
@media (min-width: 992px){
    .sx-page{ padding: 22px; }
}
.sx-page-header{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap: 14px;
    margin-bottom: 14px;
}
.sx-title{
    font-size: 18px;
    font-weight: 700;
    letter-spacing: .2px;
    margin: 0;
    color: var(--sx-text);
}
.sx-subtitle{
    margin-top: 4px;
    font-size: 13px;
    color: var(--sx-text-muted);
}
.sx-page-header__actions{
    display:flex;
    align-items:center;
    justify-content:flex-end;
    gap: 10px;
    flex-wrap: wrap;
}

/* ---------- Tables ---------- */
.sx-table{
    border-radius: var(--sx-radius);
    overflow: auto;
}
.sx-table .table{
    margin-bottom: 0;
}
.sx-table .table > :not(caption) > * > *{
    padding: .65rem .85rem;
}
.sx-table .table thead th{
    position: sticky;
    top: 0;
    z-index: 2;
    background: var(--sx-surface);
    border-bottom: 1px solid var(--sx-border);
    font-weight: 700;
    color: var(--sx-text);
    white-space: nowrap;
}
[data-bs-theme="dark"] .sx-table .table thead th{
    background: var(--sx-surface);
}

/* ---------- Empty state ---------- */
.sx-empty{
    display:flex;
    gap: 14px;
    align-items:flex-start;
    padding: 18px;
    border: 1px dashed var(--sx-border);
    border-radius: var(--sx-radius);
    background: color-mix(in srgb, var(--sx-surface) 92%, transparent);
}
.sx-empty__icon{
    width: 40px;
    height: 40px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius: 12px;
    background: var(--sx-surface-2);
    font-size: 18px;
}
.sx-empty__title{
    font-weight: 700;
    color: var(--sx-text);
}
.sx-empty__desc{
    margin-top: 2px;
    color: var(--sx-text-muted);
    font-size: 13px;
}
.sx-empty__actions{
    margin-top: 10px;
    display:flex;
    gap: 10px;
    flex-wrap: wrap;
}

/* ---------- Cards/forms subtle improvements ---------- */
.card{
    border-radius: var(--sx-radius);
}
.card .card-header{
    background: transparent;
    border-bottom: 1px solid var(--sx-border);
}


/* Skeleton loading */
.sx-skeleton{
  position:relative;
  overflow:hidden;
  background: color-mix(in srgb, var(--sx-border) 35%, transparent);
}
[data-bs-theme="dark"] .sx-skeleton{
  background: color-mix(in srgb, var(--sx-border) 55%, transparent);
}
.sx-skeleton::after{
  content:"";
  position:absolute;
  inset:0;
  transform:translateX(-100%);
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--sx-surface) 35%, transparent), transparent);
  animation: sx-shimmer 1.2s infinite;
}
@keyframes sx-shimmer{ to{ transform:translateX(100%);} }

.sx-skel-th .sx-skeleton, .sx-skel-th{ width: 100%; }
.sx-skel-td .sx-skeleton, .sx-skel-td{ width: 100%; }

/* Card section header tweaks */
.card .sx-section-header{ margin-top: -2px; }


/* =========================
   Forms (premium)
   ========================= */
.form-control, .form-select, .form-check-input {
  border-color: var(--sx-border);
}
.form-control, .form-select {
  border-radius: 12px;
  background-color: var(--sx-surface);
  color: var(--sx-text);
}
.form-control::placeholder { color: color-mix(in srgb, var(--sx-text-muted) 80%, transparent); }

.form-control:focus, .form-select:focus, .form-check-input:focus {
  border-color: color-mix(in srgb, var(--sx-accent) 65%, white);
  box-shadow: 0 0 0 .20rem rgba(var(--sx-accent-rgb), .20);
}

.form-check-input:checked {
  background-color: var(--sx-accent);
  border-color: var(--sx-accent);
}

/* Validation */
.was-validated .form-control:invalid, .form-control.is-invalid,
.was-validated .form-select:invalid, .form-select.is-invalid {
  border-color: rgba(220, 38, 38, .70);
  box-shadow: 0 0 0 .20rem rgba(220, 38, 38, .15);
}
.was-validated .form-control:valid, .form-control.is-valid,
.was-validated .form-select:valid, .form-select.is-valid {
  border-color: rgba(16, 185, 129, .60);
  box-shadow: 0 0 0 .20rem rgba(16, 185, 129, .14);
}
.invalid-feedback { font-size: .82rem; }

/* =========================
   Alerts & Toasts (modern)
   ========================= */
.alert {
  border-radius: 14px;
  border: 1px solid var(--sx-border);
  background: color-mix(in srgb, var(--sx-surface) 90%, var(--sx-surface-2));
  color: var(--sx-text);
  box-shadow: 0 1px 0 rgba(0,0,0,.02);
}
.alert a { color: var(--sx-accent-strong); }
.alert .btn-close { filter: grayscale(1); opacity: .6; }
.alert .btn-close:hover { opacity: .9; }

/* Subtle semantic tints */
.alert-success { border-color: rgba(16, 185, 129, .25); background: rgba(16, 185, 129, .08); }
.alert-danger  { border-color: rgba(220, 38, 38, .25); background: rgba(220, 38, 38, .08); }
.alert-warning { border-color: rgba(245, 158, 11, .28); background: rgba(245, 158, 11, .10); }
.alert-info    { border-color: rgba(59, 130, 246, .22); background: rgba(59, 130, 246, .08); }

.toast {
  border-radius: 14px;
  border: 1px solid var(--sx-border);
  background: var(--sx-surface);
  box-shadow: var(--sx-shadow);
  overflow: hidden;
}
.toast-header {
  background: color-mix(in srgb, var(--sx-surface) 88%, var(--sx-surface-2));
  color: var(--sx-text);
  border-bottom: 1px solid var(--sx-border);
}
.toast-body { color: var(--sx-text); }

/* =========================
   Tables (hover + actions)
   ========================= */
.table > :not(caption) > * > * { border-color: color-mix(in srgb, var(--sx-border) 85%, transparent); }

.table tbody tr { transition: background-color .12s ease; }
.table tbody tr:hover {
  background-color: color-mix(in srgb, var(--sx-surface-2) 65%, transparent);
}

/* Sticky actions column (right) */
th.sx-actions, td.sx-actions {
  position: sticky;
  right: 0;
  z-index: 2;
  background: var(--sx-surface);
}
.table thead th.sx-actions { z-index: 6; }

/* Keep hover for actions cell too */
.table tbody tr:hover td.sx-actions {
  background-color: color-mix(in srgb, var(--sx-surface-2) 65%, transparent);
}


/* Toasts */
.sx-toast-host{position:fixed; top:72px; right:16px; z-index:1080; display:flex; flex-direction:column; gap:10px; max-width:360px; width:calc(100vw - 32px);} 
.sx-toast{display:flex; align-items:flex-start; gap:10px; padding:12px 12px; border-radius:14px; box-shadow: 0 12px 30px rgba(0,0,0,.12); border:1px solid var(--sx-border); background: var(--sx-surface);}
.sx-toast-icon{width:28px; height:28px; border-radius:10px; display:flex; align-items:center; justify-content:center; font-weight:800; background: var(--sx-surface-2); color: var(--sx-text);} 
.sx-toast-title{font-weight:700; font-size:13px; line-height:1.2;}
.sx-toast-msg{font-size:12.5px; color: var(--sx-text-muted); margin-top:2px; line-height:1.35;}
.sx-toast-close{margin-left:auto; border:0; background:transparent; color: var(--sx-text-muted); padding:2px 6px; border-radius:10px;}
.sx-toast-close:hover{background: var(--sx-surface-2); color: var(--sx-text);} 
.sx-toast-success .sx-toast-icon{background: rgba(16,185,129,.15); color:#059669;}
.sx-toast-info .sx-toast-icon{background: rgba(59,130,246,.15); color:#2563eb;}
.sx-toast-warning .sx-toast-icon{background: rgba(245,158,11,.18); color:#b45309;}
.sx-toast-error .sx-toast-icon{background: rgba(239,68,68,.16); color:#dc2626;}

/* Actions menu (3-dots) */
.sx-actions-menu{position:relative; display:inline-block;}
.sx-actions-menu>summary{list-style:none;}
.sx-actions-menu>summary::-webkit-details-marker{display:none;}
.sx-actions-pop{position:absolute; top:50%; transform:translateY(-50%); right:calc(100% + 10px); min-width:180px; max-height:min(320px, calc(100vh - 24px)); overflow:auto; padding:8px; border-radius:14px; background: var(--sx-surface); border:1px solid var(--sx-border); box-shadow: 0 18px 40px rgba(0,0,0,.14);}
.sx-actions-pop.sx-open-right{left:calc(100% + 10px); right:auto;}
.sx-actions-pop .sx-menu-item{width:100%; display:flex; align-items:center; gap:10px; padding:10px 10px; border-radius:12px; border:0; background:transparent; text-align:left; color: var(--sx-text); font-size:13px;}
.sx-actions-pop .sx-menu-item:hover{background: var(--sx-surface-2);} 
.sx-actions-pop .sx-menu-item.danger{color:#dc2626;}
.sx-actions-pop .sx-menu-sep{height:1px; background: var(--sx-border); margin:6px 4px;}


/* Topbar search button */
.sx-search-btn{
    background: var(--sx-surface);
    border: 1px solid var(--sx-border);
    border-radius: 999px;
    padding: .45rem .65rem;
    color: var(--sx-text);
    box-shadow: 0 1px 0 rgba(0,0,0,.02);
    min-width: 280px;
}
.sx-search-btn:hover{
    border-color: rgba(var(--sx-accent-rgb), .35);
    box-shadow: 0 0 0 .2rem rgba(var(--sx-accent-rgb), .10);
}
.sx-search-placeholder{ color: var(--sx-muted); font-size: .9rem; }
.sx-kbd-hint kbd{
    background: var(--sx-surface-2);
    border: 1px solid var(--sx-border);
    border-bottom-width: 2px;
    padding: .05rem .35rem;
    border-radius: 6px;
    font-size: .75rem;
    color: var(--sx-muted);
}



/* Sidebar toggle button visibility */
.sx-sidebar-toggle-btn {
    border-color: rgba(17, 24, 39, .18);
    background: linear-gradient(180deg, #ffffff, #f6f7f9);
    box-shadow: 0 1px 0 rgba(255,255,255,.65), 0 1px 2px rgba(0,0,0,.06);
}
.sx-sidebar-toggle-btn .sx-ico {
    color: #374151;
}
.sx-sidebar-toggle-btn:hover {
    background: #eef2f7;
    border-color: rgba(var(--sx-accent-rgb), .38);
}
[data-bs-theme="dark"] .sx-sidebar-toggle-btn {
    background: var(--sx-surface);
    border-color: var(--sx-border);
    box-shadow: none;
}
[data-bs-theme="dark"] .sx-sidebar-toggle-btn .sx-ico {
    color: var(--sx-accent-strong);
}

/* Command palette */
.sx-cmd{ position: fixed; inset: 0; z-index: 1200; display: none; }
.sx-cmd[data-open="1"]{ display:block; }
.sx-cmd-overlay{ position:absolute; inset:0; background: rgba(0,0,0,.35); backdrop-filter: blur(2px); }
.sx-cmd-panel{
    position: absolute;
    left: 50%;
    top: 10vh;
    transform: translateX(-50%);
    width: min(720px, calc(100vw - 2rem));
    background: var(--sx-surface);
    border: 1px solid var(--sx-border);
    border-radius: calc(var(--sx-radius) + 4px);
    box-shadow: var(--sx-shadow);
    overflow: hidden;
}
.sx-cmd-header{
    display:flex;
    align-items:center;
    gap: .6rem;
    padding: .75rem .85rem;
    border-bottom: 1px solid var(--sx-border);
    background: linear-gradient(180deg, rgba(var(--sx-accent-rgb), .06), transparent);
}
.sx-cmd-icon{ width: 20px; height: 20px; opacity: .75; }
.sx-cmd-icon svg{ width: 20px; height: 20px; fill: currentColor; }
.sx-cmd-input{ border-radius: 12px; }
.sx-cmd-hint span{ opacity:.75; }
.sx-cmd-body{ max-height: 50vh; overflow:auto; padding: .5rem; }
.sx-cmd-list{ list-style:none; padding:0; margin:0; }
.sx-cmd-item{
    width:100%;
    text-align:left;
    border: 1px solid transparent;
    background: transparent;
    border-radius: 12px;
    padding: .7rem .75rem;
    display:flex;
    flex-direction:column;
    gap: .15rem;
}
.sx-cmd-item:hover{
    background: var(--sx-surface-2);
    border-color: rgba(var(--sx-accent-rgb), .15);
}
.sx-cmd-item-title{ font-weight: 600; color: var(--sx-text); }
.sx-cmd-item-sub{ font-size: .85rem; color: var(--sx-muted); }
.sx-cmd-footer{
    padding: .6rem .85rem;
    border-top: 1px solid var(--sx-border);
    background: var(--sx-surface-2);
}

/* KPI cards */
.sx-kpi{
    border: 1px solid var(--sx-border);
    border-radius: calc(var(--sx-radius) + 2px);
    box-shadow: 0 1px 0 rgba(0,0,0,.02);
    background: var(--sx-surface);
    padding: 1rem;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap: 1rem;
}
.sx-kpi .sx-kpi-title{ color: var(--sx-muted); font-size:.85rem; }
.sx-kpi .sx-kpi-value{ font-weight:700; font-size: 1.35rem; letter-spacing: -0.02em; }
.sx-kpi .sx-kpi-ico{
    width: 38px; height: 38px;
    border-radius: 12px;
    background: rgba(var(--sx-accent-rgb), .10);
    color: var(--sx-accent-strong);
    display:flex; align-items:center; justify-content:center;
}
.sx-kpi .sx-kpi-ico svg{ width: 20px; height: 20px; fill: currentColor; }



/* --- Actions menu layering fix: keep opened menu above other sticky action cells --- */
.sx-actions.sx-menu-open, td.sx-actions.sx-menu-open{z-index: 50 !important;}
details.sx-actions-menu[open]{z-index: 60;}
.sx-actions-pop{z-index: 70;}

/* ------------------------------------------------------------------
   Sidebar/Nav (GLOBAL SAFETY NET)
   NavMenu.razor.css is isolated. In some publish/setups isolated CSS
   can be missed/cached, causing links to render inline/underlined.
   These global rules guarantee the sidebar stays stacked & modern.
-------------------------------------------------------------------*/

.sx-nav{display:flex;flex-direction:column;}
.sx-nav-section{display:block;}

.sx-nav-link{
    display:flex;
    align-items:center;
    gap:.75rem;
    width:100%;
    padding:.65rem .75rem;
    border-radius:14px;
    color:var(--sx-sidebar-text);
    text-decoration:none;
    margin:.15rem 0;
}
    .sx-nav-link:hover {
        background: var(--sx-sidebar-hover);
        color: #fff;
        text-decoration: none;
    }
    .sx-nav-link.active {
        background: var(--sx-sidebar-active);
        color: #fff;
    }

.sx-nav-text {
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.sx-ico {
    width: 18px;
    height: 18px;
    display: inline-flex;
    flex: 0 0 18px;
    color: rgba(255,255,255,.85);
}
    .sx-ico svg {
        width: 18px;
        height: 18px;
        fill: currentColor;
    }


/* Card footer (fix dark mode white bar) */
.sx-card-footer,
.card-footer.sx-card-footer {
    background: var(--sx-surface-2);
    border-top: 1px solid var(--sx-border);
}

/* =========================
   Dashboard (Home)
========================= */
.sx-dashboard .card {
    background: var(--sx-surface);
}

.sx-hero-card {
    overflow: hidden;
    border: 1px solid var(--sx-border);
    background:
        radial-gradient(circle at top right, rgba(var(--sx-accent-rgb), .16), transparent 34%),
        linear-gradient(135deg, rgba(var(--sx-accent-rgb), .08), transparent 48%),
        var(--sx-surface);
}

.sx-hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    padding: .4rem .7rem;
    border-radius: 999px;
    background: rgba(var(--sx-accent-rgb), .10);
    color: var(--sx-accent-strong);
    font-size: .82rem;
    font-weight: 600;
}

.sx-hero-title {
    margin: 1rem 0 .5rem;
    font-size: clamp(1.55rem, 2vw, 2.2rem);
    line-height: 1.1;
    letter-spacing: -.03em;
}

.sx-hero-subtitle {
    max-width: 60ch;
    color: var(--sx-muted);
    line-height: 1.65;
}

.sx-hero-badges {
    display: flex;
    flex-wrap: wrap;
    gap: .6rem;
}

.sx-soft-badge {
    display: inline-flex;
    align-items: center;
    padding: .45rem .75rem;
    border-radius: 999px;
    border: 1px solid var(--sx-border);
    background: rgba(var(--sx-accent-rgb), .06);
    font-size: .8rem;
    color: var(--sx-text);
}

.sx-hero-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(160px, 1fr));
    gap: .85rem;
    width: min(100%, 430px);
}

.sx-hero-mini {
    border: 1px solid var(--sx-border);
    border-radius: 18px;
    padding: 1rem;
    background: rgba(var(--sx-accent-rgb), .05);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}

.sx-hero-mini__label,
.sx-kpi-meta,
.sx-bar-sub,
.sx-list-item__main span,
.sx-list-item__meta small,
.sx-list-empty,
.sx-alert-item span,
.sx-legend-text span,
.sx-hero-mini__meta {
    color: var(--sx-muted);
}

.sx-hero-mini__label {
    font-size: .78rem;
    margin-bottom: .35rem;
}

.sx-hero-mini__value {
    font-size: 1.45rem;
    font-weight: 700;
    letter-spacing: -.03em;
}

.sx-hero-mini__meta {
    font-size: .82rem;
    margin-top: .2rem;
}

.sx-quick-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .8rem;
}

.sx-quick-link {
    display: flex;
    flex-direction: column;
    gap: .2rem;
    padding: 1rem;
    border-radius: 18px;
    border: 1px solid var(--sx-border);
    background: linear-gradient(180deg, rgba(var(--sx-accent-rgb), .05), transparent 120%);
    text-decoration: none;
    color: var(--sx-text);
    transition: transform .14s ease, border-color .14s ease, background .14s ease;
}

.sx-quick-link:hover {
    transform: translateY(-1px);
    border-color: rgba(var(--sx-accent-rgb), .24);
    background: rgba(var(--sx-accent-rgb), .08);
    text-decoration: none;
}

.sx-quick-link span {
    font-weight: 700;
}

.sx-quick-link small {
    color: var(--sx-muted);
    line-height: 1.4;
}

.sx-kpi {
    min-height: 132px;
}

.sx-kpi--accent {
    background: linear-gradient(180deg, rgba(var(--sx-accent-rgb), .09), transparent 120%), var(--sx-surface);
}

.sx-kpi-meta {
    font-size: .82rem;
    margin-top: .25rem;
}

.sx-chart-card {
    display: flex;
    align-items: center;
    gap: 1.25rem;
}

.sx-donut {
    position: relative;
    flex: 0 0 180px;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: rgba(var(--sx-accent-rgb), .14);
}

.sx-donut::after {
    content: "";
    position: absolute;
    inset: 18px;
    border-radius: 50%;
    background: var(--sx-surface);
    box-shadow: inset 0 0 0 1px var(--sx-border);
}

.sx-donut--small {
    flex-basis: 150px;
    width: 150px;
    height: 150px;
}

.sx-donut--small::after {
    inset: 16px;
}

.sx-donut-inner {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.sx-donut-inner strong {
    font-size: 1.65rem;
    letter-spacing: -.03em;
}

.sx-donut-inner span {
    color: var(--sx-muted);
    font-size: .82rem;
}

.sx-legend-list {
    display: grid;
    gap: .8rem;
    width: 100%;
}

.sx-legend-item {
    display: flex;
    align-items: flex-start;
    gap: .75rem;
}

.sx-dot {
    width: 11px;
    height: 11px;
    border-radius: 50%;
    margin-top: .3rem;
    flex: 0 0 11px;
}

.sx-legend-text {
    display: flex;
    flex-direction: column;
    gap: .15rem;
}

.sx-legend-text strong {
    font-size: .95rem;
}

.sx-metric-stack {
    display: grid;
    gap: 1rem;
}

.sx-metric-row {
    margin-bottom: 1rem;
}

.sx-progress {
    height: 10px;
    border-radius: 999px;
    overflow: hidden;
    background: rgba(var(--sx-accent-rgb), .10);
    margin-top: .45rem;
}

.sx-progress > span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--sx-accent-strong), rgba(var(--sx-accent-rgb), .55));
}

.sx-progress--success > span {
    background: linear-gradient(90deg, #10b981, #6ee7b7);
}

.sx-progress--warning > span {
    background: linear-gradient(90deg, #f59e0b, #fcd34d);
}

.sx-inline-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .9rem;
}

.sx-inline-stats > div {
    border: 1px solid var(--sx-border);
    border-radius: 16px;
    padding: .95rem;
    background: rgba(var(--sx-accent-rgb), .04);
}

.sx-inline-stats strong {
    display: block;
    font-size: 1.2rem;
}

.sx-inline-stats span {
    display: block;
    color: var(--sx-muted);
    font-size: .82rem;
    margin-top: .1rem;
}

.sx-bar-chart {
    min-height: 280px;
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: .95rem;
    align-items: end;
}

.sx-bar-col {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .45rem;
}

.sx-bar-value {
    font-size: .82rem;
    color: var(--sx-muted);
}

.sx-bar-track {
    width: 100%;
    height: 210px;
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(var(--sx-accent-rgb), .05), rgba(var(--sx-accent-rgb), .14));
    position: relative;
    overflow: hidden;
    border: 1px solid var(--sx-border);
    display: flex;
    align-items: flex-end;
}

.sx-bar-fill {
    width: 100%;
    min-height: 10%;
    border-radius: 14px 14px 0 0;
    background: linear-gradient(180deg, rgba(var(--sx-accent-rgb), .45), var(--sx-accent-strong));
}

.sx-bar-label {
    font-weight: 700;
    font-size: .88rem;
}

.sx-bar-sub {
    font-size: .76rem;
}

.sx-alert-list,
.sx-list {
    display: grid;
    gap: .8rem;
}

.sx-alert-item {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 1rem;
    border: 1px solid var(--sx-border);
    border-radius: 18px;
    padding: .95rem 1rem;
    background: rgba(var(--sx-accent-rgb), .04);
    color: var(--sx-text);
    text-decoration: none;
}

/* Sada aksiyon olan listeler */
.sx-list-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    border: 1px solid var(--sx-border);
    border-radius: 18px;
    padding: .95rem 1rem;
    background: rgba(var(--sx-accent-rgb), .04);
    color: var(--sx-text);
    text-decoration: none;
}

/* Alert text block */
.sx-alert-item > div {
    flex: 1;
    min-width: 0;
}

.sx-alert-item:hover,
.sx-list-item:hover {
    border-color: rgba(var(--sx-accent-rgb), .24);
    background: rgba(var(--sx-accent-rgb), .08);
    text-decoration: none;
}

.sx-list-item--static:hover {
    background: rgba(var(--sx-accent-rgb), .04);
    border-color: var(--sx-border);
}

.sx-alert-icon {
    width: 40px;
    height: 40px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(var(--sx-accent-rgb), .10);
    flex: 0 0 40px;
}

.sx-alert-item div,
.sx-list-item__main {
    display: flex;
    flex-direction: column;
    gap: .2rem;
    min-width: 0;
}

.sx-alert-item strong,
.sx-list-item__main strong {
    font-size: .95rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sx-list-item__meta {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: .35rem;
    white-space: nowrap;
}

.sx-list-empty {
    border: 1px dashed var(--sx-border);
    border-radius: 18px;
    padding: 1rem;
    text-align: center;
    background: rgba(var(--sx-accent-rgb), .03);
}

@media (max-width: 1199.98px) {
    .sx-hero-grid {
        width: 100%;
    }
}

@media (max-width: 991.98px) {
    .sx-quick-actions,
    .sx-inline-stats {
        grid-template-columns: 1fr;
    }

    .sx-chart-card {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 767.98px) {
    .sx-hero-grid {
        grid-template-columns: 1fr;
    }

    .sx-bar-chart {
        gap: .6rem;
    }

    .sx-bar-track {
        height: 160px;
    }

    .sx-alert-item,
    .sx-list-item {
        align-items: flex-start;
        flex-direction: column;
    }

    .sx-list-item__meta {
        align-items: flex-start;
    }
}

.sx-donut-wrap {
    display: flex;
    gap: 1.25rem;
    align-items: center;
}

.sx-donut--sm,
.sx-donut--small {
    flex-basis: 150px;
    width: 150px;
    height: 150px;
}

.sx-donut--sm::after,
.sx-donut--small::after {
    inset: 16px;
}

.sx-donut-legend {
    display: grid;
    gap: .8rem;
    width: 100%;
}

.sx-donut-legend__item {
    display: flex;
    align-items: flex-start;
    gap: .75rem;
}

.sx-line-chart {
    display: grid;
    gap: 1rem;
}

.sx-line-chart__summary {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .85rem;
}

.sx-line-chart__summary > div {
    border: 1px solid var(--sx-border);
    border-radius: 16px;
    padding: .9rem 1rem;
    background: rgba(var(--sx-accent-rgb), .04);
}

.sx-line-chart__summary span {
    display: block;
    color: var(--sx-muted);
    font-size: .8rem;
}

.sx-line-chart__summary strong {
    display: block;
    margin-top: .2rem;
    font-size: 1.05rem;
}

.sx-line-chart__svg {
    width: 100%;
    height: 260px;
    overflow: visible;
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(var(--sx-accent-rgb), .03), transparent 90%);
}

.sx-line-chart__grid {
    stroke: rgba(var(--sx-accent-rgb), .14);
    stroke-width: .45;
    stroke-dasharray: 2 2;
}

.sx-line-chart__area {
    fill: rgba(var(--sx-accent-rgb), .10);
    stroke: transparent;
}

.sx-line-chart__path {
    fill: none;
    stroke: var(--sx-accent-strong);
    stroke-width: 1.5;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.sx-line-chart__dot {
    fill: var(--sx-accent-strong);
}

.sx-line-chart__labels {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(52px, 1fr));
    gap: .4rem;
    color: var(--sx-muted);
    font-size: .74rem;
}

.sx-attendance-card {
    display: flex;
    gap: 1.25rem;
    align-items: center;
}

.sx-attendance-ring {
    --value: 0;
    position: relative;
    width: 168px;
    height: 168px;
    border-radius: 50%;
    background: conic-gradient(#10b981 0 calc(var(--value) * 1%), rgba(var(--sx-accent-rgb), .10) 0 100%);
    flex: 0 0 168px;
}

.sx-attendance-ring::after {
    content: "";
    position: absolute;
    inset: 16px;
    border-radius: 50%;
    background: var(--sx-surface);
    box-shadow: inset 0 0 0 1px var(--sx-border);
}

.sx-attendance-ring > div {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.sx-attendance-ring strong {
    font-size: 1.5rem;
}

.sx-attendance-ring span {
    color: var(--sx-muted);
    font-size: .82rem;
}

.sx-weekday-list {
    display: grid;
    gap: .95rem;
}

.sx-weekday-item {
    border: 1px solid var(--sx-border);
    border-radius: 16px;
    padding: .9rem 1rem;
    background: rgba(var(--sx-accent-rgb), .04);
}

@media (max-width: 991.98px) {
    .sx-donut-wrap,
    .sx-attendance-card {
        flex-direction: column;
        align-items: flex-start;
    }

    .sx-line-chart__summary {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .sx-line-chart__labels {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

/* ---------- User menu ---------- */
.sx-user-menu {
    position: relative;
}

.sx-user-pill-btn {
    min-height: 42px;
    font-weight: 600;
}

    .sx-user-pill-btn .sx-ico {
        width: 18px;
        height: 18px;
    }

.sx-user-chevron {
    display: inline-flex;
    width: 16px;
    height: 16px;
    transition: transform .18s ease;
    opacity: .75;
}

    .sx-user-chevron.open {
        transform: rotate(180deg);
    }

.sx-user-dropdown {
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    min-width: 300px;
    padding: .6rem;
    border-radius: 20px;
    border: 1px solid var(--sx-border);
    background: var(--sx-surface);
    box-shadow: 0 24px 60px rgba(15, 23, 42, .16);
    z-index: 1200;
}

[data-bs-theme="dark"] .sx-user-dropdown {
    box-shadow: 0 24px 60px rgba(0, 0, 0, .38);
}

.sx-user-dropdown-overlay {
    position: fixed;
    inset: 0;
    z-index: 1100;
}

.sx-user-dropdown-item {
    width: 100%;
    display: flex;
    align-items: center;
    gap: .8rem;
    border: 0;
    background: transparent;
    color: var(--sx-text);
    padding: .8rem .9rem;
    border-radius: 14px;
    text-align: left;
    text-decoration: none;
    font-size: .95rem;
}

    .sx-user-dropdown-item:hover {
        background: rgba(var(--sx-accent-rgb), .08);
    }

    .sx-user-dropdown-item .sx-ico {
        width: 18px;
        height: 18px;
        flex: 0 0 auto;
        color: var(--sx-text);
    }

        .sx-user-dropdown-item .sx-ico svg {
            fill: currentColor;
        }

    .sx-user-dropdown-item.is-disabled {
        opacity: .55;
        cursor: not-allowed;
    }

    .sx-user-dropdown-item.danger {
        color: #dc3545;
    }

.sx-user-dropdown-note {
    margin-left: auto;
    font-size: .75rem;
    color: var(--sx-text-muted);
}

/* ---------- Account page ---------- */
.sx-account-page {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.sx-account-hero {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.4rem;
    border-radius: 28px;
    border: 1px solid var(--sx-border);
    background: radial-gradient(circle at top right, rgba(var(--sx-accent-rgb), .16), transparent 28%), linear-gradient(180deg, rgba(var(--sx-accent-rgb), .05), rgba(var(--sx-accent-rgb), .02)), var(--sx-surface);
    box-shadow: 0 14px 40px rgba(15, 23, 42, .06);
}

.sx-account-hero__main {
    display: flex;
    align-items: center;
    gap: 1rem;
    min-width: 0;
}

.sx-account-avatar {
    width: 72px;
    height: 72px;
    border-radius: 24px;
    display: grid;
    place-items: center;
    font-size: 1.15rem;
    font-weight: 800;
    color: white;
    background: linear-gradient(135deg, var(--sx-accent), var(--sx-accent-strong));
    box-shadow: 0 12px 26px rgba(var(--sx-accent-rgb), .28);
    flex: 0 0 auto;
}

.sx-account-eyebrow {
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--sx-text-muted);
    margin-bottom: .35rem;
}

.sx-account-name {
    margin: 0;
    font-size: 1.55rem;
    font-weight: 800;
    color: var(--sx-text);
}

.sx-account-meta {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-top: .7rem;
}

.sx-account-chip {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: .3rem .75rem;
    border-radius: 999px;
    border: 1px solid var(--sx-border);
    background: rgba(var(--sx-accent-rgb), .06);
    color: var(--sx-text);
    font-size: .84rem;
    font-weight: 600;
}

.sx-account-grid {
    display: grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 1rem;
}

.sx-panel {
    border-radius: 24px;
    border: 1px solid var(--sx-border);
    background: var(--sx-surface);
    padding: 1.25rem;
    box-shadow: 0 10px 30px rgba(15, 23, 42, .04);
}

.sx-panel__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.sx-panel__title {
    margin: 0;
    font-size: 1.02rem;
    font-weight: 800;
    color: var(--sx-text);
}

.sx-panel__subtitle {
    margin-top: .25rem;
    font-size: .88rem;
    color: var(--sx-text-muted);
}

.sx-kv-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .9rem;
}

.sx-kv-item {
    padding: .95rem 1rem;
    border-radius: 18px;
    border: 1px solid var(--sx-border);
    background: var(--sx-surface-2);
}

.sx-kv-item--full {
    grid-column: 1 / -1;
}

.sx-kv-label {
    font-size: .8rem;
    font-weight: 700;
    color: var(--sx-text-muted);
    margin-bottom: .35rem;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.sx-kv-value {
    font-size: .97rem;
    font-weight: 600;
    color: var(--sx-text);
    word-break: break-word;
}

.sx-password-panel {
    overflow: hidden;
}

.sx-password-actions {
    display: flex;
    gap: .75rem;
    flex-wrap: wrap;
    margin-top: 1rem;
}

@media (max-width: 991.98px) {
    .sx-account-hero {
        flex-direction: column;
        align-items: stretch;
    }

    .sx-account-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .sx-account-hero__main {
        align-items: flex-start;
    }

    .sx-kv-grid {
        grid-template-columns: 1fr;
    }
}

.sx-user-dropdown-profile {
    display: flex;
    align-items: center;
    gap: .9rem;
    padding: 1rem;
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(var(--sx-accent-rgb), .10), rgba(var(--sx-accent-rgb), .05)), var(--sx-surface-2);
    border: 1px solid rgba(var(--sx-accent-rgb), .14);
    margin-bottom: .55rem;
}

.sx-user-dropdown-profile__avatar {
    width: 48px;
    height: 48px;
    border-radius: 16px;
    display: grid;
    place-items: center;
    flex: 0 0 auto;
    color: #fff;
    background: linear-gradient(135deg, var(--sx-accent), var(--sx-accent-strong));
    box-shadow: 0 10px 24px rgba(var(--sx-accent-rgb), .24);
    font-size: .95rem;
    font-weight: 800;
    letter-spacing: .04em;
}

.sx-user-dropdown-profile__body {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: .18rem;
}

.sx-user-dropdown-profile__name {
    font-size: .96rem;
    font-weight: 800;
    color: var(--sx-text);
    line-height: 1.2;
    word-break: break-word;
}

.sx-user-dropdown-profile__welcome {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    font-size: .83rem;
    font-weight: 600;
    color: var(--sx-text-muted);
    line-height: 1.25;
    flex-wrap: wrap;
}

.sx-user-dropdown-profile__wave {
    display: inline-flex;
    width: 16px;
    height: 16px;
    color: var(--sx-accent);
}

    .sx-user-dropdown-profile__wave svg {
        width: 16px;
        height: 16px;
        fill: currentColor;
    }

.sx-user-dropdown-divider {
    height: 1px;
    background: var(--sx-border);
    opacity: .9;
    margin: .15rem 0 .45rem;
}

.sx-tenant-pill {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    padding: .45rem .9rem;
    border-radius: 999px;
    border: 1px solid var(--sx-border);
    background: var(--sx-surface);
    font-size: .85rem;
    font-weight: 600;
    color: var(--sx-text);
}

.sx-tenant-pill-icon {
    display: inline-flex;
    width: 16px;
    height: 16px;
    color: var(--sx-text-muted);
}

    .sx-tenant-pill-icon svg {
        width: 16px;
        height: 16px;
    }

.sx-tenant-pill-label {
    opacity: .7;
    font-weight: 500;
}

.sx-tenant-pill-name {
    font-weight: 700;
}

.sx-tenant-pill:hover {
    background: rgba(var(--sx-accent-rgb), .08);
    border-color: rgba(var(--sx-accent-rgb), .35);
}

.sx-folder-item-main {
    min-width: 0;
}

.sx-folder-link {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    padding: 0;
    margin: 0 0 .15rem;
    border: 0;
    background: transparent;
    color: var(--sx-text);
    font-weight: 700;
    text-align: left;
    text-decoration: none;
}

.sx-folder-link:hover {
    color: var(--sx-accent-strong);
}

.sx-folder-link__icon {
    font-size: 1rem;
    line-height: 1;
}

.sx-folder-link__text {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}


/* ---------- Revision / Portal badges ---------- */
.sx-soft-badge--info {
    background: rgba(var(--sx-accent-rgb), .10);
    color: var(--sx-accent-strong);
    border-color: rgba(var(--sx-accent-rgb), .18);
}

.sx-soft-badge--info-alt {
    background: rgba(var(--sx-accent-rgb), .06);
    color: var(--sx-text);
    border-color: rgba(var(--sx-accent-rgb), .14);
}

.sx-soft-badge--warning {
    background: rgba(245, 158, 11, .12);
    color: #b45309;
    border-color: rgba(245, 158, 11, .18);
}

.sx-soft-badge--success {
    background: rgba(34, 197, 94, .12);
    color: #15803d;
    border-color: rgba(34, 197, 94, .18);
}

.sx-soft-badge--danger {
    background: rgba(239, 68, 68, .12);
    color: #b91c1c;
    border-color: rgba(239, 68, 68, .18);
}

.sx-soft-badge--neutral {
    background: rgba(100, 116, 139, .12);
    color: var(--sx-text);
    border-color: rgba(100, 116, 139, .18);
}

[data-bs-theme="dark"] .sx-soft-badge--warning {
    color: #fbbf24;
}

[data-bs-theme="dark"] .sx-soft-badge--success {
    color: #4ade80;
}

[data-bs-theme="dark"] .sx-soft-badge--danger {
    color: #f87171;
}

.sx-inline-dot {
    width: .55rem;
    height: .55rem;
    border-radius: 999px;
    background: rgba(var(--sx-accent-rgb), .8);
    box-shadow: 0 0 0 3px rgba(var(--sx-accent-rgb), .12);
    flex: 0 0 auto;
}

.sx-revision-context {
    border: 1px solid var(--sx-border);
    border-radius: 16px;
    padding: .9rem 1rem;
    background: rgba(var(--sx-accent-rgb), .04);
    display: grid;
    gap: .25rem;
}


/* =========================
   Portal Dashboard
========================= */
.sx-portal-dashboard .sx-kpi {
    min-height: 138px;
}

.sx-portal-scoreboard {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.sx-portal-scoreboard__item {
    border: 1px solid var(--sx-border);
    border-radius: 18px;
    padding: 1rem;
    background: linear-gradient(180deg, rgba(var(--sx-accent-rgb), .06), transparent 140%);
    display: flex;
    flex-direction: column;
    gap: .3rem;
}

.sx-portal-scoreboard__item span,
.sx-portal-note span {
    color: var(--sx-muted);
}

.sx-portal-scoreboard__item strong {
    font-size: 1.4rem;
    letter-spacing: -.03em;
}

.sx-portal-scoreboard__item small {
    color: var(--sx-muted);
    font-size: .8rem;
}

.sx-portal-note {
    border: 1px dashed var(--sx-border);
    border-radius: 18px;
    padding: 1rem 1.1rem;
    background: rgba(var(--sx-accent-rgb), .03);
    display: flex;
    flex-direction: column;
    gap: .45rem;
    line-height: 1.6;
}

.sx-portal-note a {
    color: var(--sx-accent-strong);
    text-decoration: none;
}

.sx-portal-note a:hover {
    text-decoration: underline;
}

@media (max-width: 991.98px) {
    .sx-portal-scoreboard {
        grid-template-columns: 1fr;
    }
}
.sx-user-tabs .nav-link {
    border-radius: 999px;
    padding: .55rem .95rem;
}

    .sx-user-tabs .nav-link.active {
        font-weight: 600;
    }



/* ===== Public Auth / Password Flows ===== */
:root,
[data-bs-theme="light"],
[data-bs-theme="dark"] {
  --sx-bg-soft: #0f172a;
}

[data-bs-theme="light"] {
  --sx-bg-soft: #edf2ff;
}

[data-bs-theme="dark"] {
  --sx-bg-soft: #09101c;
}

.sx-auth-shell {
  min-height: 100vh;
  position: relative;
  overflow: hidden;
  background:
      radial-gradient(circle at top left, rgba(59, 130, 246, .16), transparent 30%),
      radial-gradient(circle at 100% 0%, rgba(16, 185, 129, .14), transparent 24%),
      radial-gradient(circle at bottom right, rgba(139, 92, 246, .12), transparent 28%),
      linear-gradient(180deg, var(--sx-bg), var(--sx-bg-soft));
  padding: 2rem 1rem;
}

.sx-auth-shell__backdrop {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
      linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
      linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,.85), transparent 92%);
}

.sx-auth-shell__content {
  position: relative;
  z-index: 1;
  max-width: 1180px;
  margin: 0 auto;
}

.sx-public-auth {
  display: grid;
  grid-template-columns: minmax(320px, 460px) minmax(0, 1fr);
  gap: 1.4rem;
  align-items: stretch;
}

.sx-public-auth__hero,
.sx-public-auth__panel {
  border-radius: 30px;
  border: 1px solid rgba(255,255,255,.1);
  box-shadow: 0 30px 80px rgba(15, 23, 42, .18);
  backdrop-filter: blur(14px);
}

.sx-public-auth__hero {
  padding: 2rem;
  background: linear-gradient(180deg, rgba(15, 23, 42, .72), rgba(15, 23, 42, .88));
  color: #f8fafc;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.sx-public-auth__eyebrow {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: .45rem .9rem;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.sx-public-auth__hero h1 {
  margin: 0;
  font-size: clamp(2rem, 3vw, 3rem);
  line-height: 1.05;
  font-weight: 800;
}

.sx-public-auth__hero p {
  margin: 0;
  color: rgba(248, 250, 252, .78);
  line-height: 1.65;
}

.sx-public-auth__steps {
  display: grid;
  gap: .8rem;
}

.sx-public-step {
  display: flex;
  align-items: center;
  gap: .9rem;
  padding: .9rem 1rem;
  border-radius: 20px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  color: rgba(248,250,252,.7);
}

.sx-public-step.is-active {
  background: rgba(59, 130, 246, .18);
  border-color: rgba(96, 165, 250, .35);
  color: #fff;
}

.sx-public-step > span {
  width: 2rem;
  height: 2rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  font-weight: 800;
}

.sx-public-step strong,
.sx-public-step small {
  display: block;
}

.sx-public-step small {
  color: inherit;
  opacity: .75;
  margin-top: .15rem;
}

.sx-public-auth__info {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1rem 1.1rem;
  border-radius: 22px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  margin-top: auto;
}

.sx-public-auth__info-icon {
  width: 2.3rem;
  height: 2.3rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 16px;
  background: rgba(255,255,255,.1);
  font-size: 1.1rem;
  flex: 0 0 auto;
}

.sx-public-auth__info strong {
  display: block;
  margin-bottom: .2rem;
}

.sx-public-auth__panel {
  background: rgba(255,255,255,.92);
  padding: 2rem;
}

[data-bs-theme='dark'] .sx-public-auth__panel {
  background: rgba(17, 24, 39, .88);
}

.sx-public-panel__header {
  margin-bottom: 1.5rem;
}

.sx-public-panel__header h2 {
  margin: 0 0 .45rem;
  font-size: 1.6rem;
  font-weight: 800;
}

.sx-public-panel__header p {
  margin: 0;
  color: var(--sx-text-muted);
  line-height: 1.6;
}

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

.sx-public-form-grid--single {
  grid-template-columns: 1fr;
}

.sx-public-field label {
  display: block;
  margin-bottom: .5rem;
  font-weight: 700;
  color: var(--sx-text);
}

.sx-public-field .form-control {
  min-height: 60px;
  border-radius: 18px;
  padding-inline: 1rem;
  background: rgba(var(--sx-accent-rgb), .04);
  border-color: rgba(var(--sx-accent-rgb), .14);
}

.sx-public-field .form-control:focus {
  background: rgba(var(--sx-accent-rgb), .05);
}

.sx-public-code-input {
  text-align: center;
  letter-spacing: .45em;
  font-size: 1.3rem;
  font-weight: 800;
}

.sx-public-inline-note {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  padding: .9rem 1rem;
  border-radius: 18px;
  background: rgba(var(--sx-accent-rgb), .06);
  border: 1px solid rgba(var(--sx-accent-rgb), .12);
  color: var(--sx-text);
}

.sx-public-inline-note > span {
  width: 1.7rem;
  height: 1.7rem;
  border-radius: 999px;
  background: rgba(var(--sx-accent-rgb), .12);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: .9rem;
  font-weight: 700;
  flex: 0 0 auto;
}

.sx-public-alert {
  padding: 1rem 1.1rem;
  border-radius: 18px;
  border: 1px solid transparent;
  line-height: 1.55;
}

.sx-public-alert--danger {
  background: rgba(239, 68, 68, .1);
  color: #ef4444;
  border-color: rgba(239, 68, 68, .2);
}

.sx-public-alert--success {
  background: rgba(16, 185, 129, .1);
  color: #059669;
  border-color: rgba(16, 185, 129, .2);
}

.sx-public-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.sx-public-actions .btn {
  border-radius: 16px;
  padding: .85rem 1.15rem;
  font-weight: 700;
}

.sx-password-checklist {
  border: 1px solid rgba(var(--sx-accent-rgb), .12);
  background: rgba(var(--sx-accent-rgb), .04);
  border-radius: 24px;
  padding: 1rem;
}

.sx-password-checklist__title {
  font-weight: 800;
  margin-bottom: .9rem;
}

.sx-password-checklist__items {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .7rem;
}

.sx-password-check {
  display: flex;
  align-items: center;
  gap: .7rem;
  min-height: 48px;
  padding: .8rem .9rem;
  border-radius: 18px;
  border: 1px solid rgba(var(--sx-accent-rgb), .1);
  background: rgba(255,255,255,.55);
  color: var(--sx-text-muted);
  font-weight: 600;
}

[data-bs-theme='dark'] .sx-password-check {
  background: rgba(15, 23, 42, .28);
}

.sx-password-check span:first-child {
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid currentColor;
  font-size: .85rem;
  font-weight: 800;
  flex: 0 0 auto;
}

.sx-password-check.is-ok {
  color: #16a34a;
  border-color: rgba(22, 163, 74, .18);
  background: rgba(22, 163, 74, .08);
}

@media (max-width: 991.98px) {
  .sx-public-auth {
    grid-template-columns: 1fr;
  }

  .sx-public-auth__hero,
  .sx-public-auth__panel {
    padding: 1.4rem;
    border-radius: 24px;
  }
}

@media (max-width: 767.98px) {
  .sx-public-form-grid,
  .sx-password-checklist__items {
    grid-template-columns: 1fr;
  }

  .sx-public-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .sx-public-actions > * {
    width: 100%;
  }
}
