:root{color-scheme:light;font-family:Inter,PingFang SC,Microsoft YaHei,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:var(--ink);background:var(--canvas);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--primary: #397ccf;--primary-deep: #236bb9;--primary-soft: #eef6ff;--accent: #ea6762;--accent-deep: #d65350;--accent-soft: #fff0ef;--on-primary: #ffffff;--canvas: #ffffff;--surface-soft: #f3f8fe;--ink-deep: #0a1317;--ink: #1c1e21;--charcoal: #444950;--slate: #4b4c4f;--steel: #5d6c7b;--stone: #8595a4;--hairline: #ced0d4;--hairline-soft: #dee3e9;--shadow-panel: rgba(57, 124, 207, .16) 0 1px 4px;--shadow-floating: 0 18px 42px rgba(57, 124, 207, .12);--focus-ring: rgba(57, 124, 207, .18)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed}#app{min-height:100vh}.page{min-height:100vh;background:linear-gradient(180deg,#397ccf12 0,#ea676209 360px),var(--canvas)}.top-nav{display:flex;align-items:center;justify-content:space-between;gap:24px;width:min(1180px,calc(100% - 32px));margin:0 auto;padding:20px 0}.brand{display:inline-flex;align-items:center;gap:12px;min-width:0}.brand strong,.brand small{display:block}.brand strong{font-size:17px;letter-spacing:0}.brand small{color:var(--steel);font-size:12px}.top-nav__links{display:flex;align-items:center;gap:14px;color:var(--steel);font-size:14px}.top-nav__links a.router-link-active{color:var(--primary);font-weight:700}.public-layout,.admin-layout,.narrow-layout,.login-layout{width:min(1180px,calc(100% - 32px));margin:0 auto}.public-layout{display:grid;grid-template-columns:minmax(260px,.8fr) minmax(320px,1.2fr);gap:32px;align-items:start;padding:48px 0 80px}.public-layout--single{grid-template-columns:minmax(0,1fr)}.public-layout--single .upload-panel{width:min(100%,720px);justify-self:center}.narrow-layout,.login-layout{max-width:760px;padding:48px 0 80px}.admin-layout{padding:28px 0 72px}.public-intro{padding-top:20px}.eyebrow{margin:0 0 8px;color:var(--primary);font-size:13px;font-weight:800;letter-spacing:0}h1,h2,p{overflow-wrap:anywhere}h1{margin:0;color:var(--ink-deep);font-size:44px;line-height:1.08;letter-spacing:0}h2{margin:0 0 18px;color:var(--ink-deep);font-size:20px;letter-spacing:0}.public-intro p:last-child{max-width:520px;color:var(--steel);font-size:17px}.panel{border:1px solid var(--hairline-soft);border-radius:8px;background:var(--canvas);box-shadow:var(--shadow-floating)}.upload-panel,.login-panel,.panel{padding:24px}.login-panel h1{margin-bottom:24px;font-size:32px;line-height:1.12}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}label{display:grid;gap:7px;margin-bottom:16px;color:var(--ink);font-size:14px;font-weight:700}input,textarea,select{width:100%;min-height:44px;border:1px solid var(--hairline);border-radius:6px;padding:10px 12px;color:var(--ink);background:var(--canvas);outline:none}textarea{resize:vertical}input:focus,textarea:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--focus-ring)}.file-picker{display:grid;min-height:132px;place-items:center;gap:6px;border:1px dashed var(--stone);border-radius:8px;padding:24px;color:var(--ink);background:var(--surface-soft);text-align:center;transition:border-color .16s ease,background .16s ease,box-shadow .16s ease}.file-picker--dragging{border-color:var(--primary);background:var(--primary-soft);box-shadow:0 0 0 3px var(--focus-ring)}.file-picker input,.compact-upload input{display:none}.hidden-file-input{position:fixed;width:1px;height:1px;opacity:0;pointer-events:none}.file-picker span{font-weight:800}.file-picker small{color:var(--steel);font-weight:500}.file-list{display:grid;gap:8px;margin-bottom:16px}.file-row,.download-row{display:grid;grid-template-columns:22px minmax(0,1fr) auto;gap:10px;align-items:center;min-height:46px;border:1px solid var(--hairline-soft);border-radius:6px;padding:10px 12px;color:var(--ink);background:var(--canvas)}.file-row span,.download-row span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-row small,.download-row small{color:var(--steel)}.download-row:hover{border-color:var(--primary);background:var(--primary-soft)}.primary-btn,.secondary-btn,.text-button,.compact-upload{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;border-radius:6px;padding:0 14px;border:1px solid transparent;font-weight:800;letter-spacing:0}.primary-btn{color:var(--on-primary);background:var(--primary)}.primary-btn:hover:not(:disabled){background:var(--primary-deep)}.secondary-btn,.compact-upload{color:var(--ink);border-color:var(--hairline);background:var(--canvas)}.secondary-btn:hover:not(:disabled),.compact-upload:hover{border-color:var(--primary);color:var(--primary)}.text-button{color:var(--steel);border:0;background:transparent}.full-width{width:100%}.message{border-radius:6px;padding:11px 12px;color:var(--ink);background:var(--surface-soft)}.message--error{color:var(--accent-deep);background:var(--accent-soft)}.message--success{color:var(--primary-deep);background:var(--primary-soft)}.share-box{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:end;margin:18px 0}.share-box label{margin:0}.public-task-panel{display:grid;gap:18px}.public-task-heading,.public-task-meta,.pagination-controls{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.public-task-heading h2,.public-task-item h3,.public-file-group h4{margin:0;color:var(--ink-deep)}.public-task-heading p,.public-task-item p{margin:4px 0 0;color:var(--steel)}.public-task-search{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:12px;align-items:end}.public-task-search label{margin:0}.public-task-list{display:grid;gap:10px}.public-task-row{display:grid;grid-template-columns:minmax(130px,1.2fr) repeat(auto-fit,minmax(104px,1fr));gap:10px;align-items:center;min-height:70px;border:1px solid var(--hairline-soft);border-radius:8px;padding:12px;background:var(--canvas)}.public-task-row:hover{border-color:var(--primary);box-shadow:0 10px 24px #24569d14}.public-task-name{min-width:0}.public-task-name strong,.public-task-name small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.public-task-name strong{color:var(--ink-deep);font-size:16px}.public-task-name small{margin-top:3px;color:var(--steel);font-size:12px}.task-action-box,.task-state-button,.task-delete-button{display:inline-flex;align-items:center;justify-content:center;gap:7px;width:100%;min-height:42px;border:1px solid var(--hairline);border-radius:6px;padding:0 10px;background:var(--canvas);color:var(--ink);font-size:13px;font-weight:800;letter-spacing:0;white-space:nowrap}.task-action-box span{display:-webkit-box;overflow:hidden;text-overflow:ellipsis;white-space:normal;line-height:1.15;-webkit-line-clamp:2;-webkit-box-orient:vertical}.task-action-box svg{flex:0 0 auto}.task-action-box:hover:not(:disabled),.task-state-button:hover:not(:disabled){border-color:var(--primary);color:var(--primary);background:var(--primary-soft)}.task-action-box:disabled{cursor:not-allowed;color:var(--stone);background:var(--surface-soft)}.task-action-box--upload{border-color:transparent;color:var(--primary-deep);background:var(--primary-soft)}.task-state-button{min-width:0;min-height:52px;padding-block:7px;color:var(--accent-deep);background:var(--accent-soft);border-color:transparent;line-height:1.15;text-align:center;white-space:normal;overflow-wrap:anywhere}.task-state-button--paid{color:var(--primary-deep);background:var(--primary-soft)}.task-delete-button{min-width:0;min-height:52px;width:100%;padding-block:7px;color:var(--accent-deep);border-color:transparent;background:var(--accent-soft);line-height:1.15;text-align:center;white-space:normal;overflow-wrap:anywhere}.task-delete-button:hover{color:#fff;background:var(--accent-deep)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;padding:20px;background:#0a13175c}.password-modal{width:min(100%,420px);border:1px solid var(--hairline-soft);border-radius:8px;padding:22px;background:var(--canvas);box-shadow:0 20px 60px #0a13173d}.password-modal h2{margin-bottom:8px}.password-modal p{margin:0 0 14px;color:var(--steel)}.password-modal .message{margin-top:12px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}.pagination-controls{align-items:center;padding-top:4px}.pagination-controls span{color:var(--steel);font-size:14px;font-weight:700}.panel-heading,.section-header,.detail-header,.panel-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:18px}.panel-heading h1,.section-header h1,.detail-header h1{font-size:34px;line-height:1.1}.detail-header{margin-bottom:20px}.detail-header p:last-child{max-width:760px;color:var(--steel)}.detail-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.detail-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:22px 0}.detail-list div,.summary-item{border:1px solid var(--hairline-soft);border-radius:6px;padding:14px;background:var(--surface-soft)}.detail-list dt,.summary-item span{color:var(--steel);font-size:13px}.detail-list dd{margin:4px 0 0;color:var(--ink-deep);font-weight:800}.description-text{color:var(--steel);white-space:pre-wrap}.file-section{margin-top:24px}.empty-state{margin:12px 0;color:var(--steel)}.toolbar{display:grid;grid-template-columns:minmax(260px,1fr) 160px 160px auto;gap:12px;align-items:end;margin:24px 0}.search-field{position:relative;margin:0}.search-field svg{position:absolute;left:12px;bottom:13px;color:var(--steel)}.search-field input{padding-left:40px}.table-wrap{overflow-x:auto;border:1px solid var(--hairline-soft);border-radius:8px;background:var(--canvas)}.task-table{width:100%;min-width:860px;border-collapse:collapse}.task-table th,.task-table td{border-bottom:1px solid var(--hairline-soft);padding:14px 16px;text-align:left;vertical-align:middle}.task-table th{color:var(--steel);font-size:13px;font-weight:800;background:var(--surface-soft)}.task-table tbody tr{cursor:pointer}.task-table tbody tr:hover{background:var(--primary-soft)}.task-table td strong,.task-table td small{display:block}.task-table td small{margin-top:2px;color:var(--steel)}.status-badge{display:inline-flex;align-items:center;min-height:28px;border-radius:999px;padding:4px 10px;font-size:13px;font-weight:800;white-space:nowrap}.status-badge--pending{color:var(--accent-deep);background:var(--accent-soft)}.status-badge--done,.status-badge--paid{color:var(--primary-deep);background:var(--primary-soft)}.status-badge--unpaid{color:var(--accent-deep);background:var(--accent-soft)}.load-more{display:flex;justify-content:center;margin-top:18px}.back-link{display:inline-flex;align-items:center;gap:8px;margin-bottom:22px;color:var(--primary);font-weight:800}.summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:22px}.summary-item{display:grid;gap:8px}.summary-item strong{color:var(--ink-deep)}.two-column{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.compact-upload{min-height:36px;font-size:14px}.file-list--compact{margin:8px 0 14px}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:860px){.top-nav,.top-nav__links,.panel-heading,.section-header,.detail-header,.panel-title-row{align-items:stretch;flex-direction:column}.public-layout,.two-column,.summary-grid,.detail-list,.form-grid,.toolbar,.public-task-search,.public-task-row,.share-box{grid-template-columns:1fr}.public-layout{padding-top:20px}h1{font-size:34px}.panel-heading h1,.section-header h1,.detail-header h1{font-size:28px}.detail-actions,.top-nav__links,.public-task-heading,.public-task-meta,.pagination-controls{justify-content:flex-start}.public-task-heading,.pagination-controls{flex-direction:column}.task-delete-button{width:100%}}@media(max-width:520px){.top-nav,.public-layout,.admin-layout,.narrow-layout,.login-layout{width:min(100% - 20px,1180px)}.upload-panel,.login-panel,.panel{padding:18px}.primary-btn,.secondary-btn,.compact-upload{width:100%}}.public-task-row{display:grid;grid-template-columns:minmax(170px,220px) minmax(0,1fr);gap:12px 18px;align-items:start;padding:18px 20px}.public-task-name{min-width:0;padding-top:4px}.public-task-file-actions,.public-task-status-actions{display:grid;min-width:0;gap:10px}.public-task-file-actions{grid-template-columns:repeat(6,minmax(118px,190px));justify-content:start}.public-task-status-actions{grid-template-columns:repeat(3,minmax(128px,176px));justify-content:start}.public-task-file-actions .task-action-box,.public-task-status-actions .task-state-button,.public-task-status-actions .task-delete-button{width:100%;height:auto;min-height:58px}.task-action-box,.task-state-button,.task-delete-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:normal;text-align:center;line-height:1.1}.task-action-box span,.task-state-button span,.task-delete-button span{display:block;min-width:0;max-width:none;overflow:visible;text-overflow:unset;white-space:normal}.task-action-box svg,.task-state-button svg,.task-delete-button svg{flex:0 0 auto}.task-state-button,.task-delete-button{padding:10px 14px;font-size:15px}@media(max-width:1120px){.public-task-file-actions{grid-template-columns:repeat(3,minmax(120px,1fr))}}@media(max-width:900px){.public-task-row{grid-template-columns:1fr}.public-task-file-actions{grid-template-columns:repeat(2,minmax(120px,1fr))}.public-task-status-actions{grid-template-columns:repeat(3,minmax(0,1fr))}}.login-layout--gate{max-width:1040px}.login-shell{display:grid;grid-template-columns:minmax(280px,.9fr) minmax(320px,1fr);gap:22px;align-items:stretch}.login-hero{display:grid;align-content:space-between;min-height:520px;overflow:hidden;background:radial-gradient(circle at 20% 18%,rgba(57,124,207,.2),transparent 34%),linear-gradient(145deg,#397ccf1f,#ea676214),var(--canvas)}.login-hero h1{max-width:420px;margin-bottom:14px;font-size:42px}.brand-red{color:var(--accent-deep)}.login-hero p:not(.eyebrow){max-width:420px;margin:0;color:var(--steel);font-size:16px;line-height:1.55}.login-panel--gate{display:grid;align-content:center;min-height:520px}.login-panel--gate h1{margin-bottom:26px}.captcha-row{display:grid;grid-template-columns:minmax(0,1fr) 150px;gap:12px;align-items:end}.captcha-row label{margin-bottom:0}.captcha-code{position:relative;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:44px;border:1px dashed rgba(57,124,207,.42);border-radius:10px;color:var(--primary-deep);background:linear-gradient(135deg,#397ccf1f,#ffffffdb),var(--surface-soft);font-weight:900;letter-spacing:.16em}.captcha-code:before,.captcha-code:after{position:absolute;top:0;right:0;bottom:0;left:0;content:"";pointer-events:none}.captcha-code:before{background:radial-gradient(circle at 14px 12px,rgba(219,84,79,.2) 0 1px,transparent 1.5px),radial-gradient(circle at 54px 30px,rgba(57,124,207,.24) 0 1px,transparent 1.5px),radial-gradient(circle at 106px 18px,rgba(15,23,42,.14) 0 1px,transparent 1.5px);background-size:28px 19px,31px 23px,37px 29px;opacity:.75}.captcha-code:after{background:linear-gradient(17deg,transparent 24%,rgba(219,84,79,.32) 25%,transparent 27%),linear-gradient(-12deg,transparent 58%,rgba(57,124,207,.36) 60%,transparent 62%),linear-gradient(83deg,transparent 44%,rgba(15,23,42,.18) 45%,transparent 47%);mix-blend-mode:multiply}.captcha-visual{position:relative;z-index:1;display:inline-flex;align-items:center;justify-content:center;gap:2px;min-width:70px;letter-spacing:0}.captcha-visual i{display:inline-block;color:var(--primary-deep);font-style:normal;text-shadow:1px 0 rgba(219,84,79,.28),-1px 1px rgba(57,124,207,.2);transform:translate(var(--x),var(--y)) rotate(var(--r)) skew(-8deg)}.captcha-code svg{position:relative;z-index:1;letter-spacing:0}.remember-row{display:inline-flex;grid-template-columns:none;align-items:center;gap:10px;margin:14px 0 18px;color:var(--steel);font-size:13px}.remember-row input{width:18px;min-height:18px;accent-color:var(--primary)}@media(max-width:860px){.login-shell{grid-template-columns:1fr}.login-hero,.login-panel--gate{min-height:auto}}@media(max-width:520px){.captcha-row{grid-template-columns:1fr}.captcha-code{width:100%}}.public-top-grid{display:grid;grid-template-columns:minmax(0,720px) minmax(320px,1fr);gap:24px;align-items:stretch}.public-layout--single .public-top-grid .upload-panel{width:100%;justify-self:stretch}.task-dashboard{display:grid;gap:18px;align-content:start;min-height:100%}.task-dashboard__header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.task-dashboard__header p{margin:0 0 4px;color:var(--primary);font-size:13px;font-weight:800}.task-dashboard__header h2{margin:0}.task-dashboard__header small{color:var(--steel);font-size:12px;font-weight:700;text-align:right}.task-dashboard__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.task-dashboard__item{display:grid;grid-template-columns:auto 1fr;gap:6px 10px;align-items:center;min-height:96px;border:1px solid var(--hairline-soft);border-radius:10px;padding:14px;background:var(--surface-soft)}.task-dashboard__item svg{color:var(--primary)}.task-dashboard__item span{color:var(--steel);font-size:13px;font-weight:800;line-height:1.18}.task-dashboard__item strong{grid-column:1 / -1;color:var(--ink-deep);font-size:30px;line-height:1}.task-dashboard__item small{grid-column:1 / -1;color:var(--accent-deep);font-size:11px;font-weight:700}.task-dashboard__item--total{grid-column:1 / -1;min-height:110px;background:linear-gradient(135deg,var(--primary-soft),var(--canvas))}.task-dashboard__item--late,.task-dashboard__item--unpaid{background:var(--accent-soft)}.task-dashboard__item--late svg,.task-dashboard__item--unpaid svg{color:var(--accent-deep)}@media(max-width:980px){.public-top-grid{grid-template-columns:1fr}}@media(max-width:520px){.task-dashboard__header{display:grid}.task-dashboard__header small{text-align:left}.task-dashboard__grid{grid-template-columns:1fr}}.public-task-row{grid-template-columns:minmax(176px,220px) minmax(480px,1fr) minmax(190px,230px);gap:18px;align-items:stretch;border-color:#397ccf38;border-left:4px solid var(--primary);border-radius:14px;padding:18px;background:linear-gradient(135deg,#397ccf0e,#fff0 44%),var(--canvas);box-shadow:0 16px 38px #182d4c14}.public-task-row:hover{transform:translateY(-1px);border-color:#397ccf6b;box-shadow:0 20px 46px #182d4c1f}.public-task-name{display:grid;align-content:start;gap:8px;padding:4px 18px 4px 0;border-right:1px solid var(--hairline-soft)}.public-task-name strong{font-size:18px;line-height:1.15}.public-task-name small{font-size:13px}.public-task-name .task-delete-button{width:100%;margin-top:18px}.public-task-file-actions{grid-template-columns:repeat(3,minmax(148px,1fr));gap:10px;align-content:start}.public-task-status-actions{grid-template-columns:1fr;gap:10px;align-content:start}.public-task-file-actions .task-action-box{min-height:58px;border-radius:12px;padding:10px 12px;font-size:14px}.public-task-status-actions .task-state-button,.public-task-status-actions .task-delete-button{min-height:52px;border-radius:12px;padding:10px 14px;font-size:14px}.public-task-file-actions,.public-task-status-actions{grid-auto-rows:58px}.public-task-file-actions .task-action-box,.public-task-status-actions .task-state-button,.public-task-name .task-delete-button{height:58px;min-height:58px}.task-action-box,.task-state-button,.task-delete-button{transition:transform .16s ease,border-color .16s ease,background .16s ease,color .16s ease,box-shadow .16s ease}.task-action-box:hover:not(:disabled),.task-state-button:hover:not(:disabled),.task-delete-button:hover:not(:disabled){transform:translateY(-1px)}.task-action-box--upload{border-color:#397ccf14;background:linear-gradient(180deg,var(--primary-soft),rgba(57,124,207,.08))}.task-action-box:not(.task-action-box--upload):not(:disabled){background:linear-gradient(180deg,#fff,#f8fafce0)}.task-action-box:disabled{border-color:#5b6b802e;background:#f1f5f9c7}.task-state-button,.task-delete-button{justify-content:flex-start;text-align:left;overflow-wrap:normal;word-break:keep-all}.task-state-button span,.task-delete-button span{overflow-wrap:normal;word-break:keep-all;white-space:normal}.task-state-button{border:1px solid rgba(219,84,79,.1)}.task-state-button--paid{border-color:#397ccf1f}.task-delete-button{border:1px solid rgba(219,84,79,.1)}@media(max-width:1180px){.public-task-row{grid-template-columns:minmax(160px,210px) minmax(0,1fr)}.public-task-name{grid-row:1 / span 2}.public-task-file-actions,.public-task-status-actions{grid-column:2}.public-task-status-actions{grid-template-columns:repeat(2,minmax(150px,1fr))}}@media(max-width:860px){.public-task-row{grid-template-columns:1fr}.public-task-name{grid-row:auto;padding:0 0 14px;border-right:0;border-bottom:1px solid var(--hairline-soft)}.public-task-file-actions,.public-task-status-actions{grid-column:auto}}@media(max-width:640px){.public-task-file-actions,.public-task-status-actions{grid-template-columns:1fr}}
