html,body{width:100%;height:100%}input::-ms-clear,input::-ms-reveal{display:none}*,*:before,*:after{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:rgba(0,0,0,0)}body{margin:0}[tabindex="-1"]:focus{outline:none}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5em;font-weight:500}p{margin-top:0;margin-bottom:1em}abbr[title],abbr[data-original-title]{-webkit-text-decoration:underline dotted;text-decoration:underline dotted;border-bottom:0;cursor:help}address{margin-bottom:1em;font-style:normal;line-height:inherit}input[type=text],input[type=password],input[type=number],textarea{-webkit-appearance:none}ol,ul,dl{margin-top:0;margin-bottom:1em}ol ol,ul ul,ol ul,ul ol{margin-bottom:0}dt{font-weight:500}dd{margin-bottom:.5em;margin-left:0}blockquote{margin:0 0 1em}dfn{font-style:italic}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}pre,code,kbd,samp{font-size:1em;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace}pre{margin-top:0;margin-bottom:1em;overflow:auto}figure{margin:0 0 1em}img{vertical-align:middle;border-style:none}a,area,button,[role=button],input:not([type=range]),label,select,summary,textarea{touch-action:manipulation}table{border-collapse:collapse}caption{padding-top:.75em;padding-bottom:.3em;text-align:left;caption-side:bottom}input,button,select,optgroup,textarea{margin:0;color:inherit;font-size:inherit;font-family:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}button,html [type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{padding:0;border-style:none}input[type=radio],input[type=checkbox]{box-sizing:border-box;padding:0}input[type=date],input[type=time],input[type=datetime-local],input[type=month]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;margin:0;padding:0;border:0}legend{display:block;width:100%;max-width:100%;margin-bottom:.5em;padding:0;color:inherit;font-size:1.5em;line-height:inherit;white-space:normal}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item}template{display:none}[hidden]{display:none!important}#root{margin:0;width:100%;max-width:none;padding:0}.project-dashboard-page{min-height:100vh;background:#f5f6f8;color:#1b1f24;display:flex;flex-direction:column;--card-base-width: 320px}.top-menu{height:74px;padding:0 28px;background:#fff;border-bottom:1px solid #eceff3;display:flex;align-items:center;justify-content:space-between}.top-menu-left{display:flex;align-items:center;gap:24px}.top-menu-left nav{display:flex;align-items:center;gap:30px}.top-nav-link{border:0;background:transparent;color:#4b5563;font-size:19px;line-height:74px;padding:0 2px;border-bottom:3px solid transparent;cursor:pointer}.top-nav-link.active{color:#111827;border-bottom-color:#ff875e}.top-menu-right{display:flex;align-items:center;gap:8px}.top-settings-menu{position:relative;display:inline-flex}.top-settings-dropdown{position:absolute;right:0;top:calc(100% + 6px);min-width:138px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;box-shadow:0 8px 20px #0000001f;padding:8px 0;z-index:40}.top-settings-dropdown button{width:100%;border:0;background:transparent;text-align:left;padding:10px 14px;font-size:14px;color:#1f2937;cursor:pointer}.top-settings-dropdown button:hover{background:#f3f4f6}.top-settings-dropdown button.danger{color:#111827}.reminder-bell-wrap{position:relative}.reminder-badge{position:absolute;right:-5px;top:-4px;min-width:18px;height:18px;border-radius:999px;background:#ef4444;color:#fff;font-size:11px;line-height:18px;text-align:center;padding:0 5px;box-shadow:0 2px 8px #ef444459}.upload-contract-button{height:36px;border-radius:10px;border:1px solid #ffd5c4;background:#fff7f3;color:#f46a3d;padding:0 14px;font-size:14px;cursor:pointer}.top-menu-user{margin-left:8px;display:inline-flex;align-items:center;gap:10px}.icon-button{width:36px;height:36px;border-radius:10px;border:0;background:transparent;color:#6b7280;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:18px}.icon-button:hover{background:#f3f4f6}.icon-button.small{width:28px;height:28px;border-radius:8px}.toolbar{padding:26px 32px 18px;display:flex;align-items:center;gap:16px;position:relative;min-height:56px}.toolbar-left{display:flex;align-items:center;min-width:var(--card-base-width)}.toolbar-subpage{align-items:flex-start;min-height:82px;padding-top:14px;padding-bottom:12px}.toolbar-subpage .toolbar-left{min-width:0;max-width:calc(50% - 200px);overflow:hidden}.toolbar-subpage-heading{display:grid;gap:4px;min-width:0}.toolbar-subpage-heading h2{margin:0;font-size:24px;color:#1f2937;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.toolbar-subpage-heading p{margin:0;color:#6b7280;font-size:14px}.toolbar-center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:flex;justify-content:center;align-items:center;pointer-events:none}.toolbar-center .view-tabs{pointer-events:auto}.toolbar-right{display:flex;align-items:center;gap:10px;margin-left:auto}.toolbar-user-info{display:inline-flex;align-items:center;gap:8px;border-radius:8px;padding:4px 8px;background:#fff}.user-avatar{width:34px;height:34px;border-radius:999px;background:#ff875e;color:#fff;font-size:14px;display:inline-flex;align-items:center;justify-content:center}.user-name{font-size:14px;color:#374151;font-weight:500}.search-wrap{width:var(--card-base-width);max-width:100%;height:44px;background:#fff;border:1px solid #e6e9ef;border-radius:999px;display:flex;align-items:center;gap:0;padding:0 18px;color:#9aa3af}.search-wrap input{border:0;outline:0;width:100%;font-size:15px;background:transparent}.toolbar-project-title{width:var(--card-base-width);max-width:100%;height:44px;border-radius:999px;border:1px solid #e6e9ef;background:#fff;padding:0 16px;display:inline-flex;align-items:center;color:#1f2937;font-size:16px;font-weight:500}.view-tabs{height:44px;background:#fff;border:1px solid #eceff3;border-radius:999px;padding:4px;display:inline-grid;grid-template-columns:repeat(3,minmax(120px,1fr));align-items:center}.tab-item{border:0;background:transparent;border-radius:999px;font-size:15px;color:#4b5563;padding:0 20px;cursor:pointer}.tab-item.active{background:#ff875e;color:#fff}.project-grid{padding:14px 32px 32px;display:grid;grid-template-columns:repeat(auto-fill,minmax(var(--card-base-width),1fr));gap:22px;flex:1}.project-grid-loading,.project-grid-empty{grid-column:1 / -1;display:grid;place-items:center;min-height:260px;color:#9ca3af;font-size:16px}.project-card{background:#fff;width:100%;min-height:420px;border-radius:12px;box-shadow:0 8px 20px #1418280f;border:1px solid #f1f3f7;display:grid;grid-template-rows:auto 1fr auto}.project-card-header{display:flex;align-items:flex-start;justify-content:space-between;padding:16px 16px 14px;border-bottom:1px solid #f0f1f4;gap:8px}.project-card-header h3{margin:0;font-size:18px;font-weight:500;color:#2f333a;flex:1;min-width:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4;min-height:2.8em}.project-meta{flex-shrink:0;display:flex;align-items:center;gap:4px;color:#8b939e;font-size:14px;white-space:nowrap}.card-menu-wrap{position:relative}.card-dropdown-menu{position:absolute;top:100%;right:0;z-index:20;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 6px 16px #0000001a;min-width:120px;padding:4px 0}.card-dropdown-menu button{display:block;width:100%;padding:8px 16px;text-align:left;font-size:13px;color:#374151;background:none;border:none;cursor:pointer;transition:background .12s}.card-dropdown-menu button:hover{background:#f3f4f6}.card-dropdown-menu button.danger{color:#ef4444}.card-dropdown-menu button.danger:hover{background:#fef2f2}.status-filter-tabs{display:flex;gap:4px;margin-left:12px}.status-filter-tabs button{padding:4px 12px;border-radius:6px;border:1px solid #e5e7eb;background:#fff;color:#6b7280;font-size:13px;cursor:pointer;transition:all .15s}.status-filter-tabs button.active{background:#f97316;color:#fff;border-color:#f97316}.status-filter-tabs button:hover:not(.active){background:#f9fafb;border-color:#d1d5db}.project-node-list{padding:18px 18px 16px;display:flex;flex-direction:column;gap:12px}.project-node{display:flex;align-items:flex-start;gap:10px}.node-box{width:19px;height:19px;border:1.2px solid #9ca3af;border-radius:4px;margin-top:2px;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:11px;flex-shrink:0}.node-box.done{background:#ff875e;border-color:#ff875e}.node-text{display:grid;gap:4px}.node-text-group{gap:10px}.node-field{display:grid;gap:3px}.node-text strong{font-size:16px;line-height:1.25;font-weight:500;color:#252a32}.node-text span{font-size:12px;line-height:1.35;color:#a3aab5}.node-linked-value{border:0;background:transparent;padding:0;text-align:left;font-size:12px;line-height:1.3;color:#6b7280;cursor:pointer}.node-linked-value.readonly{color:#a3aab5;cursor:default}.invoice-progress-card{border:1px solid #e5e7eb;border-radius:10px;padding:10px 12px;display:grid;gap:6px;background:#fafafa}.finance-progress-grid{display:grid;gap:10px}.invoice-progress-card strong{font-size:18px;color:#111827}.invoice-progress-card span{font-size:12px;color:#6b7280}.invoice-progress-card.warning strong{color:#ca8a04}.invoice-progress-card.good strong{color:#16a34a}.invoice-progress-track{width:100%;height:6px;border-radius:999px;background:#e5e7eb;overflow:hidden}.invoice-progress-fill{height:100%;background:#9ca3af}.invoice-progress-card.warning .invoice-progress-fill{background:#f59e0b}.invoice-progress-card.good .invoice-progress-fill{background:#22c55e}.finance-received-card{background:#fffaf5;border-color:#fed7aa}.payment-overdue-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.payment-overdue-badge{display:inline-flex;align-items:center;height:22px;padding:0 8px;border-radius:999px;border:1px solid #d1d5db;font-size:12px;font-weight:600;line-height:1}.payment-overdue-badge.danger{border-color:#fecaca;color:#b91c1c;background:#fef2f2}.payment-overdue-badge.safe{border-color:#bbf7d0;color:#15803d;background:#f0fdf4}.payment-overdue-badge.muted{border-color:#e5e7eb;color:#6b7280;background:#f9fafb}.payment-overdue-meta{font-size:12px;color:#6b7280}.invoice-history-toggle{width:fit-content;border:0;padding:0;background:transparent;color:#4b5563;font-size:12px;cursor:pointer}.invoice-add-form{display:grid;gap:6px;border-top:1px dashed #d1d5db;padding-top:8px}.invoice-add-form input{height:30px;border:1px solid #d1d5db;border-radius:6px;padding:0 8px;font-size:12px;outline:none}.invoice-add-form input:focus{border-color:#ff875e}.invoice-save-button{width:fit-content;border:0;background:#ff875e;color:#fff;border-radius:6px;height:30px;padding:0 10px;font-size:12px;cursor:pointer}.invoice-save-button:disabled{opacity:.7;cursor:not-allowed}.invoice-history-list{border-top:1px dashed #d1d5db;padding-top:6px;display:grid;gap:4px}.invoice-history-item{display:flex;justify-content:space-between;font-size:12px;color:#4b5563}.invoice-history-empty{font-size:12px;color:#9ca3af}.node-inline-input{width:220px;height:28px;border-radius:6px;border:1px solid #dfe5ee;padding:0 8px;outline:none;font-size:12px}.node-inline-input:focus{border-color:#ff875e}.project-card-footer{border-top:1px solid #f0f1f4;padding:0;display:flex;flex-direction:column}.card-action-row{display:grid;grid-template-columns:repeat(2,1fr)}.card-action-row .detail-button+.detail-button{border-left:1px solid #f0f1f4}.detail-button{border:0;background:transparent;color:#8f97a4;font-size:16px;line-height:44px;cursor:pointer}.mid-complete-button{margin-top:auto;height:38px;border:1px solid #ffd5c4;border-radius:10px;background:#fff7f3;color:#f46a3d;font-size:15px;font-weight:500;cursor:pointer}.subpage{padding:16px 32px 24px;display:flex;flex-direction:column;gap:12px;flex:1}.subpage-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.subpage-header h2{margin:0;font-size:24px;color:#1f2937}.subpage-header p{margin:0;color:#6b7280;font-size:14px}.calendar-toolbar{display:flex;align-items:center;gap:10px}.calendar-toolbar button{height:38px;border-radius:10px;border:1px solid #dde3eb;background:#fff;color:#1f2937;padding:0 14px;display:inline-flex;align-items:center;gap:8px;font-size:14px;cursor:pointer}.calendar-toolbar button:last-child{margin-left:auto}.calendar-select-wrap{height:38px;border-radius:10px;border:1px solid #dde3eb;background:#fff;padding:0 12px;display:inline-flex;align-items:center}.calendar-select-wrap select{border:0;outline:none;font-size:14px;color:#1f2937;background:transparent;cursor:pointer}.calendar-board{background:#fff;border:1px solid #e8edf3;border-radius:14px;box-shadow:0 8px 20px #1418280a;display:grid;grid-template-rows:auto 1fr;min-height:calc(100vh - 250px)}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid #eff2f6}.calendar-weekdays div{height:48px;display:grid;place-items:center;color:#6b7280;font-size:15px}.calendar-weekdays .weekend{color:#f46a3d}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:repeat(6,minmax(92px,1fr))}.calendar-cell{border-right:1px solid #f1f3f6;border-bottom:1px solid #f1f3f6;padding:10px;display:grid;align-content:start;gap:8px}.calendar-cell:nth-child(7n){border-right:0}.calendar-day{font-size:26px;line-height:1;color:#111827}.calendar-cell.muted .calendar-day{color:#c9ced6}.calendar-event-list{display:grid;gap:6px;justify-items:start}.calendar-event-tag{display:inline-flex;align-items:center;max-width:100%;border-radius:999px;padding:1px 8px;font-size:11px;line-height:1.5;color:#4b5563;background:#eef2f7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-event-tag-start{background:#e8f4ff;color:#1d4ed8}.calendar-event-tag-deadline{background:#ffefef;color:#dc2626}.calendar-event-tag-invoice{background:#fff7e8;color:#d97706}.calendar-event-tag-exit{background:#ecfdf3;color:#059669}.calendar-event-tag-payment{background:#fdf2f8;color:#be185d}.calendar-event-more{font-size:11px;color:#6b7280}.calendar-event{border:0;border-radius:8px;background:#fff4ef;color:#f46a3d;font-size:12px;padding:4px 6px;display:inline-flex;align-items:center;gap:5px;width:fit-content;cursor:pointer}.project-status{min-width:54px;height:24px;border-radius:999px;background:#eef2f7;color:#6b7280;font-size:12px;display:inline-flex;align-items:center;justify-content:center}.project-status.done{background:#fff3ed;color:#f46a3d}.calendar-modal-list{display:grid;gap:10px;margin-top:8px}.calendar-modal-item{border:1px solid #eceff3;border-radius:8px;padding:8px 10px;display:grid;gap:4px}.calendar-modal-item strong{color:#1f2937;font-size:14px;font-weight:500}.calendar-modal-item span{color:#6b7280;font-size:13px}.calendar-modal-actions{display:flex;gap:8px;margin-top:2px}.calendar-modal-actions button{border:1px solid #e5e7eb;background:#fff;color:#374151;border-radius:6px;padding:4px 8px;font-size:12px;cursor:pointer}.calendar-modal-actions button:hover{border-color:#f97316;color:#f97316}.contact-project-list{display:grid;gap:16px}.contact-project-card{background:#fff;border:1px solid #edf1f5;border-radius:12px;box-shadow:0 8px 20px #1418280a;overflow:hidden}.contact-project-card header{padding:14px 16px;border-bottom:1px solid #f0f1f4;display:flex;justify-content:space-between;align-items:center}.contact-project-card h3{margin:0;font-size:16px;color:#1f2937}.contact-project-card header span{font-size:13px;color:#9ca3af}.contact-list{padding:8px 16px 14px;display:grid;gap:8px}.contact-item{display:grid;grid-template-columns:110px 1fr;gap:10px;align-items:center;padding:8px 0;border-bottom:1px dashed #eef1f4}.contact-item:last-child{border-bottom:0}.contact-role{font-size:13px;color:#6b7280}.contact-main{display:flex;align-items:center;justify-content:space-between;gap:14px;font-size:14px;color:#1f2937}.contact-main span:last-child{display:inline-flex;align-items:center;gap:6px;color:#4b5563}.detail-files-layout,.compare-layout{display:grid;grid-template-columns:minmax(520px,1.15fr) minmax(460px,1fr);gap:18px;height:calc(100vh - 170px);min-width:0;width:100%;max-width:100%;overflow-x:auto;overflow-y:hidden;padding-right:2px;scrollbar-gutter:stable}.file-preview-panel,.file-attachment-panel,.extract-form-panel{background:#fff;border:1px solid #e8edf3;border-radius:12px;box-shadow:0 8px 20px #1418280a;padding:16px;display:grid;grid-template-rows:auto 1fr;gap:4px;min-height:0;min-width:0;overflow:hidden}.file-attachment-panel{display:flex;flex-direction:column;gap:8px;overflow-y:auto}.section-header-row{display:flex;align-items:center;justify-content:space-between}.detail-invoice-actions{display:flex;align-items:center;gap:8px}.detail-add-record-button{height:32px;padding:0 12px;border-radius:8px;border:1px solid #d1d5db;background:#fff;color:#4b5563;font-size:13px;cursor:pointer}.detail-add-record-button:hover{border-color:#ff875e;color:#f46a3d}.detail-invoice-add-form{margin-top:8px;width:100%;box-sizing:border-box;display:grid;grid-template-columns:auto 140px 150px minmax(220px,1fr) auto;gap:8px;align-items:center}.detail-payment-overdue-panel{margin-top:8px;margin-bottom:8px;display:grid;gap:12px;padding:12px;border:1px solid #e5e7eb;border-radius:12px;background:#fafafa}.detail-payment-overdue-panel.danger{border-color:#f3c8c8;background:#fff3f3}.detail-payment-overdue-panel.safe{border-color:#cdeccf;background:#f5fff5}.detail-payment-overdue-panel.muted{border-color:#e5e7eb;background:#fafafa}.detail-payment-overdue-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.detail-payment-overdue-title-wrap{display:grid;gap:6px}.detail-payment-overdue-title-wrap strong{font-size:18px;line-height:1.2;color:#111827}.detail-payment-overdue-summary{font-size:13px;line-height:1.6;color:#4b5563}.detail-payment-tail-card{display:grid;gap:10px;padding:12px;border:1px dashed #d1d5db;border-radius:10px;background:#ffffffb8}.detail-payment-tail-card.danger{border-color:#f2b5b5;background:#fff8f8}.detail-payment-tail-card.safe{border-color:#b9e3bc;background:#f7fff8}.detail-payment-tail-card.muted{border-color:#d1d5db;background:#ffffffb8}.detail-payment-tail-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.detail-payment-tail-head strong{font-size:15px;color:#111827}.detail-payment-tail-desc{font-size:13px;line-height:1.6;color:#4b5563}.detail-payment-tail-actions{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.detail-payment-tail-actions input{width:180px;height:32px;border:1px solid #d1d5db;border-radius:8px;padding:0 10px;font-size:13px;outline:none;background:#fff}.detail-payment-tail-actions input:focus{border-color:#ff875e}.detail-payment-tail-ghost{height:32px;border:1px solid #d1d5db;border-radius:8px;background:#fff;padding:0 12px;color:#374151;font-size:13px;cursor:pointer}.detail-payment-tail-ghost.active{border-color:#16a34a;color:#166534;background:#f0fdf4}.detail-payment-tail-ghost:disabled,.detail-payment-tail-actions input:disabled{opacity:.7;cursor:not-allowed}.detail-payment-milestone-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.detail-payment-milestone-card{display:grid;gap:8px;padding:12px;border:1px solid #d1d5db;border-radius:10px;background:#ffffffad}.detail-payment-milestone-card strong{font-size:15px;color:#111827}.detail-payment-milestone-date{font-size:22px;font-weight:700;line-height:1.1;color:#1d4ed8}.detail-payment-milestone-rule{font-size:13px;line-height:1.5;color:#4b5563}.detail-payment-milestone-desc{font-size:13px;line-height:1.55;color:#6b7280}.detail-record-type-group{display:inline-flex;align-items:center;border:1px solid #d1d5db;border-radius:8px;overflow:hidden;height:30px;flex:0 0 auto}.detail-record-type-button{height:100%;padding:0 12px;border:0;background:#fff;color:#6b7280;font-size:12px;cursor:pointer}.detail-record-type-button+.detail-record-type-button{border-left:1px solid #e5e7eb}.detail-record-type-button.active{background:#fff2ec;color:#f46a3d}.detail-invoice-add-form input{height:30px;border:1px solid #d1d5db;border-radius:6px;padding:0 8px;font-size:12px;outline:none}.detail-record-amount-input,.detail-record-date-input,.detail-record-remark-input{width:100%}.detail-save-record-button{min-width:84px;white-space:nowrap;flex-shrink:0}.detail-invoice-add-form input:focus{border-color:#ff875e}.section-header-row+.attachment-list+.section-header-row{border-top:1px solid #eef1f4;padding-top:10px}.upload-action-row{display:flex;justify-content:flex-end}.upload-trigger{height:32px;padding:0 12px;border-radius:8px;border:1px solid #ffd5c4;background:#fff7f3;color:#f46a3d;font-size:13px;display:inline-flex;align-items:center;cursor:pointer}.upload-trigger input{display:none}.file-preview-panel h3,.file-attachment-panel h3,.extract-form-panel h3{margin:0;font-size:15px;line-height:1.4;color:#1f2937}.file-preview-box{border:1px dashed #d6dde8;border-radius:10px;min-height:0;display:grid;justify-items:center;background:#f9fbfe;overflow:hidden}.pdf-scroll-viewer{width:100%;height:100%;display:grid;grid-template-rows:auto 1fr;overflow:hidden}.pdf-toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:10px;border-bottom:1px solid #e8edf3;background:#fff}.pdf-toolbar button,.pdf-toolbar a{height:32px;border:1px solid #d8dfe8;background:#fff;border-radius:8px;padding:0 10px;color:#374151;font-size:13px;display:inline-flex;align-items:center;gap:4px;text-decoration:none;cursor:pointer}.pdf-toolbar button:disabled{opacity:.55;cursor:not-allowed}.pdf-scroll-wrap{overflow:auto;padding:14px;display:flex;flex-direction:column;align-items:center;gap:12px}.pdf-scroll-wrap .react-pdf__Page{box-shadow:0 4px 12px #1418281a}.pdf-scroll-wrap canvas{max-width:100%;height:auto!important}.pdf-page-count{font-size:13px;color:#6b7280}.pdf-loading{color:#6b7280;font-size:14px;padding:24px}.pdf-fallback-wrap{width:100%;display:grid;gap:8px}.pdf-open-link{color:#ff875e;font-size:13px;justify-self:center}.contract-preview-frame{width:100%;min-height:320px;border:0}.file-preview-box strong{color:#1f2937;font-size:16px}.file-preview-box span{color:#6b7280;font-size:13px}.file-preview-box p{color:#9aa3af;font-size:13px}.attachment-list{display:grid;gap:8px;overflow:visible;padding-bottom:2px}.attachment-item{border:1px solid #eef2f7;border-radius:8px;min-height:40px;padding:6px 12px;display:flex;align-items:center;gap:8px;font-size:13px;color:#4b5563;transition:background .15s,border-color .15s}.att-name em{margin-left:8px;font-style:normal;color:#9ca3af;font-size:12px}.attachment-item.invoice-row .att-name{white-space:normal;display:grid;gap:2px;overflow:hidden;min-width:0}.invoice-file-name{min-width:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.invoice-amount-input{width:120px;height:28px;border:1px solid #d1d5db;border-radius:6px;padding:0 6px;font-size:12px;color:#0f172a;background:#fff}.received-amount-input{width:120px;height:28px;border:1px solid #ffd5c4;border-radius:6px;padding:0 6px;font-size:12px;color:#ea580c;background:#fff7ed}.invoice-date-input{width:132px;height:28px;border:1px solid #d1d5db;border-radius:6px;padding:0 6px;font-size:12px;color:#0f172a;background:#fff}.attachment-item.clickable{cursor:pointer}.attachment-item.clickable:hover{background:#f0f5ff;border-color:#bfdbfe}.attachment-item.active{background:#eff6ff;border-color:#3b82f6;color:#1e40af}.att-icon{flex-shrink:0;font-size:16px;color:#6b7280}.attachment-item.active .att-icon{color:#3b82f6}.att-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.att-size{flex-shrink:0;font-size:12px;color:#9ca3af;margin-left:auto}.attachment-item.invoice-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:flex-start;column-gap:10px;row-gap:8px}.attachment-item.invoice-row.invoice-row-compact{display:grid;grid-template-columns:auto minmax(120px,180px) minmax(0,1fr) auto;align-items:center;column-gap:12px;row-gap:8px}.invoice-amount-group{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);column-gap:10px;row-gap:6px;justify-content:stretch;align-items:stretch;min-width:0;width:100%;grid-column:1 / -1}.invoice-inline-fields{min-width:0;display:grid;grid-template-columns:minmax(110px,128px) minmax(132px,148px) minmax(0,1fr);align-items:end;column-gap:10px;row-gap:6px}.invoice-inline-field{display:grid;gap:2px;min-width:0}.invoice-inline-field span{font-size:11px;color:#9ca3af;line-height:1.2;white-space:nowrap}.invoice-inline-field-remark{min-width:0}.invoice-inline-fields-full{grid-template-columns:minmax(110px,128px) minmax(132px,148px) minmax(180px,1fr)}.attachment-item.invoice-row-invoice{border-color:#dbe7ff;background:#f7faff}.attachment-item.invoice-row-received{border-color:#ffd9c7;background:#fff8f3}.attachment-item.invoice-row-invoice:hover{background:#eef5ff;border-color:#bcd1ff}.attachment-item.invoice-row-received:hover{background:#fff1e8;border-color:#ffc5a7}.attachment-item.invoice-row-invoice.active{background:#e8f1ff;border-color:#7aa2ff;color:#1e40af}.attachment-item.invoice-row-received.active{background:#ffefe3;border-color:#f59e75;color:#c2410c}.attachment-item.invoice-row.invoice-row-compact .att-name{align-self:center}.attachment-item.invoice-row.invoice-row-compact .att-actions{align-self:end}.invoice-info-card{min-width:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px 8px;padding:8px 10px;border:1px solid #e5e7eb;border-radius:8px;background:#fff}.invoice-info-card-invoice{border-color:#d9d9d9}.invoice-info-card-received{border-color:#f5c3ad;background:#fffaf7}.invoice-info-title{grid-column:1 / -1;font-size:12px;line-height:1.2;font-weight:600;color:#4b5563}.invoice-amount-field{display:grid;justify-items:start;gap:2px}.invoice-amount-field span{font-size:11px;color:#9ca3af;line-height:1.2;white-space:nowrap}.invoice-remark-field{grid-column:1 / -1}.invoice-amount-input,.received-amount-input,.invoice-date-input,.invoice-remark-input{width:100%;box-sizing:border-box}.invoice-remark-input{height:28px;border:1px solid #d1d5db;border-radius:6px;padding:0 8px;font-size:12px;color:#0f172a;background:#fff}.lease-days-multi-hint{display:block;margin-top:4px;color:#6b7280;font-size:12px;line-height:1.4}.att-actions{flex-shrink:0;display:flex;gap:2px;margin-left:4px}.icon-button.tiny{width:24px;height:24px;font-size:13px;border-radius:4px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#9ca3af;cursor:pointer;transition:color .15s,background .15s}.icon-button.tiny:hover{color:#3b82f6;background:#f0f5ff}.icon-button.tiny.active{color:#2563eb;background:#e8f0ff}.preview-header-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.preview-header-row h3{margin:0;font-size:15px;line-height:1.4;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.back-to-contract-btn{flex-shrink:0;display:flex;align-items:center;gap:4px;font-size:13px;color:#3b82f6;background:transparent;border:1px solid #bfdbfe;border-radius:6px;padding:4px 10px;cursor:pointer;transition:background .15s}.back-to-contract-btn:hover{background:#eff6ff}.image-preview-wrap{width:100%;height:100%;overflow:auto;display:flex;justify-content:center;align-items:flex-start;padding:12px}.image-preview-wrap img{max-width:100%;height:auto;border-radius:4px;box-shadow:0 2px 8px #00000014}.other-file-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:100%;color:#9ca3af}.other-file-wrap p{margin:0;font-size:14px}.upload-trigger.disabled{opacity:.5;cursor:not-allowed}.attachment-empty{color:#9ca3af;font-size:13px;padding:4px 2px}.file-type-hint{display:block;font-size:11px;color:#b0b8c4;margin-top:-2px}.docx-preview-viewer{display:grid;grid-template-rows:auto 1fr;height:100%;overflow:hidden}.docx-preview-body{overflow:auto;background:#f7f8fa;padding:0}.docx-preview-body .docx-wrapper{padding:16px;background:#fff}.docx-preview-body .docx-wrapper>section.docx{box-shadow:0 1px 4px #00000014;margin:0 auto 16px;padding:40px 50px}.sheet-preview-viewer{display:grid;grid-template-rows:auto auto 1fr;height:100%;overflow:hidden}.sheet-tabs{display:flex;flex-wrap:wrap;gap:6px;padding:8px 10px;border-bottom:1px solid #e8edf3;background:#fff}.sheet-tabs button{border:1px solid #d8dfe8;background:#fff;border-radius:8px;color:#4b5563;font-size:12px;padding:4px 10px;cursor:pointer}.sheet-tabs button.active{border-color:#ff875e;color:#ff875e;background:#fff7f3}.sheet-preview-body{overflow:auto;background:#f7f8fa}.sheet-table-wrap{min-width:100%;padding:10px}.sheet-table{border-collapse:collapse;width:max-content;min-width:100%;background:#fff}.sheet-table td{border:1px solid #e5e7eb;padding:6px 8px;font-size:12px;color:#374151;white-space:pre-wrap;word-break:break-all}.reminder-modal-list{display:grid;gap:10px;max-height:420px;overflow:auto;margin-top:8px}.reminder-modal-summary{border-radius:8px;background:#f3f6fb;color:#4b5563;font-size:12px;padding:8px 10px}.reminder-modal-item{border:1px solid #eceff3;border-radius:8px;padding:10px 12px;display:grid;gap:4px;background:#fff;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.reminder-modal-item:hover,.reminder-modal-item:focus-visible{border-color:#91caff;box-shadow:0 0 0 3px #1677ff1f;outline:none}.reminder-modal-item:active{transform:translateY(1px)}.reminder-modal-item.urgent{border-color:#ffd1c2;background:#fff8f5}.reminder-modal-item strong{color:#1f2937;font-size:14px;font-weight:500}.reminder-modal-item span{color:#6b7280;font-size:13px}.reminder-modal-desc{color:#4b5563;font-size:12px;line-height:1.55}.reminder-modal-item em{color:#f46a3d;font-style:normal;font-size:12px}.extract-form-grid{display:grid;gap:10px}.extract-form-grid label{display:grid;gap:6px}.extract-form-grid span{font-size:13px;color:#6b7280}.extract-form-grid input{height:38px;border-radius:8px;border:1px solid #dfe5ee;padding:0 10px;outline:none;font-size:14px}.extract-form-grid textarea{min-height:80px;border-radius:8px;border:1px solid #dfe5ee;padding:8px 10px;outline:none;font-size:14px;resize:vertical;font-family:inherit}.extract-form-grid input:focus,.extract-form-grid textarea:focus{border-color:#ff875e}.annex-table-section{display:grid;gap:8px}.annex-table-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.annex-table-wrap{overflow:auto;border-radius:8px}.annex-table{min-width:100%;background:#fff}.annex-table .ant-table-cell{padding:6px 8px;font-size:12px;color:#374151;white-space:pre-wrap;vertical-align:top;word-break:break-word}.annex-table .ant-table-tbody>tr.annex-row-header>td{background:#f3f4f6;font-weight:600;color:#1f2937}.annex-header-cell{font-weight:600}.annex-cell-input{width:100%;min-height:32px;border:1px solid transparent;border-radius:6px;padding:4px 6px;font-size:12px;color:#374151;background:#fff;outline:none;resize:vertical;line-height:1.45;font-family:inherit;white-space:pre-wrap;word-break:break-word;resize:none;overflow-y:auto}.annex-cell-input:focus{border-color:#ff875e;background:#fffaf7}.annex-cell-readonly{min-height:32px;line-height:1.45;white-space:pre-wrap;word-break:break-word}.save-button{margin-top:4px;height:40px;border:0;border-radius:10px;background:#ff875e;color:#fff;font-size:14px;cursor:pointer}.save-button:disabled{opacity:.72;cursor:not-allowed}.upload-page-panel{background:#fff;border:1px solid #e8edf3;border-radius:12px;box-shadow:0 8px 20px #1418280a;padding:16px;display:grid;gap:14px}.upload-area{min-height:180px;border:1px dashed #d6dde8;border-radius:12px;background:#f9fbfe;display:grid;place-items:center;text-align:center;gap:6px;cursor:pointer}.upload-area input{display:none}.upload-area strong{color:#1f2937;font-size:16px}.upload-area span{color:#6b7280;font-size:13px}.selected-upload-file{color:#4b5563;font-size:13px}.upload-loading-modal{display:grid;gap:12px;padding:12px 4px}.upload-loading-modal strong{color:#111827;font-size:18px}.upload-loading-modal span{color:#6b7280;font-size:14px;line-height:1.5}.upload-loading-modal .upload-hint{font-size:12px;color:#9ca3af}.upload-progress-bar{height:6px;border-radius:3px;background:#f0f1f4;overflow:hidden}.upload-progress-bar-inner{height:100%;border-radius:3px;background:linear-gradient(90deg,#ff875e,#ffb088,#ff875e);background-size:200% 100%;animation:upload-progress-slide 1.5s ease-in-out infinite;width:60%}@keyframes upload-progress-slide{0%{background-position:200% 0}to{background-position:-200% 0}}.more-page-list{display:grid;gap:16px}.more-page-card{background:#fff;border:1px solid #e8edf3;border-radius:12px;box-shadow:0 8px 20px #1418280a;padding:14px 16px;display:flex;align-items:center;justify-content:space-between}.more-page-card h3{margin:0 0 4px;font-size:16px;color:#1f2937}.more-page-card>div>span{font-size:13px;color:#9ca3af}.dashboard-footer-placeholder{height:72px;border-top:1px solid #e6e9ef;background:#f5f6f8;margin-top:8px}.change-password-form{display:flex;flex-direction:column;gap:12px;margin-top:8px}.change-password-note{margin:0;font-size:12px;color:#6b7280}.change-password-emphasis{margin:0;padding:8px 10px;border-radius:8px;background:#fff4ef;color:#c2410c;font-size:12px;line-height:1.5}.change-password-form label{display:flex;flex-direction:column;gap:6px}.change-password-form label span{font-size:13px;color:#4b5563}.change-password-form input{height:40px;border:1px solid #e5e7eb;border-radius:8px;padding:0 12px;font-size:14px;color:#111827;outline:none}.change-password-form input:focus{border-color:#ffb79e;box-shadow:0 0 0 3px #ff875e24}@media (max-width: 1024px){.top-menu,.toolbar,.project-grid{padding-left:16px;padding-right:16px}.top-menu-left nav{gap:16px}.top-nav-link{font-size:15px}.view-tabs{width:100%;grid-template-columns:repeat(3,1fr)}.toolbar{flex-wrap:wrap}.toolbar-center{position:static;transform:none;width:100%;order:3;justify-content:flex-start}.project-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.project-card{width:100%}.node-text strong{font-size:16px}.node-text span{font-size:12px}.subpage{padding-left:16px;padding-right:16px}.calendar-board{min-height:620px}.calendar-grid{grid-template-rows:repeat(6,minmax(70px,1fr))}.calendar-day{font-size:18px}.attachment-item.invoice-row{grid-template-columns:auto minmax(0,1fr);row-gap:8px}.attachment-item.invoice-row.invoice-row-compact{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:flex-start}.att-actions{grid-column:1 / -1;justify-content:flex-end}.detail-invoice-add-form{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.detail-record-type-group{grid-column:1 / -1;width:fit-content}.detail-save-record-button{width:100%}.detail-record-remark-input{grid-column:1 / -1}.invoice-inline-fields{grid-column:1 / -1;grid-template-columns:1fr}.contact-item{grid-template-columns:1fr;gap:4px}.detail-files-layout,.compare-layout{grid-template-columns:1fr}.file-preview-box{min-height:220px}}.file-attachment-panel,.extract-form-panel{grid-template-rows:none;align-content:start;overflow:auto;gap:10px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f5f6f8;padding:24px}.login-card{width:420px;max-width:100%;background:#fff;border-radius:16px;border:1px solid #eceff3;box-shadow:0 12px 36px #0f172a14;padding:36px 34px 32px}.login-header{text-align:center;margin-bottom:28px}.login-header h1{font-size:32px;font-weight:700;color:#1b1f24;margin:0 0 8px;letter-spacing:2px}.login-header p{font-size:15px;color:#6b7280;margin:0}.login-form{display:flex;flex-direction:column;gap:18px}.login-field{display:flex;flex-direction:column;gap:8px}.login-field label{font-size:14px;font-weight:500;color:#4b5563}.login-field input{height:46px;padding:0 16px;border:1px solid #e6e9ef;border-radius:10px;font-size:15px;color:#1b1f24;outline:none;background:#fff;transition:border-color .2s,box-shadow .2s}.login-field input:focus{border-color:#ffb79e;box-shadow:0 0 0 3px #ff875e24}.login-field input::placeholder{color:#9ca3af}.login-submit{height:46px;margin-top:4px;border:none;border-radius:10px;background:#ff875e;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s,transform .2s}.login-submit:hover:not(:disabled){background:#f46a3d;transform:translateY(-1px)}.login-submit:disabled{background:#f9b9a0;cursor:not-allowed;transform:none}.login-role-hint{margin:-2px 0 0;font-size:13px;color:#6b7280;text-align:center}:root{font-family:PingFang SC,Microsoft YaHei,Inter,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;background:radial-gradient(circle at 0% 0%,#eef1ff,#f3f7ff,#f7f9ff 50%,#f8fbff);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;background:radial-gradient(circle at 0% 0%,#eef1ff,#f3f7ff,#f7f9ff 50%,#f8fbff)}button{font-family:inherit}
