.dashboard-wrapper{display:flex;min-height:100vh;background:var(--color-bg)}.dashboard-main{flex:1;overflow-y:auto;min-width:0}.dashboard-content{max-width:1200px;margin:0 auto;padding:2rem}.dashboard-content:has(.kanban-page){max-width:100%;padding:1.5rem}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem;color:var(--color-muted)}.dashboard-loading-spinner{width:32px;height:32px;border:3px solid var(--color-line);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.dashboard-sidebar{display:flex;flex-direction:column;background:var(--color-card);border-right:1px solid var(--color-line);transition:width .2s cubic-bezier(.4,0,.2,1);overflow:hidden;flex-shrink:0}.sidebar-header{justify-content:space-between;padding:1.25rem 1rem;border-bottom:1px solid var(--color-line);min-height:64px}.sidebar-header,.sidebar-logo{display:flex;align-items:center}.sidebar-logo{gap:.75rem;text-decoration:none;color:var(--color-text)}.sidebar-logo-img{width:32px;height:32px;border-radius:0;object-fit:contain}.sidebar-logo-icon{width:32px;height:32px;background:var(--color-primary);color:white;border-radius:var(--radius-sm);display:flex;align-items:center;font-weight:700;font-size:14px}.sidebar-logo-collapsed,.sidebar-logo-icon{justify-content:center}.sidebar-logo-text{font-weight:600;font-size:15px}.sidebar-toggle{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--color-muted);border-radius:6px;cursor:pointer}.sidebar-toggle:hover{background:var(--color-soft);color:var(--color-text)}.sidebar-command-trigger{display:flex;align-items:center;gap:.5rem;margin:.75rem;padding:.5rem .75rem;border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-soft);color:var(--color-muted);font-size:13px;cursor:pointer;transition:all .15s}.sidebar-command-trigger:hover{border-color:var(--color-primary);color:var(--color-primary)}.sidebar-command-trigger kbd{margin-left:auto;font-size:11px;background:var(--color-card);border:1px solid var(--color-line);border-radius:4px;padding:1px 5px;font-family:inherit}.sidebar-nav{flex:1;padding:.5rem;display:flex;flex-direction:column;gap:2px}.sidebar-nav-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;border-radius:var(--radius-sm);text-decoration:none;color:var(--color-muted);font-size:14px;font-weight:500;transition:all .15s}.sidebar-nav-item:hover{background:var(--color-soft);color:var(--color-text)}.sidebar-nav-item.active{background:rgba(4,95,116,.08);color:var(--color-primary)}.sidebar-footer{padding:.75rem;border-top:1px solid var(--color-line)}.sidebar-theme-toggle{display:flex;align-items:center;gap:.75rem;width:100%;padding:.5rem;border:none;background:none;color:var(--color-muted);font-size:13px;cursor:pointer;border-radius:var(--radius-sm);transition:all .15s;margin-bottom:.25rem}.sidebar-theme-toggle:hover{background:var(--color-soft);color:var(--color-text)}.sidebar-user{display:flex;align-items:center;gap:.75rem;padding:.5rem}.sidebar-user-avatar{width:32px;height:32px;border-radius:50%;background:var(--color-primary);color:white;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;overflow:hidden;flex-shrink:0}.sidebar-user-avatar img{width:100%;height:100%;object-fit:cover}.sidebar-user-info{display:flex;flex-direction:column;min-width:0}.sidebar-user-name{font-size:13px;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:11px;color:var(--color-muted);text-transform:capitalize}.sidebar-logout-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:6px;background:transparent;color:var(--color-muted);cursor:pointer;flex-shrink:0;margin-left:auto;transition:all .15s}.sidebar-logout-btn:hover{background:var(--color-line);color:var(--color-fg)}.notif-bell-btn,.notif-bell-wrapper{position:relative}.notif-bell-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:6px;background:transparent;color:var(--color-muted);cursor:pointer;transition:all .15s}.notif-bell-btn:hover{background:var(--color-soft);color:var(--color-text)}.notif-bell-badge{position:absolute;top:2px;right:1px;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;line-height:16px;text-align:center;color:#fff;background:var(--color-danger,#ef4444);border-radius:99px;pointer-events:none}.notif-panel{position:fixed;top:56px;left:12px;width:340px;max-height:420px;background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius);box-shadow:0 8px 24px rgba(0,0,0,.12);z-index:9100;display:flex;flex-direction:column;overflow:hidden}.notif-panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--color-line)}.notif-panel-title{font-size:13px;font-weight:600;color:var(--color-text)}.notif-panel-clear{font-size:12px;color:var(--color-primary);background:none;border:none;cursor:pointer;padding:2px 6px;border-radius:4px;transition:background .15s}.notif-panel-clear:hover{background:var(--color-soft)}.notif-panel-body{flex:1;overflow-y:auto}.notif-panel-empty{padding:2rem 1rem;text-align:center;font-size:13px;color:var(--color-muted)}.notif-item{display:flex;align-items:flex-start;gap:8px;padding:10px 14px;border-bottom:1px solid var(--color-line);transition:background .15s}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--color-soft)}.notif-item-content{flex:1;min-width:0;cursor:pointer}.notif-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}.notif-item-author{font-size:12px;font-weight:600;color:var(--color-text)}.notif-item-time{font-size:11px;color:var(--color-muted);flex-shrink:0}.notif-item-task{font-size:12px;font-weight:500;color:var(--color-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:1px}.notif-item-customer{font-size:11px;color:var(--color-muted);margin-bottom:2px}.notif-item-text{font-size:12px;color:var(--color-muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notif-item-dismiss{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border:none;border-radius:4px;background:transparent;color:var(--color-muted);cursor:pointer;font-size:14px;margin-top:2px;transition:all .15s}.notif-item-dismiss:hover{background:var(--color-ok,#22c55e);color:#fff}.command-bar-overlay{position:fixed;inset:0;background:rgba(14,44,51,.4);backdrop-filter:blur(4px);z-index:9999;display:flex;align-items:flex-start;justify-content:center;padding-top:20vh}.command-bar-container{width:100%;max-width:560px;background:var(--color-card);border-radius:var(--radius);box-shadow:0 24px 48px rgba(0,0,0,.15),0 0 0 1px rgba(4,95,116,.1);overflow:hidden}.command-bar-input-wrapper{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border-bottom:1px solid var(--color-line)}.command-bar-search-icon{color:var(--color-muted);flex-shrink:0}.command-bar-input{flex:1;border:none;outline:none;background:transparent;font-size:15px;color:var(--color-text);font-family:var(--font-sans)}.command-bar-input::placeholder{color:var(--color-muted)}.command-bar-shortcut{font-size:11px;background:var(--color-soft);border:1px solid var(--color-line);border-radius:4px;padding:2px 6px;color:var(--color-muted);font-family:inherit;flex-shrink:0}.command-bar-list{max-height:320px;overflow-y:auto;padding:.5rem}.command-bar-empty{padding:2rem;text-align:center;color:var(--color-muted);font-size:14px}.command-bar-group{padding-bottom:.25rem}.command-bar-group [cmdk-group-heading]{padding:.5rem .75rem .25rem;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted)}.command-bar-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;transition:background .1s}.command-bar-item:hover,.command-bar-item[aria-selected=true],.command-bar-item[data-selected=true]{background:var(--color-soft)}.command-bar-item-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;background:rgba(4,95,116,.08);color:var(--color-primary);flex-shrink:0}.command-bar-item-label{flex:1;color:var(--color-text);font-weight:500}.command-bar-item-module{font-size:11px;color:var(--color-muted)}.dashboard-home-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.dashboard-home-title{font-size:24px;font-weight:600;color:var(--color-text);margin:0}.dashboard-home-subtitle{font-size:14px;color:var(--color-muted);margin:.25rem 0 0}.dashboard-home-action{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-card);color:var(--color-muted);font-size:13px;cursor:pointer}.dashboard-home-action:hover{border-color:var(--color-primary);color:var(--color-primary)}.dashboard-home-action kbd{font-size:11px;background:var(--color-soft);border:1px solid var(--color-line);border-radius:4px;padding:1px 5px;font-family:inherit}.dashboard-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius)}.stat-card-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card-content{display:flex;flex-direction:column;min-width:0}.stat-card-label{font-size:12px;color:var(--color-muted);font-weight:500}.stat-card-value{font-size:24px;font-weight:700;color:var(--color-text);line-height:1.2}.stat-card-trend{font-size:12px;color:var(--color-muted);margin-top:2px}.stat-card-link{cursor:pointer;transition:border-color .15s,box-shadow .15s}.stat-card-link:hover{border-color:var(--color-primary);box-shadow:0 2px 8px rgba(4,95,116,.08)}.dashboard-section{margin-bottom:2rem}.dashboard-section-title{font-size:16px;font-weight:600;color:var(--color-text);margin:0 0 1rem}.dashboard-quick-actions{display:flex;gap:.75rem}.quick-action-card{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-sm);text-decoration:none;color:var(--color-text);font-size:14px;font-weight:500;transition:all .15s}.quick-action-card:hover{border-color:var(--color-primary);color:var(--color-primary);box-shadow:0 2px 8px rgba(4,95,116,.08)}.dashboard-empty-state{padding:3rem;text-align:center;background:var(--color-card);border:1px dashed var(--color-line);border-radius:var(--radius);color:var(--color-muted);font-size:14px}.dashboard-empty-state kbd{display:inline-block;font-size:11px;background:var(--color-soft);border:1px solid var(--color-line);border-radius:4px;padding:1px 5px;font-family:inherit}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg);padding:2rem}.login-card{width:100%;max-width:380px;background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius);padding:2.5rem 2rem;text-align:center}.login-logo{display:flex;flex-direction:column;align-items:center;margin-bottom:2rem}.login-logo img{display:block;margin-bottom:1.25rem}.login-logo-icon{width:56px;height:56px;background:var(--color-primary);color:white;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:24px;margin:0 auto 1rem}.login-title{font-size:22px;font-weight:700;color:var(--color-text);margin:0}.login-subtitle{font-size:14px;color:var(--color-muted);margin:.25rem 0 0}.login-google-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.75rem;border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-card);font-size:14px;font-weight:500;color:var(--color-text);cursor:pointer;transition:all .15s}.login-google-btn:hover{border-color:var(--color-primary);box-shadow:0 2px 8px rgba(0,0,0,.06)}.login-google-btn:disabled{opacity:.6;cursor:wait}.login-hint{margin-top:1.5rem;font-size:12px;color:var(--color-muted)}.btn-primary{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:var(--color-primary);color:white;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;text-decoration:none;line-height:1.4}.btn-primary:hover{background:#034d5e}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:var(--color-card);color:var(--color-text);border:1px solid var(--color-line);border-radius:var(--radius-sm);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;text-decoration:none;line-height:1.4}.btn-secondary:hover{border-color:var(--color-primary);color:var(--color-primary)}.modal-overlay{position:fixed;inset:0;background:rgba(14,44,51,.45);backdrop-filter:blur(4px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:2rem}.modal-container{width:100%;max-width:520px;max-height:calc(100vh - 4rem);background:var(--color-card);border-radius:var(--radius);box-shadow:0 24px 48px rgba(0,0,0,.18);overflow-y:auto;overflow-x:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-line)}.modal-title{font-size:17px;font-weight:600;color:var(--color-text);margin:0}.modal-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--color-muted);border-radius:6px;cursor:pointer}.modal-close:hover{background:var(--color-soft);color:var(--color-text)}.modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding-top:.75rem}.modal-error{padding:.5rem .75rem;background:rgba(220,38,38,.08);color:var(--color-danger);border-radius:var(--radius-sm);font-size:13px;border:1px solid rgba(220,38,38,.15)}.form-group{display:flex;flex-direction:column;gap:.35rem;flex:1}.form-label{font-size:13px;font-weight:500;color:var(--color-muted)}.form-input{padding:.5rem .75rem;border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-bg);font-size:14px;color:var(--color-text);font-family:var(--font-sans);transition:border-color .15s}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(4,95,116,.1)}.form-textarea{padding:.5rem .75rem;border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-bg);font-size:14px;color:var(--color-text);font-family:var(--font-sans);resize:vertical;transition:border-color .15s}.form-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(4,95,116,.1)}.form-select{padding:.5rem .75rem;border-radius:var(--radius-sm);font-size:14px;font-family:var(--font-sans);cursor:pointer;transition:border-color .15s}.form-select:focus{outline:none;border-color:var(--color-primary)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.tasks-page{padding-bottom:2rem}.tasks-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.tasks-page-title{font-size:24px;font-weight:600;color:var(--color-text);margin:0}.tasks-page-subtitle{font-size:14px;color:var(--color-muted);margin:.25rem 0 0}.tasks-page-actions{display:flex;gap:.5rem}.tasks-filter-bar{display:flex;gap:.75rem;margin-bottom:1rem}.tasks-search-wrapper{flex:1;display:flex;align-items:center;gap:.5rem;padding:0 .75rem;background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-sm)}.tasks-search-icon{color:var(--color-muted);flex-shrink:0}.tasks-search-input{flex:1;border:none;outline:none;background:transparent;padding:.5rem 0;font-size:14px;color:var(--color-text);font-family:var(--font-sans)}.tasks-search-input::placeholder{color:var(--color-muted)}.tasks-filter-wrapper{display:flex;align-items:center;gap:.5rem;padding:0 .75rem;background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-sm);color:var(--color-muted)}.tasks-filter-select{border:none;outline:none;background:transparent;padding:.5rem 0;font-size:14px;color:var(--color-text);font-family:var(--font-sans);cursor:pointer}.task-filters{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.task-filter-avatars{display:flex;align-items:center;gap:4px}.task-filter-avatar{width:32px;height:32px;border-radius:50%;border:2px solid transparent;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s ease;position:relative;overflow:hidden;flex-shrink:0}.task-filter-avatar:hover{transform:scale(1.1);box-shadow:0 2px 8px rgba(0,0,0,.15)}.task-filter-avatar--active{border-color:var(--color-bg);box-shadow:0 0 0 2px var(--color-primary),0 2px 8px rgba(0,0,0,.15)}.task-filter-avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.task-filter-divider{width:1px;height:24px;background:var(--color-line);margin:0 4px;flex-shrink:0}.task-filter-chip-wrap{display:flex;align-items:center;gap:0;background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-sm);padding:0 .5rem;transition:border-color .15s}.task-filter-chip-wrap:focus-within{border-color:var(--color-primary)}.task-filter-icon{color:var(--color-muted);flex-shrink:0}.task-filter-select{border:none;outline:none;background:transparent;padding:.4rem .25rem;font-size:13px;color:var(--color-muted);font-family:var(--font-sans);cursor:pointer;max-width:170px}.task-filter-select--active{color:var(--color-text);font-weight:500}.task-filter-reset{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:var(--color-soft);color:var(--color-muted);cursor:pointer;border-radius:50%;transition:all .15s;flex-shrink:0}.task-filter-reset:hover{background:#FEE2E2;color:#DC2626}.tasks-list{display:flex;flex-direction:column;gap:2px;background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius);overflow:hidden}.tasks-loading{display:flex;align-items:center;justify-content:center;gap:.75rem}.tasks-empty,.tasks-loading{padding:3rem;color:var(--color-muted);font-size:14px}.tasks-empty{text-align:center}.task-card-list{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer;transition:background .1s}.task-card-list:hover{background:var(--color-soft)}.task-card-list:not(:last-child){border-bottom:1px solid var(--color-line)}.task-card-priority-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.task-card-list-content{flex:1;display:flex;align-items:center;gap:.5rem;min-width:0}.task-card-list-title{font-size:14px;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-card-tag{display:inline-block;background:color-mix(in srgb,var(--color-primary) 10%,transparent);color:var(--color-primary)}.task-card-customer-tag,.task-card-tag{padding:1px 6px;border-radius:4px;font-size:11px;font-weight:500;white-space:nowrap}.task-card-customer-tag{display:inline-flex;align-items:center;gap:.25rem;background:color-mix(in srgb,var(--color-accent) 12%,transparent);color:var(--color-accent)}.task-card-status-badge{display:inline-block;padding:2px 8px;border:1px solid;border-radius:12px;font-size:12px;font-weight:500;white-space:nowrap}.task-card-meta-item{display:flex;align-items:center;gap:3px;font-size:12px;color:var(--color-muted);white-space:nowrap}.task-card-overdue{color:var(--color-danger)!important}.task-card-chevron{color:var(--color-muted);flex-shrink:0}.task-card-group-bar{display:flex;align-items:center;gap:.375rem;margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--color-border);font-size:.7rem;color:var(--color-muted)}.task-card-group-bar svg{flex-shrink:0;opacity:.7}.task-card-group-bar span{white-space:nowrap}.task-card-group-progress{flex:1;height:4px;background:var(--color-border);border-radius:2px;overflow:hidden;min-width:30px}.task-card-group-progress-fill{height:100%;background:var(--color-ok);border-radius:2px;transition:width .3s ease}.task-card-kanban{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem;background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-sm);cursor:pointer;transition:box-shadow .15s,border-color .15s}.task-card-kanban:hover{border-color:var(--color-primary);box-shadow:0 2px 8px rgba(4,95,116,.08)}.task-card-grip{color:var(--color-muted);flex-shrink:0;margin-top:2px;cursor:grab}.task-card-kanban-content{flex:1;min-width:0}.task-card-kanban-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem}.task-card-kanban-title{font-size:13px;font-weight:500;color:var(--color-text);line-height:1.35}.task-card-kanban-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.kanban-page{padding-bottom:2rem}.kanban-board{display:flex;gap:.75rem;overflow-x:auto;padding-bottom:1rem;min-height:60vh}.kanban-column{flex:0 0 290px;display:flex;flex-direction:column;background:var(--color-soft);border-radius:var(--radius);max-height:calc(100vh - 200px);transition:flex-basis .2s ease}.kanban-column.kanban-column--collapsed{flex:0 0 44px;overflow:hidden;cursor:pointer}.kanban-column--collapsed .kanban-column-body{display:none}.kanban-column--collapsed .kanban-column-header{writing-mode:vertical-lr;text-orientation:mixed;padding:12px 10px;border-bottom:none;justify-content:flex-start;gap:8px;height:100%}.kanban-column--collapsed .kanban-collapse-btn{display:none}.kanban-collapse-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:none;border-radius:4px;background:transparent;color:var(--color-muted);cursor:pointer;flex-shrink:0;transition:all .15s;margin-left:auto}.kanban-collapse-btn:hover{background:var(--color-line);color:var(--color-text)}.kanban-column-header{display:flex;align-items:center;gap:.5rem;padding:.75rem;border-bottom:1px solid var(--color-line)}.kanban-column-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.kanban-column-title{font-size:13px;font-weight:600;color:var(--color-text);flex:1}.kanban-column-count{font-size:12px;font-weight:500;color:var(--color-muted);background:var(--color-card);border-radius:10px;padding:0 6px;min-width:20px;text-align:center}.kanban-column-body{flex:1;overflow-y:auto;padding:.5rem;display:flex;flex-direction:column;gap:.5rem}.kanban-column-empty{padding:1.5rem .75rem;text-align:center;color:var(--color-muted);font-size:12px}.kanban-card-wrapper{transition:opacity .15s,box-shadow .15s,transform .15s;border-radius:var(--radius);position:relative}.kanban-card-wrapper[dragging]{opacity:.5}.kanban-card-wrapper--drop-target{box-shadow:0 0 0 2px var(--color-primary),0 4px 12px rgba(0,0,0,.15);transform:scale(1.02);border-radius:var(--radius)}.kanban-drop-hint{position:absolute;bottom:-2px;left:50%;transform:translateX(-50%);background:var(--color-primary);color:#fff;font-size:10px;font-weight:500;padding:2px 8px;border-radius:4px;white-space:nowrap;display:flex;align-items:center;gap:4px;z-index:10;box-shadow:0 2px 8px rgba(0,0,0,.2)}.drawer-overlay{position:fixed;inset:0;background:rgba(14,44,51,.45);z-index:8000;animation:modal-fade-in .15s ease-out}.drawer-container{position:fixed;top:0;right:0;width:580px;max-width:calc(100vw - 2rem);height:100vh;background:var(--color-card);box-shadow:-8px 0 32px rgba(0,0,0,.18),0 0 0 1px rgba(255,255,255,.06);border-radius:0;z-index:8001;display:flex;flex-direction:column;overflow:hidden;animation:drawer-slide-in .2s ease-out}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-scale-in{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes drawer-slide-in{0%{transform:translateX(100%)}to{transform:translateX(0)}}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;border-bottom:1px solid var(--color-line);flex-shrink:0}.drawer-header-left{display:flex;align-items:center;gap:.5rem}.drawer-status-dot{width:10px;height:10px;border-radius:50%}.drawer-header-label{font-size:13px;font-weight:600;color:var(--color-muted);text-transform:uppercase;letter-spacing:.03em}.drawer-header-actions{display:flex;gap:.25rem}.drawer-action-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--color-muted);border-radius:6px;cursor:pointer}.drawer-action-btn:hover{background:var(--color-soft);color:var(--color-text)}.drawer-action-danger:hover{background:rgba(220,38,38,.08);color:var(--color-danger)}.drawer-body{flex:1;overflow-y:auto;padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.drawer-title-input{width:100%;border:none;outline:none;background:transparent;font-size:20px;font-weight:600;color:var(--color-text);font-family:var(--font-sans);padding:0}.drawer-title-input::placeholder{color:var(--color-muted)}.drawer-progress{display:flex;flex-direction:column;gap:.35rem}.drawer-progress-header{display:flex;justify-content:space-between;align-items:center}.drawer-progress-text{font-size:13px;font-weight:500;color:var(--color-text)}.drawer-progress-bar{height:6px;background:var(--color-soft);border-radius:3px;overflow:hidden}.drawer-progress-fill{height:100%;border-radius:3px;transition:width .3s ease}.drawer-save-row{display:flex;justify-content:flex-end}.drawer-separator{border:none;border-top:1px solid var(--color-line);margin:.5rem 0}.drawer-section{display:flex;flex-direction:column}.drawer-section-toggle{display:flex;align-items:center;gap:.5rem;padding:.5rem 0;border:none;background:transparent;cursor:pointer;font-size:14px;font-weight:600;color:var(--color-text);font-family:var(--font-sans)}.drawer-section-toggle:hover{color:var(--color-primary)}.drawer-section-count{font-size:12px;font-weight:500;color:var(--color-muted);background:var(--color-soft);border-radius:10px;padding:0 6px}.drawer-section-body{padding:.5rem 0 .5rem .5rem;display:flex;flex-direction:column;gap:.5rem}.drawer-section-empty{font-size:13px;color:var(--color-muted);margin:0}.drawer-subtask-list{display:flex;flex-direction:column;gap:4px}.drawer-subtask-item{display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;border-radius:var(--radius-sm)}.drawer-subtask-item:hover{background:var(--color-soft)}.drawer-subtask-title{font-size:13px;color:var(--color-text)}.drawer-meta{display:flex;flex-direction:column;gap:.25rem;padding-top:.5rem;font-size:12px;color:var(--color-muted)}.time-summary{display:flex;align-items:center;gap:.5rem;font-size:13px;font-weight:500;color:var(--color-text)}.time-summary-count{color:var(--color-muted);font-weight:400}.time-entries{display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto}.time-entry{display:flex;align-items:center;gap:.75rem;padding:.35rem .5rem;border-radius:var(--radius-sm);font-size:13px}.time-entry:hover{background:var(--color-soft)}.time-entry-left{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.time-entry-hours{font-weight:600;color:var(--color-primary);min-width:36px}.time-entry-date{color:var(--color-muted);font-size:12px}.time-entry-desc{color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.time-add-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border:1px dashed var(--color-line);border-radius:var(--radius-sm);background:transparent;color:var(--color-muted);font-size:13px;cursor:pointer;transition:all .15s;align-self:flex-start}.time-add-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.time-form{flex-direction:column;padding:.75rem;background:var(--color-soft);border-radius:var(--radius-sm)}.time-form,.time-form-row{display:flex;gap:.5rem}.time-form-actions{display:flex;justify-content:flex-end;gap:.35rem;padding-top:.25rem}.drawer-v2 .dv2-header{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;border-bottom:1px solid var(--color-line);flex-shrink:0}.dv2-header-left{display:flex;align-items:center;gap:.5rem}.dv2-status-pill{color:#fff;text-transform:uppercase;letter-spacing:.04em}.dv2-overdue-pill,.dv2-status-pill{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:9999px;font-size:11px;font-weight:600}.dv2-overdue-pill{gap:.25rem;background:color-mix(in srgb,var(--color-danger) 15%,transparent);color:var(--color-danger)}.dv2-header-actions{display:flex;gap:.25rem}.dv2-icon-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--color-muted);border-radius:8px;cursor:pointer;transition:all .12s}.dv2-icon-btn:hover{background:var(--color-soft);color:var(--color-text)}.dv2-icon-btn--danger:hover{background:color-mix(in srgb,var(--color-danger) 10%,transparent);color:var(--color-danger)}.dv2-body{flex:1;overflow-y:auto;padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.dv2-toast{padding:.5rem .75rem;border-radius:8px;background:color-mix(in srgb,var(--color-danger) 10%,transparent);border:1px solid color-mix(in srgb,var(--color-danger) 20%,transparent);color:var(--color-danger);font-size:13px;font-weight:500}.dv2-title-input{width:100%;border:none;outline:none;background:transparent;font-size:20px;font-weight:700;color:var(--color-heading);font-family:var(--font-sans);padding:0;line-height:1.3}.dv2-title-input::placeholder{color:var(--color-muted);font-weight:500}.dv2-progress-strip{display:flex;align-items:center;gap:1rem;padding:.875rem 1rem;background:var(--color-soft);border-radius:12px}.dv2-progress-ring{position:relative;width:48px;height:48px;flex-shrink:0}.dv2-ring-svg{width:100%;height:100%;transform:rotate(-90deg)}.dv2-ring-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--color-heading)}.dv2-progress-info{display:flex;flex-direction:column;gap:.125rem}.dv2-progress-main{font-size:15px;font-weight:600;color:var(--color-heading)}.dv2-progress-dim{font-weight:400;color:var(--color-muted)}.dv2-progress-sub{font-size:12px;color:var(--color-muted)}.dv2-tabs{display:flex;gap:0;border-bottom:1px solid var(--color-line);margin:0 -1.25rem;padding:0 1.25rem}.dv2-tab{display:flex;align-items:center;gap:.35rem;padding:.625rem 1rem;background:transparent;color:var(--color-muted);font-size:13px;font-weight:500;cursor:pointer;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s;font-family:var(--font-sans)}.dv2-tab:hover{color:var(--color-text)}.dv2-tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.dv2-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:var(--color-soft);font-size:11px;font-weight:600;color:var(--color-muted)}.dv2-tab--active .dv2-tab-count{background:color-mix(in srgb,var(--color-primary) 12%,transparent);color:var(--color-primary)}.dv2-tab-content{gap:.875rem}.dv2-field,.dv2-tab-content{display:flex;flex-direction:column}.dv2-field{gap:.35rem}.dv2-label{display:inline-flex;align-items:center;gap:.35rem;font-size:12px;font-weight:600;color:var(--color-muted);text-transform:uppercase;letter-spacing:.04em}.dv2-textarea{width:100%;padding:.625rem .75rem;border:1px solid var(--color-line);border-radius:10px;font-size:13px;color:var(--color-text);background:var(--color-bg);font-family:var(--font-sans);resize:vertical;transition:border-color .15s}.dv2-textarea:focus{outline:none;border-color:var(--color-primary)}.dv2-field-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.dv2-select-wrap{position:relative;display:flex;align-items:center}.dv2-select-dot{position:absolute;left:.625rem;width:8px;height:8px;border-radius:50%;pointer-events:none;z-index:1}.dv2-select{width:100%;padding:.5rem 2rem .5rem 1.75rem;border:1px solid var(--color-line);border-radius:10px;font-size:13px;color:var(--color-text);background:var(--color-bg);font-family:var(--font-sans);appearance:none;cursor:pointer;transition:border-color .15s}.dv2-select:focus{outline:none;border-color:var(--color-primary)}.dv2-select-chevron{position:absolute;right:.625rem;color:var(--color-muted);pointer-events:none}.dv2-input-wrap{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border:1px solid var(--color-line);border-radius:10px;background:var(--color-bg);transition:border-color .15s;color:var(--color-muted)}.dv2-input-wrap:focus-within{border-color:var(--color-primary)}.dv2-input{flex:1;border:none;outline:none;background:transparent;font-size:13px;color:var(--color-text);font-family:var(--font-sans);min-width:0}.dv2-input-suffix{font-size:12px;color:var(--color-muted);font-weight:500}.dv2-save-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1.25rem;background:var(--color-primary);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;font-family:var(--font-sans);align-self:stretch}.dv2-save-btn:hover{background:var(--color-primary-light)}.dv2-save-btn:disabled{opacity:.6;cursor:wait}.dv2-btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.4rem .75rem;background:transparent;color:var(--color-muted);border:1px solid var(--color-line);border-radius:8px;font-size:13px;cursor:pointer;font-family:var(--font-sans);transition:all .15s}.dv2-btn-ghost:hover{background:var(--color-soft);color:var(--color-text)}.dv2-quick-add{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.75rem;border:1px dashed var(--color-line);border-radius:10px;background:transparent;color:var(--color-muted);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;font-family:var(--font-sans)}.dv2-quick-add:hover{border-color:var(--color-primary);color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 5%,transparent)}.dv2-timer{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:var(--color-soft);border-radius:12px;margin-bottom:.75rem}.dv2-timer--running{background:color-mix(in srgb,#EF4444 8%,var(--color-soft));border:1px solid color-mix(in srgb,#ef4444 20%,transparent)}.dv2-timer-display{display:flex;align-items:center;gap:.5rem;flex:1}.dv2-timer-dot{width:8px;height:8px;border-radius:50%;background:#EF4444;animation:dv2-timer-pulse 1.2s ease-in-out infinite}@keyframes dv2-timer-pulse{0%,to{opacity:1}50%{opacity:.3}}.dv2-timer-time{font-size:1.25rem;font-weight:600;font-variant-numeric:tabular-nums;color:var(--color-heading);letter-spacing:.02em}.dv2-timer-stop{display:inline-flex;align-items:center;gap:.375rem;padding:.4rem .875rem;background:#EF4444;color:#fff;border:none;border-radius:8px;font-size:.8125rem;font-weight:500;cursor:pointer;transition:background .15s}.dv2-timer-stop:hover{background:#DC2626}.dv2-timer-rec{width:36px;height:36px;border-radius:50%;border:2px solid var(--color-line);background:var(--color-bg);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .2s,box-shadow .2s;flex-shrink:0}.dv2-timer-rec:hover{border-color:#EF4444;box-shadow:0 0 0 3px color-mix(in srgb,#EF4444 12%,transparent)}.dv2-timer-rec-dot{width:12px;height:12px;border-radius:50%;background:#EF4444}.dv2-timer-label{font-size:.8125rem;color:var(--color-text);font-weight:500}.dv2-timer-hint{font-size:.75rem;color:var(--color-muted)}.dv2-timer-manual{display:inline-flex;align-items:center;gap:.375rem;padding:.4rem .75rem;background:transparent;color:var(--color-muted);border:1px dashed var(--color-line);border-radius:8px;font-size:.8125rem;cursor:pointer;transition:all .15s}.dv2-timer-manual:hover{border-color:var(--color-primary);color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 5%,transparent)}.dv2-time-form{display:flex;flex-direction:column;gap:.625rem;padding:1rem;background:var(--color-soft);border-radius:12px}.dv2-time-form-row{display:flex;gap:.5rem}.dv2-time-input-group{display:flex;align-items:center;gap:.25rem;padding:.5rem .75rem;background:var(--color-bg);border:1px solid var(--color-line);border-radius:10px;min-width:90px}.dv2-time-hours-input{width:50px;border:none;outline:none;background:transparent;font-size:18px;font-weight:700;color:var(--color-primary);font-family:var(--font-sans);text-align:center}.dv2-time-hours-input::placeholder{color:var(--color-muted);font-weight:400}.dv2-time-unit{font-size:14px;font-weight:500;color:var(--color-muted)}.dv2-time-date-input{flex:1}.dv2-time-date-input,.dv2-time-desc-input{padding:.5rem .75rem;background:var(--color-bg);border:1px solid var(--color-line);border-radius:10px;font-size:13px;color:var(--color-text);font-family:var(--font-sans)}.dv2-time-desc-input{width:100%}.dv2-time-desc-input::placeholder{color:var(--color-muted)}.dv2-time-form-actions{display:flex;justify-content:flex-end;gap:.5rem}.dv2-time-list{display:flex;flex-direction:column}.dv2-time-list-header{display:flex;justify-content:space-between;padding:.5rem 0;font-size:12px;color:var(--color-muted);border-bottom:1px solid var(--color-line);margin-bottom:.25rem}.dv2-time-entry{display:flex;align-items:flex-start;gap:.75rem;padding:.625rem .5rem;border-radius:8px;transition:background .1s;position:relative}.dv2-time-entry:hover{background:var(--color-soft)}.dv2-time-entry-avatar{width:24px;height:24px;border-radius:50%;background:var(--color-primary);color:#fff;font-size:9px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0;align-self:center;letter-spacing:.02em}.dv2-time-entry-actions{display:flex;gap:2px;opacity:0;margin-left:auto;align-self:center;flex-shrink:0;transition:opacity .15s}.dv2-time-entry:hover .dv2-time-entry-actions{opacity:1}.dv2-time-entry-delete,.dv2-time-entry-edit{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;border:none;background:transparent;color:var(--color-muted);cursor:pointer;transition:color .15s,background .15s}.dv2-time-entry-edit:hover{color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 10%,transparent)}.dv2-time-entry-delete:hover{color:#EF4444;background:color-mix(in srgb,#EF4444 10%,transparent)}.dv2-time-edit-form{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:var(--color-soft);border-radius:10px;border:1px solid var(--color-line)}.dv2-time-entry-hours{font-size:14px;font-weight:700;color:var(--color-primary);min-width:40px;flex-shrink:0}.dv2-time-entry-content{display:flex;flex-direction:column;gap:.125rem;min-width:0}.dv2-time-entry-desc{font-size:13px;color:var(--color-text)}.dv2-time-entry-date{font-size:11px;color:var(--color-muted)}.dv2-subtask-list{display:flex;flex-direction:column;gap:.25rem}.dv2-subtask{display:flex;align-items:center;gap:.625rem;padding:.5rem .625rem;border-radius:8px;transition:background .1s}.dv2-subtask:hover{background:var(--color-soft)}.dv2-subtask-check{width:20px;height:20px;border:2px solid var(--color-line);border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:transparent}.dv2-subtask-check--done{background:var(--color-ok);border-color:var(--color-ok);color:#fff}.dv2-dep-arrow{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.dv2-subtask-title{font-size:13px;color:var(--color-text)}.dv2-subtask--done .dv2-subtask-title{text-decoration:line-through;opacity:.5}.dv2-empty-state{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:2.5rem 0;color:var(--color-muted)}.dv2-empty-state p{margin:0;font-size:13px}.dv2-meta{padding-top:.75rem;font-size:11px;color:var(--color-muted);text-align:center}.dv2-comments-section{margin-top:1rem;border-top:1px solid var(--color-line);padding-top:.25rem}.dv2-comments-toggle{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem 0;background:none;border:none;font-size:12px;font-weight:500;color:var(--color-muted);cursor:pointer;transition:color .15s}.dv2-comments-toggle:hover{color:var(--color-text)}.dv2-comments-body{padding-top:.5rem}.dv2-comment-form{margin-bottom:.75rem}.dv2-comment-input-row{display:flex;gap:.375rem;align-items:flex-end}.dv2-comment-input{flex:1;padding:.5rem .75rem;border:1px solid var(--color-line);border-radius:10px;font-size:13px;font-family:inherit;background:var(--color-bg);color:var(--color-text);resize:vertical;min-height:36px;transition:border-color .15s}.dv2-comment-input:focus{outline:none;border-color:var(--color-primary)}.dv2-comment-send{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;border:none;background:var(--color-primary);color:#fff;cursor:pointer;flex-shrink:0;transition:opacity .15s}.dv2-comment-send:hover{opacity:.9}.dv2-comment-send:disabled{opacity:.4;cursor:default}.dv2-comment{display:flex;gap:.5rem;padding:.5rem 0;border-top:1px solid color-mix(in srgb,var(--color-line) 50%,transparent)}.dv2-comment:first-child{border-top:none}.dv2-comment-avatar{width:24px;height:24px;border-radius:50%;background:var(--color-primary);color:#fff;font-size:9px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0;letter-spacing:.02em}.dv2-comment-body{flex:1;min-width:0}.dv2-comment-header{display:flex;align-items:baseline;gap:.375rem;margin-bottom:.125rem}.dv2-comment-author{font-size:11px;font-weight:600;color:var(--color-heading)}.dv2-comment-date{font-size:10px;color:var(--color-muted)}.dv2-comment-text{font-size:12px;color:var(--color-text);line-height:1.45;margin:0;white-space:pre-wrap;word-break:break-word}.customer-card{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer;transition:background .1s}.customer-card:hover{background:var(--color-soft)}.customer-card:not(:last-child){border-bottom:1px solid var(--color-line)}.customer-risk-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.customer-card-content{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.customer-card-name{font-size:14px;font-weight:500;color:var(--color-text)}.customer-card-company{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--color-muted)}.customer-retainer-badge{display:inline-block;padding:2px 8px;background:rgba(4,95,116,.08);color:var(--color-primary);border-radius:12px;font-size:11px;font-weight:600;white-space:nowrap}.customer-type-tabs{display:flex;gap:.25rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.customer-type-tab{padding:.35rem .75rem;border:1px solid var(--color-line);background:transparent;color:var(--color-muted);border-radius:999px;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .15s ease}.customer-type-tab:hover{background:var(--color-hover);color:var(--color-fg)}.customer-type-tab--active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.customer-type-badge{display:inline-block;font-weight:600}.customer-type-badge,.task-card-assignee-tag{padding:2px 8px;border-radius:12px;font-size:11px;white-space:nowrap}.task-card-assignee-tag{display:inline-flex;align-items:center;gap:4px;background:rgba(99,102,241,.08);color:#6366f1;font-weight:500}.dv2-subtask-content{flex:1;min-width:0}.dv2-subtask-meta{display:flex;gap:.5rem;margin-top:2px}.dv2-subtask-badge{font-size:11px;color:var(--color-muted)}.form-static-value{padding:.5rem .75rem;background:var(--color-hover);border-radius:var(--radius);font-size:13px;color:var(--color-fg)}.customer-contacts-section{margin-bottom:1.5rem}.section-title{display:flex;align-items:center;gap:.5rem;font-size:15px;font-weight:600;color:var(--color-fg);margin-bottom:.75rem}.section-count{font-size:12px;font-weight:500;color:var(--color-muted);background:var(--color-hover);padding:1px 8px;border-radius:999px}.customer-contacts-list{display:flex;flex-direction:column;gap:.5rem}.customer-contact-card{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius)}.customer-contact-info{flex:1;min-width:0}.customer-contact-name{display:block;font-size:14px;font-weight:600;color:var(--color-fg)}.customer-contact-position{display:block;font-size:12px;color:var(--color-muted);margin-top:1px}.customer-contact-details{display:flex;gap:1rem;flex-shrink:0}.customer-contact-link{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--color-primary);text-decoration:none}.customer-contact-link:hover{text-decoration:underline}.customer-contact-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.portal-status-badge{padding:3px 8px;border-radius:999px}.contact-invite-btn,.portal-status-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:500;white-space:nowrap}.contact-invite-btn{padding:4px 10px;border:1px solid var(--color-line);border-radius:var(--radius);background:var(--color-card);color:var(--color-primary);cursor:pointer;transition:all .15s}.contact-invite-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.contact-invite-btn:disabled{opacity:.5;cursor:not-allowed}.contact-remove-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:6px;border:none;background:transparent;color:var(--color-muted);cursor:pointer;transition:all .15s ease;flex-shrink:0}.contact-remove-btn:hover{background:#FEE2E2;color:#DC2626}@keyframes spin{to{transform:rotate(1turn)}}.settings-section{background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius);margin-bottom:1rem;overflow:hidden}.settings-section-header{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-bottom:1px solid var(--color-line)}.settings-section-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.settings-section-title{font-size:16px;font-weight:600;color:var(--color-text);margin:0}.settings-section-desc{font-size:13px;color:var(--color-muted);margin:.15rem 0 0}.settings-status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:12px;font-size:12px;font-weight:500;margin-left:auto;white-space:nowrap}.status-connected{background:rgba(34,197,94,.08);color:var(--color-ok)}.status-disconnected{background:rgba(220,38,38,.08);color:var(--color-danger)}.status-planned{background:var(--color-soft);color:var(--color-muted)}.settings-section-body{padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.settings-hint{font-size:12px;color:var(--color-muted);margin-top:.25rem}.settings-hint strong,.settings-link{color:var(--color-primary)}.settings-link{display:inline-flex;align-items:center;gap:3px;text-decoration:none;margin-left:.5rem;font-size:12px;font-weight:400}.settings-link:hover{text-decoration:underline}.settings-actions{display:flex;gap:.5rem;justify-content:flex-end}.settings-message{padding:.5rem .75rem;border-radius:var(--radius-sm);font-size:13px}.settings-message-ok{background:rgba(34,197,94,.08);color:var(--color-ok);border:1px solid rgba(34,197,94,.15)}.settings-message-error{background:rgba(220,38,38,.08);color:var(--color-danger);border:1px solid rgba(220,38,38,.15)}.animate-spin{animation:spin 1s linear infinite}@media (max-width:768px){.dashboard-sidebar{position:fixed;left:0;top:0;bottom:0;z-index:100;width:240px!important;transform:translateX(-100%);transition:transform .25s}.dashboard-sidebar[data-open=true]{transform:translateX(0)}.dashboard-content{padding:1rem}.dashboard-stats-grid{grid-template-columns:1fr 1fr}.dashboard-quick-actions{flex-wrap:wrap}.command-bar-overlay{padding-top:10vh;padding-left:1rem;padding-right:1rem}.tasks-page-header{align-items:flex-start;gap:1rem}.tasks-filter-bar,.tasks-page-header{flex-direction:column}.form-row{grid-template-columns:1fr}.kanban-board{padding-left:0}.kanban-column{flex:0 0 85vw}.modal-overlay{padding:1rem;align-items:flex-end}.modal-container{max-width:100%;border-radius:var(--radius) var(--radius) 0 0}.drawer-container{width:100vw;max-width:100vw}}.customer-detail-page{display:flex;flex-direction:column;gap:1.5rem}.customer-detail-header{display:flex;flex-direction:column;gap:1rem;border-radius:8px;padding-left:1.25rem}.customer-detail-back{display:inline-flex;align-items:center;gap:.375rem;background:none;border:none;color:var(--color-muted);font-size:13px;cursor:pointer;padding:0;transition:color .15s}.customer-detail-back:hover{color:var(--color-primary)}.customer-detail-title-row{display:flex;align-items:flex-start;gap:1rem}.customer-risk-dot-lg{width:14px;height:14px;border-radius:50%;flex-shrink:0;margin-top:.5rem}.customer-detail-title-text{flex:1;min-width:0}.customer-detail-name{font-size:1.5rem;font-weight:700;color:var(--color-heading);margin:0;line-height:1.3}.customer-detail-edit-title{font-size:1.25rem;font-weight:600;padding:.375rem .5rem}.customer-detail-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;margin-top:.375rem}.customer-detail-meta-item{display:inline-flex;align-items:center;gap:.375rem;font-size:13px;color:var(--color-muted)}.customer-detail-actions{display:flex;gap:.5rem;flex-shrink:0;margin-left:auto}.btn-danger-outline{color:var(--color-danger)!important;border-color:var(--color-danger)!important}.btn-danger-outline:hover{background:var(--color-danger)!important;color:#fff!important}.customer-detail-edit-bar{display:flex;flex-wrap:wrap;gap:1.5rem;align-items:center;padding:1rem 1.25rem;background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius)}.edit-bar-divider{width:1px;height:28px;background:var(--color-line);flex-shrink:0}.retainer-toggle{display:inline-flex;align-items:center;gap:.5rem;padding:.3rem .65rem .3rem .35rem;border-radius:20px;border:1px solid var(--color-line);background:var(--color-bg);cursor:pointer;font-size:.82rem;color:var(--color-muted);font-family:inherit;transition:all .2s}.retainer-toggle--active{border-color:var(--color-accent);background:rgba(4,95,116,.06);color:var(--color-accent)}.retainer-toggle-knob{display:inline-block;width:18px;height:18px;border-radius:50%;background:var(--color-line);transition:all .2s}.retainer-toggle--active .retainer-toggle-knob{background:var(--color-accent)}.form-group-inline{display:flex;align-items:center;gap:.5rem}.form-group-inline .form-label{margin:0;white-space:nowrap;font-size:13px}.form-select{padding:.375rem .625rem;border:1px solid var(--color-line);border-radius:var(--radius);background:var(--color-bg);font-size:13px;color:var(--color-text)}.form-input-sm{padding:.25rem .5rem;font-size:13px}.customer-detail-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.customer-stat-card{display:flex;align-items:center;gap:.875rem;padding:1.125rem 1.25rem;background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius)}.customer-stat-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;background:color-mix(in srgb,var(--color-primary) 10%,transparent);color:var(--color-primary);flex-shrink:0}.customer-stat-data{display:flex;flex-direction:column}.customer-stat-value{font-size:1.25rem;font-weight:700;color:var(--color-heading);line-height:1.2}.customer-stat-label{font-size:12px;color:var(--color-muted);margin-top:.125rem}.customer-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.customer-detail-section{background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius);padding:1.25rem}.customer-detail-section-title{display:flex;align-items:center;gap:.5rem;font-size:15px;font-weight:600;color:var(--color-heading);margin:0 0 1rem}.customer-detail-section-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 .375rem;border-radius:11px;background:var(--color-line);color:var(--color-muted);font-size:12px;font-weight:600;margin-left:auto}.customer-detail-empty{font-size:13px;color:var(--color-muted);text-align:center;padding:2rem 0}.customer-projects-list{display:flex;flex-direction:column;gap:.75rem}.customer-project-card{padding:.875rem 1rem;border:1px solid var(--color-line);border-radius:var(--radius);background:var(--color-bg)}.customer-project-inactive{opacity:.5}.customer-project-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}.customer-project-name{font-size:14px;font-weight:600;color:var(--color-heading)}.customer-project-type{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;padding:.125rem .5rem;border-radius:9999px;background:var(--color-line);color:var(--color-muted)}.customer-project-type--retainer{background:color-mix(in srgb,var(--color-accent) 15%,transparent);color:var(--color-accent)}.customer-project-type--project{background:color-mix(in srgb,var(--color-primary) 10%,transparent);color:var(--color-primary)}.customer-project-progress{display:flex;align-items:center;gap:.75rem}.customer-project-bar{flex:1;height:6px;border-radius:3px;background:var(--color-line);overflow:hidden}.customer-project-bar-fill{height:100%;border-radius:3px;transition:width .3s ease}.customer-project-hours{font-size:12px;color:var(--color-muted);white-space:nowrap}.customer-project-archived{display:inline-block;margin-top:.5rem;font-size:11px;color:var(--color-muted);font-style:italic}.project-status-badge{display:inline-flex;align-items:center;padding:.15rem .5rem;border-radius:6px;font-size:.7rem;font-weight:500;letter-spacing:.02em}.project-status-badge--active{background:rgba(45,156,111,.1);color:#2D9C6F}.project-status-badge--inactive{background:rgba(0,0,0,.05);color:var(--color-muted)}.project-budget-info{display:flex;align-items:center;gap:.35rem;margin-top:.4rem;font-size:.8rem;color:var(--color-accent);font-weight:500}.project-completed-info{display:flex;align-items:center;gap:.35rem;margin-top:.5rem;font-size:.75rem;color:var(--color-muted)}.project-billing-badge{display:inline-flex;align-items:center;padding:.1rem .4rem;border-radius:4px;background:rgba(45,156,111,.1);color:#2D9C6F;font-size:.7rem;font-weight:500;margin-left:.5rem}.customer-tasks-list{display:flex;flex-direction:column;gap:.25rem}.customer-task-row{display:flex;align-items:center;gap:.75rem;padding:.625rem .75rem;border-radius:var(--radius);cursor:pointer;transition:background .1s}.customer-task-row:hover{background:var(--color-bg)}.customer-task-status{font-size:11px;font-weight:600;padding:.125rem .5rem;border-radius:9999px;background:var(--color-line);color:var(--color-muted);white-space:nowrap}.customer-task-status--in_progress{background:color-mix(in srgb,#3b82f6 15%,transparent);color:#3b82f6}.customer-task-status--done,.customer-task-status--invoiced{background:color-mix(in srgb,var(--color-ok) 15%,transparent);color:var(--color-ok)}.customer-task-status--blocked{background:color-mix(in srgb,var(--color-danger) 15%,transparent);color:var(--color-danger)}.customer-task-status--review{background:color-mix(in srgb,var(--color-accent) 15%,transparent);color:var(--color-accent)}.customer-task-title{flex:1;font-size:13px;color:var(--color-text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.customer-task-priority{font-size:11px;color:var(--color-muted)}.customer-task-priority--high,.customer-task-priority--urgent{color:var(--color-danger);font-weight:600}.customer-task-hours{display:inline-flex;align-items:center;gap:.25rem;font-size:12px;color:var(--color-muted);white-space:nowrap}.retainer-overview{background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius);padding:1.5rem}.retainer-overview-title{font-size:15px;font-weight:600;color:var(--color-heading);margin:0 0 1.25rem}.retainer-overview-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.25rem}.retainer-metric{display:flex;flex-direction:column;align-items:center;text-align:center}.retainer-metric-value{font-size:1.75rem;font-weight:700;color:var(--color-heading);line-height:1.2}.retainer-metric-ok{color:var(--color-ok)}.retainer-metric-warn{color:var(--color-warn)}.retainer-metric-over{color:var(--color-danger)}.retainer-metric-label{font-size:12px;color:var(--color-muted);margin-top:.25rem;text-transform:uppercase;letter-spacing:.04em;font-weight:500}.retainer-bar-container{margin-bottom:.75rem}.retainer-bar{height:12px;border-radius:6px;background:var(--color-line);overflow:hidden;display:flex;position:relative}.retainer-bar-fill{height:100%;border-radius:6px;transition:width .4s ease}.retainer-bar-overflow{height:100%;background:repeating-linear-gradient(-45deg,var(--color-danger),var(--color-danger) 4px,color-mix(in srgb,var(--color-danger) 60%,transparent) 4px,color-mix(in srgb,var(--color-danger) 60%,transparent) 8px)}.retainer-bar-labels{display:flex;justify-content:space-between;margin-top:.375rem;font-size:11px;color:var(--color-muted)}.retainer-budget-note{font-size:13px;color:var(--color-muted);text-align:center;padding-top:.5rem;border-top:1px solid var(--color-line)}@media (max-width:768px){.customer-detail-stats{grid-template-columns:repeat(2,1fr)}.customer-detail-grid{grid-template-columns:1fr}.customer-detail-title-row{flex-direction:column}.customer-detail-actions{margin-left:0}.customer-detail-edit-bar{flex-direction:column;gap:.75rem}.retainer-overview-grid{grid-template-columns:repeat(2,1fr)}}.dashboard-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.dashboard-section-header .dashboard-section-title{display:flex;align-items:center;gap:.5rem;margin-bottom:0}.dashboard-section-link{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--color-primary);text-decoration:none;font-weight:500;transition:opacity .15s}.dashboard-section-link:hover{opacity:.75}.retainer-dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem}.retainer-dashboard-card{background:var(--color-card);border-radius:10px;padding:1rem 1.25rem;cursor:pointer;transition:all .2s ease;border:1px solid var(--color-line);border-left:3px solid var(--color-accent)}.retainer-dashboard-card:hover{border-color:var(--color-accent);box-shadow:var(--shadow-md);transform:translateY(-1px)}.retainer-dashboard-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.retainer-dashboard-card-name{display:flex;align-items:center;gap:.4rem;font-weight:600;font-size:.9rem;color:var(--color-heading)}.retainer-dashboard-risk{font-size:.7rem;font-weight:600;padding:.15rem .5rem;border-radius:12px}.retainer-dashboard-bar-container{display:flex;align-items:center;gap:.5rem;margin-bottom:.6rem}.retainer-dashboard-bar{flex:1;height:6px;background:var(--color-soft);border-radius:3px;overflow:hidden}.retainer-dashboard-bar-fill{height:100%;border-radius:3px;transition:width .5s ease}.retainer-dashboard-pct{font-size:.8rem;font-weight:700;min-width:36px;text-align:right}.retainer-dashboard-meta{display:flex;gap:.75rem;font-size:.72rem;color:var(--color-muted)}.retainer-tasks-list{display:flex;flex-direction:column;gap:.35rem}.retainer-task-row{display:flex;align-items:center;gap:.75rem;padding:.7rem 1rem;background:var(--color-card);border:1px solid var(--color-line);border-radius:8px;cursor:pointer;transition:all .15s}.retainer-task-row:hover{border-color:var(--color-primary);background:var(--color-soft)}.retainer-task-row.retainer-task-overdue{border-left:3px solid #e74c3c;background:rgba(231,76,60,.03)}.retainer-task-priority{width:4px;height:24px;border-radius:2px;flex-shrink:0}.retainer-task-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.retainer-task-title{font-size:.85rem;font-weight:500;color:var(--color-heading);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.retainer-task-customer{display:flex;align-items:center;gap:.3rem;font-size:.72rem;color:var(--color-accent);font-weight:500}.retainer-task-status{font-size:.72rem;color:var(--color-muted);white-space:nowrap}.retainer-task-overdue-badge{font-size:.68rem;font-weight:600;padding:.15rem .45rem;border-radius:4px;background:rgba(231,76,60,.12);color:#E74C3C;white-space:nowrap}.retainer-task-due{font-size:.72rem;color:var(--color-muted);white-space:nowrap}@media (max-width:768px){.retainer-dashboard-grid{grid-template-columns:1fr}.retainer-dashboard-meta{flex-wrap:wrap}}.admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.25rem;margin-top:1.5rem}.admin-section-card{display:flex;flex-direction:column;padding:1.5rem;background:var(--color-card);border:1px solid var(--color-line);border-radius:12px;cursor:pointer;text-align:left;transition:all .2s ease;position:relative}.admin-section-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.admin-section-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.admin-section-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center}.admin-section-arrow{color:var(--color-muted);opacity:0;transition:opacity .2s,transform .2s}.admin-section-card:hover .admin-section-arrow{opacity:1;transform:translateX(2px)}.admin-section-title{font-size:1.05rem;font-weight:600;color:var(--color-heading);margin-bottom:.4rem}.admin-section-desc{font-size:.85rem;color:var(--color-muted);line-height:1.5;margin-bottom:1rem}.admin-section-footer{margin-top:auto;display:flex;align-items:center;gap:1rem;font-size:.8rem}.admin-section-stat{color:var(--color-text)}.admin-section-alert,.admin-section-stat{display:flex;align-items:center;gap:.35rem}.admin-section-alert{color:#E74C3C}.admin-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;backdrop-filter:blur(4px)}.admin-modal{background:var(--color-card);border-radius:16px;width:100%;max-width:600px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 24px 60px rgba(0,0,0,.25);border:1px solid var(--color-line)}.admin-modal-sm{max-width:460px}.admin-modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-line)}.admin-modal-title{font-size:1.1rem;font-weight:600;color:var(--color-heading)}.admin-modal-subtitle{font-size:.8rem;color:var(--color-muted);margin-top:.15rem}.admin-modal-close{background:none;border:none;cursor:pointer;color:var(--color-muted);padding:.25rem;border-radius:6px;transition:background .15s}.admin-modal-close:hover{background:var(--color-soft);color:var(--color-text)}.admin-modal-body{padding:1.5rem;overflow-y:auto;flex:1}.admin-modal-section{margin-bottom:1.5rem}.admin-modal-section-title{font-size:.9rem;font-weight:600;color:var(--color-heading);margin-bottom:.75rem}.admin-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--color-line)}.connector-catalog{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}.connector-card{background:var(--color-card);border:1px solid var(--color-line);border-radius:12px;overflow:hidden;transition:border-color .2s}.connector-card:hover{border-color:color-mix(in srgb,var(--color-line) 50%,var(--color-primary))}.connector-card-main{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem}.connector-card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.connector-card-info{flex:1;min-width:0}.connector-card-name-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.25rem}.connector-card-name{font-size:1rem;font-weight:600;color:var(--color-heading)}.connector-card-desc{font-size:.8rem;color:var(--color-muted);line-height:1.4}.connector-card-type{font-size:.65rem;font-weight:700;letter-spacing:.5px;color:var(--color-muted);margin-top:.35rem}.connector-card-actions{display:flex;gap:.5rem;align-items:center;flex-shrink:0}.connector-status-badge{display:inline-flex;align-items:center;gap:.3rem;font-size:.75rem;font-weight:500;padding:.2rem .6rem;border-radius:20px}.connector-status-badge.status-active{background:rgba(45,156,111,.12);color:#2D9C6F}.connector-status-badge.status-error{background:rgba(231,76,60,.12);color:#E74C3C}.connector-status-badge.status-inactive{background:var(--color-soft);color:var(--color-muted)}.connector-status-badge.status-setup{background:rgba(201,133,73,.12);color:var(--color-accent)}.connector-sync-result{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.8rem;border-top:1px solid var(--color-line)}.connector-sync-result.sync-success{background:rgba(45,156,111,.06);color:#2D9C6F}.connector-sync-result.sync-error{background:rgba(231,76,60,.06);color:#E74C3C}.connector-detail{padding:1rem 1.5rem;border-top:1px solid var(--color-line);background:var(--color-soft)}.connector-detail-meta{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem;font-size:.8rem;color:var(--color-text);margin-bottom:1rem}.connector-sync-log{margin-top:.75rem}.connector-log-entry{display:flex;align-items:center;gap:.75rem;padding:.4rem 0;font-size:.8rem;border-bottom:1px solid var(--color-line)}.connector-log-entry:last-child{border-bottom:none}.connector-log-status{display:flex;align-items:center}.connector-log-status.success{color:#2D9C6F}.connector-log-status.error{color:#E74C3C}.connector-log-type{font-weight:600;color:var(--color-heading);min-width:80px}.connector-log-stats{color:var(--color-muted);flex:1}.connector-log-date{color:var(--color-muted);font-size:.75rem}.connector-scope-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;border-radius:8px;cursor:pointer;margin-bottom:.5rem;border:1px solid var(--color-line);transition:background .15s}.connector-scope-item:hover{background:var(--color-soft)}.connector-scope-item.scope-disabled{opacity:.5;cursor:not-allowed}.connector-scope-item input[type=checkbox]{margin-top:.2rem;flex-shrink:0}.connector-scope-item strong{display:block;font-size:.85rem;color:var(--color-heading)}.connector-scope-desc{display:block;font-size:.78rem;color:var(--color-muted);line-height:1.4;margin-top:.15rem}.connector-scope-dep{display:block;font-size:.72rem;color:var(--color-accent);margin-top:.25rem}.admin-users-list{display:flex;flex-direction:column;gap:.5rem;margin-top:1.5rem}.admin-user-card{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--color-card);border:1px solid var(--color-line);border-radius:10px;transition:border-color .15s}.admin-user-card:hover{border-color:color-mix(in srgb,var(--color-line) 50%,var(--color-primary))}.admin-user-avatar{width:40px;height:40px;border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;font-size:.95rem;font-weight:600;color:white}.admin-user-avatar img{width:100%;height:100%;object-fit:cover}.admin-user-info{flex:1;min-width:0}.admin-user-name{font-weight:600;font-size:.9rem;color:var(--color-heading)}.admin-user-email{font-size:.78rem;color:var(--color-muted)}.admin-user-role{flex-shrink:0}.admin-role-badge{display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;font-weight:500;padding:.25rem .65rem;border-radius:20px;border:1px solid}.admin-user-actions{display:flex;gap:.25rem;flex-shrink:0}.admin-user-date{font-size:.72rem;color:var(--color-muted);white-space:nowrap;flex-shrink:0}.admin-roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;margin-top:1.5rem}.admin-role-card{background:var(--color-card);border:1px solid var(--color-line);border-radius:12px;padding:1.25rem;transition:border-color .2s}.admin-role-card:hover{border-color:color-mix(in srgb,var(--color-line) 50%,var(--color-primary))}.admin-role-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.admin-role-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-role-name{font-size:.95rem;font-weight:600;color:var(--color-heading)}.admin-role-system-badge{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-muted);background:var(--color-soft);padding:.1rem .4rem;border-radius:4px;margin-left:.4rem}.admin-role-actions{margin-left:auto;display:flex;gap:.25rem}.admin-role-desc{font-size:.8rem;color:var(--color-muted);line-height:1.45;margin-bottom:.75rem}.admin-role-perms{display:flex;flex-wrap:wrap;gap:.35rem}.admin-perm-badge{font-size:.7rem;font-weight:500;padding:.15rem .5rem;border-radius:4px;background:var(--color-soft);color:var(--color-text)}.admin-perm-wildcard{background:rgba(4,95,116,.12);color:var(--color-primary);font-weight:600}.admin-perm-more{color:var(--color-muted);font-style:italic}.admin-perm-group{margin-bottom:1rem;padding:.75rem;border-radius:8px;background:var(--color-soft)}.admin-perm-group-title{font-size:.78rem;font-weight:600;color:var(--color-heading);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.3px}.admin-perm-group-items{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.35rem}.admin-perm-checkbox{display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--color-text);cursor:pointer;padding:.25rem 0}.admin-perm-checkbox input[type=checkbox]{flex-shrink:0}.btn-icon{background:none;border:none;cursor:pointer;color:var(--color-muted);padding:.35rem;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .15s}.btn-icon:hover{background:var(--color-soft);color:var(--color-text)}.btn-sm{padding:.35rem .7rem;font-size:.8rem;gap:.35rem}.btn-danger-ghost{color:var(--color-muted)}.btn-danger-ghost:hover{color:#E74C3C!important;background:rgba(231,76,60,.08)!important}@media (max-width:768px){.admin-grid{grid-template-columns:1fr}.connector-card-main{flex-wrap:wrap}.connector-card-actions{width:100%;justify-content:flex-end}.admin-user-card{flex-wrap:wrap}.admin-user-date{width:100%;text-align:right}.admin-roles-grid{grid-template-columns:1fr}}.active-projects-list{display:flex;flex-direction:column;border:1px solid var(--color-line);border-radius:var(--radius);overflow:hidden;background:var(--color-card)}.active-project-row{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;cursor:pointer;transition:background .15s}.active-project-row:not(:last-child){border-bottom:1px solid var(--color-line)}.active-project-row:hover{background:rgba(4,95,116,.03)}.active-project-row--retainer{border-left:3px solid var(--color-accent)}.active-project-info{flex:1;display:flex;flex-direction:column;min-width:0}.active-project-name{font-size:.88rem;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.active-project-customer{display:flex;align-items:center;gap:.3rem;font-size:.75rem;color:var(--color-muted)}.active-project-type{display:inline-flex;padding:.15rem .5rem;border-radius:6px;font-size:.7rem;font-weight:500;flex-shrink:0}.active-project-type--retainer{background:rgba(4,95,116,.08);color:var(--color-accent)}.active-project-type--project{background:rgba(61,139,110,.08);color:#3d8b6e}.active-project-type--hourly{background:rgba(0,0,0,.04);color:var(--color-muted)}.active-project-budget{display:flex;align-items:center;gap:.5rem;width:180px;flex-shrink:0}.active-project-bar{flex:1;height:4px;border-radius:2px;background:var(--color-line);overflow:hidden}.active-project-bar-fill{height:100%;border-radius:2px;transition:width .3s ease}.active-project-hours{font-size:.75rem;color:var(--color-muted);white-space:nowrap}.active-project-monthly{font-size:.72rem;color:var(--color-accent);font-weight:500;white-space:nowrap;flex-shrink:0}@media (max-width:768px){.active-project-row{flex-wrap:wrap;gap:.5rem}.active-project-budget{width:100%}}.glaskugel{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 4rem);padding:2rem;transition:all .4s cubic-bezier(.4,0,.2,1)}.glaskugel--active{justify-content:flex-start;padding-top:3rem}.glaskugel-form{width:100%;max-width:680px;position:relative}.glaskugel-input-wrapper{display:flex;align-items:center;width:100%;background:var(--color-card);border:2px solid var(--color-line);border-radius:999px;padding:0 1.5rem;transition:all .25s ease;box-shadow:0 2px 20px rgba(0,0,0,.04)}.glaskugel-input-wrapper:focus-within{border-color:var(--color-primary);box-shadow:0 4px 32px rgba(4,95,116,.1),0 0 0 4px rgba(4,95,116,.05)}.glaskugel-input-icon{color:var(--color-muted);flex-shrink:0;opacity:.5}.glaskugel-input{flex:1;border:none;background:none;padding:1.25rem 1rem;font-size:1.25rem;font-weight:400;color:var(--color-text);outline:none;font-family:inherit;letter-spacing:-.01em}.glaskugel-input::placeholder{color:var(--color-muted);opacity:.4;font-weight:400}.glaskugel-submit{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;border:none;background:var(--color-primary);color:white;cursor:pointer;flex-shrink:0;transition:all .2s}.glaskugel-submit:hover{background:var(--color-accent);transform:scale(1.05)}.glaskugel-results{width:100%;max-width:680px;margin-top:1.5rem;animation:glaskugel-slide-up .3s ease}.glaskugel-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:2.5rem;color:var(--color-muted);font-size:.9rem}.glaskugel-spin{animation:spin 1s linear infinite}.glaskugel-response{display:flex;flex-direction:column;gap:1rem}.glaskugel-answer{display:flex;gap:.75rem;padding:1.25rem;background:var(--color-card);border:1px solid var(--color-line);border-radius:16px}.glaskugel-answer-icon{display:flex;align-items:flex-start;justify-content:center;width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:white;flex-shrink:0;padding-top:6px}.glaskugel-answer-text{flex:1;font-size:.92rem;line-height:1.65;color:var(--color-text)}.glaskugel-answer-text strong{font-weight:600}.glaskugel-answer-text code{background:rgba(4,95,116,.08);padding:.1em .35em;border-radius:4px;font-size:.88em}.glaskugel-actions{display:flex;flex-wrap:wrap;gap:.5rem}.glaskugel-action{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1rem;border-radius:10px;font-size:.85rem;font-weight:500;text-decoration:none;transition:all .2s;cursor:pointer}.glaskugel-action--primary{background:var(--color-primary);color:white}.glaskugel-action--primary:hover{background:var(--color-accent)}.glaskugel-action--secondary{background:rgba(4,95,116,.08);color:var(--color-primary);border:1px solid rgba(4,95,116,.15)}.glaskugel-action--secondary:hover{background:rgba(4,95,116,.14)}.glaskugel-result-list{display:flex;flex-direction:column;border:1px solid var(--color-line);border-radius:16px;overflow:hidden;background:var(--color-card)}.glaskugel-result-item{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;text-decoration:none;color:var(--color-text);transition:background .15s;cursor:pointer}.glaskugel-result-item:not(:last-child){border-bottom:1px solid var(--color-line)}.glaskugel-result-item:hover{background:rgba(4,95,116,.04)}.glaskugel-result-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:rgba(4,95,116,.08);color:var(--color-primary);flex-shrink:0}.glaskugel-result-info{flex:1;display:flex;flex-direction:column;min-width:0}.glaskugel-result-title{font-size:.88rem;font-weight:500;color:var(--color-text)}.glaskugel-result-subtitle,.glaskugel-result-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.glaskugel-result-subtitle{font-size:.78rem;color:var(--color-muted)}.glaskugel-result-type{font-size:.72rem;color:var(--color-muted);text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}.glaskugel-escape{text-align:center;padding:.75rem;font-size:.75rem;color:var(--color-muted);opacity:.6}.glaskugel-escape kbd{display:inline-block;padding:.15em .45em;border:1px solid var(--color-line);border-radius:4px;background:var(--color-bg);font-size:.85em;font-family:inherit;margin-right:.25em}.glaskugel-instant{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--color-card);border:1px solid var(--color-border);border-radius:16px;padding:.4rem;box-shadow:0 8px 32px rgba(0,0,0,.1),0 2px 8px rgba(0,0,0,.04);z-index:100;animation:glaskugel-dropdown-in .15s ease-out}@keyframes glaskugel-dropdown-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.glaskugel-instant-group+.glaskugel-instant-group{border-top:1px solid var(--color-border);margin-top:.25rem;padding-top:.25rem}.glaskugel-instant-header{display:flex;align-items:center;gap:.35rem;padding:.4rem .75rem .15rem;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted)}.glaskugel-instant-header svg{opacity:.6;width:12px;height:12px}.glaskugel-instant-item{display:flex;align-items:center;gap:.6rem;padding:.55rem .75rem;border-radius:10px;cursor:pointer;transition:background .1s;animation:glaskugel-item-in .2s ease-out both}@keyframes glaskugel-item-in{0%{opacity:0;transform:translateX(-4px)}to{opacity:1;transform:translateX(0)}}.glaskugel-instant-item:hover{background:var(--color-bg)}.glaskugel-instant-item--ai{border-top:1px solid var(--color-border);margin-top:.2rem;padding-top:.65rem}.glaskugel-instant-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;background:var(--color-bg);flex-shrink:0}.glaskugel-instant-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.05rem}.glaskugel-instant-title{font-size:.82rem;font-weight:500;color:var(--color-text)}.glaskugel-instant-sub,.glaskugel-instant-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.glaskugel-instant-sub{font-size:.68rem;color:var(--color-muted)}.glaskugel-instant-badge{flex-shrink:0;font-size:.62rem;font-weight:700;padding:.12rem .4rem;border-radius:4px;white-space:nowrap}.glaskugel-instant-chevron{flex-shrink:0;color:var(--color-muted);opacity:0;transition:opacity .12s}.glaskugel-instant-item:hover .glaskugel-instant-chevron{opacity:1}@keyframes glaskugel-slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media (max-width:640px){.glaskugel{padding:1.5rem 1rem}.glaskugel-input{font-size:1.05rem;padding:1rem .75rem}.glaskugel-input-wrapper{padding:0 1rem}}.debug-fab{position:fixed;bottom:1.25rem;right:1.25rem;width:44px;height:44px;border-radius:50%;border:none;background:var(--color-danger);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:7000;box-shadow:0 4px 16px rgba(0,0,0,.25);transition:all .2s ease}.debug-fab:hover{transform:scale(1.08);box-shadow:0 6px 24px rgba(0,0,0,.3)}.debug-panel{position:fixed;bottom:4.5rem;right:1.25rem;width:340px;max-width:calc(100vw - 2rem);background:var(--color-card);border:1px solid var(--color-line);border-radius:12px;box-shadow:0 12px 40px rgba(0,0,0,.2);z-index:7001;padding:1rem;animation:modal-scale-in .15s ease-out}.debug-panel-header{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--color-text);margin-bottom:12px}.debug-field{margin-bottom:8px}.debug-input{width:100%;padding:8px 12px;border:1px solid var(--color-line);border-radius:8px;background:var(--color-soft);color:var(--color-text);font-size:13px;outline:none;transition:border-color .15s}.debug-input:focus{border-color:var(--color-primary)}.debug-textarea{width:100%;padding:8px 12px;border:1px solid var(--color-line);border-radius:8px;background:var(--color-soft);color:var(--color-text);font-size:13px;resize:vertical;outline:none;transition:border-color .15s;font-family:inherit}.debug-textarea:focus{border-color:var(--color-primary)}.debug-hint{font-size:11px;color:var(--color-muted);margin-bottom:10px}.debug-submit{width:100%;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border:none;border-radius:8px;background:var(--color-primary);color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.debug-submit:hover:not(:disabled){opacity:.9}.debug-submit:disabled{opacity:.5;cursor:not-allowed}.debug-sent{text-align:center;padding:1.5rem 1rem;color:var(--color-ok)}.debug-sent p{font-size:15px;font-weight:600;margin:8px 0 4px}.debug-sent span{font-size:12px;color:var(--color-muted)}.briefing-screen{max-width:960px;margin:0 auto;padding:1.5rem 1rem 3rem}.briefing-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;margin-bottom:1.5rem}.briefing-greeting-text{font-size:1.4rem;font-weight:700;color:var(--color-heading);margin:0;min-height:2rem}.briefing-highlights{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.4rem}.briefing-highlight-pill{display:inline-flex;align-items:center;padding:.15rem .6rem;border-radius:999px;font-size:.7rem;font-weight:600;background:#E74C3C14;color:#E74C3C;letter-spacing:.01em}.briefing-search-form{flex-shrink:0;width:280px}.briefing-search-wrapper{display:flex;align-items:center;gap:.5rem;padding:.45rem .75rem;background:var(--color-card);border:1px solid var(--color-border);border-radius:10px;transition:border-color .2s,box-shadow .2s}.briefing-search-wrapper:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(26,115,116,.08)}.briefing-search-icon{color:var(--color-muted);flex-shrink:0}.briefing-search-input{flex:1;border:none;background:none;font-size:.82rem;color:var(--color-text);outline:none;min-width:0}.briefing-search-input::placeholder{color:var(--color-muted);opacity:.7}.briefing-search-submit{display:flex;align-items:center;justify-content:center;background:var(--color-primary);color:white;border:none;border-radius:6px;padding:.25rem;cursor:pointer;transition:background .15s}.briefing-search-submit:hover{background:var(--color-accent)}.briefing-spin{animation:spin .8s linear infinite}.briefing-ai-results{margin-bottom:1.5rem;background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;padding:1rem;animation:briefing-fade-in .2s ease-out}.briefing-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.85rem}@media (max-width:720px){.briefing-grid{grid-template-columns:1fr}.briefing-header{flex-direction:column}.briefing-search-form{width:100%}}.briefing-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;padding:.85rem 1rem;animation:briefing-slide-up .35s ease-out both;transition:box-shadow .2s,border-color .2s}.briefing-card:hover{border-color:var(--color-primary-light,var(--color-border));box-shadow:0 2px 12px rgba(0,0,0,.04)}@keyframes briefing-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes briefing-fade-in{0%{opacity:0}to{opacity:1}}.briefing-card--urgent{border-top:2.5px solid #e74c3c}.briefing-card--personal{border-top:2.5px solid var(--color-primary)}.briefing-card--hot{border-top:2.5px solid #c98549}.briefing-card--upcoming{border-top:2.5px solid #6366f1}.briefing-card--retainer{border-top:2.5px solid var(--color-accent)}.briefing-card--allclear,.briefing-card--done{border-top:2.5px solid var(--color-ok)}.briefing-card--allclear{grid-column:1/-1}.briefing-allclear{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:2rem 1rem;color:var(--color-ok);text-align:center;font-size:.9rem;font-weight:500}.briefing-card-header{display:flex;align-items:center;gap:.4rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--color-muted);margin-bottom:.6rem}.briefing-card-header svg{opacity:.8}.briefing-card--urgent .briefing-card-header{color:#E74C3C}.briefing-card--personal .briefing-card-header{color:var(--color-primary)}.briefing-card--hot .briefing-card-header{color:#C98549}.briefing-card--upcoming .briefing-card-header{color:#6366f1}.briefing-card--retainer .briefing-card-header{color:var(--color-accent)}.briefing-card--done .briefing-card-header{color:var(--color-ok)}.briefing-card-count{margin-left:auto;background:var(--color-bg);padding:.1rem .45rem;border-radius:6px;font-size:.7rem;font-weight:700}.briefing-card-list{display:flex;flex-direction:column;gap:1px}.briefing-task-row{display:flex;align-items:center;gap:.5rem;padding:.45rem .3rem;border-radius:6px;cursor:pointer;transition:background .12s}.briefing-task-row:hover{background:var(--color-bg)}.briefing-task-priority{width:3px;height:24px;border-radius:2px;flex-shrink:0}.briefing-task-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem}.briefing-task-title{font-size:.82rem;font-weight:500;color:var(--color-text)}.briefing-task-meta,.briefing-task-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.briefing-task-meta{font-size:.68rem;color:var(--color-muted)}.briefing-task-badge{flex-shrink:0;font-size:.65rem;font-weight:700;padding:.15rem .4rem;border-radius:4px}.briefing-task-badge--danger{background:#E74C3C14;color:#E74C3C}.briefing-task-badge--info{background:#6366f114;color:#6366f1}.briefing-task-chevron{flex-shrink:0;color:var(--color-muted);opacity:0;transition:opacity .15s}.briefing-task-row:hover .briefing-task-chevron{opacity:1}.briefing-card-link{display:flex;align-items:center;gap:.3rem;margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--color-border);font-size:.7rem;font-weight:600;color:var(--color-primary);cursor:pointer;transition:color .15s}.briefing-card-link:hover{color:var(--color-accent)}.briefing-retainer-row{display:flex;align-items:center;gap:.6rem;padding:.45rem .3rem;border-radius:6px;cursor:pointer;transition:background .12s}.briefing-retainer-row:hover{background:var(--color-bg)}.briefing-retainer-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem}.briefing-retainer-name{font-size:.82rem;font-weight:500;color:var(--color-text)}.briefing-retainer-meta{font-size:.68rem;color:var(--color-muted)}.briefing-retainer-bar{width:48px;height:4px;background:var(--color-border);border-radius:2px;overflow:hidden;flex-shrink:0}.briefing-retainer-bar-fill{height:100%;border-radius:2px;transition:width .4s ease}.briefing-retainer-pct{font-size:.7rem;font-weight:700;width:32px;text-align:right;flex-shrink:0}.briefing-done-row{display:flex;align-items:center;gap:.5rem;padding:.4rem .3rem;border-radius:6px;cursor:pointer;transition:background .12s}.briefing-done-row:hover{background:var(--color-bg)}.briefing-done-icon{color:var(--color-ok);flex-shrink:0}.briefing-done-row .briefing-task-title{text-decoration:line-through;opacity:.7}.briefing-card--skeleton{min-height:120px}.briefing-skeleton-header{height:14px;width:40%;border-radius:4px;margin-bottom:.8rem}.briefing-skeleton-header,.briefing-skeleton-line{background:var(--color-border);animation:briefing-pulse 1.2s ease-in-out infinite}.briefing-skeleton-line{height:10px;width:85%;border-radius:3px;margin-bottom:.6rem}.briefing-skeleton-line--short{width:55%}@keyframes briefing-pulse{0%,to{opacity:.4}50%{opacity:.8}}