:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg-0:#f0f4ff;--bg-1:#e9eefa;--text:#1e2a3e;--muted:#1e2a3eb8;--card:#ffffffa6;--card-strong:#fffc;--border:#1e2a3e1f;--shadow:0 16px 50px #1118271f;--shadow-soft:0 10px 30px #1118271a;--primary:#2c5f8a;--primary-2:#3b82f6;--danger:#dc2626;--radius-lg:24px;--radius-md:14px;--input-bg:#ffffffeb;--accent:var(--primary-2);--ease-elastic:cubic-bezier(.2, .9, .4, 1.1);color:var(--text);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,Liberation Sans,sans-serif}html,body{height:100%}body{background:radial-gradient(1200px 600px at 30% 10%, #fff 0%, transparent 55%), linear-gradient(135deg, var(--bg-0), var(--bg-1));margin:0}*{box-sizing:border-box}button,input,select{font:inherit;color:inherit}#root{flex-direction:column;min-height:100%;display:flex}.appShell{max-width:1200px;margin:0 auto;padding:20px 18px 28px}#root>.appShell:not(.appShellCloud){flex:1;justify-content:center;align-items:center;max-width:none;display:flex}.topBar{z-index:10;border:1px solid var(--border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:var(--shadow-soft);background:#ffffff80;justify-content:space-between;align-items:center;gap:16px;padding:14px 16px;display:flex;position:sticky;top:0}.brandTitle{letter-spacing:.2px;font-size:18px;font-weight:700}.brandSub{color:var(--muted);margin-top:2px;font-size:12px}.topActions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.segmented{border:1px solid var(--border);background:#ffffff8c;border-radius:999px;display:inline-flex;overflow:hidden}.segBtn{cursor:pointer;color:var(--muted);background:0 0;border:0;padding:8px 12px;font-size:13px}.segBtn.active{color:var(--text);background:linear-gradient(135deg,#3b82f62e,#2c5f8a2e)}.ghostBtn{border:1px solid var(--border);cursor:pointer;background:#ffffff8c;border-radius:999px;padding:8px 12px;font-size:13px}.ghostBtn:hover{box-shadow:var(--shadow-soft)}.main{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--card);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:var(--shadow);flex-direction:column;height:calc(100vh - 120px);margin-top:16px;display:flex;overflow:hidden}@media (width<=768px){.appShell{padding:14px 12px 18px}.topBar{flex-direction:column;align-items:stretch}.topActions{justify-content:space-between}}.authScreen{background:0 0;flex:1;justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.authCard{border-radius:var(--radius-lg);border:1px solid var(--border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);width:100%;max-width:400px;box-shadow:var(--shadow-soft);color:var(--text);background:#ffffff8c;padding:28px}.authTitle{color:var(--text);margin:0 0 8px;font-size:1.35rem}.authHint{color:var(--muted);margin:0 0 20px;font-size:13px;line-height:1.5}.authTabs{gap:8px;margin-bottom:20px;display:flex}.authTab{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:#ffffff73;border-radius:8px;flex:1;padding:8px 12px;font-size:14px}.authTab.active{color:var(--text);background:linear-gradient(135deg,#3b82f624,#2c5f8a1f);border-color:#3b82f659}.authForm{flex-direction:column;gap:14px;display:flex}.authField{color:var(--muted);flex-direction:column;gap:6px;font-size:13px;display:flex}.authField input{border:1px solid var(--border);background:var(--input-bg);color:var(--text);border-radius:12px;padding:10px 12px;font-size:14px}.authErr{color:var(--danger);font-size:13px}.authSubmit{width:100%;margin-top:4px}.drawerRoot{z-index:300;pointer-events:none;position:fixed;inset:0}.drawerBackdrop{cursor:pointer;pointer-events:auto;background:#0f172a85;border:none;margin:0;padding:0;animation:.16s drawerFadeIn;position:absolute;inset:0}.drawerPanel{pointer-events:auto;background:var(--card,#fff);border:1px solid var(--border);will-change:transform;backface-visibility:hidden;contain:layout paint;flex-direction:column;max-height:100%;animation:.22s cubic-bezier(.22,1,.36,1) drawerSlideInEnd;display:flex;position:absolute;transform:translateZ(0);box-shadow:-12px 0 48px #0f172a2e}@media (width>=769px){.drawerPanel{border-top:none;border-bottom:none;border-right:none;border-radius:0;width:min(560px,min(92vw,100vw - 32px));height:100%;top:0;right:0}@keyframes drawerSlideInEnd{0%{transform:translate(100%)}to{transform:translate(0,0)}}}@media (width<=768px){.drawerPanel{border-radius:16px 16px 0 0;width:100%;height:auto;max-height:min(88vh,720px);animation:.24s cubic-bezier(.22,1,.36,1) drawerSlideInBottom;bottom:0;left:0;right:0}@keyframes drawerSlideInBottom{0%{transform:translateY(100%)}to{transform:translate(0,0)}}}@keyframes drawerFadeIn{0%{opacity:0}to{opacity:1}}.drawerHeader{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:12px;padding:16px 18px 12px;display:flex}.drawerTitle{color:var(--text);margin:0;font-size:17px;font-weight:700;line-height:1.3}.drawerClose{background:var(--hover,#0000000f);width:36px;height:36px;color:var(--text);cursor:pointer;border:none;border-radius:10px;flex-shrink:0;font-size:22px;line-height:1}.drawerClose:hover{background:var(--border)}.drawerBody{-webkit-overflow-scrolling:touch;content-visibility:auto;flex:1;padding:16px 18px;overflow:auto}.drawerBodySkeleton{background:#64748b14;border-radius:12px;min-height:220px}@media (prefers-reduced-motion:reduce){.drawerBackdrop,.drawerPanel{animation:none!important}}.drawerFooter{border-top:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;justify-content:flex-end;gap:10px;padding:12px 18px 18px;display:flex}.taskDetailGrid{grid-template-columns:1fr 1fr;gap:12px 16px;display:grid}@media (width<=720px){.taskDetailGrid{grid-template-columns:1fr}}.taskFieldLabel{text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:6px;font-size:11px;font-weight:600;display:block}.taskField input,.taskField textarea,.taskField select{border:1px solid var(--border);background:var(--input-bg);width:100%;color:var(--text);border-radius:10px;padding:9px 11px;font-family:inherit;font-size:14px}.taskField textarea{resize:vertical;min-height:88px}.taskDetailActions{border-top:1px solid var(--border);flex-wrap:wrap;gap:10px;margin-top:16px;padding-top:14px;display:flex}.taskDetailActionsRow{grid-template-columns:1fr 1fr;align-items:stretch;display:grid}.taskDetailActionsRow .taskCompleteBtn,.taskDetailActionsRow .taskDangerBtn{box-sizing:border-box;width:100%;margin-left:0}.taskCompleteBtn{border:1px solid color-mix(in srgb, var(--accent,#3b82f6) 45%, var(--border));background:color-mix(in srgb, var(--accent,#3b82f6) 10%, transparent);color:var(--accent,#2563eb);cursor:pointer;border-radius:10px;padding:8px 14px;font-size:13px}.taskCompleteBtn:hover{background:color-mix(in srgb, var(--accent,#3b82f6) 18%, transparent)}.taskCompleteBtnDone{border-color:color-mix(in srgb, var(--border) 70%, var(--text));color:var(--muted);background:0 0}.taskCompleteBtnDone:hover{background:var(--hover,#0000000d);color:var(--text)}.taskDangerBtn{border:1px solid color-mix(in srgb, var(--danger,#ef4444) 50%, var(--border));color:var(--danger,#ef4444);cursor:pointer;background:0 0;border-radius:10px;margin-left:auto;padding:8px 14px;font-size:13px}.taskDangerBtn:hover{background:color-mix(in srgb, var(--danger) 12%, transparent)}.taskAddChildRow{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.taskAddChildRow input{border:1px solid var(--border);background:var(--input-bg);min-width:0;color:var(--text);border-radius:10px;flex:160px;padding:9px 11px}.taskMiniBtn{border:1px solid var(--border);background:var(--input-bg,transparent);color:var(--text);cursor:pointer;border-radius:6px;padding:4px 6px;font-size:12px}.taskMiniBtn:hover:not(:disabled){border-color:var(--accent,#3b82f6);color:var(--accent,#3b82f6)}.taskMiniBtn:disabled{opacity:.35;cursor:not-allowed}.taskCheck{width:18px;height:18px;accent-color:var(--accent,#3b82f6);cursor:pointer}.taskCheckRow{cursor:pointer;align-items:center;gap:8px;padding:6px 0;font-size:14px;line-height:1.2;display:flex}.taskMap{background:var(--panel-bg,var(--bg));flex-direction:column;flex:1;align-self:stretch;width:100%;min-height:0;display:flex;position:relative}.taskMapCanvas{background-image:linear-gradient(#64748b0f 1px,#0000 1px),linear-gradient(90deg,#64748b0f 1px,#0000 1px);background-position:top;background-size:24px 24px;flex:1;min-height:0;padding:16px 18px 20px;overflow:auto}.taskMapCanvas.noScroll{overflow:hidden}.taskMapTopBar{border-bottom:1px solid var(--border);background:linear-gradient(180deg, var(--card,#fff) 0%, transparent 120%);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:10px;padding:12px 18px;display:flex}.taskMapBreadcrumb{color:var(--muted);flex-wrap:wrap;flex:200px;align-items:center;gap:4px 2px;min-width:0;font-size:13px;display:flex}.taskMapCrumb{color:var(--accent,#3b82f6);cursor:pointer;font-size:inherit;text-overflow:ellipsis;white-space:nowrap;background:0 0;border:none;border-radius:8px;max-width:160px;padding:4px 6px;overflow:hidden}.taskMapCrumb:hover{background:var(--hover,#0000000d)}.taskMapCrumb.current{color:var(--text);cursor:default;font-weight:600}.taskMapCrumb.current:hover{background:0 0}.taskMapSep{color:var(--border);-webkit-user-select:none;user-select:none;padding:0 2px}.taskMapScaleHint{color:var(--muted);white-space:nowrap;border:1px solid var(--border);background:#fff6;border-radius:999px;padding:4px 10px;font-size:11px}.taskMapGrid{grid-template-columns:repeat(auto-fill,minmax(268px,1fr));align-content:start;gap:18px;display:grid}.taskMapCard{border:1px solid var(--border);background:var(--card,#fff);box-shadow:var(--shadow-soft,0 2px 12px #0000000f);text-align:left;cursor:grab;will-change:transform;border-radius:14px;flex-direction:row;align-items:stretch;min-height:0;transition:transform .15s,box-shadow .15s,border-color .15s;display:flex;position:relative;overflow:hidden}.taskMapCardCol{border-radius:0 13px 13px 0;flex-direction:column;flex:1;min-width:0;display:flex;position:relative}.taskMapGrid:has(.taskMapCardDragging) .taskMapCard:not(.taskMapCardDragging):hover{box-shadow:var(--shadow-soft,0 2px 12px #0000000f);border-color:var(--border);transform:none}.taskMapCardDragging{opacity:.72;transition:none}.taskMapCardOverlay{cursor:grabbing;opacity:.96;box-shadow:var(--shadow,0 12px 32px #00000029);pointer-events:none;width:min(100vw - 32px,320px)}.taskMapCardDragHint{width:22px;min-height:48px;color:color-mix(in srgb, var(--muted) 85%, var(--text));letter-spacing:-.12em;-webkit-user-select:none;user-select:none;border-right:1px solid color-mix(in srgb, var(--border) 65%, transparent);background:color-mix(in srgb, var(--muted) 5%, transparent);border-radius:13px 0 0 13px;flex:0 0 22px;justify-content:center;align-items:center;font-size:11px;line-height:1;display:flex}.taskMapCardMore{border:1px solid var(--border);width:34px;height:28px;color:var(--text);cursor:pointer;z-index:2;background:#ffffffa6;border-radius:10px;justify-content:center;align-items:center;font-size:18px;line-height:1;display:inline-flex;position:absolute;top:8px;right:8px}.taskMapCardMore:hover{border-color:color-mix(in srgb, var(--accent,#3b82f6) 35%, var(--border));box-shadow:var(--shadow-soft)}.taskMapCard:hover{box-shadow:var(--shadow,0 8px 24px #0000001a);border-color:color-mix(in srgb, var(--accent,#3b82f6) 35%, var(--border));transform:translateY(-2px)}.taskMapCardMain{text-align:left;width:100%;min-width:0;font:inherit;cursor:pointer;background:0 0;border:none;border-radius:0;flex-direction:column;flex:1;align-items:stretch;padding:36px 14px 12px;display:flex}.taskMapCardTitle{color:var(--text);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0 0 8px;font-weight:600;line-height:1.35;display:-webkit-box;overflow:hidden}.taskMapCardDesc{color:var(--muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:2px;font-size:12px;line-height:1.4;display:-webkit-box;overflow:hidden}.taskMapStatus{color:var(--muted);background:#64748b24;border-radius:999px;padding:2px 7px;font-size:10px;font-weight:700}.taskMapStatusDone{color:#15803d;background:#22c55e2e}.taskMapCardMeta{color:var(--muted);flex-wrap:wrap;align-items:center;gap:8px;margin-top:6px;font-size:12px;display:flex}.taskMapBadge{background:color-mix(in srgb, var(--accent) 15%, transparent);color:var(--accent,#2563eb);border-radius:999px;padding:2px 7px;font-size:10px;font-weight:700}.taskMapProgRow{margin-top:10px}.taskMapProgTop{color:var(--muted);font-variant-numeric:tabular-nums;justify-content:space-between;margin-bottom:4px;font-size:11px;display:flex}.taskMapProgBar{background:var(--border);border-radius:3px;height:6px;overflow:hidden}.taskMapProgFill{background:linear-gradient(90deg, var(--accent,#3b82f6), #22c55e);border-radius:3px;height:100%;transition:width .25s}.taskMapEmpty{text-align:center;color:var(--muted);max-width:360px;margin:0 auto;padding:48px 24px;font-size:14px}.taskTableWrap{background:var(--panel-bg,var(--bg));flex-direction:column;flex:1;align-self:stretch;width:100%;min-height:0;display:flex}.taskTableToolbar{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:10px;padding:14px 18px;display:flex}.taskTableToolbarTitle{color:var(--muted);margin-right:auto;font-size:13px;font-weight:600}.taskTableBulkHint{color:var(--muted);border:1px solid var(--border);background:#ffffff59;border-radius:999px;padding:4px 10px;font-size:12px}.taskTableScroll{flex:1;padding:0 0 12px;overflow:auto}.taskTable{table-layout:fixed;border-collapse:separate;border-spacing:0;width:100%;font-size:13px}.taskTable col:nth-child(2),.taskTable col:nth-child(3){width:calc(50% - 169px)}.taskTable.bulkMode col:nth-child(3),.taskTable.bulkMode col:nth-child(4){width:calc(50% - 191px)}.taskTable thead th{z-index:1;text-align:left;background:color-mix(in srgb, var(--panel-bg,var(--bg)) 95%, var(--border));border-bottom:1px solid var(--border);color:var(--text);letter-spacing:.01em;white-space:nowrap;padding:12px;font-size:13px;font-weight:600;position:sticky;top:0}.taskTable thead th.taskTableThDone{text-align:center;min-width:56px}.taskTable tbody td{border-bottom:1px solid var(--border);vertical-align:middle;padding:10px 12px}.taskTable:not(.bulkMode) tbody td:first-child,.taskTable.bulkMode tbody td:nth-child(2){text-align:center}.taskTable tbody tr{cursor:pointer;transition:background .1s}.taskTable tbody tr:hover{background:var(--hover,#ffffff0a)}.taskTable tbody tr.selected{background:color-mix(in srgb, var(--accent,#3b82f6) 10%, var(--panel-bg,var(--bg)))}.taskTableColTitle,.taskTableColDesc{word-wrap:break-word;overflow-wrap:anywhere;min-width:0}.taskTableTitle{color:var(--text);font-weight:500}.taskTableTitle.done{opacity:.55;text-decoration:line-through}.taskTableIndent{color:var(--muted);-webkit-user-select:none;user-select:none;margin-right:6px;font-family:ui-monospace,monospace;font-size:12px;display:inline-block}.taskTableContent{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;min-width:0;overflow:hidden}.taskTableProg{font-variant-numeric:tabular-nums;color:var(--muted);font-size:12px}.taskTableFooterHint{color:var(--muted);border-top:1px solid var(--border);flex-shrink:0;padding:10px 18px 14px;font-size:12px}.modalOverlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;background:#0f172a47;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.modal{border-radius:var(--radius-lg);border:1px solid var(--border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);width:min(560px,100%);box-shadow:var(--shadow);background:#ffffffb8;overflow:hidden}.modalHeader{border-bottom:1px solid #1e2a3e14;justify-content:space-between;align-items:center;gap:10px;padding:14px 16px 10px;display:flex}.modalTitle{letter-spacing:.2px;font-weight:900}.modalBody{gap:10px;padding:14px 16px 16px;display:grid}.formRow{gap:6px;display:grid}.label{color:var(--muted);font-size:12px;font-weight:700}.input,.select{border:1px solid var(--border);background:#ffffffbf;border-radius:12px;padding:9px 10px;font-size:14px}.textarea{border:1px solid var(--border);resize:vertical;background:#ffffffbf;border-radius:12px;min-height:64px;padding:9px 10px;font-size:14px}.modalFooter{justify-content:flex-end;gap:10px;padding:12px 16px 16px;display:flex}.btn{border:1px solid var(--border);cursor:pointer;background:#ffffffb3;border-radius:999px;padding:8px 12px;font-size:13px}.btnPrimary{box-shadow:var(--shadow-soft);background:linear-gradient(135deg,#3b82f62e,#2c5f8a2e)}.btnDanger{color:var(--danger);background:#ef44441f}.cloudTopBar{flex-direction:column;align-items:stretch;gap:10px}@media (width>=720px){.cloudTopBar{flex-direction:row;justify-content:space-between;align-items:center;gap:16px}}.cloudBrand .brandSub{display:none}@media (width>=880px){.cloudBrand .brandSub{display:block}}.cloudToolbar{flex-wrap:wrap;align-items:center;gap:8px;width:100%;display:flex}@media (width>=720px){.cloudToolbar{flex:1;justify-content:flex-end;width:auto;min-width:0}}.cloudTeamSelect{border:1px solid var(--border);min-width:0;max-width:100%;color:var(--text);cursor:pointer;background:#ffffffa6;border-radius:999px;flex:120px;padding:8px 12px;font-size:13px}@media (width>=720px){.cloudTeamSelect{flex:0 200px;max-width:200px}}.cloudSeg{border:1px solid var(--border);background:#ffffff8c;border-radius:999px;display:inline-flex;overflow:hidden}.cloudSegBtn{cursor:pointer;color:var(--muted);background:0 0;border:0;justify-content:center;align-items:center;gap:6px;padding:8px 12px;font-size:13px;display:inline-flex}.cloudSegBtn svg{opacity:.85;flex-shrink:0}.cloudSegBtn.active{color:var(--text);background:linear-gradient(135deg,#3b82f62e,#2c5f8a2e)}@media (width<=480px){.cloudSegBtn .cloudSegLabel{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.cloudSegBtn{padding:8px 12px;position:relative}}.toolbarMenuWrap{margin-left:auto;position:relative}@media (width>=720px){.toolbarMenuWrap{margin-left:0}}.menuTrigger{border:1px solid var(--border);cursor:pointer;color:var(--text);background:#ffffff8c;border-radius:999px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;display:inline-flex}.menuTrigger:hover{box-shadow:var(--shadow-soft)}.menuTrigger svg{flex-shrink:0}@media (width<=380px){.menuTriggerText{display:none}}.menuTriggerBadge{color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:11px;font-weight:700;line-height:1;display:inline-flex}.menuDropdown{border:1px solid var(--border);border-radius:var(--radius-md);min-width:228px;max-width:min(100vw - 32px,300px);box-shadow:var(--shadow);z-index:80;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff5;padding:6px;position:absolute;top:calc(100% + 6px);right:0}.menuItem{text-align:left;cursor:pointer;width:100%;color:var(--text);background:0 0;border:0;border-radius:10px;align-items:center;gap:10px;padding:10px 12px;font-size:14px;display:flex}.menuItem svg{opacity:.75;flex-shrink:0}.menuItem:hover:not(:disabled){background:#3b82f61a}.menuItem:disabled{opacity:.42;cursor:not-allowed}.menuItemDanger{color:var(--danger)}.menuItemDanger svg{opacity:1}.menuSep{background:var(--border);height:1px;margin:6px 8px}.menuItemHint{color:var(--muted);margin-left:auto;font-size:11px;font-weight:600}.appShell.appShellCloud{flex-direction:column;flex:1;width:100%;max-width:none;min-height:100dvh;margin:0;padding:0;display:flex}.appShellCloud .topBar{border-top:none;border-left:none;border-right:none;border-radius:0;flex-shrink:0}.appShellCloud .main{border:none;border-top:1px solid var(--border);height:auto;min-height:0;box-shadow:none;background:var(--card);border-radius:0;flex-direction:column;flex:1;margin:0;display:flex}.appShellCloud .main>*{flex:1;align-self:stretch;width:100%;min-height:0}@media (width<=719px){.appShellCloud .main{min-height:0}}.toastHost{z-index:1200;gap:10px;display:grid;position:fixed;top:16px;right:16px}.toast{border:1px solid var(--border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:var(--shadow-soft);background:#ffffffbf;border-radius:16px;gap:2px;min-width:220px;max-width:min(360px,90vw);padding:10px 12px;animation:.24s both toastIn;display:grid}.toastTitle{font-size:13px;font-weight:900}.toastMsg{color:var(--muted);font-size:12px;line-height:1.3}@keyframes toastIn{0%{opacity:0;transform:translateY(-6px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}
