/* container */
.table-container {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: calc(100vh - 220px);
}

.custom-modern-grid.e-grid {
    height: 100% !important;
    border: none !important;
    background: transparent !important;
    border-radius: 0 !important;
    font-family: var(--font-primary);
    font-size: var(--font-size-sm);
    font-weight: 400;
}

/* Header Container */
.custom-modern-grid.e-grid .e-gridheader {
    background-color: var(--color-table-header);
    border-radius: var(--radius-12) var(--radius-12) 0 0;
    overflow: hidden !important;
}

.custom-modern-grid.e-grid .e-headercontent {
    background-color: var(--color-table-header);
    border-right: none !important;
}

/* Header Cells */
.custom-modern-grid.e-grid .e-headercell {
    background: var(--color-table-header) !important;
    color: var(--color-black);
    padding: var(--spacing-sm) var(--spacing-lg);
    border: none;
    line-height: var(--line-height-20);
}

/* Header text */
.custom-modern-grid.e-grid .e-headertext {
    font-weight: 600;
    font-size: var(--font-size-sm);
}

/* Body Container */
.custom-modern-grid.e-grid .e-gridcontent {
    border-radius: 0 0 var(--radius-12) var(--radius-12) !important;
    overflow: hidden !important;
    background-color: var(--color-bg-main) !important;
}

/* (Body Cells) */
.custom-modern-grid.e-grid .e-rowcell {
    padding: var(--spacing-sm) var(--spacing-lg) !important;
    border: none !important;
    border-bottom: 1px solid var(--color-border-secondary) !important;
    color: var(--color-text-primary) !important;
    vertical-align: middle !important;
    background-color: var(--color-bg-main) !important;
}

.custom-modern-grid.e-grid .e-content{
    background-color: var(--color-bg-main) !important;
}

/* Hover State */
.custom-modern-grid.e-grid .e-row:hover .e-rowcell {
    background: var(--color-bg-secondary) !important;
}

/* Active / Selected State */
.custom-modern-grid.e-grid .e-row[aria-selected="true"] .e-rowcell,
.custom-modern-grid.e-grid .e-row.e-active .e-rowcell {
    background: var(--color-dlb-hover) !important;
}

/* =======================================================
   CUSTOM SCROLLBAR FOR SYNCFUSION
   ======================================================= */
/* ขนาดของ Scrollbar */
.custom-modern-grid.e-grid .e-content::-webkit-scrollbar,
.custom-modern-grid.e-grid .e-scrollbar::-webkit-scrollbar {
    width: var(--scrollbar-width); /* แกน Y */
    height: var(--scrollbar-width); /* แกน X */
}

/* สีพื้นหลังของ Scrollbar (Track) */
.custom-modern-grid.e-grid .e-content::-webkit-scrollbar-track,
.custom-modern-grid.e-grid .e-scrollbar::-webkit-scrollbar-track {
    background: var(--color-bg-secondary);
}

/* กำหนดตัวจับ Scrollbar (Thumb) - ตัวนี้แหละที่ทำให้มองเห็น! */
.custom-modern-grid.e-grid .e-content::-webkit-scrollbar-thumb,
.custom-modern-grid.e-grid .e-scrollbar::-webkit-scrollbar-thumb {
    background: var(--color-border-tertiary); /* สีของตัวจับ */
    border-radius: var(--radius-6); /* ทำให้ตัวจับมีความโค้งมน */
    border: 2px solid var(--color-bg-secondary); /* ทำขอบให้ดูมีมิติ (Option) */
}

/* ตอนนำเมาส์ไปชี้ที่ตัวจับ (Hover) ให้สีเข้มขึ้น */
.custom-modern-grid.e-grid .e-content::-webkit-scrollbar-thumb:hover,
.custom-modern-grid.e-grid .e-scrollbar::-webkit-scrollbar-thumb:hover {
    background: var(--color-text-quaternary);
}

/* Toolbar */
.custom-modern-grid.e-grid .e-toolbar {
    background: transparent !important;
    border: none !important;
    font-family: var(--font-primary);
}

.custom-modern-grid.e-grid .e-toolbar .e-toolbar-items {
    background: transparent !important;
}

.e-control.e-toolbar.e-lib.custom-modern-grid.e-keyboard {
    text-align: right !important;
}

.main-table-container {
    max-height: calc(100vh - 60%);
}

.sub-table-container {
    max-height: calc(100vh - 68%);
}

.e-centeralign {
    text-align: center;
}

.e-centeralign .badge {
    display: inline-block;
}

block-ui-cards p {
    line-break: anywhere;
}

@keyframes spinnerz {
    100% {
        transform: rotate(1turn);
    }
}

.loader-container-box {
    display: flex;
    align-items: center;
    justify-content: center;
}

.loader-container-box .loader {
    width: 50px;
    aspect-ratio: 1;
    display: grid;
    border-radius: 50%;
    background: linear-gradient(0deg, rgb(var(--light)) 40%, rgba(0, 0, 0, 0) 0 70%, rgb(var(--light), 0.2) 0) 50%/8% 100%, linear-gradient(90deg, rgb(var(--light)) 30%, rgba(0, 0, 0, 0) 0 70%, rgb(var(--light), 0.1) 0) 50%/100% 8%;
    background-repeat: no-repeat;
    animation: spinnerz 1s infinite steps(12);
}

.loader-container-box .loader::before {
    content: "";
    grid-area: 1/1;
    border-radius: 50%;
    background: inherit;
    opacity: 0.915;
    transform: rotate(30deg);
}

.loader-container-box .loader::after {
    content: "";
    grid-area: 1/1;
    border-radius: 50%;
    background: inherit;
    opacity: 0.915;
    transform: rotate(30deg);
    opacity: 0.83;
    transform: rotate(60deg);
}

blockOverlay {
    z-index: 1004 !important;
}

.bolckui-msg-box {
    background-color: rgb(var(--primary));
    padding: 10px 0;
    color: rgba(var(--white), 1);
    border-radius: 10px;
}

.block-msg-card .msg-card {
    width: 100%;
    background-color: rgb(var(--warning));
    padding: 0.938rem;
    color: rgba(var(--white), 1);
    border-radius: 10px;
}

.block-msg-card .blockMsg {
    width: 100% !important;
    left: 5px;
}

/* ปิด mask row (แถบแดง loading กลาง grid) */
.e-grid .e-masked-table,
.e-grid .e-mask {
    display: none !important;
}

/* remove default border */
.e-grid .e-headercell.e-freezeleftborder,
.e-grid .e-rowcell.e-freezeleftborder {
    border-right: none !important;
}

/* header divider */
.e-grid .e-gridheader .e-headercell.e-leftfreeze.e-freezeleftborder {
    position: relative;
}

.e-grid .e-gridheader .e-headercell.e-leftfreeze.e-freezeleftborder::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 1px;
    height: 100%;
    background: #e0e0e0;
}

/* body divider when scroll */
.e-grid.e-left-shadow .e-gridcontent .e-rowcell.e-leftfreeze.e-freezeleftborder::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 1px;
    height: 100%;
    background: #e0e0e0;
}

/*#Grid_excelexport .e-btn-icon {
    display: none !important;
}*/

.e-toolbar .e-btn {
    display: flex;
    flex-direction: row-reverse;
    gap: 6px;
}

.e-toolbar .e-toolbar-item .e-tbar-btn {
    background: #ffffff !important;
}