@import"https://fonts.googleapis.com/css2?family=Montserrat+Alternates:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400;1,500;1,600&display=swap";:root{--bg: oklch(.985 .003 260);--surface: #ffffff;--surface-2: oklch(.975 .004 260);--surface-3: oklch(.96 .005 260);--ink: oklch(.2 .018 265);--ink-2: oklch(.42 .015 265);--ink-3: oklch(.58 .012 265);--border: oklch(.92 .006 260);--border-2: oklch(.88 .008 260);--hover: oklch(.965 .005 260);--accent-h: 268;--accent: oklch(.58 .2 var(--accent-h));--accent-hover: oklch(.52 .22 var(--accent-h));--accent-soft: oklch(.96 .04 var(--accent-h));--accent-soft-2: oklch(.92 .07 var(--accent-h));--accent-ink: oklch(.4 .2 var(--accent-h));--todo: oklch(.65 .012 260);--progress: oklch(.62 .18 245);--review: oklch(.7 .16 75);--done: oklch(.62 .16 155);--bug: oklch(.62 .2 25);--priority-high: oklch(.62 .2 25);--priority-med: oklch(.7 .16 75);--priority-low: oklch(.62 .16 155);--tag-feature-bg: oklch(.96 .04 245);--tag-feature-fg: oklch(.42 .16 245);--tag-bug-bg: oklch(.96 .04 25);--tag-bug-fg: oklch(.45 .18 25);--tag-support-bg: oklch(.96 .04 155);--tag-support-fg: oklch(.4 .16 155);--tag-devops-bg: oklch(.96 .04 290);--tag-devops-fg: oklch(.42 .18 290);--tag-other-bg: oklch(.95 .005 260);--tag-other-fg: oklch(.45 .012 260);--shadow-1: 0 1px 2px oklch(.2 .02 260 / .04), 0 1px 3px oklch(.2 .02 260 / .04);--shadow-2: 0 4px 12px oklch(.2 .02 260 / .06), 0 1px 3px oklch(.2 .02 260 / .04);--shadow-3: 0 12px 40px oklch(.2 .02 260 / .1), 0 2px 8px oklch(.2 .02 260 / .05);--shadow-pop: 0 24px 64px oklch(.2 .02 260 / .18), 0 4px 12px oklch(.2 .02 260 / .08);--ease: cubic-bezier(.16, 1, .3, 1);--t-fast: .12s var(--ease);--t: .2s var(--ease);--t-slow: .36s var(--ease);--r-1: 9px;--r-2: 13px;--r-3: 18px;--r-4: 24px;--nav-w: 232px}[data-theme=dark]{--bg: oklch(.155 .012 265);--surface: oklch(.195 .014 265);--surface-2: oklch(.22 .015 265);--surface-3: oklch(.255 .016 265);--ink: oklch(.97 .005 260);--ink-2: oklch(.78 .01 260);--ink-3: oklch(.6 .012 260);--border: oklch(.28 .014 265);--border-2: oklch(.34 .014 265);--hover: oklch(.235 .016 265);--accent-soft: oklch(.3 .1 var(--accent-h));--accent-soft-2: oklch(.36 .14 var(--accent-h));--accent-ink: oklch(.82 .16 var(--accent-h));--tag-feature-bg: oklch(.3 .08 245);--tag-feature-fg: oklch(.85 .1 245);--tag-bug-bg: oklch(.32 .1 25);--tag-bug-fg: oklch(.85 .1 25);--tag-support-bg: oklch(.3 .08 155);--tag-support-fg: oklch(.85 .08 155);--tag-devops-bg: oklch(.3 .1 290);--tag-devops-fg: oklch(.85 .1 290);--tag-other-bg: oklch(.28 .008 260);--tag-other-fg: oklch(.78 .01 260);--shadow-1: 0 1px 2px #0006;--shadow-2: 0 4px 16px #0008;--shadow-3: 0 12px 40px #000a;--shadow-pop: 0 24px 64px #000c}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:Montserrat Alternates,system-ui,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5;letter-spacing:-.005em;transition:background var(--t),color var(--t)}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea,select{font-family:inherit}a{color:inherit;text-decoration:none}::selection{background:var(--accent-soft-2);color:var(--accent-ink)}*::-webkit-scrollbar{width:8px;height:8px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:4px}*::-webkit-scrollbar-thumb:hover{background:var(--ink-3)}@keyframes shimmer-loader{0%{background-position:200% 0}to{background-position:-200% 0}}.app{display:flex;min-height:100vh}.sidebar{width:var(--nav-w);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;z-index:30;transition:transform var(--t);overflow-y:auto}.brand{display:flex;align-items:center;gap:10px;padding:18px 18px 14px;font-weight:700;letter-spacing:-.02em;font-size:15px;flex-shrink:0}.brand-mark{width:26px;height:26px;border-radius:7px;background:var(--ink);color:var(--surface);display:grid;place-items:center;font-weight:700;font-size:13px;letter-spacing:-.04em;position:relative;overflow:hidden;flex-shrink:0}.brand-mark:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:conic-gradient(from 220deg at 50% 50%,var(--accent),transparent 60%);opacity:.55;mix-blend-mode:screen}.brand-mark span{position:relative;z-index:1}.nav-section{padding:6px 10px}.nav-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);padding:14px 10px 6px;font-weight:500}.nav-item{width:100%;display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--r-1);color:var(--ink-2);font-size:13px;font-weight:500;letter-spacing:-.005em;transition:background var(--t-fast),color var(--t-fast);text-align:left;position:relative}.nav-item .nav-count{margin-left:auto;font-size:11px;color:var(--ink-3);background:var(--surface-2);padding:1px 6px;border-radius:999px}.nav-item:hover{background:var(--hover);color:var(--ink)}.nav-item.active{background:var(--surface-2);color:var(--ink)}.nav-item.active:before{content:"";position:absolute;left:-10px;top:8px;bottom:8px;width:2px;border-radius:2px;background:var(--accent)}.nav-icon{width:16px;height:16px;flex-shrink:0;opacity:.85}.sidebar-projects{flex:1;overflow-y:auto}.sidebar-foot{flex-shrink:0;padding:10px;border-top:1px solid var(--border);display:flex;gap:8px;align-items:center}.user-chip{flex:1;display:flex;align-items:center;gap:9px;padding:6px 8px;border-radius:var(--r-1);transition:background var(--t-fast);cursor:pointer}.user-chip:hover{background:var(--hover)}.user-chip .avatar{width:26px;height:26px}.user-chip-meta{display:flex;flex-direction:column;line-height:1.15}.user-chip-meta .name{font-size:12.5px;font-weight:600}.user-chip-meta .role{font-size:10.5px;color:var(--ink-3)}.icon-btn{width:30px;height:30px;border-radius:var(--r-1);display:grid;place-items:center;color:var(--ink-2);transition:background var(--t-fast),color var(--t-fast)}.icon-btn:hover{background:var(--hover);color:var(--ink)}.main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{height:52px;display:flex;align-items:center;padding:0 22px;border-bottom:1px solid var(--border);background:color-mix(in oklch,var(--surface) 80%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:sticky;top:0;z-index:20;gap:12px;flex-shrink:0}.crumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-2)}.crumb .sep{color:var(--ink-3)}.crumb b{color:var(--ink);font-weight:600}.topbar-spacer{flex:1}.kbd{font-size:10.5px;padding:2px 5px;border:1px solid var(--border-2);border-bottom-width:2px;border-radius:4px;color:var(--ink-2);background:var(--surface);line-height:1}.search-trigger{display:flex;align-items:center;gap:8px;padding:5px 8px 5px 9px;border:1px solid var(--border);border-radius:var(--r-1);color:var(--ink-3);font-size:12.5px;background:var(--surface-2);min-width:220px;transition:border-color var(--t-fast),background var(--t-fast);cursor:pointer}.search-trigger:hover{border-color:var(--border-2)}.search-trigger .kbd{margin-left:auto}.btn{display:inline-flex;align-items:center;gap:7px;padding:6px 12px;border-radius:var(--r-1);font-size:12.5px;font-weight:500;border:1px solid var(--border);background:var(--surface);color:var(--ink);transition:background var(--t-fast),border-color var(--t-fast),transform var(--t-fast);letter-spacing:-.005em}.btn:hover{background:var(--hover);border-color:var(--border-2)}.btn:active{transform:scale(.98)}.btn-primary{background:var(--ink);color:var(--surface);border-color:var(--ink)}[data-theme=dark] .btn-primary{background:var(--surface);color:var(--ink);border-color:var(--surface)}.btn-primary:hover{background:oklch(from var(--ink) calc(l + .08) c h)}[data-theme=dark] .btn-primary:hover{background:var(--surface-2)}.btn-accent{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-accent:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-ghost{border-color:transparent;background:transparent;color:var(--ink-2)}.btn-ghost:hover{background:var(--hover);color:var(--ink)}.btn-sm{padding:4px 9px;font-size:12px}.btn-danger{background:var(--bug);color:#fff;border-color:var(--bug)}.btn-danger:hover{background:#d40924}.page{padding:24px 28px 80px;max-width:1400px;width:100%;margin:0 auto}.page-head{display:flex;align-items:end;justify-content:space-between;gap:16px;margin-bottom:22px}.page-title{font-size:22px;font-weight:600;letter-spacing:-.025em;margin:0}.page-sub{font-size:12.5px;color:var(--ink-3);margin-top:4px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-3);transition:border-color var(--t-fast),box-shadow var(--t-fast),transform var(--t-fast)}.card-pad{padding:18px 20px}.card-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}.card-head h3{margin:0;font-size:13px;font-weight:600;letter-spacing:-.01em}.card-head .meta{font-size:11px;color:var(--ink-3)}.avatar{border-radius:50%;display:grid;place-items:center;font-weight:600;font-size:10.5px;color:#fff;flex-shrink:0;letter-spacing:-.02em;overflow:hidden}.avatar img{width:100%;height:100%;object-fit:cover}.chip{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:var(--r-1);font-size:10.5px;font-weight:500;letter-spacing:.01em;text-transform:uppercase;border:1px solid transparent;white-space:nowrap}.chip-feature{background:var(--tag-feature-bg);color:var(--tag-feature-fg)}.chip-bug{background:var(--tag-bug-bg);color:var(--tag-bug-fg)}.chip-support{background:var(--tag-support-bg);color:var(--tag-support-fg)}.chip-devops{background:var(--tag-devops-bg);color:var(--tag-devops-fg)}.chip-other{background:var(--tag-other-bg);color:var(--tag-other-fg)}.dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.dot-todo{background:var(--todo)}.dot-progress{background:var(--progress)}.dot-review{background:var(--review)}.dot-done{background:var(--done)}.dot-high{background:var(--priority-high)}.dot-med{background:var(--priority-med)}.dot-low{background:var(--priority-low)}.input,.select,.textarea{width:100%;padding:7px 11px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-1);color:var(--ink);font-size:13px;transition:border-color var(--t-fast),box-shadow var(--t-fast);outline:none}.input:focus,.select:focus,.textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.textarea{resize:vertical;min-height:76px;line-height:1.5}.field-label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);margin-bottom:6px;font-weight:500}.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-1);padding:2px;gap:0}.seg button{padding:4px 10px;font-size:12px;border-radius:6px;color:var(--ink-2);font-weight:500;display:inline-flex;align-items:center;gap:5px;transition:background var(--t-fast),color var(--t-fast)}.seg button:hover{color:var(--ink)}.seg button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-1)}[data-theme=dark] .seg button.on{background:var(--surface-3)}.pill{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;font-size:11.5px;font-weight:500;background:var(--surface-2);color:var(--ink-2);border:1px solid transparent;transition:all var(--t-fast);cursor:pointer}.pill:hover{background:var(--surface-3);color:var(--ink)}.pill.on{background:var(--ink);color:var(--surface)}[data-theme=dark] .pill.on{background:var(--surface);color:var(--ink)}.menu-btn{display:none}@media (max-width: 880px){.sidebar{position:fixed;left:0;top:0;bottom:0;transform:translate(-100%);box-shadow:var(--shadow-pop)}.sidebar.open{transform:translate(0)}.menu-btn{display:grid}.page{padding:16px 14px 100px}.topbar{padding:0 12px;gap:8px}.topbar .crumb b{max-width:clamp(80px,30vw,200px)!important}.search-trigger{min-width:0;flex:none;width:32px;height:32px;padding:0;justify-content:center;border-radius:50%}.search-trigger .search-trigger-label,.search-trigger .kbd{display:none}.topbar .btn-new{width:32px;height:32px;padding:0;justify-content:center;border-radius:50%;gap:0}.topbar .btn-new .btn-text{display:none}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:25;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}}.bottom-nav{display:none;position:fixed;left:0;right:0;bottom:0;background:color-mix(in oklch,var(--surface) 92%,transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-top:1px solid var(--border);padding:6px 10px calc(8px + env(safe-area-inset-bottom));z-index:22;justify-content:space-around}.bottom-nav button{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 10px;color:var(--ink-3);font-size:10px;font-weight:500}.bottom-nav button.active{color:var(--accent)}.bottom-nav .fab{width:44px;height:44px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;margin-top:-16px;box-shadow:0 8px 22px var(--accent-soft-2);flex-direction:row}@media (max-width: 880px){.bottom-nav{display:flex}.main{padding-bottom:70px}}@keyframes pop-in{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}.pop-in{animation:pop-in .28s var(--ease) both}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.skeleton{background:var(--surface-2);border-radius:var(--r-1);overflow:hidden;position:relative}.skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,var(--surface-3) 50%,transparent);animation:shimmer 1.4s infinite}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 20px;color:var(--ink-3);text-align:center}.empty-state svg{opacity:.4}.empty-state h3{margin:0;font-size:15px;font-weight:600;color:var(--ink-2)}.empty-state p{margin:0;font-size:13px;max-width:280px;line-height:1.5}.density-comfy .task-row{padding:14px 16px}.density-compact .task-row{padding:8px 12px}.density-comfy .nav-item{padding:9px 10px}.density-compact .nav-item{padding:5px 10px}.stat-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:16px}.stat-tile{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-3);padding:14px 16px;display:flex;flex-direction:column;gap:4px}.stat-tile-k{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);font-weight:500}.stat-tile-v{font-size:26px;font-weight:600;letter-spacing:-.03em;line-height:1}.stat-tile-bar{height:3px;border-radius:2px;background:var(--surface-2);overflow:hidden;margin-top:8px}.stat-tile-bar span{display:block;height:100%;border-radius:2px;transition:width .6s var(--ease)}.stat-tile-streak{background:linear-gradient(135deg,var(--accent-soft),var(--surface) 80%)}[data-theme=dark] .stat-tile-streak{background:linear-gradient(135deg,var(--accent-soft),var(--surface))}.alert-row{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff0ee;background:oklch(.97 .04 25);border:1px solid oklch(.88 .07 25);border-radius:var(--r-3);margin-bottom:16px;width:100%;font-size:13px;color:#8a0314;text-align:left;transition:all var(--t-fast);cursor:pointer}.alert-row:hover{transform:translateY(-1px);box-shadow:var(--shadow-2)}[data-theme=dark] .alert-row{background:#551112;border-color:#932b2a;color:#ffd0cb;color:oklch(.9 .1 25)}.alert-dot{width:8px;height:8px;border-radius:50%;background:var(--bug);box-shadow:0 0 0 4px #e643432e;flex-shrink:0;animation:pulse 2s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #e6434380}50%{box-shadow:0 0 0 6px #e6434300}}.alert-cta{margin-left:auto;display:inline-flex;align-items:center;gap:5px;font-weight:500}.dash-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.dash-grid>.card{grid-column:span 2}.week-card{grid-column:span 4!important}@media (max-width: 1100px){.stat-strip{grid-template-columns:repeat(3,1fr)}.dash-grid{grid-template-columns:repeat(2,1fr)}.dash-grid>.card{grid-column:span 1!important}.week-card{grid-column:span 2!important}}@media (max-width: 700px){.stat-strip{grid-template-columns:repeat(2,1fr)}.dash-grid,.dash-grid>.card{grid-template-columns:1fr!important;grid-column:span 1!important}.week-card{grid-column:span 1!important}}.btn-link{font-size:12px;font-weight:500;color:var(--accent-ink);display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:4px;transition:background var(--t-fast);cursor:pointer}.btn-link:hover{background:var(--accent-soft)}.focus-list{padding:8px}.focus-row{width:100%;display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:var(--r-1);text-align:left;transition:background var(--t-fast);cursor:pointer}.focus-row:hover{background:var(--hover)}.check-circle{width:16px;height:16px;border-radius:50%;border:1.5px solid var(--border-2);flex-shrink:0;transition:all var(--t-fast)}.focus-row:hover .check-circle{border-color:var(--accent);background:var(--accent-soft)}.focus-title{flex:1;font-size:13px}.focus-meta{display:flex;gap:8px;align-items:center}.meta-due{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--ink-3)}.card-foot-row{padding:10px 18px;border-top:1px solid var(--border)}.schedule-row{padding:12px 14px;border:1px solid var(--border);border-radius:var(--r-2);border-left:3px solid var(--priority-high)}.schedule-time{display:flex;align-items:center;gap:6px;margin-bottom:6px}.schedule-title{font-size:13.5px;font-weight:500;line-height:1.4}.schedule-meta{display:flex;align-items:center;gap:8px;margin-top:8px}.schedule-empty{margin-top:12px;padding:14px;border:1.5px dashed var(--border-2);border-radius:var(--r-2);text-align:center}.week-body{display:grid;grid-template-columns:1.4fr 1fr;gap:24px;padding:18px 22px 22px}.week-bars{display:grid;grid-template-columns:repeat(7,1fr);gap:14px;align-items:end;height:180px}.bar-col{display:flex;flex-direction:column;align-items:center;gap:6px;height:100%}.bar-num{font-size:11px;color:var(--ink-3);height:12px}.bar{width:100%;flex:1;display:flex;align-items:end;justify-content:center}.bar span{width:100%;background:var(--surface-3);border-radius:4px 4px 0 0;min-height:3px;transition:height .7s var(--ease)}.bar span.peak{background:linear-gradient(180deg,var(--accent),var(--accent-hover))}.bar-day{font-size:10.5px;color:var(--ink-3)}.week-stats{display:flex;flex-direction:column;gap:10px;justify-content:center}.kv{padding:10px 12px;background:var(--surface-2);border-radius:var(--r-2)}.kv-k{font-size:10px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}.kv-v{font-size:22px;font-weight:600;letter-spacing:-.03em}.kv-delta{font-size:11px;font-weight:500;color:var(--ink-3);margin-left:6px}.kv-delta.up{color:var(--done)}.status-bars{padding:10px 18px 18px;display:flex;flex-direction:column;gap:10px}.status-row{display:grid;grid-template-columns:110px 1fr 30px;align-items:center;gap:12px}.status-row-label{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--ink-2)}.status-row-bar{height:6px;background:var(--surface-2);border-radius:3px;overflow:hidden}.status-row-bar span{display:block;height:100%;border-radius:3px;transition:width .7s var(--ease)}.status-row-n{font-size:12px;text-align:right;font-weight:500}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;padding:14px 16px 16px}.project-grid-lg{padding:0;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.project-tile{display:flex;flex-direction:column;gap:10px;padding:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-3);text-align:left;transition:all var(--t-fast);position:relative;overflow:hidden;cursor:pointer}.project-tile:hover{border-color:var(--border-2);transform:translateY(-2px);box-shadow:var(--shadow-2)}.project-tile-head{display:flex;align-items:center;gap:10px}.project-mark{width:28px;height:28px;border-radius:7px;color:#fff;display:grid;place-items:center;font-weight:700;font-size:10.5px;letter-spacing:-.02em}.project-name{font-size:13.5px;font-weight:600;letter-spacing:-.01em}.project-meta{font-size:11.5px;color:var(--ink-3)}.project-progress{height:5px;background:var(--surface-2);border-radius:3px;overflow:hidden}.project-progress span{display:block;height:100%;border-radius:3px;transition:width .7s var(--ease)}.project-foot{display:flex;align-items:center;justify-content:space-between}.project-pct{font-size:11px;color:var(--ink-2);font-weight:500}.project-tile-new{align-items:center;justify-content:center;border-style:dashed;color:var(--ink-3);text-align:center}.project-tile-new:hover{color:var(--accent);border-color:var(--accent)}.project-tile-lg{padding:16px 18px;min-height:140px}.project-accent{position:absolute;left:0;top:0;bottom:0;width:3px}.proj-pct-tag{margin-left:auto;font-size:11px;padding:2px 8px;background:var(--surface-2);border-radius:999px;color:var(--ink-2)}.avatar-stack{display:flex}.avatar-stack .avatar{margin-left:-6px;border:2px solid var(--surface)}.avatar-stack .avatar:first-child{margin-left:0}.activity{padding:8px 10px 14px}.activity-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r-1);font-size:13px;transition:background var(--t-fast)}.activity-row:hover{background:var(--hover)}.activity-tgt{color:var(--ink);font-weight:500}.activity-line{flex:1;color:var(--ink-2)}.activity-when{font-size:11px;color:var(--ink-3);white-space:nowrap}.comment-row{display:flex;gap:10px;padding:10px}.comment-body{margin-top:6px;padding:10px 12px;background:var(--surface-2);border-radius:var(--r-2);font-size:13px;line-height:1.5}.comment-input{display:flex;gap:8px;align-items:center;padding:12px 0 0;border-top:1px solid var(--border);margin-top:12px}.comment-input .input{flex:1}.proj-head{display:flex;align-items:center;gap:12px;margin-bottom:18px}.proj-toolbar{display:flex;flex-direction:column;gap:12px;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-3);margin-bottom:16px}.proj-toolbar-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;align-items:start}.kcol{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-3);display:flex;flex-direction:column;min-height:400px}.kcol-head{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border)}.kcol-name{font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-weight:600;color:var(--ink-2)}.kcol-count{font-size:10.5px;background:var(--surface);padding:1px 7px;border-radius:999px;color:var(--ink-3)}.kcol-body{padding:8px;display:flex;flex-direction:column;gap:8px;flex:1;min-height:200px}.kcard{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-2);padding:11px 12px;display:flex;flex-direction:column;gap:8px;text-align:left;transition:all var(--t-fast);cursor:pointer;width:100%}.kcard:hover{border-color:var(--border-2);transform:translateY(-1px);box-shadow:var(--shadow-2)}.kcard-top{display:flex;align-items:center;justify-content:space-between}.kcard-title{font-size:13px;font-weight:500;line-height:1.4;letter-spacing:-.005em;text-align:left}.kcard-foot{display:flex;align-items:center;gap:8px}.kcard-due{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;color:var(--ink-3)}.kcol-add{width:100%;padding:8px;border:1.5px dashed var(--border-2);border-radius:var(--r-1);color:var(--ink-3);font-size:12px;display:flex;align-items:center;justify-content:center;gap:5px;transition:all var(--t-fast)}.kcol-add:hover{border-color:var(--accent);color:var(--accent)}.kcol-drop-over{background:var(--accent-soft);border-color:var(--accent)}@media (max-width: 1100px){.kanban{grid-template-columns:repeat(2,1fr)}}@media (max-width: 700px){.kanban{grid-template-columns:1fr}}.cal-wrap{border:1px solid var(--border);border-radius:var(--r-3);overflow:hidden;background:var(--surface)}.cal-nav{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--surface-2);flex-wrap:wrap}.cal-range-label{font-size:13px;font-weight:600}.cal-scroll{overflow-x:auto}.cal-header{display:grid;grid-template-columns:220px 1fr;border-bottom:2px solid var(--border);background:var(--surface-2);min-width:640px}.cal-label-col{padding:8px 14px;border-right:1px solid var(--border);display:flex;align-items:center;gap:8px;overflow:hidden}.cal-task-label{font-size:12.5px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.cal-days-row{display:grid}.cal-day-head{padding:4px 2px;text-align:center;border-right:1px solid var(--border)}.cal-day-head.today{background:var(--accent-soft)}.cal-day-num{display:block;font-size:13px;font-weight:600}.cal-day-name{display:block;font-size:10px;color:var(--ink-3)}.cal-row{display:grid;grid-template-columns:220px 1fr;border-bottom:1px solid var(--border);min-height:44px;cursor:pointer;transition:background var(--t-fast);min-width:640px}.cal-row:hover{background:var(--hover)}.cal-track{position:relative;overflow:hidden}.cal-today-line{position:absolute;top:0;bottom:0;width:2px;background:var(--accent);opacity:.4;pointer-events:none;z-index:1}.cal-grid-line{position:absolute;top:0;bottom:0;width:1px;background:var(--border);pointer-events:none}.cal-bar{position:absolute;top:7px;bottom:7px;border-radius:4px;border:1px solid;display:flex;align-items:center;padding:0 6px;font-size:11px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;z-index:2;min-width:8px}.cal-unscheduled{padding:10px 14px;border-top:1px solid var(--border);background:var(--surface-2);display:flex;align-items:center;gap:8px;flex-wrap:wrap}.dropzone{border:2px dashed var(--border-2);border-radius:var(--r-2);padding:28px 20px;text-align:center;cursor:pointer;color:var(--ink-3);font-size:13px;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--t-fast)}.filter-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:14px}.task-rows{display:flex;flex-direction:column;gap:6px;margin-top:14px}.task-row{display:grid;grid-template-columns:4px 64px 12px 1fr auto auto auto auto 14px;align-items:center;gap:12px;padding:11px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-2);text-align:left;transition:all var(--t-fast);cursor:pointer}.task-row:hover{border-color:var(--border-2);transform:translate(2px);box-shadow:var(--shadow-1)}.priority-bar{width:3px;height:22px;border-radius:2px}.priority-bar.dot-high{background:var(--priority-high)}.priority-bar.dot-med{background:var(--priority-med)}.priority-bar.dot-low{background:var(--priority-low)}.task-id{font-size:11px;color:var(--ink-3);font-weight:500}.task-row-title{font-size:13.5px;font-weight:500;letter-spacing:-.005em;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-proj{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--ink-2)}.task-status-pill{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;background:var(--surface-2);font-size:11.5px;color:var(--ink-2);font-weight:500;white-space:nowrap}@media (max-width: 800px){.task-row{grid-template-columns:4px 1fr auto 22px;gap:10px;padding:12px}.task-row .task-id,.task-row .task-proj,.task-row .task-status-pill,.task-row .chip{display:none}}.task-detail-grid{display:grid;grid-template-columns:1fr 320px;gap:16px}.checklist-bar{height:5px;background:var(--surface-2);border-radius:3px;overflow:hidden}.checklist-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--done),oklch(.7 .16 155));border-radius:3px;transition:width .6s var(--ease)}.checkrow{display:flex;align-items:center;gap:10px;padding:8px 4px;border-radius:var(--r-1);cursor:pointer;transition:background var(--t-fast);font-size:13px}.checkrow:hover{background:var(--hover)}.checkrow input{width:16px;height:16px;accent-color:var(--accent)}.checkrow .done{color:var(--ink-3);text-decoration:line-through}.status-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.status-cell{display:flex;align-items:center;gap:6px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--r-1);font-size:12.5px;font-weight:500;background:var(--surface);color:var(--ink-2);transition:all var(--t-fast);cursor:pointer}.status-cell:hover{border-color:var(--border-2);color:var(--ink)}.status-cell.on{background:var(--accent);border-color:var(--accent);color:#fff}.status-cell.on .dot{background:#fff!important}.assign-btn{width:100%;display:flex;align-items:center;gap:8px;padding:7px 10px;border:1px solid var(--border);border-radius:var(--r-1);background:var(--surface);font-size:13px;text-align:left;transition:border-color var(--t-fast);cursor:pointer}.assign-btn:hover{border-color:var(--border-2)}.detail-meta-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border);font-size:13px}.detail-meta-row:last-child{border-bottom:none}.detail-meta-label{font-size:10.5px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em}@media (max-width: 880px){.task-detail-grid{grid-template-columns:1fr}}.admin-head{display:grid;grid-template-columns:1.4fr 1.4fr .8fr 1.2fr .8fr;padding:12px 18px;background:var(--surface-2);border-bottom:1px solid var(--border);font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);font-weight:600;gap:12px}.admin-row{display:grid;grid-template-columns:1.4fr 1.4fr .8fr 1.2fr .8fr;align-items:center;padding:12px 18px;border-bottom:1px solid var(--border);gap:12px;font-size:13px;transition:background var(--t-fast)}.admin-row:hover{background:var(--hover)}.admin-row:last-of-type{border-bottom:none}.admin-foot{padding:14px 18px;border-top:1px solid var(--border);font-size:12px;color:var(--ink-3);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.role-tag{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.role-admin{background:var(--accent-soft);color:var(--accent-ink)}.role-manager{background:#ffebd1;background:oklch(.95 .06 75);color:#734c00;color:oklch(.45 .16 75)}[data-theme=dark] .role-manager{background:#402800;background:oklch(.3 .1 75);color:#f4c582}.role-member{background:var(--surface-2);color:var(--ink-2)}.proj-tag{display:inline-flex;align-items:center;gap:5px;padding:2px 7px;border-radius:4px;font-size:10.5px;background:var(--surface-2);color:var(--ink-2)}@media (max-width: 880px){.admin-head{display:none}.admin-row{grid-template-columns:auto 1fr;row-gap:6px}.admin-row>*{grid-column:2}.admin-row>div:first-child{grid-column:1 / -1}}.modal-back{position:fixed;top:0;right:0;bottom:0;left:0;background:#13161c80;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;z-index:50;animation:fade-in .2s var(--ease);padding:20px}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-4);box-shadow:var(--shadow-pop);max-width:95vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-head{display:flex;align-items:start;justify-content:space-between;padding:18px 22px 14px;border-bottom:1px solid var(--border)}.modal-title{font-size:16px;font-weight:600;letter-spacing:-.02em}.modal-sub{font-size:12px;color:var(--ink-3);margin-top:2px}.modal-body{padding:18px 22px;overflow-y:auto}.modal-foot{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:14px 22px;border-top:1px solid var(--border);background:var(--surface-2)}.type-pill{padding:5px 11px;background:var(--surface);border:1px solid var(--border);border-radius:999px;font-size:12px;font-weight:500;color:var(--ink-2);text-transform:uppercase;letter-spacing:.04em;transition:all var(--t-fast);cursor:pointer}.type-pill:hover{border-color:var(--border-2)}.type-pill.on{border-color:transparent;color:inherit}.priority-pick{padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-1);font-size:12.5px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:6px;transition:all var(--t-fast);cursor:pointer}.priority-pick:hover{border-color:var(--border-2)}.priority-pick.on.prio-high{border-color:var(--priority-high);background:#fff0ee;background:oklch(.97 .04 25);color:#a20519}.priority-pick.on.prio-med{border-color:var(--priority-med);background:#fff3e4;background:oklch(.97 .04 75);color:#734c00;color:oklch(.45 .16 75)}.priority-pick.on.prio-low{border-color:var(--priority-low);background:#e1feea;color:#005d33;color:oklch(.42 .14 155)}[data-theme=dark] .priority-pick.on.prio-high{background:#551112;color:#ffc7c1;color:oklch(.88 .1 25)}[data-theme=dark] .priority-pick.on.prio-med{background:#402800;background:oklch(.3 .1 75);color:#fece8c}[data-theme=dark] .priority-pick.on.prio-low{background:#00381c;background:oklch(.3 .1 155);color:#a1ecbb}.dropzone{border:1.5px dashed var(--border-2);border-radius:var(--r-2);padding:18px;display:flex;align-items:center;justify-content:center;gap:10px;color:var(--ink-3);transition:all var(--t-fast);cursor:pointer}.dropzone:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.big-toggle{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--border);background:var(--surface);border-radius:var(--r-2);text-align:left;transition:all var(--t-fast);cursor:pointer}.big-toggle:hover{border-color:var(--border-2)}.big-toggle.on{border-color:var(--accent);background:var(--accent-soft)}.cmdk-back{position:fixed;top:0;right:0;bottom:0;left:0;background:#13161c66;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;padding-top:14vh;z-index:60;animation:fade-in .15s var(--ease)}.cmdk{width:580px;max-width:95vw;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-3);box-shadow:var(--shadow-pop);display:flex;flex-direction:column;height:fit-content;max-height:60vh}.cmdk-input{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border)}.cmdk-input input{flex:1;background:transparent;border:none;outline:none;font-size:14px;color:var(--ink)}.cmdk-list{padding:6px;overflow-y:auto;max-height:380px}.cmdk-row{width:100%;display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:var(--r-1);text-align:left;font-size:13px;color:var(--ink-2);transition:background var(--t-fast),color var(--t-fast);cursor:pointer}.cmdk-row:hover,.cmdk-row.focused{background:var(--accent-soft);color:var(--ink)}.cmdk-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cmdk-kind{font-size:10.5px;color:var(--ink-3)}.cmdk-empty{padding:24px;text-align:center;font-size:13px;color:var(--ink-3)}.cmdk-foot{display:flex;gap:16px;padding:10px 16px;border-top:1px solid var(--border);font-size:11.5px;color:var(--ink-3);background:var(--surface-2)}.cmdk-foot span{display:inline-flex;align-items:center;gap:4px}.fab-feedback{position:fixed;right:22px;bottom:22px;z-index:18;padding:10px 16px;background:var(--ink);color:var(--surface);border-radius:999px;display:flex;align-items:center;gap:8px;box-shadow:var(--shadow-3);font-size:12.5px;font-weight:500;transition:transform var(--t-fast);cursor:pointer;border:none}[data-theme=dark] .fab-feedback{background:var(--surface);color:var(--ink)}.fab-feedback:hover{transform:translateY(-2px)}@media (max-width: 880px){.fab-feedback{bottom:80px;right:14px;padding:9px 13px}}.notif-panel{position:fixed;right:16px;top:60px;width:360px;max-height:480px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-3);box-shadow:var(--shadow-pop);z-index:40;display:flex;flex-direction:column;overflow:hidden;animation:pop-in .2s var(--ease) both}.notif-head{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.notif-list{overflow-y:auto;flex:1}.notif-row{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border);transition:background var(--t-fast);cursor:pointer;width:100%;text-align:left}.notif-row:hover{background:var(--hover)}.notif-row.unread{background:var(--accent-soft)}.notif-row.unread:hover{background:var(--accent-soft-2)}.notif-msg{font-size:12.5px;line-height:1.4;flex:1}.notif-when{font-size:10.5px;color:var(--ink-3);margin-top:2px}.login-wrap{min-height:100vh;display:grid;place-items:center;background:var(--bg);padding:20px}.login-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-4);padding:32px;box-shadow:var(--shadow-3)}.login-brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px;letter-spacing:-.02em;margin-bottom:28px}.form-group{margin-bottom:16px}.login-error{padding:10px 12px;background:#fff0ee;background:oklch(.97 .04 25);border:1px solid oklch(.88 .07 25);border-radius:var(--r-1);color:#8a0314;font-size:13px;margin-bottom:16px}[data-theme=dark] .login-error{background:#551112;border-color:#932b2a;color:#ffd0cb;color:oklch(.9 .1 25)}.settings-section{margin-bottom:28px}.settings-section h3{font-size:13px;font-weight:600;margin:0 0 12px}.accent-swatches{display:flex;gap:8px;flex-wrap:wrap}.accent-swatch{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform var(--t-fast),border-color var(--t-fast)}.accent-swatch:hover{transform:scale(1.15)}.accent-swatch.on{border-color:var(--ink)}.filter-collapse,.filter-collapse-content{display:none}.filter-chip-group{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.filter-chip-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);font-weight:500;width:100%;margin-bottom:4px}.filter-collapse-badge{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 5px;border-radius:999px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;margin-left:4px}@media (max-width: 880px){.filter-collapse{position:relative;display:inline-flex}.filter-collapse-trigger.on{border-color:var(--accent);color:var(--accent-ink);background:var(--accent-soft)}.filter-collapse-content{position:absolute;top:calc(100% + 6px);left:0;z-index:30;width:max-content;min-width:260px;max-width:calc(100vw - 28px);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-2);box-shadow:var(--shadow-pop);padding:12px;flex-direction:column;gap:12px;animation:pop-in .2s var(--ease) both}.filter-collapse-content.open{display:flex}.filter-collapse-content .select,.filter-collapse-content .input{width:100%!important}.filter-collapse-clear{justify-content:center;margin-top:4px}.filter-desktop-only{display:none!important}}@media (max-width: 700px){.stat-tile{padding:11px 13px}.stat-tile-v{font-size:20px}.stat-tile-bar{margin-top:5px}.week-body{grid-template-columns:1fr;gap:16px;padding:14px}.week-bars{height:140px;gap:8px}.week-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.project-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));padding:10px 12px 12px}.project-grid-lg{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}}@media (max-width: 600px){.page-head{flex-wrap:wrap;gap:12px;margin-bottom:16px}.page-head>div:first-child{flex:1;min-width:0}.page-title{font-size:18px}}@media (max-width: 880px){.proj-head{flex-wrap:wrap;gap:8px;margin-bottom:12px}.proj-head .proj-head-title{flex:1;min-width:0}.proj-head h1.page-title{font-size:16px!important}.proj-head .proj-head-actions{width:100%;justify-content:space-between;gap:8px;margin-left:0!important}.proj-head .seg .seg-label{display:none}.proj-toolbar{padding:10px 12px;margin-bottom:12px}.proj-toolbar-row{gap:6px}.proj-toolbar-row .drag-hint{display:none}.view-btn-calendar{display:none!important}}@media (max-width: 1100px){.kanban{display:flex;grid-template-columns:none;gap:12px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}.kcol{min-width:280px;max-width:280px;flex-shrink:0;min-height:320px;scroll-snap-align:start}}@media (max-width: 700px){.kanban{margin:0 -14px;padding:0 14px 8px}.kcol{min-width:78vw;max-width:78vw;min-height:260px}}.kcard-foot{flex-wrap:wrap}@media (max-width: 700px){.cal-label-col{padding:6px 10px}.cal-task-label{font-size:12px}}@media (max-width: 880px){.filter-bar{gap:6px}.filter-bar .filter-search{flex:1 1 100%!important;min-width:0!important}.filter-bar .filter-desktop-only,.my-tasks-btn .btn-text{display:none}}@media (max-width: 600px){.task-row{grid-template-columns:4px 1fr auto 14px;gap:10px;padding:11px 12px}.task-row .task-id,.task-row .task-proj,.task-row .task-status-pill,.task-row .chip{display:none}.task-row-title{font-size:13px}}@media (max-width: 600px){.task-detail-grid{gap:12px}.task-detail-grid .card-pad{padding:14px}.status-grid{grid-template-columns:1fr 1fr}.activity-row{padding:6px 8px;gap:8px}.activity-line{font-size:12px}.comment-input{gap:6px}.comment-row{padding:8px 6px}}@media (max-width: 600px){.modal-back{padding:12px}.modal-head{padding:14px 16px 12px}.modal-body{padding:14px 16px}.modal-foot{padding:12px 16px}}@media (max-width: 600px){.login-card{padding:24px 22px}}
