:root{--bg-deep: #f3faf3;--bg-main: #f8fdf8;--bg-sidebar: linear-gradient(180deg, #e8f5e9 0%, #c8e6c9 100%);--bg-card: rgba(255, 255, 255, .9);--primary: #16a34a;--primary-light: #22c55e;--primary-glow: rgba(22, 163, 74, .18);--accent: #14532d;--accent-soft: rgba(22, 163, 74, .12);--accent-blue: #2563eb;--accent-pink: #db2777;--accent-orange: #ea580c;--accent-teal: #0d9488;--text-main: #0f1f0f;--text-muted: #1e4020;--text-dim: #3d6b40;--success: #15803d;--warning: #b45309;--danger: #b91c1c;--info: #1d4ed8;--border: rgba(20, 83, 45, .1);--border-bright: rgba(22, 163, 74, .28);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--radius-xl: 28px;--shadow-sm: 0 2px 8px rgba(0, 60, 0, .07);--shadow-md: 0 8px 24px rgba(0, 60, 0, .1);--shadow-lg: 0 24px 48px rgba(0, 60, 0, .14);--font-sans: "Outfit", -apple-system, BlinkMacSystemFont, sans-serif}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-sans);background:var(--bg-deep);color:var(--text-main);line-height:1.55;overflow:hidden;-webkit-font-smoothing:antialiased;font-size:1.1rem}#app{display:grid;grid-template-columns:270px 1fr;height:100vh;background:var(--bg-deep)}.sidebar{background:linear-gradient(180deg,#e8f5e9,#c8e6c9);border-right:1.5px solid rgba(22,163,74,.18);display:flex;flex-direction:column;padding:1.75rem 1.25rem;z-index:10;overflow-y:auto}.sidebar-brand{font-size:1rem;font-weight:900;letter-spacing:2px;color:var(--primary);margin-bottom:2rem;display:flex;align-items:center;gap:.75rem}.sidebar-brand:before{content:"";width:14px;height:14px;background:var(--primary);border-radius:3px;box-shadow:0 0 14px var(--primary-glow);flex-shrink:0}.sidebar-nav{display:flex;flex-direction:column;gap:.15rem}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.65rem .9rem;border-radius:var(--radius-md);cursor:pointer;font-size:.95rem;font-weight:500;color:var(--text-muted);transition:all .18s ease;position:relative}.nav-item .icon{font-size:1.05rem;width:20px}.nav-item:hover{background:#16a34a1a;color:var(--accent)}.nav-item.active{background:#16a34a24;color:var(--primary);font-weight:700}.nav-item.active:after{content:"";position:absolute;left:-1.25rem;top:50%;transform:translateY(-50%);width:3px;height:18px;background:var(--primary);border-radius:0 4px 4px 0}.main-content{overflow-y:auto;padding:1.5rem 2.25rem;background:var(--bg-main);background-image:radial-gradient(ellipse at 20% 0%,rgba(22,163,74,.04) 0%,transparent 50%),radial-gradient(ellipse at 85% 90%,rgba(22,163,74,.03) 0%,transparent 45%)}.view-header{margin-bottom:2rem}.view-title{font-size:2.1rem;font-weight:800;letter-spacing:-1px;color:var(--text-main);margin-bottom:.3rem}.glass-panel{background:#fffc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem;box-shadow:var(--shadow-sm);transition:border-color .2s,box-shadow .2s}.glass-panel:hover{border-color:var(--border-bright);box-shadow:var(--shadow-md)}.month-picker{display:flex;align-items:center;gap:.75rem;padding:.4rem .9rem;width:fit-content;border-radius:100px;background:#fff9;border:1px solid var(--border)}.month-tabs{display:flex;gap:.2rem}.month-tab{padding:.35rem .85rem;border-radius:100px;cursor:pointer;font-size:.9rem;font-weight:600;color:var(--text-dim);transition:all .18s}.month-tab:hover{color:var(--text-main);background:#16a34a14}.month-tab.active{background:var(--primary);color:#fff}.picker-btn{background:transparent;border:none;color:var(--text-dim);width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:50%;transition:all .18s;font-size:1rem}.picker-btn:hover{background:var(--primary-glow);color:var(--primary)}.year-label{font-size:.95rem;font-weight:800;color:var(--primary)}.job-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:1.5rem}.job-card{cursor:pointer;padding:1.25rem;display:flex;flex-direction:column;gap:.875rem;background:#fff;border:1.5px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s,border-color .2s}.job-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--border-bright)}.job-card-header{display:flex;justify-content:space-between;align-items:flex-start}.job-card-title{font-size:1.15rem;font-weight:800;letter-spacing:-.3px;color:var(--text-main);margin-bottom:.2rem;line-height:1.3}.job-date{font-size:.88rem;color:var(--text-dim);font-weight:500}.job-status-pill{padding:.3rem .75rem;border-radius:7px;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px;border:1px solid transparent;white-space:nowrap}.status-đã-hoàn-thành{background:#15803d14;border-color:#15803d33;color:#15803d}.status-nhận-feedback{background:#2563eb14;border-color:#2563eb33;color:#2563eb}.status-chưa-gửi{background:#b4530914;border-color:#b4530933;color:#b45309}.status-đang-edit{background:#db277714;border-color:#db277733;color:#db2777}.job-card .detail-item{display:flex;align-items:center;gap:.6rem;font-size:.92rem;color:var(--text-muted)}.job-id-badge{background:var(--accent-soft);border:1px solid rgba(22,163,74,.25);color:var(--primary);font-size:.72rem;font-weight:800;padding:.2rem .65rem;border-radius:6px}.monthly-report{background:#ffffffb3;border:1.5px solid var(--border-bright)}.modal-overlay{position:fixed;inset:0;background:#0a190a99;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .35s cubic-bezier(.16,1,.3,1)}.modal-overlay.active{opacity:1;visibility:visible}.modal-container{width:min(1020px,97vw);max-height:94vh;background:#fafcfa;border-radius:var(--radius-xl);border:1.5px solid var(--border-bright);box-shadow:0 32px 80px #0028002e;transform:scale(.95) translateY(24px);transition:all .4s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;overflow:hidden}.modal-overlay.active .modal-container{transform:scale(1) translateY(0)}.modal-header{padding:1.75rem 2rem 1rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);background:linear-gradient(135deg,#f0faf0,#fafcfa)}.modal-header h2{font-size:1.55rem;font-weight:800;letter-spacing:-.5px;color:var(--text-main)}.close-btn{background:#0000000d;border:1px solid var(--border);color:var(--text-dim);width:38px;height:38px;border-radius:50%;font-size:1.35rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .18s}.close-btn:hover{background:#dc262614;border-color:#dc262640;color:var(--danger)}.modal-body{padding:1.5rem 2rem 2rem;overflow-y:auto;flex:1;max-height:calc(94vh - 90px)}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);margin-bottom:.5rem}.form-control{width:100%;background:#fff;border:1.5px solid var(--border);padding:.7rem 1rem;border-radius:var(--radius-md);color:var(--text-main);font-family:inherit;font-size:1rem;transition:border-color .18s,box-shadow .18s}.form-control:focus{outline:none;border-color:var(--primary-light);box-shadow:0 0 0 3px #16a34a1f}.btn{padding:.72rem 1.5rem;border-radius:var(--radius-md);font-weight:700;font-size:.95rem;cursor:pointer;transition:all .18s;display:inline-flex;align-items:center;gap:.5rem;border:1.5px solid transparent;line-height:1}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:#15803d;transform:translateY(-1px);box-shadow:0 4px 16px #16a34a4d}.btn-secondary{background:#fff;border:1.5px solid var(--border);color:var(--text-main)}.btn-secondary:hover{background:#16a34a0f;border-color:var(--border-bright)}.btn-sm{padding:.4rem .9rem;font-size:.82rem;border-radius:var(--radius-sm)}.data-table{width:100%;border-collapse:separate;border-spacing:0 .35rem}.data-table th{padding:.75rem 1rem;text-align:left;font-size:.72rem;font-weight:800;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px}.data-table td{padding:1rem;background:#ffffffd9;font-size:.95rem;color:var(--text-main);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.data-table tr td:first-child{border-radius:8px 0 0 8px;border-left:1px solid var(--border)}.data-table tr td:last-child{border-radius:0 8px 8px 0;border-right:1px solid var(--border)}.stat-card{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.stat-card .label{font-size:.72rem;font-weight:800;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px}.stat-card .value{font-size:2rem;font-weight:900;letter-spacing:-1px;line-height:1;color:var(--text-main)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:.75rem}.progress-container{width:100%;height:4px;background:#0064000f;border-radius:2px;overflow:hidden}.progress-bar{height:100%;background:var(--primary)}.profit-estimate label{display:block;font-size:.65rem;color:var(--text-dim);text-transform:uppercase;font-weight:800;margin-bottom:.2rem}.profit-estimate .value{font-size:.95rem;font-weight:800}.view-detail-link{font-size:.78rem;color:var(--primary);font-weight:600;opacity:.75}.timeline-quick-toggle{display:flex;align-items:center;gap:1rem;background:#16a34a0a;padding:.5rem .75rem;border-radius:8px;border:1px solid var(--border)}.toggle-item{font-size:.78rem;color:var(--text-dim);font-weight:600}.toggle-item .time{color:var(--primary);background:var(--accent-soft);padding:.1rem .4rem;border-radius:4px;margin-left:.25rem}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#16a34a66}.reveal{animation:revealView .4s cubic-bezier(.16,1,.3,1)}@keyframes revealView{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.empty-state{padding:4rem;text-align:center;color:var(--text-dim);border:1.5px dashed var(--border);border-radius:var(--radius-lg);background:#fff6}.color-green{color:var(--success)}.info-group label{font-size:.72rem;font-weight:700;text-transform:uppercase;color:var(--text-dim);display:block;margin-bottom:.3rem;letter-spacing:.3px}.info-group input,.info-group textarea{color:var(--text-main);background:#fff;border:1.5px solid var(--border);border-radius:var(--radius-sm)}.info-group input:focus,.info-group textarea:focus{border-color:var(--primary-light);outline:none;box-shadow:0 0 0 3px #16a34a1a}.badge{display:inline-flex;align-items:center;padding:.2rem .55rem;border-radius:6px;font-size:.72rem;font-weight:700}select.form-control{color:var(--text-main);background:#fff;cursor:pointer}@keyframes toastIn{0%{opacity:0;transform:translateY(8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}tr.paid-row{background:#15803d0f!important}.service-paid-check{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}@media(max-width:900px){#app{display:flex;flex-direction:column;height:100vh}.sidebar{flex:0 0 auto;border-right:none;border-bottom:1px solid var(--border);padding:1rem;overflow-x:auto}.sidebar-brand{margin-bottom:1rem;font-size:1.1rem}.sidebar-nav{flex-direction:row;flex-wrap:nowrap;gap:.5rem}.sidebar-nav>div[style*="font-size: 0.82rem"]{display:none}.nav-item{white-space:nowrap;padding:.5rem .8rem;flex-shrink:0}.nav-item.active:after{display:none}.main-content{flex:1;padding:1rem}.view-title{font-size:1.6rem}.job-grid,.staff-grid{grid-template-columns:1fr}.data-table{display:block;overflow-x:auto;white-space:nowrap}}
