*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--brand-900:#0f1e4d;--brand-800:#1e3a8a;--brand-700:#1d4ed8;--brand-600:#2563eb;--brand-500:#3b82f6;--brand-100:#dbeafe;--brand-50:#eff6ff;--green-500:#10b981;--green:#22c55e;--amber-500:#f59e0b;--orange:#f97316;--red:#ef4444;--purple:#a855f7;--cyan:#06b6d4;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--text:#1e293b;--text-sub:#64748b;--border:#e2e8f0;--sidebar-w:232px;--topbar-h:52px;--radius:8px;--radius-lg:12px;--shadow-sm:0 1px 2px #0000000f;--shadow:0 4px 16px #0000001a;--shadow-lg:0 8px 32px #00000024}body{color:var(--text);background:var(--gray-50);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,sans-serif;font-size:13px;line-height:1.5}.app-layout{grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--topbar-h) 1fr;grid-template-areas:"sidebar topbar""sidebar main";height:100vh;display:grid;overflow:hidden}.sidebar{background:var(--brand-900);flex-direction:column;grid-area:sidebar;display:flex;overflow:hidden}.sidebar-logo{height:var(--topbar-h);flex-shrink:0;align-items:center;gap:10px;padding:0 18px;display:flex}.sidebar-logo-icon{background:linear-gradient(135deg, var(--brand-600), #7c3aed);border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.sidebar-logo-text{color:#fff;letter-spacing:-.3px;font-size:14px;font-weight:700}.sidebar-section{letter-spacing:.8px;text-transform:uppercase;color:#ffffff59;padding:20px 12px 4px;font-size:10px;font-weight:600}.sidebar-nav{flex-direction:column;gap:1px;padding:4px 8px;display:flex}.sidebar-nav.main{flex:1}.nav-item{cursor:pointer;color:#ffffffa6;border-radius:7px;align-items:center;gap:10px;padding:8px 10px;font-size:13px;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.nav-item:hover{color:#fff;background:#ffffff14}.nav-item.active{background:var(--brand-700);color:#fff}.nav-item-icon{opacity:.85;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;display:flex}.nav-badge{background:var(--brand-500);color:#fff;text-align:center;border-radius:100px;min-width:18px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:700}.nav-item.active .nav-badge{background:#ffffff40}.sidebar-footer{border-top:1px solid #ffffff14;flex-shrink:0;padding:12px}.online-dot{background:var(--green);border:2px solid var(--brand-900);border-radius:50%;width:8px;height:8px;position:absolute;bottom:0;right:0}.topbar{border-bottom:1px solid var(--border);background:#fff;grid-area:topbar;align-items:center;gap:12px;padding:0 20px;display:flex}.topbar-breadcrumb{color:var(--gray-500);align-items:center;gap:6px;font-size:13px;display:flex}.topbar-breadcrumb-sep{color:var(--gray-300)}.topbar-page{color:var(--text);font-size:14px;font-weight:600}.topbar-search{flex:1;max-width:320px;margin:0 8px;position:relative}.topbar-search-input{border:1px solid var(--border);width:100%;color:var(--text);background:var(--gray-50);border-radius:7px;outline:none;padding:6px 12px 6px 32px;font-family:inherit;font-size:13px;transition:border-color .15s,box-shadow .15s}.topbar-search-input:focus{border-color:var(--brand-500);background:#fff;box-shadow:0 0 0 3px #3b82f61f}.topbar-search-icon{color:var(--gray-400);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.topbar-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.topbar-icon-btn{cursor:pointer;width:32px;height:32px;color:var(--gray-500);background:0 0;border:none;border-radius:7px;justify-content:center;align-items:center;transition:background .15s;display:flex}.topbar-icon-btn:hover{background:var(--gray-100);color:var(--text)}.topbar-new-btn{background:var(--brand-600);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:7px;align-items:center;gap:5px;padding:6px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:background .15s;display:inline-flex}.topbar-new-btn:hover{background:var(--brand-700)}.page-area{flex-direction:column;grid-area:main;display:flex;overflow:hidden}.page-content{flex:1;padding:20px 24px;overflow-y:auto}.card{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px;font-size:13px;font-weight:600;display:flex}.card-body{padding:16px}.btn{cursor:pointer;white-space:nowrap;border:1px solid #0000;border-radius:7px;align-items:center;gap:5px;padding:6px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:background .15s,opacity .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--brand-600);color:#fff}.btn-primary:hover:not(:disabled){background:var(--brand-700)}.btn-ghost{color:var(--text);border-color:var(--border);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--gray-100)}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover:not(:disabled){opacity:.88}.btn-sm{padding:4px 10px;font-size:12px}.filter-bar{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:16px;display:flex}.chip{cursor:pointer;border:1px solid var(--border);color:var(--gray-600);background:#fff;border-radius:100px;padding:4px 12px;font-size:12px;font-weight:500;transition:all .15s}.chip:hover{background:var(--gray-100)}.chip.active{background:var(--brand-600);color:#fff;border-color:var(--brand-600)}.form-group{flex-direction:column;gap:5px;display:flex}.form-label{color:var(--gray-600);font-size:12px;font-weight:500}.input,.select,.textarea{border:1px solid var(--border);width:100%;color:var(--text);background:#fff;border-radius:7px;outline:none;padding:7px 11px;font-family:inherit;font-size:13px;transition:border-color .15s}.input:focus,.select:focus,.textarea:focus{border-color:var(--brand-500);box-shadow:0 0 0 3px #3b82f61f}.textarea{resize:vertical;min-height:80px}.badge{border-radius:100px;align-items:center;padding:2px 7px;font-size:11px;font-weight:600;display:inline-flex}.badge-high{color:#dc2626;background:#fef2f2}.badge-medium{color:#d97706;background:#fffbeb}.badge-low{color:#16a34a;background:#f0fdf4}.badge-todo{background:var(--gray-100);color:var(--gray-600)}.badge-progress{color:#d97706;background:#fffbeb}.badge-review{background:var(--brand-50);color:var(--brand-600)}.badge-done{color:#16a34a;background:#f0fdf4}.status-pill{border-radius:100px;align-items:center;gap:5px;padding:3px 9px;font-size:11px;font-weight:600;display:inline-flex}.status-pill:before{content:"";border-radius:50%;flex-shrink:0;width:6px;height:6px}.status-pill.todo{background:var(--gray-100);color:var(--gray-600)}.status-pill.todo:before{background:var(--gray-400)}.status-pill.doing{color:#d97706;background:#fffbeb}.status-pill.doing:before{background:var(--amber-500)}.status-pill.review{background:var(--brand-50);color:var(--brand-600)}.status-pill.review:before{background:var(--brand-500)}.status-pill.done{color:#16a34a;background:#f0fdf4}.status-pill.done:before{background:var(--green)}.tag{border-radius:4px;align-items:center;padding:2px 7px;font-size:10px;font-weight:600;display:inline-flex}.tag.area-design{color:var(--purple);background:#faf5ff}.tag.area-dev{background:var(--brand-50);color:var(--brand-600)}.tag.area-qa{color:var(--orange);background:#fff7ed}.tag.area-pm{color:#16a34a;background:#f0fdf4}.avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:11px;font-weight:700;display:flex;position:relative;overflow:hidden}.avatar img{object-fit:cover;width:100%;height:100%}.avatar-sm{width:22px;height:22px;font-size:9px}.avatar-lg{width:36px;height:36px;font-size:13px}.avatar-xl{width:48px;height:48px;font-size:17px}.modal-backdrop{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a73;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);background:#fff;width:100%;max-width:520px;max-height:92vh;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 20px 14px;font-size:15px;font-weight:600;display:flex}.modal-body{flex-direction:column;gap:14px;padding:18px 20px;display:flex}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:14px 20px 18px;display:flex}.modal-close{width:28px;height:28px;color:var(--gray-400);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:16px;transition:background .15s;display:flex}.modal-close:hover{background:var(--gray-100);color:var(--text)}.auth-page{background:linear-gradient(135deg, var(--brand-900) 0%, #1a3a6b 50%, #1e293b 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{border:1px solid var(--border);box-shadow:var(--shadow-lg);background:#fff;border-radius:16px;width:100%;max-width:400px;padding:40px}.auth-logo{color:var(--text);align-items:center;gap:10px;margin-bottom:28px;font-size:18px;font-weight:700;display:flex}.auth-title{margin-bottom:6px;font-size:22px;font-weight:700}.auth-sub{color:var(--text-sub);margin-bottom:28px;font-size:13px}.auth-form{flex-direction:column;gap:14px;display:flex}.auth-link{color:var(--brand-600);font-weight:500;text-decoration:none}.auth-link:hover{text-decoration:underline}.auth-divider{text-align:center;color:var(--text-sub);margin-top:20px;font-size:12px}.alert{border-radius:7px;align-items:center;gap:7px;padding:9px 12px;font-size:12px;display:flex}.alert-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca}.alert-success{color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0}.alert-info{background:var(--brand-50);color:var(--brand-600);border:1px solid var(--brand-100)}.stats-grid{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px;display:grid}@media (width<=900px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{flex-direction:column;gap:10px;padding:16px 18px;display:flex}.stat-card-top{justify-content:space-between;align-items:flex-start;display:flex}.stat-icon-wrap{border-radius:9px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.stat-delta{border-radius:100px;align-items:center;gap:2px;padding:2px 6px;font-size:11px;font-weight:600;display:flex}.stat-delta.up{color:#16a34a;background:#f0fdf4}.stat-delta.down{color:#dc2626;background:#fef2f2}.stat-value{font-size:26px;font-weight:700;line-height:1}.stat-label{color:var(--text-sub);font-size:12px}.install-banner{border:1px solid var(--brand-100);border-radius:var(--radius-lg);background:linear-gradient(90deg,#eff6ff,#f5f3ff);align-items:center;gap:12px;margin-bottom:18px;padding:10px 16px;font-size:13px;display:flex}.install-banner-icon{background:var(--brand-600);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.install-banner-close{cursor:pointer;color:var(--gray-400);background:0 0;border:none;margin-left:auto;padding:2px 4px;font-size:18px;line-height:1}.dash-grid{grid-template-columns:1.4fr 1fr;align-items:start;gap:16px;display:grid}@media (width<=960px){.dash-grid{grid-template-columns:1fr}}.agenda-item{border-bottom:1px solid var(--border);align-items:flex-start;gap:10px;padding:10px 0;display:flex}.agenda-item:last-child{border-bottom:none}.agenda-bar{border-radius:2px;flex-shrink:0;align-self:stretch;width:3px;min-height:36px}.agenda-title{font-size:13px;font-weight:500}.agenda-meta{color:var(--text-sub);margin-top:2px;font-size:11px}.agenda-time{color:var(--text-sub);flex-shrink:0;min-width:44px;font-size:11px;font-weight:500}.activity-item{border-bottom:1px solid var(--border);align-items:flex-start;gap:10px;padding:9px 0;display:flex}.activity-item:last-child{border-bottom:none}.activity-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:5px}.kanban-board{align-items:flex-start;gap:14px;padding-bottom:16px;display:flex;overflow-x:auto}.kanban-col{background:var(--gray-50);border-radius:var(--radius-lg);border:1px solid var(--border);flex-direction:column;min-width:272px;max-width:272px;display:flex}.kanban-col-header{border-bottom:1px solid var(--border);align-items:center;gap:7px;padding:11px 14px;font-size:12px;font-weight:600;display:flex}.kanban-col-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.kanban-col-count{background:var(--gray-200);color:var(--gray-600);border-radius:100px;margin-left:auto;padding:1px 7px;font-size:11px;font-weight:600}.kanban-cards{flex-direction:column;flex:1;gap:7px;min-height:60px;padding:8px;display:flex}.task-card{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:9px;padding:11px 12px;transition:box-shadow .15s,border-color .15s}.task-card:hover{box-shadow:var(--shadow);border-color:var(--gray-300)}.task-card-id{color:var(--brand-500);letter-spacing:.3px;margin-bottom:5px;font-size:10px;font-weight:700}.task-card-title{margin-bottom:8px;font-size:13px;font-weight:500;line-height:1.4}.task-card-tags{flex-wrap:wrap;gap:4px;margin-bottom:8px;display:flex}.task-card-meta{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.task-card-due{color:var(--gray-500);align-items:center;gap:3px;font-size:11px;display:flex}.tlist-wrap{border-radius:var(--radius-lg);overflow-x:auto}.tlist{border-collapse:collapse;width:100%}.tlist thead th{text-align:left;color:var(--text-sub);border-bottom:2px solid var(--border);background:var(--gray-50);white-space:nowrap;-webkit-user-select:none;user-select:none;padding:9px 14px;font-size:11px;font-weight:600}.tlist thead th:first-child{border-radius:var(--radius-lg) 0 0 0;width:40px}.tlist thead th:last-child{border-radius:0 var(--radius-lg) 0 0}.tlist tbody tr{border-bottom:1px solid var(--border);transition:background .1s}.tlist tbody tr:last-child{border-bottom:none}.tlist tbody tr:hover{background:var(--gray-50)}.tlist tbody td{vertical-align:middle;padding:10px 14px;font-size:13px}.tlist-check{border:1.5px solid var(--gray-300);cursor:pointer;width:15px;height:15px;accent-color:var(--brand-600);border-radius:3px;flex-shrink:0}.week-cal{flex-direction:column;flex:1;display:flex;overflow:hidden}.week-cal-header{border-bottom:1px solid var(--border);background:var(--gray-50);flex-shrink:0;display:grid}.week-col-head{text-align:center;border-right:1px solid var(--border);padding:10px 8px;font-size:12px;font-weight:600}.week-col-head:last-child{border-right:none}.week-col-head-date{font-size:20px;font-weight:700;line-height:1.2;display:block}.week-col-head.today .week-col-head-date{color:var(--brand-600)}.week-body{flex:1;display:flex;overflow-y:auto}.week-time-col{border-right:1px solid var(--border);flex-shrink:0;width:52px}.week-time-slot{height:48px;color:var(--gray-400);border-bottom:1px solid var(--border);align-items:flex-start;padding:3px 6px 0;font-size:10px;font-weight:500;display:flex}.week-grid{flex:1;display:grid}.week-day-col{border-right:1px solid var(--border);position:relative}.week-day-col:last-child{border-right:none}.week-slot{border-bottom:1px solid var(--border);cursor:pointer;height:48px}.week-slot:hover{background:var(--brand-50)}.week-event{color:#fff;cursor:pointer;border-left:3px solid #0003;border-radius:5px;padding:3px 7px;font-size:11px;font-weight:500;line-height:1.3;position:absolute;left:3px;right:3px;overflow:hidden}.calendar-grid{background:var(--border);border:1px solid var(--border);border-radius:var(--radius-lg);grid-template-columns:repeat(7,1fr);gap:1px;display:grid;overflow:hidden}.cal-header-cell{background:var(--gray-50);text-align:center;color:var(--text-sub);text-transform:uppercase;letter-spacing:.5px;padding:8px;font-size:11px;font-weight:600}.cal-cell{cursor:pointer;background:#fff;min-height:88px;padding:7px;transition:background .1s}.cal-cell:hover{background:var(--gray-50)}.cal-cell.other-month .cal-day{color:var(--gray-300)}.cal-cell.today .cal-day-num{background:var(--brand-600);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.cal-day{margin-bottom:4px;font-size:12px;font-weight:600}.cal-event{color:#fff;text-overflow:ellipsis;white-space:nowrap;cursor:pointer;border-radius:4px;margin-bottom:2px;padding:2px 5px;font-size:10px;overflow:hidden}.view-switch{border:1px solid var(--border);border-radius:7px;display:flex;overflow:hidden}.view-switch-btn{cursor:pointer;color:var(--text-sub);background:#fff;border:none;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:500;transition:background .15s,color .15s}.view-switch-btn:hover{background:var(--gray-50);color:var(--text)}.view-switch-btn.active{background:var(--brand-600);color:#fff}.standup-layout{grid-template-columns:240px 1fr;gap:16px;height:100%;display:grid}@media (width<=800px){.standup-layout{grid-template-columns:1fr}}.standup-card{padding:20px}.standup-author{align-items:center;gap:10px;margin-bottom:16px;display:flex}.standup-block{background:var(--gray-50);border-left:3px solid;border-radius:8px;margin-bottom:10px;padding:12px}.standup-block:last-child{margin-bottom:0}.standup-block-label{text-transform:uppercase;letter-spacing:.6px;margin-bottom:5px;font-size:10px;font-weight:700}.standup-block-text{color:var(--text-sub);font-size:13px;line-height:1.6}.history-list{flex-direction:column;display:flex}.history-item{border-bottom:1px solid var(--border);cursor:pointer;align-items:center;gap:10px;padding:11px 14px;transition:background .1s;display:flex}.history-item:hover{background:var(--gray-50)}.history-item.active{background:var(--brand-50)}.history-date{color:var(--text-sub);margin-left:auto;font-size:11px}.member-top{align-items:flex-start;gap:14px;margin-bottom:16px;display:flex}.member-card{padding:18px 20px}.member-workload-bar{background:var(--gray-200);border-radius:3px;height:6px;margin-top:6px;overflow:hidden}.member-workload-fill{border-radius:3px;height:100%;transition:width .4s}.notif-tabs{border-bottom:1px solid var(--border);gap:0;padding:0 4px;display:flex}.notif-tab{cursor:pointer;color:var(--text-sub);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 16px;font-family:inherit;font-size:13px;font-weight:500;transition:color .15s}.notif-tab:hover{color:var(--text)}.notif-tab.active{color:var(--brand-600);border-bottom-color:var(--brand-600)}.notif-group-label{letter-spacing:.6px;text-transform:uppercase;color:var(--text-sub);padding:14px 16px 6px;font-size:11px;font-weight:700}.notif-item{border-bottom:1px solid var(--border);cursor:pointer;align-items:flex-start;gap:12px;padding:12px 16px;transition:background .1s;display:flex}.notif-item:hover{background:var(--gray-50)}.notif-item.unread{background:#f0f7ff}.notif-item.unread:hover{background:#e8f2ff}.notif-unread-dot{background:var(--brand-500);border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-top:5px}.notif-content{flex:1}.notif-title{margin-bottom:2px;font-size:13px;font-weight:500;line-height:1.4}.notif-meta{color:var(--text-sub);font-size:11px}.divider{background:var(--border);height:1px;margin:4px 0}.spinner{border:2px solid var(--gray-200);border-top-color:var(--brand-600);border-radius:50%;width:22px;height:22px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{color:var(--text-sub);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:48px 20px;display:flex}.empty-icon{opacity:.6;font-size:36px;line-height:1}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gray-200);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-300)}.color-dot{cursor:pointer;border:2px solid #0000;border-radius:50%;width:18px;height:18px;transition:border-color .15s}.color-dot.selected{border-color:var(--text);box-shadow:inset 0 0 0 2px #fff}
