:root{--color-primary: #1a1a1a;--color-accent: #2563eb;--color-accent-light: #eff6ff;--color-bg: #f5f5f5;--color-surface: #ffffff;--color-border: #e5e5e5;--color-text: #1a1a1a;--color-text-secondary: #666666;--color-text-muted: #999999;--color-danger: #dc2626;--color-success: #16a34a;--color-warning: #d97706;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.06);--shadow-lg: 0 8px 24px rgba(0,0,0,.08);--radius: 8px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,sans-serif;background:var(--color-bg);color:var(--color-text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}.layout{display:flex;min-height:100vh}.sidebar{width:224px;background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;flex-shrink:0;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar-logo{padding:20px 20px 16px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;gap:10px}.sidebar-logo img{height:32px;width:auto;object-fit:contain}.sidebar-logo-text{display:flex;flex-direction:column}.sidebar-logo-text .brand{font-size:15px;font-weight:800;color:var(--color-primary);letter-spacing:-.3px;line-height:1.2}.sidebar-logo-text .sub{font-size:10px;color:var(--color-text-muted);letter-spacing:.5px;text-transform:uppercase}.sidebar-role{padding:8px 20px;font-size:11px;font-weight:600;color:var(--color-accent);text-transform:uppercase;letter-spacing:.8px;background:var(--color-accent-light);border-bottom:1px solid var(--color-border)}.sidebar nav{padding:8px 0;flex:1}.sidebar nav a{display:flex;align-items:center;gap:10px;padding:9px 20px;color:var(--color-text-secondary);text-decoration:none;font-size:13.5px;font-weight:500;transition:background .12s,color .12s;border-left:2px solid transparent}.sidebar nav a .nav-icon{font-size:15px;width:20px;text-align:center;flex-shrink:0}.sidebar nav a:hover{background:var(--color-bg);color:var(--color-text)}.sidebar nav a.active{background:var(--color-accent-light);color:var(--color-accent);border-left-color:var(--color-accent);font-weight:600}.sidebar-footer{padding:16px 20px;border-top:1px solid var(--color-border);margin-top:auto}.sidebar-footer .user-name{font-size:13px;font-weight:600;color:var(--color-text)}.sidebar-footer .user-role{font-size:12px;color:var(--color-text-muted);margin-top:1px}.main{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:14px 28px;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:10}.topbar-title{font-size:15px;font-weight:700;color:var(--color-text);letter-spacing:-.2px}.page{padding:28px;flex:1;overflow:auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.page-title{font-size:20px;font-weight:700;color:var(--color-text);letter-spacing:-.3px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius);border:none;font-size:13.5px;font-weight:600;cursor:pointer;transition:all .15s;text-decoration:none}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:#333}.btn-accent{background:var(--color-accent);color:#fff}.btn-accent:hover{background:#1d4ed8}.btn-outline{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.btn-outline:hover{background:var(--color-bg)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover{background:var(--color-bg);color:var(--color-text)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-sm{padding:5px 10px;font-size:12px}.btn-lg{padding:11px 22px;font-size:15px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card-header{padding:16px 20px;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center}.card-title{font-size:14px;font-weight:700;color:var(--color-text)}.card-body{padding:20px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm);transition:box-shadow .15s}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-label{font-size:12px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.stat-value{font-size:28px;font-weight:800;color:var(--color-text);letter-spacing:-1px;line-height:1}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13.5px}thead th{text-align:left;padding:10px 16px;font-size:11px;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;background:var(--color-bg);border-bottom:1px solid var(--color-border);white-space:nowrap}tbody td{padding:12px 16px;border-bottom:1px solid var(--color-border);color:var(--color-text-secondary);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:#fafafa}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:600;color:var(--color-text);margin-bottom:5px}.form-input,.form-select,.form-textarea{width:100%;padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:14px;color:var(--color-text);background:var(--color-surface);transition:border-color .15s;outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #2563eb1a}.form-textarea{resize:vertical;min-height:80px}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.3px;white-space:nowrap}.badge-blue{background:#dbeafe;color:#1d4ed8}.badge-green{background:#dcfce7;color:#16a34a}.badge-yellow{background:#fef9c3;color:#854d0e}.badge-red{background:#fee2e2;color:#dc2626}.badge-gray{background:var(--color-bg);color:var(--color-text-muted)}.badge-black{background:#1a1a1a;color:#fff}.tabs{display:flex;gap:0;border-bottom:2px solid var(--color-border);margin-bottom:20px}.tab{padding:10px 18px;font-size:13.5px;font-weight:600;color:var(--color-text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s;background:none;border-top:none;border-left:none;border-right:none}.tab:hover{color:var(--color-text)}.tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.text-muted{color:var(--color-text-muted)}.text-sm{font-size:12px}.text-xs{font-size:11px}.font-bold{font-weight:700}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.flex-1{flex:1}.w-full{width:100%}.grid{display:grid}.grid-2{grid-template-columns:repeat(2,1fr);gap:16px}.grid-3{grid-template-columns:repeat(3,1fr);gap:16px}.grid-4{grid-template-columns:repeat(4,1fr);gap:16px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mr-2{margin-right:8px}.ml-auto{margin-left:auto}.p-4{padding:16px}.p-5{padding:20px}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.overflow-auto{overflow:auto}.min-w-\[120px\]{min-width:120px}.loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--color-text-muted)}.empty-state{text-align:center;padding:48px 24px;color:var(--color-text-muted)}.empty-state .empty-icon{font-size:36px;margin-bottom:12px;opacity:.4}.empty-state p{font-size:13px}@media (max-width: 768px){.sidebar{width:60px}.sidebar-logo-text,.sidebar-role,.sidebar-footer .user-name,.sidebar-footer .user-role,.sidebar nav a span:not(.nav-icon){display:none}.sidebar nav a{justify-content:center;padding:10px}.sidebar-logo{padding:12px;justify-content:center}.page{padding:16px}.stat-grid{grid-template-columns:repeat(2,1fr)}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d4d4d4;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#a3a3a3}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f5f5,#e8e8e8);padding:20px}.auth-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;box-shadow:var(--shadow-lg);padding:36px 40px;width:100%;max-width:400px}.auth-title{font-size:20px;font-weight:800;color:var(--color-text);margin-bottom:24px;text-align:center;letter-spacing:-.3px}.pipeline-board{display:grid;gap:12px;margin-top:12px}.pipeline-col{background:var(--color-bg);border-radius:8px;padding:12px;text-align:center}.pipeline-col-label{font-size:11px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.pipeline-col-count{font-size:24px;font-weight:800;color:var(--color-text);letter-spacing:-1px}.pipeline-col-amount{font-size:11px;color:var(--color-text-muted);margin-top:2px}.task-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--color-border)}.task-item:last-child{border-bottom:none}.task-check{width:16px;height:16px;cursor:pointer;flex-shrink:0}.task-title{font-size:13.5px;color:var(--color-text);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-title.done{text-decoration:line-through;color:var(--color-text-muted)}.task-due{font-size:11px;color:var(--color-text-muted);background:var(--color-bg);padding:2px 7px;border-radius:20px;white-space:nowrap;flex-shrink:0}.task-overdue{background:#fee2e2;color:#dc2626}.empty{text-align:center;padding:24px;color:var(--color-text-muted);font-size:13px}
