
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --primary:#1a56db;--primary-dark:#1e40af;--primary-light:#eff6ff;
  --success:#16a34a;--warning:#d97706;--danger:#dc2626;--info:#0891b2;
  --gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;
  --gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;
  --gray-800:#1f2937;--gray-900:#111827;
  --sidebar-width:240px;--header-height:56px;
}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--gray-100);color:var(--gray-800);min-height:100vh}

/* ── LOGIN ── */
#login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#1a56db 0%,#1e40af 100%);padding:16px}
.login-card{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:400px;box-shadow:0 20px 60px rgba(0,0,0,.2)}
.login-logo{text-align:center;margin-bottom:32px}
.login-logo h1{font-size:28px;font-weight:700;color:var(--primary)}
.login-logo p{color:var(--gray-500);font-size:14px;margin-top:4px}
.form-group{margin-bottom:16px}
.preset-chips{display:flex;flex-wrap:wrap;gap:4px;margin-top:5px}
.preset-chip{font-size:11px;padding:2px 8px;border:1px solid var(--gray-300);border-radius:12px;background:var(--gray-100);color:var(--gray-700);cursor:pointer;white-space:nowrap;transition:all .15s}
.preset-chip:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.form-group label,.form-label{display:block;font-size:13px;font-weight:600;color:var(--gray-700);margin-bottom:6px}
.form-control{width:100%;padding:10px 14px;border:1.5px solid var(--gray-200);border-radius:8px;font-size:14px;outline:none;transition:border-color .2s}
.form-control:focus{border-color:var(--primary)}
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:all .15s;white-space:nowrap}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark)}
.btn-success{background:var(--success);color:#fff}
.btn-success:hover{background:#15803d}
.btn-warning{background:var(--warning);color:#fff}
.btn-danger{background:var(--danger);color:#fff}
.btn-outline{background:#fff;color:var(--gray-700);border:1.5px solid var(--gray-200)}
.btn-outline:hover{border-color:var(--primary);color:var(--primary)}
.btn-sm{padding:6px 12px;font-size:12px}
.btn-block{width:100%;justify-content:center}
.demo-accounts{margin-top:20px;padding:14px;background:var(--gray-50);border-radius:8px;font-size:12px;color:var(--gray-600)}
.demo-accounts strong{display:block;margin-bottom:6px}

/* ── LAYOUT ── */
#app{display:none;min-height:100vh}

/* SIDEBAR */
.sidebar{position:fixed;left:0;top:0;width:var(--sidebar-width);height:100vh;background:var(--gray-900);display:flex;flex-direction:column;z-index:200;overflow-y:auto;transition:transform .25s}
.sidebar-header{padding:16px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:10px}
.sidebar-header h2{color:#fff;font-size:18px;font-weight:700;flex:1}
.sidebar-close-btn{display:none;background:none;border:none;color:var(--gray-400);font-size:22px;cursor:pointer;line-height:1}
.sidebar-header p{color:var(--gray-400);font-size:12px}
.sidebar-user{padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:10px}
.avatar{width:36px;height:36px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;flex-shrink:0}
.sidebar-user-info{flex:1;min-width:0}
.sidebar-user-info strong{color:#fff;font-size:13px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-user-info span{color:var(--gray-400);font-size:11px}
nav{flex:1;padding:8px 0}
.nav-section{padding:8px 16px 4px;font-size:10px;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.8px}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 16px;color:var(--gray-300);cursor:pointer;transition:all .15s;font-size:13px;font-weight:500;border-left:3px solid transparent}
.nav-item:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-item.active{background:rgba(26,86,219,.25);color:#fff;border-left-color:var(--primary)}
.nav-icon{font-size:16px;width:20px;text-align:center}
.nav-sub{padding:7px 16px 7px 46px;font-size:12.5px}
.nav-caret{margin-left:auto;font-size:11px;color:var(--gray-500);transition:transform .2s;padding:2px 4px}
.nav-caret.collapsed{transform:rotate(-90deg)}
.sidebar-footer{padding:12px 16px;border-top:1px solid rgba(255,255,255,.08)}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:199}

/* MAIN */
.main{margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column;transition:margin .25s;flex:1;min-width:0;width:calc(100% - var(--sidebar-width))}
.topbar{height:var(--header-height);background:#fff;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;padding:0 16px 0 24px;gap:12px;position:sticky;top:0;z-index:50}
.topbar-title{font-size:18px;font-weight:700;color:var(--gray-900);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hamburger{display:none;background:none;border:none;font-size:22px;cursor:pointer;color:var(--gray-700);padding:4px}
.page-content{padding:20px;flex:1}
.page-content > div{width:100%;min-width:0}
.module-page{min-width:0;display:flex;flex-direction:column;gap:14px}
.module-page{width:100%}
.module-page > *{min-width:0}
.module-page .toolbar,
.module-page .stats-grid,
.module-page .card,
.module-page .alert,
.module-page .tabs{min-width:0;max-width:100%}
.module-page .toolbar,
.module-page .stats-grid,
.module-page .card,
.module-page .alert,
.module-page .tabs{width:100%}
.module-page .card-body,
.module-page .card-header{min-width:0}
.module-page .toolbar .toolbar-group,
.module-page .toolbar .search-box{min-width:0}
.module-page .toolbar .form-control,
.module-page .toolbar .btn,
.module-page .toolbar .btn-group{max-width:100%}

/* STATS */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:20px}
.stat-card{background:#fff;border-radius:12px;padding:18px;border:1px solid var(--gray-200)}
.stat-card .label{font-size:11px;color:var(--gray-500);font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.stat-card .value{font-size:26px;font-weight:700;margin:6px 0;color:var(--gray-900)}
.stat-card .change{font-size:12px;color:var(--gray-500)}
.stat-card .icon{font-size:26px;float:right;margin-top:-8px}

/* CARD */
.card{background:#fff;border-radius:12px;border:1px solid var(--gray-200);overflow:hidden}.card>.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.card-header{padding:14px 18px;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.card-header h3{font-size:14px;font-weight:700;flex:1}
.card-body{padding:18px}

/* ── RESIZABLE TABLE ── */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;font-size:13px;table-layout:fixed}
th{
  text-align:left;padding:10px 12px;background:var(--gray-50);color:var(--gray-600);
  font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.4px;
  border-bottom:2px solid var(--gray-200);position:relative;
  user-select:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
th .col-resize-handle{
  position:absolute;right:0;top:0;width:6px;height:100%;
  cursor:col-resize;background:transparent;z-index:10;
}
th .col-resize-handle:hover,th.resizing .col-resize-handle{background:var(--primary);opacity:.4}
th.resizing{background:var(--primary-light)}
td{padding:10px 12px;border-bottom:1px solid var(--gray-100);color:var(--gray-700);vertical-align:middle;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.items-tbl{table-layout:auto}
.items-tbl td{overflow:visible;text-overflow:clip}
/* Mọi ô trong list view (có data-col) đều cho xuống dòng — không cắt "..." */
td[data-col]{white-space:normal;overflow:visible;text-overflow:clip;word-break:break-word;overflow-wrap:anywhere;vertical-align:top}
/* Import-costing detail/edit grids: size columns to content, never clip numbers */
.ic-data-tbl{table-layout:auto}
.ic-data-tbl th,.ic-data-tbl td{overflow:visible;text-overflow:clip;white-space:nowrap}
.ic-data-tbl .cell-desc{white-space:normal;word-break:break-word}
.ic-data-tbl td:last-child{border-bottom:1px solid var(--gray-100)}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--gray-50)}
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
.badge-success{background:#dcfce7;color:#15803d}
.badge-warning{background:#fef3c7;color:#92400e}
.badge-danger{background:#fee2e2;color:#991b1b}
.badge-info{background:#e0f2fe;color:#075985}
.badge-gray{background:var(--gray-100);color:var(--gray-600)}
.badge-purple{background:#f3e8ff;color:#6b21a8}

/* TOOLBAR */
.toolbar{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.toolbar-group{display:flex;gap:6px;flex-wrap:wrap}
.search-box{display:flex;align-items:center;background:#fff;border:1.5px solid var(--gray-200);border-radius:8px;padding:7px 12px;gap:8px;flex:1;min-width:180px}
.search-box input{border:none;outline:none;font-size:13px;width:100%;background:transparent}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding:16px;overflow-y:auto}
.modal{background:#fff;border-radius:16px;width:560px;min-width:320px;min-height:180px;max-height:calc(100vh - 32px);display:flex;flex-direction:column;box-shadow:0 25px 60px rgba(0,0,0,.2);position:relative;resize:both;overflow:hidden;will-change:transform;margin:auto;transition:transform .2s ease,filter .2s ease}
.modal-lg{width:820px}
.modal-xl{width:1100px}
/* Stacked modals: background modal is dimmed + shifted */
.modal-overlay.modal-behind{background:transparent;pointer-events:none}
.modal-overlay.modal-behind .modal{transform:scale(0.97) translateY(-14px);filter:brightness(0.55);pointer-events:none}
.modal::after{content:'⠿';position:absolute;bottom:4px;right:6px;font-size:14px;color:var(--gray-300);pointer-events:none;line-height:1;transform:rotate(45deg)}
.modal-header{padding:16px 22px;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;background:#fff;z-index:5;flex-shrink:0;cursor:grab;user-select:none;border-radius:16px 16px 0 0}
.modal-header.dragging{cursor:grabbing}
.modal-header h3{flex:1;font-size:15px;font-weight:700}
.modal-close{background:none;border:none;font-size:22px;cursor:pointer;color:var(--gray-400);line-height:1;padding:2px}
.modal-body{padding:22px;overflow-y:auto;flex:1;min-height:0;scrollbar-gutter:stable}
.modal-footer{padding:12px 22px;border-top:1px solid var(--gray-100);display:flex;justify-content:flex-end;gap:10px;background:#fff;flex-shrink:0;border-radius:0 0 16px 16px;flex-wrap:wrap}
.modal-footer .btn{max-width:100%;white-space:nowrap}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
select.form-control{cursor:pointer}
textarea.form-control{resize:vertical;min-height:72px}
/* Select/ss-wrap trong flex container tự động giãn đầy chiều rộng */
[style*="display:flex"] > select.form-control{flex:1 1 0%;min-width:0}
[style*="display:flex"] > .ss-wrap{flex:1 1 0%;min-width:0}

/* KANBAN */
.kanban-board{display:flex;gap:14px;overflow-x:auto;padding-bottom:14px;-webkit-overflow-scrolling:touch}
.kanban-col{background:var(--gray-100);border-radius:12px;padding:12px;min-width:220px;flex:1;max-width:340px}
.kanban-col-header{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-600);margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}
.kanban-card{background:#fff;border-radius:8px;padding:12px;margin-bottom:8px;box-shadow:0 1px 3px rgba(0,0,0,.08);cursor:pointer;border-left:3px solid transparent;transition:all .15s}
.kanban-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.12);transform:translateY(-1px)}
.kanban-card h4{font-size:13px;font-weight:600;margin-bottom:5px;color:var(--gray-800)}
.kanban-card .meta{font-size:11px;color:var(--gray-500);margin-top:2px}

/* PROGRESS */
.progress{background:var(--gray-200);border-radius:99px;height:6px;overflow:hidden}
.progress-bar{height:100%;border-radius:99px;background:var(--primary);transition:width .3s}

/* TABS */
.tabs{display:flex;gap:0;border-bottom:2px solid var(--gray-200);margin-bottom:18px;overflow-x:auto}
.tab{padding:9px 18px;font-size:13px;font-weight:600;cursor:pointer;color:var(--gray-500);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;white-space:nowrap}
.tab.active{color:var(--primary);border-bottom-color:var(--primary)}

/* EMPTY */
.empty-state{text-align:center;padding:50px 20px;color:var(--gray-400)}
.empty-state .icon{font-size:44px;margin-bottom:10px}
.empty-state p{font-size:14px}

/* ALERT */
.alert{padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.alert-success{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0}
.alert-danger{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}
.alert-info{background:#e0f2fe;color:#075985;border:1px solid #bae6fd}

/* LANG */
.lang-switcher{display:flex;gap:4px;flex-shrink:0}
.lang-btn{padding:4px 9px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;border:1.5px solid var(--gray-200);background:#fff;color:var(--gray-600)}
.lang-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}

/* ACTIONS */
.actions{display:flex;gap:5px;flex-wrap:nowrap;justify-content:flex-end}
.table-wrap table td:last-child{position:sticky;right:0;background:#fff;z-index:2;box-shadow:-2px 0 5px rgba(0,0,0,.07);overflow:visible}
.table-wrap table th:last-child{position:sticky;right:0;background:var(--gray-50);z-index:3;box-shadow:-2px 0 5px rgba(0,0,0,.07)}
/* ROW MENU (3-dot dropdown) */
.row-menu{position:relative;display:inline-block;vertical-align:middle}
.row-menu-btn{background:none;border:1.5px solid var(--gray-200);border-radius:6px;cursor:pointer;padding:3px 10px;font-size:18px;line-height:1.1;color:var(--gray-400);transition:background .12s,border-color .12s;letter-spacing:1px}
.row-menu-btn:hover,.row-menu.open .row-menu-btn{background:var(--gray-100);border-color:var(--gray-300);color:var(--gray-700)}
.row-menu-drop{display:none;position:absolute;right:0;bottom:calc(100% + 4px);top:auto;background:#fff;border:1px solid var(--gray-200);border-radius:10px;box-shadow:0 6px 24px rgba(0,0,0,.14);z-index:400;min-width:150px;padding:4px;flex-direction:column}
.row-menu.open{z-index:500;position:relative}
.row-menu.open .row-menu-drop{display:flex}
.row-menu-drop-portal{display:flex!important;position:fixed!important;right:auto!important;bottom:auto!important;top:0;left:0;background:#fff;border:1px solid var(--gray-200);border-radius:10px;box-shadow:0 10px 30px rgba(0,0,0,.18);z-index:99999;min-width:180px;padding:4px;flex-direction:column;max-height:min(360px,calc(100vh - 16px));overflow:auto}
.row-menu-empty{padding:8px 10px;font-size:12px;color:var(--gray-400)}
.row-menu-item{display:flex;align-items:center;gap:8px;background:none;border:none;text-align:left;padding:7px 12px;font-size:13px;color:var(--gray-700);cursor:pointer;border-radius:7px;white-space:nowrap;width:100%}
.row-menu-item:hover{background:var(--gray-100);color:var(--gray-900)}
.row-menu-item.danger{color:var(--danger)}
.row-menu-item.danger:hover{background:#fee2e2}

/* IMPORT/EXPORT dropdown */
.btn-group{position:relative;display:inline-flex}
.dropdown-menu{display:none;position:absolute;top:calc(100% + 4px);right:0;background:#fff;border:1px solid var(--gray-200);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.12);min-width:180px;z-index:300;overflow:hidden}
.dropdown-menu.open{display:block}
.dropdown-item{display:flex;align-items:center;gap:8px;padding:10px 14px;font-size:13px;cursor:pointer;color:var(--gray-700);transition:background .1s}
.dropdown-item:hover{background:var(--gray-50)}
.dropdown-divider{border-top:1px solid var(--gray-100);margin:4px 0}

/* TOAST */
.toast-container{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{background:var(--gray-900);color:#fff;padding:12px 18px;border-radius:10px;font-size:13px;display:flex;align-items:center;gap:8px;box-shadow:0 4px 16px rgba(0,0,0,.2);animation:slideIn .2s ease;max-width:320px}
.toast.success{background:#15803d}
.toast.error{background:var(--danger)}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}

/* PIPELINE (Opportunities) */
.pipeline{display:flex;gap:12px;overflow-x:auto;padding-bottom:12px;-webkit-overflow-scrolling:touch}
.pipeline-col{background:var(--gray-100);border-radius:12px;padding:12px;min-width:200px;flex:1;max-width:260px}
.pipeline-col-header{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;margin-bottom:10px;padding-bottom:8px;border-bottom:2px solid;display:flex;justify-content:space-between;align-items:center}
.pipeline-card{background:#fff;border-radius:8px;padding:11px;margin-bottom:8px;box-shadow:0 1px 3px rgba(0,0,0,.07);border-left:3px solid transparent;transition:box-shadow .15s,transform .15s;cursor:pointer}
.pipeline-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.12);transform:translateY(-1px)}
.pipeline-card h4{font-size:13px;font-weight:600;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pipeline-card .meta{font-size:11px;color:var(--gray-500);margin-top:2px}
.pipeline-card .value{font-size:12px;font-weight:700;color:var(--primary);margin-top:5px}
.prob-bar{height:4px;border-radius:99px;background:var(--gray-200);margin-top:6px;overflow:hidden}
.prob-bar-fill{height:100%;border-radius:99px;background:var(--primary)}

/* COMPARE TABLE */
.compare-table{width:100%;border-collapse:collapse;font-size:13px;table-layout:auto}
.compare-table th{padding:9px 12px;text-align:left;background:var(--gray-50);border:1px solid var(--gray-200);font-weight:600;font-size:12px;white-space:nowrap}
.compare-table td{padding:9px 12px;border:1px solid var(--gray-200);vertical-align:top}
.compare-table .best-price{background:#dcfce7;color:#15803d;font-weight:700;border-radius:4px;padding:2px 6px}
.compare-table .winner-col{background:#eff6ff}
.compare-table .item-col{background:var(--gray-50);font-weight:600;min-width:160px}
/* ── COLUMN UTILITY CLASSES ── */
.cell-desc{white-space:normal;overflow-wrap:anywhere;word-break:break-word;overflow:visible;min-width:180px;vertical-align:top}
.cell-money{white-space:nowrap;text-align:right;width:120px}
.cell-qty{white-space:nowrap;text-align:right;width:70px}
.cell-unit{white-space:nowrap;text-align:center;width:70px}
.cell-code{white-space:nowrap;width:90px}
.cell-date{white-space:nowrap;text-align:center;width:100px}
.cell-vat{white-space:nowrap;text-align:center;width:65px}
.cell-num{white-space:nowrap;text-align:center;width:44px}
.cell-status{white-space:nowrap;text-align:center}
.cell-nowrap{white-space:nowrap}
.winner-badge{display:inline-flex;align-items:center;gap:4px;background:#fef9c3;color:#854d0e;border:1.5px solid #fde047;border-radius:6px;padding:3px 9px;font-size:11px;font-weight:700}
.rfq-cat-badge{display:inline-flex;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:600}
.rfq-purpose-internal{background:#ede9fe;color:#5b21b6}
.rfq-purpose-resale{background:#fce7f3;color:#9d174d}

/* LIST VIEW / SCREEN OPTIONS */
.listview-toolbar{display:flex;align-items:center;gap:10px;justify-content:flex-end;margin:0 0 10px;flex-wrap:wrap}
.listview-toolbar-note{font-size:12px;color:var(--gray-500)}
.listview-panel{background:#f8fbff;border:1px solid #bfdbfe;border-radius:12px;padding:12px 14px;margin:0 0 12px}
.listview-panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px;flex-wrap:wrap}
.listview-panel-actions{display:flex;gap:8px;flex-wrap:wrap}
.listview-panel-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px 14px}
.listview-check{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--gray-700);cursor:pointer}
.listview-th{display:flex;align-items:center;min-height:28px}
.listview-sort-btn{display:inline-flex;align-items:center;gap:6px;border:none;background:transparent;padding:0;font:inherit;font-weight:700;color:inherit;cursor:pointer;text-align:left}
.listview-sort-icon{font-size:11px;color:var(--gray-400)}
.listview-th-label{font-weight:700}
.listview-filter-row th{background:#fafcff;padding-top:6px;padding-bottom:8px}
.listview-filter-input,.listview-filter-select{width:100%;border:1px solid var(--gray-200);border-radius:8px;padding:5px 8px;font-size:12px;background:#fff}
.listview-filter-input:focus,.listview-filter-select:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 3px rgba(59,130,246,.12)}
.listview-datefilter{display:flex;flex-direction:column;gap:4px}
.listview-datefilter-range{display:flex;flex-direction:column;gap:4px}
.listview-filter-date{width:100%;min-width:0;border:1px solid var(--gray-200);border-radius:8px;padding:4px 6px;font-size:11px;background:#fff;color:var(--gray-700)}
.listview-filter-date:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 3px rgba(59,130,246,.12)}
/* Pagination bar */
.lv-pagination-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;padding:8px 2px 2px;border-top:1px solid var(--gray-100);margin-top:8px}
.lv-pg-info{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--gray-500)}
.lv-pagesize-sel{border:1px solid var(--gray-200);border-radius:6px;padding:3px 6px;font-size:12px;background:#fff;cursor:pointer}
.lv-pg-btns{display:flex;gap:3px;flex-wrap:wrap}
.lv-pg-btn{min-width:30px;height:28px;padding:0 7px;border:1px solid var(--gray-200);border-radius:6px;background:#fff;font-size:12px;cursor:pointer;color:var(--gray-700);transition:background .15s,border-color .15s}
.lv-pg-btn:hover{background:#eff6ff;border-color:#93c5fd;color:var(--primary)}
.lv-pg-active{background:var(--primary)!important;border-color:var(--primary)!important;color:#fff!important;font-weight:700}
.lv-pg-ellipsis{display:inline-flex;align-items:center;padding:0 4px;font-size:12px;color:var(--gray-400)}

/* ── PRINT ── */
@media print{
  td{white-space:normal!important;overflow:visible!important;text-overflow:clip!important}
  .items-tbl td{overflow-wrap:anywhere;word-break:break-word}
  .data-table td{white-space:normal!important;overflow:visible!important;text-overflow:clip!important}
}
/* ── RESPONSIVE ── */
@media(max-width:900px){
  :root{--sidebar-width:240px}
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .sidebar-close-btn{display:block}
  .sidebar-overlay.open{display:block}
  .main{margin-left:0!important;width:100%}
  .hamburger{display:flex}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .page-content{padding:12px}
}
@media(max-width:600px){
  .stats-grid{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  .form-row-3{grid-template-columns:1fr}
  .toolbar{gap:6px}
  .module-page .toolbar{align-items:stretch}
  .module-page .toolbar>.toolbar-group,
  .module-page .toolbar>.search-box,
  .module-page .toolbar>select.form-control,
  .module-page .toolbar>.btn-group{width:100%}
  .module-page .toolbar .toolbar-group{justify-content:flex-start}
  .module-page .toolbar .search-box{flex:1 1 100%}
  .module-page .toolbar .form-control{width:100% !important;min-width:0}
  .module-page .toolbar .btn{flex-shrink:0}
  .topbar{padding:0 12px}
  .topbar-title{font-size:15px}
  .modal-body{padding:16px}
  .modal-header{padding:14px 16px}
  .modal-footer{padding:12px 16px}
  .listview-panel-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .stats-grid{grid-template-columns:1fr}
  .listview-panel-grid{grid-template-columns:1fr}
}
