@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#0f1117;--bg-secondary:#161822;--bg-card:#1c1f2e;--bg-hover:#242738;--border:#2a2d3e;--text-primary:#e4e6f0;--text-secondary:#8b8fa8;--text-muted:#5f6380;--accent:#6366f1;--accent-light:#818cf8;--accent-bg:#6366f11f;--green:#22c55e;--green-bg:#22c55e1f;--yellow:#f59e0b;--yellow-bg:#f59e0b1f;--red:#ef4444;--red-bg:#ef44441f;--purple:#a855f7;--purple-bg:#a855f71f;--blue:#3b82f6;--blue-bg:#3b82f61f;--radius:12px;--radius-sm:8px;--shadow:0 4px 24px #0000004d;color:var(--text-primary);background:var(--bg-primary);font-family:Inter,system-ui,sans-serif;font-size:15px}body{min-height:100vh;margin:0}#root{min-height:100vh}.auth-page{background:var(--bg-primary);background-image:radial-gradient(at 20%,#6366f114 0%,#0000 50%),radial-gradient(at 80% 20%,#a855f70f 0%,#0000 50%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-container{background:var(--bg-secondary);border:1px solid var(--border);width:100%;max-width:420px;box-shadow:var(--shadow);border-radius:20px;padding:40px;animation:.4s fadeUp}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.auth-header{text-align:center;margin-bottom:28px}.auth-logo{margin-bottom:16px}.auth-header h1{margin-bottom:6px;font-size:26px;font-weight:700}.auth-subtitle{color:var(--text-secondary);font-size:14px}.auth-form{flex-direction:column;gap:18px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}input,select,textarea{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);outline:none;width:100%;padding:12px 14px;font-family:inherit;font-size:15px;transition:border-color .2s,box-shadow .2s}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}input::placeholder,textarea::placeholder{color:var(--text-muted)}textarea{resize:vertical}select{cursor:pointer}.auth-btn{background:linear-gradient(135deg, var(--accent), var(--purple));color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;padding:13px;font-family:inherit;font-size:15px;font-weight:600;transition:opacity .2s,transform .1s}.auth-btn:hover{opacity:.9}.auth-btn:active{transform:scale(.98)}.auth-btn:disabled{opacity:.6;cursor:not-allowed}.btn-loading{justify-content:center;align-items:center;gap:8px;display:flex}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.auth-error{background:var(--red-bg);color:var(--red);border-radius:var(--radius-sm);border:1px solid #ef444433;margin-bottom:16px;padding:12px 16px;font-size:14px}.auth-success{background:var(--green-bg);color:var(--green);border-radius:var(--radius-sm);border:1px solid #22c55e33;margin-bottom:16px;padding:12px 16px;font-size:14px}.auth-switch{text-align:center;color:var(--text-secondary);margin-top:24px;font-size:14px}.auth-switch a{color:var(--accent-light);font-weight:600;text-decoration:none}.auth-switch a:hover{text-decoration:underline}.dashboard-layout{min-height:100vh;display:flex}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);z-index:100;flex-direction:column;width:240px;min-height:100vh;padding:20px 12px;display:flex;position:fixed;top:0;left:0}.sidebar-logo{align-items:center;gap:10px;margin-bottom:28px;padding:8px 12px;font-size:18px;font-weight:700;display:flex}.sidebar-nav{flex-direction:column;flex:1;gap:4px;display:flex}.nav-item{color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:10px 14px;font-family:inherit;font-size:14px;font-weight:500;transition:all .15s;display:flex}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent-bg);color:var(--accent-light)}.sidebar-user{border-top:1px solid var(--border);align-items:center;gap:10px;margin-top:8px;padding:12px;display:flex}.user-avatar{background:linear-gradient(135deg, var(--accent), var(--purple));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.user-info{flex-direction:column;flex:1;min-width:0;display:flex}.user-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.user-role{text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.role-admin{color:var(--purple)}.role-member{color:var(--blue)}.logout-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;font-size:18px;transition:color .15s}.logout-btn:hover{color:var(--red)}.main-content{flex:1;max-width:1200px;margin-left:240px;padding:32px}.page-header{margin-bottom:28px}.page-header h1{margin-bottom:4px;font-size:28px;font-weight:700}.page-header p{color:var(--text-secondary);font-size:14px}.toast-error{background:var(--red-bg);color:var(--red);border-radius:var(--radius-sm);border:1px solid #ef444433;justify-content:space-between;align-items:center;margin-bottom:20px;padding:12px 16px;font-size:14px;animation:.3s fadeUp;display:flex}.toast-error button{color:var(--red);cursor:pointer;background:0 0;border:none;font-size:16px}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:32px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:14px;padding:20px;transition:transform .15s,box-shadow .15s;display:flex}.stat-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.stat-icon{border-radius:10px;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;display:flex}.stat-icon.blue{background:var(--blue-bg)}.stat-icon.green{background:var(--green-bg)}.stat-icon.yellow{background:var(--yellow-bg)}.stat-icon.red{background:var(--red-bg)}.stat-icon.purple{background:var(--purple-bg)}.stat-icon.indigo{background:var(--accent-bg)}.stat-value{font-size:24px;font-weight:700;display:block}.stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:12px}.section{margin-bottom:32px}.section-title{margin-bottom:16px;font-size:18px;font-weight:600}.overdue-title{color:var(--red)}.task-list{flex-direction:column;gap:12px;display:flex}.task-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;transition:border-color .15s}.task-card:hover{border-color:var(--accent)}.task-card.overdue{border-left:3px solid var(--red)}.task-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;display:flex}.task-header h3{font-size:16px;font-weight:600}.task-desc{color:var(--text-secondary);margin-bottom:10px;font-size:13px}.task-meta{color:var(--text-muted);flex-wrap:wrap;gap:16px;font-size:13px;display:flex}.task-actions{align-items:center;gap:8px;display:flex}.overdue-date{font-weight:600;color:var(--red)!important}.overdue-badge{background:var(--red);color:#fff;letter-spacing:.5px;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:700}.status-badge{text-transform:capitalize;border-radius:20px;padding:4px 10px;font-size:12px;font-weight:600}.status-pending{background:var(--yellow-bg);color:var(--yellow)}.status-in-progress{background:var(--purple-bg);color:var(--purple)}.status-completed{background:var(--green-bg);color:var(--green)}.status-select{border-radius:6px;min-width:130px;padding:6px 10px;font-size:13px}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;display:grid}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:22px;transition:border-color .15s}.project-card:hover{border-color:var(--accent)}.project-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.project-header h3{font-size:18px;font-weight:600}.project-desc{color:var(--text-secondary);margin-bottom:12px;font-size:14px}.project-meta{color:var(--text-muted);margin-bottom:16px;font-size:12px}.members-section{border-top:1px solid var(--border);padding-top:14px}.members-section h4{color:var(--text-secondary);margin-bottom:10px;font-size:13px;font-weight:600}.member-chips{flex-wrap:wrap;gap:8px;margin-bottom:10px;display:flex}.member-chip{background:var(--accent-bg);color:var(--accent-light);border-radius:20px;align-items:center;gap:6px;padding:4px 12px;font-size:13px;font-weight:500;display:flex}.member-chip button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:12px}.member-chip button:hover{color:var(--red)}.add-member-row{gap:8px;display:flex}.add-member-row select{flex:1}.btn-small{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:6px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:600}.btn-small:hover{opacity:.9}.icon-btn{cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:16px;transition:background .15s}.icon-btn.danger:hover{background:var(--red-bg)}.create-grid{grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:20px;display:grid}.create-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px}.create-card h2{margin-bottom:20px;font-size:20px}.create-card form{flex-direction:column;gap:16px;display:flex}.empty-state{text-align:center;color:var(--text-muted);padding:40px;font-size:14px}@media (width<=768px){.sidebar{width:64px;padding:12px 8px}.sidebar-logo span,.nav-item span,.user-info,.logout-btn{display:none}.nav-item{justify-content:center;padding:12px}.sidebar-user{justify-content:center}.main-content{margin-left:64px;padding:20px}.stats-grid{grid-template-columns:repeat(2,1fr)}.create-grid,.projects-grid{grid-template-columns:1fr}}
