:root{--bg-app: #f4f6f9;--bg-sidebar: #ffffff;--bg-card: #ffffff;--bg-topbar: #ffffff;--bg-input: #f8fafc;--bg-hover: #f1f5f9;--bg-active-nav:#e8f5ec;--border: #e8ecf0;--border-light: #f1f5f9;--text-primary: #0f172a;--text-secondary: #64748b;--text-muted: #94a3b8;--nav-active: #16a34a;--nav-active-bg: rgba(22,163,74,.08);--accent: #3b82f6;--accent-hover: #2563eb;--accent-glow: rgba(59,130,246,.12);--sq-purple: #7c3aed;--sq-red: #e11d48;--sq-orange: #ea580c;--sq-amber: #d97706;--sq-teal: #0d9488;--sq-blue: #1d4ed8;--sq-green: #16a34a;--green: #16a34a;--green-bg: #dcfce7;--red: #dc2626;--red-bg: #fee2e2;--amber: #d97706;--amber-bg: #fef3c7;--blue: #2563eb;--blue-bg: #dbeafe;--slate-bg: #f1f5f9;--slate: #475569;--sidebar-w: 230px;--topbar-h: 64px;--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--shadow-card: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;background:var(--bg-app);color:var(--text-primary);line-height:1.5;font-size:14px}.app-container{display:flex;height:100vh;overflow:hidden;background:var(--bg-app)}.app-body{display:flex;flex-direction:column;flex:1;overflow:hidden}.main-content{flex:1;overflow-y:auto;background:var(--bg-app)}.sidebar{width:var(--sidebar-w);background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:20px 20px 18px;border-bottom:1px solid var(--border);margin-bottom:8px}.sidebar-logo span{font-size:17px;font-weight:800;color:var(--text-primary);letter-spacing:-.4px}.sidebar-section-label{font-size:10.5px;font-weight:700;letter-spacing:1.2px;color:var(--text-muted);padding:12px 20px 6px;text-transform:uppercase}.sidebar nav ul{list-style:none;padding:0 10px}.nav-link{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:var(--radius-sm);color:var(--text-secondary);text-decoration:none;font-size:13.5px;font-weight:500;transition:all .15s;position:relative;margin-bottom:2px}.nav-link:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-link.active{background:var(--nav-active-bg);color:var(--nav-active);font-weight:600}.nav-link.active .nav-icon{color:var(--nav-active)}.nav-icon{display:flex;align-items:center;flex-shrink:0}.nav-indicator{position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--nav-active);border-radius:0 3px 3px 0}.topbar{height:var(--topbar-h);background:var(--bg-topbar);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 28px;flex-shrink:0}.topbar-greeting{display:flex;flex-direction:column}.topbar-greeting-main{font-size:15px;font-weight:700;color:var(--text-primary)}.topbar-greeting-sub{font-size:12px;color:var(--text-muted);margin-top:1px}.topbar-right{display:flex;align-items:center;gap:8px}.topbar-icon-btn{width:36px;height:36px;background:var(--bg-app);border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);cursor:pointer;transition:all .15s}.topbar-icon-btn:hover{background:var(--border);box-shadow:none;transform:none;color:var(--text-primary)}.user-avatar{width:36px;height:36px;background:linear-gradient(135deg,var(--sq-purple),var(--accent));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0;cursor:pointer}.btn-ghost{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary);box-shadow:none;transform:none}.page-main{padding:28px 32px;max-width:1440px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px}.page-header-left h1{font-size:22px;font-weight:800;color:var(--text-primary);letter-spacing:-.4px}.page-header-left p{font-size:13px;color:var(--text-secondary);margin-top:3px}.page-title{font-size:22px;font-weight:800;color:var(--text-primary);letter-spacing:-.4px;margin-bottom:4px}.page-subtitle{font-size:13px;color:var(--text-secondary)}.section-header{display:flex;align-items:center;justify-content:space-between;margin:28px 0 16px}.section-title{font-size:16px;font-weight:700;color:var(--text-primary)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:8px}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-card);position:relative;transition:box-shadow .2s,transform .15s}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi-period{position:absolute;top:14px;right:16px;font-size:11px;color:var(--text-muted);display:flex;align-items:center;gap:3px;cursor:pointer}.kpi-square{width:64px;height:64px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:800;color:#fff;flex-shrink:0;letter-spacing:-1px}.kpi-square.purple{background:linear-gradient(135deg,#6d28d9,#7c3aed)}.kpi-square.red{background:linear-gradient(135deg,#be123c,#e11d48)}.kpi-square.orange{background:linear-gradient(135deg,#c2410c,#ea580c)}.kpi-square.amber{background:linear-gradient(135deg,#b45309,#d97706)}.kpi-square.teal{background:linear-gradient(135deg,#0f766e,#0d9488)}.kpi-square.blue{background:linear-gradient(135deg,#1e40af,#2563eb)}.kpi-square.green{background:linear-gradient(135deg,#15803d,#16a34a)}.kpi-body{flex:1;min-width:0;padding-top:20px}.kpi-label{font-size:12.5px;color:var(--text-secondary);font-weight:500;line-height:1.3;margin-bottom:6px}.kpi-value{font-size:22px;font-weight:800;color:var(--text-primary);letter-spacing:-.5px;line-height:1}.kpi-trend{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px;margin-top:8px}.kpi-trend.up{background:var(--green-bg);color:var(--green)}.kpi-trend.down{background:var(--red-bg);color:var(--red)}.kpi-trend.flat{background:var(--slate-bg);color:var(--slate)}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-card)}.chart-card--full{grid-column:1 / -1}.chart-container{display:flex;flex-direction:column;width:100%}.chart-container h3{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.data-table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card);overflow:hidden}.data-table-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.data-table-header h2{font-size:15px;font-weight:700;color:var(--text-primary)}.data-table-header .count{font-size:11.5px;color:var(--text-muted);background:var(--bg-app);padding:2px 9px;border-radius:20px;margin-left:8px;border:1px solid var(--border);font-weight:600}table{width:100%;border-collapse:collapse}thead{background:#fafbfc;border-bottom:1px solid var(--border)}th{padding:10px 16px;text-align:left;font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.7px;white-space:nowrap}td{padding:13px 16px;font-size:13.5px;color:var(--text-primary);border-bottom:1px solid var(--border-light)}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:#fafbfc}.badge,.status-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11.5px;font-weight:600;text-transform:capitalize;white-space:nowrap}.status-badge.active,.badge-green{background:var(--green-bg);color:var(--green)}.status-badge.cancelled,.badge-red{background:var(--red-bg);color:var(--red)}.status-badge.on_hold,.status-badge.on-hold,.badge-amber{background:var(--amber-bg);color:var(--amber)}.status-badge.planned,.status-badge.billable,.badge-blue{background:var(--blue-bg);color:var(--blue)}.status-badge.completed,.badge-slate{background:var(--slate-bg);color:var(--slate)}.status-badge.non_billable,.status-badge.bench{background:var(--amber-bg);color:var(--amber)}.status-badge.full_time{background:var(--green-bg);color:var(--green)}.status-badge.part_time{background:var(--blue-bg);color:var(--blue)}.status-badge.contractor{background:var(--amber-bg);color:var(--amber)}button{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:13.5px;font-weight:600;cursor:pointer;transition:background .15s,box-shadow .15s,transform .1s;white-space:nowrap;font-family:inherit}button:hover{background:var(--accent-hover);box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}button:active{transform:translateY(0)}button.primary{background:var(--accent)}button.secondary{background:#fff;color:var(--text-secondary);border:1px solid var(--border)}button.secondary:hover{background:var(--bg-app);box-shadow:none;color:var(--text-primary)}button.danger{background:var(--red)}button.danger:hover{background:#b91c1c;box-shadow:0 4px 12px #dc26264d}.button-group{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap}.form-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:20px;box-shadow:var(--shadow-card)}.form-card-title{font-size:15px;font-weight:700;color:var(--text-primary);margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border)}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}input,select,textarea{width:100%;padding:9px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13.5px;color:var(--text-primary);font-family:inherit;transition:border-color .15s,box-shadow .15s}input::placeholder{color:var(--text-muted)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}textarea{min-height:90px;resize:vertical}.filter-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:18px;box-shadow:var(--shadow-card)}.filter-panel h3{font-size:13.5px;font-weight:700;color:var(--text-primary);margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--border)}.filter-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:14px}.filter-group{display:flex;flex-direction:column;gap:5px;margin-bottom:0}.filter-group label{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px}.filter-actions{display:flex;gap:10px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.state-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:80px 20px;color:var(--text-secondary);font-size:14px}.spinner{width:20px;height:20px;border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.state-error{margin:20px;padding:14px 18px;background:var(--red-bg);color:var(--red);border-radius:var(--radius-sm);font-size:13.5px;border-left:3px solid var(--red)}.state-empty{display:flex;align-items:center;justify-content:center;padding:48px 20px;color:var(--text-muted);font-size:14px}.loading{padding:60px;text-align:center;color:var(--text-muted)}.error-message{padding:14px 18px;background:var(--red-bg);color:var(--red);border-radius:var(--radius-sm);margin-bottom:16px;font-size:13.5px;border-left:3px solid var(--red)}.empty-state{padding:48px;text-align:center;color:var(--text-muted)}.section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:18px;box-shadow:var(--shadow-card)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-app)}.login-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:40px;width:100%;max-width:420px;box-shadow:var(--shadow-md);border:1px solid var(--border);text-align:center}.login-header h1{font-size:26px;font-weight:800;color:var(--text-primary);letter-spacing:-.5px}.login-header p{color:var(--text-secondary);margin-top:6px;font-size:13.5px}.login-content{margin:28px 0}.login-button{width:100%;padding:12px;font-size:14px;border-radius:var(--radius-sm);margin-top:16px}.login-footer p{font-size:12px;color:var(--text-muted)}.demo-notice{background:var(--green-bg);color:var(--green);padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:12px;border-left:3px solid var(--green);text-align:left}@media (max-width: 900px){.sidebar{display:none}.kpi-grid{grid-template-columns:repeat(2,1fr)}.charts-grid{grid-template-columns:1fr}.chart-card--full{grid-column:1}}@media (max-width: 600px){.page-main{padding:16px}.kpi-grid{grid-template-columns:1fr 1fr}.filter-row,.form-grid{grid-template-columns:1fr}}.row-actions{display:flex;gap:6px;justify-content:center;align-items:center}.action-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--radius-sm);border:none;background:#f3f4f6;cursor:pointer;transition:all .15s ease;color:#6b7280;padding:0;flex-shrink:0}.action-btn svg{width:16px;height:16px;stroke-width:2}.action-btn:hover{transform:scale(1.12)}.action-btn.edit{color:#3b82f6}.action-btn.edit:hover{background:#dbeafe;color:#1d4ed8}.action-btn.delete{color:#dc2626}.action-btn.delete:hover{background:#fee2e2;color:#991b1b}.inline-edit-input,.inline-edit-select{width:100%;padding:5px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;color:var(--text-primary);background:var(--bg-card);outline:none;box-sizing:border-box}.inline-edit-input:focus,.inline-edit-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #16a34a1f}.btn-save-inline{padding:4px 12px;font-size:12px;font-weight:600;background:var(--green);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:opacity .15s}.btn-save-inline:hover{opacity:.85}.btn-cancel-inline{padding:4px 10px;font-size:12px;font-weight:500;background:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}.btn-cancel-inline:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-delete-confirm{padding:4px 12px;font-size:12px;font-weight:600;background:var(--red);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:opacity .15s}.btn-delete-confirm:hover{opacity:.85}.form-error{padding:10px 14px;background:var(--red-bg);color:var(--red);border-radius:var(--radius-sm);font-size:13px;border-left:3px solid var(--red);margin-bottom:14px}
