@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f0f4ff;--sidebar:#fff;--surface:#fff;--border:#e4eaf5;--blue:#2563eb;--blue-l:#eff6ff;--blue-d:#1d4ed8;--text:#0f172a;--sub:#64748b;--muted:#94a3b8;--ok:#10b981;--warn:#f59e0b;--bad:#ef4444;--radius:14px;--shadow:0 2px 12px #1e40af14,0 1px 3px #1e40af0d;--shadow-lg:0 8px 32px #1e40af1f,0 2px 8px #1e40af12}body,.app-wrapper{background:var(--bg);color:var(--text);flex-direction:column;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex}.topnav{background:var(--surface);border-bottom:1.5px solid var(--border);z-index:100;align-items:center;gap:16px;height:58px;padding:0 24px;display:flex;position:sticky;top:0;box-shadow:0 1px 8px #1e40af12}.nav-brand{-webkit-user-select:none;user-select:none;align-items:center;text-decoration:none;display:flex}.nav-logo-text{align-items:baseline;gap:0;line-height:1;display:flex}.nav-logo-text .part-quanly{color:var(--text);letter-spacing:-.6px;font-size:17px;font-weight:900}.nav-logo-text .part-htx{background:linear-gradient(135deg,#1d4ed8,#0ea5e9);-webkit-text-fill-color:transparent;letter-spacing:-.6px;-webkit-background-clip:text;background-clip:text;font-size:17px;font-weight:900}.nav-logo-text .part-dot{color:var(--muted);letter-spacing:0;-webkit-text-fill-color:var(--muted);margin-left:1px;font-size:13px;font-weight:700}.nav-title{color:var(--text);letter-spacing:-.3px;font-size:16px;font-weight:800}.nav-title span{color:var(--blue)}.nav-sub{color:var(--muted);font-size:11px;font-weight:500}.nav-search{background:var(--bg);border:1.5px solid var(--border);border-radius:10px;flex:1;align-items:center;gap:8px;max-width:380px;margin-left:24px;padding:7px 12px;transition:border-color .2s,box-shadow .2s;display:flex}.nav-search:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px #2563eb1f}.nav-search svg{width:15px;height:15px;fill:var(--muted);flex-shrink:0}.nav-search input{color:var(--text);background:0 0;border:none;outline:none;width:100%;font-size:13px}.nav-search input::placeholder{color:var(--muted)}.nav-right{align-items:center;gap:8px;margin-left:auto;display:flex}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:9px;align-items:center;gap:6px;padding:7px 14px;font-size:12.5px;font-weight:700;transition:all .18s;display:inline-flex}.btn-ghost{color:var(--sub);border:1.5px solid var(--border);background:0 0}.btn-ghost:hover{background:var(--bg);border-color:var(--blue);color:var(--blue)}.btn-primary{background:linear-gradient(135deg,var(--blue-d),var(--blue));color:#fff;box-shadow:0 3px 10px #2563eb4d}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 18px #2563eb61}.btn-primary:active{transform:translateY(0)}.btn-upload{color:#fff;background:linear-gradient(135deg,#059669,#10b981);box-shadow:0 3px 10px #10b98159}.btn-upload:hover{background:linear-gradient(135deg,#047857,#059669);transform:translateY(-1px);box-shadow:0 6px 18px #10b98173}.btn-upload:active{transform:translateY(0)}.btn-danger{color:var(--bad);background:#fff1f2;border:1.5px solid #fecdd3}.btn-danger:hover{background:var(--bad);color:#fff}.btn svg{fill:currentColor;width:14px;height:14px}.avatar{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:800;display:flex;box-shadow:0 2px 8px #6366f14d}.app{flex:1;min-height:0;display:flex}.sidebar{background:var(--sidebar);border-right:1.5px solid var(--border);flex-direction:column;flex-shrink:0;gap:4px;width:220px;height:calc(100vh - 58px);padding:16px 12px;transition:width .25s,padding .25s,opacity .2s;display:flex;position:sticky;top:58px;overflow:hidden auto}.sidebar.collapsed{opacity:0;pointer-events:none;width:0;padding:0}.sidebar-toggle{background:var(--surface);border:1.5px solid var(--border);cursor:pointer;z-index:50;width:18px;height:48px;color:var(--muted);border-left:none;border-radius:0 8px 8px 0;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.sidebar-toggle:hover{background:var(--blue-l);color:var(--blue);border-color:#93c5fd}.sidebar-toggle svg{fill:currentColor;width:10px;height:10px;transition:transform .25s}.sidebar.collapsed+.sidebar-toggle-wrap .sidebar-toggle svg{transform:rotate(180deg)}.sidebar-toggle-wrap{z-index:50;flex-shrink:0;width:0;height:0;position:sticky;top:calc(50vh - 24px)}.sidebar-section{color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;padding:12px 8px 6px;font-size:9.5px;font-weight:800}.nav-item{color:var(--sub);cursor:pointer;border-radius:10px;align-items:center;gap:9px;padding:8px 10px;font-size:13px;font-weight:600;text-decoration:none;transition:all .15s;display:flex}.nav-item:hover{background:var(--bg);color:var(--text)}.nav-item.active{background:var(--blue-l);color:var(--blue);font-weight:700}.nav-item svg{fill:currentColor;opacity:.7;flex-shrink:0;width:16px;height:16px}.nav-item.active svg{opacity:1}.nav-item .badge-count{background:var(--bad);color:#fff;border-radius:20px;margin-left:auto;padding:1px 6px;font-size:9px;font-weight:800}.nav-item.active .badge-count{background:var(--blue)}.nav-child{padding-left:28px;font-size:12px}.main{flex:1;min-width:0;padding:16px 20px;transition:all .25s;overflow-y:auto}.page-hdr{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:14px;display:flex}.page-hdr-left h1{color:var(--text);letter-spacing:-.4px;font-size:20px;font-weight:800}.page-hdr-left p{color:var(--sub);margin-top:3px;font-size:12.5px}.page-hdr-actions{flex-wrap:wrap;gap:8px;display:flex}.htx-tabs{background:var(--surface);border:1.5px solid var(--border);border-radius:12px;flex-wrap:wrap;gap:6px;margin-bottom:20px;padding:6px;display:flex}.htx-tab{cursor:pointer;color:var(--sub);background:0 0;border:none;border-radius:8px;padding:6px 14px;font-size:12px;font-weight:700;transition:all .18s}.htx-tab:hover{background:var(--bg);color:var(--text)}.htx-tab.active{background:var(--blue);color:#fff;box-shadow:0 3px 10px #2563eb4d}.htx-tab .dot{border-radius:50%;width:7px;height:7px;margin-right:5px;display:inline-block}.stats{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin-bottom:14px;display:grid}.stat-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 18px;transition:box-shadow .2s,transform .2s;position:relative;overflow:hidden}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.stat-card:before{content:"";background:var(--accent,var(--blue));border-radius:14px 14px 0 0;height:3px;position:absolute;top:0;left:0;right:0}.stat-label{color:var(--muted);letter-spacing:.5px;text-transform:uppercase;margin-bottom:8px;font-size:10.5px;font-weight:700}.stat-num{color:var(--text);letter-spacing:-1px;font-size:30px;font-weight:900;line-height:1}.stat-num span{color:var(--sub);letter-spacing:0;margin-left:2px;font-size:13px;font-weight:600}.stat-sub{color:var(--muted);margin-top:5px;font-size:10.5px}.stat-icon{border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:flex;position:absolute;top:14px;right:14px}.stat-icon svg{width:18px;height:18px}.toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;display:flex}.toolbar-search{background:var(--surface);border:1.5px solid var(--border);border-radius:10px;flex:1;align-items:center;gap:8px;min-width:200px;max-width:360px;padding:8px 12px;transition:border-color .2s,box-shadow .2s;display:flex}.toolbar-search:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px #2563eb1a}.toolbar-search svg{width:14px;height:14px;fill:var(--muted);flex-shrink:0}.toolbar-search input{color:var(--text);background:0 0;border:none;outline:none;width:100%;font-size:13px}.select-wrap{position:relative}.select-wrap select{appearance:none;background:var(--surface);border:1.5px solid var(--border);color:var(--text);cursor:pointer;border-radius:10px;outline:none;padding:8px 32px 8px 12px;font-size:12.5px;font-weight:600;transition:border-color .2s}.select-wrap select:focus{border-color:var(--blue)}.select-wrap:after{content:"▾";color:var(--muted);pointer-events:none;font-size:11px;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.toolbar-right{gap:8px;margin-left:auto;display:flex}.table-wrap{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.table-head{border-bottom:1.5px solid var(--border);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.table-head h3{color:var(--text);font-size:14px;font-weight:800}.table-head p{color:var(--muted);margin-top:1px;font-size:11.5px}table{border-collapse:collapse;width:100%}thead tr{background:#f8fafc}th{text-align:left;color:var(--muted);letter-spacing:.8px;text-transform:uppercase;border-bottom:1.5px solid var(--border);white-space:nowrap;padding:8px 12px;font-size:10.5px;font-weight:800}td{color:var(--text);border-bottom:1px solid var(--border);vertical-align:middle;padding:8px 12px;font-size:13px}tr:last-child td{border-bottom:none}tbody tr{transition:background .15s}tbody tr:hover{background:#f8faff}.cell-name{color:var(--text);font-weight:700}.cell-sub{color:var(--muted);margin-top:2px;font-size:11px;font-weight:500}.cell-mono{color:var(--blue);font-size:12px;font-weight:600}.tag{border-radius:20px;align-items:center;gap:4px;padding:3px 9px;font-size:10.5px;font-weight:700;display:inline-flex}.tag-ok{color:#065f46;background:#d1fae5}.tag-warn{color:#92400e;background:#fef3c7}.tag-bad{color:#991b1b;background:#fee2e2}.tag-blue{color:#1e40af;background:#dbeafe}.tag-purple{color:#5b21b6;background:#ede9fe}.tag .dot{background:currentColor;border-radius:50%;width:5px;height:5px}.row-actions{opacity:0;gap:6px;transition:opacity .15s;display:flex}tbody tr:hover .row-actions{opacity:1}.act-btn{border:1.5px solid var(--border);cursor:pointer;background:#fff;border-radius:7px;justify-content:center;align-items:center;width:28px;height:28px;transition:all .15s;display:flex}.act-btn:hover{border-color:var(--blue);background:var(--blue-l)}.act-btn:hover svg{fill:var(--blue)}.act-btn svg{width:13px;height:13px;fill:var(--muted)}.act-btn.del:hover{border-color:var(--bad);background:#fff1f2}.act-btn.del:hover svg{fill:var(--bad)}.pagination{border-top:1.5px solid var(--border);color:var(--muted);justify-content:space-between;align-items:center;padding:14px 18px;font-size:12.5px;font-weight:600;display:flex}.page-btns{gap:4px;display:flex}.page-btn{border:1.5px solid var(--border);cursor:pointer;width:30px;height:30px;color:var(--sub);background:#fff;border-radius:8px;justify-content:center;align-items:center;font-size:12px;font-weight:700;transition:all .15s;display:flex}.page-btn:hover,.page-btn.active{background:var(--blue);border-color:var(--blue);color:#fff}.overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:500;opacity:0;pointer-events:none;background:#0f172a80;justify-content:center;align-items:center;transition:opacity .25s;display:flex;position:fixed;inset:0}.overlay.open{opacity:1;pointer-events:all}.modal{background:#fff;border-radius:20px;width:100%;max-width:520px;margin:16px;transition:transform .28s cubic-bezier(.34,1.56,.64,1);transform:scale(.96)translateY(10px);box-shadow:0 24px 60px #0f172a33}.overlay.open .modal{transform:scale(1)translateY(0)}.modal-hdr{border-bottom:1.5px solid var(--border);justify-content:space-between;align-items:center;padding:20px 22px 16px;display:flex}.modal-hdr h2{color:var(--text);font-size:16px;font-weight:800}.modal-hdr p{color:var(--muted);margin-top:2px;font-size:11.5px}.close-btn{border:1.5px solid var(--border);cursor:pointer;background:#fff;border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.close-btn svg{width:14px;height:14px;fill:var(--muted)}.modal-body,.app-wrapper{padding:20px 22px}.form-row{margin-bottom:14px}.form-label{color:var(--text);margin-bottom:5px;font-size:11.5px;font-weight:700;display:block}.form-label .req{color:var(--bad);margin-left:2px}.form-input{border:1.5px solid var(--border);width:100%;color:var(--text);background:var(--bg);border-radius:10px;outline:none;padding:9px 12px;font-size:13px;transition:border-color .2s,box-shadow .2s}.form-input:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px #2563eb1a}.form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.upload-zone{border:2px dashed var(--border);text-align:center;cursor:pointer;background:var(--bg);border-radius:12px;margin-bottom:14px;padding:28px 20px;transition:all .2s}.upload-zone:hover,.upload-zone.drag{border-color:var(--blue);background:var(--blue-l)}.upload-zone svg{width:36px;height:36px;fill:var(--muted);margin-bottom:10px}.upload-zone:hover svg{fill:var(--blue)}.upload-zone p{color:var(--sub);font-size:13px;font-weight:600}.upload-zone span{color:var(--muted);font-size:11px}.upload-zone input{display:none}.file-list{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.file-item{background:var(--bg);border:1.5px solid var(--border);border-radius:10px;align-items:center;gap:10px;padding:9px 12px;display:flex}.file-item svg{width:16px;height:16px;fill:var(--blue);flex-shrink:0}.file-item span{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:12px;font-weight:600;overflow:hidden}.file-item .rm{cursor:pointer;color:var(--muted);flex-shrink:0;font-size:16px;line-height:1}.file-item .rm:hover{color:var(--bad)}.modal-footer{border-top:1.5px solid var(--border);justify-content:flex-end;gap:8px;padding:14px 22px 20px;display:flex}.detail-panel{border-left:1.5px solid var(--border);z-index:200;background:#fff;flex-direction:column;width:360px;transition:transform .3s cubic-bezier(.34,1.56,.64,1);display:flex;position:fixed;top:58px;bottom:0;right:0;overflow-y:auto;transform:translate(100%);box-shadow:-8px 0 32px #0f172a1a}.detail-panel.open{transform:translate(0)}.dp-hdr{border-bottom:1.5px solid var(--border);align-items:center;gap:10px;padding:18px 18px 14px;display:flex}.dp-avatar{background:linear-gradient(135deg,#2563eb,#0ea5e9);border-radius:13px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:18px;display:flex}.dp-name{color:var(--text);font-size:15px;font-weight:800}.dp-sub{color:var(--muted);margin-top:1px;font-size:11.5px}.dp-close{cursor:pointer;color:var(--muted);margin-left:auto}.dp-close:hover{color:var(--text)}.dp-section{border-bottom:1px solid var(--border);padding:14px 18px}.dp-section-title{color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-bottom:10px;font-size:10px;font-weight:800}.dp-field{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px;display:flex}.dp-field-label{color:var(--muted);flex-shrink:0;font-size:11.5px;font-weight:600}.dp-field-val{color:var(--text);text-align:right;font-size:12.5px;font-weight:700}.dp-docs{flex-direction:column;gap:6px;display:flex}.dp-doc{background:var(--bg);border:1.5px solid var(--border);border-radius:10px;align-items:center;gap:9px;padding:9px 11px;display:flex}.dp-doc svg{width:14px;height:14px;fill:var(--blue);flex-shrink:0}.dp-doc span{color:var(--text);flex:1;font-size:12px;font-weight:600}.dp-doc-tag{border-radius:10px;padding:2px 7px;font-size:9.5px;font-weight:700}.dp-footer{gap:8px;margin-top:auto;padding:14px 18px;display:flex}.toast{z-index:999;color:#fff;opacity:0;background:#0f172a;border-radius:12px;align-items:center;gap:10px;padding:12px 18px;font-size:13px;font-weight:600;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;position:fixed;bottom:24px;right:24px;transform:translateY(80px);box-shadow:0 8px 24px #0f172a40}.toast.show{opacity:1;transform:translateY(0)}.toast svg{fill:#10b981;flex-shrink:0;width:16px;height:16px}.year-badge{border:1px solid var(--border);color:var(--sub);background:#f1f5f9;border-radius:6px;align-items:center;gap:3px;padding:2px 7px;font-size:10.5px;font-weight:700;display:inline-flex}.doc-card{border:1.5px solid var(--border);background:#fff;border-radius:10px;flex-direction:column;gap:3px;min-width:140px;padding:7px 10px;display:flex}.doc-card.st-ok{border-left:3px solid var(--ok);background:#f0fdf4}.doc-card.st-warn{border-left:3px solid var(--warn);background:#fffbeb}.doc-card.st-bad{border-left:3px solid var(--bad);background:#fff1f2}.doc-card.st-pend{background:#fffbeb;border-left:3px solid #f59e0b}.doc-card-top{justify-content:space-between;align-items:center;gap:6px;display:flex}.doc-card-name{color:var(--text);align-items:center;gap:5px;font-size:11.5px;font-weight:700;display:flex}.doc-card-name .ico{flex-shrink:0;font-size:13px}.doc-card-badge{white-space:nowrap;border-radius:20px;flex-shrink:0;padding:2px 7px;font-size:9.5px;font-weight:800}.badge-ok{color:#166534;background:#dcfce7}.badge-warn{color:#92400e;background:#fef3c7}.badge-bad{color:#991b1b;background:#fee2e2}.badge-pend{color:#92400e;background:#fef3c7}.doc-card-date{color:var(--muted);font-size:10px;font-weight:500}.doc-card-link{color:var(--blue);cursor:pointer;align-items:center;gap:3px;font-size:10px;font-weight:600;display:flex}.doc-card-link:hover{text-decoration:underline}body.dark .doc-card{background:var(--surface)}body.dark .doc-card.st-ok{background:#052e16}body.dark .doc-card.st-warn{background:#451a03}body.dark .doc-card.st-bad{background:#450a0a}.up-step{color:#fff6;white-space:nowrap;border-radius:20px;padding:4px 10px;font-size:11px;font-weight:700;transition:all .2s}.up-step.active{color:#fff;background:#ffffff26;font-weight:800}.up-step.done{color:#ffffffb3}.up-doc-tab{color:var(--muted);cursor:pointer;background:0 0;border:none;border-bottom:2.5px solid #0000;margin-bottom:-2px;padding:10px 16px;font-size:12.5px;font-weight:700;transition:all .15s}.up-doc-tab:hover{color:var(--text)}.up-doc-tab.active{color:var(--blue);border-bottom-color:var(--blue)}.up-doc-row{border:1.5px solid var(--border);background:#fff;border-radius:12px;margin-bottom:8px;padding:12px 14px;transition:border-color .2s}.up-doc-row:hover{border-color:#bfdbfe}.up-doc-row-top{align-items:center;gap:10px;display:flex}.up-doc-row-icon{flex-shrink:0;font-size:18px}.up-doc-row-name{color:var(--text);flex:1;font-size:13px;font-weight:700}.up-doc-row-toggle{border:1.5px solid var(--border);cursor:pointer;background:#fff;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:15px;font-weight:700;transition:all .2s;display:flex}.up-doc-row.expanded .up-doc-row-toggle{background:var(--blue);border-color:var(--blue);color:#fff;transform:rotate(45deg)}.up-doc-row-body,.app-wrapper{border-top:1.5px solid var(--border);margin-top:10px;padding-top:10px;display:none}.up-doc-row.expanded .up-doc-row-body,.app-wrapper{display:block}.up-mini-grid{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px;display:grid}.up-mini-field label{color:var(--muted);letter-spacing:.5px;text-transform:uppercase;margin-bottom:3px;font-size:10px;font-weight:800;display:block}.up-mini-field input,.up-mini-field select{border:1.5px solid var(--border);width:100%;color:var(--text);background:var(--bg);border-radius:8px;outline:none;padding:7px 10px;font-size:12px;transition:border-color .2s}.up-mini-field input:focus,.up-mini-field select:focus{border-color:var(--blue);background:#fff}.up-mini-drop{border:2px dashed var(--border);cursor:pointer;background:#fafbff;border-radius:9px;align-items:center;gap:10px;padding:10px 14px;transition:all .2s;display:flex}.up-mini-drop:hover,.up-mini-drop.drag{border-color:var(--blue);background:var(--blue-l)}.up-mini-drop svg{width:18px;height:18px;fill:var(--muted);flex-shrink:0}.up-mini-drop:hover svg{fill:var(--blue)}.up-mini-drop p{color:var(--sub);margin:0;font-size:12px;font-weight:700}.up-mini-drop span{color:var(--muted);font-size:10px}.up-mini-preview{background:var(--bg);border:1.5px solid var(--border);border-radius:8px;align-items:center;gap:8px;margin-top:6px;padding:7px 10px;display:none}.up-mini-preview.show{display:flex}.up-mini-preview .fname{color:var(--blue);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:11.5px;font-weight:700;overflow:hidden}.up-mini-preview .rm{cursor:pointer;color:var(--muted);flex-shrink:0;font-size:16px;line-height:1}.up-mini-preview .rm:hover{color:var(--bad)}.up-sum-row{border:1.5px solid var(--border);background:#fff;border-radius:10px;align-items:center;gap:10px;padding:9px 12px;display:flex}.up-sum-row.has-file{background:#f0fdf4;border-color:#bbf7d0}.up-sum-row.no-file{opacity:.6}.dkxe-radio-opt{border:1.5px solid var(--border);cursor:pointer;background:#fff;border-radius:10px;align-items:center;gap:10px;padding:9px 12px;transition:all .15s;display:flex}.dkxe-radio-opt:hover{background:#f0f9ff;border-color:#93c5fd}.dkxe-radio-opt.selected{border-color:var(--blue);background:var(--blue-l)}.dkxe-radio-opt b{color:var(--text);font-size:12.5px}.sale-wrap{display:inline-flex;position:relative}.sale-card{z-index:999;background:var(--surface);border:1.5px solid var(--border);border-radius:14px;width:240px;padding:14px;animation:.15s fadeUp;display:none;position:absolute;bottom:calc(100% + 8px);left:0;box-shadow:0 8px 30px #00000026}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.sale-wrap:hover .sale-card{display:block}.sale-card-avatar{color:#fff;background:linear-gradient(135deg,#1d4ed8,#0ea5e9);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:13px;font-weight:800;display:flex;box-shadow:0 3px 10px #1d4ed84d}.sale-card-name{color:var(--text);font-size:13px;font-weight:800}.sale-card-uid{color:var(--muted);margin-top:1px;font-size:10px}.sale-card-row{border-bottom:1px solid var(--border);align-items:center;gap:7px;padding:5px 0;font-size:11.5px;display:flex}.sale-card-row:last-child{border-bottom:none;padding-bottom:0}.sale-card-lbl{color:var(--muted);flex-shrink:0;width:44px;font-size:10.5px;font-weight:600}.sale-card-val{color:var(--text);font-size:11px;font-weight:700}.sale-card-img{object-fit:cover;background:#f1f5f9;border-radius:8px;justify-content:center;align-items:center;width:100%;height:72px;margin-bottom:10px;display:flex;overflow:hidden}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}body.dark{--bg:#0f172a;--sidebar:#1e293b;--surface:#1e293b;--border:#334155;--text:#f1f5f9;--sub:#94a3b8;--muted:#64748b;--blue-l:#1e3a5f}body.dark .topnav,body.dark .sidebar,body.dark .stat-card,body.dark .table-wrap,body.dark .modal,.dark .detail-panel{background:var(--surface)}body.dark thead tr,body.dark tbody tr:hover{background:#0f172a}body.dark .year-badge{background:#334155}body.dark .nav-search,body.dark .toolbar-search,body.dark .htx-tabs{background:var(--bg)}body.dark .form-input{color:var(--text);background:#0f172a}body.dark .upload-zone,body.dark .file-item,body.dark .dp-doc{background:#0f172a}.doc-modal-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:600;opacity:0;pointer-events:none;background:#0a143299;justify-content:center;align-items:center;padding:16px;transition:opacity .25s;display:flex;position:fixed;inset:0}.doc-modal-overlay.open{opacity:1;pointer-events:all}.doc-modal{background:#fff;border-radius:22px;flex-direction:column;width:100%;max-width:740px;max-height:90vh;transition:transform .32s cubic-bezier(.34,1.4,.64,1);display:flex;overflow:hidden;transform:translateY(24px)scale(.97);box-shadow:0 32px 80px #0a143240,0 0 0 1px #ffffff1a}.doc-modal-overlay.open .doc-modal{transform:translateY(0)scale(1)}.dm-hero{background:linear-gradient(135deg,#0f172a 0%,#1e3a6e 60%,#1d4ed8 100%);flex-shrink:0;padding:24px 28px 20px;position:relative;overflow:hidden}.dm-hero:before{content:"";background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");position:absolute;inset:0}.dm-hero-top{justify-content:space-between;align-items:flex-start;gap:12px;display:flex;position:relative}.dm-doc-icon{background:#ffffff1f;border:1.5px solid #fff3;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:24px;display:flex}.dm-hero-info{flex:1}.dm-doc-type{color:#ffffff80;letter-spacing:2px;text-transform:uppercase;margin-bottom:4px;font-size:10px;font-weight:800}.dm-doc-name{color:#fff;letter-spacing:-.4px;font-size:20px;font-weight:900;line-height:1.2}.dm-owner{color:#ffffffa6;align-items:center;gap:6px;margin-top:5px;font-size:12.5px;display:flex}.dm-owner span{background:#ffffff1a;border-radius:20px;padding:2px 8px;font-weight:600}.dm-close{cursor:pointer;background:#ffffff14;border:1.5px solid #fff3;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:background .15s;display:flex}.dm-close:hover{background:#ffffff2e}.dm-close svg{fill:#fffc;width:16px;height:16px}.dm-status-bar{background:#ffffff12;border:1px solid #ffffff1a;border-radius:12px;align-items:center;gap:10px;margin-top:16px;padding:12px 16px;display:flex;position:relative}.dm-status-pill{border-radius:20px;align-items:center;gap:6px;padding:5px 12px;font-size:12px;font-weight:800;display:flex}.dm-status-ok{color:#166534;background:#dcfce7}.dm-status-warn{color:#92400e;background:#fef3c7}.dm-status-bad{color:#991b1b;background:#fee2e2}.dm-status-pend{color:#713f12;background:#fef9c3}.dm-countdown{text-align:right;margin-left:auto}.dm-countdown .days{color:#fff;font-family:JetBrains Mono,monospace;font-size:22px;font-weight:900;line-height:1}.dm-countdown .days.warn{color:#fde68a}.dm-countdown .days.bad{color:#fca5a5}.dm-countdown .label{color:#ffffff80;font-size:10px;font-weight:600}.dm-fine{color:#fca5a5;background:#ef444426;border:1px solid #ef44444d;border-radius:8px;padding:4px 10px;font-size:11px;font-weight:700}.dm-body,.app-wrapper{flex:1;gap:0;display:flex;overflow-y:auto}.dm-img-panel{border-right:1.5px solid var(--border);background:#fafbff;flex-direction:column;flex-shrink:0;gap:14px;width:260px;padding:20px;display:flex}.dm-img-wrap{border:2px solid var(--border);aspect-ratio:3/4;cursor:pointer;background:#f1f5f9;border-radius:12px;justify-content:center;align-items:center;transition:border-color .2s;display:flex;position:relative;overflow:hidden}.dm-img-wrap:hover{border-color:var(--blue)}.dm-img-placeholder{text-align:center;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:20px;display:flex}.dm-img-placeholder .big-icon{opacity:.4;margin-bottom:8px;font-size:48px}.dm-img-placeholder p{color:var(--muted);font-size:11px;font-weight:600}.dm-img-thumb{object-fit:cover;width:100%;height:100%}.dm-img-overlay{opacity:0;background:#2563ebb3;flex-direction:column;justify-content:center;align-items:center;gap:6px;transition:opacity .2s;display:flex;position:absolute;inset:0}.dm-img-wrap:hover .dm-img-overlay{opacity:1}.dm-img-overlay svg{fill:#fff;width:28px;height:28px}.dm-img-overlay span{color:#fff;font-size:11px;font-weight:700}.dm-upload-zone{border:2px dashed var(--border);text-align:center;cursor:pointer;background:#fff;border-radius:10px;padding:16px;transition:all .2s}.dm-upload-zone:hover,.dm-upload-zone.drag{border-color:var(--blue);background:var(--blue-l)}.dm-upload-zone p{color:var(--sub);font-size:11.5px;font-weight:600}.dm-upload-zone span{color:var(--muted);font-size:10px}.dm-upload-zone svg{width:22px;height:22px;fill:var(--muted);margin-bottom:6px}.dm-upload-zone:hover svg{fill:var(--blue)}.dm-upload-zone input{display:none}.dm-fields-panel{flex:1;padding:20px 22px;overflow-y:auto}.dm-section-lbl{color:var(--muted);letter-spacing:2px;text-transform:uppercase;align-items:center;gap:8px;margin-top:16px;margin-bottom:10px;font-size:9.5px;font-weight:900;display:flex}.dm-section-lbl:after{content:"";background:var(--border);flex:1;height:1px}.dm-section-lbl:first-child{margin-top:0}.dm-field-grid{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:4px;display:grid}.dm-field{background:var(--bg);border:1.5px solid var(--border);border-radius:10px;padding:10px 12px}.dm-field.full{grid-column:1/-1}.dm-field label{color:var(--muted);letter-spacing:.8px;text-transform:uppercase;margin-bottom:4px;font-size:9.5px;font-weight:800;display:block}.dm-field .val{color:var(--text);font-size:13px;font-weight:700}.dm-field .val.mono{color:var(--blue)}.dm-field .val.ok{color:#16a34a}.dm-field .val.warn{color:#d97706}.dm-field .val.bad{color:#dc2626}.dm-fine-box{background:#fff1f2;border:1.5px solid #fecdd3;border-radius:12px;margin-top:4px;padding:12px 14px}.dm-fine-box .fine-title{color:#991b1b;align-items:center;gap:6px;margin-bottom:8px;font-size:11px;font-weight:800;display:flex}.dm-fine-row{justify-content:space-between;align-items:center;margin-bottom:5px;display:flex}.dm-fine-row:last-child{border-top:1px solid #fecdd3;margin-bottom:0;padding-top:6px}.dm-fine-row .fine-label{color:#9f1239;font-size:11px;font-weight:600}.dm-fine-row .fine-val{color:#be123c;font-family:JetBrains Mono,monospace;font-size:12px;font-weight:800}.dm-footer{border-top:1.5px solid var(--border);background:#fff;flex-shrink:0;justify-content:space-between;align-items:center;gap:10px;padding:14px 22px;display:flex}.dm-footer-left{color:var(--muted);font-size:11.5px;font-weight:600}.dm-footer-left b{color:var(--text)}button,input,textarea,select{font-family:inherit}
