:root{--bg: #f6f7fb;--text: #111827;--muted: #6b7280;--card: #ffffff;--border: #e5e7eb;--primary: #3b82f6;--primary-hover: #2563eb;--tile-color: #e5e7eb;--kanban-gap: 14px;--insert-line-w: 4px;--radius: 10px;--focus-ring: 0 0 0 3px rgba(59,130,246,.22);--btn-h: 36px;--btn-h-sm: 30px;--sidebar-w: 250px;--sidebar-w-collapsed: 72px;--sidebar-progress: 1;--sidebar-toggle-w: 25px;--site-header-h: 56px;--page-gutter: 12px;--skeleton-delay: .3s}*{box-sizing:border-box}html,#root{height:100%}body{min-height:100%;overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none;margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Helvetica Neue,Arial,"Apple Color Emoji","Segoe UI Emoji";background:var(--bg);color:var(--text);line-height:1.45;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body::-webkit-scrollbar{display:none;height:0;width:0}html,body,#root,.app-shell,.app-content,.project-page,.project-layout{height:100%;min-height:100%}.container{margin:10px auto;padding:0 16px}.header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.site-header{display:flex;align-items:center;justify-content:space-between;background:#f1f5f9;padding:5px 20px 5px 5px;border-bottom:1px solid var(--border);position:fixed;top:0;left:0;right:0;height:var(--site-header-h);z-index:60;gap:28px;padding-left:calc(var(--sidebar-w) + 5px)}.site-header__left{display:flex;align-items:center;gap:24px}.logo-btn{margin:0;font-size:20px;cursor:pointer}.logo-btn__image{display:block;height:28px;width:auto}.main-nav{display:flex;gap:16px}.main-nav a{text-decoration:none;color:#1f2937;font-weight:500;padding:6px 10px;border-radius:6px}.main-nav a:hover{background:#e2e8f0}.site-header__right{display:flex;gap:8px}.button--danger{background:#dc2626}.button--danger:hover{background:#b91c1c}.button--danger.button--ghost{background:transparent;color:#dc2626;border-color:#dc2626}.button--danger.button--ghost:hover{background:#fee2e2}.btn-row{display:flex;gap:8px;margin-bottom:16px}.button{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:var(--btn-h);padding:0 12px;border-radius:var(--radius);font-size:14px;font-weight:600;background:var(--primary);color:#fff;border:1px solid transparent;cursor:pointer;transition:background-color .15s ease,border-color .15s ease,box-shadow .15s ease,transform .05s ease}.button:hover{background:var(--primary-hover)}.button:active{transform:translateY(1px)}.button:focus-visible{outline:none;box-shadow:var(--focus-ring)}.button:disabled{opacity:.6;cursor:not-allowed}.button--ghost{background:#fff;color:var(--text);border-color:var(--border)}.button--ghost:hover{background:#f8fafc}.button--secondary{background:#10b981}.button--secondary:hover{background:#059669}.button--small{height:var(--btn-h-sm);padding:0 10px;font-size:13px}.icon-btn{background:#fff;border:1px solid var(--border);border-radius:8px;padding:4px 8px;cursor:pointer;line-height:1}.icon-btn:hover{background:#f3f4f6}.icon-btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.icon-btn--square{padding:6px;display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px}.input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:#fff;font-size:14px}.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f626}textarea.input{height:auto;min-height:80px}@media(max-width:768px){.input,input,select,textarea{font-size:16px}}.input-counter{position:absolute;right:10px;bottom:8px;font-size:11px;color:var(--muted);pointer-events:none;line-height:1}.sidebar__notify-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px;border-radius:10px;border:1px solid var(--border);background:#fff;cursor:pointer;font-weight:600}.sidebar__notify-btn:hover{background:#f8fafc}.sidebar__notify-btn img{width:24px;height:24px}.sidebar__notify-badge{min-width:24px;padding:2px 8px;border-radius:999px;background:var(--primary);color:#fff;font-size:12px;text-align:center}.sidebar__user{margin-top:auto;width:100%;display:flex;align-items:center;gap:10px;padding:5px 0;border-radius:12px;border:none;background:transparent;cursor:pointer}.sidebar__user-meta{display:flex;flex-direction:column;align-items:flex-start;gap:2px;font-size:13px;overflow:hidden}.sidebar__user-meta strong{font-size:14px;font-weight:600;display:block;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar__user-meta span{font-size:12px;display:block;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-shell.is-collapsed .sidebar__user{justify-content:center}.app-shell.is-collapsed .sidebar__user-meta{display:none}.notifications-page{display:flex;flex-direction:column;gap:16px;padding-right:20px}.notifications-page__header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.notifications-page__actions{display:flex;gap:8px;flex-wrap:wrap}.notifications-empty{padding:28px;text-align:center;color:var(--muted);border:1px dashed var(--border);border-radius:12px;background:#fff}.notifications-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.notifications-list__item{display:flex;flex-direction:row;gap:12px;border:1px solid var(--border);border-radius:12px;padding:12px 16px;background:#fff;align-items:center}.notifications-list__item.is-unread{border-color:var(--primary);box-shadow:0 0 0 1px #3b82f640}.notifications-list__content{flex:1 1 auto;min-width:0}.notifications-list__message{font-weight:600;margin-bottom:6px}.notifications-list__meta{font-size:12px;color:var(--muted)}.notifications-list__actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.notifications-list__actions .button{min-width:120px}.notifications-list__actions .button--small{min-width:0}.notifications-list__delete{border:none;background:#f3f4f6;border-radius:8px;width:34px;height:34px;font-size:18px;cursor:pointer;color:#111827}.notifications-list__delete:hover{background:#e5e7eb}.telegram-card{border:1px solid var(--border);border-radius:14px;padding:20px;background:#fff}.telegram-card__header{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.telegram-card__title{font-weight:700;font-size:17px}.telegram-card__eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:#1d4ed8}.telegram-card__desc{margin:6px 0 0;color:#374151}.telegram-card__pill{align-self:flex-start;padding:6px 12px;border-radius:999px;border:1px solid rgba(55,65,81,.15);background:#fff;color:#374151;font-weight:700}.telegram-card__pill.is-on{background:#ecfdf3;border-color:#34d399;color:#065f46}.telegram-card__body{margin-top:12px;display:flex;flex-direction:column;gap:12px}.telegram-card__status-row{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}.telegram-card__label{font-size:12px;letter-spacing:.05em;color:var(--muted);text-transform:uppercase}.telegram-card__value{font-size:16px;font-weight:700}.telegram-card__hint{font-size:13px;color:#4b5563}.telegram-card__hint--warning{background:#fef2f2;border:1px solid #fecaca;padding:10px 12px;border-radius:12px}.telegram-card__code{border:1px dashed var(--border);padding:12px;border-radius:12px;background:#fff}.telegram-card__code-row{display:flex;align-items:center;gap:10px;justify-content:space-between;flex-wrap:wrap}.telegram-card__code-value{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-weight:700;font-size:18px;letter-spacing:.1em;padding:8px 12px;background:#111827;color:#f9fafb;border-radius:10px}.telegram-card__actions{display:flex;gap:8px;flex-wrap:wrap;align-items:end}.telegram-card__alert{background:#fef3c7;color:#92400e;border:1px solid #f59e0b;padding:10px 12px;border-radius:12px}.telegram-card__loader{color:var(--muted);font-size:14px}.badge{display:inline-flex;align-items:center;gap:6px;padding:2px 8px;border-radius:999px;font-size:12px;border:1px solid var(--border);color:var(--muted);background:#fff}.user-badges{display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap}.user-badges--xs{gap:4px}.user-badges--sm{gap:6px}.user-badges--lg{gap:8px}.user-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;border:1px solid var(--border);font-size:12px;font-weight:600;line-height:1.2}.user-badge--xs{font-size:10px;padding:1px 6px}.user-badge--sm{font-size:11px;padding:2px 8px}.board-grid{gap:14px}.board-tile{height:110px;padding:12px;border-radius:var(--radius);overflow:hidden}.board-tile__name{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.board-tile:focus-visible{outline:none;box-shadow:var(--focus-ring)}.auth-logo{width:100%}.auth-form{max-width:360px;margin:60px auto;display:grid;gap:10px}.auth-form h3{margin-bottom:4px}.auth-form__forgot{display:flex;align-items:center;justify-content:center;gap:6px;font-size:13px;color:var(--muted);margin-top:12px}.auth-form__forgot-link{background:none;border:none;color:var(--primary);font-weight:600;cursor:pointer;padding:4px 0}.auth-form__forgot-link:hover,.auth-form__forgot-link:focus-visible{color:var(--primary-hover);text-decoration:underline}.auth-form__forgot-link:focus-visible{outline:none}.actions{display:flex;gap:8px;align-items:center}.error{color:#dc2626;font-size:13px;margin-top:8px}.info{color:#15803d;font-size:13px;margin-top:8px}.muted{color:var(--muted)}.board-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-bottom:20px}.board-tile{color:#1f2937;text-shadow:none;background:var(--tile-color, #eef2f7);border:1px solid rgba(0,0,0,.06);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);height:120px;border-radius:12px;box-shadow:0 2px 6px #00000014;display:flex;align-items:end;padding:12px;cursor:pointer;position:relative;transition:transform .18s ease,box-shadow .18s ease}.board-tile:hover{filter:none;box-shadow:0 6px 14px #0000001f}.board-tile__name{font-weight:600}.board-tile--adder{background:#f8fafc;color:#475569;border:2px dashed #cbd5e1;display:flex;align-items:center;justify-content:center;padding:12px;transition:background .15s ease,color .15s ease,border-color .15s ease,box-shadow .15s ease}.board-tile--adder:hover,.board-tile--adder:focus{background:#f1f5f9;border-color:#94a3b8;color:#1e293b;box-shadow:0 0 0 3px #94a3b859;outline:none}.board-tile--adder:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.board-tile__adder-inner{display:flex;flex-direction:column;gap:6px;align-items:center;font-size:14px}.board-tile--adder .plus{font-size:34px;line-height:1}.board-tile{transition:transform .18s ease,box-shadow .18s ease}.board-tile:before,.board-tile:after{content:none!important}.board-tile:hover,.board-tile:focus-visible{transform:translateY(-4px);box-shadow:0 6px 14px #0000001f}@media(prefers-reduced-motion:reduce){.board-tile:hover,.board-tile:focus-visible{transform:none}}.kanban{display:flex;align-items:flex-start;gap:var(--kanban-gap);padding:0 calc(var(--kanban-gap)/2 + var(--insert-line-w)/2) 8px}.kanban::-webkit-scrollbar{display:none!important}.kanban__column{margin-top:2px;background:var(--card);border:1px solid var(--border);border-radius:12px;min-width:280px;max-width:320px;flex:0 0 auto;display:flex;flex-direction:column;--kanban-column-max-h: calc(100vh - var(--site-header-h));max-height:var(--kanban-column-max-h);box-shadow:0 2px 6px #0000000f;transition:box-shadow .12s ease,transform .12s ease;position:relative}.kanban__column.insert-before:before,.kanban__column.insert-after:after{content:"";position:absolute;top:4px;bottom:4px;width:var(--insert-line-w);border-radius:2px;background:var(--primary);box-shadow:0 0 0 2px #3b82f640;pointer-events:none}.kanban__column.insert-before:before{left:calc(-.5 * var(--kanban-gap) - var(--insert-line-w)/2)}.kanban__column.insert-after:after{right:calc(-.5 * var(--kanban-gap) - var(--insert-line-w)/2)}.kanban__column.col-drop-target{outline:2px dashed var(--primary);outline-offset:0}.kanban__tasks.is-over{outline:2px dashed var(--primary);outline-offset:2px}.kanban__column-header{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:6px;padding:10px 12px;position:sticky;top:0;background:var(--card);border-bottom:1px solid var(--border);border-top-left-radius:12px;border-top-right-radius:12px;z-index:1;cursor:pointer}.kanban__column-header.is-readonly{cursor:default}.kanban__column-title{font-weight:700}.kanban__column-count{font-size:12px;padding:2px 8px;border-radius:999px;border:1px solid var(--border);color:var(--muted)}.kanban__column-actions{display:inline-flex;gap:6px;opacity:.75}.kanban__column:hover .kanban__column-actions{opacity:1}.kanban__tasks{padding:12px;display:grid;gap:10px;overflow-y:auto;cursor:pointer;flex:1 1 auto}.tasks{list-style:none;padding:0;margin:0;display:grid;gap:10px}.task{padding:12px 14px;border:1px solid var(--border);border-radius:10px;background:var(--card)}.task:hover{background:#f9fafb}.task__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.task__desc{margin:0;color:var(--muted)}.home-tasks__header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.home-tasks__actions{display:flex;gap:8px;align-items:center}.home-tasks__table-wrapper{width:100%;overflow-x:auto}.home-tasks__table{width:100%;border-collapse:collapse;min-width:600px;font-size:14px;border-left:1px solid var(--border);border-right:1px solid var(--border);border-radius:12px;overflow:hidden}.home-tasks__table thead th{text-align:left;font-weight:600;color:var(--muted);padding:8px 12px;border-bottom:1px solid var(--border)}.home-task-row{cursor:pointer;transition:background .1s ease}.home-task-row:hover{background:#f0f2f8}.home-task-row:focus-visible{outline:2px solid var(--primary);outline-offset:-2px}.home-task-row.is-completed{opacity:.85}.home-tasks__table tbody .home-task-row.is-skeleton{cursor:default;position:relative;overflow:hidden}.home-tasks__table tbody .home-task-row.is-skeleton:hover{background:transparent}.home-tasks__table tbody .home-task-row.is-skeleton .home-task-cell{border-bottom-color:transparent}.home-task-cell{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:top}.home-task-cell--title{font-weight:600;min-width:200px}.home-task-cell--deadline.is-overdue{color:#dc2626;font-weight:600}.home-task-assignees{display:inline-flex;gap:6px;align-items:center;flex-wrap:wrap}.home-task-skeleton-line{position:relative;height:12px;display:inline-block;border-radius:999px;background:linear-gradient(120deg,#94a3b840 25%,#e2e8f0bf,#94a3b840 75%);background-size:220% 100%;animation:home-task-line-shimmer 1.6s ease-in-out infinite;animation-delay:calc(var(--skeleton-delay, 0s) - .8s);animation-fill-mode:both}.home-tasks__table tbody .home-task-row.is-skeleton:nth-child(1) .home-task-skeleton-line{animation-delay:0s}.home-tasks__table tbody .home-task-row.is-skeleton:nth-child(2) .home-task-skeleton-line{animation-delay:.2s}.home-tasks__table tbody .home-task-row.is-skeleton:nth-child(3) .home-task-skeleton-line{animation-delay:.4s}.home-tasks__table tbody .home-task-row.is-skeleton:nth-child(4) .home-task-skeleton-line{animation-delay:.6s}.home-tasks__table tbody .home-task-row.is-skeleton:nth-child(5) .home-task-skeleton-line{animation-delay:.8s}.home-tasks__table tbody .home-task-row.is-skeleton:nth-child(6) .home-task-skeleton-line{animation-delay:1s}@keyframes home-task-line-shimmer{0%{background-position:150% 0;opacity:.35}35%{background-position:80% 0;opacity:.75}55%{background-position:40% 0;opacity:.95}75%{background-position:0% 0;opacity:.65}to{background-position:-150% 0;opacity:.35}}.task:active{cursor:grabbing}.task{box-shadow:0 1px 2px #0000000d;position:relative}.task.task-insert-before:before,.task.task-insert-after:after{content:"";position:absolute;left:-6px;right:-6px;height:4px;background:var(--primary);border-radius:2px;box-shadow:0 0 0 2px #3b82f640;pointer-events:none}.task.task-insert-before:before{top:-6px}.task.task-insert-after:after{bottom:-6px}.kanban__column--adder{min-width:280px;max-width:320px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;border:2px dashed var(--border);background:#f8fafc;color:#475569;cursor:pointer;border-radius:12px;font-weight:500;padding:16px;-webkit-user-select:none;user-select:none;transition:background .15s ease,color .15s ease,border-color .15s ease,box-shadow .15s ease}.kanban__column--adder:hover,.kanban__column--adder:focus{background:#f1f5f9;border-color:#94a3b8;color:#1e293b;box-shadow:0 0 0 3px #94a3b859;outline:none}.kanban__column--adder:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.kanban__column-adder-inner{display:flex;flex-direction:column;align-items:center;gap:6px;font-size:14px}.kanban__column--adder .plus{font-size:32px;line-height:1}.kanban::-webkit-scrollbar,.kanban__tasks::-webkit-scrollbar{height:8px;width:8px}.kanban::-webkit-scrollbar-thumb,.kanban__tasks::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px}.kanban::-webkit-scrollbar-track,.kanban__tasks::-webkit-scrollbar-track{background:transparent}.modal{position:fixed;left:0;right:0;top:0;bottom:env(safe-area-inset-bottom,0px);display:flex;align-items:center;justify-content:center;z-index:50;padding:24px;padding-top:calc(var(--site-header-h) + 24px);background:#1118278c;overflow-y:auto}@media(max-width:640px){.modal{padding:12px 8px;padding-top:calc(var(--site-header-h) + 12px)}}.modal__overlay{position:absolute;inset:0;background:#1118278c}.modal__content{position:relative;width:min(640px,92vw);max-height:calc(100vh - var(--site-header-h) - env(safe-area-inset-bottom,0px) - 80px);background:var(--card);border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 30px #0003;display:flex;flex-direction:column;overflow:hidden}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);flex:0 0 auto}.modal__body{display:grid;gap:12px;padding:16px;flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.modal__content form{flex:1 1 auto;display:flex;flex-direction:column;min-height:0}.modal__footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 16px;border-top:1px solid var(--border);flex:0 0 auto}.modal__footer--with-delete{justify-content:space-between}.modal__actions-right{display:flex;gap:8px}.modal__close{background:transparent;border:none;font-size:22px;line-height:1;cursor:pointer;color:var(--muted);padding:4px 8px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center}.field{display:grid;gap:6px}.field__label{font-size:13px;color:var(--muted)}.field__note{font-size:12px;margin-top:4px;color:var(--muted)}.field__note--warning{color:#b45309}textarea.input{resize:vertical}.time-estimate-row{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-end}.time-estimate-control{display:inline-flex;align-items:center;gap:4px}.time-estimate-control .input{width:96px;padding-right:12px}.time-estimate-unit{font-size:13px;color:var(--muted)}.task__meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px;justify-content:space-between}.tag{display:inline-flex;align-items:center;gap:6px;background:#f3f4f6;color:#374151;border:1px solid var(--border);border-radius:999px;padding:2px 8px;font-size:12px}.tag--overdue{background:#dc2626;color:#fff;border-color:#b91c1c;box-shadow:0 1px #0000000f}.sidebar__header{display:flex;align-items:center;justify-content:space-between;width:100%}.sidebar__header{position:static}.sidebar__toggle{position:absolute;right:calc(-1 * var(--sidebar-toggle-w) / 2);top:50%;transform:translateY(-50%);width:var(--sidebar-toggle-w);height:50px;padding:4px;border:1px solid var(--border);border-radius:8px;background:#f3f4f6;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 6px #0000000f;z-index:49;overflow:hidden}.sidebar__toggle:hover{background:#e9edf2}.sidebar__toggle:focus{outline:none;box-shadow:0 0 0 4px #3b82f614}.sidebar__toggle:after{content:"";position:absolute;top:50%;left:50%;width:6px;height:6px;transform:translate(-25%,-50%) rotate(135deg);border-right:2px solid currentColor;border-bottom:2px solid currentColor;box-sizing:content-box}.app-shell.is-collapsed .sidebar__toggle:after{transform:translate(-50%,-50%) rotate(-45deg)}.app-shell.is-collapsed .sidebar__header{display:none}@media(max-width:520px){.sidebar__toggle{display:none!important}}.sidebar{display:flex;flex-direction:column;align-items:stretch;gap:16px;height:100%}.sidebar__logo{padding:7px 10px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;transition:transform .25s ease,opacity .18s ease}.sidebar__logo:hover{background:#f3f4f6}.sidebar__logo:focus-visible{outline:none;box-shadow:var(--focus-ring)}.sidebar__logo img,.sidebar__logo .logo-mark{display:block;height:32px;width:auto;max-width:100%;object-fit:contain}.app-shell.is-collapsed .sidebar__logo{justify-content:center;padding:8px 0}.app-shell.is-collapsed .sidebar__logo img,.app-shell.is-collapsed .sidebar__logo .logo-mark{height:28px;opacity:.9}.app-shell.is-resizing .sidebar__logo{transition:none!important}.proj-badge{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;color:#fff;font-weight:700;font-size:12px}.site-header{padding-left:calc(var(--sidebar-w) + var(--page-gutter))}.app-shell.is-collapsed .site-header{padding-left:calc(var(--sidebar-w-collapsed) + var(--page-gutter))}@media(orientation:portrait){.site-header{padding-left:5px!important}.app-content{padding-left:16px!important;padding-right:16px}}.app-content{padding-left:20px;padding-right:20px;padding-top:20px;position:absolute;top:0;left:var(--sidebar-w);right:0;bottom:0;overflow-y:auto}.app-sidebar{padding:12px 16px;display:flex;flex-direction:column;gap:10px;width:var(--sidebar-w);position:absolute;top:0;left:0;height:100%;background:var(--card);border-right:1px solid var(--border);box-shadow:2px 0 6px #0000001a;z-index:35;transition:width .18s ease,padding .12s ease}.sidebar__resizer{position:absolute;right:0;top:0;bottom:0;width:10px;cursor:ew-resize;z-index:60}.sidebar__resizer:after{content:"";position:absolute;left:2px;top:0;bottom:0;width:2px;background:transparent;transition:background .12s ease}.sidebar__resizer:hover:after{background:#1118270f}.app-content{padding-left:20px;padding-top:20px;position:absolute;top:0;left:var(--sidebar-w);right:0;bottom:0}.app-content::-webkit-scrollbar{height:0;display:none}.app-shell.is-collapsed .app-sidebar{width:var(--sidebar-w-collapsed);padding-left:6px;padding-right:6px}.app-shell.is-collapsed .app-content{left:var(--sidebar-w-collapsed)}.sidebar__add{width:25px;height:25px;border-radius:6px;border:none}.app-shell.is-collapsed .sidebar__actions,.app-shell.is-collapsed .sidebar__logo .logo-text,.app-shell.is-collapsed .sidebar__add{display:none!important}.sidebar__title,.tree__board>span:nth-child(2){white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:transform .22s ease,opacity .18s ease;transform-origin:left center}.project-board-item.project-board-item--mini.is-active{background:#dbeafe;border-color:#93c5fd;color:#1e293b;box-shadow:inset 0 0 0 2px #2563eb59}.project-layout{display:grid;grid-template-columns:auto 1fr;gap:14px;padding:0;align-items:flex-start}.project-layout:has(.project-sidebar.is-collapsed){grid-template-columns:auto 1fr}.project-layout.no-board-selected{align-items:stretch;height:100%}.app-shell.is-collapsed .sidebar__title,.app-shell.is-collapsed .tree__board>span:nth-child(2){transform:translate(-110%);opacity:0;pointer-events:none}.project-layout.is-dimmed{opacity:.7;transition:opacity .18s ease;pointer-events:none}.project-plan{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:12px;align-self:flex-start}.project-plan--modal{border:none;padding:0;background:transparent}.project-plan__header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.project-plan__eyebrow{margin:0;font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}.project-plan__balance{font-size:14px;color:var(--muted)}.project-plan__balance strong{color:var(--text);font-size:16px}.project-plan__description{margin:0;color:var(--muted)}.project-plan__status{display:flex;flex-wrap:wrap;gap:10px;font-weight:600;color:var(--text)}.project-plan__hint{font-size:13px;color:var(--muted);background:#f8fafc;border:1px dashed var(--border);border-radius:10px;padding:8px 10px}.project-plan__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.project-plan-option{border:1px solid var(--border);border-radius:12px;padding:12px;background:#fff;display:flex;flex-direction:column;gap:8px;cursor:pointer;text-align:left;transition:border-color .15s ease,box-shadow .15s ease}.project-plan-option:hover:not(:disabled){border-color:#6366f173;box-shadow:0 6px 24px #0f172a1f}.project-plan-option:disabled{cursor:not-allowed;opacity:.85}.project-plan-option.is-active{border-color:#6366f1;box-shadow:inset 0 0 0 2px #6366f159}.project-plan-option__top{display:flex;align-items:center;justify-content:space-between;gap:10px}.project-plan-option__badge{font-size:11px;text-transform:uppercase;border-radius:999px;padding:2px 8px;font-weight:600;color:#1d4ed8;background:#dbeafe}.project-plan-option__price{font-size:18px;font-weight:700}.project-plan-option__description{margin:0;color:var(--muted);font-size:13px}.project-plan-option__limits{margin:0;padding-left:18px;font-size:13px;color:var(--muted);display:grid;gap:2px}.project-plan-option__hint{font-size:12px;color:var(--muted);display:block}.project-plan-option__loader{font-size:12px;color:var(--muted)}.project-plan__error{color:#b91c1c;font-weight:600}.project-plan__error-screen{position:fixed;inset:0;background:#0f172ab8;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}.project-plan__error-card{background:#fff;border-radius:16px;padding:24px;max-width:360px;width:100%;text-align:center;display:grid;gap:12px;box-shadow:0 18px 60px #0f172a59}.project-plan__error-card h4{margin:0;font-size:20px}.project-plan__error-card p{margin:0;color:var(--muted)}.project-plan__skeleton{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.project-plan__skeleton-card{height:130px;border-radius:12px;background:linear-gradient(90deg,#94a3b833,#94a3b80d,#94a3b833);background-size:200% 100%;animation:skeleton-shimmer 1.4s linear infinite}.avatar-crop-modal__body{display:flex;flex-direction:column;gap:16px;align-items:center}.avatar-cropper{border-radius:18px;overflow:hidden;position:relative;background:#0f172a;touch-action:none;cursor:grab}.avatar-cropper img{position:absolute;top:0;left:0;-webkit-user-select:none;user-select:none;pointer-events:none}.avatar-cropper__slider{width:100%;display:flex;flex-direction:column;gap:6px;font-weight:600}.avatar-cropper__hint{margin:0;font-size:13px;color:var(--muted);text-align:center}.task__row{display:flex;align-items:flex-start;gap:10px}.task__check{width:20px;height:20px;flex:0 0 20px;border-radius:50%;border:2px solid var(--border);background:#fff;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;line-height:1;cursor:pointer;-webkit-user-select:none;user-select:none}button.task__check:hover{border-color:var(--primary)}.task__check.is-checked{background:var(--primary);border-color:var(--primary);color:#fff}.task__check.is-disabled{cursor:not-allowed;opacity:.5}.task__body{flex:1 1 auto;min-width:0}.task__subtasks{display:flex;flex-direction:column;gap:4px;margin-top:6px}.task__subtask{display:flex;align-items:center;gap:6px}.task__subtask-toggle{border:none;background:transparent;padding:0;cursor:pointer;line-height:0;border-radius:4px}.task__subtask-toggle:disabled{cursor:default;opacity:.6}.task__subtask-check{width:14px;height:14px;border:1px solid var(--border);border-radius:4px;font-size:10px;display:flex;align-items:center;justify-content:center;color:var(--primary);background:#fff}.task__subtask-check.is-checked{background:var(--primary);color:#fff;border-color:var(--primary)}.task__subtask-title{flex:1 1 auto;font-size:12px;color:#1f2937}.task__subtask.is-completed .task__subtask-title{text-decoration:line-through;color:var(--muted)}.task--completed{opacity:.75}.task--completed .task__header b{text-decoration:line-through;color:var(--muted)}.kebab-anchor{position:relative;display:inline-block}.kebab-btn{width:36px;height:36px;padding:0;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:8px;color:inherit;cursor:pointer}.kebab-btn:hover{background:#ffffff80;border:1px solid var(--border)}.kebab-btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.kebab-icon{opacity:.7}.kebab-btn:hover .kebab-icon{opacity:1}.project-board-list{display:grid;gap:6px;padding-top:8px}.projects-list-list{padding-top:0}.project-board-item{--board-border-default: rgba(15,23,42,.08);--board-border-active: var(--primary);--board-shadow-default: inset 0 0 0 rgba(79,70,229,0);--board-shadow-active: inset 3px 0 0 rgba(79,70,229,.85);display:flex;align-items:center;gap:8px;padding:8px 10px;width:100%;background:var(--board-color, #fff);border:1px solid var(--board-border-default);border-radius:10px;box-shadow:var(--board-shadow-default);cursor:pointer;color:inherit;position:relative;text-align:left;white-space:normal;word-break:break-word;overflow:hidden;transition:border-color .32s cubic-bezier(.4,0,.2,1),box-shadow .32s cubic-bezier(.4,0,.2,1),background-color .28s ease,color .2s ease,transform .12s ease,max-width .2s ease,opacity .2s ease;will-change:border-color,box-shadow}.project-board-item:hover{border-color:#0f172a2e;box-shadow:0 4px 12px #0f172a14}.project-board-item:active{transform:translateY(1px)}.project-board-item:focus-visible{outline:none;box-shadow:var(--focus-ring);background:var(--board-color, #fff)}.project-board-item.is-active{background:var(--board-color, #fff);border-color:var(--board-border-active);color:#1e293b;font-weight:600;box-shadow:var(--board-shadow-active)}.project-board-item.project-board-item--mini{--board-border-default: rgba(15,23,42,.12);--board-shadow-default: inset 0 0 0 rgba(37,99,235,0);--board-shadow-active: inset 0 0 0 2px rgba(37,99,235,.35);width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;font-weight:700;border-radius:10px;background:var(--board-color, #fff);border:1px solid var(--board-border-default);text-transform:uppercase}.project-board-item.project-board-item--mini.is-active{background:var(--board-color, #fff);border-color:var(--primary);color:#1e293b;box-shadow:var(--board-shadow-active)}.project-sidebar.is-collapsing .project-board-item.project-board-item--mini.is-active{animation:board-active-collapse .36s ease forwards}@keyframes board-active-collapse{0%{box-shadow:inset 3px 0 #2563ebd9;border-color:var(--primary)}60%{box-shadow:inset 0 0 0 4px #2563eb40;border-color:#2563eb00}to{box-shadow:inset 0 0 0 2px #2563eb59;border-color:var(--primary)}}.project-sidebar.is-expanding .project-board-item.is-active:not(.project-board-item--mini){animation:board-active-expand .36s ease forwards}@keyframes board-active-expand{0%{box-shadow:inset 0 0 0 2px #2563eb59;border-color:#2563eb00}50%{box-shadow:inset 0 0 0 4px #2563eb40;border-color:#2563eb80}to{box-shadow:inset 3px 0 #2563ebd9;border-color:var(--primary)}}.project-item-skeleton{pointer-events:none;cursor:default;box-shadow:none;border-style:dashed}.project-item-skeleton .skeleton-circle,.project-item-skeleton .skeleton-line{background:#0f172a14}.project-item-skeleton.project-board-item--mini{justify-content:center}.project-board-list--mini .kebab-anchor{display:none}.kebab-menu{right:0;left:auto;min-width:180px}.board-color-picker{display:flex;flex-wrap:wrap;gap:10px}.board-color-picker__swatch{width:36px;height:36px;border-radius:999px;border:1px solid rgba(15,23,42,.15);padding:0;cursor:pointer;background-clip:padding-box;box-sizing:border-box}.board-color-picker__swatch.is-active{border-color:#1d4ed8;box-shadow:0 0 0 2px #2563eb40}.board-color-picker__swatch:focus-visible{outline:none;box-shadow:0 0 0 3px #2563eb59}.board-color-picker__swatch:disabled{opacity:.6;cursor:not-allowed}.members-list{display:grid;gap:8px}.list__item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;background:#fff;border:1px solid var(--border);border-radius:10px}.list__item.is-active{background:#eef2ff;border-color:#c7d2fe;box-shadow:inset 3px 0 0 var(--primary)}.list__item--admin{border-color:#dc2626;box-shadow:inset 3px 0 #dc2626}.checkbox{display:inline-flex;align-items:center;gap:8px;-webkit-user-select:none;user-select:none;cursor:pointer}.checkbox input{width:16px;height:16px}.checkbox.is-disabled{opacity:.6;cursor:not-allowed}.roles-pane{padding:10px}.roles-toolbar{margin-bottom:4px}.roles-list{max-height:360px;overflow:auto;display:grid;gap:8px;padding-right:4px}.roles-item{cursor:pointer;text-align:left;width:100%;border:1px solid var(--border);background:#fff;border-radius:10px}.roles-item:hover{background:#f8fafc}.roles-item .badge{background:#f1f5f9;border-color:#e2e8f0}.role-dot{width:12px;height:12px;border-radius:999px;box-shadow:inset 0 0 0 1px #00000014}.project-roles-modal__body{display:grid;grid-template-columns:320px 1fr;gap:16px;min-height:0;overflow:hidden;width:100%}.project-roles-modal__sidebar,.project-roles-modal__details{display:flex;flex-direction:column;gap:12px;min-height:0;min-width:0}.project-roles-modal__details{gap:16px}.project-roles-modal__roles-list{display:grid;gap:8px;overflow:auto;padding-right:4px;min-height:0;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.project-roles-modal__scroll-area{flex:1;min-height:0;overflow:auto;padding-right:4px;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.project-roles-modal__roles-toolbar{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:nowrap}.project-roles-modal__roles-title{margin:0;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-roles-modal__roles-toolbar .button{white-space:nowrap;flex-shrink:0}.project-roles-modal__form-row{display:flex;flex-wrap:nowrap;align-items:center;gap:12px}.project-roles-modal__row-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.project-roles-modal__order-buttons{display:inline-flex;align-items:center;gap:8px}.project-roles-modal__color-input{width:44px;height:44px;padding:0;border:1px solid var(--border);border-radius:8px;background:#fff;cursor:pointer}.project-roles-modal__color-input:disabled{opacity:.6;cursor:not-allowed}.project-roles-modal__name-field{flex:1;min-width:220px;position:relative}@media(max-width:900px){.project-roles-modal__body{grid-template-columns:1fr;grid-auto-rows:min-content}.project-roles-modal__sidebar,.project-roles-modal__details{min-height:initial}.project-roles-modal__roles-list{max-height:240px}.project-roles-modal__scroll-area{padding-right:0}}@media(max-width:640px){.project-roles-modal{width:calc(100vw - 16px)!important;max-width:none;max-height:calc(100vh - var(--site-header-h) - env(safe-area-inset-bottom,0px) - 64px);height:auto;border-radius:12px}.project-roles-modal__body{padding:12px;gap:12px;overflow-y:auto;-webkit-overflow-scrolling:touch}.project-roles-modal__sidebar,.project-roles-modal__details{gap:10px}.project-roles-modal__name-field{min-width:160px}.project-roles-modal__row-actions,.project-roles-modal__order-buttons{gap:6px}}.section-title{font-weight:700;color:#374151}.perm-grid{align-items:start}.roles-list::-webkit-scrollbar{width:8px;height:8px}.roles-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px}.roles-list::-webkit-scrollbar-track{background:transparent}.admin-dashboard{padding:0 24px 24px 0;display:flex;flex-direction:column;gap:20px;min-height:calc(100vh - var(--site-header-h))}.admin-dashboard__header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}.admin-dashboard__header-actions{display:flex;gap:8px}.admin-dashboard__header-actions--dual{gap:10px}.admin-dashboard__grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.admin-dashboard__grid--charts{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.admin-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:20px;box-shadow:0 10px 25px #0f172a14}.admin-card--metric{display:flex;flex-direction:column;gap:6px}.admin-card--interactive{cursor:pointer;text-align:left;transition:border-color .15s ease,box-shadow .15s ease}.admin-card--interactive:hover{border-color:var(--primary);box-shadow:0 12px 28px #0f172a1f}.admin-card--interactive:focus-visible{outline:none;box-shadow:var(--focus-ring)}.admin-card--column{display:flex;flex-direction:column;gap:12px}.admin-card__label{font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.admin-card__value{font-size:32px;font-weight:700;color:#0f172a}.admin-card__caption{color:var(--muted);font-size:13px}.admin-card__title{font-weight:600;margin-bottom:12px}.admin-users-list{display:flex;flex-direction:column;gap:8px;max-height:360px;overflow:auto}.admin-user-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px;border:1px solid var(--border);border-radius:12px;background:#fff;cursor:pointer;text-align:left}.admin-user-row:hover{border-color:var(--primary)}.admin-user-row.is-active{border-color:var(--primary);background:#eef2ff}.admin-user-row strong{display:block;font-size:14px}.admin-user-detail{display:flex;flex-direction:column;gap:16px}.admin-user-flag{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500}.admin-user-row-card{border:1px solid var(--border);border-radius:12px;padding:12px;background:#fff;display:flex;flex-direction:column;gap:8px}.admin-user-row-card.is-editing{border-color:var(--primary);background:#eef2ff}.admin-user-row__header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.admin-user-row__info{display:flex;flex-direction:column;gap:6px;flex:1}.admin-user-row__actions{display:flex;gap:8px}.admin-user-edit-btn{min-width:40px;display:inline-flex;align-items:center;justify-content:center}.admin-projects-stats{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;font-size:14px}.admin-projects-stats__metrics{display:flex;flex-wrap:wrap;gap:12px;color:#0f172a}.admin-projects-stats__metrics span{padding:4px 10px;border-radius:999px;background:#f1f5f9}.admin-projects-owner{display:flex;flex-direction:column;gap:2px}.admin-projects-plan{display:flex;flex-direction:column;gap:4px}.admin-projects-plan__limits{font-size:12px;color:#475569}.admin-user-row__editor{display:flex;flex-direction:column;gap:8px}.badge-ms{display:flex;flex-direction:column;gap:12px}.badge-ms__summary{min-height:42px}.badge-ms__chips{display:flex;gap:6px;flex-wrap:wrap}.badge-ms__panel{border:1px solid var(--border);border-radius:12px;padding:12px;background:#fff;display:flex;flex-direction:column;gap:8px}.badge-ms__list{max-height:220px;overflow:auto;display:flex;flex-direction:column;gap:6px}.badge-ms__item{display:flex;gap:12px;align-items:center;padding:8px;border-radius:8px;border:1px solid var(--border)}.badge-ms__item.is-checked{background:#eff6ff;border-color:var(--primary)}.admin-table-wrapper{overflow:auto;border-radius:12px;border:1px solid var(--border)}.admin-table{width:100%;border-collapse:collapse;background:#fff}.admin-table th,.admin-table td{padding:10px 12px;border-bottom:1px solid var(--border);text-align:left;font-size:14px}.admin-table th{background:#f8fafc;text-transform:uppercase;font-size:12px;letter-spacing:.05em;color:var(--muted)}.admin-table__actions{width:60px;text-align:right}.admin-modal{max-width:520px}.admin-modal__body{display:flex;flex-direction:column;gap:16px;padding-bottom:8px}.admin-modal__section{margin:10px 0}.admin-modal__actions{display:flex;gap:8px;justify-content:flex-end;padding-top:8px;border-top:1px solid var(--border)}.admin-user-edit label{display:flex;flex-direction:column;gap:4px;font-weight:600;font-size:13px;margin-bottom:12px}.admin-user-edit label.admin-user-switch{flex-direction:row;align-items:center;gap:10px}.admin-user-edit label span{line-height:1.4}.admin-user-edit .input{padding-top:12px;padding-bottom:12px}.admin-user-switch{display:flex;align-items:center;gap:10px;padding:4px 0;font-weight:600}.switch{appearance:none;width:44px;height:24px;border-radius:999px;background:#cbd5e1;position:relative;cursor:pointer;transition:background .2s ease;border:1px solid transparent}.switch:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .2s ease}.switch:checked{background:#3b82f6}.switch:checked:after{transform:translate(20px)}.admin-badge-grid{display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));max-height:260px;overflow:auto;padding:4px 0}.admin-bar-row{display:grid;grid-template-columns:1fr minmax(120px,2fr) min-content;gap:8px;align-items:center;margin-bottom:10px}.admin-bar-row:last-child{margin-bottom:0}.admin-bar-row__label{font-weight:500;min-width:0}.admin-bar-row__chart{background:#e2e8f0;border-radius:999px;overflow:hidden;height:10px}.admin-bar-row__fill{height:100%;border-radius:999px}.admin-bar-row__value{font-variant-numeric:tabular-nums;font-weight:600}.admin-ranked-row{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.admin-ranked-row:last-child{border-bottom:none;padding-bottom:0}.admin-ranked-row:first-child{padding-top:0}.admin-ranked-row__index{width:28px;height:28px;border-radius:8px;background:#eff6ff;color:#1d4ed8;display:flex;align-items:center;justify-content:center;font-weight:600}.admin-ranked-row__content{display:grid;gap:8px;flex:1}.admin-ranked-row__col-label{font-size:12px;text-transform:uppercase;color:var(--muted)}.admin-ranked-row__col-value{font-weight:600}.admin-badge-form{display:flex;flex-direction:column;gap:8px}.admin-badge-form--inline{flex-direction:row;gap:8px;align-items:center}.admin-badge-form--inline .input{flex:1}.admin-badge-form__colors{display:flex;gap:12px;flex-wrap:wrap;font-size:12px;color:var(--muted)}.admin-badge-form__colors label{display:flex;flex-direction:column;gap:4px;font-weight:600}.admin-badge-list{display:flex;flex-direction:column;gap:8px;max-height:320px;overflow:auto}.admin-badge-item{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:12px;border:1px solid var(--border);border-radius:12px;background:#fff}.admin-badge-assignment{display:flex;flex-direction:column;gap:12px}.admin-badge-assignment__user{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.admin-badge-assignment__list{display:flex;flex-direction:column;gap:8px;max-height:240px;overflow:auto}.admin-badge-checkbox{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:8px 12px;border:1px solid var(--border);border-radius:10px;background:#fff}.admin-badge-checkbox.is-checked{border-color:var(--primary);background:#eff6ff}.admin-badge-checkbox input{margin-top:0}.admin-chip{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#dc2626;color:#fff;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:2px 8px;font-size:11px;line-height:1.1}.admin-chip--xs{font-size:9px;padding:3px 6px}.alert{border-radius:12px;padding:12px 16px;border:1px solid transparent;font-weight:500}.alert--error{background:#fee2e2;border-color:#fecaca;color:#991b1b}@media(max-width:768px){.admin-bar-row{grid-template-columns:1fr minmax(80px,1.5fr) min-content}.admin-dashboard{padding:12px}}.sidebar__admin-entry{margin:16px 0;padding:12px;border:1px solid rgba(79,70,229,.25);border-radius:12px;background:#4f46e514}.sidebar__admin-entry button{width:100%;justify-content:center}input[type=color]{border-radius:50%;width:28px;height:28px;padding:0;border:none;cursor:pointer;background:none}input[type=color]:focus-visible{outline:none;box-shadow:var(--focus-ring)}input[type=color]:disabled{opacity:.6;cursor:not-allowed}input[type=color]::-webkit-color-swatch-wrapper{padding:0;border-radius:50%}input[type=color]::-webkit-color-swatch{border-radius:50%;border:none;width:100%;height:100%}input[type=color]::-moz-color-swatch{border-radius:50%;border:none;width:100%;height:100%}input::-webkit-contacts-auto-fill-button,input::-webkit-credentials-auto-fill-button{visibility:hidden;pointer-events:none;position:absolute;right:0;display:none}.tree__boards{max-height:320px;overflow-y:auto;padding:6px;background:#fff;border-top:1px solid var(--border);width:100%}.tree__boards::-webkit-scrollbar{width:8px}.tree__boards::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px}.tree__boards::-webkit-scrollbar-track{background:transparent}.tree__board{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;background:transparent;border:1px solid transparent;cursor:pointer;color:inherit;text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease,transform .04s ease,color .15s ease}.tree__board{width:100%}.sidebar__skeletons{display:grid;gap:6px;width:100%}.tree__board--skeleton{border:1px dashed rgba(15,23,42,.15);pointer-events:none}.tree__board--skeleton .skeleton-circle,.tree__board--skeleton .skeleton-line{background:#0f172a1a}.app-shell.is-collapsed .tree__board{padding:8px 6px;gap:8px;border-radius:8px;background:transparent;border:1px solid transparent;cursor:pointer;color:inherit;text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease,transform .04s ease,color .15s ease;width:44px;height:46px}.app-shell.is-collapsed .tree__board.is-active{background:#eef2ff;border-color:#c7d2fe;color:#1e293b;box-shadow:inset 0 0 0 2px #6366f159}.app-shell.is-collapsed .proj-badge{width:100%;height:100%}.projects-list .proj-badge{width:22px;height:22px}.tree__board:hover{background:#f8fafc;border-color:var(--border)}.tree__board:active{transform:translateY(1px)}.tree__board:focus-visible{outline:none;box-shadow:var(--focus-ring);background:#fff}.tree__board.is-active{background:#eef2ff;border-color:#c7d2fe;color:#1e293b;font-weight:600;box-shadow:inset 3px 0 0 var(--primary)}.app-shell.is-collapsed .sidebar__logo{display:none}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:#e5e7eb;color:#374151;border:1px solid var(--border);overflow:hidden;-webkit-user-select:none;user-select:none;position:relative}.avatar--admin{border-color:#dc2626;box-shadow:0 8px 20px #dc262659}.avatar img{display:block;width:100%;height:100%;object-fit:cover}.avatar__initials{font-weight:700}.avatar--xs{width:22px;height:22px;font-size:10px}.avatar--sm{width:28px;height:28px;font-size:12px}.avatar--md{width:36px;height:36px;font-size:14px}.avatar--lg{width:112px;height:112px;font-size:28px}.task__assignees{display:inline-flex;align-items:center;gap:6px}.task__assignee-btn{background:transparent;border:none;padding:0;line-height:0;cursor:pointer;border-radius:999px;display:inline-flex}.task__assignee-btn:focus-visible{outline:none;box-shadow:0 0 0 2px #6366f173}.task__assignee-btn:hover .avatar{box-shadow:0 0 0 2px #0f172a26}.profile-avatar{position:relative;display:inline-block}.profile-avatar__edit{position:absolute;right:-6px;bottom:-6px;width:40px;height:40px;border-radius:999px;background:var(--primary);color:#fff;border:2px solid #fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 10px #00000026}.profile-avatar__edit:hover{background:var(--primary-hover)}.profile-avatar__edit:disabled{opacity:.6;cursor:not-allowed}.profile__name{font-weight:700;font-size:20px}.profile__email{color:var(--muted);font-size:14px}.hidden-file-input{display:none}.profile-page{max-width:820px;margin:24px auto 40px;display:flex;flex-direction:column;gap:20px;padding:0 16px}.profile-summary{display:flex;gap:20px;padding:24px;border-radius:24px;background:var(--card);border:1px solid var(--border);box-shadow:0 20px 45px #0f172a14;flex-wrap:wrap}.profile-summary__avatar{position:relative}.profile-summary__body{flex:1;min-width:220px;display:flex;flex-direction:column;gap:14px}.profile-summary__heading{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.profile-summary__heading h2{margin:0;font-size:28px}.profile-summary__actions{display:flex;gap:8px;flex-wrap:wrap}.profile-summary__body .chip-button{font-size:13px}.profile-widgets{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.profile-widget{background:#f8fafc;border:1px solid rgba(148,163,184,.35);border-radius:18px;padding:16px;display:flex;flex-direction:column;gap:4px}.profile-widget span{text-transform:uppercase;font-size:12px;letter-spacing:.05em;color:#94a3b8}.profile-widget strong{font-size:20px;color:#0f172a}.profile-widget--primary{background:#e0f2ff;border:1px solid rgba(59,130,246,.35);color:#1d4ed8;box-shadow:0 12px 24px #3b82f626}.profile-widget--primary span,.profile-widget--primary small{color:#1e3a8a}.profile-widget--primary strong{color:#1d4ed8}.profile-footer-actions{display:flex;justify-content:flex-end}.profile-stat{background:#f8fafc;border:1px solid rgba(148,163,184,.4);border-radius:18px;padding:16px;display:flex;flex-direction:column;gap:6px}.profile-stat span{font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:#94a3b8}.profile-stat strong{font-size:22px;color:#0f172a}.profile-stat--accent{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;box-shadow:0 15px 35px #2563eb59}.profile-stat--accent span,.profile-stat--accent small{color:#ffffffd9}.profile-stat--accent strong{color:#fff}.chip-button{border:1px solid var(--border);background:#fff;border-radius:999px;padding:4px 12px;font-size:13px;cursor:pointer;transition:.2s}.chip-button:hover{border-color:var(--primary);color:var(--primary)}.chip-button--ghost{background:transparent;border-color:#94a3b899}.chip-button--ghost:hover{border-color:var(--primary);color:var(--primary)}.chip-button--danger{background:#fee2e2;border-color:#fca5a5;color:#b91c1c}.chip-button--danger:hover{background:#fecaca;border-color:#f87171;color:#991b1b}.profile-summary__heading{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.profile-summary__actions{display:flex;gap:10px;flex-wrap:wrap}.profile-summary__meta{color:var(--muted)}.profile-summary__body .profile-summary__heading h2{margin:0}.profile-summary__body .user-badges{margin-top:6px}.profile-card__edit{display:flex;flex-direction:column;gap:12px}.profile-card__edit .field{width:100%}.profile-card__edit-actions{display:flex;gap:10px;flex-wrap:wrap}.profile-card--skeleton{display:flex}.profile-card--skeleton .skeleton-line,.profile-card--skeleton .skeleton-circle{background:#94a3b833}.user-ms{position:relative;width:100%}.user-ms__control{display:block;width:100%;text-align:left;cursor:pointer;min-height:38px}.user-ms__chips{display:flex;flex-wrap:wrap;gap:6px}.chip{display:inline-flex;align-items:center;gap:6px;background:#eef2f7;border:1px solid var(--border);padding:2px 5px 2px 2px;border-radius:999px;font-size:12px}.chip__remove{background:transparent;border:none;cursor:pointer;padding:0 4px;font-size:14px;color:#64748b}.chip__remove:hover{color:#0f172a}.user-ms__dropdown{position:absolute;z-index:60;top:calc(100% + 6px);left:0;right:0;background:var(--card);border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 30px #00000026;overflow:hidden}.user-ms__search{padding:8px;border-bottom:1px solid var(--border)}.user-ms__list{max-height:240px;overflow:auto;display:grid}.user-ms__item{display:flex;align-items:center;gap:10px;padding:8px 10px;background:transparent;border:none;cursor:pointer;text-align:left}.user-ms__item:hover{background:#f8fafc}.user-ms__item.is-checked{background:#eef2ff}.user-ms__meta{display:grid}.user-ms__name{font-weight:600}.user-ms__email{font-size:12px;color:var(--muted)}.user-ms__check{margin-left:auto;font-weight:700;color:var(--primary)}.user-ms__actions{padding:8px;border-top:1px solid var(--border);display:flex;justify-content:flex-end}.mini-profile{position:fixed;background:var(--card, #fff);border:1px solid var(--border);border-radius:16px;box-shadow:0 30px 60px #0f172a33;padding:20px;z-index:1200;width:min(320px,calc(100vw - 24px))}.mini-profile--admin{border-color:#dc2626;box-shadow:0 30px 60px #dc262640}.mini-profile__close{position:absolute;top:8px;right:10px;border:none;background:transparent;font-size:22px;cursor:pointer;color:#64748b}.mini-profile__close:hover{color:#0f172a}.mini-profile__avatar{display:flex;justify-content:center;margin-bottom:12px}.mini-profile__name{text-align:center;font-weight:700;font-size:18px}.mini-profile__email{text-align:center;color:var(--muted);font-size:13px;margin-bottom:12px;word-break:break-all}.mini-profile__section{border-top:1px solid var(--border);padding-top:12px;margin-top:12px;display:grid;gap:10px}.mini-profile__section-title{font-weight:600}.mini-profile__roles-list{display:grid;gap:8px;max-height:220px;overflow:auto;padding-right:4px}.mini-profile__role{display:flex;align-items:center;gap:8px;font-size:14px}.mini-profile__role-dot{width:10px;height:10px;border-radius:999px;display:inline-block;margin-right:6px}.mini-profile__role-dot--inline{margin-right:4px;width:8px;height:8px}.mini-profile__role-badges{display:flex;flex-wrap:wrap;gap:6px}.profile-menu{position:fixed;z-index:90;min-width:180px;background:var(--card);border:1px solid var(--border);border-radius:10px;box-shadow:0 14px 40px #0f172a38;padding:6px;display:grid;gap:4px}.profile-menu__item{width:100%;background:transparent;border:none;text-align:left;padding:8px 10px;border-radius:8px;font-size:14px;font-weight:500;color:var(--text);cursor:pointer;display:flex;align-items:center;gap:8px}.profile-menu__item:hover{background:#eef2ff}.profile-menu__item--danger{color:#dc2626}.profile-menu__item--danger:hover{background:#fee2e2;color:#991b1b}.user-menu{position:relative}.user-chip{display:inline-flex;align-items:center;gap:8px;background:transparent;border:1px solid var(--border);color:var(--text);padding:4px 8px 4px 4px;border-radius:999px;cursor:pointer}.app-shell.is-collapsed .tree__board>span:nth-child(2){display:none!important}.app-shell.is-collapsed .tree__board .kebab-anchor,.app-shell.is-collapsed .tree__board .kebab-btn,.app-shell.is-collapsed .tree__board button,.app-shell.is-collapsed .tree__board .proj-actions{display:none!important}.dropdown__item:hover{background:#f1f5f9}.dtp{position:relative;width:100%}.dtp__control{display:flex;align-items:center;justify-content:space-between;width:100%;cursor:pointer}.dtp__icon{margin-left:8px;opacity:.6}.dtp__popup{position:absolute;z-index:60;top:calc(100% + 6px);left:0;background:var(--card);border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 30px #00000026;width:min(320px,92vw);padding:10px}.dtp__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.dtp__nav{background:transparent;border:1px solid var(--border);border-radius:6px;padding:2px 8px;cursor:pointer}.dtp__nav:hover{background:#f3f4f6}.dtp__month{font-weight:700;text-transform:capitalize}.dtp__weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin:6px 0;color:var(--muted);font-size:12px}.dtp__wd{text-align:center}.dtp__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.dtp__day{height:32px;border:1px solid var(--border);background:#fff;border-radius:8px;cursor:pointer}.dtp__day:hover{background:#eef2f7}.dtp__day.is-today{background:#e7f0ff;border-color:#c9ddff}.dtp__day.is-selected{background:var(--primary);color:#fff;border-color:var(--primary)}.dtp__day.is-empty{visibility:hidden}.dtp__time{display:flex;align-items:flex-end;flex-wrap:wrap;gap:8px;margin-top:8px}.task-sidepanel__subtasks{display:flex;flex-direction:column;gap:6px;margin-bottom:6px}.task-sidepanel__subtasks-empty{font-size:14px;padding:6px 0}.task-sidepanel__subtask{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:10px;position:relative;cursor:grab;background:var(--bg)}.task-sidepanel__subtask.is-dragging{opacity:.65}.task-sidepanel__subtask.is-drop-before:before,.task-sidepanel__subtask.is-drop-after:after{content:"";position:absolute;left:0;right:0;height:2px;border-radius:999px;background:var(--primary)}.task-sidepanel__subtask.is-drop-before:before{top:-3px}.task-sidepanel__subtask.is-drop-after:after{bottom:-3px}.task-sidepanel__subtask-handle{width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:12px;color:#9ca3af;-webkit-user-select:none;user-select:none;cursor:inherit}.task-sidepanel__subtask-handle:active{cursor:grabbing}.task-sidepanel__subtask-toggle{display:flex;align-items:center;gap:8px;border:none;background:transparent;padding:4px 0;text-align:left;cursor:pointer;color:inherit}.task-sidepanel__subtask-toggle:disabled{cursor:default;opacity:.6}.task-sidepanel__subtask-check{width:18px;height:18px;border-radius:5px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--primary);background:#fff}.task-sidepanel__subtask-check.is-checked{background:var(--primary);border-color:var(--primary);color:#fff}.task-sidepanel__subtask-title{flex:1 1 auto;font-size:14px;color:var(--text)}.task-sidepanel__subtask.is-completed .task-sidepanel__subtask-title{text-decoration:line-through;color:var(--muted)}.task-sidepanel__subtask-remove{border:none;background:transparent;color:#9ca3af;width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:18px}.task-sidepanel__subtask-remove:hover{background:#0000000d;color:#111827}.task-sidepanel__subtask-remove:disabled{opacity:.4;cursor:default}.task-sidepanel__subtask-add{display:flex;gap:8px;align-items:center}.task-sidepanel__subtask-add .input{flex:1 1 auto}.task-sidepanel__content{flex:1 1 auto;padding:16px;display:flex;flex-direction:column;gap:10px;overflow-y:auto}.tree__board>span:nth-child(2){display:inline-block;white-space:nowrap;overflow:hidden;will-change:width;transition:width .25s ease,padding .2s ease}.project-sidebar{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:8px;box-shadow:0 2px 6px #0000000f;top:10px;width:260px;overflow:hidden;will-change:width;transition:width .25s ease,padding .2s ease;height:max-content}.projects-list{width:100%;padding:16px}.project-sidebar.is-collapsed{width:62px;padding:8px}.project-sidebar__header{display:flex;align-items:center;gap:8px;justify-content:flex-start}.project-sidebar__toggle{flex:0 0 auto}.project-layout.no-board-selected .project-sidebar__toggle{display:none}.project-sidebar .board-selector__add-btn{flex:1 1 auto;height:44px;display:inline-flex;align-items:center;justify-content:center;font-weight:600;text-align:center;background:var(--primary);color:#fff;border-color:var(--primary);font-size:16px}.project-sidebar .board-selector__add-btn:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.project-sidebar .board-selector__add-btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.project-sidebar.is-collapsed .board-selector__add-btn{display:none}.project-board-list.project-board-list--mini{align-content:start;grid-auto-rows:min-content}.list__item:hover{background:#f8fafc}.list__item strong{font-weight:700}.list__item .badge{margin-left:auto}.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:12px;box-shadow:0 2px 6px #0000000f}.sidebar__nav{width:100%;flex:1 1 auto;display:flex;flex-direction:column;align-content:flex-start;justify-content:flex-start;align-items:center}.sidebar__top{display:flex;align-items:center;width:100%;justify-content:space-between}.app-shell.is-collapsed .sidebar__top{justify-content:center}.site-header{display:none}.project-selector__add-bottom{padding:3px;border-radius:8px}.mobile-projects{display:none}.skeleton-line,.skeleton-circle{position:relative;overflow:hidden;background:#00000014}.skeleton-line:after,.skeleton-circle:after{content:"";position:absolute;top:0;left:-150%;width:150%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.1) 50%,transparent 100%);animation:skeleton-shimmer 1.6s infinite}.kanban-skeletons{display:flex;gap:var(--kanban-gap);width:100%;box-sizing:border-box;overflow-x:auto;scrollbar-width:none}.kanban-skeletons::-webkit-scrollbar{display:none}.kanban-skeleton{width:280px;min-width:280px;max-width:320px;flex:0 0 auto;border-radius:var(--radius);background:var(--card);border:1px solid var(--border);box-shadow:0 2px 6px #0000000f;position:relative;overflow:hidden;transition:height 1.2s ease-in-out,transform .3s ease,opacity .3s ease;animation:skeleton-pulse 5s ease-in-out infinite}.kanban-skeleton:before{content:"";position:absolute;inset:0;background-size:200% 100%;pointer-events:none;will-change:background-position}@keyframes skeleton-pulse{0%,to{transform:translateY(0);opacity:.95}50%{transform:translateY(-4px);opacity:1}}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media(max-width:640px){.kanban-skeletons{gap:10px;padding:12px}.kanban-skeleton{width:240px;min-width:240px;flex:0 0 auto}}@media(max-width:768px){.kanban__column{--kanban-column-max-h: calc(100vh - var(--site-header-h) - 80px)}}@media(max-width:640px){.kanban__column{height:auto;max-height:none}}@media(orientation:portrait){.route-fade{padding-top:calc(var(--site-header-h) + 16px)}.site-header{display:flex}.app-shell{--sidebar-w: 0px}.app-sidebar{display:none!important}.site-header{padding-left:5px!important}.app-content{padding-left:16px!important}.sidebar__toggle{display:none!important}.app-content{padding-top:0;padding-right:16px}.non-mobile{display:none!important}.mobile-projects{display:block}.mobile-projects .board-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.mobile-projects .board-tile{min-height:64px;padding:10px;display:flex;align-items:center}.project-layout.no-board-selected .project-sidebar{position:fixed;top:var(--site-header-h);margin-top:16px;left:16px;right:16px;bottom:0;width:auto;padding:16px;background:var(--card);border-right:none;overflow:auto}.project-layout.no-board-selected,.project-layout.no-board-selected .route-fade{height:100%;min-height:100%}.project-layout.no-board-selected .app-content,.project-layout.no-board-selected .route-fade{margin-left:0!important}}.badge-ms__list{padding:10px 8px}.route-fade{height:100%}.project-week-calendar{width:100%;min-width:0;min-height:100%;height:100%;flex:1 1 auto;padding:4px 0 0;display:flex;flex-direction:column;gap:18px}.project-week-calendar__header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.project-week-calendar__header h3{margin:0;font-size:1.05rem}.project-week-calendar__header p{margin:4px 0 0;color:var(--text-muted);font-size:.9rem}.project-week-calendar__note{display:block;font-size:.8rem;color:var(--warning, #b45309)}.project-week-calendar__controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-weight:600}.week-calendar__nav-btn{border:1px solid rgba(148,163,184,.6);background:#ffffffe6;color:var(--text);padding:6px 14px;border-radius:999px;font-size:.85rem;cursor:pointer;transition:border-color .18s ease,color .18s ease,background .18s ease}.week-calendar__nav-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.week-calendar__nav-btn:disabled{opacity:.6;cursor:default}.week-calendar__range{font-weight:600;color:var(--text);min-width:180px;text-align:center}.project-week-calendar__kanban{position:relative;flex:1 1 auto;min-height:0;display:flex;flex-direction:column}.project-week-calendar__viewport{flex:1 1 auto;min-height:0;overflow-x:auto;padding-bottom:20px;display:flex;align-items:stretch;position:relative}.project-week-calendar__kanban.is-loading .project-week-calendar__viewport{pointer-events:none}.project-week-calendar__track{display:flex;align-items:stretch;gap:14px;min-height:100%;flex:1 1 auto}.project-week-calendar__kanban .kanban-skeletons{padding:6px 0 12px;flex:1 1 auto;width:auto;gap:14px}.project-week-calendar__kanban .kanban-skeletons .kanban-skeleton{flex:0 0 300px;min-width:300px;border-radius:16px}.week-kanban__column{flex:0 0 300px;max-height:100%;height:max-content;background:var(--card);border-radius:16px;border:1px solid var(--border);display:flex;flex-direction:column;gap:8px;scroll-snap-align:start;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}.week-kanban__column.is-today{border-color:#2563eb80;box-shadow:0 6px 20px #2563eb1f}.week-kanban__column.is-past{opacity:.92}.week-kanban__column-header{display:flex;justify-content:space-between;gap:8px;align-items:flex-start;padding:12px 14px;border-bottom:1px solid var(--border)}.week-kanban__column-day{font-weight:700;letter-spacing:.04em;text-transform:uppercase;font-size:1rem;color:var(--text-muted)}.week-kanban__column-date{font-size:.95rem;font-weight:600;color:var(--text)}.week-kanban__add-task{margin:0 12px;padding:8px 10px;border-radius:10px;border:1px dashed var(--border);background:#fffc;color:var(--text);font-size:.9rem;font-weight:600;cursor:pointer;transition:border-color .2s ease,color .2s ease,background .2s ease}.week-kanban__add-task:hover{border-color:var(--primary);color:var(--primary);background:#fff}.week-kanban__add-task:focus-visible{outline:none;box-shadow:0 0 0 2px #3b82f659}.week-kanban__pill{background:#e2e8f0cc;color:var(--text);font-size:.74rem;border-radius:999px;padding:2px 10px;font-weight:600}.week-kanban__tasks{list-style:none;margin:0;padding:0 12px 12px;display:flex;flex-direction:column;gap:10px;overflow-y:auto;flex:1 1 auto}.project-week-calendar .week-kanban__tasks .task,.project-week-calendar .week-kanban__tasks .task:active{cursor:pointer}.week-kanban__tasks::-webkit-scrollbar{width:6px}.week-kanban__tasks::-webkit-scrollbar-thumb{background:#94a3b873;border-radius:999px}.week-kanban__tasks::-webkit-scrollbar-track{background:transparent}.week-kanban__empty-spacer{flex:1 1 auto;padding-bottom:0}.week-kanban__empty{border-radius:14px;padding:16px;text-align:center;color:var(--text-muted);font-size:.85rem;flex:1 1 auto;display:flex;justify-content:center;align-content:center;align-items:center}.project-week-calendar__error{background:#f8717126;border:1px solid rgba(248,113,113,.45);color:#b91c1c;border-radius:12px;padding:10px 12px;font-size:.9rem}@media(max-width:1024px){.project-week-calendar{display:none}}
