.team-page{background:#f4f7fb;min-height:100vh;padding:24px}.team-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.team-header h1{color:#111827;font-size:34px;font-weight:700}.team-header p{color:#6b7280;margin-top:6px;font-size:14px}.invite-btn{color:#fff;cursor:pointer;background:#1677ff;border:none;border-radius:12px;align-items:center;gap:10px;height:48px;padding:0 20px;font-weight:600;transition:all .2s;display:flex}.invite-btn:hover{opacity:.9}.search-wrapper{background:#fff;border:1px solid #e5e7eb;border-radius:14px;align-items:center;gap:12px;height:52px;margin-bottom:24px;padding:0 18px;display:flex}.search-wrapper input{background:0 0;border:none;outline:none;flex:1;font-size:15px}.team-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-bottom:28px;display:grid}.team-card{background:#fff;border:1px solid #e5e7eb;border-radius:20px;padding:22px;transition:all .2s}.team-card:hover{transform:translateY(-3px);box-shadow:0 10px 30px #0000000f}.team-top{align-items:center;gap:14px;display:flex}.team-avatar{color:#fff;background:linear-gradient(135deg,#1677ff,#8db8ff);border-radius:18px;justify-content:center;align-items:center;width:56px;height:56px;font-size:22px;font-weight:700;display:flex}.team-top h3{color:#111827;margin-bottom:4px;font-size:22px}.team-top p{color:#6b7280;font-size:14px}.team-members{color:#6b7280;align-items:center;gap:8px;margin-top:22px;font-size:14px;display:flex}.team-actions{gap:12px;margin-top:22px;display:flex}.edit-btn,.delete-btn,.save-btn,.cancel-btn{cursor:pointer;border:none;border-radius:10px;height:42px;padding:0 16px;font-weight:600}.edit-btn{color:#1677ff;background:#edf4ff}.delete-btn{color:#ef4444;background:#fff0f0}.save-btn{color:#fff;background:#1677ff}.cancel-btn{color:#111827;background:#eef2f7}.team-table-wrapper{background:#fff;border:1px solid #e5e7eb;border-radius:22px;overflow:hidden}.table-header{border-bottom:1px solid #e5e7eb;padding:22px}.table-header h2{color:#111827;font-size:24px}.team-table{border-collapse:collapse;width:100%}.team-table th{text-align:left;color:#6b7280;background:#f9fafb;padding:18px;font-size:14px}.team-table td{border-top:1px solid #f1f5f9;padding:18px;font-size:15px}.table-actions{gap:10px;display:flex}.loading{text-align:center;color:#6b7280;padding:24px}.modal{background:#fff;border-radius:24px;width:450px;padding:28px}.modal h2{margin-bottom:22px;font-size:28px}.form-group{flex-direction:column;margin-bottom:18px;display:flex}.form-group label{color:#374151;margin-bottom:8px;font-weight:600}.form-group input,.form-group textarea{border:1px solid #d1d5db;border-radius:12px;outline:none;padding:14px;font-size:15px}.modal-actions{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}.member-select{background:#fff;border:1px solid #dbe3ea;border-radius:10px;outline:none;width:100%;min-height:140px;padding:10px;font-size:14px}.member-select:focus{border-color:#2563eb}.member-select option{padding:8px}.member-hint{color:#64748b;margin-top:6px;font-size:12px;display:block}.team-member-list,.table-member-list{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.member-chip{color:#2563eb;background:#eff6ff;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:500}.no-members{color:#94a3b8;font-size:12px}.form-error{color:#e53e3e;margin-bottom:.5rem;font-size:.85rem}@media (width<=768px){.team-member-list,.table-member-list{gap:6px}.member-chip{padding:4px 8px;font-size:11px}.member-select{min-height:120px}}.vp-page{box-sizing:border-box;width:100%;max-width:100%;padding:16px 20px 40px}.vp-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.vp-title{color:#111827;letter-spacing:-.015em;font-size:21px;font-weight:600}.vp-meta{color:#9ca3af;margin-top:3px;font-size:12.5px}.vp-header-actions{flex-wrap:wrap;align-items:center;gap:9px;display:flex}.vp-btn-primary{color:#fff;cursor:pointer;white-space:nowrap;background:#2563eb;border:none;border-radius:8px;justify-content:center;align-items:center;gap:6px;height:36px;padding:0 16px;font-size:13px;font-weight:500;transition:background .15s;display:inline-flex}.vp-btn-primary:hover:not(:disabled){background:#1d4ed8}.vp-btn-primary:disabled{opacity:.65;cursor:not-allowed}.vp-btn-secondary{color:#374151;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #e5e7eb;border-radius:8px;justify-content:center;align-items:center;gap:6px;height:36px;padding:0 14px;font-size:13px;font-weight:500;transition:background .15s;display:inline-flex}.vp-btn-secondary:hover:not(:disabled){background:#f9fafb}.vp-btn-secondary:disabled{opacity:.65;cursor:not-allowed}.vp-filters{background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:14px;padding:10px 14px;display:flex}.vp-filter-search{flex:1;min-width:240px;position:relative}.vp-fsicon{color:#9ca3af;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.vp-fsInput{color:#111827;box-sizing:border-box;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;outline:none;width:100%;height:32px;padding:0 10px 0 30px;font-family:inherit;font-size:12.5px;transition:border-color .15s}.vp-fsInput::placeholder{color:#c0c4cc}.vp-fsInput:focus{border-color:#2563eb}.vp-drop-wrap{position:relative}.vp-filter-btn{color:#6b7280;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #e5e7eb;border-radius:6px;align-items:center;gap:5px;height:32px;padding:0 12px;font-family:inherit;font-size:12.5px;transition:background .12s,border-color .12s;display:inline-flex}.vp-filter-btn:hover{background:#f9fafb}.vp-filter-btn.active{color:#2563eb;border-color:#2563eb}.vp-dropdown{z-index:200;background:#fff;border:1px solid #e5e7eb;border-radius:8px;min-width:160px;position:absolute;top:calc(100% + 4px);left:0;overflow:hidden;box-shadow:0 4px 16px #00000014}.vp-ditem{color:#111827;cursor:pointer;padding:8px 14px;font-size:13px;transition:background .1s}.vp-ditem:hover{background:#f9fafb}.vp-ditem.sel{color:#2563eb;background:#eff6ff;font-weight:500}.vp-table-wrap{-webkit-overflow-scrolling:touch;background:#fff;border:1px solid #e5e7eb;border-radius:8px;width:100%;overflow:auto hidden}.vp-table{border-collapse:collapse;width:100%;min-width:1200px}.vp-table thead tr{background:#fafafa;border-bottom:1px solid #f0f1f3}.vp-table th{color:#9ca3af;text-align:left;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;padding:10px 14px;font-size:10.5px;font-weight:600}.th-check{width:40px}.vp-table tbody tr{cursor:pointer;border-bottom:1px solid #f0f1f3;transition:background .1s}.vp-table tbody tr:last-child{border-bottom:none}.vp-table tbody tr:hover{background:#fafbff}.vp-table tbody tr.row-sel{background:#eff6ff}.vp-table td{color:#111827;vertical-align:middle;white-space:nowrap;padding:12px 14px;font-size:13px}.td-check{width:40px}.vp-cb{accent-color:#2563eb;cursor:pointer;width:15px;height:15px}.project-code{color:#2563eb;font-weight:500}.site-cell{flex-direction:column;gap:2px;display:flex}.site-name{font-weight:500}.site-code{color:#9ca3af;font-size:11px}.date-cell{color:#6b7280;font-size:12.5px}.team-cell{align-items:center;gap:8px;display:flex}.badge-status{white-space:nowrap;border-radius:20px;align-items:center;gap:5px;padding:3px 9px;font-size:12px;font-weight:500;display:inline-flex}.badge-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.s-progress{color:#c2410c;background:#fff7ed}.s-assigned{color:#1d4ed8;background:#eff6ff}.s-quote{color:#6d28d9;background:#f5f3ff}.s-completed{color:#166534;background:#f0fdf4}.s-invoice{color:#1d4ed8;background:#eff6ff}.s-pending{color:#c2410c;background:#fff7ed}.s-paid{color:#166534;background:#f0fdf4}.badge-priority{letter-spacing:.04em;border-radius:5px;padding:3px 9px;font-size:11px;font-weight:600;display:inline-block}.p-high{color:#c2410c;background:#fff7ed;border:1px solid #fed7aa}.p-medium{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.p-low{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.p-critical{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca}.badge-worktype{color:#475569;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:5px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-block}.vp-loader,.vp-error,.vp-empty{text-align:center;padding:60px 20px;font-size:13.5px}.vp-loader{color:#6b7280;justify-content:center;align-items:center;gap:10px;display:flex}.vp-error{color:#b91c1c}.vp-empty{color:#9ca3af}tr.row-editing td{background:#eff6ff;border-bottom:none}.inline-edit-row td,.inline-edit-td{padding:0!important}.inline-edit-panel{background:#f8fafc;border:1.5px solid #3b82f6;border-top:none;border-radius:0 0 8px 8px;padding:16px 20px 20px;animation:.18s ie-slide-down}@keyframes ie-slide-down{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.inline-edit-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.inline-edit-title{color:#64748b;font-size:12px}.inline-edit-title strong{color:#0f172a;font-weight:600}.inline-edit-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px 16px;display:grid}.ie-field{flex-direction:column;gap:4px;display:flex}.ie-field span{color:#64748b;text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:500}.ie-field input,.ie-field select{color:#0f172a;background:#fff;border:1px solid #e2e8f0;border-radius:6px;outline:none;height:34px;padding:0 10px;font-size:13px;transition:border-color .15s}.ie-field input:focus,.ie-field select:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61f}.inline-edit-footer{border-top:1px solid #e2e8f0;justify-content:flex-end;gap:8px;margin-top:16px;padding-top:14px;display:flex}.vp-icon-btn.edit.active{color:#fff;background:#3b82f6}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:.8s linear infinite spin}@media (width<=1024px){.vp-page{padding:14px 16px 32px}.vp-table{min-width:1000px}.inline-edit-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.vp-page{padding:12px}.vp-header{flex-direction:column;align-items:stretch}.vp-header-actions{width:100%}.vp-btn-primary,.vp-btn-secondary{flex:1}.vp-filters{flex-direction:column;align-items:stretch}.vp-filter-search{width:100%;min-width:unset}.vp-drop-wrap{width:100%}.vp-filter-btn{justify-content:space-between;width:100%}.vp-dropdown{width:100%}.vp-table{min-width:900px}.inline-edit-grid{grid-template-columns:1fr}.inline-edit-footer{flex-direction:column}.inline-edit-footer .vp-btn-primary,.inline-edit-footer .vp-btn-secondary{width:100%}}@media (width<=576px){.vp-page{padding:10px}.vp-title{font-size:18px}.vp-meta{font-size:12px}.vp-header-actions{flex-direction:column}.vp-btn-primary,.vp-btn-secondary{width:100%}.vp-table{min-width:780px}.vp-table th,.vp-table td{padding:10px;font-size:12px}.team-avatar{width:22px;height:22px;font-size:10px}.badge-status,.badge-priority,.badge-worktype{font-size:10px}.inline-edit-panel{padding:12px}}.pd-page{box-sizing:border-box;width:100%;max-width:100%;padding:16px 20px 40px}.pd-back-btn{color:#374151;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:8px;align-items:center;gap:6px;height:34px;margin-bottom:18px;padding:0 14px;font-size:13px;font-weight:500;transition:background .15s;display:inline-flex}.pd-back-btn:hover{background:#f9fafb}.pd-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:20px;display:flex}.pd-title{color:#111827;letter-spacing:-.02em;margin:0 0 4px;font-size:22px;font-weight:700}.pd-code{color:#6b7280;font-size:13px;font-weight:500}.pd-header-badge{padding-top:4px}.pd-tabs{border-bottom:1px solid #e5e7eb;gap:0;margin-bottom:20px;display:flex}.pd-tab{color:#6b7280;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 22px;font-family:inherit;font-size:13.5px;font-weight:500;transition:color .15s,border-color .15s}.pd-tab:hover{color:#374151}.pd-tab.pd-tab-active{color:#6366f1;border-bottom-color:#6366f1;font-weight:600}.pd-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:16px;overflow:hidden}.pd-grid{grid-template-columns:1fr 1fr;display:grid}.pd-field{border-bottom:1px solid #f0f1f3;flex-direction:column;gap:5px;padding:14px 18px;display:flex}.pd-field:nth-child(odd){border-right:1px solid #f0f1f3}.pd-field-label{color:#9ca3af;text-transform:uppercase;letter-spacing:.06em;font-size:10.5px;font-weight:600}.pd-field-value{color:#111827;font-size:13.5px;font-weight:500}.pd-assignment-block{padding:20px 24px}.pd-assignment-header{color:#374151;border-bottom:1px solid #f0f1f3;margin-bottom:14px;padding-bottom:10px;font-size:13px;font-weight:600}.pd-assignment-status{color:#6b7280;font-weight:400}.pd-timeline{padding-left:24px;position:relative}.pd-timeline:before{content:"";background:#e5e7eb;border-radius:2px;width:2px;position:absolute;top:8px;bottom:8px;left:7px}.pd-timeline-item{margin-bottom:18px;position:relative}.pd-timeline-item:before{content:"";background:#6366f1;border:2px solid #fff;border-radius:50%;width:10px;height:10px;position:absolute;top:4px;left:-17px;box-shadow:0 0 0 2px #6366f1}.pd-timeline-date{color:#9ca3af;margin-bottom:3px;font-size:11px}.pd-timeline-status{color:#374151;margin-bottom:3px;font-size:12.5px;font-weight:600}.pd-timeline-note{color:#4b5563;font-size:13px;line-height:1.5}.pd-photo-section{margin-top:16px}.pd-photo-label{color:#9ca3af;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;font-size:11px;font-weight:600}.pd-photo-grid{flex-wrap:wrap;gap:8px;display:flex}.pd-photo-thumb{-o-object-fit:cover;object-fit:cover;cursor:pointer;border:1px solid #e5e7eb;border-radius:8px;width:60px;height:60px;transition:transform .15s,box-shadow .15s}.pd-photo-thumb:hover{transform:scale(1.06);box-shadow:0 4px 14px #00000026}.pd-expense-table-wrap{overflow-x:auto}.pd-expense-table{border-collapse:collapse;width:100%;font-size:13px}.pd-expense-table thead tr{background:#fafafa;border-bottom:1px solid #e5e7eb}.pd-expense-table th{text-align:left;color:#9ca3af;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;padding:10px 14px;font-size:10.5px;font-weight:600}.pd-expense-table tbody tr{border-bottom:1px solid #f0f1f3;transition:background .1s}.pd-expense-table tbody tr:last-child{border-bottom:none}.pd-expense-table tbody tr:hover{background:#fafbff}.pd-expense-table td{color:#111827;vertical-align:middle;padding:12px 14px}.pd-amount-cell{font-variant-numeric:tabular-nums;font-weight:500}.pd-expense-total{color:#111827;border-top:1px solid #e5e7eb;justify-content:flex-end;padding:14px 18px;font-size:14px;font-weight:600;display:flex}.pd-receipt-thumb{-o-object-fit:cover;object-fit:cover;cursor:pointer;border:1px solid #e5e7eb;border-radius:8px;width:60px;height:60px;transition:box-shadow .15s}.pd-receipt-thumb:hover{box-shadow:0 2px 10px #00000026}.pd-loader{color:#6b7280;justify-content:center;align-items:center;gap:10px;padding:48px 20px;font-size:13.5px;display:flex}.pd-empty{text-align:center;color:#9ca3af;padding:48px 20px;font-size:13.5px}@keyframes pd-spin{to{transform:rotate(360deg)}}.pd-spin{animation:.8s linear infinite pd-spin}@media (width<=768px){.pd-grid{grid-template-columns:1fr}.pd-field:nth-child(odd){border-right:none}.pd-tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}.pd-page{padding:12px 14px 32px}}@media (width<=576px){.pd-title{font-size:18px}.pd-header{flex-direction:column}.pd-expense-table{min-width:600px}}.np-header-left{align-items:flex-start;gap:12px;display:flex}.np-back-btn{color:#374151;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;margin-top:2px;transition:background .15s;display:inline-flex}.np-back-btn:hover{background:#f9fafb}.np-api-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:13px}.np-form-wrap{flex-direction:column;gap:20px;display:flex}.np-section{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:20px 20px 24px}.np-section-title{color:#111827;letter-spacing:-.01em;border-bottom:1px solid #f0f1f3;margin:0 0 16px;padding-bottom:12px;font-size:13.5px;font-weight:600}.np-grid{grid-template-columns:repeat(3,1fr);gap:14px 16px;display:grid}.np-field{flex-direction:column;gap:5px;display:flex}.np-field label{color:#374151;letter-spacing:.01em;font-size:12px;font-weight:500}.np-field.required>label:after{content:" *";color:#ef4444}.np-field input,.np-field select,.np-field textarea{color:#111827;box-sizing:border-box;background:#fff;border:1px solid #e5e7eb;border-radius:7px;outline:none;width:100%;height:36px;padding:0 10px;font-family:inherit;font-size:13px;transition:border-color .15s,box-shadow .15s}.np-field textarea{resize:vertical;height:auto;padding:8px 10px}.np-field input::-moz-placeholder{color:#c0c4cc}.np-field textarea::-moz-placeholder{color:#c0c4cc}.np-field input::placeholder,.np-field textarea::placeholder{color:#c0c4cc}.np-field input:focus,.np-field select:focus,.np-field textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.np-field.has-error input,.np-field.has-error select,.np-field.has-error textarea{border-color:#ef4444;box-shadow:0 0 0 3px #ef444414}.np-err{color:#dc2626;margin-top:2px;font-size:11.5px}.np-field-full{grid-column:1/-1}.np-field-toggle{justify-content:flex-start}.toggle{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;display:inline-flex}.toggle input[type=checkbox]{display:none}.toggle-track{background:#e5e7eb;border-radius:20px;flex-shrink:0;width:36px;height:20px;transition:background .2s;position:relative}.toggle-track:after{content:"";background:#fff;border-radius:50%;width:14px;height:14px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #00000026}.toggle input:checked~.toggle-track{background:#2563eb}.toggle input:checked~.toggle-track:after{transform:translate(16px)}.toggle-text{color:#374151;min-width:24px;font-size:13px}@media (width<=1024px){.np-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.np-section{padding:16px}.np-grid{grid-template-columns:repeat(2,1fr);gap:12px}}@media (width<=576px){.np-section{padding:14px 12px}.np-grid{grid-template-columns:1fr}.np-field-full{grid-column:1}}.quotes-page{padding:24px}.quotes-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.quotes-header h1{margin:0;font-size:28px}.quotes-header p{color:#777;margin-top:6px}.add-btn{color:#fff;cursor:pointer;background:#111827;border:none;border-radius:10px;padding:12px 18px;font-weight:600}.quotes-table-wrapper{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 14px #0000000f}.quotes-table{border-collapse:collapse;width:100%}.quotes-table thead{background:#f3f4f6}.quotes-table th{text-align:left;color:#374151;padding:16px;font-size:14px}.quotes-table td{border-top:1px solid #f1f1f1;padding:16px;font-size:14px}.action-buttons{gap:10px;display:flex}.view-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600}.delete-btn{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600}.modal-card{background:#fff;border-radius:18px;width:600px;overflow:hidden}.modal-header h2{margin:0}.modal-header button{cursor:pointer;background:0 0;border:none;font-size:18px}.modal-body label{flex-direction:column;gap:8px;font-size:14px;font-weight:500;display:flex}.modal-body input,.modal-body select,.modal-body textarea{border:1px solid #ddd;border-radius:10px;padding:12px;font-size:14px}.cancel-btn{cursor:pointer;background:#e5e7eb;border:none;border-radius:10px;padding:10px 18px}.save-btn{color:#fff;cursor:pointer;background:#111827;border:none;border-radius:10px;padding:10px 18px}.works-page{background:#f4f7fb;min-height:100vh;padding:24px}.works-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.works-header h1{color:#111827;font-size:34px;font-weight:700}.works-header p{color:#6b7280;margin-top:6px;font-size:14px}.works-grid{grid-template-columns:1fr 320px;align-items:start;gap:20px;display:grid}.works-left{flex-direction:column;gap:20px;display:flex}.works-card{background:#fff;border:1px solid #e5e7eb;border-radius:20px;overflow:hidden}.works-card-header{border-bottom:1px solid #f1f5f9;padding:20px 24px}.works-card-header h2{color:#111827;font-size:18px;font-weight:700}.works-card-header p{color:#6b7280;margin-top:4px;font-size:13px}.works-card-body{padding:24px}.works-card-footer{border-top:1px solid #f1f5f9;justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.form-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-group{flex-direction:column;gap:6px;display:flex}.form-group.full-span{grid-column:1/-1}.form-label{text-transform:uppercase;letter-spacing:.05em;color:#6b7280;font-size:11px;font-weight:700}.form-select,.form-input,.form-textarea{color:#111827;background:#fff;border:1px solid #e5e7eb;border-radius:12px;outline:none;width:100%;padding:10px 14px;font-family:inherit;font-size:14px;transition:border-color .15s}.form-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.form-select:focus,.form-input:focus,.form-textarea:focus{border-color:#1677ff;box-shadow:0 0 0 3px #1677ff14}.form-textarea{resize:vertical;min-height:90px}.form-error{color:#ef4444;background:#fff0f0;border-radius:10px;margin-top:12px;padding:10px 14px;font-size:13px}.btn{cursor:pointer;border:none;border-radius:12px;align-items:center;gap:8px;height:42px;padding:0 18px;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{color:#fff;background:#1677ff}.btn-primary:hover:not(:disabled){opacity:.9}.btn-secondary{color:#111827;background:#eef2f7}.btn-secondary:hover:not(:disabled){background:#e5eaf2}.btn-success{color:#15803d;background:#dcfce7}.btn-success:hover:not(:disabled){background:#bbf7d0}.btn-danger{color:#ef4444;background:#fff0f0}.btn-danger:hover:not(:disabled){background:#fee2e2}.btn-sm{border-radius:10px;height:34px;padding:0 14px;font-size:13px}.btn-icon{cursor:pointer;color:#6b7280;background:0 0;border:none;padding:4px;font-size:18px;line-height:1;transition:color .15s}.btn-icon:hover{color:#111827}.team-list{flex-direction:column;gap:2px;padding:8px;display:flex}.team-item{cursor:pointer;border-radius:14px;align-items:center;gap:12px;padding:12px;transition:background .15s;display:flex}.team-item:hover{background:#f4f7fb}.team-item.selected{background:#edf4ff}.team-avatar{color:#fff;background:linear-gradient(135deg,#1677ff,#8db8ff);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:15px;font-weight:700;display:flex}.team-info{flex:1;min-width:0}.team-name{color:#111827;font-size:14px;font-weight:600}.team-meta{color:#9ca3af;margin-top:2px;font-size:12px}.progress-bar{background:#f1f5f9;border-radius:999px;height:3px;margin-top:6px;overflow:hidden}.progress-fill{border-radius:999px;height:100%;transition:width .3s}.load-low{background:#22c55e}.load-mid{background:#f59e0b}.load-high{background:#ef4444}.load-pct{flex-shrink:0;font-size:12px;font-weight:700}.load-pct.load-low{color:#16a34a}.load-pct.load-mid{color:#d97706}.load-pct.load-high{color:#dc2626}.section-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.review-list{flex-direction:column;display:flex}.review-row{border-bottom:1px solid #f1f5f9;align-items:center;gap:14px;padding:16px 24px;transition:background .1s;display:flex}.review-row:last-child{border-bottom:none}.review-row:hover{background:#fafafa}.review-icon{background:#f4f7fb;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:16px;display:flex}.review-info{flex:1;min-width:0}.review-title{color:#111827;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.review-meta{color:#9ca3af;margin-top:2px;font-size:12px}.review-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.badge{border-radius:999px;align-items:center;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge-gray{color:#57534e;background:#f1f5f9}.badge-blue{color:#1d4ed8;background:#eff6ff}.badge-amber{color:#b45309;background:#fffbeb}.badge-green{color:#15803d;background:#f0fdf4}.badge-red{color:#b91c1c;background:#fef2f2}.modal-overlay{z-index:999;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:24px;width:500px;overflow:hidden}.modal-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-title{color:#111827;font-size:18px;font-weight:700}.modal-body{flex-direction:column;gap:16px;padding:24px;display:flex}.modal-footer{border-top:1px solid #f1f5f9;justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.empty-state{text-align:center;color:#9ca3af;padding:48px 24px;font-size:14px}@media (width<=960px){.works-grid{grid-template-columns:1fr}}@media (width<=640px){.form-grid{grid-template-columns:1fr}.works-header{flex-direction:column;align-items:flex-start;gap:12px}.review-actions{flex-wrap:wrap}}.wp-panel{background:#fff;border:1px solid #e2e8f0;border-radius:20px;margin-top:24px;padding:24px}.wp-panel-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:20px;display:flex}.wp-panel-title{color:#0f172a;margin:0 0 4px;font-size:16px;font-weight:700}.wp-panel-sub{color:#64748b;margin:0;font-size:12px}.wp-filters{flex-wrap:wrap;gap:8px;display:flex}.wp-filter-btn{color:#64748b;cursor:pointer;background:#f8fafc;border:1px solid #e2e8f0;border-radius:20px;padding:5px 14px;font-size:12px;font-weight:600;transition:all .15s}.wp-filter-btn:hover{color:#2563eb;border-color:#2563eb}.wp-filter-btn.active{color:#fff;background:#2563eb;border-color:#2563eb}.wp-assignments{flex-direction:column;gap:20px;display:flex}.wp-assignment-block{border:1px solid #e2e8f0;border-radius:14px;overflow:hidden}.wp-assignment-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding:12px 16px;display:flex}.wp-assignment-info{align-items:center;gap:10px;display:flex}.wp-project-code{color:#64748b;background:#e2e8f0;border-radius:20px;padding:2px 8px;font-size:11px;font-weight:700}.wp-project-name{color:#0f172a;font-size:14px;font-weight:600}.wp-assignment-meta{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.wp-employee{color:#64748b;font-size:12px}.wp-status-badge{border-radius:20px;padding:2px 10px;font-size:11px;font-weight:600}.wp-status-badge.wp-status-in_progress{color:#d97706;background:#fef3c7}.wp-status-badge.wp-status-completed{color:#16a34a;background:#dcfce7}.wp-photo-count{color:#94a3b8;font-size:11px;font-weight:500}.wp-photo-grid{flex-wrap:wrap;gap:10px;padding:14px 16px;display:flex}.wp-photo-thumb{cursor:pointer;border:1px solid #e2e8f0;border-radius:10px;flex-shrink:0;width:100px;height:100px;position:relative;overflow:hidden}.wp-photo-thumb img{-o-object-fit:cover;object-fit:cover;width:100%;height:100%;transition:transform .2s;display:block}.wp-photo-thumb:hover img{transform:scale(1.05)}.wp-photo-overlay{opacity:0;background:#00000059;justify-content:center;align-items:center;font-size:18px;transition:opacity .2s;display:flex;position:absolute;inset:0}.wp-photo-thumb:hover .wp-photo-overlay{opacity:1}.wp-loading-row{gap:10px;padding:14px 16px;display:flex}.wp-photo-skeleton{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 50%,#f1f5f9 75%) 0 0/200% 100%;border-radius:10px;width:100px;height:100px;animation:1.4s infinite wp-shimmer}@keyframes wp-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.wp-empty{text-align:center;color:#94a3b8;padding:40px 20px}.wp-empty-icon{margin-bottom:8px;font-size:36px;display:block}.wp-empty p{margin:0;font-size:14px}.wp-no-photos{color:#94a3b8;margin:0;padding:14px 16px;font-size:12px;font-style:italic}.wp-error-text{color:#dc2626;margin:0;padding:14px 16px;font-size:12px}.wp-lightbox{z-index:1000;background:#000000d9;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.wp-lightbox-inner{flex-direction:column;align-items:center;gap:12px;max-width:90vw;max-height:90vh;display:flex;position:relative}.wp-lightbox-inner img{-o-object-fit:contain;object-fit:contain;border-radius:12px;max-width:100%;max-height:80vh;box-shadow:0 20px 60px #00000080}.wp-lightbox-close{cursor:pointer;color:#0f172a;z-index:1;background:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:700;display:flex;position:absolute;top:-14px;right:-14px;box-shadow:0 2px 8px #0000004d}.wp-lightbox-download{color:#fff;background:#ffffff26;border:1px solid #ffffff4d;border-radius:20px;padding:6px 16px;font-size:13px;text-decoration:none;transition:background .15s}.wp-lightbox-download:hover{background:#ffffff40}.lm-page{background:#f1f5f9;flex-direction:column;height:calc(100vh - 56px);display:flex;overflow:hidden}.lm-header{background:#fff;border-bottom:1px solid #e2e8f0;flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:16px 24px;display:flex}.lm-title{color:#0f172a;margin:0 0 2px;font-size:20px;font-weight:700}.lm-sub{color:#64748b;margin:0;font-size:12px}.lm-header-actions{align-items:center;gap:12px;display:flex}.lm-toggle{color:#64748b;cursor:pointer;align-items:center;gap:6px;font-size:13px;display:flex}.lm-toggle input{accent-color:#2563eb}.lm-btn-refresh{color:#0f172a;cursor:pointer;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:7px 16px;font-size:13px;font-weight:600;transition:background .15s}.lm-btn-refresh:hover{background:#e2e8f0}.lm-body{flex:1;display:flex;overflow:hidden}.lm-sidebar{background:#fff;border-right:1px solid #e2e8f0;flex-direction:column;flex-shrink:0;gap:8px;width:280px;padding:16px;display:flex;overflow-y:auto}.lm-section-label{color:#94a3b8;letter-spacing:1.2px;margin-top:8px;margin-bottom:4px;font-size:10px;font-weight:700}.lm-loading,.lm-empty{color:#94a3b8;padding:12px 0;font-size:13px}.lm-employee-list{flex-direction:column;gap:8px;display:flex}.lm-employee-card{cursor:pointer;border:1px solid #e2e8f0;border-radius:12px;align-items:center;gap:10px;padding:10px 12px;transition:all .15s;display:flex}.lm-employee-card:hover,.lm-employee-card.active{background:#eff6ff;border-color:#2563eb}.lm-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:12px;font-weight:700;display:flex}.lm-employee-info{flex:1;min-width:0}.lm-employee-name{color:#0f172a;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.lm-employee-meta{color:#64748b;white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.lm-employee-time{color:#94a3b8;margin-top:2px;font-size:10px}.lm-status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.lm-history{border-top:1px solid #e2e8f0;margin-top:8px;padding-top:12px}.lm-history-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.lm-clear-btn{cursor:pointer;color:#94a3b8;background:0 0;border:none;padding:2px 6px;font-size:14px}.lm-clear-btn:hover{color:#dc2626}.lm-history-list{flex-direction:column;max-height:300px;display:flex;overflow-y:auto}.lm-history-item{gap:10px;padding-bottom:12px;display:flex;position:relative}.lm-history-dot{z-index:1;border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:4px}.lm-history-line{background:#e2e8f0;width:2px;position:absolute;top:14px;bottom:0;left:4px}.lm-history-content{flex:1}.lm-history-type{color:#0f172a;font-size:12px;font-weight:600}.lm-history-time{color:#94a3b8;margin-top:1px;font-size:11px}.lm-history-project{color:#64748b;margin-top:2px;font-size:11px}.lm-map-wrap{flex:1;position:relative}.lm-map{width:100%;height:100%}.lm-map-loading{z-index:1000;background:#ffffffb3;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.lm-spinner{border:3px solid #e2e8f0;border-top-color:#2563eb;border-radius:50%;width:32px;height:32px;animation:.8s linear infinite lm-spin}@keyframes lm-spin{to{transform:rotate(360deg)}}.pp-page{box-sizing:border-box;width:100%;padding:20px 24px 48px}.pp-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.pp-title{color:#111827;letter-spacing:-.015em;font-size:21px;font-weight:700}.pp-meta{color:#9ca3af;margin-top:3px;font-size:12.5px}.pp-header-actions{flex-wrap:wrap;align-items:center;gap:9px;display:flex}.pp-btn-export{color:#fff;cursor:pointer;white-space:nowrap;background:#6366f1;border:none;border-radius:10px;align-items:center;gap:7px;height:38px;padding:0 20px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s,box-shadow .15s;display:inline-flex}.pp-btn-export:hover:not(:disabled){background:#4f46e5;box-shadow:0 4px 12px #6366f159}.pp-btn-export:disabled{opacity:.65;cursor:not-allowed}.pp-filter-bar{background:#fff;border:1px solid #e5e7eb;border-radius:14px;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;padding:12px 16px;display:flex}.pp-search-wrap{flex:1;min-width:240px;position:relative}.pp-search-icon{color:#9ca3af;pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.pp-search-input{color:#111827;box-sizing:border-box;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;outline:none;width:100%;height:36px;padding:0 12px 0 32px;font-family:inherit;font-size:13px;transition:border-color .15s,box-shadow .15s}.pp-search-input::placeholder{color:#c0c4cc}.pp-search-input:focus{border-color:#6366f1;box-shadow:0 0 0 2px #6366f11a}.pp-filter-select{color:#374151;cursor:pointer;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;outline:none;min-width:160px;height:36px;padding:0 12px;font-family:inherit;font-size:13px;transition:border-color .15s}.pp-filter-select:focus{border-color:#6366f1}.pp-card{background:#fff;border:1px solid #e5e7eb;border-radius:20px;overflow:hidden}.pp-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.pp-table{border-collapse:collapse;width:100%;min-width:2200px}.pp-table thead tr{background:#fafafa;border-bottom:1.5px solid #f0f1f3}.pp-table th{color:#9ca3af;text-align:left;letter-spacing:.07em;text-transform:uppercase;white-space:nowrap;padding:12px 14px;font-size:10.5px;font-weight:700}.pp-table tbody tr{border-bottom:1px solid #f0f1f3;transition:background .1s}.pp-table tbody tr:last-child{border-bottom:none}.pp-table tbody tr:hover{background:#fafbff}.pp-table td{color:#111827;vertical-align:middle;white-space:nowrap;padding:12px 14px;font-size:13px}.pp-sl{color:#9ca3af;font-size:12px;font-weight:500}.pp-code{color:#6366f1;font-size:13px;font-weight:700}.pp-desc{text-overflow:ellipsis;white-space:nowrap;color:#374151;max-width:200px;display:inline-block;overflow:hidden}.pp-date{color:#6b7280;font-size:12.5px}.pp-amount{color:#111827;font-variant-numeric:tabular-nums;font-weight:600}.pp-dash{color:#d1d5db}.pp-badge{white-space:nowrap;letter-spacing:.02em;border-radius:20px;align-items:center;padding:3px 10px;font-size:11.5px;font-weight:600;display:inline-flex}.pp-status-completed{color:#059669;background:#34d39926}.pp-status-in-progress{color:#2563eb;background:#60a5fa26}.pp-status-assigned{color:#d97706;background:#fbbf2426}.pp-status-completed-by-team{color:#7c3aed;background:#a78bfa26}.pp-status-quote-needed{color:#ea580c;background:#fb923c26}.pp-status-default{color:#64748b;background:#f1f5f9}.pp-pay-paid{color:#059669;background:#34d39926}.pp-pay-partial{color:#d97706;background:#fbbf2426}.pp-pay-pending{color:#dc2626;background:#f8717126}.pp-pay-default{color:#64748b;background:#f1f5f9}.pp-loader{color:#6b7280;justify-content:center;align-items:center;gap:10px;padding:80px 20px;font-size:14px;display:flex}.pp-empty{color:#9ca3af;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:80px 20px;font-size:14px;display:flex}.pp-empty-icon{color:#e5e7eb}.pp-error{color:#dc2626;justify-content:center;align-items:center;padding:60px 20px;font-size:13.5px;display:flex}@keyframes pp-spin{to{transform:rotate(360deg)}}.pp-spin{animation:.75s linear infinite pp-spin}@media (width<=1024px){.pp-page{padding:16px 16px 40px}}@media (width<=768px){.pp-page{padding:14px 12px 36px}.pp-header{flex-direction:column;align-items:stretch}.pp-btn-export{justify-content:center;width:100%}.pp-filter-bar{border-radius:12px;flex-direction:column;align-items:stretch}.pp-search-wrap,.pp-filter-select{width:100%;min-width:unset}}
