:root{--bg:#000000;--surface:#1c1c1e;--border:#2c2c2e;--text:#f5f5f7;--text-muted:#86868b;--primary:#0071e3;--primary-hover:#147ce5;--primary-soft:rgba(0,113,227,0.15);--danger:#ff453a;--danger-soft:rgba(255,69,58,0.15);--success:#32d74b;--warning:#ff9f0a;--radius:12px;--shadow:0 4px 12px rgba(0,0,0,0.3);--shadow-lg:0 20px 48px rgba(0,0,0,0.5)}*{box-sizing:border-box}body,html{margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,SF Pro Icons,Helvetica Neue,Helvetica,Arial,sans-serif;background:var(--bg);background-image:radial-gradient(circle at 50% -20%,#1a1a35 0,#000000 80%);background-attachment:fixed;color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}h1,h2,h3{margin:0;font-weight:650}.app-shell{min-height:100vh}.navbar{background:rgba(28,28,30,.75);border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;z-index:20;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.navbar-inner{max-width:1200px;margin:0 auto;padding:0 24px;height:60px;gap:24px}.brand,.navbar-inner{display:flex;align-items:center}.brand{font-weight:700;font-size:16px;gap:8px}.brand-dot{width:22px;height:22px;border-radius:6px;background:var(--primary);display:inline-block}.nav-links{display:flex;gap:4px;flex:1 1}.nav-link{padding:8px 12px;border-radius:8px;color:var(--text-muted);font-weight:550;transition:background-color .2s,color .2s,transform .1s}.nav-link:hover{background:rgba(255,255,255,.06);color:var(--text)}.nav-link:active{transform:scale(.97)}.nav-link.active{background:var(--primary-soft);color:var(--primary)}.nav-user{display:flex;align-items:center;gap:12px}.container{max-width:1200px;margin:0 auto;padding:28px 24px 64px;opacity:0;animation:page-fade-in .6s cubic-bezier(.16,1,.3,1) forwards}@keyframes page-fade-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}.page-title{font-size:22px}.page-subtitle{color:var(--text-muted);margin-top:4px}.auth-wrap{background:linear-gradient(135deg,#eef2ff,#f4f5f7)}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-lg);padding:32px}.auth-card h1{font-size:20px;margin-bottom:4px}.auth-card .muted{color:var(--text-muted);margin-bottom:22px}.auth-switch{margin-top:18px;color:var(--text-muted)}.auth-switch a{color:var(--primary);font-weight:600}.demo-box{margin-top:20px;padding:12px 14px;background:var(--bg);border:1px dashed var(--border);border-radius:8px;font-size:12.5px;color:var(--text-muted)}.demo-box code{color:var(--text)}.field{margin-bottom:16px}.field label{display:block;font-weight:600;margin-bottom:6px;font-size:13px}input,select,textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:10px;font-size:14px;font-family:inherit;background:rgba(255,255,255,.04);color:var(--text);transition:border-color .25s,box-shadow .25s,background-color .25s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);background:rgba(255,255,255,.08);box-shadow:0 0 0 3px var(--primary-soft)}textarea{resize:vertical;min-height:72px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 16px;border-radius:10px;border:1px solid transparent;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:background-color .2s,border-color .2s,transform .1s,opacity .15s;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);color:var(--text)}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;border:none;box-shadow:0 2px 8px rgba(0,113,227,.2)}.btn-primary:hover:not(:disabled){background:var(--primary-hover);box-shadow:0 4px 12px rgba(0,113,227,.35)}.btn-block{width:100%}.btn-outline{border-color:var(--border);background:transparent}.btn-outline:hover:not(:disabled){background:rgba(255,255,255,.06)}.btn-danger{background:rgba(255,69,58,.12);color:#ff453a;border-color:rgba(255,69,58,.25)}.btn-danger:hover:not(:disabled){background:rgba(255,69,58,.18)}.btn-sm{padding:5px 10px;font-size:12.5px}.btn-ghost{background:transparent;border:1px solid transparent;color:var(--text-muted)}.btn-ghost:hover:not(:disabled){background:rgba(255,255,255,.06);color:var(--text)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.card-pad{padding:18px}.grid{display:grid;grid-gap:16px;gap:16px}.grid-cards{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:28px}.stat{padding:18px}.stat-value{font-size:28px;font-weight:700}.stat-label{color:var(--text-muted);margin-top:2px}.project-card{padding:18px;display:flex;flex-direction:column;gap:10px;background:var(--surface);border:1px solid var(--border);transition:transform .25s cubic-bezier(.16,1,.3,1),box-shadow .25s,background-color .25s}.project-card:hover{transform:translateY(-3px);background:rgba(255,255,255,.04);box-shadow:var(--shadow-lg);border-color:rgba(255,255,255,.1)}.project-card h3{font-size:16px}.project-card .desc{color:var(--text-muted);font-size:13px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-meta{display:flex;gap:14px;color:var(--text-muted);font-size:12.5px;margin-top:auto}.badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:999px;font-size:11.5px;font-weight:650;letter-spacing:.02em}.badge-admin{background:rgba(255,159,10,.15);color:#ff9f0a}.badge-manager{background:rgba(10,132,255,.15);color:#0a84ff}.badge-member{color:#f5f5f7}.badge-member,.badge-todo{background:rgba(255,255,255,.1)}.badge-todo{color:#86868b}.badge-in_progress{background:rgba(10,132,255,.15);color:#0a84ff}.badge-done{background:rgba(48,209,88,.15);color:#30d158}.table{width:100%;border-collapse:collapse}.table td,.table th{text-align:left;padding:12px 14px;border-bottom:1px solid var(--border)}.table th{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.table tr:last-child td{border-bottom:none}.kanban{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:16px;gap:16px;align-items:start}@media (max-width:820px){.kanban{grid-template-columns:1fr}}.kanban-col{background:var(--surface);border:1px solid var(--border);border-radius:16px;display:flex;flex-direction:column;min-height:120px}.kanban-col.drag-over{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-soft)}.kanban-col-head{padding:12px 14px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);font-weight:650}.kanban-count{background:var(--bg);color:var(--text-muted);border-radius:999px;padding:1px 9px;font-size:12px;font-weight:600}.kanban-body{padding:12px;display:flex;flex-direction:column;gap:10px;flex:1 1}.task-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:14px 12px;cursor:-webkit-grab;cursor:grab;box-shadow:var(--shadow);transition:transform .2s cubic-bezier(.16,1,.3,1),box-shadow .2s,background-color .2s}.task-card:hover{transform:translateY(-2px);background:rgba(255,255,255,.05);box-shadow:var(--shadow-lg);border-color:rgba(255,255,255,.1)}.task-card:active{cursor:-webkit-grabbing;cursor:grabbing}.task-card.dragging{opacity:.5}.task-title{font-weight:600;margin-bottom:6px}.task-desc{color:var(--text-muted);font-size:12.5px;margin-bottom:8px}.task-foot{display:flex;align-items:center;justify-content:space-between;gap:8px}.avatar{width:24px;height:24px;border-radius:999px;background:var(--primary-soft);color:var(--primary);border:1px solid rgba(255,255,255,.08);display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}.task-assignee{display:flex;align-items:center;gap:6px;font-size:12px}.due,.task-assignee{color:var(--text-muted)}.due{font-size:11.5px}.due.overdue{color:var(--danger);font-weight:600}.task-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}.task-card:hover .task-actions{opacity:1}.icon-btn{background:transparent;border:none;cursor:pointer;color:var(--text-muted);padding:2px 4px;border-radius:4px;font-size:13px}.icon-btn:hover{background:var(--bg);color:var(--text)}.row{gap:8px}.row,.row-between{display:flex;align-items:center}.row-between{justify-content:space-between;gap:12px}.muted{color:var(--text-muted)}.error-text{color:var(--danger);background:rgba(255,69,58,.1);border:1px solid rgba(255,69,58,.2);padding:9px 12px;border-radius:10px;font-size:13px;margin-bottom:16px}.empty{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty h3{color:var(--text);margin-bottom:6px}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:grid;place-items:center;z-index:50;padding:20px;animation:overlay-fade-in .25s ease-out forwards}@keyframes overlay-fade-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border:1px solid rgba(255,255,255,.08);border-radius:20px;box-shadow:var(--shadow-lg);width:100%;max-width:460px;max-height:90vh;overflow-y:auto;animation:modal-zoom-in .3s cubic-bezier(.16,1,.3,1) forwards}@keyframes modal-zoom-in{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-head{padding:18px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-head h3{font-size:16px}.modal-body{padding:20px}.modal-foot{padding:16px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}.spinner{display:grid;place-items:center;padding:64px;color:var(--text-muted)}.task-card.drag-over-before{border-top:3px solid var(--primary)!important;margin-top:-2px}.task-card.drag-over-after{border-bottom:3px solid var(--primary)!important;margin-bottom:-2px}.modal.modal-lg{max-width:820px}.modal-split{display:flex;gap:24px}@media (max-width:768px){.modal-split{flex-direction:column}.modal-split-right{border-left:none!important;padding-left:0!important;border-top:1px solid var(--border);padding-top:20px}}.attachment-item{transition:background .15s}.attachment-item:hover{background:#eaebed!important}.comment-bubble{margin-bottom:4px}.comment-bubble .avatar{background:var(--primary-soft);color:var(--primary);border:1px solid var(--border)}.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:#000000;background-image:radial-gradient(circle at 50% -20%,#1a1a35 0,#000000 70%);color:#f5f5f7;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,SF Pro Icons,Helvetica Neue,Helvetica,Arial,sans-serif;overflow:hidden;position:relative}.auth-wrap:before{content:"";position:absolute;top:-10%;left:30%;width:400px;height:400px;background:radial-gradient(circle,rgba(99,102,241,.15) 0,transparent 60%);filter:blur(40px);pointer-events:none;animation:auth-float-glow 12s ease-in-out infinite alternate}@keyframes auth-float-glow{0%{transform:translate(0) scale(1)}to{transform:translate(-30px,25px) scale(1.1)}}.auth-card{width:100%;max-width:400px;background:rgba(28,28,30,.72)!important;backdrop-filter:blur(20px) saturate(190%);-webkit-backdrop-filter:blur(20px) saturate(190%);border:1px solid rgba(255,255,255,.08)!important;border-radius:20px!important;box-shadow:0 24px 48px rgba(0,0,0,.6)!important;padding:40px 32px!important;opacity:0;transform:translateY(20px);animation:auth-slide-up-fade .7s cubic-bezier(.16,1,.3,1) forwards}@keyframes auth-slide-up-fade{to{opacity:1;transform:translateY(0)}}.auth-card h1{font-size:24px;font-weight:700;letter-spacing:-.03em;margin-bottom:6px;color:#ffffff;text-align:center}.auth-card .muted{color:#86868b!important;margin-bottom:24px;text-align:center;font-size:13.5px}.auth-wrap input{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:#ffffff;border-radius:10px;padding:12px 14px;font-size:14.5px;transition:border-color .25s,box-shadow .25s,background-color .25s}.auth-wrap input::placeholder{color:rgba(255,255,255,.3)}.auth-wrap input:focus{background:rgba(255,255,255,.09);border-color:#0071e3;box-shadow:0 0 0 4px rgba(0,113,227,.25);outline:none}.auth-wrap label{color:#f5f5f7;font-weight:500;font-size:12.5px;letter-spacing:-.01em}.auth-wrap .btn-primary{background:#0071e3!important;color:#ffffff!important;border-radius:10px!important;font-weight:600!important;font-size:14px!important;padding:12px!important;border:none!important;transition:background .25s,transform .15s,box-shadow .25s!important;box-shadow:0 4px 12px rgba(0,113,227,.3)!important;cursor:pointer}.auth-wrap .btn-primary:hover:not(:disabled){background:#147ce5!important;box-shadow:0 6px 16px rgba(0,113,227,.4)!important}.auth-wrap .btn-primary:active:not(:disabled){transform:scale(.98)}.auth-switch{margin-top:24px;text-align:center;color:#86868b;font-size:13.5px}.auth-switch a{color:#2997ff!important;font-weight:550;text-decoration:none;transition:color .2s}.auth-switch a:hover{color:#51a8ff!important;text-decoration:underline}.auth-wrap .error-text{background:rgba(255,69,58,.12)!important;color:#ff453a!important;border:1px solid rgba(255,69,58,.25)!important;border-radius:10px!important;padding:10px 14px!important;font-size:13px!important;margin-bottom:20px!important;text-align:left}.switch-row{display:flex;align-items:center;gap:10px;margin-top:14px;margin-bottom:20px}.switch-label{font-size:13px;color:#86868b;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.switch{position:relative;display:inline-block;width:42px;height:22px}.switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:rgba(255,255,255,.16);border-radius:22px}.slider,.slider:before{position:absolute;transition:.25s}.slider:before{content:"";height:16px;width:16px;left:3px;bottom:3px;background-color:white;border-radius:50%;box-shadow:0 2px 4px rgba(0,0,0,.3)}.switch input:checked+.slider{background-color:#34c759}.switch input:checked+.slider:before{transform:translateX(20px)}.oauth-divider{display:flex;align-items:center;margin:24px 0 16px;color:#515154;font-size:12px}.oauth-divider:after,.oauth-divider:before{content:"";flex:1 1;border-bottom:1px solid rgba(255,255,255,.08)}.oauth-divider span{padding:0 12px;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.oauth-buttons{display:flex;flex-direction:column;gap:10px;margin-bottom:8px}.btn-oauth{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:11px;border-radius:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);color:#ffffff;font-weight:600;font-size:13.5px;cursor:pointer;transition:background .2s,transform .1s}.btn-oauth:hover{background:rgba(255,255,255,.1)}.btn-oauth:active{transform:scale(.98)}.oauth-icon{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center}.password-input-wrapper{position:relative;display:flex;align-items:center;width:100%}.password-input-wrapper input{padding-right:44px!important}.password-toggle-btn{position:absolute;right:12px;background:transparent;border:none;color:#86868b;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;font-size:18px;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:color .2s;outline:none}.password-toggle-btn:hover{color:#ffffff}