@import "https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg-primary:#0a0a0f;--bg-secondary:#111118;--bg-card:#16161f;--bg-hover:#1e1e2a;--bg-glass:#16161fcc;--border:#ffffff12;--border-hover:#ffffff24;--text-primary:#f0f0f8;--text-secondary:#88a;--text-muted:#55556a;--accent:#7c6af7;--accent-light:#9d8fff;--accent-dim:#7c6af726;--accent-glow:#7c6af74d;--green:#4ade80;--green-dim:#4ade801f;--red:#f87171;--red-dim:#f871711f;--yellow:#fbbf24;--yellow-dim:#fbbf241f;--blue:#60a5fa;--radius-sm:8px;--radius:12px;--radius-lg:16px;--radius-xl:24px;--shadow:0 4px 24px #0006;--shadow-lg:0 8px 48px #0009;--font:"Sora", sans-serif;--font-mono:"JetBrains Mono", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;line-height:1.6}#root{min-height:100vh}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-hover);border-radius:99px}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.animate-in{animation:.3s forwards fadeIn}.slide-in{animation:.3s forwards slideIn}.btn{border-radius:var(--radius-sm);font-family:var(--font);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:7px;padding:9px 18px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-light);box-shadow:0 0 20px var(--accent-glow);transform:translateY(-1px)}.btn-secondary{background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--border-hover);background:#222230}.btn-ghost{color:var(--text-secondary);background:0 0;padding:8px}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-hover)}.btn-danger{background:var(--red-dim);color:var(--red);border:1px solid #f8717133}.btn-danger:hover{background:#f8717133}.btn-sm{padding:6px 12px;font-size:13px}.btn-lg{padding:12px 24px;font-size:15px}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-secondary);font-size:13px;font-weight:500}.form-input,.form-textarea,.form-select{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font);outline:none;padding:10px 14px;font-size:14px;transition:border-color .2s,box-shadow .2s}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-textarea{resize:vertical;min-height:80px}.form-select{cursor:pointer;appearance:none}option{background:var(--bg-secondary)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color .2s,box-shadow .2s}.badge{text-transform:uppercase;letter-spacing:.04em;border-radius:99px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-low{background:var(--green-dim);color:var(--green)}.badge-medium{background:var(--yellow-dim);color:var(--yellow)}.badge-high{background:var(--red-dim);color:var(--red)}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.7s linear infinite spin;display:inline-block}.spinner-lg{border-width:3px;width:36px;height:36px}.skeleton{background:linear-gradient(90deg, var(--bg-card) 25%, var(--bg-hover) 50%, var(--bg-card) 75%);border-radius:var(--radius-sm);background-size:400px 100%;animation:1.4s infinite shimmer}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#000000bf;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-xl);width:100%;max-width:480px;box-shadow:var(--shadow-lg);padding:28px;animation:.2s scaleIn}.modal-header{justify-content:space-between;align-items:center;margin-bottom:22px;display:flex}.modal-title{font-size:18px;font-weight:600}.modal-footer{justify-content:flex-end;gap:10px;margin-top:24px;display:flex}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:56px 24px;display:flex}.empty-state svg{opacity:.25;margin-bottom:4px}.empty-state h3{color:var(--text-secondary);font-size:15px;font-weight:600}.empty-state p{max-width:280px;font-size:13px}.divider{background:var(--border);height:1px}.error-msg{background:var(--red-dim);color:var(--red);border-radius:var(--radius-sm);border:1px solid #f8717140;padding:10px 14px;font-size:13px}.layout{min-height:100vh;display:flex}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);z-index:50;flex-direction:column;flex-shrink:0;width:240px;height:100vh;transition:transform .25s;display:flex;position:sticky;top:0}.sidebar-inner{flex-direction:column;height:100%;padding:20px 12px;display:flex;overflow:hidden}.sidebar-brand{border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-bottom:16px;padding:4px 8px 20px;display:flex}.brand-icon{border-radius:var(--radius-sm);background:var(--accent-dim);border:1px solid var(--accent);width:32px;height:32px;color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;display:flex}.brand-name{letter-spacing:-.3px;flex:1;font-size:16px;font-weight:700}.sidebar-close{display:none}.sidebar-nav{flex-direction:column;flex:1;gap:2px;display:flex}.nav-section-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);padding:0 10px 8px;font-size:11px;font-weight:600}.nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;border:1px solid #0000;align-items:center;gap:10px;padding:9px 12px;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.nav-item:hover{color:var(--text-primary);background:var(--bg-hover)}.nav-item.active{color:var(--accent-light);background:var(--accent-dim);border-color:#7c6af733}.nav-arrow{opacity:0;margin-left:auto;transition:opacity .15s}.nav-item:hover .nav-arrow,.nav-item.active .nav-arrow{opacity:1}.sidebar-footer{border-top:1px solid var(--border);align-items:center;gap:8px;padding-top:16px;display:flex}.sidebar-user{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.user-avatar{background:var(--accent-dim);border:1px solid var(--accent);width:32px;height:32px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.user-avatar.sm{width:28px;height:28px;font-size:12px}.user-info{min-width:0}.user-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.user-email{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.logout-btn{color:var(--text-muted);flex-shrink:0}.logout-btn:hover{color:var(--red)!important;background:var(--red-dim)!important}.layout-main{flex-direction:column;flex:1;min-width:0;display:flex}.topbar{border-bottom:1px solid var(--border);background:var(--bg-secondary);z-index:30;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.hamburger{display:none}.topbar-right{align-items:center;gap:12px;display:flex}.topbar-user{display:none}.layout-content{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:32px}.sidebar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:40;background:#0009;display:none;position:fixed;inset:0}@media (width<=768px){.sidebar{height:100%;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block}.sidebar-close,.hamburger,.topbar-user{display:flex}.layout-content{padding:20px 16px}}.auth-page{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative;overflow:hidden}.auth-bg{pointer-events:none;z-index:0;position:fixed;inset:0}.auth-orb{filter:blur(80px);opacity:.12;border-radius:50%;position:absolute}.auth-orb-1{background:radial-gradient(circle,#7c6af7,#0000);width:500px;height:500px;top:-100px;left:-100px}.auth-orb-2{background:radial-gradient(circle,#4ade80,#0000);width:400px;height:400px;bottom:-80px;right:-80px}.auth-grid{background-image:linear-gradient(#ffffff05 1px,#0000 1px),linear-gradient(90deg,#ffffff05 1px,#0000 1px);background-size:40px 40px;position:absolute;inset:0}.auth-container{z-index:1;flex-direction:column;gap:24px;width:100%;max-width:400px;display:flex;position:relative}.auth-brand{justify-content:center;align-items:center;gap:10px;display:flex}.auth-logo{background:var(--accent-dim);border:1px solid var(--accent);border-radius:var(--radius-sm);width:40px;height:40px;color:var(--accent);justify-content:center;align-items:center;display:flex}.auth-logo-text{letter-spacing:-.5px;font-size:20px;font-weight:700}.auth-card{background:var(--bg-card);padding:32px}.auth-card-header{text-align:center;margin-bottom:28px}.auth-title{margin-bottom:6px;font-size:24px;font-weight:700}.auth-subtitle{color:var(--text-secondary);font-size:14px}.auth-form{flex-direction:column;gap:16px;display:flex}.input-wrap{position:relative}.input-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:13px;transform:translateY(-50%)}.form-input.has-icon{padding-left:38px}.auth-submit{justify-content:center;width:100%;margin-top:4px}.auth-switch{text-align:center;color:var(--text-secondary);margin-top:20px;font-size:13px}.auth-link{color:var(--accent);cursor:pointer;font-size:13px;font-family:var(--font);background:0 0;border:none;padding:0;font-weight:500;text-decoration:none}.auth-link:hover{color:var(--accent-light);text-decoration:underline}.auth-features{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.auth-feature{color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border);border-radius:99px;align-items:center;gap:5px;padding:4px 10px;font-size:12px;display:flex}.auth-feature svg{color:var(--accent)}.dashboard{flex-direction:column;gap:28px;display:flex}.dash-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.dash-greeting{letter-spacing:-.5px;margin-bottom:4px;font-size:26px;font-weight:700}.dash-subtitle{color:var(--text-secondary);font-size:14px}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.stat-card{align-items:center;gap:16px;padding:20px;display:flex}.stat-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.stat-value{letter-spacing:-.5px;margin-bottom:4px;font-size:24px;font-weight:700;line-height:1}.stat-label{color:var(--text-secondary);font-size:13px}.progress-section{padding:20px 24px}.progress-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.progress-title{font-size:14px;font-weight:600}.progress-pct{color:var(--accent);font-size:14px;font-weight:700}.progress-track{background:var(--bg-hover);border-radius:99px;height:6px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--accent), var(--accent-light));border-radius:99px;height:100%;transition:width .8s}.progress-sub{color:var(--text-muted);margin-top:10px;font-size:12px}.recent-section{flex-direction:column;gap:16px;display:flex}.section-header{justify-content:space-between;align-items:center;display:flex}.section-title{font-size:18px;font-weight:600}.section-link{color:var(--accent);align-items:center;gap:5px;font-size:13px;font-weight:500;text-decoration:none;display:flex}.section-link:hover{color:var(--accent-light)}.projects-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.project-card{color:inherit;cursor:pointer;flex-direction:column;gap:10px;padding:20px;text-decoration:none;display:flex;position:relative;overflow:hidden}.project-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow);transform:translateY(-2px)}.project-card-top{align-items:center;gap:10px;display:flex}.project-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.project-name{font-size:15px;font-weight:600}.project-desc{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:13px;line-height:1.4;display:-webkit-box;overflow:hidden}.project-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.meta-tag{color:var(--text-muted);background:var(--bg-hover);border-radius:99px;align-items:center;gap:4px;padding:3px 8px;font-size:12px;display:flex}.meta-tag.done{color:var(--green);background:var(--green-dim)}.mini-progress{background:var(--bg-hover);border-radius:99px;height:3px;overflow:hidden}.mini-fill{border-radius:99px;height:100%;transition:width .6s}.project-arrow{color:var(--text-muted);opacity:0;transition:opacity .2s,transform .2s;position:absolute;top:20px;right:20px}.project-card:hover .project-arrow{opacity:1;transform:translate(2px)}@media (width<=1024px){.stats-grid,.projects-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.stats-grid{grid-template-columns:repeat(2,1fr)}.projects-grid{grid-template-columns:1fr}.dash-greeting{font-size:22px}}.projects-page{flex-direction:column;gap:24px;display:flex}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.page-title{letter-spacing:-.5px;margin-bottom:4px;font-size:26px;font-weight:700}.page-sub{color:var(--text-secondary);font-size:13px}.search-wrap{max-width:360px;position:relative}.search-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-input{padding-left:36px}.projects-list{flex-direction:column;gap:10px;display:flex}.project-row{align-items:stretch;transition:all .2s;display:flex;position:relative;overflow:hidden}.project-row:hover{border-color:var(--border-hover);transform:translate(2px)}.project-color-bar{flex-shrink:0;width:4px}.project-row-content{cursor:pointer;flex:1;align-items:center;gap:16px;min-width:0;padding:16px 20px;display:flex}.project-row-left{flex:1;min-width:0}.project-row-name{margin-bottom:4px;font-size:15px;font-weight:600}.project-row-desc{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:8px;font-size:13px;overflow:hidden}.project-row-meta{flex-wrap:wrap;gap:8px;display:flex}.project-row-right{flex-shrink:0;align-items:center;gap:12px;display:flex}.row-progress{background:var(--bg-hover);border-radius:99px;width:80px;height:4px;overflow:hidden}.row-fill{border-radius:99px;height:100%;transition:width .5s}.row-arrow{color:var(--text-muted);transition:transform .15s}.project-row:hover .row-arrow{color:var(--text-primary);transform:translate(3px)}.row-actions{flex-shrink:0;align-items:center;padding:0 8px;display:flex;position:relative}.dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);z-index:20;min-width:140px;position:absolute;top:calc(100% + 4px);right:0;overflow:hidden}.dropdown-item{cursor:pointer;width:100%;font-family:var(--font);color:var(--text-secondary);text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:9px 14px;font-size:13px;transition:all .15s;display:flex}.dropdown-item:hover{background:var(--bg-hover);color:var(--text-primary)}.dropdown-item.danger:hover{background:var(--red-dim);color:var(--red)}@media (width<=600px){.row-progress{display:none}}.project-detail{flex-direction:column;gap:24px;display:flex}.back-link{color:var(--text-secondary);align-items:center;gap:6px;width:fit-content;font-size:13px;font-weight:500;text-decoration:none;transition:color .15s;display:inline-flex}.back-link:hover{color:var(--text-primary)}.detail-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.detail-header-left{align-items:flex-start;gap:14px;display:flex}.detail-dot{border-radius:50%;flex-shrink:0;width:14px;height:14px;margin-top:6px}.detail-title{letter-spacing:-.5px;margin-bottom:4px;font-size:26px;font-weight:700}.detail-desc{color:var(--text-secondary);font-size:14px}.detail-actions{gap:4px;display:flex}.detail-progress{padding:20px 24px}.dp-stats{align-items:center;gap:0;margin-bottom:16px;display:flex}.dp-stat{text-align:center;flex:1}.dp-stat-value{letter-spacing:-.5px;margin-bottom:2px;font-size:22px;font-weight:700;display:block}.dp-stat-label{color:var(--text-muted);font-size:12px}.dp-divider{background:var(--border);width:1px;height:40px}.dp-bar{background:var(--bg-hover);border-radius:99px;height:6px;overflow:hidden}.dp-fill{border-radius:99px;height:100%;transition:width .6s}.todos-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.filter-tabs{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);gap:2px;padding:3px;display:flex}.filter-tab{color:var(--text-secondary);font-family:var(--font);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.filter-tab:hover{color:var(--text-primary)}.filter-tab.active{background:var(--bg-hover);color:var(--text-primary)}.filter-count{background:var(--bg-hover);color:var(--text-muted);border-radius:99px;padding:1px 6px;font-size:11px}.filter-tab.active .filter-count{background:var(--accent-dim);color:var(--accent)}.todos-list{flex-direction:column;gap:8px;display:flex}.todo-item{align-items:flex-start;gap:12px;padding:14px 16px;transition:all .2s;display:flex;position:relative}.todo-item:hover{border-color:var(--border-hover)}.todo-item.completed{opacity:.6}.todo-item.completed:hover{opacity:.8}.todo-check{border:2px solid var(--border-hover);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;margin-top:2px;transition:all .15s;display:flex}.todo-check:hover{border-color:var(--accent)}.todo-check.checked{border-color:#0000}.todo-body{cursor:pointer;flex:1;min-width:0}.todo-top{flex-wrap:wrap;align-items:flex-start;gap:10px;margin-bottom:4px;display:flex}.todo-title{flex:1;min-width:0;font-size:14px;font-weight:500}.todo-item.completed .todo-title{color:var(--text-muted);text-decoration:line-through}.todo-badges{flex-shrink:0;gap:6px;display:flex}.todo-desc{color:var(--text-secondary);margin-bottom:6px;font-size:13px;line-height:1.4}.todo-due{color:var(--text-muted);align-items:center;gap:4px;font-size:12px;display:inline-flex}.todo-due.overdue{color:var(--red)}.todo-due.today{color:var(--yellow)}.todo-actions{flex-shrink:0;align-items:center;display:flex;position:relative}.todo-menu-btn{opacity:0;transition:opacity .15s}.todo-item:hover .todo-menu-btn{opacity:1}@media (width<=600px){.detail-title{font-size:20px}.dp-stat-value{font-size:18px}}
