*,:before,:after,::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;line-height:1.5}body{line-height:inherit;margin:0}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder{opacity:1;color:#9ca3af}textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.stat-card{--tw-border-opacity:1;border-width:1px;border-color:rgb(243 244 246/var(--tw-border-opacity,1));--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1));--tw-shadow:0 1px 2px 0 #0000000d;--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow);border-radius:.75rem;padding:1rem;transition-property:box-shadow;transition-duration:.2s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.stat-card:hover{--tw-shadow:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.stat-value{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity,1));margin-top:.25rem;font-size:1.5rem;font-weight:700;line-height:2rem}.stat-label{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity,1));font-size:.875rem;font-weight:500;line-height:1.25rem}.page-header{margin-bottom:1.5rem}.page-title{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity,1));font-size:1.25rem;font-weight:600;line-height:1.75rem}.page-subtitle{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity,1));margin-top:.25rem;font-size:.875rem;line-height:1.25rem}.btn-primary{--tw-bg-opacity:1;background-color:rgb(2 132 199/var(--tw-bg-opacity,1));--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1));--tw-shadow:0 1px 2px 0 #0000000d;--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow);border-radius:.5rem;align-items:center;gap:.5rem;padding:.5rem 1rem;font-weight:500;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-duration:.2s;transition-timing-function:cubic-bezier(.4,0,.2,1);display:flex}.btn-primary:hover{--tw-bg-opacity:1;background-color:rgb(3 105 161/var(--tw-bg-opacity,1))}.search-input{--tw-border-opacity:1;border-width:1px;border-color:rgb(209 213 219/var(--tw-border-opacity,1));border-radius:.5rem;width:16rem;padding:.5rem 1rem;font-size:.875rem;line-height:1.25rem}.search-input:focus{outline-offset:2px;--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow,0 0 #0000);--tw-ring-opacity:1;--tw-ring-color:rgb(14 165 233/var(--tw-ring-opacity,1));border-color:#0000;outline:2px solid #0000}.table-container{--tw-border-opacity:1;border-width:1px;border-color:rgb(243 244 246/var(--tw-border-opacity,1));--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1));--tw-shadow:0 1px 2px 0 #0000000d;--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow);border-radius:.75rem;overflow:hidden}.table-wrapper{width:100%;min-height:0;max-height:65vh;display:block;overflow:auto}.contract-table,.table-wrapper table{width:max-content;min-width:1600px}.table-body{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.table-header{--tw-bg-opacity:1;background-color:rgb(240 249 255/var(--tw-bg-opacity,1));--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1));font-size:.875rem;font-weight:600;line-height:1.25rem}.sticky-col{z-index:20;background-color:#f0f4ff;position:sticky;top:0}.table-row{cursor:pointer;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.table-row:hover{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.col-contract-no{min-width:120px}.col-project-name{min-width:220px}.col-customer-name{min-width:250px}.col-tender-name{min-width:220px}.col-pm-name{min-width:200px}.col-status{min-width:140px}.col-money{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.status-badge{border-radius:9999px;align-items:center;padding:.125rem .625rem;font-size:.75rem;font-weight:500;line-height:1rem;display:inline-flex}.status-active{--tw-bg-opacity:1;background-color:rgb(220 252 231/var(--tw-bg-opacity,1));--tw-text-opacity:1;color:rgb(22 101 52/var(--tw-text-opacity,1))}.status-completed{--tw-bg-opacity:1;background-color:rgb(219 234 254/var(--tw-bg-opacity,1));--tw-text-opacity:1;color:rgb(30 64 175/var(--tw-text-opacity,1))}.status-pending{--tw-bg-opacity:1;background-color:rgb(254 249 195/var(--tw-bg-opacity,1));--tw-text-opacity:1;color:rgb(133 77 14/var(--tw-text-opacity,1))}.status-cancelled{--tw-bg-opacity:1;background-color:rgb(254 226 226/var(--tw-bg-opacity,1));--tw-text-opacity:1;color:rgb(153 27 27/var(--tw-text-opacity,1))}.pm-badge{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1));border-radius:.375rem;align-items:center;gap:.5rem;padding:.25rem .625rem;font-size:.875rem;line-height:1.25rem;display:inline-flex}.pm-avatar{--tw-bg-opacity:1;background-color:rgb(2 132 199/var(--tw-bg-opacity,1));--tw-text-opacity:1;width:1.5rem;height:1.5rem;color:rgb(255 255 255/var(--tw-text-opacity,1));border-radius:9999px;justify-content:center;align-items:center;font-size:.75rem;font-weight:500;line-height:1rem;display:flex}.btn-manage{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity,1));border-radius:.5rem;padding:.375rem;transition-property:all;transition-duration:.2s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.btn-manage:hover{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1));--tw-text-opacity:1;color:rgb(2 132 199/var(--tw-text-opacity,1))}.table-wrapper::-webkit-scrollbar{width:8px;height:8px}.table-wrapper::-webkit-scrollbar-track{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1));border-radius:.25rem}.table-wrapper::-webkit-scrollbar-thumb{--tw-bg-opacity:1;background-color:rgb(209 213 219/var(--tw-bg-opacity,1));border-radius:.25rem}.table-wrapper::-webkit-scrollbar-thumb:hover{--tw-bg-opacity:1;background-color:rgb(156 163 175/var(--tw-bg-opacity,1))}thead .sticky-col-1{z-index:50;background:#f1f5f9;width:70px;min-width:70px;position:sticky;top:0;left:0}thead .sticky-col-2{z-index:49;background:#f1f5f9;border-right:1px solid #e5e7eb;width:160px;min-width:160px;position:sticky;top:0;left:70px;box-shadow:3px 0 6px #0000000d}tbody .sticky-col-1{z-index:20;background:#fff;width:70px;min-width:70px;position:sticky;left:0}tbody .sticky-col-2{z-index:19;background:#fff;border-right:1px solid #e5e7eb;width:160px;min-width:160px;position:sticky;left:70px;box-shadow:3px 0 6px #0000000d}.visible{visibility:visible}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.right-0{right:0}.z-50{z-index:50}.mx-auto{margin-left:auto;margin-right:auto}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-1{margin-left:.25rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.table-row{display:table-row}.grid{display:grid}.hidden{display:none}.h-12{height:3rem}.h-20{height:5rem}.h-4{height:1rem}.h-5{height:1.25rem}.min-h-screen{min-height:100vh}.w-12{width:3rem}.w-20{width:5rem}.w-4{width:1rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-56{width:14rem}.w-full{width:100%}.max-w-md{max-width:28rem}.transform{transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-pointer{cursor:pointer}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.space-y-5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.25rem * var(--tw-space-y-reverse))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse:0;border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px * var(--tw-divide-y-reverse))}.divide-gray-100>:not([hidden])~:not([hidden]){--tw-divide-opacity:1;border-color:rgb(243 244 246/var(--tw-divide-opacity,1))}.divide-gray-200>:not([hidden])~:not([hidden]){--tw-divide-opacity:1;border-color:rgb(229 231 235/var(--tw-divide-opacity,1))}.whitespace-nowrap{white-space:nowrap}.rounded-3xl{border-radius:1.5rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-gray-200{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity,1))}.border-gray-300{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity,1))}.border-slate-300{--tw-border-opacity:1;border-color:rgb(203 213 225/var(--tw-border-opacity,1))}.bg-blue-600{--tw-bg-opacity:1;background-color:rgb(37 99 235/var(--tw-bg-opacity,1))}.bg-gray-100{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.bg-gray-50{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.bg-tecapro-100{--tw-bg-opacity:1;background-color:rgb(224 242 254/var(--tw-bg-opacity,1))}.bg-tecapro-50{--tw-bg-opacity:1;background-color:rgb(240 249 255/var(--tw-bg-opacity,1))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-gradient-to-br{background-image:linear-gradient(to bottom right, var(--tw-gradient-stops))}.from-slate-100{--tw-gradient-from:#f1f5f9 var(--tw-gradient-from-position);--tw-gradient-to:#f1f5f900 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.via-slate-200{--tw-gradient-to:#e2e8f000 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), #e2e8f0 var(--tw-gradient-via-position), var(--tw-gradient-to)}.to-slate-300{--tw-gradient-to:#cbd5e1 var(--tw-gradient-to-position)}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.tracking-wider{letter-spacing:.05em}.text-blue-600{--tw-text-opacity:1;color:rgb(37 99 235/var(--tw-text-opacity,1))}.text-gray-400{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity,1))}.text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity,1))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1))}.text-gray-800{--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity,1))}.text-gray-900{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity,1))}.text-green-600{--tw-text-opacity:1;color:rgb(22 163 74/var(--tw-text-opacity,1))}.text-slate-500{--tw-text-opacity:1;color:rgb(100 116 139/var(--tw-text-opacity,1))}.text-slate-600{--tw-text-opacity:1;color:rgb(71 85 105/var(--tw-text-opacity,1))}.text-slate-700{--tw-text-opacity:1;color:rgb(51 65 85/var(--tw-text-opacity,1))}.text-tecapro-600{--tw-text-opacity:1;color:rgb(2 132 199/var(--tw-text-opacity,1))}.text-tecapro-700{--tw-text-opacity:1;color:rgb(3 105 161/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.shadow-2xl{--tw-shadow:0 25px 50px -12px #00000040;--tw-shadow-colored:0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.outline-none{outline-offset:2px;outline:2px solid #0000}.outline{outline-style:solid}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-property:all;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}body{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.hover\:bg-blue-700:hover{--tw-bg-opacity:1;background-color:rgb(29 78 216/var(--tw-bg-opacity,1))}.hover\:bg-gray-100:hover{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.hover\:bg-gray-50:hover{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.hover\:text-gray-700:hover{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1))}.hover\:text-tecapro-600:hover{--tw-text-opacity:1;color:rgb(2 132 199/var(--tw-text-opacity,1))}.hover\:text-tecapro-700:hover{--tw-text-opacity:1;color:rgb(3 105 161/var(--tw-text-opacity,1))}.hover\:text-tecapro-900:hover{--tw-text-opacity:1;color:rgb(12 74 110/var(--tw-text-opacity,1))}.focus\:border-tecapro-500:focus{--tw-border-opacity:1;border-color:rgb(14 165 233/var(--tw-border-opacity,1))}.focus\:outline-none:focus{outline-offset:2px;outline:2px solid #0000}.focus\:ring-2:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow,0 0 #0000)}.focus\:ring-blue-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(59 130 246/var(--tw-ring-opacity,1))}.focus\:ring-tecapro-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(14 165 233/var(--tw-ring-opacity,1))}@media (width>=768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width>=1024px){.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.contract-documents-tab{gap:12px;height:calc(100vh - 280px);min-height:500px;display:flex}.documents-left-panel{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;flex-direction:column;flex-shrink:0;width:260px;min-width:200px;display:flex;overflow:hidden}.panel-header{background:#fff;border-bottom:1px solid #e5e7eb;flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.panel-header h3{color:#374151;text-transform:uppercase;letter-spacing:.06em;margin:0;font-size:12px;font-weight:600}.btn-icon{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;transition:all .15s;display:inline-flex}.btn-icon:hover{color:#15803d;background:#e5e7eb}.folder-tree{flex:1;padding:6px 0;overflow-y:auto}.folder-tree-empty{text-align:center;color:#9ca3af;padding:24px 16px;font-size:13px}.folder-tree-item{-webkit-user-select:none;user-select:none}.folder-node{cursor:pointer;border-radius:6px;align-items:center;gap:3px;min-width:0;margin:1px 6px;padding:5px 6px 5px 0;transition:background .12s;display:flex;position:relative}.folder-node:hover{background:#16653412}.folder-node.selected{background:#1665341f}.folder-actions{flex-shrink:0;align-items:center;gap:1px;margin-left:auto;padding-right:2px;display:none}.folder-node:hover .folder-actions,.folder-node.selected .folder-actions{display:flex}.folder-action-btn{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:20px;height:20px;padding:0;transition:all .12s;display:inline-flex}.folder-action-btn:hover{color:#374151;background:#e5e7eb}.folder-action-btn.folder-action-delete:hover{color:#dc2626;background:#fee2e2}.expand-btn{color:#d1d5db;cursor:pointer;background:0 0;border:none;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;padding:0;transition:transform .15s;display:flex}.expand-btn.visible{color:#9ca3af}.expand-btn.expanded{transform:rotate(90deg)}.expand-btn:disabled{visibility:hidden}.folder-icon{color:#fbbf24;flex-shrink:0}.folder-name{color:#374151;white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:13px;overflow:hidden}.folder-children{margin-left:0}.documents-right-panel{flex-direction:column;flex:1;gap:10px;min-width:0;display:flex;overflow:hidden}.documents-main-content{background:#fff;border:1px solid #e5e7eb;border-radius:10px;flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.documents-toolbar{background:#f9fafb;border-bottom:1px solid #e5e7eb;flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.toolbar-left,.toolbar-right{gap:6px;display:flex}.btn-toolbar{color:#374151;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #d1d5db;border-radius:7px;align-items:center;gap:5px;padding:7px 13px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.btn-toolbar:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.btn-toolbar:disabled{opacity:.4;cursor:not-allowed}.btn-toolbar.btn-upload{color:#fff;background:#15803d;border-color:#15803d}.btn-toolbar.btn-upload:hover:not(:disabled){background:#166534;border-color:#166534}.btn-toolbar.btn-delete:hover:not(:disabled){color:#dc2626;background:#fef2f2;border-color:#ef4444}.documents-breadcrumb{background:#fff;border-bottom:1px solid #f3f4f6;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:2px;min-height:34px;padding:7px 16px;font-size:13px;display:flex}.breadcrumb-home{color:#9ca3af;cursor:pointer;border-radius:4px;align-items:center;padding:2px 5px;transition:color .12s;display:inline-flex}.breadcrumb-home:hover{color:#15803d}.breadcrumb-segment{align-items:center;gap:2px;display:inline-flex}.breadcrumb-sep{color:#d1d5db;padding:0 2px}.breadcrumb-item{color:#6b7280;cursor:pointer;text-overflow:ellipsis;white-space:nowrap;border-radius:4px;max-width:180px;padding:2px 5px;transition:all .12s;overflow:hidden}.breadcrumb-item:hover{color:#15803d;background:#15803d0f}.breadcrumb-item.active{color:#111827;cursor:default;font-weight:500}.breadcrumb-item.active:hover{color:#111827;background:0 0}.upload-queue{border-bottom:1px solid #f3f4f6;flex-shrink:0;max-height:110px;overflow-y:auto}.upload-queue-item{color:#374151;border-bottom:1px solid #f9fafb;align-items:center;gap:8px;padding:5px 16px;font-size:12px;display:flex}.upload-queue-item:last-child{border-bottom:none}.upload-queue-item--pending{color:#9ca3af}.upload-queue-item--uploading{color:#2563eb;background:#eff6ff}.upload-queue-item--done{color:#15803d}.upload-queue-item--error{color:#dc2626;background:#fef2f2}.upload-queue-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.upload-queue-status{flex-shrink:0;font-weight:500}.documents-table-container{flex:1;min-height:0;position:relative;overflow:auto}.documents-table-container.drag-over{outline-offset:-2px;background:#15803d05;outline:2px dashed #15803d}.drop-overlay{color:#15803d;z-index:10;pointer-events:none;background:#15803d12;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:15px;font-weight:500;display:flex;position:absolute;inset:0}.no-folder-selected{color:#d1d5db;flex-direction:column;justify-content:center;align-items:center;gap:12px;height:100%;display:flex}.no-folder-selected p{color:#9ca3af;margin:0;font-size:14px}.documents-table{border-collapse:collapse;width:100%}.documents-table th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;z-index:1;background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:9px 14px;font-size:11px;font-weight:600;position:sticky;top:0}.documents-table td{color:#374151;border-bottom:1px solid #f3f4f6;padding:9px 14px;font-size:13px}.documents-table tbody tr{cursor:pointer;transition:background .1s}.documents-table tbody tr:last-child td{border-bottom:none}.documents-table tbody tr:hover{background:#f9fafb}.documents-table tbody tr.selected{background:#16653412}.documents-table tbody tr.previewing{background:#1665341c;font-weight:500}.col-select{width:38px}.col-select input[type=checkbox]{cursor:pointer;width:15px;height:15px}.col-name{min-width:200px}.col-size{color:#6b7280;width:100px;font-size:12px}.col-date{color:#6b7280;width:150px;font-size:12px}.col-uploader{color:#6b7280;width:130px;font-size:12px}.file-info{align-items:center;gap:8px;display:flex}.file-icon{flex-shrink:0;font-size:16px}.file-name-text{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.empty-message{text-align:center;font-size:14px;color:#9ca3af!important;padding:48px 16px!important}.documents-preview-panel{background:#fff;border:1px solid #e5e7eb;border-radius:10px;flex-direction:column;flex:0 0 300px;display:flex;overflow:hidden}.preview-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:9px 14px;display:flex}.preview-title-area{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.preview-title{color:#374151;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.preview-header-actions{flex-shrink:0;align-items:center;gap:5px;display:flex}.preview-content{background:#f8f9fa;flex:1;justify-content:center;align-items:center;display:flex;overflow:hidden}.pdf-preview{border:none;width:100%;height:100%}.image-preview{-o-object-fit:contain;object-fit:contain;max-width:100%;max-height:100%}.modal-content{background:#fff;border-radius:12px;min-width:400px;max-width:90%;padding:24px;box-shadow:0 20px 40px #00000029}.modal-content h3{color:#1f2937;margin:0 0 20px;font-size:17px;font-weight:600}.confirm-message{color:#4b5563;margin:0 0 24px;font-size:14px;line-height:1.65}.form-group{margin-bottom:16px}.form-group label{color:#374151;margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-group input,.form-group select{box-sizing:border-box;background:#fff;border:1px solid #d1d5db;border-radius:7px;width:100%;padding:9px 12px;font-family:inherit;font-size:14px;transition:border-color .15s,box-shadow .15s}.form-group input:focus,.form-group select:focus{border-color:#15803d;outline:none;box-shadow:0 0 0 3px #15803d1a}.modal-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.btn-confirm:hover{background:#166534}.btn-confirm.btn-danger{background:#dc2626}.btn-confirm.btn-danger:hover{background:#b91c1c}.documents-loading{color:#6b7280;justify-content:center;align-items:center;height:300px;font-size:15px;display:flex}.boq-tab{flex-direction:column;height:100%;display:flex;overflow:hidden}.boq-loading{color:#9ca3af;justify-content:center;align-items:center;height:200px;font-size:14px;display:flex}.boq-toolbar{background:#f9fafb;border-bottom:1px solid #e5e7eb;flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:10px 16px;display:flex}.boq-toolbar-left{align-items:center;gap:8px;display:flex}.boq-toolbar-right{align-items:center;display:flex}.boq-btn{color:#374151;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #d1d5db;border-radius:7px;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.boq-btn:hover{background:#f3f4f6;border-color:#9ca3af}.boq-btn.boq-btn-green{color:#fff;background:#15803d;border-color:#15803d}.boq-btn.boq-btn-green:hover{background:#166534}.boq-summary{color:#4b5563;align-items:center;gap:8px;font-size:13px;display:flex}.boq-summary strong{color:#111827;font-variant-numeric:tabular-nums}.boq-summary-count{color:#374151;font-weight:600}.boq-summary-sep{color:#d1d5db}.boq-table-wrapper{background:#fff;flex:1;overflow:auto}.boq-table{border-collapse:collapse;width:100%;min-width:1080px;font-size:13px}.boq-table thead th{text-align:center;color:#475569;text-transform:uppercase;letter-spacing:.05em;z-index:2;white-space:nowrap;background:#f1f5f9;border-bottom:2px solid #e2e8f0;padding:9px 8px;font-size:11px;font-weight:700;line-height:1.4;position:sticky;top:0}.boq-table tfoot td{background:#f8fafc;border-top:2px solid #e2e8f0;padding:10px 8px;font-size:13px}.boq-table tbody td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:3px 5px}.boq-table tbody tr:last-child td{border-bottom:none}.boq-table tbody tr{transition:background .1s}.boq-table tbody tr:hover{background:#f8fafc}.boq-table tbody tr.row-dirty{background:#fffbeb}.boq-table tbody tr.row-new{background:#f0fdf4}.boq-table tbody tr.row-saving{opacity:.6;pointer-events:none}.th-stt{width:44px}.th-name{min-width:220px;text-align:left!important}.th-hs{width:96px}.th-unit{width:64px}.th-amt{width:130px}.th-vat{width:68px}.th-warranty{width:110px}.stt-num{display:inline-block}.td-amt{text-align:right;font-variant-numeric:tabular-nums;padding-right:10px!important}.td-amt.computed{color:#1e40af;font-weight:500}.td-vat{text-align:center}.boq-table td input{box-sizing:border-box;color:#1f2937;background:0 0;border:1px solid #0000;border-radius:5px;width:100%;padding:5px 7px;font-family:inherit;font-size:13px;transition:border-color .12s,background .12s,box-shadow .12s}.boq-table td input:hover{background:#fff;border-color:#cbd5e1}.boq-table td input:focus{background:#fff;border-color:#16a34a;outline:none;box-shadow:0 0 0 2px #16a34a26}.boq-table td input[type=number]{text-align:right}.preview-text{color:#374151;padding:4px 7px;font-size:12px;display:block}.totals-row .td-amt{color:#0f172a;font-size:14px;font-weight:700}.boq-empty{text-align:center;color:#9ca3af;padding:56px 16px;font-size:14px;line-height:2}.boq-empty strong{color:#4b5563}.act{cursor:pointer;color:#9ca3af;background:0 0;border:none;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;padding:0;font-size:12px;transition:all .12s;display:inline-flex}.act.insert{color:#2563eb;background:#dbeafe}.act.insert:hover:not(:disabled){background:#bfdbfe}@keyframes spin{to{transform:rotate(360deg)}}.boq-import-modal{background:#fff;border-radius:12px;flex-direction:column;width:92vw;max-width:1160px;max-height:88vh;display:flex;overflow:hidden;box-shadow:0 24px 64px #0003}.boq-import-header{border-bottom:1px solid #e5e7eb;flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:16px 20px 14px;display:flex}.boq-import-header h3{color:#111827;margin:0 0 3px;font-size:16px;font-weight:700}.boq-import-count{color:#6b7280;margin:0;font-size:13px}.boq-import-mode{color:#374151;border-bottom:1px solid #f3f4f6;flex-shrink:0;gap:24px;padding:10px 20px;font-size:13px;display:flex}.boq-import-mode label{cursor:pointer;align-items:center;gap:7px;display:flex}.boq-import-mode input[type=radio]{accent-color:#15803d;cursor:pointer}.replace-warn{color:#dc2626}.boq-import-hint{color:#3b82f6;background:#eff6ff;border-bottom:1px solid #dbeafe;flex-shrink:0;align-items:flex-start;gap:6px;padding:8px 20px;font-size:12px;line-height:1.5;display:flex}.boq-import-preview{flex:1;overflow:auto}.boq-import-footer{border-top:1px solid #e5e7eb;flex-shrink:0;justify-content:flex-end;gap:8px;padding:12px 20px;display:flex}.btn-cancel{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:7px;padding:8px 18px;font-size:14px;font-weight:500;transition:all .15s}.btn-cancel:hover{background:#f3f4f6}.btn-confirm{color:#fff;cursor:pointer;background:#15803d;border:none;border-radius:7px;padding:8px 20px;font-size:14px;font-weight:600;transition:all .15s}.btn-confirm:hover:not(:disabled){background:#166534}.btn-confirm:disabled{opacity:.5;cursor:not-allowed}.btn-close-preview{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;transition:all .15s;display:inline-flex}.prog-tab{flex-direction:column;height:100%;display:flex;overflow:hidden}.prog-loading{color:#9ca3af;justify-content:center;align-items:center;height:200px;font-size:14px;display:flex}.prog-toolbar{background:#f9fafb;border-bottom:1px solid #e5e7eb;flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:10px;padding:10px 16px;display:flex}.prog-toolbar-left{gap:8px;display:flex}.prog-btn{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:7px;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.prog-btn:hover{background:#f3f4f6;border-color:#9ca3af}.prog-btn.prog-btn-primary{color:#fff;background:#15803d;border-color:#15803d}.prog-btn.prog-btn-primary:hover{background:#166534}.prog-stats{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.stat-chip{border-radius:20px;align-items:center;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.stat-total{color:#475569;background:#f1f5f9}.stat-done{color:#15803d;background:#dcfce7}.stat-late{color:#dc2626;background:#fee2e2}.prog-table-wrapper{background:#fff;flex:1;overflow:auto}.prog-table{border-collapse:collapse;width:100%;min-width:900px;font-size:13px}.prog-table thead th{text-align:left;color:#475569;text-transform:uppercase;letter-spacing:.05em;z-index:2;white-space:nowrap;background:#f1f5f9;border-bottom:2px solid #e2e8f0;padding:9px 10px;font-size:11px;font-weight:700;position:sticky;top:0}.prog-table tbody td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:4px 6px}.prog-table tbody tr:last-child td{border-bottom:none}.th-type{min-width:200px}.th-date,.th-status{width:140px}.th-penalty{width:160px}.th-action{width:72px}.prog-table tbody tr{transition:background .1s}.prog-table tbody tr:hover{filter:brightness(.97)}.prog-table tbody tr.status-pending{background:#fafafa}.prog-table tbody tr.status-overdue{background:#fff7ed}.prog-table tbody tr.status-ok{background:#f0fdf4}.prog-table tbody tr.status-late{background:#fff1f2}.prog-table tbody tr.status-unknown{background:#fff}.prog-table tbody tr.row-dirty{outline-offset:-1px;outline:1px solid #fbbf24}.prog-table tbody tr.row-new{background:#f0fdf4!important}.prog-table tbody tr.row-saving{opacity:.55;pointer-events:none}.prog-table td select,.prog-table td input[type=text],.prog-table td input[type=date]{color:#1f2937;box-sizing:border-box;background:0 0;border:1px solid #0000;border-radius:5px;width:100%;padding:5px 8px;font-family:inherit;font-size:13px;transition:border-color .12s,background .12s,box-shadow .12s}.prog-table td select:hover,.prog-table td input:hover{background:#fff;border-color:#cbd5e1}.prog-table td select:focus,.prog-table td input:focus{background:#fff;border-color:#16a34a;outline:none;box-shadow:0 0 0 2px #16a34a26}.status-badge{white-space:nowrap;border-radius:20px;align-items:center;padding:3px 9px;font-size:12px;font-weight:600;display:inline-flex}.badge-ok{color:#15803d;background:#dcfce7}.badge-late{color:#dc2626;background:#fee2e2}.badge-overdue{color:#c2410c;background:#ffedd5}.badge-pending{color:#64748b;background:#f1f5f9}.badge-done{color:#1d4ed8;background:#dbeafe}.badge-unknown{color:#9ca3af;background:#f1f5f9}.prog-empty{text-align:center;color:#9ca3af;padding:56px 16px;font-size:14px;line-height:2}.prog-empty strong{color:#4b5563}.bbmgr-modal{background:#fff;border-radius:12px;flex-direction:column;width:560px;max-width:95vw;max-height:80vh;display:flex;overflow:hidden;box-shadow:0 20px 60px #0000002e}.bbmgr-header{border-bottom:1px solid #e5e7eb;flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.bbmgr-header h3{color:#111827;margin:0;font-size:16px;font-weight:700}.bbmgr-body{flex:1;padding:12px 16px 16px;overflow:auto}.bbmgr-table{border-collapse:collapse;width:100%;font-size:13px}.bbmgr-table th{text-align:left;color:#64748b;text-transform:uppercase;letter-spacing:.05em;background:#f8fafc;border-bottom:1px solid #e5e7eb;padding:8px 10px;font-size:11px;font-weight:700}.bbmgr-table td{vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:6px 8px}.bbmgr-table tr:last-child td{border-bottom:none}.bbmgr-table tbody tr:hover td{background:#f9fafb}.bbmgr-add-row td{background:#f0fdf4}.bbmgr-input{border:1px solid #d1d5db;border-radius:5px;width:70px;padding:5px 8px;font-family:inherit;font-size:13px;transition:border-color .12s}.bbmgr-input:focus{border-color:#15803d;outline:none;box-shadow:0 0 0 2px #15803d1f}.bbmgr-input-wide{box-sizing:border-box;width:100%}.bbmgr-actions{align-items:center;gap:4px;display:flex}.bbmgr-btn{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:5px;justify-content:center;align-items:center;gap:4px;min-width:28px;height:28px;padding:4px 8px;font-size:12px;font-weight:500;transition:all .12s;display:inline-flex}.bbmgr-btn:hover{background:#f3f4f6}.bbmgr-btn:disabled{opacity:.45;cursor:not-allowed}.bbmgr-btn-save{color:#fff;background:#15803d;border-color:#15803d}.bbmgr-btn-save:hover{background:#166534}.bbmgr-btn-del:hover{color:#dc2626;background:#fee2e2;border-color:#ef4444}.btn-close-preview{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;transition:all .15s;display:inline-flex}.btn-close-preview:hover{color:#374151;background:#f3f4f6}.recv-tab{flex-direction:column;gap:0;height:100%;display:flex;overflow-y:auto}.recv-loading{color:#9ca3af;justify-content:center;align-items:center;height:200px;font-size:14px;display:flex}.recv-summary{background:#f8fafc;border-bottom:1px solid #e2e8f0;flex-wrap:wrap;flex-shrink:0;align-items:stretch;gap:12px;padding:14px 16px;display:flex}.recv-card{border:1px solid #0000;border-radius:10px;flex:1;min-width:160px;padding:12px 16px}.recv-card--blue{background:#eff6ff;border-color:#bfdbfe}.recv-card--green{background:#f0fdf4;border-color:#bbf7d0}.recv-card--orange{background:#fff7ed;border-color:#fed7aa}.recv-card--highlight{box-shadow:0 0 0 2px #f97316}.recv-card-label{text-transform:uppercase;letter-spacing:.05em;color:#64748b;margin-bottom:4px;font-size:11px;font-weight:600}.recv-card-value{color:#0f172a;font-variant-numeric:tabular-nums;font-size:20px;font-weight:700}.recv-card-unit{color:#64748b;font-size:13px;font-weight:500}.recv-card-sub{color:#94a3b8;margin-top:2px;font-size:12px}.recv-card--orange .recv-card-value{color:#c2410c}.recv-card--green .recv-card-value{color:#15803d}.recv-card--blue .recv-card-value{color:#1d4ed8}.recv-progress-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;flex-direction:column;flex:1.5;justify-content:center;gap:8px;min-width:200px;padding:12px 16px;display:flex}.recv-progress-label{color:#64748b;justify-content:space-between;align-items:center;font-size:12px;display:flex}.recv-progress-label strong{color:#0f172a;font-size:18px;font-weight:700}.recv-progress-bar{background:#f1f5f9;border-radius:5px;height:10px;overflow:hidden}.recv-progress-fill{border-radius:5px;height:100%;transition:width .4s}.recv-section{border-bottom:1px solid #e2e8f0;flex-direction:column;flex-shrink:0;display:flex}.recv-section-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.recv-section-title{color:#374151;text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:13px;font-weight:700}.recv-btn{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:6px;align-items:center;gap:5px;padding:6px 12px;font-size:12px;font-weight:500;transition:all .15s;display:inline-flex}.recv-btn:hover{background:#f3f4f6;border-color:#9ca3af}.recv-btn.recv-btn-primary{color:#fff;background:#15803d;border-color:#15803d}.recv-btn.recv-btn-primary:hover{background:#166534}.recv-table-wrapper{overflow-x:auto}.recv-table{border-collapse:collapse;width:100%;min-width:860px;font-size:13px}.recv-table thead th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;background:#f9fafb;border-bottom:2px solid #e5e7eb;padding:8px;font-size:11px;font-weight:700}.recv-table tbody td{vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:3px 5px}.recv-table tbody tr:last-child td{border-bottom:none}.recv-table tbody tr{transition:background .1s}.recv-table tbody tr:hover{background:#f9fafb}.recv-table tbody tr.row-overdue{background:#fff7ed}.recv-table tbody tr.row-dirty{outline-offset:-1px;outline:1px solid #fbbf24}.recv-table tbody tr.row-new{background:#f0fdf4!important}.recv-table tbody tr.row-saving{opacity:.55;pointer-events:none}.th-stt{width:40px;text-align:center!important}.th-desc{min-width:200px}.th-cur{width:80px}.th-num{width:120px}.th-rate{width:100px}.th-vnd,.th-date{width:140px}.th-reason{min-width:160px}.th-ratio{width:90px}.th-ratio2{width:90px;text-align:center!important}.th-note{min-width:140px}.th-act{width:68px}.td-stt{text-align:center;color:#9ca3af;-webkit-user-select:none;user-select:none;font-size:12px;position:relative}.td-vnd{text-align:right;font-variant-numeric:tabular-nums;padding-right:10px!important}.td-vnd.computed{color:#1d4ed8;font-weight:600}.td-ratio{text-align:center}.recv-table td input[type=text],.recv-table td input[type=number],.recv-table td input[type=date],.recv-table td select{color:#1f2937;box-sizing:border-box;background:0 0;border:1px solid #0000;border-radius:5px;width:100%;padding:5px 7px;font-family:inherit;font-size:13px;transition:border-color .12s,background .12s}.recv-table td input:hover,.recv-table td select:hover{background:#fff;border-color:#d1d5db}.recv-table td input:focus,.recv-table td select:focus{background:#fff;border-color:#15803d;outline:none;box-shadow:0 0 0 2px #15803d1f}.recv-table td input[type=number]{text-align:right}.recv-table td input:disabled{color:#9ca3af;cursor:not-allowed;background:0 0}.input-warn{background:#fff7ed!important;border-color:#f97316!important}.input-warn::placeholder{color:#ea580c}.overdue-tag{color:#c2410c;text-align:center;margin-top:2px;font-size:10px;font-weight:600;display:block}.ratio-cell{align-items:center;gap:2px;display:flex}.ratio-cell input{flex:1}.ratio-pct{color:#6b7280;flex-shrink:0;font-size:12px}.dirty-dot{background:#f59e0b;border-radius:50%;width:6px;height:6px;display:inline-block;position:absolute;top:50%;left:5px;transform:translateY(-50%)}.totals-row{background:#f8fafc}.totals-row td{border-top:2px solid #e5e7eb;border-bottom:none;padding:9px 8px}.totals-row .totals-label{text-align:right;color:#475569;letter-spacing:.06em;text-transform:uppercase;font-size:11px;font-weight:700}.totals-row .td-vnd{color:#0f172a;font-size:14px;font-weight:700}.recv-ref-banner{color:#1d4ed8;background:#eff6ff;border-bottom:1px solid #bfdbfe;flex-shrink:0;align-items:flex-start;gap:8px;padding:9px 16px;font-size:13px;line-height:1.5;display:flex}.recv-ref-banner svg{flex-shrink:0;margin-top:2px}.recv-ref-banner strong{color:#1e3a8a}.recv-ref-sub{color:#6b7280;font-size:12px}.recv-ref-warn{color:#dc2626;font-weight:600}.td-ratio2{text-align:center}.recv-empty{text-align:center;color:#9ca3af;padding:36px 16px;font-size:13px;line-height:2}.recv-empty strong{color:#4b5563}.action-group{justify-content:center;align-items:center;gap:3px;display:flex}.act{cursor:pointer;color:#9ca3af;background:0 0;border:none;border-radius:5px;justify-content:center;align-items:center;width:26px;height:26px;padding:0;transition:all .12s;display:inline-flex}.act:disabled{opacity:.3;cursor:not-allowed}.act.save:hover:not(:disabled){background:#bbf7d0}.act.delete:hover:not(:disabled){color:#dc2626;background:#fee2e2}.spin{font-size:14px;animation:.8s linear infinite spin;display:inline-block}.guar-tab{flex-direction:column;gap:20px;padding:24px;display:flex}.guar-summary{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;display:grid}.guar-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;flex-direction:column;gap:4px;padding:16px 20px;display:flex}.guar-card--blue{border-left:4px solid #3b82f6}.guar-card--green{border-left:4px solid #16a34a}.guar-card--red{border-left:4px solid #dc2626}.guar-card--orange{border-left:4px solid #f59e0b}.guar-card-label{color:#6b7280;font-size:12px;font-weight:500}.guar-card-value{color:#111827;font-size:22px;font-weight:700}.guar-card-sub{color:#9ca3af;font-size:12px}.guar-section{background:#fff;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.guar-section-header{background:#f9fafb;border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.guar-section-title{color:#374151;margin:0;font-size:14px;font-weight:600}.guar-btn{cursor:pointer;border:none;border-radius:6px;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:500;transition:background .15s;display:inline-flex}.guar-btn-primary{color:#fff;background:#16a34a}.guar-btn-primary:hover{background:#15803d}.guar-table-wrapper{overflow-x:auto}.guar-table{border-collapse:collapse;width:100%;font-size:13px}.guar-table thead{background:#f9fafb}.guar-table th{text-align:left;color:#374151;white-space:nowrap;border-bottom:1px solid #e5e7eb;padding:10px 12px;font-weight:600}.guar-table td{vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:8px 12px}.guar-table tbody tr:last-child td{border-bottom:none}.guar-table tbody tr:hover{background:#fafafa}.guar-table th.th-stt,.guar-table td.td-stt{text-align:center;color:#9ca3af;width:40px;font-size:12px}.guar-table th.th-type{min-width:180px}.guar-table th.th-amount{min-width:160px}.guar-table th.th-date{min-width:130px}.guar-table th.th-status{min-width:140px}.guar-table th.th-note{min-width:160px}.guar-table th.th-act{width:64px}.guar-table input[type=text],.guar-table input[type=number],.guar-table input[type=date],.guar-table select{box-sizing:border-box;background:0 0;border:1px solid #0000;border-radius:5px;outline:none;width:100%;padding:5px 8px;font-size:13px}.guar-table input:hover,.guar-table select:hover{background:#fff;border-color:#d1d5db}.guar-table input:focus,.guar-table select:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f626}.row-dirty{background:#fffbeb!important}.row-new{background:#f0fdf4!important}.row-saving{opacity:.6;pointer-events:none}.row-expiring{background:#fff7ed!important}.row-expired{background:#fef2f2!important}.dirty-dot{vertical-align:middle;background:#f59e0b;border-radius:50%;width:6px;height:6px;margin-right:4px;display:inline-block}.guar-table tfoot td{background:#f9fafb;border-top:2px solid #e5e7eb;padding:10px 12px;font-size:13px;font-weight:600}.totals-label{text-align:right;color:#374151}.status-pill{white-space:nowrap;border-radius:99px;padding:2px 10px;font-size:11px;font-weight:600;display:inline-block}.status-pill--active{color:#15803d;background:#dcfce7}.status-pill--expiring{color:#a16207;background:#fef9c3}.status-pill--expired{color:#b91c1c;background:#fee2e2}.status-pill--returned{color:#6b7280;background:#f3f4f6}.expiry-warn{color:#f59e0b;margin-top:2px;font-size:11px;display:block}.expiry-error{color:#dc2626;margin-top:2px;font-size:11px;display:block}.action-group{justify-content:center;gap:4px;display:flex}.act{cursor:pointer;border:none;border-radius:5px;justify-content:center;align-items:center;width:28px;height:28px;padding:0;transition:background .15s;display:inline-flex}.act.save{color:#1d4ed8;background:#dbeafe}.act.save:hover{background:#bfdbfe}.act.delete{color:#b91c1c;background:#fee2e2}.act.delete:hover{background:#fecaca}.spin{animation:.8s linear infinite spin;display:inline-block}.guar-empty{text-align:center;color:#9ca3af;padding:32px;font-size:13px}.guar-loading{text-align:center;color:#9ca3af;padding:40px}.task-tab{flex-direction:column;gap:20px;padding:24px;display:flex}.task-summary{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;display:grid}.task-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;flex-direction:column;gap:4px;padding:14px 18px;display:flex}.task-card--total{border-left:4px solid #6366f1}.task-card--waiting{border-left:4px solid #9ca3af}.task-card--doing{border-left:4px solid #3b82f6}.task-card--done{border-left:4px solid #16a34a}.task-card--overdue{border-left:4px solid #dc2626}.task-card-label{color:#6b7280;text-transform:uppercase;letter-spacing:.4px;font-size:11px;font-weight:500}.task-card-value{color:#111827;font-size:26px;font-weight:700;line-height:1.1}.task-card-sub{color:#9ca3af;font-size:11px}.task-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.task-filters{flex-wrap:wrap;gap:6px;display:flex}.task-filter-btn{color:#6b7280;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:99px;padding:5px 14px;font-size:12px;font-weight:500;transition:all .15s}.task-filter-btn:hover{color:#3b82f6;border-color:#3b82f6}.task-filter-btn.active{color:#fff;background:#3b82f6;border-color:#3b82f6}.task-filter-btn.filter-overdue.active{background:#dc2626;border-color:#dc2626}.task-add-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#16a34a;border:none;border-radius:7px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:background .15s;display:inline-flex}.task-add-btn:hover{background:#15803d}.task-dept-group{background:#fff;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.task-dept-header{cursor:pointer;-webkit-user-select:none;user-select:none;background:#f9fafb;border-bottom:1px solid #e5e7eb;align-items:center;gap:12px;padding:12px 18px;display:flex}.task-dept-header:hover{background:#f3f4f6}.task-dept-toggle{color:#9ca3af;font-size:11px;transition:transform .2s}.task-dept-toggle.open{transform:rotate(90deg)}.task-dept-name{color:#374151;flex:1;font-size:13px;font-weight:700}.task-dept-name span{color:#9ca3af;margin-left:6px;font-size:12px;font-weight:400}.task-dept-progress{align-items:center;gap:8px;min-width:160px;display:flex}.task-dept-progress-bar{background:#e5e7eb;border-radius:99px;flex:1;height:6px;overflow:hidden}.task-dept-progress-fill{border-radius:99px;height:100%;transition:width .3s}.task-dept-progress-pct{color:#6b7280;text-align:right;min-width:32px;font-size:11px;font-weight:600}.task-dept-badges{gap:4px;display:flex}.dept-badge{border-radius:99px;padding:1px 8px;font-size:11px;font-weight:600}.dept-badge--doing{color:#1d4ed8;background:#dbeafe}.dept-badge--overdue{color:#b91c1c;background:#fee2e2}.task-table-wrapper{overflow-x:auto}.task-table{border-collapse:collapse;width:100%;font-size:13px}.task-table thead{background:#f9fafb}.task-table th{text-align:left;color:#4b5563;white-space:nowrap;border-bottom:1px solid #e5e7eb;padding:9px 14px;font-size:12px;font-weight:600}.task-table td{vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:10px 14px}.task-table tbody tr:last-child td{border-bottom:none}.task-table tbody tr{transition:background .1s}.task-table tbody tr:hover{background:#fafafa}.task-row--overdue{background:#fff5f5!important}.task-row--warning{background:#fffbeb!important}.task-row--done{opacity:.65}.task-title-cell{flex-direction:column;gap:2px;max-width:300px;display:flex}.task-title{color:#111827;font-weight:600;line-height:1.3}.task-desc-preview{color:#9ca3af;white-space:nowrap;text-overflow:ellipsis;max-width:280px;font-size:11px;overflow:hidden}.due-date-cell{flex-direction:column;gap:2px;display:flex}.due-date-text{color:#374151;font-size:13px}.due-date-warn{color:#d97706;font-size:11px;font-weight:600}.due-date-error{color:#dc2626;font-size:11px;font-weight:600}.priority-badge{white-space:nowrap;border-radius:99px;padding:2px 9px;font-size:11px;font-weight:600;display:inline-block}.status-badge-task{white-space:nowrap;cursor:default;border-radius:99px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.status--waiting{color:#6b7280;background:#f3f4f6}.status--doing{color:#1d4ed8;background:#dbeafe}.status--done{color:#15803d;background:#dcfce7}.status--cancel{color:#9d174d;background:#fce7f3}.assignee-cell{align-items:center;gap:6px;display:flex}.assignee-avatar{color:#1d4ed8;background:#dbeafe;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:11px;font-weight:700;display:flex}.assignee-name{color:#374151;font-size:13px}.assignee-empty{color:#d1d5db;font-size:12px;font-style:italic}.task-actions{gap:5px;display:flex}.task-act-btn{cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;width:29px;height:29px;padding:0;transition:background .15s;display:inline-flex}.task-act-btn.edit{color:#2563eb;background:#eff6ff}.task-act-btn.edit:hover{background:#dbeafe}.task-act-btn.delete{color:#dc2626;background:#fff5f5}.task-act-btn.delete:hover{background:#fee2e2}.task-modal-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.task-modal{background:#fff;border-radius:12px;flex-direction:column;width:620px;max-width:100%;max-height:90vh;display:flex;box-shadow:0 20px 60px #0003}.task-modal-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:18px 24px 14px;display:flex}.task-modal-header h3{color:#111827;margin:0;font-size:16px;font-weight:700}.task-modal-close{cursor:pointer;color:#6b7280;background:#f3f4f6;border:none;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;font-size:16px;transition:background .15s;display:flex}.task-modal-close:hover{background:#e5e7eb}.task-modal-body{flex-direction:column;gap:16px;padding:20px 24px;display:flex;overflow-y:auto}.task-modal-footer{border-top:1px solid #e5e7eb;justify-content:flex-end;gap:10px;padding:14px 24px;display:flex}.task-form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.task-form-group{flex-direction:column;gap:5px;display:flex}.task-form-group.full{grid-column:1/-1}.task-form-group label{color:#374151;font-size:12px;font-weight:600}.task-form-group input,.task-form-group select,.task-form-group textarea{color:#111827;background:#fff;border:1px solid #d1d5db;border-radius:7px;outline:none;padding:8px 12px;font-size:13px;transition:border-color .15s,box-shadow .15s}.task-form-group input:focus,.task-form-group select:focus,.task-form-group textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61f}.task-form-group textarea{resize:vertical;min-height:72px}.task-form-group input.has-error{border-color:#dc2626}.task-form-error{color:#dc2626;font-size:11px}.task-modal-btn{cursor:pointer;border:none;border-radius:7px;padding:8px 20px;font-size:13px;font-weight:600;transition:background .15s}.task-modal-btn.cancel{color:#374151;background:#f3f4f6}.task-modal-btn.cancel:hover{background:#e5e7eb}.task-modal-btn.save{color:#fff;background:#16a34a}.task-modal-btn.save:hover{background:#15803d}.task-modal-btn:disabled{opacity:.5;cursor:not-allowed}.status-radio-group{flex-wrap:wrap;gap:8px;display:flex}.status-radio-opt{cursor:pointer;color:#6b7280;background:#fff;border:2px solid #e5e7eb;border-radius:99px;padding:5px 14px;font-size:12px;font-weight:600;transition:all .15s}.status-radio-opt.selected-waiting{color:#374151;background:#f3f4f6;border-color:#9ca3af}.status-radio-opt.selected-doing{color:#1d4ed8;background:#dbeafe;border-color:#3b82f6}.status-radio-opt.selected-done{color:#15803d;background:#dcfce7;border-color:#16a34a}.status-radio-opt.selected-cancel{color:#9d174d;background:#fce7f3;border-color:#db2777}.task-empty{text-align:center;color:#9ca3af;padding:40px;font-size:13px}.task-loading{text-align:center;color:#9ca3af;padding:48px}.task-nodept .task-dept-header{background:#fafafa}.assign-hint{color:#9ca3af;margin-top:3px;font-size:11px}.wty-tab{flex-direction:column;height:100%;display:flex}.wty-body{flex-direction:column;flex:1;gap:18px;padding:20px 24px;display:flex;overflow-y:auto}.wty-subtab-bar{background:#fff;border-bottom:2px solid #e5e7eb;gap:0;padding:0 24px;display:flex}.wty-subtab-btn{color:#6b7280;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:12px 20px;font-size:13px;font-weight:500;transition:color .15s,border-color .15s}.wty-subtab-btn:hover{color:#374151}.wty-subtab-btn.active{color:#16a34a;border-bottom-color:#16a34a;font-weight:700}.wty-summary{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;display:grid}.wty-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;flex-direction:column;gap:3px;padding:14px 16px;display:flex}.wty-card--blue{border-left:4px solid #3b82f6}.wty-card--green{border-left:4px solid #16a34a}.wty-card--orange{border-left:4px solid #f59e0b}.wty-card--red{border-left:4px solid #dc2626}.wty-card--purple{border-left:4px solid #8b5cf6}.wty-card-label{color:#6b7280;text-transform:uppercase;letter-spacing:.3px;font-size:11px;font-weight:500}.wty-card-value{color:#111827;font-size:24px;font-weight:700;line-height:1.1}.wty-card-sub{color:#9ca3af;font-size:11px}.wty-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.wty-toolbar-left,.wty-toolbar-right{flex-wrap:wrap;gap:8px;display:flex}.wty-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:6px;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:500;transition:background .15s;display:inline-flex}.wty-btn-primary{color:#fff;background:#16a34a}.wty-btn-primary:hover{background:#15803d}.wty-btn-secondary{color:#374151;background:#f3f4f6;border:1px solid #e5e7eb}.wty-btn-secondary:hover{background:#e5e7eb}.wty-btn-blue{color:#2563eb;background:#eff6ff;border:1px solid #bfdbfe}.wty-btn-blue:hover{background:#dbeafe}.wty-search{color:#374151;border:1px solid #e5e7eb;border-radius:6px;outline:none;min-width:220px;padding:7px 12px;font-size:13px;transition:border-color .15s}.wty-search:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61f}.wty-section{background:#fff;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.wty-section-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:12px 18px;display:flex}.wty-section-title{color:#374151;margin:0;font-size:13px;font-weight:700}.wty-table-wrap{overflow-x:auto}.wty-table{border-collapse:collapse;width:100%;font-size:13px}.wty-table thead{background:#f9fafb}.wty-table th{text-align:left;color:#4b5563;white-space:nowrap;border-bottom:1px solid #e5e7eb;padding:9px 14px;font-size:12px;font-weight:600}.wty-table td{vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:10px 14px}.wty-table tbody tr:last-child td{border-bottom:none}.wty-table tbody tr:hover{background:#fafafa}.wty-table tbody tr.row-expanded td{background:#f0fdf4}.wty-table tbody tr.row-expanded:hover td{background:#dcfce7}.wty-badge{white-space:nowrap;border-radius:99px;padding:2px 9px;font-size:11px;font-weight:600;display:inline-block}.wty-badge--active{color:#15803d;background:#dcfce7}.wty-badge--expiring{color:#a16207;background:#fef9c3}.wty-badge--expired{color:#b91c1c;background:#fee2e2}.wty-badge--none{color:#9ca3af;background:#f3f4f6}.case-status{border-radius:99px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.cs--receive{color:#374151;background:#f3f4f6}.cs--progress{color:#1d4ed8;background:#dbeafe}.cs--waiting{color:#a16207;background:#fef9c3}.cs--done{color:#15803d;background:#dcfce7}.cs--closed{color:#6b7280;background:#e5e7eb}.priority-badge{border-radius:99px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.priority--low{color:#6b7280;background:#f3f4f6}.priority--normal{color:#1d4ed8;background:#dbeafe}.priority--high{color:#a16207;background:#fef9c3}.priority--urgent{color:#b91c1c;background:#fee2e2}.serial-chips{flex-wrap:wrap;gap:4px;display:flex}.serial-chip{color:#1d4ed8;background:#eff6ff;border-radius:99px;padding:2px 8px;font-size:11px;font-weight:500}.serial-count-btn{color:#15803d;cursor:pointer;background:#f0fdf4;border:none;border-radius:99px;padding:2px 8px;font-size:11px;font-weight:600;transition:background .15s}.serial-count-btn:hover{background:#dcfce7}.wty-expand-row td{border-bottom:2px solid #bbf7d0!important;padding:0!important}.wty-expand-inner{background:#f0fdf4;padding:12px 20px 12px 40px}.wty-serial-list{flex-direction:column;gap:6px;display:flex}.wty-serial-row{background:#fff;border:1px solid #d1fae5;border-radius:6px;align-items:center;gap:10px;padding:6px 12px;font-size:12px;display:flex}.wty-serial-row .sn{color:#1d4ed8;flex:1;font-weight:700}.wty-serial-row .ss{color:#9ca3af}.wty-serial-add-row{gap:8px;margin-top:8px;display:flex}.wty-serial-add-row input{border:1px solid #d1d5db;border-radius:5px;outline:none;flex:1;padding:6px 10px;font-size:12px}.wty-serial-add-row input:focus{border-color:#3b82f6}.wty-actions{gap:4px;display:flex}.wty-act{cursor:pointer;border:none;border-radius:5px;justify-content:center;align-items:center;width:28px;height:28px;transition:background .15s;display:inline-flex}.wty-act.edit{color:#2563eb;background:#eff6ff}.wty-act.edit:hover{background:#dbeafe}.wty-act.delete{color:#dc2626;background:#fff5f5}.wty-act.delete:hover{background:#fee2e2}.wty-act.expand{color:#16a34a;background:#f0fdf4}.wty-act.expand:hover{background:#dcfce7}.wty-empty{text-align:center;color:#9ca3af;padding:36px;font-size:13px}.wty-loading{text-align:center;color:#9ca3af;padding:48px}.wty-modal-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.wty-modal{background:#fff;border-radius:12px;flex-direction:column;width:680px;max-width:100%;max-height:92vh;display:flex;box-shadow:0 20px 60px #0003}.wty-modal.wty-modal--wide{width:900px}.wty-modal-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;gap:12px;padding:16px 24px 12px;display:flex}.wty-modal-header h3{color:#111827;margin:0;font-size:16px;font-weight:700}.wty-modal-close{cursor:pointer;color:#6b7280;background:#f3f4f6;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:16px;display:flex}.wty-modal-close:hover{background:#e5e7eb}.wty-modal-body{flex-direction:column;gap:14px;padding:20px 24px;display:flex;overflow-y:auto}.wty-modal-footer{border-top:1px solid #e5e7eb;justify-content:flex-end;gap:10px;padding:14px 24px;display:flex}.wty-case-sections{flex-direction:column;gap:0;display:flex}.wty-case-section{border-bottom:1px solid #f3f4f6}.wty-case-section:last-child{border-bottom:none}.wty-case-section-header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:12px 0;display:flex}.wty-case-section-title{color:#374151;font-size:13px;font-weight:700}.wty-case-section-body{padding-bottom:16px}.wty-form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.wty-form-group{flex-direction:column;gap:4px;display:flex}.wty-form-group.full{grid-column:1/-1}.wty-form-group label{color:#374151;font-size:12px;font-weight:600}.wty-form-group input,.wty-form-group select,.wty-form-group textarea{color:#111827;background:#fff;border:1px solid #d1d5db;border-radius:6px;outline:none;padding:7px 11px;font-size:13px;transition:border-color .15s,box-shadow .15s}.wty-form-group input:focus,.wty-form-group select:focus,.wty-form-group textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61f}.wty-form-group textarea{resize:vertical;min-height:64px}.wty-form-group input.err{border-color:#dc2626}.wty-form-err{color:#dc2626;font-size:11px}.wty-modal-btn{cursor:pointer;border:none;border-radius:6px;padding:8px 18px;font-size:13px;font-weight:600}.wty-modal-btn.cancel{color:#374151;background:#f3f4f6}.wty-modal-btn.cancel:hover{background:#e5e7eb}.wty-modal-btn.save{color:#fff;background:#16a34a}.wty-modal-btn.save:hover{background:#15803d}.wty-modal-btn:disabled{opacity:.5;cursor:not-allowed}.status-pill-group{flex-wrap:wrap;gap:6px;display:flex}.status-pill-opt{cursor:pointer;color:#6b7280;border:2px solid #e5e7eb;border-radius:99px;padding:4px 12px;font-size:12px;font-weight:600;transition:all .15s}.status-pill-opt.sel-receive{color:#374151;background:#f3f4f6;border-color:#6b7280}.status-pill-opt.sel-progress{color:#1d4ed8;background:#dbeafe;border-color:#3b82f6}.status-pill-opt.sel-waiting{color:#a16207;background:#fef9c3;border-color:#f59e0b}.status-pill-opt.sel-done{color:#15803d;background:#dcfce7;border-color:#16a34a}.status-pill-opt.sel-closed{color:#374151;background:#e5e7eb;border-color:#9ca3af}.activity-timeline{flex-direction:column;gap:0;display:flex}.activity-item{border-bottom:1px solid #f3f4f6;gap:12px;padding:10px 0;font-size:13px;display:flex}.activity-item:last-child{border-bottom:none}.activity-dot{color:#1d4ed8;background:#dbeafe;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;margin-top:2px;font-size:13px;display:flex}.activity-content{flex:1}.activity-meta{color:#9ca3af;margin-top:2px;font-size:11px}.activity-type-tag{color:#374151;background:#f3f4f6;border-radius:99px;margin-right:6px;padding:1px 7px;font-size:11px;font-weight:600;display:inline-block}.activity-case-ref{color:#3b82f6;font-size:11px;font-weight:600}.import-preview{border:1px solid #d1fae5;border-radius:8px;max-height:240px;margin-top:12px;overflow:hidden auto}.import-preview table{border-collapse:collapse;width:100%;font-size:12px}.import-preview th{background:#f0fdf4;border-bottom:1px solid #d1fae5;padding:7px 10px;font-weight:600}.import-preview td{border-bottom:1px solid #f3f4f6;padding:6px 10px}.import-preview tbody tr:last-child td{border-bottom:none}.serial-group{background:#fff;border:1px solid #e5e7eb;border-radius:10px;margin-bottom:12px;overflow:hidden}.serial-group-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;align-items:center;gap:12px;padding:11px 16px;display:flex}.serial-group-name{color:#374151;flex:1;font-size:13px;font-weight:700}.serial-group-model{color:#6b7280;font-size:12px}.shell{flex-direction:column;min-height:100svh;display:flex}.topbar{z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(90deg,#95b79b 0%,#2f6b3a 55%,#2b5f35 100%);border-bottom:1px solid #ffffff2e;position:sticky;top:0}.topbar-inner{align-items:center;gap:1rem;max-width:1200px;margin:0 auto;padding:.65rem 1rem;display:flex}.brand{cursor:pointer;background:0 0;border:none;align-items:center;gap:.6rem;padding:0;display:inline-flex}.brand-logo{filter:drop-shadow(0 10px 16px #0000002e);width:auto;height:44px;display:block}.menu{scrollbar-width:thin;flex:auto;align-items:center;gap:.25rem;display:flex;overflow:hidden}.menu-item{color:#ffffffeb;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #0000;border-radius:999px;padding:.5rem .75rem;font-size:.92rem;font-weight:700;transition:background .2s,border-color .2s,opacity .2s}.menu-item:hover{background:#ffffff24;border-color:#ffffff38}.menu-item.is-active{background:#ffffff2e;border-color:#ffffff59}.topbar-actions{align-items:center;gap:.5rem;display:inline-flex}.user-pill{text-overflow:ellipsis;white-space:nowrap;color:#ffffffeb;background:#0000001f;border:1px solid #fff3;border-radius:999px;max-width:220px;padding:.4rem .65rem;font-size:.9rem;overflow:hidden}.topbar-btn{color:#fff;cursor:pointer;background:#ffffff1f;border:1px solid #ffffff40;border-radius:999px;padding:.45rem .75rem;font-size:.9rem;font-weight:700;transition:background .2s,transform .2s}.topbar-btn:hover{background:#ffffff2e;transform:translateY(-1px)}.topbar-btn:active{transform:translateY(0)}.page{background:radial-gradient(ellipse 80% 50% at 50% -20%, var(--accent-soft), transparent), linear-gradient(180deg, #f8fbf8 0%, #edf6ef 100%);background:radial-gradient(circle at 0 0,#22c55e2e,#0000 30%),radial-gradient(circle at 100% 100%,#1665342e,#0000 30%),linear-gradient(#eef7f0 0%,#dfeee3 100%);flex:auto;justify-content:center;align-items:center;padding:2rem;display:flex;position:relative;overflow:hidden}.page--home{justify-content:stretch;align-items:stretch;padding:0}.home-hero{width:100%;padding:0}.home-hero-img{-o-object-fit:cover;object-fit:cover;width:100%;height:min(78vh,720px);display:block}.glow{filter:blur(80px);pointer-events:none;border-radius:50%;width:28rem;height:28rem;position:absolute}.glow--left{background:#2f6b3a38;top:10%;left:-8%}.glow--right{background:#4e8a582e;bottom:5%;right:-6%}.content{z-index:1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:32px;width:100%;max-width:480px;padding:3rem;animation:.7s ease-out both fade-up;position:relative;box-shadow:0 20px 40px #0000001f,0 8px 20px #16653414}@keyframes fade-up{0%{opacity:0;transform:translateY(1.25rem)}to{opacity:1;transform:translateY(0)}}.eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin:0 0 1rem;font-size:.875rem;font-weight:600}.title{letter-spacing:-.03em;color:var(--text-heading);margin:0;font-size:clamp(3.5rem,12vw,5.5rem);font-weight:700;line-height:1.05}.title-accent{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);color:#0000;-webkit-background-clip:text;background-clip:text}.subtitle{max-width:22rem;color:var(--text);margin:1.25rem auto 2rem;font-size:1.125rem;line-height:1.6}.login-subtitle{margin-bottom:1.5rem}.login-header{text-align:center}.login-title{letter-spacing:-.02em;color:var(--text-heading);margin:0;font-size:2rem;font-weight:700}.login-form{flex-direction:column;gap:1.5rem;width:100%;max-width:100%;margin-top:2rem;display:flex}.field-label{color:var(--text-heading);margin-bottom:.375rem;font-size:.875rem;font-weight:600;display:block}.field-input{width:100%;color:var(--text-heading);border:1px solid var(--border);background:#ffffffe6;border-radius:.75rem;padding:.75rem 1rem;font-family:inherit;font-size:1rem;transition:border-color .2s,box-shadow .2s}.field-input::placeholder{color:#94a3b8}.field-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.form-error{color:#dc2626;text-align:center;margin:0 0 1rem;font-size:.875rem}.link-back{color:var(--accent);cursor:pointer;background:0 0;border:none;margin-top:1.25rem;padding:0;font-family:inherit;font-size:.9375rem;font-weight:500;transition:opacity .2s;display:inline-block}.link-back:hover{opacity:.8}.btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#166534 0%,#22c55e 100%);border:none;border-radius:999px;justify-content:center;align-items:center;min-width:10rem;padding:.875rem 2rem;font-family:inherit;font-size:1rem;font-weight:600;transition:transform .2s,box-shadow .2s,background .2s;display:inline-flex;box-shadow:0 4px 14px #2f6b3a59}.btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #2f6b3a66}.btn:active{transform:translateY(0)}.btn:focus-visible{outline:3px solid var(--accent-soft);outline-offset:3px}.btn--full{width:100%;min-width:unset;margin-top:.25rem}@media (width<=480px){.topbar-inner{gap:.75rem}.brand-logo{height:38px}.content{padding:2.5rem 1.5rem}}.admin-layout{gap:24px;width:100%;display:flex}.sidebar{flex-direction:column;gap:14px;width:240px;display:flex}.sidebar-btn{cursor:pointer;color:#1e293b;text-align:left;background:linear-gradient(135deg,#1665341f,#22c55e14);border:none;border-radius:18px;padding:16px 18px;font-size:15px;font-weight:700;transition:all .2s;box-shadow:0 4px 12px #0000000f}.sidebar-btn.active{color:#fff;background:linear-gradient(135deg,#166534,#15803d);transform:translateY(-1px);box-shadow:0 10px 24px #16653440}.sidebar-btn:hover{background:linear-gradient(135deg,#1665342e,#22c55e24);transform:translateY(-2px)}.content-area{background:#fff;border-radius:16px;flex:1;padding:24px}.content-scrollable{flex:1;min-height:0;overflow:auto}.user-table{border-collapse:separate;border-spacing:0;width:100%;min-width:800px;margin-top:20px}.user-table th,.user-table td{text-align:left;word-wrap:break-word;white-space:nowrap;border-bottom:1px solid #ddd;padding:12px}.user-table th{z-index:10;background:#f8fafc;position:sticky;top:0}.admin-page{align-items:flex-start;padding:24px 32px}.admin-layout{align-items:flex-start;gap:24px;width:100%;display:flex}.sidebar{flex-shrink:0;width:240px}.content-area{background:#fff;border-radius:20px;flex-direction:column;flex:1;min-height:500px;padding:24px;display:flex;overflow:hidden;box-shadow:0 8px 24px #0000000f}.content-header{flex-shrink:0}.content-scrollable{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.table-wrapper{border-radius:8px;flex:1;min-height:0;overflow:auto}.login-card{width:100%;max-width:420px}.section-title{text-align:center}.add-btn{color:#fff;cursor:pointer;background:#15803d;border:none;border-radius:10px;margin-bottom:16px;padding:10px 18px;font-weight:600}.add-btn:hover{background:#166534}.edit-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;padding:6px 12px;font-weight:600}.edit-btn:hover{background:#1d4ed8}.modal-overlay{z-index:999;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#f3f8f3;border-radius:16px;width:900px;max-width:90%;padding:24px;box-shadow:0 10px 30px #0003}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-header h2{color:#1f2937;margin:0;font-size:24px;font-weight:700}.close-btn{cursor:pointer;background:0 0;border:none;font-size:20px}.modal-body{grid-template-columns:1fr 1fr;gap:16px 20px;display:grid}.modal-footer{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}.cancel-btn{cursor:pointer;background:#e5e7eb;border:none;border-radius:10px;padding:10px 18px}.save-btn{color:#fff;cursor:pointer;background:#15803d;border:none;border-radius:10px;padding:10px 18px}.field{flex-direction:column;gap:8px;display:flex}.field label{color:#374151;font-weight:600}.field input{border:1px solid #d1d5db;border-radius:10px;outline:none;width:100%;padding:12px 14px;font-size:14px;transition:all .2s}.field input:focus{border-color:#15803d;box-shadow:0 0 0 3px #15803d26}.field select{background:#fff;border:1px solid #d1d5db;border-radius:8px;width:100%;padding:12px}.contract-management-layout{flex-direction:column;width:100%;height:100%;display:flex}.contract-management-page{width:100%;height:100%}.contract-header{background:#fff;border:1px solid #e5e7eb;border-radius:16px;margin-bottom:20px;padding:24px;box-shadow:0 4px 12px #0000000d}.contract-header-loading{text-align:center;color:#6b7280;padding:20px}.contract-header-title{text-align:center;border-bottom:none;margin-bottom:0;padding-bottom:0}.contract-header-title h1{color:#1f2937;margin:0 0 8px;font-size:32px;font-weight:700}.contract-header-title .contract-no{color:#9ca3af;margin:0;font-size:16px;font-weight:500}.contract-header-kpi-grid{grid-template-columns:repeat(5,1fr);gap:16px;display:grid}@media (width<=1024px){.contract-header-kpi-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=640px){.contract-header-kpi-grid{grid-template-columns:1fr}}.contract-header-kpi-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;flex-direction:column;gap:8px;padding:16px;display:flex}.contract-header-kpi-label{color:#6b7280;text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:500}.contract-header-kpi-value{color:#1f2937;font-size:18px;font-weight:600;line-height:1.4}.contract-header-kpi-value.money{color:#15803d}.contract-header-item{flex-direction:column;gap:4px;display:flex}.contract-header-label{color:#6b7280;text-transform:uppercase;font-size:12px;font-weight:500}.contract-header-value{color:#1f2937;font-size:14px;font-weight:600}.contract-header-value.money{color:#15803d;font-family:monospace}.contract-management-body{gap:20px;min-height:600px;display:flex}.contract-sidebar{background:#fff;border:1px solid #e5e7eb;border-radius:16px;flex-shrink:0;width:280px;max-height:calc(100vh - 200px);padding:16px;overflow-y:auto;box-shadow:0 4px 12px #0000000d}.contract-sidebar-section{margin-bottom:20px}.contract-sidebar-category{color:#374151;text-transform:uppercase;border-bottom:2px solid #e5e7eb;margin-bottom:8px;padding:8px 12px;font-size:13px;font-weight:700}.contract-sidebar-items{flex-direction:column;gap:4px;display:flex}.contract-sidebar-item{text-align:left;color:#4b5563;cursor:pointer;background:0 0;border:none;border-radius:8px;padding:10px 14px;font-size:14px;font-weight:500;transition:all .2s}.contract-sidebar-item:hover{color:#1f2937;background:#f3f4f6}.contract-sidebar-item.active{color:#fff;background:linear-gradient(135deg,#166534,#15803d);font-weight:600}.contract-management-content{background:#fff;border:1px solid #e5e7eb;border-radius:16px;flex:1;min-height:500px;padding:24px;box-shadow:0 4px 12px #0000000d}.contract-info-tab{gap:24px;height:100%;display:flex}.contract-info-left{flex:1;min-width:0}.contract-info-right{border-left:1px solid #e5e7eb;flex-shrink:0;width:320px;padding-left:24px}.contract-info-section-title{color:#1f2937;border-bottom:2px solid #e5e7eb;margin-bottom:16px;padding-bottom:8px;font-size:16px;font-weight:700}.contract-info-form{flex-direction:column;gap:16px;display:flex}.form-row{gap:16px;display:flex}.form-group{flex-direction:column;flex:1;gap:6px;display:flex}.form-group.full-width{flex-basis:100%}.form-group label{color:#6b7280;font-size:13px;font-weight:600}.form-group input,.form-group textarea,.form-group select{color:#1f2937;background:#f9fafb;border:1px solid #d1d5db;border-radius:8px;width:100%;padding:10px 12px;font-size:14px}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{background:#fff;border-color:#15803d;outline:none;box-shadow:0 0 0 3px #15803d1a}.form-group textarea{resize:vertical;min-height:80px}.status-container{padding:10px 12px}.staff-groups{flex-direction:column;gap:16px;display:flex}.staff-group{flex-direction:column;gap:8px;display:flex}.staff-group-label{color:#6b7280;font-size:13px;font-weight:600}.staff-members{flex-wrap:wrap;align-items:center;gap:8px;min-height:32px;display:flex}.staff-chip{color:#166534;background:linear-gradient(135deg,#1665341a,#22c55e14);border:1px solid #16653433;border-radius:20px;align-items:center;padding:6px 12px;font-size:13px;font-weight:600;display:inline-flex}.staff-empty{color:#9ca3af;font-size:14px}.placeholder-tab{text-align:center;color:#6b7280;padding:60px 20px}.placeholder-tab h3{color:#374151;margin-bottom:8px;font-size:18px;font-weight:600}.contract-management-loading{text-align:center;color:#6b7280;padding:60px;font-size:16px}.btn-edit-contract{color:#15803d;cursor:pointer;white-space:nowrap;background:0 0;border:none;align-items:center;gap:8px;padding:4px 0;font-size:18px;font-weight:600;transition:all .2s;display:inline-flex}.btn-edit-contract:hover{color:#166534}.btn-edit-contract svg{flex-shrink:0;width:20px;height:20px}@media (width<=1024px){.contract-info-tab{flex-direction:column}.contract-info-right{border-top:1px solid #e5e7eb;border-left:none;width:100%;padding-top:24px;padding-left:0}.contract-sidebar{width:240px}}.hamburger{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:8px;flex-shrink:0;padding:.4rem .65rem;font-size:1.25rem;line-height:1;transition:background .2s;display:none}.hamburger:hover{background:#ffffff40}@media (width<=768px){.topbar-inner{flex-wrap:wrap;gap:.5rem;padding:.5rem .75rem}.hamburger{margin-left:auto;display:block}.menu{flex-direction:column;order:4;gap:.25rem;width:100%;padding-bottom:.5rem;display:none;overflow:visible}.menu--open{display:flex}.menu-item{text-align:left;border-radius:10px;width:100%;padding:.65rem 1rem}.user-pill{display:none}.page{padding:1rem}.admin-page{padding:12px 16px}.admin-layout{flex-direction:column}.sidebar{flex-flow:wrap;gap:8px;width:100%}.sidebar-btn{text-align:center;flex:140px;padding:10px;font-size:12px}.contract-management-body{flex-direction:column;min-height:auto}.contract-sidebar{flex-wrap:wrap;gap:8px;max-height:none;padding:12px;display:flex;width:100%!important}.contract-sidebar-section{flex:160px;margin-bottom:0}.contract-sidebar-category{margin-bottom:4px;padding:6px 8px;font-size:11px}.contract-sidebar-item{padding:8px 10px;font-size:13px}.contract-management-content,.contract-header{padding:16px}.contract-header-title h1{font-size:22px}.table-wrapper,.content-scrollable{overflow-x:auto}.modal{max-width:96%;max-height:90vh;padding:16px;overflow-y:auto;width:96%!important}.modal-body{grid-template-columns:1fr}.modal-header h2{font-size:18px}.form-row{flex-direction:column;gap:12px}.contract-info-tab{flex-direction:column}.contract-info-right{border-top:1px solid #e5e7eb;border-left:none;width:100%;padding-top:16px;padding-left:0}.content{border-radius:20px;padding:2rem 1.25rem}}
