:root{--font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--primary: #2f7d68;--primary-dark: #205a4c;--primary-light: #e6f4ef;--bg: #f2f2f7;--surface: #ffffff;--surface-raised: #f9f9fb;--surface-overlay: rgba(255, 255, 255, .9);--border: rgba(60, 60, 67, .1);--border-strong: rgba(60, 60, 67, .2);--text: #1c1c1e;--text-secondary: #636366;--text-tertiary: #aeaeb2;--blue: #3478f6;--blue-bg: #eef3ff;--orange: #c47900;--orange-bg: #fff5d9;--green: #25a65a;--green-bg: #e6f8ed;--red: #d63251;--red-bg: #ffeef3;--radius-xs: 6px;--radius-sm: 10px;--radius-md: 14px;--radius-lg: 18px;--radius-full: 999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 1px 6px rgba(0, 0, 0, .06), 0 2px 10px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08), 0 2px 6px rgba(0, 0, 0, .05);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .14), 0 4px 12px rgba(0, 0, 0, .08);--shadow-primary: 0 4px 16px rgba(47, 125, 104, .32);--tab-btn-h: 54px;font-family:var(--font);color:var(--text);background:var(--bg);color-scheme:light;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}html,body,#root{height:100%;overflow:hidden}*{box-sizing:border-box}body{margin:0;min-width:320px;overflow-x:hidden;background:var(--bg)}button,input,select,textarea{font:inherit}button{cursor:pointer}button,select,input,textarea{max-width:100%}.crash-screen{min-height:100vh;display:grid;place-items:center;padding:24px;background:var(--bg)}.crash-screen div{width:min(460px,100%);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-lg)}.crash-screen h1{margin:0 0 10px;font-size:24px}.crash-screen p{color:var(--text-secondary);line-height:1.5;margin:0 0 18px}.crash-screen button{min-height:44px;padding:0 16px;border:0;border-radius:var(--radius-sm);background:var(--primary);color:#fff;font-weight:700}.app-shell{height:100dvh;min-height:100vh;display:grid;grid-template-columns:240px minmax(0,1fr);align-items:start;overflow:hidden}.sidebar{height:100dvh;min-height:0;background:var(--surface);color:var(--text);border-right:1px solid var(--border);padding:24px 20px;display:flex;flex-direction:column;gap:24px}.brand{display:grid;align-items:start;justify-items:center;gap:8px;text-align:center}.brand-mark{width:40px;height:40px;display:grid;place-items:center;border-radius:var(--radius-sm);background:var(--primary-light);color:var(--primary-dark)}.brand-logo{width:min(164px,100%);height:auto;display:block;object-fit:contain}.sidebar .brand{padding-bottom:4px}.login-brand{justify-items:start;padding-bottom:10px;border-bottom:1px solid var(--border)}.brand strong,.brand span{display:block;overflow-wrap:anywhere}.brand strong{font-size:16px;line-height:1.2;text-align:center}.brand span,.user-switcher label,.topbar p{color:var(--text-secondary);font-size:13px}.nav-list{display:grid;gap:4px}.nav-list button,.primary-btn,.secondary-btn,.task-actions button,.admin-item button,.category-item button,.modal-head button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:var(--radius-sm)}.nav-list button{min-height:44px;justify-content:flex-start;padding:0 12px;background:transparent;color:var(--text-secondary);font-weight:600;transition:background .15s,color .15s}.nav-list button.active,.nav-list button:hover{background:var(--primary-light);color:var(--primary-dark)}.user-switcher{margin-top:auto;display:grid;gap:8px}.session-card{display:grid;grid-template-columns:36px minmax(0,1fr);align-items:center;gap:10px;border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 12px;background:var(--surface-raised)}.session-card strong,.session-card span{display:block;overflow-wrap:anywhere}.session-card span{color:var(--text-secondary);font-size:12px}.sync-chip{min-height:30px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(196,121,0,.25);border-radius:var(--radius-full);background:var(--orange-bg);color:var(--orange);font-size:12px;font-weight:700;padding:0 10px}.sync-chip.online{border-color:#25a65a40;background:var(--green-bg);color:var(--green)}.user-switcher select,.filters select,.filters input,.task-actions select,.stack-form input,.stack-form select,.inline-form input,.login-panel input,.task-modal input,.task-modal select,.task-modal textarea{width:100%;border:1.5px solid var(--border-strong);background:var(--surface);color:var(--text);border-radius:var(--radius-sm);padding:10px 12px;min-height:42px;transition:border-color .15s}.user-switcher select:focus,.filters select:focus,.filters input:focus,.task-actions select:focus,.stack-form input:focus,.stack-form select:focus,.inline-form input:focus,.login-panel input:focus,.task-modal input:focus,.task-modal select:focus,.task-modal textarea:focus{outline:none;border-color:var(--primary)}.workspace{padding:28px;height:100dvh;overflow:hidden;min-width:0;display:flex;flex-direction:column}.topbar{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px;min-width:0}.topbar p,.topbar h1{margin:0}.topbar p{color:var(--text-secondary);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}.topbar h1{font-size:28px;line-height:1.15;overflow-wrap:anywhere;font-weight:700;letter-spacing:-.3px}.primary-btn{min-height:42px;padding:0 16px;background:var(--primary);color:#fff;font-weight:600;white-space:nowrap;transition:background .15s,transform .1s}.primary-btn:hover{background:var(--primary-dark)}.primary-btn:active{transform:scale(.98)}.secondary-btn{min-height:42px;padding:0 16px;border:1.5px solid var(--border-strong);background:var(--surface);color:var(--text);font-weight:600;transition:background .15s}.secondary-btn:hover{background:var(--bg)}.danger-btn{min-height:42px;display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:var(--radius-sm);background:var(--red);color:#fff;padding:0 16px;font-weight:700;white-space:nowrap;transition:background .15s}.danger-btn:hover{background:#b22743}.mobile-fab{display:none}.confirm-toast-zone{position:fixed;inset:0;z-index:30;display:grid;place-items:center;padding:18px;background:#1c1c1e66;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.confirm-toast{width:min(420px,100%);display:grid;gap:16px;padding:20px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-lg)}.confirm-toast strong,.confirm-toast p{margin:0;overflow-wrap:anywhere}.confirm-toast p{margin-top:4px;color:var(--text-secondary);line-height:1.4}.confirm-actions{display:flex;justify-content:end;gap:10px}.login-screen{min-height:100vh;display:grid;place-items:center;padding:24px;background:var(--bg);overflow:auto}.login-panel{width:min(440px,100%);display:grid;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-md)}.login-panel h1,.login-panel p{margin:0}.login-panel h1{font-size:26px;line-height:1.15;font-weight:700}.login-panel p{color:var(--text-secondary)}.login-panel label{display:grid;gap:6px;font-weight:600}.form-error{border:1px solid rgba(214,50,81,.25);background:var(--red-bg);color:var(--red);border-radius:var(--radius-sm);padding:10px 14px;font-weight:600}.google-login-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 16px;border:1.5px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:15px;font-weight:600;text-decoration:none;transition:background .15s,border-color .15s;cursor:pointer}.google-login-btn:hover{background:var(--bg);border-color:var(--primary)}.login-divider{display:flex;align-items:center;gap:10px;color:var(--text-tertiary);font-size:13px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border)}.login-panel form{display:grid;gap:14px}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:24px;flex:0 0 auto}.my-work-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,320px);gap:16px;align-items:start;flex:1 1 auto;min-height:0}.my-work-main,.tasks-view,.board-section{min-height:0;display:flex;flex-direction:column}.my-work-main{height:100%}.my-work-search{display:flex;align-items:center;width:100%;margin-bottom:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-xs);flex:0 0 auto}.my-work-search input{flex:1;border:none;background:transparent;color:var(--text);padding:11px 14px 11px 38px;font-size:14px;outline:none;min-height:42px}.comment-form input,.comment-form select{width:100%;border:1.5px solid var(--border-strong);background:var(--surface);color:var(--text);border-radius:var(--radius-sm);padding:10px 12px;min-height:42px}.stat-card,.admin-panel,.activity-panel,.task-column,.task-row,.empty-state{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md)}.stat-card{padding:18px;min-height:112px;display:grid;align-content:space-between;min-width:0;box-shadow:var(--shadow-xs)}.stat-head,.section-heading,.column-head,.task-meta span,.task-topline,.row-foot{display:flex;align-items:center;gap:8px}.stat-head{color:var(--text-secondary);font-size:13px;font-weight:500}.stat-card strong{font-size:32px;font-weight:700;letter-spacing:-.5px}.stat-card.warning strong{color:var(--red)}.stat-card.clickable{cursor:pointer;transition:box-shadow .15s,transform .1s}.stat-card.clickable:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-card.clickable.active{border-color:var(--primary);background:var(--primary-light);box-shadow:0 0 0 1.5px var(--primary),var(--shadow-xs)}.stat-card.clickable.active .stat-head{color:var(--primary-dark)}.progress-track{height:8px;background:var(--border);border-radius:var(--radius-full);overflow:hidden}.progress-track span{display:block;height:100%;background:linear-gradient(90deg,var(--primary),#6cb86a);border-radius:var(--radius-full);transition:width .5s ease}.section-heading{margin-bottom:14px;min-width:0;flex:0 0 auto}.section-heading h2{margin:0;font-size:18px;font-weight:700}.section-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:14px;flex:0 0 auto}.section-toolbar .section-heading{margin-bottom:0}.view-switcher{display:inline-grid;grid-auto-flow:column;gap:4px;border:1.5px solid var(--border-strong);border-radius:var(--radius-sm);padding:4px;background:var(--bg)}.view-switcher button{min-height:34px;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:0;border-radius:var(--radius-xs);background:transparent;color:var(--text-secondary);padding:0 10px;font-weight:600;font-size:13px;transition:background .15s,color .15s}.view-switcher button.active,.view-switcher button:hover{background:var(--primary);color:#fff}.board-section{flex:1 1 auto;min-height:0}.board-section>.kanban,.board-section>.calendar-board,.board-section>.task-list{flex:1 1 auto}.tasks-view{flex:1 1 auto}.tasks-view .filters{flex:0 0 auto}.kanban{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;align-items:start;min-height:0}.task-column{display:flex;flex-direction:column;padding:14px;min-height:0;min-width:0;align-self:start;border-top:3px solid var(--border);border-radius:var(--radius-md)}.task-column.status-todo{background:#f7f9ff;border-top-color:var(--blue)}.task-column.status-in-progress{background:#fffcf0;border-top-color:var(--orange)}.task-column.status-done{background:#f3fbf6;border-top-color:var(--green)}.column-head{flex:0 0 auto;justify-content:space-between;margin-bottom:12px}.column-scroll{min-height:0;max-height:clamp(320px,calc(100dvh - 360px),600px);overflow-y:auto;overscroll-behavior:contain;padding-right:4px;scrollbar-width:thin}.column-scroll::-webkit-scrollbar{width:6px}.column-scroll::-webkit-scrollbar-track{background:transparent}.column-scroll::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-full)}.column-head span{display:inline-flex;align-items:center;gap:8px;font-weight:700}.column-head strong{min-width:24px;height:24px;display:grid;place-items:center;background:var(--border);border-radius:var(--radius-xs);font-size:13px}.task-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;margin-bottom:10px;border-left:4px solid var(--border-strong);box-shadow:var(--shadow-xs)}.kanban .task-card{margin-bottom:10px}.task-card.status-todo{background:#f8fbff;border-left-color:var(--blue)}.task-card.status-in-progress{background:#fffdf0;border-left-color:var(--orange)}.task-card.status-done{background:#f3fbf6;border-left-color:var(--green)}.task-topline{justify-content:space-between;margin-bottom:8px;min-width:0;flex-wrap:wrap;gap:6px}.category-pill{border-left:3px solid var(--accent);background:#0000000a;border-radius:var(--radius-xs);padding:4px 8px;font-size:11px;font-weight:700;min-width:0;overflow-wrap:anywhere;letter-spacing:.2px}.priority{font-size:12px;font-weight:700;white-space:nowrap}.status-pill{border-radius:var(--radius-full);padding:4px 10px;font-size:11px;font-weight:700;white-space:nowrap}.status-pill.status-todo{background:var(--blue-bg);color:#1a5eb8}.status-pill.status-in-progress{background:var(--orange-bg);color:#8a5a00}.status-pill.status-done{background:var(--green-bg);color:#1a6e3d}.priority.high,.priority.urgent,.overdue{color:var(--red)}.priority.medium{color:var(--orange)}.priority.low{color:var(--primary)}.task-card h3{font-size:15px;margin:0 0 6px;overflow-wrap:anywhere;font-weight:600;line-height:1.35}.task-card p{color:var(--text-secondary);margin:0 0 10px;line-height:1.45;overflow-wrap:anywhere;font-size:14px}.kanban .task-card p{display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2}.task-meta{display:grid;gap:6px;color:var(--text-secondary);font-size:13px;margin-bottom:12px;min-width:0}.task-meta span{min-width:0;overflow-wrap:anywhere}.task-actions{display:flex;align-items:center;gap:8px}.task-actions select{flex:1 1 140px;min-width:0}.task-actions button{flex:0 0 36px}.task-actions button,.admin-item button,.category-item button,.modal-head button{width:36px;height:36px;border:1.5px solid var(--border-strong);background:var(--surface);color:var(--text-secondary);transition:background .15s}.task-actions button:hover,.admin-item button:hover,.category-item button:hover,.modal-head button:hover{background:var(--bg)}.soft-empty{display:grid;place-items:center;min-height:78px;color:var(--text-tertiary);border:1.5px dashed var(--border-strong);border-radius:var(--radius-md);font-size:14px}.filters{display:grid;grid-template-columns:minmax(200px,1fr) repeat(3,minmax(140px,160px));gap:10px;margin-bottom:14px}.search-box{position:relative}.search-box svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-tertiary)}.search-box input{padding-left:38px}.task-list{display:grid;gap:10px;min-height:0;max-height:calc(100dvh - 220px);overflow-y:auto;overscroll-behavior:contain;padding-right:4px;scrollbar-width:thin}.task-list::-webkit-scrollbar,.admin-list::-webkit-scrollbar,.category-list::-webkit-scrollbar,.activity-panel::-webkit-scrollbar,.calendar-board::-webkit-scrollbar{width:6px;height:6px}.task-list::-webkit-scrollbar-thumb,.admin-list::-webkit-scrollbar-thumb,.category-list::-webkit-scrollbar-thumb,.activity-panel::-webkit-scrollbar-thumb,.calendar-board::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-full)}.my-work-main .task-list{max-height:calc(100dvh - 202px)}.dashboard-list{max-height:calc(100dvh - 332px)}.tasks-view .task-list{max-height:calc(100dvh - 244px)}.task-row{padding:0;min-width:0;border-left:4px solid var(--border-strong);border-radius:var(--radius-md);box-shadow:var(--shadow-xs);overflow:hidden}.task-row-summary{padding:11px 14px 9px;display:grid;gap:4px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .12s}.task-row-summary:hover{background:#00000004}.task-row-main{display:flex;align-items:center;gap:8px;min-width:0}.task-row-name{flex:1 1 0;min-width:0;font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-row-sub{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.task-row-due{font-size:12px;color:var(--text-secondary);font-weight:500}.task-row-due.overdue{color:var(--red);font-weight:600}.due-label{font-weight:700}.task-row-chevron{color:var(--text-tertiary);flex-shrink:0;transition:transform .18s}.task-row-chevron.open{transform:rotate(90deg)}.task-row-detail{padding:12px 14px 14px;border-top:1px solid var(--border);background:var(--surface-raised);display:grid;gap:10px}.task-row-desc{color:var(--text-secondary);font-size:14px;line-height:1.5;margin:0;overflow-wrap:anywhere}.task-actions .task-text-btn{width:auto;height:auto;min-height:32px;flex:0 0 auto;padding:0 12px;font-size:13px;font-weight:600;border:1.5px solid var(--border-strong);background:var(--surface);color:var(--text);border-radius:var(--radius-sm);transition:background .15s}.task-actions .task-text-btn:hover{background:var(--bg)}.task-row.status-todo{background:#f8fbff;border-left-color:var(--blue)}.task-row.status-in-progress{background:#fffdf0;border-left-color:var(--orange)}.task-row.status-done{background:#f3fbf6;border-left-color:var(--green)}.task-row .task-card{border:0;box-shadow:none;margin:0 0 10px;padding:0;background:transparent;border-left:none}.calendar-board{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;overflow-x:auto;overflow-y:auto;max-height:calc(100dvh - 332px)}.calendar-title-row{display:flex;align-items:end;justify-content:space-between;gap:12px;margin-bottom:14px}.calendar-title-row div{display:grid;gap:2px}.calendar-title-row span{color:var(--text-secondary);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px}.calendar-title-row strong{color:var(--text);font-size:22px;line-height:1.15;text-transform:capitalize;font-weight:700;letter-spacing:-.3px}.calendar-nav{display:inline-flex;align-items:center;justify-content:end;gap:6px}.calendar-nav button{min-height:32px;border:1.5px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-secondary);padding:0 10px;font-weight:600;font-size:13px;transition:border-color .15s,color .15s}.calendar-nav button:hover{border-color:var(--primary);color:var(--primary)}.calendar-grid.month-grid{display:grid;grid-template-columns:repeat(7,minmax(100px,1fr));gap:0;min-width:700px;overflow:hidden;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--border)}.weekday{min-height:32px;display:flex;align-items:center;padding:0 8px;background:var(--surface-raised);color:var(--text-secondary);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.month-cell{min-height:116px;min-width:0;padding:8px;background:var(--surface);border-top:1px solid var(--border);display:grid;align-content:start;gap:4px}.month-cell.muted{background:var(--surface-raised)}.month-cell.today{background:#2f7d680a}.month-cell-date{color:var(--text);font-size:13px;font-weight:700}.month-cell.today .month-cell-date{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;background:var(--primary);color:#fff;border-radius:50%;font-size:13px;font-weight:800}.month-tasks,.undated-list{display:grid;gap:4px}.calendar-task{width:100%;min-height:34px;border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius-xs);background:var(--surface-raised);color:var(--text);display:grid;gap:2px;padding:5px 7px;text-align:left;cursor:pointer;transition:box-shadow .15s}.calendar-task:hover{box-shadow:var(--shadow-sm)}.calendar-task span,.calendar-task small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calendar-task span{font-size:11px;font-weight:700}.calendar-task small{color:var(--text-secondary);font-size:10px;font-weight:600}.calendar-task.status-todo{background:#f7fbff}.calendar-task.status-in-progress{background:#fffdf0}.calendar-task.status-done{background:#f3fbf6}.more-count{color:var(--text-secondary);font-size:11px;font-weight:700}.undated-strip{margin-top:14px;border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;background:var(--surface-raised)}.undated-list{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.calendar-day-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px;min-height:32px;border-bottom:1px solid var(--border);padding-bottom:10px}.calendar-day-head strong,.calendar-day-head span{overflow-wrap:anywhere}.calendar-day-head span{color:var(--text-secondary);font-size:13px;font-weight:600;white-space:nowrap}.calendar-view-toggle{display:inline-flex;align-items:center;gap:0;background:var(--border);border-radius:var(--radius-sm);padding:2px;margin-bottom:14px}.calendar-view-toggle button{min-height:28px;padding:0 14px;border:none;border-radius:calc(var(--radius-sm) - 2px);background:transparent;color:var(--text-secondary);font-size:12px;font-weight:600;transition:background .15s,color .15s}.calendar-view-toggle button.active{background:var(--surface);color:var(--primary);box-shadow:0 1px 3px #00000014}.calendar-week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:0;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;background:var(--border);min-width:0}.week-day-col{display:flex;flex-direction:column;background:var(--surface);min-height:300px}.week-day-col.today{background:#2f7d6808}.week-day-col+.week-day-col{border-left:1px solid var(--border)}.week-day-head{display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 4px;border-bottom:1px solid var(--border);background:var(--surface-raised)}.week-day-name{color:var(--text-secondary);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.week-day-num{color:var(--text);font-size:16px;font-weight:700;line-height:1;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%}.week-day-num.today{background:var(--primary);color:#fff}.week-day-tasks{display:flex;flex-direction:column;gap:4px;padding:6px 4px;flex:1;min-height:0;overflow-y:auto}.week-no-task{display:block;min-height:20px}.row-foot{justify-content:space-between;color:var(--text-secondary);font-size:12px;margin-top:8px;min-width:0;font-weight:500}.row-foot span{min-width:0;overflow-wrap:anywhere}.empty-state{min-height:200px;display:grid;place-items:center;align-content:center;gap:8px;color:var(--text-secondary)}.empty-state strong{color:var(--text)}.admin-layout{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:16px;flex:1 1 auto;min-height:0}.admin-panel{padding:20px;min-height:0;display:flex;flex-direction:column}.activity-panel{padding:18px;position:sticky;top:18px;max-height:calc(100dvh - 56px);overflow:auto}.activity-panel .section-heading{position:sticky;top:0;z-index:1;background:var(--surface);padding-bottom:4px;margin-bottom:6px}.activity-list,.comment-list{display:grid;gap:10px}.activity-list.compact{max-height:260px;overflow:auto}.activity-item,.comment-item{display:grid;grid-template-columns:34px minmax(0,1fr);gap:10px;padding:12px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-raised)}.activity-item strong,.activity-item p,.comment-item strong,.comment-item p{margin:0;overflow-wrap:anywhere}.activity-item p,.comment-item p{color:var(--text);line-height:1.4;font-size:14px}.activity-item span,.comment-item span{color:var(--text-secondary);font-size:12px}.stack-form{display:grid;gap:10px;margin-bottom:16px}.edit-user-form{border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;background:var(--surface-raised)}.edit-user-delete{width:100%;margin-top:6px;justify-content:center}.form-caption{color:var(--text);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.form-hint{font-size:12px;color:var(--text-secondary);margin-bottom:8px;line-height:1.5}.onboarding-modal{width:min(520px,100%);background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-lg);padding:32px 28px 24px;display:flex;flex-direction:column;gap:20px}.onboarding-header{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}.onboarding-wave{font-size:40px;line-height:1}.onboarding-header h2{font-size:20px;font-weight:700;color:var(--text);margin:0}.onboarding-body{display:flex;flex-direction:column;gap:14px}.onboarding-body p{font-size:14px;color:var(--text-secondary);line-height:1.6;margin:0}.onboarding-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.onboarding-list li{display:flex;gap:10px;align-items:flex-start;font-size:14px;color:var(--text);line-height:1.5}.onboarding-icon{font-size:18px;flex-shrink:0;margin-top:1px}.onboarding-note{font-size:13px!important;color:var(--text-tertiary)!important;border-top:1px solid var(--border);padding-top:12px}.onboarding-btn{width:100%;justify-content:center;padding:12px;font-size:15px}.check-line{display:inline-flex;align-items:center;gap:8px;color:var(--text);font-weight:600}.split-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.inline-form{display:grid;grid-template-columns:1fr 54px auto;gap:10px;margin-bottom:16px}.inline-form input[type=color]{padding:3px}.admin-list,.category-list{display:grid;gap:10px;min-height:0;overflow-y:auto;padding-right:4px;scrollbar-width:thin}.admin-list,.category-list{flex:1 1 auto;max-height:none}.admin-item,.category-item{display:grid;align-items:center;gap:10px;border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;background:var(--surface-raised)}.admin-item{grid-template-columns:38px minmax(0,1fr) 36px 36px 36px}.category-item{grid-template-columns:18px minmax(0,1fr) 36px}.category-item strong{min-width:0;overflow-wrap:anywhere}.admin-item span{display:block;color:var(--text-secondary);font-size:13px;overflow-wrap:anywhere}.avatar{width:34px;height:34px;border-radius:var(--radius-sm);background:var(--primary-light);color:var(--primary-dark);display:grid;place-items:center;font-weight:800;font-size:12px}.swatch{width:18px;height:18px;border-radius:50%}.modal-backdrop{position:fixed;inset:0;background:#1c1c1e66;display:grid;place-items:center;padding:20px;z-index:10;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.task-modal{width:min(720px,100%);max-height:calc(100vh - 40px);overflow:auto;background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-lg);padding:22px;display:grid;gap:14px;min-width:0}.modal-head,.modal-actions{display:flex;align-items:center;justify-content:space-between;gap:12px}.modal-head span{color:var(--text-secondary);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.modal-head h2{margin:0;font-size:20px;overflow-wrap:anywhere;font-weight:700}.task-modal label,.assignee-box{display:grid;gap:6px;font-weight:600}.task-modal textarea{resize:vertical}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr));gap:12px}.collab-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,.9fr);gap:14px}.task-workspace{width:min(980px,100%)}.workspace-summary{display:flex;flex-wrap:wrap;gap:8px}.workspace-summary span,.preview-status{min-height:32px;display:inline-flex;align-items:center;border:1.5px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface-raised);color:var(--text);padding:0 10px;font-size:13px;font-weight:600}.preview-status{gap:8px;padding-right:4px}.preview-status select{min-height:28px;border:0;background:transparent;padding:0 24px 0 4px;font-weight:700}.workspace-summary .secondary-btn{min-height:32px;padding:0 10px}.preview-description{margin:10px 0 0;padding:14px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-raised);color:var(--text);line-height:1.6;overflow-wrap:anywhere;font-size:15px}.workspace-panel{display:grid;align-content:start;gap:12px;min-width:0}.comment-form{display:grid;grid-template-columns:120px minmax(0,1fr) auto;gap:8px;margin-top:10px;align-items:start}.workspace-panel .comment-form{margin-top:0}.checklist-form{grid-template-columns:minmax(0,1fr) auto}.checklist-list{display:grid;gap:8px;margin-bottom:12px}.checklist-item{display:grid;grid-template-columns:18px minmax(0,1fr);align-items:center;gap:8px;border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;background:var(--surface-raised);font-weight:600}.checklist-item span{overflow-wrap:anywhere}.checklist-item input:checked+span{color:var(--text-tertiary);text-decoration:line-through}.assignee-grid{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr));gap:10px}.check-card{display:grid;grid-template-columns:18px 34px 1fr;align-items:center;border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;min-width:0;gap:8px}.check-card span:last-child{overflow-wrap:anywhere}.modal-actions{justify-content:flex-end}.modal-actions button:not(.primary-btn){min-height:42px;padding:0 16px;border:1.5px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);font-weight:600}@media(max-width:1050px){.app-shell{display:flex;flex-direction:column;grid-template-columns:1fr;align-items:stretch}.sidebar{height:auto;min-height:0;position:sticky;top:0;z-index:5;flex-direction:row;align-items:center;flex-wrap:wrap;padding:12px 16px;gap:10px;border-right:0;border-bottom:1px solid var(--border);box-shadow:0 1px 6px #0000000f}.nav-list{grid-auto-flow:column;overflow-x:auto;scrollbar-width:none;gap:4px}.nav-list::-webkit-scrollbar{display:none}.user-switcher{margin-left:auto;margin-top:0;min-width:200px;flex-direction:row;align-items:center;gap:8px}.workspace{flex:1 1 auto;height:auto;min-height:0}.stats-grid,.kanban,.calendar-grid,.my-work-layout,.admin-layout{grid-template-columns:1fr}.column-scroll{max-height:440px}.activity-panel{position:static}.filters{grid-template-columns:1fr 1fr}}@media(max-width:640px){body{min-width:0}.app-shell{height:100dvh;min-height:0;overflow:hidden}.sidebar{display:flex;flex-direction:row;flex:0 0 auto;align-items:center;flex-wrap:nowrap;gap:8px;position:relative;top:auto;height:auto;min-height:0;padding:max(10px,env(safe-area-inset-top)) 14px 10px;overflow:visible}.sidebar .brand{flex:0 0 auto;width:auto;min-width:0;justify-items:flex-start;gap:0;padding-bottom:0;border-bottom:0}.brand-logo{width:min(120px,36vw)}.brand strong{display:none}.nav-list{position:fixed;left:0;right:0;bottom:0;z-index:20;display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:0;padding:0;background:var(--surface-overlay);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-top:.5px solid var(--border-strong);box-shadow:0 -1px 0 var(--border);border-radius:0;overflow:visible;flex-direction:unset}.nav-list button{min-height:var(--tab-btn-h, 54px);padding:8px 4px calc(8px + env(safe-area-inset-bottom,0px));justify-content:center;flex-direction:column;gap:3px;font-size:10px;font-weight:600;line-height:1.1;border-radius:0;white-space:nowrap;flex-shrink:unset;color:var(--text-tertiary);background:transparent;letter-spacing:0;transition:color .15s}.nav-list button.active{color:var(--primary);background:transparent}.nav-list button:hover{background:transparent;color:var(--primary)}.mobile-fab{display:flex;align-items:center;justify-content:center;position:fixed;right:18px;bottom:calc(70px + env(safe-area-inset-bottom,8px));width:52px;height:52px;border-radius:50%;background:var(--primary);color:#fff;border:none;box-shadow:0 4px 16px #2f7d6866,0 1px 4px #0000001f;z-index:19;cursor:pointer;transition:transform .15s,box-shadow .15s}.topbar-new-task{display:none}.user-switcher{flex:1;justify-content:flex-end;display:flex;flex-direction:row;align-items:center;gap:6px;margin:0;width:auto;min-width:0}.user-switcher label{display:none}.session-card{grid-template-columns:28px minmax(0,1fr);padding:6px 8px;min-width:100px;max-width:160px}.session-card .avatar{width:28px;height:28px;font-size:11px}.session-card strong{font-size:13px;line-height:1.2}.session-card span{font-size:11px}.sync-chip{min-height:28px;padding:0 8px;font-size:11px;white-space:nowrap}.logout-btn{flex-shrink:0;min-height:36px;width:36px;padding:0;display:inline-flex;align-items:center;justify-content:center}.logout-btn .btn-label{display:none}.workspace{flex:1 1 auto;min-height:0;height:auto;padding:16px 14px calc(80px + env(safe-area-inset-bottom,8px)) 14px;overflow-y:auto;overscroll-behavior:contain;display:block}.stats-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.kanban,.calendar-grid,.my-work-layout,.admin-layout{grid-template-columns:1fr}.my-work-main{height:auto}.activity-panel{position:static;max-height:none;overflow-y:visible;margin-top:8px}.activity-panel .section-heading{position:static}.topbar{flex-direction:row;align-items:flex-start;margin-bottom:16px}.topbar h1{font-size:24px}.confirm-toast-zone{padding:14px}.filters{grid-template-columns:1fr 1fr;gap:8px}.form-grid,.collab-grid,.assignee-grid{grid-template-columns:1fr}.inline-form{grid-template-columns:minmax(0,1fr) 50px auto}.comment-form{grid-template-columns:1fr}.view-switcher{grid-auto-flow:row;grid-template-columns:repeat(3,minmax(0,1fr))}.view-switcher button{padding:0 6px}.column-scroll{max-height:420px}.task-list,.calendar-board{max-height:none;overflow:visible;padding-right:0}.tasks-view .task-list,.my-work-main .task-list,.task-list.dashboard-list{max-height:none;overflow:visible}.admin-layout{flex:0 0 auto}.admin-panel{display:block}.admin-list,.category-list{max-height:none;overflow:visible;padding-right:0}.admin-item{grid-template-columns:36px minmax(0,1fr) 36px 36px 36px;gap:6px}.category-item{grid-template-columns:18px minmax(0,1fr) 36px}.login-screen{align-items:start;padding:18px}.login-panel{margin-top:22px;padding:20px}.login-panel h1{font-size:22px}.crash-screen{align-items:start;padding:18px}.crash-screen div{margin-top:36px;padding:20px}.crash-screen h1{font-size:22px;overflow-wrap:anywhere}.calendar-board{overflow-x:visible;padding:12px}.calendar-grid.month-grid{min-width:0;grid-template-columns:repeat(7,1fr)}.weekday{min-height:28px;font-size:10px;padding:0 2px;text-align:center;justify-content:center;font-weight:700}.month-cell{min-height:52px;padding:4px 2px;gap:3px;align-items:center}.month-cell-date{font-size:12px;font-weight:700;text-align:center;line-height:1;display:flex;align-items:center;justify-content:center;width:26px;height:26px;margin:0 auto;border-radius:50%}.month-cell.today{background:transparent}.month-cell.today .month-cell-date{background:var(--primary);color:#fff;width:26px;height:26px;font-size:12px;font-weight:800}.month-tasks{display:flex;flex-wrap:wrap;gap:2px;justify-content:center}.calendar-task{width:7px;height:7px;min-height:0;border-radius:50%;background:var(--accent, var(--primary));padding:0;border:none;display:inline-block;box-shadow:none}.calendar-task:hover{box-shadow:none;transform:scale(1.4);transition:transform .1s}.calendar-task span,.calendar-task small{display:none}.more-count{font-size:9px;font-weight:800;color:var(--text-tertiary);line-height:1}.calendar-title-row strong{font-size:18px}.calendar-week-grid{grid-template-columns:repeat(7,1fr);min-height:160px}.week-day-col{min-height:120px}.week-day-head{padding:6px 2px;gap:2px}.week-day-name{font-size:9px}.week-day-num{font-size:13px;width:24px;height:24px}.week-day-tasks{padding:4px 2px;gap:3px}.calendar-week-grid .calendar-task{width:100%;height:15px;min-height:0;border-radius:3px;background:var(--accent, var(--primary));padding:0 3px;border:none;display:flex;align-items:center;box-shadow:none;opacity:.9}.calendar-week-grid .calendar-task span{display:block;color:#fffffff2;font-size:9px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;line-height:1}.calendar-week-grid .calendar-task small{display:none}.calendar-week-grid .week-day-tasks{flex-direction:column;flex-wrap:nowrap;align-content:start;justify-content:flex-start;gap:2px;overflow-y:hidden}.calendar-view-toggle{margin-bottom:10px}}@media(max-width:460px){.sidebar{padding:max(8px,env(safe-area-inset-top)) 12px 8px;gap:6px}.brand-logo{width:min(88px,27vw)}.sync-chip{display:none}.session-card{max-width:128px;grid-template-columns:26px minmax(0,1fr);padding:5px 7px}.session-card .avatar{width:26px;height:26px;font-size:10px}.session-card strong{font-size:12px}.session-card span{display:none}.logout-btn{min-height:32px;width:32px}.mobile-fab:hover,.mobile-fab:active{transform:scale(1.06);box-shadow:0 6px 24px #2f7d6880,0 2px 6px #00000026}.topbar{flex-direction:row;align-items:center;margin-bottom:14px;gap:10px}.topbar h1{font-size:22px}.section-toolbar,.modal-actions{align-items:stretch;flex-direction:column}.modal-actions button{width:100%}.confirm-actions{flex-direction:column}.stats-grid{gap:8px}.stat-card{min-height:90px;padding:14px}.stat-card strong{font-size:26px}.task-actions button{flex-basis:38px;height:38px}.admin-item{grid-template-columns:30px minmax(0,1fr) 32px 32px 32px;gap:6px}.admin-item button,.category-item button{width:32px;min-height:32px;padding:0;flex-shrink:0}.split-actions{grid-template-columns:1fr 1fr}.category-item{grid-template-columns:18px minmax(0,1fr)}.inline-form{grid-template-columns:minmax(0,1fr) 44px auto}.task-modal{max-height:calc(100dvh - 20px);padding:16px}}@media(max-width:360px){.workspace{padding-inline:10px}.topbar h1{font-size:20px}.task-actions{align-items:stretch;flex-direction:column}.task-actions button{width:100%}.modal-backdrop{padding:8px}}
