@import url("https://fonts.googleapis.com/css2?family=IBM+Plex+Sans+Thai:wght@300;400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap");:root{--r-xs:5px;--r-sm:7px;--r-md:10px;--r-lg:14px;--r-xl:20px;--r-full:999px;--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;--sp-8:32px;--sp-10:40px;--font-sans:"IBM Plex Sans Thai",system-ui,-apple-system,sans-serif;--font-mono:"IBM Plex Mono",ui-monospace,monospace;--personal:#6366f1;--personal-soft:rgba(99,102,241,0.14);--team-a:#10b981;--team-a-soft:rgba(16,185,129,0.14);--team-b:#f59e0b;--team-b-soft:rgba(245,158,11,0.15);--team-c:#8b5cf6;--team-c-soft:rgba(139,92,246,0.15);--prio-none:#64748b;--prio-low:#3b82f6;--prio-medium:#eab308;--prio-high:#f97316;--prio-urgent:#ef4444;--st-backlog:#94a3b8;--st-todo:#64748b;--st-progress:#f59e0b;--st-done:#10b981;--st-canceled:#6b7280;--shadow-sm:0 1px 2px rgba(0,0,0,0.18);--shadow-md:0 6px 20px -4px rgba(0,0,0,0.35);--shadow-lg:0 24px 60px -12px rgba(0,0,0,0.55)}:root,[data-theme=dark]{--bg:#0b0d12;--bg-elev:#11141b;--surface:#14181f;--surface-2:#191e27;--surface-hover:#1d232d;--sidebar:#0d0f15;--border:#232a35;--border-soft:#1b212b;--text:#e8ebf0;--text-2:#aab2c0;--text-3:#717b8c;--text-faint:#4b5462;--ring:rgba(99,102,241,0.55);--overlay:rgba(5,7,11,0.62);--heat-0:#181d26}[data-theme=light]{--bg:#f7f8fa;--bg-elev:#ffffff;--surface:#ffffff;--surface-2:#f4f5f8;--surface-hover:#f0f2f6;--sidebar:#fbfbfd;--border:#e6e8ee;--border-soft:#eef0f4;--text:#15181f;--text-2:#515a68;--text-3:#828b9a;--text-faint:#aab1bd;--ring:rgba(99,102,241,0.4);--overlay:rgba(20,24,32,0.34);--heat-0:#eceef2;--shadow-md:0 6px 20px -6px rgba(20,24,40,0.14);--shadow-lg:0 24px 60px -16px rgba(20,24,40,0.2)}*{box-sizing:border-box}body,html{margin:0;height:100%}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-feature-settings:"ss01";transition:background .35s ease,color .35s ease}#__next,#root{height:100%}button{font-family:inherit;cursor:pointer}::selection{background:var(--personal-soft)}*{scrollbar-width:thin;scrollbar-color:var(--border) transparent}::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:var(--border);border-radius:999px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:var(--text-faint)}.mono{font-family:var(--font-mono);font-feature-settings:"tnum"}.kbd{font-family:var(--font-mono);font-size:11px;line-height:1;padding:3px 6px;border-radius:var(--r-xs);border:1px solid var(--border);background:var(--surface-2);color:var(--text-2)}.fade-in{animation:fade-in .28s ease both}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.pop-in{animation:pop-in .22s cubic-bezier(.2,.9,.3,1.2) both}@keyframes pop-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:none}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-hover) 50%,var(--surface-2) 75%);background-size:800px 100%;animation:shimmer 1.4s linear infinite;border-radius:var(--r-sm)}.skeleton-title{width:240px;height:28px;margin-bottom:22px}.skeleton-filter{width:320px;height:34px;margin-bottom:18px;border-radius:var(--r-full)}.skeleton-row{display:flex;align-items:center;gap:12px;padding:12px 14px}.skeleton-row-dot{width:19px;height:19px;border-radius:6px}.skeleton-row-line{height:13px}.skeleton-row-line-w45{width:45%}.skeleton-row-line-w58{width:58%}.skeleton-row-line-w71{width:71%}.skeleton-row-line-w84{width:84%}.skeleton-row-line-w57{width:57%}.skeleton-row-line-w70{width:70%}.skeleton-row-line-w83{width:83%}.skeleton-row-spacer{flex:1 1}.skeleton-row-meta{width:70px;height:18px;border-radius:var(--r-full)}.app{display:flex;height:100%;overflow:hidden}.sidebar{width:236px;flex:0 0 236px;background:var(--sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:10px 8px 10px 9px;gap:1px}.sb-brand{display:flex;align-items:center;gap:9px;padding:3px 6px 10px}.sb-logo{width:26px;height:26px;border-radius:7px;display:grid;place-items:center;background:var(--personal);color:#fff;flex:0 0 auto;box-shadow:0 2px 8px -2px color-mix(in srgb,var(--personal) 55%,transparent)}.sb-wordmark{flex:1 1;min-width:0;font-size:14.5px;font-weight:750;letter-spacing:.05em;color:var(--text)}.ws-wrap{position:relative}.ws-switch{display:flex;align-items:center;gap:9px;width:100%;padding:7px 9px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);color:var(--text);text-align:left;transition:background .12s ease,border-color .12s ease}.ws-switch.open,.ws-switch:hover{background:var(--surface-hover);border-color:var(--text-faint)}.ws-switch>svg:last-child{color:var(--text-faint);flex:0 0 auto;transition:transform .15s ease}.ws-switch.open>svg:last-child{transform:rotate(180deg)}.ws-backdrop{position:fixed;inset:0;z-index:39}.ws-menu{position:absolute;top:calc(100% + 5px);left:0;right:0;z-index:40;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-md);padding:5px;animation:wspop .14s ease}.ws-menu-sep{height:1px;background:var(--border-soft);margin:4px 6px}.ws-opt{display:flex;align-items:center;gap:9px;width:100%;padding:7px 8px;border:none;background:transparent;border-radius:var(--r-sm);text-align:left;color:var(--text)}.ws-opt:hover{background:var(--surface-hover)}.ws-opt .ws-mark{width:22px;height:22px;font-size:10px}.ws-opt .ws-copy strong{font-size:12.5px}.ws-opt .check{color:var(--personal);flex:0 0 auto;display:inline-flex}.ws-copy{flex:1 1;min-width:0}.ws-copy strong{font-size:13px;font-weight:650}.ws-copy span,.ws-copy strong{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ws-copy span{font-size:10.5px;color:var(--text-3)}.sb-search{display:flex;align-items:center;gap:9px;width:100%;height:34px;margin:8px 0 2px;padding:0 9px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);color:var(--text-3);font-size:13px;font-weight:500;text-align:left;transition:background .12s ease,border-color .12s ease}.sb-search:hover{background:var(--surface-hover);border-color:var(--text-faint);color:var(--text-2)}.sb-search>svg{flex:0 0 auto;color:var(--text-3)}.sb-search>span{flex:1 1;min-width:0}.sb-group{display:flex;flex-direction:column;gap:1px;padding:3px 0}.mobile-nav-spacer,.mobile-topbar-spacer,.sidebar-spacer{flex:1 1}.sb-sec{padding:11px 9px 5px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);border-top:1px solid var(--border-soft);margin-top:3px}.nav-btn{width:100%;height:32px;border:none;border-radius:var(--r-sm);background:transparent;color:var(--text-2);display:flex;align-items:center;gap:9px;padding:0 9px;font-size:13px;font-weight:500;position:relative;text-align:left;text-decoration:none}.nav-btn>svg{color:var(--text-3);flex:0 0 auto;transition:color .12s ease}.nav-btn>span{flex:1 1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-btn:hover{background:var(--surface-2);color:var(--text)}.nav-btn:hover>svg{color:var(--text-2)}.nav-btn.active{background:var(--surface-hover);color:var(--text);font-weight:600}.nav-btn.active>svg{color:var(--personal)}.nav-btn.active:before{content:"";position:absolute;left:-9px;top:7px;bottom:7px;width:3px;border-radius:0 3px 3px 0;background:var(--personal)}.nav-btn.active .count{color:var(--personal)}.sb-user{margin-top:5px;border-top:1px solid var(--border-soft);padding:9px 6px 2px;display:flex;align-items:center;gap:9px}.sb-user .ws-copy strong{font-size:12.5px;font-weight:600}.sb-user .ws-copy span{font-size:10px}.main{flex:1 1;min-width:0;display:flex;flex-direction:column;position:relative;overflow:hidden}.mobile-topbar{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--border);background:var(--bg-elev)}.content{flex:1 1;overflow:auto;padding:26px 30px 72px}.inner{max-width:920px;width:100%;margin:0 auto;display:flex;flex-direction:column}.inner.wide{max-width:none;height:100%}.mobile-nav{position:fixed;inset:0;z-index:70;display:none}.mobile-nav.open{display:block}.mobile-nav .backdrop{position:absolute;inset:0;background:var(--overlay)}.mobile-nav .sidebar{position:absolute;left:0;top:0;bottom:0;width:min(284px,86vw);display:flex;box-shadow:var(--shadow-lg);animation:nav-in .22s cubic-bezier(.3,.8,.4,1);overflow-y:auto}.mobile-nav-admin-link{margin-top:14px}.page-head{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:16px}.page-head-main{flex:1 1;min-width:0}.page-title{margin:0;font-size:19px;line-height:1.3;font-weight:650;letter-spacing:0}.subtitle{margin-top:4px;color:var(--text-3);font-size:12.5px;line-height:1.45}.head-actions{margin-left:auto;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.segmented{gap:2px;padding:3px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface-2);box-shadow:var(--shadow-sm)}.segmented,.segmented button{display:inline-flex;align-items:center}.segmented button{height:30px;min-width:38px;border:none;border-radius:var(--r-md);background:transparent;color:var(--text-3);gap:6px;padding:0 10px;font-size:12.5px}.segmented button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.filter-bar{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin:0 0 14px;scrollbar-width:none}.filter-bar::-webkit-scrollbar{display:none}.filter-wrap{position:relative;flex:0 0 auto}.filter-btn{display:inline-flex;align-items:center;gap:7px;height:36px;padding:0 12px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);color:var(--text-2);font-size:13px;font-weight:550}.filter-btn:hover{background:var(--surface-hover);color:var(--text)}.filter-btn.active{color:var(--personal);border-color:color-mix(in srgb,var(--personal) 40%,var(--border));background:var(--personal-soft)}.filter-backdrop{position:fixed;inset:0;z-index:39}.filter-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:210px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-lg);padding:6px;z-index:40}.filter-menu.left{right:auto;left:0}.filter-menu-label{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-faint);padding:6px 9px 7px}.filter-opt{display:flex;align-items:center;gap:9px;width:100%;padding:8px 9px;border:none;background:transparent;border-radius:var(--r-sm);color:var(--text-2);font-size:13px;text-align:left}.filter-opt:hover{background:var(--surface-hover)}.filter-opt.active{color:var(--text);font-weight:600}.filter-opt .fo-dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}.filter-opt .fo-name{flex:1 1}.filter-opt .check{display:inline-flex;color:var(--personal)}.filter-opt-clear{color:var(--text-3);justify-content:center}.filter-opt-clear .fo-name{flex:none}.filter-clear{display:inline-flex;align-items:center;gap:5px;height:36px;padding:0 11px;border:none;background:transparent;color:var(--text-3);font-size:12.5px;font-weight:500;border-radius:var(--r-md)}.filter-clear:hover{background:var(--surface-2);color:var(--text)}.filter-clear svg,.list-empty{color:var(--text-faint)}.list-empty{display:flex;flex-direction:column;align-items:center;gap:10px;padding:48px 20px;font-size:13px;text-align:center}.list-empty svg{opacity:.7}.search-overlay{position:fixed;inset:0;z-index:120;background:var(--overlay);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:flex-start;justify-content:center;padding:12vh 20px 20px}.search-modal{width:100%;max-width:560px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden}.search-bar{display:flex;align-items:center;gap:11px;padding:15px 18px;border-bottom:1px solid var(--border-soft)}.search-bar>svg{color:var(--text-3);flex:0 0 auto}.search-bar input{flex:1 1;min-width:0;border:none;outline:none;background:transparent;color:var(--text);font-size:16px;font-family:inherit}.search-bar input::placeholder{color:var(--text-faint)}.search-clear{display:grid;place-items:center;width:20px;height:20px;flex:0 0 auto;border:none;background:transparent;color:var(--text-faint);border-radius:50%;padding:0}.search-clear:hover{background:var(--surface-2);color:var(--text-2)}.search-results{padding:7px;display:flex;flex-direction:column;gap:1px;max-height:52vh;overflow-y:auto}.sr-row{display:flex;align-items:center;gap:10px;width:100%;padding:9px 11px;border:none;background:transparent;border-radius:var(--r-sm);text-align:left;color:var(--text)}.sr-row:hover{background:var(--surface-hover)}.sr-row>svg{color:var(--text-3);flex:0 0 auto}.sr-title{flex:1 1;min-width:0;font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sr-meta{font-size:11px;color:var(--text-faint);flex:0 0 auto}.search-empty,.search-hint{padding:28px 20px;text-align:center;color:var(--text-faint);font-size:13px}.tip-wrap{position:relative;display:inline-flex}.tip-bubble{position:absolute;bottom:calc(100% + 7px);left:50%;transform:translateX(-50%);background:var(--text);color:var(--bg);font-size:11px;font-weight:500;padding:4px 8px;border-radius:6px;white-space:nowrap;z-index:50;pointer-events:none;box-shadow:var(--shadow-md)}.icon-btn,.wd-icon-btn{width:32px;height:32px;padding:0;border-radius:var(--r-md);border:1px solid transparent;background:transparent;color:var(--text-3);display:grid;place-items:center;transition:transform .13s cubic-bezier(.34,1.56,.64,1),background .13s ease,color .13s ease,border-color .13s ease}.icon-btn:hover,.wd-icon-btn:hover{background:var(--surface-2);color:var(--text);border-color:var(--border)}.icon-btn:active,.wd-icon-btn:active{transform:scale(.86)}.icon-btn[disabled],.wd-icon-btn[disabled]{opacity:.32;cursor:default}.icon-btn[disabled]:hover,.wd-icon-btn[disabled]:hover{background:transparent;color:var(--text-3);border-color:transparent}.icon-btn.tinted,.wd-icon-btn.tinted{background:var(--personal-soft);color:var(--personal);border-color:transparent}.icon-btn.settings-preview-cycle{width:34px;height:34px}.icon-btn.settings-preview-cycle.pop{transform:scale(1.08)}.icon-btn.check-control,.icon-btn.row-status-toggle{width:var(--check-size,22px);height:var(--check-size,22px);flex:0 0 auto}.check-control .status-glyph,.row-status-toggle .status-glyph{width:18px;height:18px}.fab{position:absolute;right:26px;bottom:26px;width:54px;height:54px;border:none;border-radius:50%;background:var(--personal);color:#fff;box-shadow:0 8px 24px -4px color-mix(in srgb,var(--personal) 60%,transparent);display:grid;place-items:center;z-index:30;transition:transform .15s ease}.fab:hover{transform:scale(1.06)}.toast-stack{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);flex-direction:column;gap:8px;z-index:90;pointer-events:none}.toast,.toast-stack{display:flex;align-items:center}.toast{gap:9px;background:var(--text);color:var(--bg);padding:10px 16px;border-radius:var(--r-md);font-size:13px;font-weight:550;box-shadow:var(--shadow-lg);transition:opacity .22s ease,transform .22s ease}.toast,.toast.show{opacity:1;transform:translateY(0)}.avatar{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;background:radial-gradient(circle at 35% 25%,#41486c,#111827 70%);color:#fff;font-weight:700;border:1px solid color-mix(in srgb,var(--personal) 50%,transparent);flex-shrink:0}.scope-chip{display:inline-flex;align-items:center;gap:5px;padding:2px 8px 2px 7px;border-radius:var(--r-full);font-size:11px;font-weight:550;color:var(--text-2);background:var(--surface-2);flex:0 0 auto;min-width:0}.scope-chip .sc-dot{width:6px;height:6px;border-radius:50%;flex:0 0 auto}.scope-chip-label{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scope-chip--dot-only{padding:0;background:transparent;color:inherit}.prio-ic{display:inline-grid;place-items:center;line-height:0;flex:0 0 auto}.prio-ic svg{display:block}.status-glyph{display:inline-grid;place-items:center;line-height:0}.status-glyph svg{display:block}.dot{width:8px;height:8px;border-radius:50%;display:inline-block;background:currentColor;box-shadow:0 0 0 3px color-mix(in srgb,currentColor 14%,transparent)}.count{margin-left:auto;font-size:11px;font-weight:550;color:var(--text-faint);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.work-view{min-height:0}.work-list,.work-view{display:flex;flex-direction:column}.work-list{gap:0}.section-head{display:flex;align-items:center;gap:8px;padding:16px 12px 7px;font-size:12px;font-weight:650;color:var(--text-2)}.section-spacer{flex:1 1}.item-row{position:relative;display:flex;align-items:center;gap:11px;padding:11px 14px;border-radius:var(--r-md);transition:background .12s ease;cursor:pointer}.item-row.selected,.item-row:hover{background:var(--surface-hover)}.spine{position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:3px;opacity:.58;background:var(--personal)}.item-row.selected .spine,.item-row:hover .spine{opacity:.9}.row-main{flex:1 1;flex-direction:column;gap:3px}.row-main,.row-title{min-width:0;display:flex}.row-title{align-items:center;gap:8px}.row-title>svg{color:var(--text-faint);flex:0 0 auto}.rt-title{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13.5px;font-weight:460;color:var(--text)}.streak{display:inline-flex;align-items:center;gap:2px;flex:0 0 auto;font-size:11px;font-weight:650;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.streak,.streak svg{color:var(--prio-high)}.row-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:3px}.meta-proj{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--text-3)}.meta-proj svg{opacity:.65}.right-meta{display:flex;align-items:center;gap:9px;flex:0 0 auto}.avatar.avatar-ring,.right-meta .avatar{box-shadow:0 0 0 2px var(--bg-elev)}.row-date{font-size:11.5px;color:var(--text-3);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;white-space:nowrap;flex:0 0 auto}.row-date.overdue{color:var(--prio-high)}.label-pill{display:inline-flex;align-items:center;gap:5px;padding:1px 8px 1px 6px;border-radius:var(--r-full);font-size:11px;color:var(--text-3);background:var(--surface-2)}.label-pill .lp-dot{width:6px;height:6px;border-radius:50%;flex:0 0 auto}.ws-mark{width:24px;height:24px;border-radius:6px;display:grid;place-items:center;color:#fff;background:var(--personal);font-weight:700;font-size:11px;flex:0 0 auto}.project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));grid-gap:12px;gap:12px}.project-card{padding:14px;border-radius:var(--r-lg);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-sm);cursor:pointer}.project-card-head{display:flex;align-items:center;gap:10px;min-width:0}.project-card-copy{min-width:0}.project-card-title{display:block;font-size:13.5px;font-weight:650}.project-card-subtitle,.project-card-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-card-subtitle{margin-top:2px;font-size:12px;color:var(--text-3)}.project-card-description{color:var(--text-2);font-size:13px;line-height:1.55;margin:14px 0 0}.progress{height:7px;background:var(--surface-2);border-radius:var(--r-full);overflow:hidden;margin-top:14px}.progress>*{display:block;height:100%;border-radius:inherit}.project-progress-bar{width:var(--project-progress);background:var(--project-progress-color)}.project-card-foot{display:flex;justify-content:space-between;margin-top:8px;font-size:12px;color:var(--text-3)}.calendar-view{display:flex;flex-direction:column;height:100%;min-height:0}.calendar-view.year-mode{height:auto}.calendar-tools{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}.calendar-tools-spacer{flex:1 1}.cal-label{font-size:14px;font-weight:650}.cal-scroll{flex:1 1;min-height:0;overflow:auto}.month-wrap{min-width:560px}.dow-row{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-gap:6px;gap:6px;margin-bottom:6px}.dow-head{text-align:center;font-size:11px;font-weight:650;color:var(--text-faint);padding:2px 0}.month-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-gap:6px;gap:6px}.day-cell{min-height:118px;border-radius:var(--r-md);border:1px solid var(--border-soft);background:var(--surface-2);padding:7px;display:flex;flex-direction:column;gap:5px}.day-cell.today{border-color:var(--personal);background:color-mix(in srgb,var(--personal) 7%,var(--surface-2))}.day-num{font-size:12px;color:var(--text-3);font-weight:650}.event-chip{display:block;min-width:0;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left;border:none;border-left:2.5px solid var(--personal);border-radius:var(--r-sm);background:var(--personal-soft);color:var(--text);padding:4px 6px;font-size:11.5px}.event-chip.is-done{opacity:.5;text-decoration:line-through}.more-chip{display:inline-block;font-size:10.5px;color:var(--text-3);padding:1px 6px}.cal-cols{display:grid;grid-gap:8px;gap:8px}.cal-col{background:var(--surface-2);border:1px solid var(--border-soft);border-radius:var(--r-md);min-height:340px;display:flex;flex-direction:column;overflow:hidden}.cal-col.today{border-color:var(--personal)}.cal-col-head{display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 6px;border-bottom:1px solid var(--border-soft)}.cal-dow{font-size:11px;font-weight:650;color:var(--text-3)}.cal-date{width:28px;height:28px;display:grid;place-items:center;border-radius:50%;font-size:14px;font-weight:650;color:var(--text-2)}.cal-date.is-today{background:var(--personal);color:#fff}.cal-col-body{display:flex;flex-direction:column;gap:5px;padding:8px;flex:1 1}.cal-empty{color:var(--text-faint);font-size:12px;text-align:center;padding:10px 0}.cal-agenda{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:var(--surface)}.cal-agenda-head{padding:13px 16px;border-bottom:1px solid var(--border-soft);font-size:15px;font-weight:650;background:var(--surface-2)}.cal-agenda-head.today{color:var(--personal)}.cal-agenda-body{padding:6px}.year-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:10px;gap:10px}.year-cell{display:flex;flex-direction:column;align-items:flex-start;gap:7px;padding:15px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);min-height:92px;text-align:left;transition:border-color .12s ease,background .12s ease;cursor:pointer}.year-cell:hover{border-color:var(--text-faint);background:var(--surface-hover)}.year-cell.today{border-color:var(--personal)}.year-mon{font-size:14px;font-weight:650;color:var(--text)}.year-count{font-size:12px;color:var(--text-3)}.year-bar{display:flex;gap:3px;flex-wrap:wrap;margin-top:auto}.year-dot{width:6px;height:6px;border-radius:50%}.labels-empty{color:var(--text-faint);font-size:13px;padding:8px 2px}.drive-upload-btn{min-height:32px;padding:0 12px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface);color:var(--text-2);font-size:12.5px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:6px;cursor:pointer}.drive-file-input{display:none}.drive-view{position:relative;min-height:60vh}.drive-uploading{margin-bottom:10px;color:var(--text-3);font-size:12.5px}.drive-empty{padding:22px 0;color:var(--text-faint);font-size:12.5px}.drive-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:12px;gap:12px}.file-card{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);padding:12px;min-height:120px;display:flex;flex-direction:column;gap:10px}.file-preview{height:58px;border-radius:var(--r-sm);background:linear-gradient(135deg,var(--surface-2),var(--border-soft));display:grid;place-items:center;color:var(--text-3)}.drive-file-title{font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drive-file-meta{margin:0;font-size:12.5px;line-height:1.45;color:var(--text-3)}.drive-file-chip{align-self:flex-start;display:inline-flex;align-items:center;gap:5px;max-width:100%;padding:1px 8px 1px 6px;border-radius:var(--r-full);font-size:11px;color:var(--text-3);background:var(--surface-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.issues-view{display:flex;flex-direction:column;height:100%}.kanban{display:grid;grid-template-columns:repeat(5,minmax(230px,1fr));grid-gap:12px;gap:12px;overflow-x:auto;padding-bottom:10px;flex:1 1}.kanban-col{min-height:520px;background:var(--surface-2);border:1px solid var(--border-soft);border-radius:var(--r-lg);display:flex;flex-direction:column}.kanban-head{padding:11px 12px;border-bottom:1px solid var(--border-soft);display:flex;align-items:center;gap:8px;font-size:13px;font-weight:650}.kanban-status-glyph{width:16px;height:16px;display:inline-flex;flex-shrink:0}.kanban-cards{padding:10px;display:flex;flex-direction:column;gap:8px}.kanban-drop{font-size:12px;color:var(--text-faint);text-align:center;padding:16px 0;border:1px dashed var(--border);border-radius:var(--r-md)}.kanban-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:11px 12px;display:flex;flex-direction:column;gap:8px;box-shadow:var(--shadow-sm);cursor:-webkit-grab;cursor:grab;transition:opacity .12s,border-color .15s}.kanban-card:hover{border-color:var(--text-faint)}.kanban-card.dragging{opacity:.45;-webkit-user-select:none;-moz-user-select:none;user-select:none}.kanban-card-title{font-size:13.5px;line-height:1.45;color:var(--text)}.kanban-card-meta{display:flex;align-items:center;gap:7px;flex-wrap:wrap;min-width:0}.kanban-card-project{font-size:12px;color:var(--text-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kanban-card-footer{display:flex;align-items:center;gap:8px;min-width:0}.kanban-scope-chip{max-width:130px}.settings-view{max-width:780px}.set-tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:22px;overflow-x:auto;scrollbar-width:none}.set-tabs::-webkit-scrollbar{display:none}.set-tab{display:inline-flex;align-items:center;gap:7px;padding:10px 14px;background:transparent;color:var(--text-3);font-size:13.5px;font-weight:600;white-space:nowrap;border:none;border-bottom:2px solid transparent;margin-bottom:-1px}.set-tab:hover{color:var(--text-2)}.set-tab.active{color:var(--text);border-bottom-color:var(--personal)}.set-stack{display:flex;flex-direction:column;gap:18px;max-width:680px}.set-card{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);overflow:hidden}.set-card.danger{border-color:color-mix(in srgb,var(--prio-urgent) 40%,var(--border))}.set-card-head{padding:14px 16px;border-bottom:1px solid var(--border-soft)}.set-card-head-action{display:flex;align-items:center;gap:10px}.set-card-head-main{flex:1 1;min-width:0}.settings-workspace-create{white-space:nowrap}.settings-workspace-create:disabled{cursor:default}.settings-workspace-create-row{align-items:stretch}.settings-workspace-create-form{align-items:center}.settings-workspace-create-name{flex:1 1;min-width:0}.settings-workspace-create-submit:disabled{cursor:default;opacity:.64}.set-card-head strong{display:block;font-size:14px;font-weight:700}.set-card.danger .set-card-head strong{color:var(--prio-urgent)}.set-card-head p{margin:3px 0 0;color:var(--text-3);font-size:12.5px}.set-row{display:flex;align-items:center;gap:14px;padding:14px 16px;border-bottom:1px solid var(--border-soft)}.set-row:last-child{border-bottom:none}.set-label{flex:1 1;min-width:0}.set-label>strong{display:block;font-size:13.5px;font-weight:550;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.set-label>span{display:block;font-size:12px;color:var(--text-3);margin-top:2px;line-height:1.45}.set-control{flex:0 0 auto;margin-left:auto}.set-control,.settings-profile-form{display:flex;align-items:center;gap:8px}.settings-profile-form{flex-wrap:wrap}.settings-profile-name{flex:1 1 180px;min-width:0}.settings-select-auto{width:auto}.switch{width:38px;height:22px;border-radius:var(--r-full);background:var(--surface-hover);border:1px solid var(--border);position:relative;transition:background .18s ease,border-color .18s ease;flex:0 0 auto;padding:0}.switch.on{background:var(--personal);border-color:var(--personal)}.switch:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);transition:transform .18s ease}.switch.on:after{transform:translateX(16px)}.role-pill{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:650;padding:3px 9px;border-radius:var(--r-full);background:var(--surface-2);color:var(--text-2)}.role-pill.owner{background:var(--personal-soft);color:var(--personal)}.swatch{width:28px;height:28px;border-radius:50%;cursor:pointer;border:2px solid var(--bg-elev);box-shadow:0 0 0 1px var(--border);padding:0;transition:box-shadow .15s ease}.swatch.active{box-shadow:0 0 0 2px var(--personal)}.invite,.settings-invite-form{display:flex;gap:8px;width:100%}.invite input{flex:1 1;min-width:0}.invite .select,.settings-invite-form select{width:auto}.settings-invite-submit:disabled{cursor:default;opacity:.64}.settings-member-list{display:flex;flex-direction:column}.settings-member-you{color:var(--text-faint);font-weight:400}.admin-shell{min-height:100vh;background:var(--bg);color:var(--text)}.admin-topbar{gap:18px;padding:13px 24px;border-bottom:1px solid var(--border);background:var(--sidebar);flex-wrap:wrap}.admin-brand,.admin-topbar{display:flex;align-items:center}.admin-brand{gap:9px}.admin-logo{width:26px;height:26px;border-radius:7px;background:var(--prio-urgent);display:grid;place-items:center;color:#fff;font-size:13px;font-weight:800;flex:0 0 auto}.admin-wordmark{font-size:16px;font-weight:700}.admin-spacer{flex:1 1}.admin-email{font-size:12.5px;color:var(--text-3)}.admin-back-link{font-size:13px;font-weight:600;color:var(--personal);text-decoration:none}.admin-main{max-width:1120px;margin:0 auto;padding:28px 24px 60px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));grid-gap:12px;gap:12px;margin-bottom:18px}.stat-card{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);padding:16px}.stat-card .num{font-size:26px;font-weight:700;letter-spacing:-.5px;line-height:1}.stat-card .lbl{font-size:12.5px;color:var(--text-3);margin-top:4px}.stat-card .sub{font-size:12px;color:var(--text-faint);margin-top:6px;line-height:1.35}.admin-policy-stack{max-width:none;margin-top:26px}.admin-policy-note{font-size:12.5px;color:var(--text-3);padding:9px 11px;border-radius:var(--r-md);background:var(--surface-2);border:1px solid var(--border-soft)}.modal-wrap{position:fixed;inset:0;z-index:60;background:var(--overlay);display:grid;place-items:start center;padding-top:11vh}.modal{width:min(580px,93vw);background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);overflow:hidden}.modal-head{padding:13px 14px 13px 16px;border-bottom:1px solid var(--border-soft);display:flex;align-items:center;gap:8px}.modal-head-spacer{flex:1 1}.modal-body{padding:16px;display:flex;flex-direction:column;gap:12px}.field{display:flex;gap:10px;align-items:center}.field.field-start{align-items:flex-start}.field label{width:74px;color:var(--text-3);font-size:12px;flex-shrink:0}.modal-body .textarea{min-height:86px}.quickadd-actions{display:flex;justify-content:flex-end;gap:8px}.landing-shell{min-height:100%;background:var(--bg);color:var(--text)}.landing-nav{gap:12px;padding:20px clamp(20px,6vw,72px);max-width:1200px;margin:0 auto}.landing-brand,.landing-nav{display:flex;align-items:center}.landing-brand{gap:9px}.landing-wordmark{font-size:19px;font-weight:700;letter-spacing:0}.landing-nav-spacer{flex:1 1}.btn.landing-nav-btn{padding:8px 16px;background:transparent;color:var(--text);font-size:13.5px}.btn.landing-nav-primary{padding:8px 18px;font-size:13.5px}.landing-hero{max-width:980px;margin:0 auto;padding:clamp(40px,8vw,90px) clamp(20px,6vw,72px) 40px;text-align:center}.landing-kicker{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--surface);color:var(--text-2);font-size:12.5px;margin-bottom:26px}.landing-kicker-icon{color:var(--personal)}.landing-hero-title{font-size:clamp(36px,6.5vw,62px);font-weight:700;line-height:1.08;letter-spacing:0;margin:0 0 22px}.landing-hero-accent{background:linear-gradient(120deg,var(--personal),var(--team-c));-webkit-background-clip:text;background-clip:text;color:transparent}.landing-hero-copy{font-size:clamp(15px,2vw,18px);color:var(--text-2);max-width:560px;margin:0 auto 30px;line-height:1.6}.landing-hero-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.btn.landing-hero-primary{padding:12px 26px;font-size:15px;gap:8px}.btn.landing-hero-secondary{padding:12px 22px;background:var(--surface);color:var(--text);font-size:15px}.landing-scope-pills{display:flex;gap:10px;justify-content:center;margin-top:40px;flex-wrap:wrap}.landing-scope-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--r-full);background:var(--scope-soft);color:var(--scope-color);font-size:13.5px;font-weight:600}.landing-scope-dot{width:9px;height:9px;border-radius:50%;background:var(--scope-color)}.landing-preview{max-width:1000px;margin:0 auto;padding:10px clamp(16px,5vw,40px) 60px}.landing-preview-panel{border-radius:var(--r-xl);border:1px solid var(--border);background:var(--bg-elev);box-shadow:var(--shadow-lg);overflow:hidden}.landing-preview-chrome{display:flex;align-items:center;gap:7px;padding:11px 14px;border-bottom:1px solid var(--border)}.landing-preview-dot{width:11px;height:11px;border-radius:50%}.landing-preview-dot.red{background:#ff5f57}.landing-preview-dot.yellow{background:#febc2e}.landing-preview-dot.green{background:#28c840}.landing-preview-address{flex:1 1;text-align:center;font-size:12px;color:var(--text-faint)}.landing-preview-body{padding:22px 26px}.landing-preview-title{font-size:18px;font-weight:600;margin-bottom:16px}.landing-preview-row{display:flex;align-items:center;gap:12px;padding:11px 4px}.landing-preview-row+.landing-preview-row{border-top:1px solid var(--border-soft)}.landing-preview-check{width:18px;height:18px;border-radius:6px;border:1.8px solid var(--border);background:transparent;display:grid;place-items:center;flex:0 0 auto}.landing-preview-check.streak{border-radius:50%}.landing-preview-check.done{border-color:var(--preview-color);background:var(--preview-color)}.landing-preview-check-icon{color:#fff}.landing-preview-row-title{flex:1 1;min-width:0;text-align:left;font-size:14px;color:var(--text)}.landing-preview-row.done .landing-preview-row-title{color:var(--text-3);text-decoration:line-through}.landing-preview-streak{display:inline-flex;align-items:center;gap:2px;color:var(--prio-high);font-size:12px;font-weight:600}.landing-preview-streak-icon{color:var(--prio-high)}.landing-preview-chip{display:inline-flex;align-items:center;gap:6px;padding:2px 9px;border-radius:var(--r-full);background:var(--scope-soft);color:var(--scope-color);font-size:11.5px;font-weight:500;flex:0 0 auto}.landing-preview-chip-dot{width:7px;height:7px;border-radius:50%;background:var(--scope-color)}.landing-preview-time{width:60px;text-align:right;color:var(--text-3);font-size:12px;flex:0 0 auto}.landing-features{max-width:1000px;margin:0 auto;padding:20px clamp(20px,6vw,72px) 80px}.landing-feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:16px;gap:16px}.landing-feature-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px}.landing-feature-icon{width:40px;height:40px;border-radius:var(--r-md);display:grid;place-items:center;background:color-mix(in srgb,var(--feature-color) 15%,transparent);margin-bottom:14px}.landing-feature-icon-svg{color:var(--feature-color)}.landing-feature-title{font-size:16px;font-weight:600;margin-bottom:6px}.landing-feature-copy{font-size:13px;color:var(--text-3);line-height:1.55}.landing-footer{border-top:1px solid var(--border);padding:28px clamp(20px,6vw,72px);text-align:center;font-size:12.5px;color:var(--text-faint)}.wd-logo{width:26px;height:26px;border-radius:8px;background:var(--personal);color:#fff;display:grid;place-items:center;flex:0 0 auto}.wd-logo-lg{width:36px;height:36px}.wd-logo-xl{width:40px;height:40px}.wd-logo-icon{color:#fff}.auth-modal-wrap{position:fixed;inset:0;z-index:250;background:var(--overlay);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:grid;place-items:start center;padding-top:11vh}.auth-modal{width:min(420px,92vw)}.auth-head{padding:26px 26px 8px;display:flex;flex-direction:column;align-items:center;gap:12px}.auth-title{font-size:19px;font-weight:700}.auth-subtitle{font-size:13px;color:var(--text-3);text-align:center}.auth-form{padding:14px 26px 8px;display:flex;flex-direction:column;gap:11px}.auth-form .auth-input{background:var(--surface);padding:10px 12px;font-size:14px}.auth-error{display:flex;align-items:center;gap:6px;color:var(--prio-urgent);font-size:12.5px}.auth-form .auth-submit{margin-top:4px;min-height:44px;padding:0 12px;font-size:14.5px;gap:7px}.auth-form .auth-submit:disabled{opacity:.6;cursor:default}.auth-foot{padding:10px 26px 24px;text-align:center;font-size:13px;color:var(--text-3)}.auth-toggle{border:none;background:transparent;color:var(--personal);font-weight:600;font-size:13px;padding:0}.banned-screen{height:100vh;display:grid;place-items:center;background:var(--bg);color:var(--text)}.banned-card{text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px;max-width:360px;padding:24px}.banned-title{font-size:20px;font-weight:700}.banned-copy{font-size:14px;color:var(--text-3);line-height:1.6}.btn.banned-signout{margin-top:8px;padding:9px 18px;color:var(--text);font-size:13.5px}.detail-overlay{position:fixed;inset:0;z-index:50;display:flex}.detail-overlay.end{justify-content:flex-end}.detail-overlay.center{align-items:center;justify-content:center;padding:4vh 20px}.backdrop{position:absolute;inset:0;background:var(--overlay);opacity:1;transition:opacity .18s ease}.backdrop.closing{opacity:0}.detail-drawer,.detail-full,.detail-modal{position:relative;z-index:1;background:var(--bg-elev);display:flex;flex-direction:column;box-shadow:var(--shadow-lg);overflow:hidden;transition:transform .2s cubic-bezier(.3,.8,.4,1),opacity .18s ease}.detail-drawer{width:min(440px,94vw);height:100%;border-left:1px solid var(--border)}.detail-modal{width:min(640px,94vw);max-height:92vh}.detail-full,.detail-modal{border:1px solid var(--border);border-radius:var(--r-xl)}.detail-full{width:min(1080px,95vw);height:92vh}.detail-drawer.entering{animation:drawer-in .22s cubic-bezier(.3,.8,.4,1)}.detail-full.entering,.detail-modal.entering{animation:detail-pop .2s cubic-bezier(.3,.8,.4,1)}.detail-drawer.closing{transform:translateX(100%)}.detail-full.closing,.detail-modal.closing{opacity:0;transform:scale(.98)}.drawer-head{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border)}.detail-head-icon,.detail-head-type{color:var(--text-3)}.detail-head-type{font-size:12.5px;font-weight:650;text-transform:capitalize}.detail-head-id{font-size:11px;color:var(--text-faint)}.detail-head-spacer{flex:1 1}.drawer-body{flex:1 1;overflow:auto;padding:18px 20px}.modal-scroll{flex:1 1;overflow:auto;padding:18px 22px}.full-body{flex:1 1;min-height:0;display:grid;grid-template-columns:1fr 322px}.full-main{overflow:auto;padding:24px 28px}.full-side{overflow:auto;padding:22px;border-left:1px solid var(--border-soft);background:var(--surface)}.drawer-foot{padding:10px 16px;border-top:1px solid var(--border);font-size:11px;color:var(--text-faint);display:flex;justify-content:space-between}.status-name-input{flex:1 1;min-width:0;background:transparent;border:1px solid transparent;border-radius:var(--r-sm);padding:6px 9px;color:var(--text);font-size:14px;font-weight:550;outline:none;transition:border-color .12s ease,background .12s ease}.status-name-input:hover{border-color:var(--border)}.status-name-input:focus{border-color:var(--personal);background:var(--surface-2)}.status-list{display:flex;flex-direction:column}.status-item{border-bottom:1px solid var(--border-soft);padding:12px 16px}.status-item:last-child{border-bottom:none}.status-item-head{display:flex;align-items:center;gap:8px}.settings-glyph-slot{width:22px;height:22px;flex:0 0 auto}.status-count{font-size:11.5px;color:var(--text-faint);min-width:18px;text-align:center;flex:0 0 auto}.status-edit{margin-top:12px;padding:13px 14px;background:var(--surface-2);border:1px solid var(--border-soft);border-radius:var(--r-md)}.status-edit-label{font-size:11px;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:9px}.status-edit .color-grid+.status-edit-label,.status-edit .status-edit-label+.status-edit-label,.status-edit .symbol-grid+.status-edit-label{margin-top:15px}.symbol-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(42px,1fr));grid-gap:6px;gap:6px}.symbol-btn{display:grid;place-items:center;padding:8px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface);cursor:pointer;transition:border-color .12s ease,background .12s ease,transform .12s ease}.symbol-btn:hover{border-color:var(--text-faint);transform:translateY(-1px)}.symbol-btn.active{border-color:var(--personal);background:var(--personal-soft)}.color-grid{display:flex;flex-wrap:wrap;gap:9px}.color-swatch{width:28px;height:28px;border-radius:50%;cursor:pointer;border:2px solid var(--bg-elev);box-shadow:0 0 0 1px var(--border);padding:0;transition:transform .12s ease,box-shadow .12s ease}.color-swatch:hover{transform:scale(1.1)}.color-swatch.active{box-shadow:0 0 0 2px var(--personal)}.detail-subtask-row{display:flex;align-items:center;gap:9px;padding:4px 0}.detail-subtask-title-input{flex:1 1;min-width:0;border:none;border-bottom:1px solid transparent;background:transparent;color:var(--text-2);font-size:13px;padding:5px 0;outline:none}.detail-subtask-row.done .detail-subtask-title-input{color:var(--text-3);text-decoration:line-through}.d-title{display:flex;align-items:flex-start;gap:11px;margin-bottom:18px}.d-title h1{font-size:21px;line-height:1.3;font-weight:650}.d-title-icon{margin-top:3px;display:inline-grid;place-items:center;line-height:0;flex:0 0 auto}.d-title-input{flex:1 1;min-width:0;margin:0;padding:0;border:none;outline:none;background:transparent;font:inherit;font-size:21px;font-weight:650;line-height:1.3;color:var(--text)}.d-title-input.done{color:var(--text-3);text-decoration:line-through}.meta-grid{display:flex;flex-direction:column}.meta-row{display:flex;align-items:center;gap:12px;min-height:42px;padding:5px 0;border-bottom:1px solid var(--border-soft)}.detail-full-side .meta-row:first-child{padding-top:0}.meta-k{width:96px;flex:0 0 auto;color:var(--text-3);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.meta-v{flex:1 1;display:flex;gap:7px;flex-wrap:wrap}.detail-meta-inline,.meta-v{min-width:0;align-items:center}.detail-meta-inline{display:inline-flex}.detail-assignee-value{gap:7px}.detail-project-value{gap:6px}.detail-meta-icon{color:var(--text-3)}.detail-meta-text{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13px}.detail-meta-empty{color:var(--text-faint);font-size:12.5px}.d-block{margin-top:20px}.d-block-head{font-size:12.5px;color:var(--text-3);margin-bottom:8px;display:flex;align-items:center;gap:6px}.d-block-spacer{flex:1 1}.desc-box{width:100%;min-height:84px;padding:12px 14px;border-radius:var(--r-md);border:1px solid var(--border-soft);background:var(--surface-2);color:var(--text-2);font:inherit;font-size:13.5px;line-height:1.65;white-space:pre-wrap;text-align:left;cursor:text}.desc-box.empty{color:var(--text-faint)}.textarea{resize:vertical;min-height:104px;font:inherit;font-size:13.5px;line-height:1.6;padding:12px 14px}.input,.select,.textarea{width:100%;color:var(--text);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);outline:none}.input,.select{padding:9px 11px;font:inherit;font-size:13px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:32px;padding:0 12px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface);color:var(--text-2);font-size:12.5px;font-weight:600;cursor:pointer}.btn:hover{background:var(--surface-hover);color:var(--text)}.btn.primary{background:var(--personal);border-color:var(--personal);color:#fff}.btn.danger-btn{background:var(--prio-urgent);border-color:var(--prio-urgent);color:#fff}.d-block-head .btn{min-height:26px}.detail-desc-editing{display:flex;flex-direction:column;gap:8px}.detail-desc-actions{display:flex;justify-content:flex-end;gap:8px}.detail-attachment-list{display:flex;align-items:center;gap:7px;flex-wrap:wrap}.detail-attachment-chip{max-width:100%;text-decoration:none;line-height:1.7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.detail-attachment-chip>span{min-width:0;overflow:hidden;text-overflow:ellipsis}.detail-attachments-empty{font-size:12.5px;color:var(--text-faint);line-height:1.5}.detail-subtasks-block{margin-top:18px}.detail-subtasks-head{font-size:12.5px;color:var(--text-3);margin-bottom:8px;display:flex;align-items:center;gap:6px}.detail-subtasks-list{display:flex;flex-direction:column;gap:7px}.detail-subtask-form{display:flex;align-items:center;gap:8px;margin-top:3px}.detail-subtask-input{flex:1 1;min-width:0}.detail-subtask-empty{font-size:12.5px;color:var(--text-faint)}.dm-switch{display:inline-flex;background:var(--surface-2);border:1px solid var(--border-soft);border-radius:var(--r-md);padding:2px;gap:2px}.dm-btn{width:28px;height:26px;display:grid;place-items:center;border:none;background:transparent;color:var(--text-3);border-radius:var(--r-sm)}.dm-btn:hover{color:var(--text)}.dm-btn.active{background:var(--bg-elev);color:var(--personal);box-shadow:var(--shadow-sm)}.picker{position:relative;max-width:100%}.picker-btn{display:inline-flex;align-items:center;gap:7px;height:32px;padding:0 9px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);color:var(--text);font-size:13px;max-width:100%}.picker-btn>span:not(.status-glyph):not(.prio-ic){min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.picker-btn:hover{background:var(--surface-hover);border-color:var(--text-faint)}.picker-btn>svg:last-child{color:var(--text-faint);flex:0 0 auto}.picker.open .picker-btn{border-color:var(--personal)}.picker .status-glyph{width:16px;height:16px;flex:0 0 auto}.picker-backdrop{position:fixed;inset:0;z-index:70}.picker-menu{position:fixed;z-index:80;min-width:180px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-md);padding:5px;animation:wspop .13s ease;max-height:320px;overflow:auto}.picker-opt{display:flex;align-items:center;gap:9px;width:100%;padding:8px 9px;border:none;background:transparent;border-radius:var(--r-sm);color:var(--text-2);font-size:13px;text-align:left}.picker-opt:hover{background:var(--surface-hover);color:var(--text)}.picker-opt.active{color:var(--text);font-weight:600}.po-name{flex:1 1;min-width:0}.picker-opt .check{color:var(--personal);display:inline-flex;flex:0 0 auto}.reduce-motion *,.reduce-motion :after,.reduce-motion :before{animation:none!important;transition:none!important}@keyframes drawer-in{0%{transform:translateX(100%)}to{transform:none}}@keyframes detail-pop{0%{opacity:0;transform:scale(.975)}to{opacity:1;transform:none}}@keyframes wspop{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}@keyframes nav-in{0%{transform:translateX(-100%)}to{transform:translateX(0)}}@media (max-width:760px){.sidebar{display:none}.mobile-nav .sidebar{display:flex}.content{padding:18px 16px 96px}.day-cell{min-height:84px}.calendar-tools{gap:8px}.kanban{grid-template-columns:repeat(5,264px)}.detail-full-body,.full-body{grid-template-columns:1fr!important}.detail-full-side,.full-side{border-left:none!important;border-top:1px solid var(--border-soft)!important}.detail-full-panel{height:94vh!important}.filter-bar{flex-wrap:nowrap;overflow-x:auto;margin:-4px -16px 16px;padding:2px 16px}.set-tabs{margin:0 -16px 22px;padding:0 16px}.set-row{flex-wrap:wrap}.invite,.settings-invite-form{flex-direction:column;align-items:stretch}.invite .select,.invite input,.settings-invite-form input,.settings-invite-form select{width:100%!important}.fab{right:18px;bottom:18px}.year-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.001ms!important;transition-duration:.001ms!important}}