:root{--accent-50: #eef2ff;--accent-100: #e0e7ff;--accent-200: #c7d2fe;--accent-300: #a5b4fc;--accent-400: #818cf8;--accent-500: #6366f1;--accent-600: #4f46e5;--accent-700: #4338ca;--accent-800: #3730a3;--accent-900: #312e81;--st-backlog: #71717a;--st-pending: #f59e0b;--st-progress: #3b82f6;--st-review: #a855f7;--st-done: #10b981;--st-canceled: #64748b;--st-blocked: #ef4444;--pr-urgent: #ef4444;--pr-high: #f97316;--pr-medium: #eab308;--pr-low: #38bdf8;--tag-1: #ec4899;--tag-2: #f97316;--tag-3: #eab308;--tag-4: #22c55e;--tag-5: #06b6d4;--tag-6: #6366f1;--tag-7: #a855f7;--tag-8: #f43f5e;--r-xs: 4px;--r-sm: 6px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px;--r-2xl: 20px;--r-full: 9999px;--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 20px;--s-6: 24px;--s-8: 32px;--s-10: 40px;--s-12: 48px;--row-h: 40px;--sidebar-w: 248px;--font-sans: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-mono: ui-monospace, "SF Mono", Menlo, monospace}:root,[data-theme=dark]{--bg-0: #0a0a0b;--bg-1: #111114;--bg-2: #16161a;--bg-3: #1c1c22;--bg-hover: #1f1f26;--bg-active: #26262e;--border: #232329;--border-strong: #2e2e36;--border-subtle: #1a1a20;--text-1: #f4f4f5;--text-2: #c8c8d0;--text-3: #8a8a93;--text-4: #5b5b63;--shadow-sm: 0 1px 2px rgba(0,0,0,.4);--shadow-md: 0 4px 12px rgba(0,0,0,.35);--shadow-lg: 0 24px 48px -12px rgba(0,0,0,.55);--kbd-bg: #1c1c22;--kbd-border: #2e2e36;color-scheme:dark}[data-theme=light]{--bg-0: #fafafa;--bg-1: #ffffff;--bg-2: #ffffff;--bg-3: #f4f4f5;--bg-hover: #f4f4f5;--bg-active: #e9e9ee;--border: #e7e7ea;--border-strong: #d4d4d8;--border-subtle: #efeff2;--text-1: #09090b;--text-2: #3f3f46;--text-3: #71717a;--text-4: #a1a1aa;--shadow-sm: 0 1px 2px rgba(15,15,20,.06);--shadow-md: 0 4px 12px rgba(15,15,20,.08);--shadow-lg: 0 24px 48px -12px rgba(15,15,20,.18);--kbd-bg: #f4f4f5;--kbd-border: #d4d4d8;color-scheme:light}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font-sans);background:var(--bg-0);color:var(--text-1);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button{font:inherit;color:inherit;cursor:pointer}input,textarea,select{font:inherit;color:inherit}a{color:inherit;text-decoration:none}::selection{background:var(--accent-500);color:#fff}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:10px;border:2px solid transparent;background-clip:padding-box}*::-webkit-scrollbar-thumb:hover{background:var(--text-4);border:2px solid transparent;background-clip:padding-box}.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;height:100vh;overflow:hidden}.sidebar{background:var(--bg-1);border-right:1px solid var(--border);display:flex;flex-direction:column;min-height:0}.sb-head{height:56px;padding:0 12px 0 14px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border-subtle)}.sb-logo{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,var(--accent-400),var(--accent-600));display:grid;place-items:center;color:#fff;font-weight:700;font-size:14px;letter-spacing:-.02em;box-shadow:0 0 0 1px #ffffff0f inset,0 6px 14px -4px var(--accent-700)}.sb-name{font-weight:600;letter-spacing:-.02em;font-size:14.5px}.sb-name small{display:block;color:var(--text-3);font-weight:500;font-size:11.5px;letter-spacing:0}.sb-chev{margin-left:auto;color:var(--text-3)}.sb-search{margin:12px 12px 4px;display:flex;align-items:center;gap:8px;height:32px;padding:0 10px;border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-3);font-size:13px;cursor:text;background:transparent;transition:border-color .12s}.sb-search:hover{border-color:var(--border-strong)}.sb-search kbd{margin-left:auto;font-family:var(--font-sans);font-size:11px;padding:1px 5px;border:1px solid var(--kbd-border);border-radius:4px;background:var(--kbd-bg);color:var(--text-3)}.sb-nav{padding:12px 8px;overflow-y:auto;flex:1;min-height:0}.sb-group{padding:12px 8px 4px;font-size:11px;color:var(--text-4);letter-spacing:.06em;text-transform:uppercase;font-weight:600;display:flex;align-items:center;justify-content:space-between}.sb-group .plus{color:var(--text-4);cursor:pointer}.sb-group .plus:hover{color:var(--text-2)}.sb-item{display:flex;align-items:center;gap:10px;padding:0 10px;height:32px;border-radius:var(--r-sm);color:var(--text-2);font-size:13.5px;font-weight:500;cursor:pointer;-webkit-user-select:none;user-select:none;position:relative}.sb-item:hover,.sb-item.active{background:var(--bg-hover);color:var(--text-1)}.sb-item.active:before{content:"";position:absolute;left:-8px;top:6px;bottom:6px;width:2px;border-radius:2px;background:var(--accent-500)}.sb-item .ic{width:16px;height:16px;color:var(--text-3);flex-shrink:0}.sb-item.active .ic{color:var(--accent-400)}[data-theme=light] .sb-item.active .ic{color:var(--accent-600)}.sb-item .count{margin-left:auto;font-size:11px;color:var(--text-3);background:var(--bg-3);padding:1px 6px;border-radius:999px;font-variant-numeric:tabular-nums}.sb-item .dot{margin-left:auto;width:6px;height:6px;border-radius:50%;background:var(--accent-500)}.sb-sub{display:flex;align-items:center;gap:8px;padding:0 10px 0 28px;height:28px;border-radius:var(--r-sm);color:var(--text-2);font-size:13px;cursor:pointer}.sb-sub:hover,.sb-sub.active{background:var(--bg-hover);color:var(--text-1)}.sb-sub .sw{width:8px;height:8px;border-radius:2px;flex-shrink:0}.sb-foot{padding:10px 12px;border-top:1px solid var(--border-subtle);display:flex;align-items:center;gap:10px}.sb-foot .who{font-size:13px;font-weight:600;line-height:1.1}.sb-foot .who small{display:block;color:var(--text-3);font-weight:500;font-size:11.5px}.sb-foot .icbtn{margin-left:auto}.main{display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden}.content{flex:1;min-height:0;overflow-y:auto}.topbar{height:52px;display:flex;align-items:center;gap:12px;padding:0 20px;border-bottom:1px solid var(--border);background:var(--bg-0);flex-shrink:0}.crumbs{display:flex;align-items:center;gap:6px;font-size:13.5px;color:var(--text-2)}.crumbs .sep{color:var(--text-4);width:14px;height:14px}.crumbs .cur{color:var(--text-1);font-weight:600}.topbar .spacer{flex:1}.search{display:flex;align-items:center;gap:8px;height:32px;padding:0 10px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg-2);color:var(--text-3);min-width:280px;cursor:text}.search:hover{border-color:var(--border-strong)}.search input{background:transparent;border:0;outline:0;flex:1;color:var(--text-1);font-size:13px}.search input::placeholder{color:var(--text-3)}.search kbd{font-family:var(--font-sans);font-size:11px;padding:1px 5px;border:1px solid var(--kbd-border);border-radius:4px;background:var(--kbd-bg);color:var(--text-3)}.btn{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--bg-2);color:var(--text-1);font-size:13px;font-weight:500;cursor:pointer;transition:background .12s,border-color .12s;white-space:nowrap}.btn:hover{background:var(--bg-hover);border-color:var(--border-strong)}.btn .ic{width:14px;height:14px}.btn.primary{background:var(--accent-500);border-color:var(--accent-500);color:#fff;box-shadow:0 0 0 1px #ffffff0a inset,0 4px 10px -4px var(--accent-700)}.btn.primary:hover{background:var(--accent-600);border-color:var(--accent-600)}.btn.ghost{background:transparent;border-color:transparent;color:var(--text-2)}.btn.ghost:hover{background:var(--bg-hover);color:var(--text-1)}.btn.sm{height:28px;padding:0 10px;font-size:12.5px;border-radius:var(--r-sm)}.btn.icon{padding:0;width:32px;justify-content:center}.btn.icon.sm{width:28px}.btn.danger{color:var(--pr-urgent)}.btn.danger:hover{background:color-mix(in oklab,var(--pr-urgent) 12%,transparent)}.btn:disabled{opacity:.5;cursor:not-allowed}.input,.select,.textarea{width:100%;height:32px;padding:0 10px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg-2);color:var(--text-1);font-size:13px;outline:none;transition:border-color .12s,box-shadow .12s}.input:focus,.select:focus,.textarea:focus{border-color:var(--accent-500);box-shadow:0 0 0 3px color-mix(in oklab,var(--accent-500) 22%,transparent)}.textarea{height:auto;padding:10px;min-height:84px;line-height:1.5;resize:vertical}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='none' stroke='%238a8a93' stroke-width='1.5' d='M1 1l4 4 4-4'/></svg>");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}.input-icon{position:relative}.input-icon .ic-l{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-3);pointer-events:none;width:14px;height:14px}.input-icon .input{padding-left:32px}.page{flex:1;min-height:0;min-width:0;overflow:auto;position:relative}.page-head{padding:22px 28px 16px;display:flex;align-items:flex-end;gap:16px;border-bottom:1px solid var(--border-subtle)}.page-head h1{margin:0;font-size:22px;font-weight:600;letter-spacing:-.02em}.page-head .sub{color:var(--text-3);font-size:13px;margin-top:4px}.page-head .actions{margin-left:auto;display:flex;gap:8px;align-items:center}.page-body{padding:20px 28px 40px}.tabs{display:flex;gap:4px;padding:0 28px;border-bottom:1px solid var(--border);background:var(--bg-0);position:sticky;top:0;z-index:5}.tab{padding:10px 12px;font-size:13px;font-weight:500;color:var(--text-3);display:inline-flex;align-items:center;gap:6px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.tab:hover{color:var(--text-1)}.tab.active{color:var(--text-1);border-bottom-color:var(--accent-500)}.tab .ic{width:14px;height:14px}.tab .count{font-variant-numeric:tabular-nums;color:var(--text-4);font-weight:500;margin-left:2px}.toolbar{display:flex;align-items:center;gap:8px;padding:12px 28px;border-bottom:1px solid var(--border-subtle);flex-wrap:wrap}.chip{display:inline-flex;align-items:center;gap:6px;height:28px;padding:0 10px;border:1px dashed var(--border-strong);border-radius:var(--r-md);background:transparent;color:var(--text-2);font-size:12.5px;cursor:pointer}.chip:hover{background:var(--bg-hover);color:var(--text-1)}.chip.set{border-style:solid;border-color:var(--border);background:var(--bg-2);color:var(--text-1)}.chip .ic{width:12px;height:12px}.card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-lg)}.kpi{grid-column:span 3;padding:16px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-lg)}.kpi .label{font-size:12px;color:var(--text-3);font-weight:500;letter-spacing:.01em;display:flex;align-items:center;gap:6px}.kpi .label .ic{width:14px;height:14px}.kpi .num{font-size:30px;font-weight:600;letter-spacing:-.025em;margin-top:8px;line-height:1.1;font-variant-numeric:tabular-nums}.kpi .delta{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;font-weight:500;margin-top:6px}.kpi .delta.up{color:var(--st-done)}.kpi .delta.down{color:var(--pr-urgent)}.kpi .spark{margin-top:10px}.section{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px}.section-head{display:flex;align-items:center;gap:8px;margin-bottom:12px}.section-head h3{margin:0;font-size:14px;font-weight:600;letter-spacing:-.01em}.section-head .sub{color:var(--text-3);font-size:12.5px;margin-left:auto}.tlist{width:100%}.tlist .row{display:grid;grid-template-columns:28px 52px 1fr 140px 110px 110px 90px 64px 60px;align-items:center;height:var(--row-h);padding:0 28px;border-bottom:1px solid var(--border-subtle);cursor:pointer;font-size:13.5px;position:relative}.tlist .row:hover{background:var(--bg-hover)}.tlist .row.head{color:var(--text-3);font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;font-weight:600;height:36px;cursor:default;background:var(--bg-0);border-top:1px solid var(--border-subtle)}.tlist .row.head:hover{background:var(--bg-0)}.tlist .row .check{width:16px;height:16px;border-radius:4px;border:1.5px solid var(--border-strong);cursor:pointer}.tlist .row:hover .check{border-color:var(--text-3)}.tlist .id{color:var(--text-3);font-family:var(--font-mono);font-size:11.5px;letter-spacing:-.01em}.tlist .title{font-weight:500;color:var(--text-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-right:16px;display:flex;align-items:center;gap:8px;min-width:0}.tlist .title .tags{display:inline-flex;gap:4px}.tlist .grp{background:var(--bg-1);height:36px;display:flex;align-items:center;gap:8px;padding:0 28px;font-size:12px;font-weight:600;color:var(--text-2);letter-spacing:-.01em;border-bottom:1px solid var(--border-subtle);border-top:1px solid var(--border)}.tlist .grp .ic{width:12px;height:12px;color:var(--text-3)}.tlist .grp .n{color:var(--text-3);font-weight:500}.tlist .grp .add{margin-left:auto;color:var(--text-3);font-size:11.5px;cursor:pointer;display:inline-flex;align-items:center;gap:4px}.tlist .grp .add:hover{color:var(--text-1)}.tlist .row.selected{background:color-mix(in oklab,var(--accent-500) 8%,transparent)}.status{display:inline-flex;align-items:center;gap:6px;height:22px;padding:0 8px;border-radius:var(--r-full);font-size:11.5px;font-weight:500;color:var(--text-1);background:color-mix(in oklab,var(--c, var(--text-3)) 16%,transparent);border:1px solid color-mix(in oklab,var(--c, var(--text-3)) 28%,transparent)}.status .dot{width:6px;height:6px;border-radius:50%;background:var(--c, var(--text-3))}.status.backlog{--c: var(--st-backlog)}.status.pending{--c: var(--st-pending)}.status.progress{--c: var(--st-progress)}.status.review{--c: var(--st-review)}.status.done{--c: var(--st-done)}.status.canceled{--c: var(--st-canceled);color:var(--text-3)}.status.blocked{--c: var(--st-blocked)}.priority{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--text-2)}.priority .flag{width:12px;height:12px;color:var(--c, var(--text-3))}.priority.urgent{--c: var(--pr-urgent);color:var(--pr-urgent)}.priority.high{--c: var(--pr-high);color:var(--text-1)}.priority.medium{--c: var(--pr-medium);color:var(--text-1)}.priority.low{--c: var(--pr-low);color:var(--text-2)}.av{width:22px;height:22px;border-radius:50%;display:inline-grid;place-items:center;font-size:10.5px;font-weight:600;color:#fff;flex-shrink:0;letter-spacing:.01em;border:1px solid color-mix(in oklab,#000 30%,transparent)}.av.lg{width:32px;height:32px;font-size:12px}.av.xl{width:44px;height:44px;font-size:15px}.av.xs{width:18px;height:18px;font-size:9.5px}.av-stack{display:inline-flex}.av-stack .av{margin-left:-6px;box-shadow:0 0 0 2px var(--bg-0)}.av-stack .av:first-child{margin-left:0}.tag{display:inline-flex;align-items:center;height:18px;padding:0 7px;border-radius:4px;font-size:10.5px;font-weight:600;letter-spacing:.01em;color:#fff;background:var(--c, var(--text-4))}.tag.soft{color:var(--c, var(--text-3));background:color-mix(in oklab,var(--c, var(--text-3)) 16%,transparent)}.date{color:var(--text-2);font-variant-numeric:tabular-nums;font-size:12.5px}.date.overdue{color:var(--pr-urgent)}.date.today{color:var(--pr-high)}.kanban{display:flex;gap:14px;padding:16px 28px 28px;height:100%;overflow-x:auto;align-items:flex-start}.kcol{width:304px;flex-shrink:0;background:var(--bg-1);border:1px solid var(--border-subtle);border-radius:var(--r-lg);display:flex;flex-direction:column;max-height:calc(100vh - 220px)}.kcol .head{height:40px;display:flex;align-items:center;gap:8px;padding:0 12px;border-bottom:1px solid var(--border-subtle)}.kcol .head .dot{width:8px;height:8px;border-radius:50%;background:var(--c, var(--text-3))}.kcol .head .name{font-weight:600;font-size:13px;letter-spacing:-.01em}.kcol .head .n{color:var(--text-3);font-size:12px;font-variant-numeric:tabular-nums}.kcol .head .add{margin-left:auto;color:var(--text-3);cursor:pointer}.kcol .head .add:hover{color:var(--text-1)}.kcol .body{padding:8px;flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.kcol.drop-over{outline:2px dashed var(--accent-500);outline-offset:-4px;background:color-mix(in oklab,var(--accent-500) 4%,var(--bg-1))}.kcard{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);padding:10px 12px 11px;cursor:pointer;transition:transform .12s,box-shadow .12s,border-color .12s}.kcard:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.kcard:active{transform:scale(.99)}.kcard .top{display:flex;align-items:center;gap:6px;margin-bottom:6px}.kcard .kid{font-family:var(--font-mono);font-size:10.5px;color:var(--text-3)}.kcard .title{font-size:13.5px;font-weight:500;color:var(--text-1);letter-spacing:-.005em;line-height:1.35}.kcard .meta{display:flex;align-items:center;gap:8px;margin-top:10px;color:var(--text-3);font-size:11.5px}.kcard .meta .right{margin-left:auto;display:flex;align-items:center;gap:8px}.kcard .tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:8px}.kcard .progress{height:3px;border-radius:999px;background:var(--bg-3);margin-top:8px;overflow:hidden}.kcard .progress>div{height:100%;background:var(--accent-500)}.kcard.dragging{opacity:.4}.cal{padding:16px 28px 28px}.cal-head{display:flex;align-items:center;gap:8px;padding:0 0 12px}.cal-head .month{font-size:16px;font-weight:600;letter-spacing:-.01em}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:var(--bg-1)}.cal-grid .dow{padding:8px 10px;font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-weight:600;border-bottom:1px solid var(--border-subtle);border-right:1px solid var(--border-subtle);background:var(--bg-0)}.cal-grid .dow:last-child{border-right:0}.cal-day{min-height:116px;padding:6px 8px;background:var(--bg-1);border-right:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:4px;position:relative}.cal-day.off{background:var(--bg-0);color:var(--text-4)}.cal-day .num{font-size:12px;color:var(--text-2);font-weight:500;font-variant-numeric:tabular-nums}.cal-day.today .num{background:var(--accent-500);color:#fff;width:22px;height:22px;border-radius:50%;display:grid;place-items:center}.cal-evt{display:flex;align-items:center;gap:6px;height:20px;padding:0 6px;border-radius:4px;background:color-mix(in oklab,var(--c, var(--accent-500)) 18%,transparent);color:color-mix(in oklab,var(--c, var(--accent-500)) 80%,white);border-left:2px solid var(--c, var(--accent-500));font-size:11.5px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer}[data-theme=light] .cal-evt{color:color-mix(in oklab,var(--c, var(--accent-500)) 50%,black)}.dash{padding:20px 28px 40px;display:grid;grid-template-columns:repeat(12,1fr);gap:16px}.drawer-back{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:50;opacity:0;pointer-events:none;transition:opacity .18s}.drawer-back.open{opacity:1;pointer-events:all}.drawer{position:fixed;top:0;right:0;bottom:0;width:min(820px,calc(100vw - 80px));background:var(--bg-1);border-left:1px solid var(--border);z-index:51;transform:translate(100%);transition:transform .22s cubic-bezier(.32,.72,0,1);display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.drawer.open{transform:translate(0)}.drawer .dhead{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border-subtle);min-height:52px}.drawer .dhead .did{font-family:var(--font-mono);font-size:12px;color:var(--text-3)}.drawer .dhead .actions{margin-left:auto;display:flex;gap:4px}.drawer .dbody{display:grid;grid-template-columns:1fr 280px;flex:1;min-height:0;overflow:hidden}.drawer .dmain{padding:24px 28px;overflow-y:auto;display:flex;flex-direction:column;gap:18px}.drawer .dside{padding:18px;border-left:1px solid var(--border-subtle);background:var(--bg-0);overflow-y:auto}.drawer .dside .row{display:grid;grid-template-columns:96px 1fr;align-items:center;gap:8px;padding:8px 0}.drawer .dside .row .k{font-size:12px;color:var(--text-3);font-weight:500}.drawer .dside .row .v{font-size:12.5px;color:var(--text-1);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.drawer .dside hr{border:0;border-top:1px solid var(--border-subtle);margin:6px 0}.title-edit{font-size:22px;font-weight:600;letter-spacing:-.02em;color:var(--text-1);background:transparent;border:0;outline:0;padding:4px 0;width:100%}.title-edit:focus{background:var(--bg-2);border-radius:6px;padding:4px 8px}.checklist{display:flex;flex-direction:column;gap:6px}.checklist .item{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid var(--border-subtle)}.checklist .item:last-child{border-bottom:0}.checklist .box{width:16px;height:16px;border-radius:4px;border:1.5px solid var(--border-strong);display:grid;place-items:center;cursor:pointer;flex-shrink:0}.checklist .box.on{background:var(--accent-500);border-color:var(--accent-500)}.checklist .text{flex:1;font-size:13.5px}.checklist .item.on .text{color:var(--text-3);text-decoration:line-through}.comments{display:flex;flex-direction:column;gap:14px}.cmt{display:flex;gap:10px}.cmt .bubble{flex:1;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:10px 12px}.cmt .bubble .who{font-size:12.5px;font-weight:600}.cmt .bubble .when{font-size:11.5px;color:var(--text-3);margin-left:6px;font-weight:500}.cmt .bubble .body{margin-top:4px;font-size:13.5px;color:var(--text-2)}.cmt-compose{display:flex;gap:10px}.cmt-compose .field{flex:1;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--bg-2);padding:8px 10px;display:flex;flex-direction:column;gap:6px}.cmt-compose .field:focus-within{border-color:var(--accent-500);box-shadow:0 0 0 3px color-mix(in oklab,var(--accent-500) 22%,transparent)}.cmt-compose textarea{background:transparent;border:0;outline:0;resize:none;color:var(--text-1);min-height:40px;font:inherit}.cmt-compose .tools{display:flex;align-items:center;gap:4px}.act-log{display:flex;flex-direction:column;gap:6px}.act{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text-3)}.act b{color:var(--text-2);font-weight:600}.modal-back{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:60;display:grid;place-items:center;opacity:0;pointer-events:none;transition:opacity .16s}.modal-back.open{opacity:1;pointer-events:all}.modal{background:var(--bg-1);border:1px solid var(--border);border-radius:14px;width:min(640px,calc(100vw - 40px));max-height:calc(100vh - 80px);transform:scale(.96);transition:transform .18s cubic-bezier(.32,.72,0,1);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden}.modal-back.open .modal{transform:scale(1)}.modal-head{padding:14px 16px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;gap:8px}.modal-head h3{margin:0;font-size:14.5px;font-weight:600}.modal-head .actions{margin-left:auto;display:flex;gap:6px}.modal-body{padding:16px 18px;display:flex;flex-direction:column;gap:12px;overflow:auto}.modal-foot{padding:12px 16px;border-top:1px solid var(--border-subtle);display:flex;gap:8px}.modal-foot .right{margin-left:auto;display:flex;gap:8px}.field-row{display:flex;align-items:center;gap:8px}.field-label{font-size:12px;color:var(--text-3);font-weight:500;width:80px;flex-shrink:0;display:flex;align-items:center;gap:4px}.pop{position:fixed;z-index:70;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);min-width:220px;overflow:hidden}.pop .ph{padding:8px 10px 6px;font-size:11px;color:var(--text-4);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.pop .pi{display:flex;align-items:center;gap:8px;height:30px;padding:0 10px;font-size:13px;cursor:pointer;color:var(--text-1)}.pop .pi:hover{background:var(--bg-hover)}.pop .pi .ic{width:14px;height:14px;color:var(--text-3)}.pop .pi.on .check{color:var(--accent-500);margin-left:auto}.pop .sep{height:1px;background:var(--border-subtle);margin:4px 0}.toasts{position:fixed;bottom:20px;right:20px;z-index:100;display:flex;flex-direction:column;gap:8px}.toast{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r-md);padding:10px 14px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-lg);font-size:13px;animation:toast-in .2s cubic-bezier(.32,.72,0,1)}@keyframes toast-in{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}.toast .ic{color:var(--st-done)}.empty{padding:60px 20px;text-align:center;color:var(--text-3)}.empty .icbox{width:56px;height:56px;border-radius:14px;background:var(--bg-2);border:1px solid var(--border);display:grid;place-items:center;margin:0 auto 14px;color:var(--text-3)}.empty h4{margin:0 0 4px;color:var(--text-1);font-size:15px;font-weight:600}.empty p{margin:0 0 14px;font-size:13px}.clients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.client-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;cursor:pointer;transition:border-color .12s,transform .12s}.client-card:hover{border-color:var(--border-strong);transform:translateY(-1px)}.client-card .top{display:flex;align-items:center;gap:10px;margin-bottom:12px}.client-card .logo{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;font-size:14px;font-weight:600;color:#fff}.client-card .name{font-size:14px;font-weight:600;letter-spacing:-.01em}.client-card .company{font-size:12px;color:var(--text-3)}.client-card .stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.client-card .stat .v{font-size:16px;font-weight:600;font-variant-numeric:tabular-nums}.client-card .stat .l{font-size:11px;color:var(--text-3)}.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.member-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;text-align:center;cursor:pointer;transition:border-color .12s}.member-card:hover{border-color:var(--border-strong)}.bar-chart{display:flex;align-items:flex-end;gap:6px;height:140px}.bar-chart .bar{flex:1;background:var(--accent-500);border-radius:4px 4px 0 0;opacity:.85;min-height:4px;position:relative;transition:opacity .12s}.bar-chart .bar:hover{opacity:1}.bar-chart .bar.b{background:var(--st-done)}.bar-chart .col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px}.bar-chart .col .label{font-size:10.5px;color:var(--text-3)}.gantt{display:grid;grid-template-columns:320px 1fr;height:calc(100vh - 250px);border-top:1px solid var(--border-subtle);overflow:hidden;background:var(--bg-0);position:relative}.gantt-left{border-right:1px solid var(--border);overflow:auto;background:var(--bg-1)}.gantt-right{overflow:auto;position:relative}.gantt-header{position:sticky;top:0;z-index:5;background:var(--bg-0);border-bottom:1px solid var(--border)}.gantt-months{display:flex;height:28px;border-bottom:1px solid var(--border-subtle)}.gantt-month{border-right:1px solid var(--border-subtle);padding:0 12px;display:flex;align-items:center;font-size:12.5px;font-weight:600;letter-spacing:-.01em;color:var(--text-1);white-space:nowrap}.gantt-days{display:flex;height:36px}.gantt-day{border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:10.5px;color:var(--text-3);flex-shrink:0;position:relative}.gantt-day.weekend{background:color-mix(in oklab,var(--text-3) 4%,transparent)}.gantt-day.today .dn{background:var(--accent-500);color:#fff;width:20px;height:20px;border-radius:50%;display:grid;place-items:center;font-size:11px}.gantt-left-head{position:sticky;top:0;z-index:5;height:64px;background:var(--bg-1);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-weight:600;color:var(--text-3)}.gantt-row{height:36px;display:flex;align-items:center;border-bottom:1px solid var(--border-subtle);padding:0 16px;gap:10px;cursor:pointer;font-size:13px;min-width:0}.gantt-row:hover{background:var(--bg-hover)}.gantt-row .rid{font-family:var(--font-mono);font-size:10.5px;color:var(--text-3);flex-shrink:0;width:50px}.gantt-row .ttl{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.gantt-tracks{position:relative}.gantt-track{height:36px;border-bottom:1px solid var(--border-subtle);position:relative}.gantt-track:hover{background:var(--bg-hover)}.gantt-bar{position:absolute;top:7px;height:22px;border-radius:6px;background:color-mix(in oklab,var(--c, var(--accent-500)) 22%,transparent);border:1px solid color-mix(in oklab,var(--c, var(--accent-500)) 50%,transparent);display:flex;align-items:center;gap:6px;padding:0 8px;overflow:hidden;cursor:pointer;transition:transform 80ms,box-shadow .12s;z-index:1}.gantt-bar:hover{transform:translateY(-1px);box-shadow:0 6px 14px -4px color-mix(in oklab,var(--c, var(--accent-500)) 60%,transparent);z-index:3}.gantt-bar.done{opacity:.7}.gantt-bar .progress{position:absolute;left:0;top:0;bottom:0;background:color-mix(in oklab,var(--c, var(--accent-500)) 45%,transparent);border-radius:5px 0 0 5px;pointer-events:none}.gantt-bar .label{position:relative;z-index:1;font-size:11.5px;font-weight:500;color:color-mix(in oklab,var(--c, var(--accent-500)) 70%,white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gantt-bar.overdue{border-color:var(--pr-urgent)}.gantt-today{position:absolute;top:0;bottom:0;width:2px;background:var(--accent-500);z-index:4;pointer-events:none;box-shadow:0 0 12px color-mix(in oklab,var(--accent-500) 50%,transparent)}.gantt-today:before{content:"Hoje";position:absolute;top:-2px;left:4px;font-size:10px;font-weight:600;color:var(--accent-400);background:var(--bg-0);padding:1px 5px;border-radius:4px;border:1px solid var(--accent-500)}.gantt-tip{position:fixed;z-index:100;background:var(--bg-1);border:1px solid var(--border);border-radius:8px;padding:10px 12px;box-shadow:var(--shadow-lg);font-size:12px;min-width:220px;pointer-events:none}.gantt-zoom{display:inline-flex;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);padding:2px;gap:2px}.gantt-zoom button{height:24px;padding:0 10px;border:0;background:transparent;font-size:12px;font-weight:500;color:var(--text-3);border-radius:4px;cursor:pointer}.gantt-zoom button.on{background:var(--bg-3);color:var(--text-1)}.sprint-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:16px}.sprint-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;cursor:pointer;transition:border-color .12s,transform .12s;position:relative;overflow:hidden}.sprint-card:hover{border-color:var(--border-strong);transform:translateY(-1px)}.sprint-card.active{border-color:color-mix(in oklab,var(--st-progress) 50%,var(--border))}.sprint-card.planning{border-color:color-mix(in oklab,var(--st-review) 40%,var(--border))}.sprint-card .badge{display:inline-flex;align-items:center;gap:6px;font-size:10.5px;font-weight:600;padding:3px 8px;border-radius:99px;text-transform:uppercase;letter-spacing:.04em}.sprint-card .badge.active{background:color-mix(in oklab,var(--st-progress) 16%,transparent);color:var(--st-progress)}.sprint-card .badge.planning{background:color-mix(in oklab,var(--st-review) 16%,transparent);color:var(--st-review)}.sprint-card .badge.completed{background:var(--bg-3);color:var(--text-3)}.sprint-card h3{margin:10px 0 4px;font-size:17px;font-weight:600;letter-spacing:-.02em}.sprint-card .goal{font-size:12.5px;color:var(--text-3);line-height:1.5;min-height:36px}.sprint-card .dates{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-2);margin:14px 0 10px;font-variant-numeric:tabular-nums}.sprint-card .progress-track{height:6px;border-radius:99px;background:var(--bg-3);overflow:hidden;position:relative;margin:6px 0 12px}.sprint-card .progress-track .fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--accent-500),var(--accent-400))}.sprint-card .meta-row{display:flex;align-items:center;gap:14px;font-size:11.5px;color:var(--text-3)}.sprint-card .meta-row b{color:var(--text-1);font-weight:600;font-variant-numeric:tabular-nums}.sprint-planning{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:16px 28px 28px}.sp-panel{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r-lg);display:flex;flex-direction:column;max-height:calc(100vh - 280px)}.sp-panel .h{padding:12px 14px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;gap:8px}.sp-panel .h .ttl{font-size:13.5px;font-weight:600;letter-spacing:-.01em}.sp-panel .h .n{color:var(--text-3);font-weight:500;margin-left:6px;font-variant-numeric:tabular-nums}.sp-panel .h .actions{margin-left:auto;display:flex;gap:6px}.sp-panel .b{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:6px}.sp-panel.drop-over{border-color:var(--accent-500);background:color-mix(in oklab,var(--accent-500) 4%,var(--bg-1))}.sp-task{display:grid;grid-template-columns:18px 1fr 80px 22px 26px;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg-2);cursor:pointer;transition:border-color .12s,transform 80ms}.sp-task:hover{border-color:var(--border-strong)}.sp-task .move{width:26px;height:26px;border-radius:6px;border:1px solid var(--border);background:var(--bg-2);display:grid;place-items:center;color:var(--text-3);cursor:pointer;transition:all .12s}.sp-task .move:hover{background:var(--accent-500);border-color:var(--accent-500);color:#fff}.sprint-header-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-lg);margin:20px 28px 0;padding:18px 22px}.sprint-header-card .stats{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border-subtle)}.sprint-header-card .stat .v{font-size:18px;font-weight:600;font-variant-numeric:tabular-nums}.sprint-header-card .stat .l{font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.04em;font-weight:500}.sprint-dates{position:relative;display:inline-flex;align-items:center}.sprint-dates .pill{display:inline-flex;align-items:center;gap:6px;height:28px;padding:0 10px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--bg-2);font-size:12.5px;color:var(--text-2);cursor:pointer;transition:border-color .12s}.sprint-dates .pill:hover{border-color:var(--border-strong)}.sprint-dates .pill .ic{opacity:0;transition:opacity .12s}.sprint-dates .pill:hover .ic{opacity:1}.sprint-dates .date-popover{position:absolute;top:calc(100% + 6px);left:0;z-index:60;width:300px;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:14px}.sprint-dates .date-popover .head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.sprint-dates .date-popover .head .t{font-size:13px;font-weight:600;color:var(--text-1)}.sprint-dates .date-popover .grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}.sprint-dates .date-popover label{display:block;font-size:10.5px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.sprint-dates .date-popover input[type=date]{width:100%;height:32px;padding:0 8px;font-size:12.5px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-1)}.sprint-dates .date-popover .quick{display:flex;align-items:center;gap:6px;margin-bottom:10px;flex-wrap:wrap}.sprint-dates .date-popover .quick button{height:26px;padding:0 10px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg-2);font-size:11.5px;color:var(--text-2);cursor:pointer}.sprint-dates .date-popover .quick button:hover{border-color:var(--accent-500);color:var(--accent-400)}.sprint-dates .date-popover .err{display:flex;align-items:flex-start;gap:6px;padding:8px 10px;background:color-mix(in oklab,var(--pr-urgent) 10%,transparent);border:1px solid color-mix(in oklab,var(--pr-urgent) 25%,transparent);border-radius:var(--r-sm);font-size:12px;color:var(--pr-urgent);margin-bottom:10px}.sprint-dates .date-popover .warn{display:flex;align-items:flex-start;gap:6px;padding:8px 10px;background:color-mix(in oklab,#f97316 10%,transparent);border:1px solid color-mix(in oklab,#f97316 25%,transparent);border-radius:var(--r-sm);font-size:12px;color:#f97316;margin-bottom:10px}.sprint-dates .date-popover .foot{display:flex;justify-content:flex-end;gap:8px;padding-top:10px;border-top:1px solid var(--border-subtle)}.sprint-bar{height:8px;border-radius:99px;background:var(--bg-3);overflow:visible;position:relative;margin:10px 0 6px}.sprint-bar .fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--accent-500),var(--accent-400))}.sprint-bar .today{position:absolute;top:-4px;width:2px;height:16px;background:var(--text-1);border-radius:2px;transform:translate(-50%)}.workload{margin:0 28px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px}.workload .head{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}.workload .head .t{font-size:13px;font-weight:600;color:var(--text-1)}.workload .head .sub{font-size:12px;color:var(--text-3)}.workload .head .legend{display:flex;align-items:center;gap:6px;margin-left:auto;flex-wrap:wrap}.workload .head .legend .item{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;color:var(--text-3);height:24px;padding:0 8px;border-radius:var(--r-sm);border:1px solid transparent;background:transparent;cursor:pointer;transition:border-color .12s,background .12s,color .12s}.workload .head .legend .item:hover{border-color:var(--border);background:var(--bg-3);color:var(--text-2)}.workload .head .legend .item.active{border-color:var(--border-strong);background:var(--bg-3);color:var(--text-1);font-weight:600}.workload .head .legend .sw{width:8px;height:8px;border-radius:2px;display:inline-block;flex-shrink:0}.wl-empty{font-size:12px;color:var(--text-3);text-align:center;padding:24px 20px}.wl-rows{display:flex;flex-direction:column;gap:10px}.wl-row{display:grid;grid-template-columns:100px 1fr 80px;align-items:center;gap:12px}.wl-who{display:flex;align-items:center;gap:7px;min-width:0}.wl-who .nm{font-size:12.5px;color:var(--text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wl-bar-wrap{flex:1}.wl-bar{height:10px;border-radius:99px;background:var(--bg-3);overflow:hidden;display:flex}.wl-seg{height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.wl-counts{display:flex;align-items:center;gap:4px;justify-content:flex-end}.wl-count-chip{font-size:11.5px;font-weight:600;font-variant-numeric:tabular-nums}.wl-total{font-size:12px;font-weight:600;color:var(--text-1);font-variant-numeric:tabular-nums;margin-left:2px}.wl-of{font-weight:400;color:var(--text-3)}.wl-trophy{font-size:13px;line-height:1;filter:grayscale(1) brightness(1.4)}.wl-trophy-silver{filter:grayscale(1) brightness(1.5) contrast(.85)}.wl-trophy-gold{filter:none}.rollover-tasks{display:flex;flex-direction:column;gap:2px;max-height:200px;overflow-y:auto;margin-bottom:16px;border:1px solid var(--border);border-radius:var(--r-md)}.rollover-task{display:flex;align-items:center;gap:10px;padding:8px 12px;border-bottom:1px solid var(--border-subtle);transition:background .12s}.rollover-task:last-child{border-bottom:0}.rollover-task:hover{background:var(--bg-hover)}.rollover-task input[type=checkbox]{flex-shrink:0;accent-color:var(--accent-500);width:14px;height:14px;cursor:pointer}.rollover-task .ttl{flex:1;font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.rollover-task .id{font-family:var(--font-mono);font-size:10.5px;color:var(--text-3);flex-shrink:0}.rollover-dest{display:flex;flex-direction:column;gap:6px}.rollover-dest .opt{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:border-color .12s}.rollover-dest .opt:hover{border-color:var(--border-strong)}.rollover-dest .opt.selected{border-color:var(--accent-500);background:color-mix(in oklab,var(--accent-500) 6%,transparent)}.rollover-dest .opt .radio{width:14px;height:14px;border-radius:50%;border:2px solid var(--border-strong);flex-shrink:0;transition:border-color .12s,background .12s}.rollover-dest .opt.selected .radio{border-color:var(--accent-500);background:var(--accent-500)}.rollover-dest .opt .info{flex:1;min-width:0}.rollover-dest .opt .info .n{font-size:13px;font-weight:600;color:var(--text-1)}.rollover-dest .opt .info .d{font-size:11.5px;color:var(--text-3);margin-top:1px}.rollover-dest .opt .badge-s{font-size:10.5px;font-weight:600;padding:2px 7px;border-radius:99px;flex-shrink:0}.rollover-dest .opt .badge-s.planning{background:color-mix(in oklab,var(--st-review) 16%,transparent);color:var(--st-review)}.rollover-dest .opt .badge-s.active{background:color-mix(in oklab,var(--st-progress) 16%,transparent);color:var(--st-progress)}.rollover-dest .opt .badge-s.new{background:color-mix(in oklab,var(--accent-500) 16%,transparent);color:var(--accent-400)}.rollover-foot-note{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;background:color-mix(in oklab,var(--accent-500) 8%,transparent);border:1px solid color-mix(in oklab,var(--accent-500) 20%,transparent);border-radius:var(--r-md);font-size:12.5px;color:var(--text-2);margin-top:16px}.notif-panel{position:absolute;top:48px;right:16px;width:380px;max-height:520px;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);z-index:70;display:flex;flex-direction:column}.notif-panel .h{padding:12px 14px;display:flex;align-items:center;border-bottom:1px solid var(--border-subtle)}.notif-panel .h h4{margin:0;font-size:13.5px;font-weight:600}.notif-panel .h .a{margin-left:auto;font-size:12px;color:var(--text-3);cursor:pointer}.notif-panel .l{overflow-y:auto;flex:1}.notif-panel .it{padding:12px 14px;display:flex;gap:10px;border-bottom:1px solid var(--border-subtle);cursor:pointer}.notif-panel .it:hover{background:var(--bg-hover)}.notif-panel .it.unread{background:color-mix(in oklab,var(--accent-500) 5%,transparent)}.global-loader{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:color-mix(in oklab,var(--bg-0) 80%,transparent);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);pointer-events:none;animation:loader-fade-in .12s ease}@keyframes loader-fade-in{0%{opacity:0}to{opacity:1}}.global-loader .spinner{width:36px;height:36px;border-radius:50%;border:3px solid var(--border);border-top-color:var(--accent-500);animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.global-loader .label{font-size:13px;color:var(--text-3);font-weight:500;letter-spacing:.01em}.kbd{font-family:var(--font-sans);font-size:11px;padding:1px 5px;border:1px solid var(--kbd-border);border-radius:4px;background:var(--kbd-bg);color:var(--text-3)}.divider{height:1px;background:var(--border-subtle);margin:8px 0}[data-density=comfy]{--row-h: 44px}[data-density=cozy]{--row-h: 40px}[data-density=compact]{--row-h: 32px}.perm-badge{display:inline-flex;align-items:center;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:2px 7px;border-radius:99px;white-space:nowrap}.perm-badge.admin{background:color-mix(in oklab,var(--accent-500) 18%,transparent);color:var(--accent-400);border:1px solid color-mix(in oklab,var(--accent-500) 30%,transparent)}.perm-badge.member{background:var(--bg-3);color:var(--text-3);border:1px solid var(--border-subtle)}[data-theme=light] .perm-badge.admin{color:var(--accent-700)}.invite-field{display:flex;flex-direction:column;gap:6px}.invite-field>label{font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.invite-preview{margin-top:4px;border:1px solid var(--border-subtle);border-radius:var(--r-lg);background:var(--bg-2);overflow:hidden}.invite-preview .left{display:flex;align-items:center;gap:8px;padding:8px 12px;background:color-mix(in oklab,var(--accent-500) 6%,var(--bg-2));border-bottom:1px solid var(--border-subtle)}.invite-preview .body{padding:12px;display:flex;flex-direction:column;gap:8px}.invite-preview .subj{font-size:13px;color:var(--text-2);line-height:1.5}.invite-preview .cta{padding:4px 0}.invite-preview .fake-link{display:inline-block;background:var(--accent-500);color:#fff;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:500;box-shadow:0 0 0 1px #ffffff0a inset,0 4px 10px -4px var(--accent-700)}.invite-preview .meta{font-size:11.5px;color:var(--text-3)}.invite-error{display:flex;align-items:center;gap:6px;padding:8px 10px;background:color-mix(in oklab,var(--pr-urgent) 12%,transparent);border:1px solid color-mix(in oklab,var(--pr-urgent) 28%,transparent);color:var(--pr-urgent);border-radius:var(--r-md);font-size:12.5px}.pending-invites{background:color-mix(in oklab,var(--accent-500) 5%,var(--bg-2));border:1px dashed color-mix(in oklab,var(--accent-500) 35%,var(--border));border-radius:var(--r-lg);padding:14px 16px;margin-bottom:18px}.pending-invites>.head{display:flex;align-items:center;gap:10px;margin-bottom:10px}.pending-invites .list{display:flex;flex-direction:column;gap:6px}.pending-invites .row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r-md);background:var(--bg-2);border:1px solid var(--border-subtle)}.pending-invites .av-placeholder{width:32px;height:32px;border-radius:50%;background:var(--bg-3);color:var(--text-3);display:grid;place-items:center;font-size:11.5px;font-weight:600;border:1px dashed var(--border-strong);flex-shrink:0}.pending-invites .main{flex:1;min-width:0}.pending-invites .nm{font-size:13px;font-weight:500;display:flex;align-items:center;gap:6px}.pending-invites .em{font-size:11.5px;color:var(--text-3);margin-top:1px}.pending-invites .acts{display:flex;gap:4px}.member-card.is-me{border-color:color-mix(in oklab,var(--accent-500) 40%,var(--border));background:color-mix(in oklab,var(--accent-500) 4%,var(--bg-2))}.auth-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-0);color:var(--text-1);display:flex;flex-direction:column;overflow:auto;z-index:200}.auth-screen .bg-orbs{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:0}.auth-screen .bg-orbs .orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5}.auth-screen .bg-orbs .orb.a{width:480px;height:480px;background:color-mix(in oklab,var(--accent-500) 70%,transparent);top:-120px;left:-120px}.auth-screen .bg-orbs .orb.b{width:380px;height:380px;background:color-mix(in oklab,var(--accent-700) 60%,transparent);bottom:-120px;right:-100px}[data-theme=light] .auth-screen .bg-orbs .orb{opacity:.22}.auth-top{position:relative;z-index:2;display:flex;align-items:center;padding:18px 28px}.auth-top .brand{display:flex;align-items:center;gap:10px;font-size:15px}.auth-top .brand .logo{width:28px;height:28px;border-radius:7px;background:linear-gradient(135deg,var(--accent-400),var(--accent-700));color:#fff;display:grid;place-items:center;font-weight:700}.auth-main{position:relative;z-index:2;flex:1;display:grid;grid-template-columns:minmax(380px,480px) minmax(280px,340px);gap:32px;align-content:center;justify-content:center;padding:20px 28px 48px}@media (max-width: 880px){.auth-main{grid-template-columns:1fr}.auth-side{display:none}}.auth-card{background:var(--bg-1);border:1px solid var(--border);border-radius:18px;box-shadow:0 28px 80px -20px #0000008c,0 0 0 1px var(--border-subtle);overflow:hidden}.auth-card-head{padding:24px 28px 22px;border-bottom:1px solid var(--border-subtle);background:var(--bg-2)}.auth-card-head .invitor{display:inline-flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;background:var(--bg-3);border:1px solid var(--border-subtle);border-radius:99px;margin-bottom:14px}.auth-card-head h1{font-size:24px;letter-spacing:-.02em;font-weight:600;margin:0 0 6px}.auth-card-head p{margin:0;color:var(--text-3);font-size:13.5px;line-height:1.55}.invite-summary{display:flex;align-items:center;gap:12px;margin-top:18px;padding:12px;background:var(--bg-1);border:1px solid var(--border-subtle);border-radius:var(--r-md)}.invite-summary .role-pill{margin-left:auto;font-size:10.5px;font-weight:600;padding:3px 9px;border-radius:99px;background:color-mix(in oklab,var(--accent-500) 16%,transparent);color:var(--accent-400);text-transform:uppercase;letter-spacing:.04em}[data-theme=light] .invite-summary .role-pill{color:var(--accent-700)}.auth-form{padding:22px 28px 26px;display:flex;flex-direction:column;gap:16px}.auth-field{display:flex;flex-direction:column;gap:8px}.auth-field>label{font-size:11.5px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.pwd-strength{display:flex;align-items:center;gap:4px;margin-top:2px}.pwd-strength .bar{flex:1;height:4px;border-radius:99px;background:var(--bg-3);transition:background .16s}.pwd-strength .bar.on{background:var(--pr-urgent)}.pwd-strength .bar.on.lvl2{background:var(--pr-high)}.pwd-strength .bar.on.lvl3{background:var(--pr-medium)}.pwd-strength .bar.on.lvl4{background:var(--st-done)}.pwd-strength .lbl{margin-left:6px;font-size:11px;color:var(--text-3);min-width:56px;text-align:right}.pwd-reqs{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:4px 14px;font-size:11.5px;color:var(--text-3)}.pwd-reqs li{display:flex;align-items:center;gap:6px}.pwd-reqs li .dot{width:6px;height:6px;border-radius:50%;background:var(--bg-3);border:1px solid var(--border-strong);flex-shrink:0}.pwd-reqs li.ok{color:var(--text-2)}.auth-warn{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;color:var(--pr-urgent)}.auth-check{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text-3);cursor:pointer;padding:4px 0}.auth-check input{width:16px;height:16px;accent-color:var(--accent-500);cursor:pointer}.auth-check a{color:var(--accent-400);cursor:pointer}.auth-check a:hover{text-decoration:underline}.auth-foot{text-align:center;font-size:11.5px;color:var(--text-4);padding-top:4px}.auth-side{align-self:center}.auth-side h3{margin:0 0 14px;font-size:13px;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.auth-side ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}.auth-side li{display:flex;gap:10px}.auth-side li .ic{width:32px;height:32px;flex-shrink:0;border-radius:8px;background:color-mix(in oklab,var(--accent-500) 14%,transparent);color:var(--accent-400);display:grid;place-items:center}[data-theme=light] .auth-side li .ic{color:var(--accent-700)}.auth-side li div{display:flex;flex-direction:column}.auth-side li b{font-size:13.5px;font-weight:600}.auth-side li span{font-size:12.5px;color:var(--text-3);line-height:1.45;margin-top:2px}
