@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";
:root{--sidebar-width:260px;--sidebar-collapsed:72px;--radius:14px;--radius-sm:10px;--radius-lg:20px;--transition:.3s cubic-bezier(.4, 0, .2, 1);--bg-primary:#141414;--bg-secondary:#0e0e0e;--bg-card:#1c1c1c;--bg-card-hover:#222;--bg-input:#1a1a1a;--border:#ffffff0d;--border-focus:var(--accent);--accent:#10b981;--accent-hover:#059669;--accent-light:#10b9811a;--accent-glow:#10b9814d;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#4b5563;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--shadow-sm:0 2px 4px #0000004d;--shadow-md:0 4px 12px #0000004d;--shadow-lg:0 12px 24px #0006;--shadow-accent:0 0 20px var(--accent-glow);--glass-bg:#0e0e0ed1;--glass-border:#ffffff0d}[data-theme=light]{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-card:#fff;--bg-card-hover:#f1f5f9;--bg-input:#f1f5f9;--border:#0f172a1f;--border-focus:var(--accent);--accent:#10b981;--accent-hover:#059669;--accent-light:#10b98114;--accent-glow:#10b98126;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--success:#059669;--warning:#d97706;--danger:#dc2626;--shadow-sm:0 2px 8px #0f172a14;--shadow-md:0 8px 16px #0f172a1a;--shadow-lg:0 16px 32px #0f172a24;--shadow-accent:0 0 20px #10b9811a;--glass-bg:#ffffffd9;--glass-border:#0f172a1f}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background var(--transition), color var(--transition), border-color var(--transition), box-shadow var(--transition);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-shell{height:100vh;display:flex;overflow:hidden}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;transition:margin-left .3s;display:flex;overflow-y:auto}.main-content.collapsed{margin-left:var(--sidebar-collapsed)}.page-header{border-bottom:1px solid var(--border);background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);z-index:90;flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 32px;display:flex;position:sticky;top:0}.page-title{color:var(--text-primary);font-size:1.5rem;font-weight:700}.page-subtitle{color:var(--text-secondary);margin-top:2px;font-size:.875rem}.page-body{flex:1;padding:32px;overflow-y:auto}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);z-index:100;transition:width var(--transition), background var(--transition), border-color var(--transition);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar.collapsed{width:var(--sidebar-collapsed)}.collapse-btn{background:var(--bg-secondary);border:1px solid var(--border);cursor:pointer;z-index:110;width:24px;height:24px;color:var(--text-muted);box-shadow:var(--shadow-sm);border-radius:50%;justify-content:center;align-items:center;font-size:.75rem;transition:all .2s;display:flex;position:absolute;top:24px;right:-12px}.collapse-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:var(--shadow-md);transform:scale(1.1)}.sidebar-user-header{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;box-shadow:var(--shadow-sm);border-radius:14px;align-items:center;gap:12px;margin:20px 14px 10px;padding:12px;transition:all .2s;display:flex;position:relative;overflow:hidden}.sidebar-user-header:hover{background:var(--bg-card-hover);border-color:var(--accent-light);transform:translateY(-1px)}.sidebar.collapsed .sidebar-user-header{justify-content:center;margin:20px 12px;padding:8px}.sidebar-user-header-icon{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;box-shadow:inset 0 2px 4px #0000001a}.sidebar-user-header-info{flex:1;overflow:hidden}.sidebar-user-header-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:700;overflow:hidden}.sidebar-user-header-email{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:-1px;font-size:.72rem;overflow:hidden}.sidebar-user-header-chevron{color:var(--text-muted);opacity:.5;font-size:.8rem}.sidebar-search{margin:4px 14px 16px;position:relative}.sidebar.collapsed .sidebar-search{display:none}.search-pill{background:var(--bg-card);border:1px solid var(--border);width:100%;color:var(--text-primary);border-radius:10px;outline:none;padding:8px 12px 8px 36px;font-size:.8rem;transition:all .2s}.search-pill:focus{border-color:var(--accent-light);background:var(--bg-input)}.search-icon-fixed{color:var(--text-muted);pointer-events:none;font-size:.9rem;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-shortcut{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-muted);border-radius:4px;padding:1px 6px;font-size:.65rem;font-weight:600;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.sidebar-logo{display:none}.sidebar-nav{flex-direction:column;flex:1;gap:6px;padding:16px 14px;display:flex;overflow-y:auto}.nav-section-label{text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);padding:16px 12px 8px;font-size:.65rem;font-weight:800}.nav-item{color:var(--text-secondary);white-space:nowrap;border-radius:14px;align-items:center;gap:12px;width:100%;padding:12px 16px;font-size:.9rem;font-weight:600;text-decoration:none;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;overflow:hidden}.sidebar.collapsed .nav-item{justify-content:center;width:100%;padding:12px 0}.nav-item:hover{background:var(--bg-secondary);color:var(--text-primary);transform:translate(4px)}.sidebar.collapsed .nav-item:hover{background:var(--bg-secondary);transform:none}.nav-item.active{box-shadow:none;background:linear-gradient(90deg,#10b98126,#0000);font-weight:700;position:relative;color:var(--accent)!important}.nav-item.active:after{content:"";background:var(--accent);width:3px;height:20px;box-shadow:0 0 12px var(--accent-glow);border-radius:0 4px 4px 0;position:absolute;left:0}.sidebar.collapsed .nav-item.active{background:var(--accent-light);width:44px;margin:0 auto}.sidebar.collapsed .nav-item.active:after{left:unset;right:-2px}.nav-item.active .nav-icon{color:var(--accent);text-shadow:0 0 10px var(--accent-glow)}.nav-sub-items{border-left:1px dashed var(--border);flex-direction:column;gap:4px;margin-top:4px;margin-bottom:8px;margin-left:28px;padding-left:8px;display:flex}.nav-sub-item{color:var(--text-muted);border-radius:10px;padding:8px 12px;font-size:.8rem;text-decoration:none;transition:all .2s}.nav-sub-item:hover{color:var(--text-primary);background:var(--bg-secondary)}.nav-sub-item.active{color:var(--accent);background:var(--accent-light);font-weight:700}.nav-item .nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:1.1rem;display:flex}.sidebar-footer{border-top:1px solid var(--border);padding:8px 12px}.sidebar-user-container{align-items:center;gap:4px;display:flex;position:relative}.sidebar-user{cursor:pointer;border-radius:12px;flex:1;align-items:center;gap:10px;padding:10px 12px;transition:all .2s;display:flex;overflow:hidden}.theme-toggle-minimal{cursor:pointer;width:34px;height:34px;color:var(--text-muted);background:0 0;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.1rem;transition:all .2s;display:flex}.theme-toggle-minimal:hover{background:var(--bg-secondary);color:var(--accent);transform:translateY(-1px)}.sidebar.collapsed .theme-toggle-minimal{display:none}.sidebar-user:hover{background:var(--bg-card)}.avatar{background:linear-gradient(135deg, var(--accent), #059669);color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.8rem;font-weight:700;display:flex}.avatar.lg{width:44px;height:44px;font-size:1rem}.user-info{overflow:hidden}.user-name{white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:600;overflow:hidden}.user-role{color:var(--text-muted);white-space:nowrap;font-size:.75rem}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;transition:all .2s}.card:hover{border-color:var(--accent);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-grid{gap:20px;display:grid}.card-grid-2{grid-template-columns:repeat(2,1fr)}.card-grid-3{grid-template-columns:repeat(3,1fr)}.card-grid-4{grid-template-columns:repeat(4,1fr)}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:8px;padding:20px 24px;transition:all .2s;display:flex;position:relative;overflow:hidden}.stat-card:after{content:"";border-radius:var(--radius) var(--radius) 0 0;height:3px;position:absolute;top:0;left:0;right:0}.stat-card.accent:after{background:linear-gradient(90deg, var(--accent), #ca8a04)}.stat-card.success:after{background:var(--success)}.stat-card.warning:after{background:var(--warning)}.stat-card.danger:after{background:var(--danger)}.stat-card:hover{box-shadow:var(--shadow-lg);border-color:var(--accent);transform:translateY(-4px)}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:500}.stat-value{color:var(--text-primary);font-size:2rem;font-weight:700;line-height:1}.stat-sub{color:var(--text-secondary);font-size:.8rem}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:8px;padding:10px 18px;font-size:.875rem;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:var(--shadow-accent);transform:translateY(-1px)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--border-focus)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--accent-light);color:var(--text-primary)}.btn-danger{background:var(--danger-bg);color:var(--danger);border:1px solid #ef44444d}.btn-danger:hover:not(:disabled){background:var(--danger);color:#fff}.btn-sm{padding:6px 12px;font-size:.8rem}.btn-lg{padding:14px 24px;font-size:1rem}.btn-icon{border-radius:var(--radius-sm);padding:8px}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-secondary);font-size:.85rem;font-weight:500}.form-input,.form-select,.form-textarea{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);width:100%;padding:10px 14px;font-family:inherit;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-light);outline:none}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-textarea{resize:vertical;min-height:100px}.form-select{appearance:none;cursor:pointer}.form-error{color:var(--danger);font-size:.8rem}.form-hint{color:var(--text-muted);font-size:.8rem}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#000000b3;justify-content:center;align-items:center;padding:20px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:560px;max-height:90vh;box-shadow:var(--shadow-lg);padding:28px;animation:.2s slideUp;overflow-y:auto}.modal-lg{max-width:760px}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-title{font-size:1.2rem;font-weight:700}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;margin-top:24px;padding-top:20px;display:flex}.badge{border-radius:999px;align-items:center;gap:4px;padding:3px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-todo{color:var(--status-todo);background:#6366f126}.badge-in_progress{color:var(--status-progress);background:#f59e0b26}.badge-done{color:var(--status-done);background:#22c55e26}.badge-low{color:var(--priority-low);background:#22c55e26}.badge-medium{color:var(--priority-medium);background:#f59e0b26}.badge-high{color:var(--priority-high);background:#ef444426}.badge-planned{color:var(--week-planned);background:#6366f126}.badge-done-week{color:var(--week-done);background:#22c55e26}.badge-skipped{color:var(--text-muted);background:#4755694d}.badge-admin{color:var(--danger);background:#ef444426}.badge-manager{color:var(--warning);background:#f59e0b26}.badge-member{color:var(--accent);background:#6366f126}.table-wrapper{border:1px solid var(--border);border-radius:var(--radius);overflow-x:auto}table{border-collapse:collapse;width:100%}th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:12px 16px;font-size:.75rem;font-weight:600}td{border-bottom:1px solid var(--border);color:var(--text-primary);padding:12px 16px;font-size:.875rem}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg-card-hover)}.kanban-board{grid-template-columns:repeat(3,1fr);align-items:start;gap:20px;display:grid}.kanban-column{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.kanban-column-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.kanban-column-title{align-items:center;gap:8px;font-size:.875rem;font-weight:600;display:flex}.kanban-column-dot{border-radius:50%;width:8px;height:8px}.dot-todo{background:var(--status-todo)}.dot-in_progress{background:var(--status-progress)}.dot-done{background:var(--status-done)}.kanban-count{background:var(--border);color:var(--text-secondary);border-radius:999px;padding:2px 8px;font-size:.75rem}.kanban-column-body{flex-direction:column;gap:10px;min-height:80px;padding:12px;display:flex}.task-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;padding:14px;transition:all .15s}.task-card:hover{border-color:var(--accent);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.task-card-title{margin-bottom:8px;font-size:.9rem;font-weight:600;line-height:1.4}.task-card-meta{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.task-card-date{color:var(--text-muted);font-size:.75rem}.week-grid{grid-template-columns:repeat(13,1fr);gap:4px;display:grid}.week-cell{aspect-ratio:1;cursor:pointer;border:1px solid #0000;border-radius:4px;transition:all .15s;position:relative}.week-cell:hover{z-index:1;border-color:var(--accent);transform:scale(1.15)}.week-cell.empty{background:var(--bg-secondary);border-color:var(--border)}.week-cell.planned{background:#6366f159}.week-cell.done{background:#22c55e66}.week-cell.skipped{background:#47556966}.week-cell.current-week{box-shadow:var(--shadow-accent);border-color:var(--accent)!important}.week-legend{align-items:center;gap:20px;margin-bottom:16px;display:flex}.week-legend-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:.8rem;display:flex}.week-legend-dot{border-radius:3px;width:12px;height:12px}.auth-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.auth-page:before{content:"";pointer-events:none;background:radial-gradient(circle,#6366f126 0%,#0000 70%);width:600px;height:600px;position:absolute;top:-200px;right:-200px}.auth-page:after{content:"";pointer-events:none;background:radial-gradient(circle,#a78bfa1a 0%,#0000 70%);width:400px;height:400px;position:absolute;bottom:-100px;left:-100px}.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);z-index:1;width:100%;max-width:440px;box-shadow:var(--shadow-lg);padding:40px;position:relative}.auth-logo{align-items:center;gap:12px;margin-bottom:32px;display:flex}.auth-logo-icon{background:linear-gradient(135deg, var(--accent), #a78bfa);border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.3rem;display:flex}.auth-logo-text{background:linear-gradient(90deg, var(--accent), #a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.4rem;font-weight:800}.auth-title{margin-bottom:6px;font-size:1.5rem;font-weight:700}.auth-subtitle{color:var(--text-secondary);margin-bottom:28px;font-size:.9rem}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-footer{text-align:center;color:var(--text-secondary);margin-top:20px;font-size:.875rem}.auth-footer a{color:var(--accent-hover);font-weight:500;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.empty-state{color:var(--text-muted);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:60px 20px;display:flex}.empty-icon{opacity:.4;font-size:3rem}.empty-title{color:var(--text-secondary);font-size:1rem;font-weight:600}.empty-desc{max-width:280px;font-size:.875rem}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:20px;height:20px;animation:.6s linear infinite spin}.loading-page{height:100vh;color:var(--text-secondary);justify-content:center;align-items:center;gap:12px;display:flex}.divider{background:var(--border);height:1px;margin:20px 0}.divider-text{color:var(--text-muted);align-items:center;gap:12px;margin:16px 0;font-size:.8rem;display:flex}.divider-text:before,.divider-text:after{content:"";background:var(--border);flex:1;height:1px}.search-bar{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:10px;padding:8px 14px;transition:border-color .15s;display:flex}.search-bar:focus-within{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-light)}.search-bar input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:.9rem}.search-bar input::placeholder{color:var(--text-muted)}.collapse-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;transition:all .15s;display:flex}.collapse-btn:hover{background:var(--accent-light);color:var(--text-primary)}.checklist-item{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:8px 0;display:flex}.checklist-item:last-child{border-bottom:none}.checklist-checkbox{border:2px solid var(--border);cursor:pointer;width:18px;height:18px;accent-color:var(--accent);border-radius:4px;flex-shrink:0}.checklist-text{color:var(--text-primary);flex:1;font-size:.875rem}.job-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:all .2s;overflow:hidden}.job-card:hover{border-color:var(--accent);box-shadow:var(--shadow-card)}.job-card-header{cursor:pointer;justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.job-card-title{font-size:1rem;font-weight:600}.job-card-dept{color:var(--text-secondary);margin-top:2px;font-size:.8rem}.job-card-body{border-top:1px solid var(--border);padding:16px 20px}.activity-item{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:8px;overflow:hidden}.activity-header{cursor:pointer;justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.activity-title{font-size:.875rem;font-weight:600}.day-badge{background:var(--accent-light);color:var(--accent-hover);border-radius:999px;padding:2px 8px;font-size:.7rem;font-weight:600}.activity-body{border-top:1px solid var(--border);padding:8px 14px 14px}.toast{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);z-index:9999;box-shadow:var(--shadow-lg);align-items:center;gap:12px;max-width:380px;padding:14px 18px;font-size:.875rem;animation:.3s slideInRight;display:flex;position:fixed;bottom:24px;right:24px}.toast.success{border-left:3px solid var(--success)}.toast.error{border-left:3px solid var(--danger)}.toast.info{border-left:3px solid var(--accent)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(50px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width:1200px){.card-grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:900px){.kanban-board{grid-template-columns:1fr}.card-grid-3{grid-template-columns:repeat(2,1fr)}.sidebar{width:var(--sidebar-collapsed)}.sidebar-logo-text,.nav-item span,.nav-section-label,.user-info{display:none}.main-content{margin-left:var(--sidebar-collapsed)}.page-body{padding:16px}}@media (max-width:640px){.card-grid-2,.card-grid-3,.card-grid-4{grid-template-columns:1fr}.auth-card{padding:24px}.page-header{padding:16px 20px}.modal{padding:20px}}input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.85);cursor:pointer;opacity:.8;transition:opacity .2s}input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}[data-theme=light] input[type=date]::-webkit-calendar-picker-indicator{filter:none}
