@import "https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:wght@300;400;500;600;700;800&display=swap";
*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0f1a;--surface:#1a1a2e;--surface2:#16213e;--card:#1e2746;--primary:#e94560;--primary-glow:#e945604d;--accent:#0f3460;--gold:#f5c518;--text:#e8e8e8;--text2:#a0a0b8;--green:#2ecc71;--blue:#3498db;--radius:14px;--shadow:0 8px 32px #0006}body{background:var(--bg);color:var(--text);-webkit-text-size-adjust:100%;min-height:100vh;font-family:Be Vietnam Pro,sans-serif;overflow-x:hidden}#loader{background:var(--bg);z-index:9999;flex-direction:column;justify-content:center;align-items:center;transition:opacity .5s;display:flex;position:fixed;inset:0}#loader.hidden{opacity:0;pointer-events:none}.loader-ring{border:4px solid var(--surface2);border-top-color:var(--primary);border-radius:50%;width:70px;height:70px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}#loader p{color:var(--text2);margin-top:20px;font-size:15px;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.header{background:linear-gradient(135deg,var(--surface) 0%,var(--accent) 100%);text-align:center;border-bottom:2px solid var(--primary);padding:24px 20px;position:relative;overflow:hidden}.header:before{content:"";background:radial-gradient(circle at 30% 50%,var(--primary-glow),transparent 60%);pointer-events:none;position:absolute;inset:0}.header h1{background:linear-gradient(135deg,#fff,var(--gold));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:clamp(1.3rem,4vw,2rem);font-weight:800}.header p{color:var(--text2);margin-top:4px;font-size:13px}.strip-wrap{background:var(--surface);border-bottom:1px solid #ffffff0d;position:relative}.strip-wrap.bottom-strip{border-top:1px solid #ffffff0d;border-bottom:none}.strip{-webkit-overflow-scrolling:touch;scrollbar-width:none;align-items:center;gap:8px;padding:10px 16px;display:flex;overflow:auto visible}.strip::-webkit-scrollbar{display:none}.strip-wrap:after{content:"";pointer-events:none;background:linear-gradient(to left,var(--surface),transparent);z-index:2;width:32px;position:absolute;top:0;bottom:0;right:0}.search-box{flex:none;width:clamp(160px,50vw,260px);position:relative}.search-box input{background:var(--card);border-radius:var(--radius);width:100%;color:var(--text);white-space:nowrap;border:1px solid #ffffff14;padding:10px 14px 10px 38px;font-family:inherit;font-size:13px;transition:border .3s}.search-box input:focus{border-color:var(--primary);outline:none}.search-box .search-icon{color:var(--text2);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.strip select{background:var(--card);color:var(--text);border-radius:var(--radius);appearance:none;cursor:pointer;white-space:nowrap;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' fill='%23a0a0b8' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border:1px solid #ffffff14;flex:none;padding:10px 30px 10px 12px;font-family:inherit;font-size:13px;transition:border .3s}.strip select:focus{border-color:var(--primary);outline:none}.btn{border-radius:var(--radius);cursor:pointer;white-space:nowrap;letter-spacing:.2px;border:1px solid #ffffff14;flex:none;align-items:center;gap:5px;padding:10px 14px;font-family:inherit;font-size:13px;font-weight:600;transition:all .25s;display:inline-flex}.btn-primary{background:linear-gradient(135deg,var(--primary),#c0392b);color:#fff;box-shadow:0 3px 12px var(--primary-glow);border:none}.btn-primary:hover{box-shadow:0 5px 18px var(--primary-glow);transform:translateY(-1px)}.btn-outline{color:var(--text);background:0 0;border:1px solid #ffffff26}.btn-outline:hover{background:#ffffff0d}.btn-danger{color:#fff;background:linear-gradient(135deg,#922b21,#e74c3c);border:none;box-shadow:0 3px 12px #e74c3c4d}.btn-danger:hover{transform:translateY(-1px);box-shadow:0 5px 18px #e74c3c73}.btn-sm{border-radius:8px;padding:7px 11px;font-size:12px}.btn-edit{color:var(--blue);background:#3498db26;border:1px solid #3498db4d}.btn-delete{color:#e74c3c;background:#e74c3c1f;border:1px solid #e74c3c4d}.strip-divider{background:#ffffff1a;flex:0 0 1px;height:24px;margin:0 2px}.filter-badge{color:var(--gold);white-space:nowrap;background:#f5c5181a;border:1px solid #f5c51859;border-radius:20px;flex:none;align-items:center;gap:5px;padding:5px 11px;font-size:12px;font-weight:600;display:none}.filter-badge.active{display:inline-flex}.filter-badge .close-btn{color:var(--gold);cursor:pointer;opacity:.7;background:0 0;border:none;padding:0 0 0 2px;font-size:14px;line-height:1}.filter-badge .close-btn:hover{opacity:1}.pagination{background:var(--surface);flex-wrap:wrap;justify-content:center;gap:8px;padding:14px 20px;display:flex}.page-btn{background:var(--card);color:var(--text);cursor:pointer;border:1px solid #ffffff1a;border-radius:8px;padding:6px 13px;font-size:13px;font-weight:600;transition:all .2s}.page-btn:hover:not(:disabled){background:#ffffff0d}.page-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.page-btn:disabled{opacity:.5;cursor:not-allowed}.table-wrap{-webkit-overflow-scrolling:touch;padding:0 12px;overflow-x:auto}table{border-collapse:separate;border-spacing:0;white-space:nowrap;width:100%;min-width:680px}thead th{background:var(--card);color:var(--text2);text-transform:uppercase;letter-spacing:.8px;text-align:left;z-index:1;border-bottom:2px solid var(--primary);padding:13px 12px;font-size:12px;font-weight:600;position:sticky;top:0}thead th:first-child{border-radius:var(--radius) 0 0 0}thead th:last-child{border-radius:0 var(--radius) 0 0}tbody tr{transition:background .2s}tbody tr:hover{background:#e945600f}tbody td{border-bottom:1px solid #ffffff0a;padding:11px 12px;font-size:14px}.col-stt{text-align:center;width:50px;color:var(--text2);font-weight:600}.col-money{color:var(--gold);white-space:nowrap;font-weight:700}.col-rel{border-radius:20px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-block}.rel-ban-be{color:#5dade2;background:#3498db26}.rel-dong-nghiep{color:#2ecc71;background:#2ecc7126}.rel-ho-hang{color:var(--primary);background:#e9456026}.rel-hang-xom{color:var(--gold);background:#f5c51826}.rel-other{color:var(--text2);background:#a0a0b826}.col-actions{white-space:nowrap}.no-data{text-align:center;color:var(--text2);padding:60px 20px}.no-data span{margin-bottom:12px;font-size:48px;display:block}.summary{background:linear-gradient(135deg,var(--surface),var(--surface2));border-radius:var(--radius);border:1px solid #ffffff0f;margin:18px 12px;padding:22px 20px}.summary h2{align-items:center;gap:8px;margin-bottom:14px;font-size:17px;display:flex}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-bottom:18px;display:grid}.stat-card{background:var(--card);text-align:center;border:1px solid #ffffff0d;border-radius:12px;padding:14px}.stat-card .label{color:var(--text2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px;font-size:11px}.stat-card .value{font-size:clamp(1rem,3vw,1.45rem);font-weight:700}.stat-card .value.gold{color:var(--gold)}.stat-card .value.green{color:var(--green)}.stat-card .value.blue{color:var(--blue)}.dist-title{color:var(--text2);margin-bottom:9px;font-size:13px}.dist-bar{align-items:center;gap:10px;margin-bottom:7px;font-size:13px;display:flex}.dist-bar .range{min-width:130px;color:var(--text2)}.dist-bar .bar{background:var(--card);border-radius:6px;flex:1;height:22px;overflow:hidden}.dist-bar .fill{border-radius:6px;min-width:2px;height:100%;transition:width .8s}.dist-bar .count{text-align:right;min-width:40px;font-size:12px;font-weight:600}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#000000b8;justify-content:center;align-items:center;padding:16px;display:none;position:fixed;inset:0}.modal-overlay.show{display:flex}.modal{background:var(--surface);border-radius:var(--radius);width:100%;max-width:500px;max-height:92vh;box-shadow:var(--shadow);border:1px solid #ffffff14;padding:26px;overflow-y:auto}.modal h2{align-items:center;gap:8px;margin-bottom:18px;font-size:17px;display:flex}.form-group{margin-bottom:14px}.form-group label{color:var(--text2);margin-bottom:5px;font-size:13px;font-weight:500;display:block}.form-group input,.form-group select,.form-group textarea{background:var(--card);width:100%;color:var(--text);border:1px solid #ffffff14;border-radius:10px;padding:10px 13px;font-family:inherit;font-size:14px;transition:border .3s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);outline:none}.form-group textarea{resize:vertical;min-height:68px}.form-actions{gap:10px;margin-top:18px;display:flex}.form-actions .btn{flex:1;justify-content:center;padding:12px}.autocomplete-list{background:var(--card);z-index:10;border:1px solid #ffffff1f;border-radius:10px;max-height:200px;margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 8px 24px #00000080}.autocomplete-item{cursor:pointer;border-bottom:1px solid #ffffff0a;padding:9px 14px;font-size:13px;transition:background .15s}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item:hover{color:var(--primary);background:#e945601f}.money-presets{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;gap:8px;margin-top:8px;padding-bottom:2px;display:flex;overflow-x:auto}.money-presets::-webkit-scrollbar{display:none}.money-pill{color:#111;cursor:pointer;white-space:nowrap;background:#fff;border:1.5px solid #ddd;border-radius:999px;flex:none;padding:6px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:all .2s}.money-pill:hover{border-color:var(--primary);color:var(--primary);background:#fff0f3}.money-pill.active{background:var(--primary);color:#fff;border-color:var(--primary)}.rel-list{flex-direction:column;gap:7px;max-height:280px;margin-bottom:12px;padding-right:2px;display:flex;overflow-y:auto}.rel-item{background:var(--card);border:1px solid #ffffff0f;border-radius:10px;align-items:center;gap:8px;padding:9px 12px;transition:border .2s;display:flex}.rel-item:focus-within{border-color:var(--primary)}.rel-item-inp{color:var(--text);cursor:default;background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:14px}.rel-item-inp.editing{cursor:text;border-bottom:1px solid var(--primary)}.rel-item-btns{flex-shrink:0;gap:4px;display:flex}.rel-add-row{gap:8px;display:flex}.rel-add-inp{background:var(--card);color:var(--text);border:1px solid #ffffff14;border-radius:10px;flex:1;padding:10px 13px;font-family:inherit;font-size:14px}.rel-add-inp:focus{border-color:var(--primary);outline:none}.dup-table-wrap{border:1px solid #ffffff14;border-radius:10px;max-height:220px;margin-bottom:14px;overflow-y:auto}.dup-table{border-collapse:collapse;width:100%;font-size:12px}.dup-table th{background:var(--card);color:var(--text2);text-align:left;text-transform:uppercase;letter-spacing:.5px;padding:8px 10px;font-size:11px;position:sticky;top:0}.dup-table td{vertical-align:top;border-bottom:1px solid #ffffff0a;padding:8px 10px}.dup-table tr:last-child td{border-bottom:none}.dup-tag{border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.dup-tag.old{color:var(--blue);background:#3498db26}.dup-tag.new{color:var(--gold);background:#f5c51826}.import-option-row{gap:10px;margin-bottom:14px;display:flex}.import-option{background:var(--card);cursor:pointer;text-align:center;border:2px solid #ffffff14;border-radius:12px;flex:1;padding:12px;transition:all .25s}.import-option:hover{border-color:var(--primary)}.import-option.selected{border-color:var(--primary);background:#e945601a}.import-option .opt-icon{margin-bottom:6px;font-size:26px}.import-option .opt-title{margin-bottom:3px;font-size:13px;font-weight:700}.import-option .opt-desc{color:var(--text2);font-size:11px;line-height:1.4}.confirm-modal{max-width:420px}.confirm-top{text-align:center;margin-bottom:14px}.confirm-icon{margin-bottom:8px;font-size:54px}.confirm-modal p{color:var(--text2);text-align:center;margin-bottom:4px;font-size:14px;line-height:1.7}.fab{background:linear-gradient(135deg,var(--primary),#c0392b);color:#fff;cursor:pointer;width:56px;height:56px;box-shadow:0 4px 16px var(--primary-glow);z-index:100;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .25s;display:flex;position:fixed;bottom:28px;right:28px}.fab:hover{box-shadow:0 6px 24px var(--primary-glow);transform:scale(1.1)}.fab:active{transform:scale(.95)}.toast{color:#fff;z-index:9999;opacity:0;border-radius:12px;max-width:calc(100vw - 40px);padding:13px 20px;font-size:14px;font-weight:500;transition:all .4s;position:fixed;bottom:22px;right:20px;transform:translateY(100px)}.toast.show{opacity:1;transform:translateY(0)}.toast.success{background:linear-gradient(135deg,#27ae60,#2ecc71)}.toast.error{background:linear-gradient(135deg,#c0392b,#e74c3c)}.toast.info{background:linear-gradient(135deg,#2471a3,#3498db)}.login-page{background:linear-gradient(135deg,var(--bg) 0%,var(--surface2) 50%,var(--bg) 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:var(--surface);border-radius:var(--radius);width:100%;max-width:400px;box-shadow:var(--shadow);border:1px solid #ffffff14;padding:36px 30px}.login-header{text-align:center;margin-bottom:28px}.login-header h1{background:linear-gradient(135deg,#fff,var(--gold));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:12px 0 6px;font-size:1.4rem;font-weight:800}.login-header p{color:var(--text2);font-size:13px}.login-icon{color:var(--primary);margin:0 auto;display:block}.login-form{flex-direction:column;gap:16px;display:flex}.login-field label{color:var(--text2);align-items:center;gap:6px;margin-bottom:6px;font-size:13px;font-weight:500;display:flex}.login-field input{background:var(--card);width:100%;color:var(--text);border:1px solid #ffffff14;border-radius:10px;padding:12px 14px;font-family:inherit;font-size:14px;transition:border .3s}.login-field input:focus{border-color:var(--primary);outline:none}.login-btn{background:linear-gradient(135deg,var(--primary),#c0392b);color:#fff;border-radius:var(--radius);cursor:pointer;box-shadow:0 3px 12px var(--primary-glow);border:none;justify-content:center;align-items:center;gap:8px;padding:13px;font-family:inherit;font-size:15px;font-weight:700;transition:all .25s;display:flex}.login-btn:hover:not(:disabled){box-shadow:0 5px 18px var(--primary-glow);transform:translateY(-1px)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#e74c3c;background:#e74c3c26;border:1px solid #e74c3c4d;border-radius:10px;align-items:center;gap:8px;padding:10px 14px;font-size:13px;display:flex}.login-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin;display:inline-block}.user-bar{background:var(--surface2);color:var(--text2);border-bottom:1px solid #ffffff0d;justify-content:flex-end;align-items:center;gap:10px;padding:6px 16px;font-size:12px;display:flex}.user-bar .user-name{align-items:center;gap:5px;font-weight:500;display:flex}.user-bar .logout-btn{color:var(--text2);cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:6px;align-items:center;gap:4px;padding:4px 10px;font-family:inherit;font-size:11px;transition:all .2s;display:flex}.user-bar .logout-btn:hover{color:#e74c3c;background:#e74c3c26;border-color:#e74c3c4d}@media (max-width:480px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}.dist-bar .range{min-width:88px;font-size:11px}.import-option-row{flex-direction:column}}
