:root {
    --bg: #ffffff;
    --grid: #e5e7eb;
    --card: #ffffff;
    --card2: #f8fafc;
    --text: #0f172a;
    --muted: #64748b;
    --border: #cbd5e1;
    --blue: #2563eb;
    --blue2: #1e40af;
    --chip: #f1f5f9;
    --shadow: 0 10px 24px rgba(2,6,23,.10);
    --barMaxW: 52px;
    --drawerW: 520px;
    --drawerGap: 14px;
}


[data-theme="dark"] {
    --bg: #0b1220;
    --grid: #142036;
    --card: #050b18;
    --card2: #070f22;
    --text: #e5e7eb;
    --muted: #9aa4b2;
    --border: #22304a;
    --blue: #2f6cf6;
    --blue2: #1f55d6;
    --chip: #0b1630;
    --shadow: 0 18px 40px rgba(0,0,0,.45);
}

html {
    font-size: 14px;
}

@media (min-width: 768px) {
    html {
        font-size: 16px;
    }
}

body {
    background: radial-gradient(circle at 20% 20%, #eef2ff 0%, #f7f9ff 40%, #e5e7eb 100%);
    color: #1f2933;
    font-family: "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
    box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

html {
    position: relative;
    min-height: 100%;
}

body {
    margin-bottom: 60px;
}

.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;
}

.header-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
}

.actions-container {
    margin-left: auto;
}

.select2 {
    border: 1px solid #cfcfcf;
    height: 37px;
    border-radius: 5px;
}


/* Limit Select2 dropdown height and enable scrolling */
.select2-container .select2-results__options {
    max-height: 350px; /* adjust as needed */
    overflow-y: auto;
}

.select2-container .select2-selection--single .select2-selection__rendered {
    padding-top: 8px;
}


.k-svg-icon.k-icon-xs {
    width: 24px !important;
    height: 24px !important;
}

.blurred {
    filter: blur(6px);
    user-select: none;
    pointer-events: none;
}

/* html2pdf uses print-like rules; these help pagination */
.pdf-page-break {
    break-after: page;
    page-break-after: always;
}

/* avoid splitting a card across pages */
.pdf-card {
    break-inside: avoid;
    page-break-inside: avoid;
}

.k-splitbar {
    background-color: #e5e7eb !important;
    border-radius: 10px !important;
    max-width: 15px !important;
    min-width: 15px !important;
}

.k-splitter{
    background-color:transparent !important;
    border:none !important;
    color:transparent !important;
}
.splitter-pane {
    background-color: transparent !important;
    border: none !important;
}

.next-prev-button-container {
    display: flex;
    justify-content: flex-end; /* move to the right */
    align-items: center;
    gap: 8px; /* space between buttons */
    margin-right: 10px;
}

.btn-circle {
    width: 37px;
    height: 37px;
    border-radius: 50%;
    border: 1px solid #d0d5dd;
    background: #ffffff;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s ease;
    box-shadow: 0 1px 2px rgba(16,24,40,0.05);
    padding: 0;
}

    .btn-circle svg {
        width: 22px !important;
        height: 22px !important;
        transition: transform 0.25s ease;
    }

    .btn-circle[aria-expanded="true"] svg {
        transform: rotate(90deg);
    }

    .btn-circle:hover {
        border-color: #2563eb;
        color: #2563eb;
        box-shadow: 0 4px 10px rgba(37,99,235,0.15);
    }

.nav-count {
    display: inline-flex;
    min-width: 72px;
    height: 44px;
    padding: 0 12px;
    border-radius: 999px;
    background: #f8fafc;
    border: 1px solid #e5e7eb;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    color: #0f172a;
    letter-spacing: 0.2px;
    margin-top: -5px;
}

    .nav-count .slash {
        margin: 0 6px;
        color: #64748b;
        font-weight: 700;
    }

button {
    padding: 10px 14px;
    border-radius: 10px;
    border: 1px solid var(--border);
    background: var(--card2);
    font-weight: 900;
    cursor: pointer;
    color: var(--text);
}

.primary {
    background: rgba(47,108,246,.16);
    border-color: rgba(47,108,246,.45);
}

.danger {
    background: rgba(239,68,68,.14);
    border-color: rgba(239,68,68,.45);
}

select {
    width: 100%;
    padding: 10px;
    border-radius: 10px;
    border: 1px solid var(--border);
    background: var(--card2);
    color: var(--text);
}

.card {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 14px 40px rgba(24, 39, 75, 0.12);
}

.cardHeader {
    padding: 10px 12px;
    font-weight: 900;
    border-bottom: 1px solid var(--border);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
}