.app-layout{display:flex;min-height:100vh;padding-bottom:70px}.layout-loading{display:flex;align-items:center;justify-content:center;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--color-white);border-right:1px solid var(--color-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:200;transition:transform .3s ease;overflow:hidden}.sidebar-logo{padding:16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--color-border);height:var(--header-height);flex-shrink:0}.sidebar-close-btn{display:none;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:none;cursor:pointer;color:var(--color-text-secondary);border-radius:var(--radius-sm);flex-shrink:0}.sidebar-logo-img{width:36px;height:36px;object-fit:contain;flex-shrink:0}.sidebar-logo-text{display:flex;flex-direction:column;gap:2px;min-width:0}.sidebar-logo-name{font-size:14px;font-weight:700;color:var(--color-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-logo-sub{font-size:11px;color:var(--color-text-secondary)}.sidebar-nav{flex:1;padding:8px;overflow-y:auto;overflow-x:hidden}.nav-group{margin-bottom:8px}.nav-group-title{font-size:10px;font-weight:700;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.08em;padding:8px 12px 4px;opacity:.7}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-md);color:var(--color-text-secondary);font-weight:500;cursor:pointer;margin-bottom:2px;white-space:nowrap;transition:all .15s ease}.nav-item:hover{background:var(--color-bg);color:var(--color-primary)}.nav-item-active{background:#073ceb14;color:var(--color-primary);font-weight:600}.nav-icon{font-size:20px;width:22px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.nav-label{font-size:14px}.sidebar-footer{padding:12px;border-top:1px solid var(--color-border);flex-shrink:0}.user-info{display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--radius-md);background:var(--color-bg);margin-bottom:8px}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.user-name{font-weight:600;font-size:13px;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:11px;color:var(--color-text-secondary)}.user-info-text{flex:1;min-width:0}.sidebar-logout-btn{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;border:1px solid var(--color-border);background:var(--color-white);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease}.sidebar-logout-btn:hover{border-color:#ef4444;color:#ef4444;background:#fef2f2}.main-content{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh;transition:margin-left .3s ease}.header{height:var(--header-height);background:var(--color-white);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:50;flex-shrink:0}.header-left{display:flex;align-items:center;gap:12px;min-width:0}.header-title-group{display:flex;flex-direction:column;gap:2px;min-width:0}.header-title{font-size:18px;font-weight:700;color:var(--color-text);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-breadcrumb{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--color-text-secondary)}.header-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.header-date{font-size:13px;color:var(--color-text-secondary);font-weight:500}.header-bell-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--radius-md);border:1.5px solid var(--color-border);background:var(--color-white);cursor:pointer;color:var(--color-text-secondary);transition:all .2s ease}.header-bell-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:#073ceb0a}.header-bell-badge{position:absolute;top:-5px;right:-5px;display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;border:2px solid var(--color-white);line-height:1;animation:bellPulse 2s ease-in-out infinite}@keyframes bellPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.header-hamburger{width:38px;height:38px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-white);display:none;align-items:center;justify-content:center;cursor:pointer;font-size:18px;color:var(--color-text-secondary);transition:all .2s;flex-shrink:0}.header-hamburger:hover{border-color:var(--color-primary);color:var(--color-primary)}.page-content{flex:1;padding:24px}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:199}.bottom-tab-bar{display:none;position:fixed;bottom:0;left:0;right:0;height:64px;background:var(--color-white);border-top:1px solid var(--color-border);z-index:100;padding:0 8px;padding-bottom:env(safe-area-inset-bottom,0);box-shadow:0 -2px 12px #00000014}.bottom-tab-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;border:none;background:none;cursor:pointer;color:var(--color-text-secondary);padding:8px 4px;transition:all .15s ease;position:relative;-webkit-tap-highlight-color:transparent}.bottom-tab-item:active{transform:scale(.95)}.bottom-tab-active{color:var(--color-primary)}.bottom-tab-icon{font-size:22px;position:relative;display:flex;align-items:center;justify-content:center}.bottom-tab-badge{position:absolute;top:-4px;right:-8px;min-width:16px;height:16px;padding:0 3px;border-radius:8px;background:#ef4444;color:#fff;font-size:9px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;border:1.5px solid var(--color-white)}.bottom-tab-label{font-size:10px;font-weight:600;line-height:1}.sidebar-collapsed{width:64px}.sidebar-collapsed .sidebar-logo{justify-content:center;padding:16px 8px}.sidebar-logo-img-center{margin:0 auto}.nav-item-collapsed{justify-content:center;padding:10px}.sidebar-logout-btn-collapsed{width:40px;height:40px;margin:0 auto;justify-content:center;padding:0}.main-content-collapsed{margin-left:64px}.header-collapse-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);border:1.5px solid var(--color-border);background:var(--color-white);cursor:pointer;color:var(--color-text-secondary);transition:all .2s ease;flex-shrink:0}.header-collapse-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:#073ceb0a}@media (max-width: 1024px){.header-collapse-btn{display:none}.sidebar{transform:translate(-100%);width:280px;z-index:200}.sidebar.sidebar-open{transform:translate(0)}.sidebar-close-btn{display:flex}.sidebar-overlay{display:block}.main-content{margin-left:0}.header-hamburger{display:flex}.bottom-tab-bar{display:none}}@media (max-width: 768px){.header-collapse-btn{display:none}.app-layout{padding-bottom:0}.sidebar{transform:translate(-100%);width:280px;z-index:200}.sidebar.sidebar-open{transform:translate(0)}.sidebar-close-btn{display:flex}.sidebar-overlay{display:block}.main-content{margin-left:0}.header-hamburger{display:flex}.header-date{display:none}.page-content{padding:16px}}@media (max-width: 480px){.sidebar{width:100%}.page-content{padding:12px}.header-title{font-size:16px}}:root{--color-primary: #073ceb;--color-primary-dark: #052fa8;--color-primary-light: #3b82f6;--color-secondary: #1e40af;--color-success: #10b981;--color-warning: #f59e0b;--color-danger: #ef4444;--color-danger-dark: #dc2626;--color-danger-light: rgba(239, 68, 68, .08);--color-info: #06b6d4;--color-purple: #8b5cf6;--color-add: #073ceb;--color-add-hover: #052fa8;--color-edit: #073ceb;--color-edit-hover: #052fa8;--color-delete: #ea0000;--color-delete-hover: #c20000;--color-save: #3d805f;--color-save-hover: #2d6349;--color-cancel: #ea0000;--color-cancel-hover: #c20000;--color-bg: #f0f4f8;--color-white: #ffffff;--color-text: #1e293b;--color-text-secondary: #64748b;--color-border: #e2e8f0;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--sidebar-width: 260px;--sidebar-collapsed-width: 64px;--header-height: 64px;--font-family: "Roboto", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-family);background-color:var(--color-bg);color:var(--color-text);font-size:14px;line-height:1.5}.confirm-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:300;padding:20px;animation:confirmOverlayIn .2s ease}@keyframes confirmOverlayIn{0%{opacity:0}to{opacity:1}}.confirm-modal{background:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:400px;padding:32px 24px;text-align:center;animation:confirmModalIn .2s ease}@keyframes confirmModalIn{0%{transform:scale(.9) translateY(-10px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.confirm-modal-icon{display:flex;justify-content:center;margin-bottom:16px}.confirm-modal-title{font-size:18px;font-weight:700;color:var(--color-text);margin-bottom:8px}.confirm-modal-message{font-size:14px;color:var(--color-text-secondary);line-height:1.5;margin-bottom:24px}.confirm-modal-footer{display:flex;gap:12px;justify-content:center}.confirm-btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 24px;border-radius:var(--radius-md);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;border:none;transition:all .2s ease;min-width:100px}.confirm-btn:disabled{opacity:.6;cursor:not-allowed}.confirm-btn-cancel{background:var(--color-danger);color:#fff;border:2px solid var(--color-danger)}.confirm-btn-cancel:hover:not(:disabled){background:var(--color-danger-dark);border-color:var(--color-danger-dark);box-shadow:0 4px 12px #dc262659;transform:translateY(-1px)}.confirm-btn-stay{background:transparent;color:var(--color-danger);border:2px solid var(--color-danger)}.confirm-btn-stay:hover:not(:disabled){background:var(--color-danger-light);box-shadow:0 2px 8px #dc262626;transform:translateY(-1px)}.confirm-btn-danger{background:var(--color-danger);color:#fff}.confirm-btn-danger:hover:not(:disabled){background:var(--color-danger-dark);box-shadow:0 4px 12px #ea00004d}.confirm-btn-warning{background:var(--color-warning);color:#fff}.confirm-btn-warning:hover:not(:disabled){background:#d97706;box-shadow:0 4px 12px #f59e0b4d}.confirm-btn-info{background:var(--color-primary);color:#fff}.confirm-btn-info:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:0 4px 12px #073ceb4d}.confirm-btn-success{background:#22c55e;color:#fff}.confirm-btn-success:hover:not(:disabled){background:#16a34a;box-shadow:0 4px 12px #22c55e59}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:9px 18px;border-radius:var(--radius-md);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s ease;border:none;text-decoration:none;position:relative;min-height:38px}.btn:disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.btn-loading{display:inline-flex;align-items:center;gap:8px}.btn-loading:before{content:"";display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:btn-spin .8s linear infinite}@keyframes btn-spin{to{transform:rotate(360deg)}}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-dark)}.btn-secondary{background:var(--color-white);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{border-color:var(--color-primary);color:var(--color-primary)}.btn-add,.btn-edit{background:var(--color-add);color:#fff}.btn-add:hover,.btn-edit:hover{background:var(--color-add-hover);box-shadow:0 4px 12px #073ceb4d}.btn-save{background:var(--color-save);color:#fff}.btn-save:hover{background:var(--color-save-hover);box-shadow:0 4px 12px #3d805f4d}.btn-cancel,.btn-delete{background:var(--color-cancel);color:#fff}.btn-cancel:hover,.btn-delete:hover{background:var(--color-cancel-hover);box-shadow:0 4px 12px #ea00004d}.btn-sm{padding:6px 12px;font-size:12px}.btn-icon{width:34px;height:34px;padding:0;border-radius:var(--radius-md)}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:600;color:var(--color-text);margin-bottom:6px}.form-input,.form-select,.form-textarea{width:100%;padding:9px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:14px;font-family:inherit;color:var(--color-text);background:var(--color-white);transition:border-color .2s ease}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #073ceb1a}.form-textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.form-section-title{font-size:14px;font-weight:700;color:var(--color-primary);margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--color-border)}.form-divider{height:1px;background:var(--color-border);margin:20px 0}.form-error{font-size:12px;color:var(--color-danger);margin-top:4px}.card{background:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.card-header{padding:16px 20px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:16px;font-weight:700;color:var(--color-text)}.card-body{padding:20px}.table-wrapper{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:13px}.table th{background:var(--color-bg);padding:10px 14px;text-align:left;font-weight:700;color:var(--color-text-secondary);font-size:12px;text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--color-border);white-space:nowrap}.table td{padding:12px 14px;border-bottom:1px solid var(--color-border);color:var(--color-text);vertical-align:middle}.table tr:hover td{background:#073ceb05}.table tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}.badge-cho-duyet{background:#f59e0b1f;color:#b45309}.badge-da-duyet{background:#3b82f61f;color:#1d4ed8}.badge-dang-san-xuat{background:#8b5cf61f;color:#6d28d9}.badge-dang-giao{background:#f973161f;color:#c2410c}.badge-da-giao{background:#06b6d41f;color:#0e7490}.badge-nghiem-thu{background:#6366f11f;color:#4338ca}.badge-da-thanh-toan{background:#10b9811f;color:#047857}.badge-tu-choi{background:#ef44441f;color:#b91c1c}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:24px}.kpi-card{background:var(--color-white);border-radius:var(--radius-lg);padding:20px;border:1px solid var(--color-border);box-shadow:var(--shadow-sm);transition:box-shadow .2s,transform .2s}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi-label{font-size:12px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em;margin-bottom:6px}.kpi-value{font-size:28px;font-weight:800;color:var(--color-text);line-height:1.2}.kpi-value-currency{font-size:22px}.kpi-icon{font-size:24px;opacity:.8}.action-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:16px;flex-wrap:wrap}.action-bar-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0;flex-wrap:wrap}.action-bar-left .form-select{min-width:180px;max-width:220px}.action-bar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.search-box{position:relative;flex:1;min-width:200px;max-width:320px}.search-box input{padding-left:38px;width:100%}.search-box-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text-secondary);font-size:16px}.pagination-wrap{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px 16px 24px;border-top:1px solid var(--color-border);margin-top:4px}.pagination-info{font-size:13px;color:var(--color-text-secondary);text-align:center}.pagination-info strong{color:var(--color-primary)}.pagination-controls{display:flex;align-items:center;gap:4px}.pagination-btn{min-width:36px;height:36px;padding:0 8px;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--color-border);border-radius:10px;background:var(--color-white);cursor:pointer;font-size:13px;font-weight:600;font-family:inherit;color:var(--color-text-secondary);transition:all .18s ease}.pagination-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);background:#073ceb0a;transform:translateY(-1px);box-shadow:0 2px 8px #073ceb1f}.pagination-btn:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:none}.pagination-btn-active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;box-shadow:0 3px 10px #073ceb4d}.pagination-btn-active:hover:not(:disabled){background:var(--color-primary-dark);border-color:var(--color-primary-dark);color:#fff;transform:translateY(-1px)}.pagination-ellipsis{display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;font-size:13px;font-weight:600;color:var(--color-text-secondary);letter-spacing:1px}.react-datepicker{font-family:inherit;border:1px solid var(--color-border)!important;border-radius:12px!important;box-shadow:0 8px 32px #0000001f!important}.react-datepicker__header{background:var(--color-white);border-bottom:1px solid var(--color-border);border-radius:12px 12px 0 0;padding:12px 16px}.react-datepicker__current-month{font-size:15px;font-weight:700;color:var(--color-primary)}.react-datepicker__day-name{color:var(--color-text-secondary);font-weight:600;font-size:12px;width:36px;line-height:36px}.react-datepicker__day{width:36px;line-height:36px;border-radius:8px;color:var(--color-text);font-weight:500;transition:all .15s ease}.react-datepicker__day:hover{background:#073ceb14;color:var(--color-primary)}.react-datepicker__day--selected,.react-datepicker__day--keyboard-selected{background:var(--color-primary)!important;color:#fff!important;font-weight:700}.react-datepicker__day--today{font-weight:800;color:var(--color-primary);background:#073ceb0f}.react-datepicker__day--outside-month{color:var(--color-text-secondary);opacity:.5}.react-datepicker__day--disabled{color:var(--color-text-secondary);opacity:.3;cursor:not-allowed}.react-datepicker__navigation{top:14px}.react-datepicker__navigation-icon:before{border-color:var(--color-primary);border-width:2px 2px 0 0}.react-datepicker__navigation:hover *{border-color:var(--color-primary-dark)}.react-datepicker__time-container{border-left:1px solid var(--color-border)}.react-datepicker-time__header{font-size:14px;font-weight:700;color:var(--color-primary)}.react-datepicker__time-box{border-radius:0 12px 12px 0}.react-datepicker__time-list-item{border-radius:6px;font-weight:500}.react-datepicker__time-list-item:hover{background:#073ceb14!important}.react-datepicker__time-list-item--selected{background:var(--color-primary)!important;color:#fff!important;font-weight:700}.react-datepicker__today-button{background:var(--color-primary);color:#fff;border:none;border-radius:8px;margin:8px 12px 12px;padding:8px;font-weight:600;cursor:pointer;transition:background .15s ease}.react-datepicker__today-button:hover{background:var(--color-primary-dark)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.modal{background:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:600px;max-height:90vh;overflow-y:auto}.modal-sm{max-width:420px}.modal-lg{max-width:800px}.modal-header{padding:16px 20px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:16px;font-weight:700}.modal-close{width:32px;height:32px;border:none;background:none;cursor:pointer;font-size:20px;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s ease}.modal-close:hover{background:var(--color-bg);color:var(--color-danger)}.modal-body{padding:20px}.modal-footer{padding:16px 20px;border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:10px}.toast-container{position:fixed;top:20px;right:20px;z-index:300;display:flex;flex-direction:column;gap:8px}.toast{padding:12px 16px;border-radius:var(--radius-md);box-shadow:var(--shadow-md);font-size:13px;font-weight:500;display:flex;align-items:center;gap:10px;animation:taSlideIn .3s ease;min-width:280px}.toast-success{background:var(--color-success);color:#fff}.toast-error{background:var(--color-danger);color:#fff}.toast-warning{background:var(--color-warning);color:#fff}@keyframes taSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--color-text-secondary)}.loading-spinner{width:36px;height:36px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:taSpin .8s linear infinite;margin-right:12px}@keyframes taSpin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:48px 20px;color:var(--color-text-secondary)}.empty-state-icon{font-size:48px;margin-bottom:12px;opacity:.5}.empty-state-text{font-size:15px;font-weight:500}.row-actions{display:flex;gap:6px}.info-box{background:var(--color-bg);border-radius:var(--radius-md);padding:12px;font-size:13px;margin-bottom:16px;border:1px solid var(--color-border)}.info-box-row{display:flex;justify-content:space-between;padding:3px 0}.info-box-label{color:var(--color-text-secondary)}.info-box-value{font-weight:600;color:var(--color-text)}.info-box-value-success{color:var(--color-success)}.info-box-value-warning{color:var(--color-warning)}.info-box-value-danger{color:var(--color-danger)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:16px;flex-wrap:wrap}.page-header-title{font-size:20px;font-weight:800;color:var(--color-text)}.page-header-desc{font-size:13px;color:var(--color-text-secondary);margin-top:2px}.page-header-back{display:flex;align-items:center;gap:16px}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.card-grid-item{background:var(--color-white);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border);transition:box-shadow .2s}.card-grid-item:hover{box-shadow:var(--shadow-md)}.card-grid-item-danger{border-left:4px solid var(--color-danger)}.card-grid-item-warning{border-left:4px solid var(--color-warning)}.card-grid-item-success{border-left:4px solid var(--color-success)}.card-grid-item-info{border-left:4px solid var(--color-info)}.card-grid-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.card-grid-title{font-size:15px;font-weight:700;color:var(--color-text)}.card-grid-meta{font-size:12px;color:var(--color-text-secondary);margin-bottom:4px}.card-grid-value{font-size:13px;margin-bottom:4px}.card-grid-footer{display:flex;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border)}.section-title{font-size:16px;font-weight:700;color:var(--color-text);margin-bottom:12px;display:flex;align-items:center;gap:8px}.role-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.03em;text-transform:uppercase}.role-badge-admin{background:#073ceb1a;color:var(--color-primary)}.role-badge-ke_toan{background:#10b9811a;color:var(--color-success)}.role-badge-dieu_phoi{background:#f973161a;color:#f97316}.role-badge-lanh_dao{background:#8b5cf61a;color:#8b5cf6}.access-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:40px}.access-denied-icon{font-size:64px;margin-bottom:20px;opacity:.5}.access-denied h2{font-size:24px;font-weight:800;color:var(--color-text);margin-bottom:8px}.access-denied p{color:var(--color-text-secondary);margin-bottom:24px;max-width:400px}.access-denied .btn{min-width:160px}.thanh-tien-box{background:var(--color-primary);color:#fff;border-radius:var(--radius-lg);padding:16px 20px;display:flex;justify-content:space-between;align-items:center;margin-top:16px}.thanh-tien-label{font-size:14px;font-weight:500}.thanh-tien-value{font-size:20px;font-weight:800}.filterBar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:12px;flex-wrap:wrap}.filterBarLeft{display:flex;align-items:center;gap:12px;flex:1;min-width:0;flex-wrap:wrap}.filterItem{display:flex;flex-direction:column;gap:4px}.filterLabel{font-size:11px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;padding-left:2px}.filterSelect{-moz-appearance:none;appearance:none;-webkit-appearance:none;padding:8px 36px 8px 14px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:13px;font-weight:500;font-family:inherit;color:var(--color-text);background:var(--color-white);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' viewBox='0 0 24 24'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease;min-width:160px;white-space:nowrap}.filterSelect:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #073ceb1a}.filterSelect:hover:not(:focus){border-color:var(--color-primary)}.filterSelectActive{border-color:var(--color-primary);color:var(--color-primary);background-color:#073ceb0a}.filterSearch{position:relative;flex:1;min-width:220px;max-width:320px}.filterSearchInput{width:100%;padding:8px 14px 8px 38px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:13px;font-family:inherit;color:var(--color-text);background:var(--color-white);transition:border-color .2s ease,box-shadow .2s ease}.filterSearchInput::placeholder{color:var(--color-text-secondary)}.filterSearchInput:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #073ceb1a}.filterSearchIcon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text-secondary);font-size:15px;pointer-events:none}.filterClearBtn{display:inline-flex;align-items:center;gap:5px;padding:8px 14px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:12px;font-weight:600;font-family:inherit;color:var(--color-text-secondary);background:var(--color-white);cursor:pointer;transition:all .2s ease;white-space:nowrap}.filterClearBtn:hover{border-color:var(--color-danger);color:var(--color-danger);background:#ef44440a}.filterStats{font-size:12px;color:var(--color-text-secondary);padding:8px 0}.filterStats strong{color:var(--color-primary)}.filter-group{display:flex;gap:8px;align-items:center}.notification-popup-container{position:fixed;top:0;left:0;right:0;bottom:0;z-index:99999;display:flex;flex-direction:column;align-items:flex-end;gap:10px;padding:20px;max-width:100vw;width:100%;pointer-events:none}.np-popup{background:#fff;border-radius:14px;box-shadow:0 8px 32px #0000001f,0 2px 8px #073ceb14;border:1px solid rgba(7,60,235,.1);overflow:hidden;pointer-events:all;animation:npSlideIn .4s cubic-bezier(.34,1.56,.64,1);position:relative}@keyframes npSlideIn{0%{opacity:0;transform:translate(110%) scale(.9)}to{opacity:1;transform:translate(0) scale(1)}}.np-popup--exiting{animation:npSlideOut .25s ease-in forwards}@keyframes npSlideOut{to{opacity:0;transform:translate(110%)}}.np-popup__header{display:flex;align-items:flex-start;gap:12px;padding:14px 14px 10px}.np-popup__icon-wrap{position:relative;flex-shrink:0}.np-popup__icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;background:#073ceb0f;font-size:20px;line-height:1}.np-popup__dot{position:absolute;top:-2px;right:-2px;width:10px;height:10px;background:#ef4444;border-radius:50%;border:2px solid #ffffff}.np-popup__title-wrap{flex:1;min-width:0}.np-popup__title{font-size:14px;font-weight:700;color:#111827;line-height:1.4;margin:0}.np-popup__time{font-size:11.5px;color:#9ca3af;margin-top:2px}.np-popup__close{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;background:#0000000a;border-radius:8px;cursor:pointer;color:#6b7280;flex-shrink:0;transition:all .15s ease;padding:0;font-size:12px}.np-popup__close:hover{background:#ef444414;color:#ef4444}.np-popup__body{padding:0 14px 14px;cursor:pointer}.np-popup__message{font-size:13px;color:#4b5563;line-height:1.5;margin:0 0 8px}.np-popup__cta{font-size:12px;font-weight:700;color:#073ceb;letter-spacing:.01em}.np-popup__progress{height:3px;background:#0000000a;overflow:hidden}.np-popup__progress-bar{height:100%;background:linear-gradient(90deg,#073ceb,#3b82f6);border-radius:0 2px 2px 0;animation:npProgress linear forwards}@keyframes npProgress{0%{width:100%}to{width:0%}}.notif-page{display:flex;flex-direction:column;gap:0}.notif-page__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.notif-page__header-left{display:flex;align-items:center;gap:14px}.notif-page__title{font-size:22px;font-weight:800;color:var(--color-text);letter-spacing:-.3px}.notif-page__subtitle{font-size:13px;color:var(--color-text-secondary);margin-top:2px}.notif-page__badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 6px;border-radius:12px;background:#ef4444;color:#fff;font-size:11px;font-weight:700;line-height:1}.notif-filter-bar{display:flex;align-items:center;gap:8px;margin-bottom:20px;flex-wrap:wrap}.notif-filter-tab{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;border:1.5px solid var(--color-border);background:var(--color-white);color:var(--color-text-secondary);transition:all .18s ease;font-family:inherit}.notif-filter-tab:hover{border-color:var(--color-primary);color:var(--color-primary);background:#073ceb08}.notif-filter-tab--active{border-color:var(--color-primary);color:var(--color-primary);background:#073ceb0f;font-weight:700}.notif-filter-tab__count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 5px;border-radius:10px;background:#073ceb1a;color:var(--color-primary);font-size:11px;font-weight:700}.notif-filter-tab--active .notif-filter-tab__count{background:var(--color-primary);color:#fff}.notif-card{background:var(--color-white);border-radius:14px;box-shadow:0 1px 3px #0000000f,0 0 0 1px #0000000a;overflow:hidden}.notif-list{list-style:none;margin:0;padding:0}.notif-list__item{display:flex;align-items:flex-start;gap:14px;padding:16px 20px;border-bottom:1px solid rgba(0,0,0,.04);cursor:pointer;transition:background .12s ease;position:relative}.notif-list__item:last-child{border-bottom:none}.notif-list__item:hover,.notif-list__item--unread{background:#073ceb05}.notif-list__item--unread:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--color-primary);border-radius:0 2px 2px 0}.notif-list__icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:#073ceb0f;font-size:20px;flex-shrink:0;transition:background .15s ease}.notif-list__item--unread .notif-list__icon{background:#073ceb1a}.notif-list__content{flex:1;min-width:0}.notif-list__header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px}.notif-list__title{font-size:13.5px;font-weight:700;color:var(--color-text);line-height:1.4}.notif-list__title--unread{color:#111827}.notif-list__time{font-size:11.5px;color:#9ca3af;white-space:nowrap;flex-shrink:0}.notif-list__message{font-size:13px;color:var(--color-text-secondary);line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notif-list__actions{display:flex;align-items:center;gap:4px;flex-shrink:0;opacity:0;transition:opacity .15s ease}.notif-list__item:hover .notif-list__actions{opacity:1}.notif-action-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;border:1.5px solid var(--color-border);background:var(--color-white);cursor:pointer;color:var(--color-text-secondary);transition:all .15s ease;padding:0;font-size:12px}.notif-action-btn:hover{transform:translateY(-1px);box-shadow:0 2px 6px #00000014}.notif-action-btn--read:hover{border-color:var(--color-primary);color:var(--color-primary);background:#073ceb0a}.notif-action-btn--delete:hover{border-color:var(--color-danger);color:var(--color-danger);background:#ef44440a}.notif-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;text-align:center;gap:12px}.notif-empty__icon{font-size:52px;opacity:.5}.notif-empty__text{font-size:14px;color:var(--color-text-secondary);font-weight:500;margin:0}.notif-pagination{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-top:1px solid var(--color-border);background:var(--color-bg);gap:12px;flex-wrap:wrap}.notif-pagination__info{font-size:12.5px;color:var(--color-text-secondary);font-weight:500}.notif-pagination__info strong{color:var(--color-primary);font-weight:700}.notif-pagination__controls{display:flex;align-items:center;gap:4px}.notif-pagination__btn{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;padding:0 8px;border:1.5px solid var(--color-border);border-radius:8px;background:var(--color-white);cursor:pointer;font-size:13px;font-weight:500;color:var(--color-text-secondary);transition:all .18s ease;font-family:inherit}.notif-pagination__btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);background:#073ceb08;transform:translateY(-1px);box-shadow:0 2px 6px #073ceb1a}.notif-pagination__btn:disabled{opacity:.35;cursor:not-allowed}.notif-pagination__btn--active{background:var(--color-primary)!important;border-color:var(--color-primary)!important;color:#fff!important;font-weight:700;box-shadow:0 2px 8px #073ceb40!important;transform:translateY(-1px)!important}@media (max-width: 640px){.notification-popup-container{top:10px;right:10px;left:10px;width:auto;max-width:none}.notif-page__header{flex-direction:column;align-items:flex-start}.notif-filter-bar{width:100%}.notif-filter-tab{flex:1;justify-content:center}.notif-pagination{flex-direction:column;align-items:flex-start}.notif-pagination__controls{width:100%;justify-content:center}.notif-list__item{padding:14px 16px;gap:12px}.notif-list__icon{width:38px;height:38px;font-size:18px}}.notif-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:notifOverlayIn .2s ease;pointer-events:auto}@keyframes notifOverlayIn{0%{opacity:0}to{opacity:1}}.notif-modal{background:#fff;border-radius:14px;box-shadow:0 20px 60px #00000026,0 4px 16px #073ceb1a;width:100%;max-width:440px;overflow:hidden;animation:notifModalIn .3s cubic-bezier(.34,1.56,.64,1);pointer-events:auto}@keyframes notifModalIn{0%{opacity:0;transform:scale(.85) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.notif-modal__header{padding:16px 20px;background:linear-gradient(135deg,#073ceb,#0952f0);display:flex;align-items:center;gap:12px;color:#fff}.notif-modal__icon{width:44px;height:44px;background:#fff3;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.notif-modal__meta{flex:1}.notif-modal__label{font-size:13px;font-weight:600;opacity:.9;text-transform:uppercase;letter-spacing:.5px}.notif-modal__time{font-size:12px;opacity:.75;margin-top:2px}.notif-modal__close{width:32px;height:32px;border:none;background:#ffffff26;cursor:pointer;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;transition:background .2s ease;flex-shrink:0}.notif-modal__close:hover{background:#ffffff4d}.notif-modal__body{padding:20px 24px}.notif-modal__title{font-size:16px;font-weight:700;color:#1a1a1a;margin:0 0 8px;line-height:1.4}.notif-modal__message{font-size:14px;color:#555;margin:0;line-height:1.6}.notif-modal__footer{padding:16px 24px;border-top:1px solid #e8e8e8;display:flex;justify-content:flex-end;gap:10px;background:#fafafa}.notif-modal__footer .btn{cursor:pointer;min-width:110px}@media (max-width: 480px){.notif-modal-overlay{padding:16px;align-items:center;justify-content:center}.notif-modal{max-width:100%;border-radius:14px}.notif-modal__footer{flex-direction:column-reverse;gap:8px}.notif-modal__footer .btn{width:100%;justify-content:center}}.auth-wrapper{min-height:100vh;display:grid;grid-template-columns:minmax(300px,1fr) 1fr;background:linear-gradient(120deg,#f6f8ff,#f3f8fb)}.auth-illustration{background:linear-gradient(135deg,#0129a0,#073ceb);color:#fff;display:flex;align-items:center;justify-content:center;padding:3rem;position:relative;overflow:hidden}.auth-illustration:before{content:"";position:absolute;top:-150px;right:-150px;width:450px;height:450px;border-radius:50%;background:#ffffff0a;border:1px solid rgba(255,255,255,.06)}.auth-illustration:after{content:"";position:absolute;bottom:-200px;left:-100px;width:550px;height:550px;border-radius:50%;background:#ffffff08;border:1px solid rgba(255,255,255,.04)}.illustration-content{max-width:420px;position:relative;z-index:1}.illustration-logo{width:100px;height:100px;object-fit:contain;border-radius:20px;margin-bottom:2rem;filter:drop-shadow(0 8px 20px rgba(0,0,0,.25))}.illustration-content h1{font-size:1.9rem;line-height:1.3;margin-bottom:.75rem;color:#fff;font-weight:800}.illustration-content .intro-text{font-size:.9rem;opacity:.75;line-height:1.6}.illustration-content ul{list-style:none;padding:0;margin-top:1.75rem;display:flex;flex-direction:column;gap:.65rem}.illustration-content ul li{display:flex;align-items:center;gap:.75rem;font-size:.9rem;opacity:.9;color:#fffffff2}.illustration-content ul li:before{content:"";width:6px;height:6px;border-radius:50%;background:#ffffff80;flex-shrink:0}.illustration-footer{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1);font-size:.75rem;opacity:.45;text-align:center;letter-spacing:.05em}.login-container{display:flex;align-items:center;justify-content:center;padding:3rem}.login-card{background:#fff;border-radius:28px;padding:3rem;width:min(440px,100%);box-shadow:0 8px 40px #0129a01a}.login-header{text-align:center;margin-bottom:2rem}.login-logo{width:80px;height:80px;object-fit:contain;margin-bottom:1rem;border-radius:16px}.login-header h1{color:#0129a0;margin-bottom:.4rem;font-size:1.75rem;font-weight:800}.login-header .login-subtitle{color:#64748b;font-size:.9rem}.login-role-tag{display:inline-block;background:#eff6ff;color:#073ceb;font-size:.75rem;font-weight:700;padding:.25rem .75rem;border-radius:20px;margin-bottom:1rem;letter-spacing:.05em;text-transform:uppercase}.login-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.45rem}.form-group label{font-weight:600;font-size:.875rem;color:#334155}.form-group input{width:100%;padding:.85rem 1rem;border:1.5px solid #e2e8f0;border-radius:12px;font-size:.95rem;background-color:#f8fafc;color:#1e293b;transition:border-color .2s,background-color .2s,box-shadow .2s;outline:none;box-sizing:border-box}.form-group input::placeholder{color:#94a3b8}.form-group input:focus{border-color:#073ceb;background-color:#fff;box-shadow:0 0 0 3px #073ceb14;outline:none}.input-with-icon{position:relative}.input-with-icon input{width:100%;padding-left:2.75rem;padding-right:2.75rem}.input-icon{position:absolute;left:.85rem;top:50%;transform:translateY(-50%);color:#94a3b8;font-size:1.1rem;pointer-events:none;transition:color .2s}.input-with-icon:focus-within .input-icon{color:#073ceb}.eye-button{position:absolute;top:50%;right:.75rem;transform:translateY(-50%);border:none;background:transparent;font-size:1.25rem;cursor:pointer;color:#94a3b8;display:flex;align-items:center;justify-content:center;padding:.25rem;transition:color .2s}.eye-button:hover{color:#073ceb;background:transparent}.eye-button:focus{outline:none;background:transparent}.eye-button svg{display:block;width:1.25rem;height:1.25rem}.error-message{background-color:#fef2f2;color:#dc2626;padding:.75rem 1rem;border-radius:10px;font-size:.875rem;border:1px solid #fecaca;display:flex;align-items:center;gap:.5rem}.remember-password{margin-top:0}.remember-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:400;font-size:.875rem;color:#64748b}.remember-checkbox input[type=checkbox]{width:17px;height:17px;cursor:pointer;accent-color:#073ceb;flex-shrink:0}.remember-checkbox span{-webkit-user-select:none;user-select:none}.btn-primary-login{width:100%;padding:.9rem 1.5rem;font-size:1rem;border-radius:12px;margin-top:.5rem;display:flex;align-items:center;justify-content:center;background:#073ceb!important;color:#fff!important;border:none;font-weight:700;cursor:pointer;transition:background .2s,box-shadow .2s,transform .1s;box-shadow:0 2px 10px #073ceb40;letter-spacing:.2px}.btn-primary-login:hover{background:#0129a0!important;box-shadow:0 4px 16px #073ceb59}.btn-primary-login:active{transform:scale(.99)}.btn-primary-login:disabled{opacity:.65;cursor:not-allowed;transform:none}.login-version{text-align:center;margin-top:1.75rem;font-size:.75rem;color:#94a3b8}@media (max-width: 900px){.auth-wrapper{grid-template-columns:1fr}.auth-illustration{min-height:auto;padding:2.5rem 2rem;display:none}.login-container{padding:2rem;align-items:flex-start}.login-card{padding:2rem;border-radius:20px;width:100%}}@media (max-width: 480px){.login-container{padding:1.5rem 1rem;align-items:flex-start}.login-card{padding:1.5rem}}
