.not-found-page{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:var(--space-8)}.not-found-content{text-align:center}.not-found-title{font-size:48px;font-weight:700;color:var(--color-text-primary);margin:0 0 var(--space-2) 0;letter-spacing:-.02em}.not-found-text{font-size:var(--text-body);color:var(--color-text-secondary);margin:0 0 var(--space-6) 0}.dashboard-greeting{margin-bottom:20px}.dashboard-greeting h1{font-size:22px;font-weight:500;color:var(--color-text-primary);margin-bottom:4px}.dashboard-greeting p{font-size:13px;color:var(--color-text-secondary)}.dashboard-metrics{display:flex;gap:16px;margin-bottom:28px}.dashboard-metrics .metric-card{flex:1}.dashboard-project-card{display:block;padding:16px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);text-decoration:none;color:var(--color-text-primary);transition:border-color .15s var(--transition-ease)}.dashboard-project-card:hover{border-color:var(--color-accent);text-decoration:none}.dashboard-project-card+.dashboard-project-card{margin-top:10px}.dashboard-project-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.dashboard-project-card-name{font-size:14px;font-weight:500}.dashboard-project-card-group{font-size:12px;color:var(--color-text-secondary);margin-bottom:10px}.dashboard-project-card-progress{height:4px;background:var(--color-surface-alt);border-radius:2px;overflow:hidden;margin-bottom:6px}.dashboard-project-card-progress-fill{height:100%;background:var(--color-accent);border-radius:2px;transition:width .3s var(--transition-ease)}.dashboard-project-card-completion{font-size:11px;color:var(--color-text-secondary)}.dashboard-quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.dashboard-quick-action{display:flex;flex-direction:column;gap:4px;padding:14px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);text-decoration:none;color:var(--color-text-primary);transition:border-color .15s var(--transition-ease);cursor:pointer}.dashboard-quick-action:hover{border-color:var(--color-accent);text-decoration:none}.dashboard-quick-action-label{font-size:13px;font-weight:500}.dashboard-quick-action-desc{font-size:11px;color:var(--color-text-secondary)}.dashboard-deadline-list{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);overflow:hidden}.dashboard-deadline-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px}.dashboard-deadline-item+.dashboard-deadline-item{border-top:1px solid var(--color-border)}.dashboard-deadline-name{font-size:13px;font-weight:500;color:var(--color-text-primary)}.dashboard-deadline-project{font-size:11px;color:var(--color-text-secondary)}.dashboard-deadline-date{font-size:12px;color:var(--color-text-secondary);white-space:nowrap;margin-left:16px}.dashboard-activity-card{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);padding:16px}.dashboard-panel-section+.dashboard-panel-section{margin-top:24px}.dashboard-quick-action-icon{color:var(--color-accent)}.dashboard-quick-actions-section{margin-top:28px}@media (max-width: 1024px){.dashboard-metrics{display:grid;grid-template-columns:1fr 1fr}}.dashboard-skeleton-greeting{margin-bottom:20px}.dashboard-skeleton-metrics{display:flex;gap:16px;margin-bottom:28px}.dashboard-skeleton-metric{flex:1;height:80px}.dashboard-skeleton-panel-card{height:200px;margin-top:12px}.dashboard-skeleton-panel-heading{margin-top:24px}.dashboard-skeleton-panel-card-sm{height:160px;margin-top:12px}.dashboard-skeleton-project{height:90px;margin-top:10px}@media (max-width: 1024px){.dashboard-skeleton-metrics{display:grid;grid-template-columns:1fr 1fr}}.project-detail-metrics{display:flex;gap:16px;margin-bottom:24px}.project-detail-metrics .metric-card{flex:1}.project-detail-milestones{display:flex;flex-direction:column;gap:12px}.project-detail-panel-section{padding-bottom:20px}.project-detail-panel-section+.project-detail-panel-section{border-top:1px solid var(--color-border);padding-top:20px}.project-detail-kv-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0}.project-detail-kv-label{font-size:13px;color:var(--color-text-secondary)}.project-detail-kv-value{font-size:13px;font-weight:500;color:var(--color-text-primary)}.project-detail-file-row{display:flex;align-items:center;gap:8px;padding:6px 0}.project-detail-file-icon{width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.project-detail-file-icon svg{width:14px;height:14px;color:#fff}.project-detail-file-name{font-size:13px;color:var(--color-text-primary)}.project-detail-top-bar{margin-bottom:20px}.project-detail-description{font-size:13px;color:var(--color-text-secondary);margin-bottom:16px}.project-detail-overflow{position:relative}@media (max-width: 1024px){.project-detail-metrics{flex-direction:row}.project-detail-header{order:1}.project-detail-metrics-section{order:2}.project-detail-milestones{order:3}.project-detail-panel-details{order:4}.project-detail-panel-files{order:5}.project-detail-panel-comments{order:6}.project-detail-panel-activity{order:7}}@media (max-width: 768px){.project-detail-metrics{flex-direction:column}}.project-detail-skeleton-metrics{display:flex;gap:16px;margin-bottom:24px}.project-detail-skeleton-metric{flex:1;height:80px}.client-groups-description{font-size:13px;color:var(--color-text-secondary);margin-bottom:24px}.client-group-card{padding:20px}.client-group-card.inactive{opacity:.55}.client-group-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.client-group-avatar{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#fff;flex-shrink:0}.client-group-card-name{font-size:15px;font-weight:500;color:var(--color-text-primary);margin-bottom:4px}.client-group-card-meta{font-size:12px;color:var(--color-text-secondary);margin-bottom:16px}.client-group-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding-top:16px;border-top:1px solid var(--color-border);margin-bottom:16px;text-align:center}.client-group-stat-value{font-size:18px;font-weight:500;color:var(--color-text-primary)}.client-group-stat-label{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin-top:2px}.client-group-card-actions{display:flex;gap:8px;padding-top:16px;border-top:1px solid var(--color-border)}.client-group-card-actions .btn{flex:1}.client-group-actions-desktop{display:flex}.client-group-overflow{display:none}@media (max-width: 768px){.client-group-actions-desktop{display:none}.client-group-overflow{display:flex;position:relative}}.client-groups-skeleton{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media (max-width: 1024px){.client-groups-skeleton{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.client-groups-skeleton{grid-template-columns:1fr}}.templates-description{font-size:13px;color:var(--color-text-secondary);margin-bottom:24px}.template-card{overflow:hidden}.template-card-preview{background:var(--color-surface-alt);padding:20px;min-height:140px}.template-card-preview-milestone{display:flex;align-items:center;gap:8px;padding:4px 0}.template-card-preview-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.template-card-preview-name{font-size:12px;color:var(--color-text-primary);flex:1}.template-card-preview-count{font-size:11px;color:var(--color-text-secondary)}.template-card-info{padding:16px 20px}.template-card-name{font-size:15px;font-weight:500;color:var(--color-text-primary);margin-bottom:4px}.template-card-desc{font-size:12px;color:var(--color-text-secondary);line-height:1.4;margin-bottom:8px}.template-card-meta{font-size:11px;color:var(--color-text-secondary);display:flex;gap:12px}.template-card-actions{display:flex;gap:8px;padding:12px 20px;border-top:1px solid var(--color-border)}.template-card-actions .btn{flex:1;justify-content:center}.template-card-actions-desktop{display:flex;gap:8px;flex:1}.template-card-actions-desktop .btn{flex:1}.template-card-overflow{display:none}@media (max-width: 768px){.template-card-actions-desktop{display:none}.template-card-overflow{display:flex;position:relative}.template-card-actions{flex-wrap:wrap}}.templates-skeleton{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.templates-skeleton-card{height:280px}@media (max-width: 1024px){.templates-skeleton{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.templates-skeleton{grid-template-columns:1fr}}.admin-page{width:100%}.admin-tab-content{padding:var(--space-6) 0}.admin-tab-loading{display:flex;align-items:center;justify-content:center;padding:var(--space-12)}.admin-section-title{font-size:var(--text-section-heading);font-weight:var(--weight-section-heading);letter-spacing:var(--tracking-section-heading);margin-bottom:var(--space-4)}.admin-filter-bar{display:flex;gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap}.admin-filter-bar .form-input{max-width:200px}.admin-search-input{display:flex;align-items:center;gap:var(--space-2);position:relative}.admin-search-input svg{position:absolute;left:var(--space-3);color:var(--color-text-secondary);pointer-events:none}.admin-search-input .form-input{padding-left:var(--space-8);min-width:220px}.admin-table-wrapper{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-md)}.admin-table{width:100%;border-collapse:collapse;font-size:var(--text-body)}.admin-table th{text-align:left;padding:var(--space-3) var(--space-4);font-size:var(--text-label);font-weight:var(--weight-label);letter-spacing:var(--tracking-label);text-transform:uppercase;color:var(--color-text-secondary);background:var(--color-surface-alt);border-bottom:1px solid var(--color-border);white-space:nowrap}.admin-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);vertical-align:middle}.admin-table tr:last-child td{border-bottom:none}.admin-table tbody tr:hover{background:var(--color-surface-alt)}.admin-table tbody tr.row-selected{background:var(--color-accent-soft)}.admin-pill{display:inline-flex;align-items:center;height:24px;padding:var(--space-1) var(--space-2);font-size:var(--text-caption);font-weight:500;border-radius:var(--radius-pill);background:var(--color-surface-alt);color:var(--color-text-secondary);margin-right:var(--space-1);white-space:nowrap}.admin-pill.type-owner{color:var(--color-warning);background:var(--color-warning-soft)}.admin-pill.type-team{color:#0d9488;background:#0d94881a}.admin-pill.type-client{color:var(--color-accent);background:var(--color-accent-soft)}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:var(--space-2);vertical-align:middle}.status-dot.active{background:var(--color-success)}.status-dot.inactive{background:var(--color-text-secondary)}.user-cell{display:flex;align-items:center;gap:var(--space-3)}.user-avatar-sm{width:32px;height:32px;border-radius:50%;background:var(--color-accent-soft);color:var(--color-accent);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--text-caption);overflow:hidden;flex-shrink:0}.user-avatar-sm img{width:100%;height:100%;object-fit:cover}.user-name{font-weight:500;color:var(--color-text-primary)}.user-email{font-size:var(--text-caption);color:var(--color-text-secondary)}.people-tab .bulk-action-bar{position:static;box-shadow:none;border-top:none;background:var(--color-accent-soft);border-radius:var(--radius-md);margin-bottom:var(--space-4);font-size:var(--text-body);font-weight:500}.invite-composer{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-6);margin-bottom:var(--space-6)}.invite-rows{display:flex;flex-direction:column;gap:var(--space-3)}.invite-row{display:flex;gap:var(--space-3);align-items:center}.invite-row .form-input{flex:1;min-width:0}.invite-row-remove{flex-shrink:0;padding:var(--space-2)!important}.invite-type-toggle{display:flex;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;flex-shrink:0}.type-btn{padding:var(--space-2) var(--space-3);font-size:var(--text-caption);font-weight:500;border:none;background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:all .15s var(--transition-ease);white-space:nowrap}.type-btn.active{background:var(--color-accent);color:var(--color-accent-foreground)}.invite-composer-actions{display:flex;gap:var(--space-3);margin-top:var(--space-3)}.invite-message{margin-top:var(--space-3);min-height:80px}.invite-composer-send{display:flex;justify-content:flex-end;margin-top:var(--space-4)}.invite-history{margin-top:var(--space-6)}.people-drawer-content{display:flex;flex-direction:column;gap:var(--space-6)}.drawer-user-header{display:flex;gap:var(--space-4);align-items:flex-start}.drawer-avatar{width:64px;height:64px;border-radius:50%;background:var(--color-accent-soft);color:var(--color-accent);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--text-page-title);overflow:hidden;flex-shrink:0}.drawer-avatar img{width:100%;height:100%;object-fit:cover}.drawer-user-info{flex:1;min-width:0}.drawer-user-info h3{font-size:var(--text-section-heading);font-weight:var(--weight-section-heading);margin-bottom:var(--space-1)}.drawer-user-title{font-size:var(--text-body);color:var(--color-text-secondary);margin-bottom:var(--space-1)}.drawer-user-email{font-size:var(--text-body);color:var(--color-accent);display:block;margin-bottom:var(--space-2)}.drawer-user-badges{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-caption)}.drawer-section{border-top:1px solid var(--color-border);padding-top:var(--space-4)}.drawer-section-title{font-size:var(--text-card-title);font-weight:var(--weight-card-title);margin-bottom:var(--space-3)}.drawer-groups-list{display:flex;flex-direction:column;gap:var(--space-2)}.drawer-group-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);background:var(--color-surface-alt);border-radius:var(--radius-md);font-size:var(--text-body)}.drawer-add-group{display:flex;gap:var(--space-2);margin-top:var(--space-3)}.drawer-add-group .form-input{flex:1}.roles-matrix .roles-name-col{min-width:180px}.roles-matrix .roles-module-col{text-align:center;width:100px}.roles-matrix .roles-perm-cell{text-align:center}.roles-name-cell .roles-name-inner{display:flex;flex-direction:column;gap:var(--space-1)}.roles-name{font-weight:500;display:flex;align-items:center;gap:var(--space-2)}.roles-name.editable{cursor:pointer}.roles-name.editable:hover{color:var(--color-accent)}.roles-system-badge{font-size:10px;font-weight:600;text-transform:uppercase;color:var(--color-text-secondary);background:var(--color-surface-alt);padding:2px 6px;border-radius:var(--radius-sm);letter-spacing:.05em}.roles-target-type{font-size:var(--text-caption);color:var(--color-text-secondary)}.audit-details{margin-top:var(--space-1)}.audit-diff{font-size:var(--text-caption);color:var(--color-text-secondary);font-style:italic}@media (max-width: 768px){.invite-row{flex-direction:column;align-items:stretch}.invite-row .form-input{max-width:none}.admin-filter-bar{flex-direction:column}.admin-filter-bar .form-input{max-width:none}.drawer-user-header{flex-direction:column;align-items:center;text-align:center}.drawer-user-badges{justify-content:center}.bulk-action-bar{flex-wrap:wrap}}.team-page{display:flex;height:100%;position:relative;overflow:hidden}.team-directory-panel{width:33%;min-width:280px;max-width:380px;border-right:1px solid var(--color-border);overflow-y:auto;display:flex;flex-direction:column}.team-detail-panel{flex:1;overflow-y:auto;position:relative}.team-search{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-4);border-bottom:1px solid var(--color-border);position:sticky;top:0;background:var(--color-surface);z-index:1}.team-search svg{color:var(--color-text-secondary);flex-shrink:0}.team-search .form-input{flex:1;border:none;background:transparent;padding:var(--space-1) 0;font:var(--text-body)}.team-search .form-input:focus{outline:none;box-shadow:none}.team-sections{flex:1;overflow-y:auto}.team-section{border-bottom:1px solid var(--color-border)}.team-section-header{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);background:var(--color-surface-alt);border:none;cursor:pointer;font:var(--text-label);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.02em;text-align:left;transition:background .2s var(--transition-ease)}.team-section-header:hover{background:var(--color-border)}.team-section-header:focus-visible{outline:2px solid var(--color-accent);outline-offset:-2px}.team-section-header svg{flex-shrink:0;color:var(--color-text-secondary)}.team-section-title{flex:1}.team-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 var(--space-1);border-radius:var(--radius-pill);background:var(--color-accent-soft);color:var(--color-accent);font:var(--text-caption);font-weight:600}.team-section-content{padding:var(--space-1) 0}.team-section-empty{padding:var(--space-3) var(--space-4);font:var(--text-body);color:var(--color-text-secondary);margin:0}.team-person-row{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-2) var(--space-4);background:transparent;border:none;border-left:3px solid transparent;cursor:pointer;text-align:left;transition:background .2s var(--transition-ease),border-color .2s var(--transition-ease)}.team-person-row:hover{background:var(--color-surface-alt)}.team-person-row:focus-visible{outline:2px solid var(--color-accent);outline-offset:-2px}.team-person-row.selected{background:var(--color-accent-soft);border-left-color:var(--color-accent)}.team-initials-wrapper{position:relative;flex-shrink:0}.team-initials{width:32px;height:32px;border-radius:50%;background:var(--color-accent-soft);color:var(--color-accent);display:flex;align-items:center;justify-content:center;font:var(--text-caption);font-weight:600;overflow:hidden}.team-avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.team-online-dot{position:absolute;top:-1px;right:-1px;width:8px;height:8px;border-radius:50%;background:var(--color-success);border:2px solid var(--color-surface)}.team-online-dot-inline{position:static;display:inline-block;border:none;margin-right:var(--space-1);vertical-align:middle}.team-person-info{display:flex;flex-direction:column;min-width:0}.team-person-name{font:var(--text-body);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.team-person-title{font:var(--text-caption);color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.team-skeleton-rows{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.team-skeleton-row{display:flex;align-items:center;gap:var(--space-3)}.person-detail{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4)}.person-header{display:flex;gap:var(--space-4);align-items:flex-start}.person-avatar-large{width:72px;height:72px;border-radius:50%;background:var(--color-accent-soft);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.person-avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.person-avatar-initials{font-size:24px;font-weight:600;color:var(--color-accent)}.person-header-info{display:flex;flex-direction:column;gap:var(--space-1);min-width:0}.person-name{font:var(--text-section-heading);color:var(--color-text-primary);margin:0}.person-title{font:var(--text-body);color:var(--color-text-secondary);margin:0}.person-header-meta{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap;margin-top:var(--space-1)}.person-status{font:var(--text-caption);color:var(--color-text-secondary);display:flex;align-items:center}.person-status.online{color:var(--color-success)}.person-contact-info{display:flex;flex-direction:column;gap:var(--space-2);padding-top:var(--space-4);border-top:1px solid var(--color-border)}.person-contact-row{display:flex;align-items:center;gap:var(--space-2);font:var(--text-body)}.person-contact-row svg{color:var(--color-text-secondary);flex-shrink:0}.person-contact-row a{color:var(--color-accent);text-decoration:none}.person-contact-row a:hover{text-decoration:underline}.person-section-label{font:var(--text-label);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.02em;margin:0 0 var(--space-2) 0}.person-section-empty{font:var(--text-body);color:var(--color-text-secondary);margin:0}.person-groups{padding-top:var(--space-4);border-top:1px solid var(--color-border)}.person-group-pills{display:flex;flex-wrap:wrap;gap:var(--space-2)}.person-group-pill{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-pill);background:var(--color-accent-soft);color:var(--color-accent);font:var(--text-caption);font-weight:500}.person-projects{padding-top:var(--space-4);border-top:1px solid var(--color-border)}.person-project-list{display:flex;flex-direction:column;gap:var(--space-2)}.person-project-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2);border-radius:var(--radius-sm);transition:background .2s var(--transition-ease)}.person-project-row:hover{background:var(--color-surface-alt)}.person-project-info{display:flex;flex-direction:column;gap:2px;min-width:0}.person-project-name{font:var(--text-body);color:var(--color-text-primary)}.person-project-group{font:var(--text-caption);color:var(--color-text-secondary)}.person-activity{padding-top:var(--space-4);border-top:1px solid var(--color-border)}.person-activity-list{display:flex;flex-direction:column;gap:var(--space-2)}.person-activity-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.person-activity-action{font:var(--text-body);color:var(--color-text-primary);min-width:0}.person-activity-target{color:var(--color-text-secondary)}.person-activity-time{font:var(--text-caption);color:var(--color-text-secondary);white-space:nowrap;flex-shrink:0}.person-activity-empty{display:flex;align-items:center;gap:var(--space-2);font:var(--text-body);color:var(--color-text-secondary)}.person-activity-empty svg{color:var(--color-text-secondary)}.person-skeleton-list{display:flex;flex-direction:column;gap:var(--space-2)}.person-admin-actions{display:flex;gap:var(--space-2);padding-top:var(--space-4);border-top:1px solid var(--color-border)}.person-admin-actions .btn{display:inline-flex;align-items:center;gap:var(--space-1)}.team-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:var(--space-6);text-align:center}.team-summary-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.team-summary-icon{color:var(--color-text-secondary)}.team-summary-title{font:var(--text-section-heading);color:var(--color-text-primary);margin:0}.team-summary-stats{font:var(--text-body);color:var(--color-text-primary);margin:0}.team-summary-hint{font:var(--text-body);color:var(--color-text-secondary);margin:0;max-width:360px}.team-quick-pick{margin-top:var(--space-6);display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.team-quick-pick-label{font:var(--text-label);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.02em}.team-quick-pick-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);cursor:pointer;transition:background .2s var(--transition-ease),border-color .2s var(--transition-ease)}.team-quick-pick-row:hover{background:var(--color-surface-alt);border-color:var(--color-accent)}.team-quick-pick-row:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.team-back-button{display:none}.team-directory-panel .empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6);text-align:center}@media (max-width: 768px){.team-page{position:relative}.team-directory-panel,.team-detail-panel{width:100%;min-width:unset;max-width:unset;position:absolute;top:0;left:0;bottom:0;transition:transform .2s var(--transition-ease)}.team-directory-panel{border-right:none;transform:translate(0);z-index:1}.team-detail-panel{transform:translate(100%);z-index:2;background:var(--color-surface)}.team-page.show-detail .team-directory-panel{transform:translate(-100%)}.team-page.show-detail .team-detail-panel{transform:translate(0)}.team-back-button{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:transparent;border:none;cursor:pointer;color:var(--color-text-primary);position:sticky;top:0;z-index:1;background:var(--color-surface)}.team-back-button:hover{background:var(--color-surface-alt)}.team-back-button:focus-visible{outline:2px solid var(--color-accent);outline-offset:-2px}.person-detail{padding:var(--space-4)}.person-header{flex-direction:column;align-items:center;text-align:center}.person-header-meta{justify-content:center}}.settings-layout{display:flex;gap:var(--space-6);max-width:1200px;padding:var(--space-6)}.settings-nav{position:sticky;top:calc(var(--header-height) + var(--space-6));width:200px;min-width:200px;height:fit-content;display:flex;flex-direction:column;gap:var(--space-1)}.settings-nav-item{display:block;padding:var(--space-2) var(--space-3);font-size:var(--text-body);font-weight:var(--weight-body);color:var(--color-text-secondary);text-decoration:none;border-radius:var(--radius-sm);border-left:2px solid transparent;transition:all .15s var(--transition-ease);cursor:pointer}.settings-nav-item:hover{color:var(--color-text-primary);background:var(--color-surface-alt)}.settings-nav-item.active{color:var(--color-accent);font-weight:500;border-left-color:var(--color-accent);background:var(--color-accent-soft)}.settings-nav-pill-bar{display:none;overflow-x:auto;gap:var(--space-2);padding:var(--space-3) 0;margin-bottom:var(--space-4);-webkit-overflow-scrolling:touch;scrollbar-width:none}.settings-nav-pill-bar::-webkit-scrollbar{display:none}.settings-nav-pill{flex-shrink:0;padding:var(--space-2) var(--space-3);font-family:var(--font-body);font-size:var(--text-secondary);font-weight:var(--weight-body);color:var(--color-text-secondary);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-pill);cursor:pointer;white-space:nowrap;transition:all .15s var(--transition-ease)}.settings-nav-pill:hover{color:var(--color-text-primary);border-color:var(--color-text-secondary)}.settings-nav-pill.active{color:var(--color-accent-foreground);background:var(--color-accent);border-color:var(--color-accent);font-weight:500}.settings-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-6)}.settings-section-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6)}.settings-section-title{font-family:var(--font-heading);font-size:var(--text-section-heading);font-weight:var(--weight-section-heading);letter-spacing:var(--tracking-section-heading);color:var(--color-text-primary);margin-bottom:var(--space-5)}.settings-section-subtitle{font-size:var(--text-secondary);color:var(--color-text-secondary);margin-top:calc(-1 * var(--space-3));margin-bottom:var(--space-5)}.settings-section-divider{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) 0}.settings-section-divider:before,.settings-section-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.settings-section-divider span{font-size:var(--text-label);font-weight:var(--weight-label);letter-spacing:var(--tracking-label);color:var(--color-text-secondary);text-transform:uppercase;white-space:nowrap}.settings-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}.settings-form-grid .form-group.full-width{grid-column:1 / -1}.read-only-context{border-top:1px solid var(--color-border);padding-top:var(--space-5);margin-top:var(--space-5);display:flex;flex-wrap:wrap;gap:var(--space-5)}.read-only-context-item{display:flex;flex-direction:column;gap:var(--space-1)}.read-only-context-label{font-size:var(--text-label);font-weight:var(--weight-label);letter-spacing:var(--tracking-label);color:var(--color-text-secondary);text-transform:uppercase}.read-only-context-value{font-size:var(--text-body);color:var(--color-text-primary)}.read-only-context-pills{display:flex;flex-wrap:wrap;gap:var(--space-1)}.notification-table{width:100%;border-collapse:collapse}.notification-table th{font-size:var(--text-label);font-weight:var(--weight-label);letter-spacing:var(--tracking-label);color:var(--color-text-secondary);text-transform:uppercase;text-align:left;padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border)}.notification-table td{padding:var(--space-3);border-bottom:1px solid var(--color-border);font-size:var(--text-body);vertical-align:middle}.notification-table tr:last-child td{border-bottom:none}.notification-event-name{font-weight:500;color:var(--color-text-primary)}.notification-org-default{font-size:var(--text-caption);color:var(--color-text-secondary)}.integration-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-4)}.integration-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);transition:border-color .2s var(--transition-ease)}.integration-card:hover{border-color:var(--color-text-secondary)}.integration-card-header{display:flex;align-items:center;gap:var(--space-3)}.integration-card-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);background:var(--color-surface-alt);color:var(--color-text-secondary)}.integration-card-info{flex:1;min-width:0}.integration-card-name{font-size:var(--text-card-title);font-weight:var(--weight-card-title);color:var(--color-text-primary)}.integration-card-description{font-size:var(--text-caption);color:var(--color-text-secondary)}.integration-card-status{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-caption)}.integration-status-dot{width:8px;height:8px;border-radius:50%}.integration-status-dot.connected{background:var(--color-success)}.integration-status-dot.disconnected{background:var(--color-border)}.integration-status-dot.error{background:var(--color-danger)}.integration-card-actions{display:flex;gap:var(--space-2);margin-top:var(--space-3)}.integration-card-expanded{border-top:1px solid var(--color-border);margin-top:var(--space-4);padding-top:var(--space-4);animation:settings-fade-in .2s var(--transition-ease)}@keyframes settings-fade-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.integration-sync-log{margin-top:var(--space-4)}.integration-sync-log-title{font-size:var(--text-label);font-weight:var(--weight-label);letter-spacing:var(--tracking-label);text-transform:uppercase;color:var(--color-text-secondary);margin-bottom:var(--space-2)}.integration-sync-entry{display:flex;justify-content:space-between;padding:var(--space-1) 0;font-size:var(--text-caption);color:var(--color-text-secondary)}.settings-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.settings-confirm-dialog{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-6);max-width:420px;width:90%}.settings-confirm-title{font-family:var(--font-heading);font-size:var(--text-card-title);font-weight:var(--weight-card-title);color:var(--color-text-primary);margin-bottom:var(--space-3)}.settings-confirm-text{font-size:var(--text-body);color:var(--color-text-secondary);line-height:var(--leading-body);margin-bottom:var(--space-6)}.settings-confirm-actions{display:flex;justify-content:flex-end;gap:var(--space-3)}.digest-section{margin-top:var(--space-5);padding-top:var(--space-5);border-top:1px solid var(--color-border)}.digest-section-title{font-size:var(--text-card-title);font-weight:var(--weight-card-title);color:var(--color-text-primary);margin-bottom:var(--space-4)}.digest-controls{display:flex;flex-wrap:wrap;gap:var(--space-4);align-items:flex-end}.settings-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-5)}.settings-section-header .settings-section-title{margin-bottom:0}.settings-section-header-action{font-size:var(--text-secondary);color:var(--color-accent);background:none;border:none;cursor:pointer;font-family:var(--font-body);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);transition:background .15s var(--transition-ease)}.settings-section-header-action:hover{background:var(--color-accent-soft)}.branding-previews{display:flex;gap:var(--space-6);align-items:flex-end;margin-bottom:var(--space-5)}.branding-preview{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.branding-preview-label{font-size:var(--text-caption);color:var(--color-text-secondary)}.branding-colors{display:flex;gap:var(--space-4);margin-top:var(--space-4)}.branding-color-preview{display:flex;align-items:center;gap:var(--space-3)}.branding-color-swatch{width:40px;height:40px;border-radius:var(--radius-md);border:1px solid var(--color-border)}.logo-upload-area{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);border:2px dashed var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:border-color .2s var(--transition-ease)}.logo-upload-area:hover{border-color:var(--color-accent)}.logo-upload-area.disabled{cursor:not-allowed;opacity:.6}.logo-upload-preview{display:flex;align-items:center;justify-content:center;width:64px;height:64px;background:var(--color-surface-alt);border-radius:var(--radius-md);overflow:hidden}.logo-upload-preview img{max-width:100%;max-height:100%;object-fit:contain}.logo-upload-text{font-size:var(--text-body);color:var(--color-text-secondary)}.logo-upload-text strong{color:var(--color-accent)}.form-input-locked{position:relative}.form-input-locked .form-input{padding-right:var(--space-8)}.form-input-lock-icon{position:absolute;right:var(--space-3);top:50%;transform:translateY(-50%);color:var(--color-text-secondary)}.ip-warning{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--color-warning-soft);border:1px solid var(--color-warning);border-radius:var(--radius-md);font-size:var(--text-secondary);color:var(--color-text-primary);margin-top:var(--space-2)}.invoice-prefix-preview{font-size:var(--text-secondary);color:var(--color-text-secondary);margin-top:var(--space-1)}.invoice-prefix-preview code{font-family:var(--font-mono);background:var(--color-surface-alt);padding:2px var(--space-1);border-radius:var(--radius-sm)}.char-count{font-size:var(--text-caption);color:var(--color-text-secondary);text-align:right;margin-top:var(--space-1)}.settings-note{font-size:var(--text-secondary);color:var(--color-text-secondary);font-style:italic;margin-top:var(--space-3)}@media (max-width: 1024px){.settings-nav{display:none}.settings-nav-pill-bar{display:flex}.settings-layout{flex-direction:column}}@media (max-width: 768px){.settings-layout{padding:var(--space-4)}.settings-form-grid,.integration-grid{grid-template-columns:1fr}.branding-previews{flex-wrap:wrap}.read-only-context{flex-direction:column}.digest-controls{flex-direction:column;align-items:stretch}.settings-section-card{padding:var(--space-4)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary: #0F172A;--color-primary-foreground: #F8FAFC;--color-accent: #0EAFC7;--color-accent-foreground: #FFFFFF;--color-surface: #FFFFFF;--color-surface-alt: #F1F5F9;--color-border: #E2E8F0;--color-text-primary: #0F172A;--color-text-secondary: #64748B;--color-success: #10B981;--color-warning: #F59E0B;--color-danger: #EF4444;--color-sidebar: #0F172A;--color-sidebar-foreground: #F8FAFC;--font-heading: "DM Sans", sans-serif;--font-body: "DM Sans", sans-serif;--font-mono: "Space Mono", monospace;--transition-ease: cubic-bezier(.16, 1, .3, 1);--sidebar-width: 260px;--header-height: 64px;--text-page-title: 24px;--weight-page-title: 600;--tracking-page-title: -.02em;--text-section-heading: 18px;--weight-section-heading: 600;--tracking-section-heading: -.01em;--text-card-title: 16px;--weight-card-title: 600;--text-body: 14px;--weight-body: 400;--leading-body: 1.5;--text-secondary: 13px;--weight-secondary: 400;--text-label: 12px;--weight-label: 500;--tracking-label: .02em;--text-caption: 12px;--weight-caption: 400;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 28px;--space-8: 32px;--space-9: 36px;--space-10: 40px;--space-11: 44px;--space-12: 48px;--color-accent-soft: rgba(14, 175, 199, .1);--color-success-soft: rgba(16, 185, 129, .1);--color-warning-soft: rgba(245, 158, 11, .1);--color-danger-soft: rgba(239, 68, 68, .1);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-pill: 100px}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);color:var(--color-text-primary);background:var(--color-surface);line-height:1.5}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;line-height:1.2}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}a{color:var(--color-accent);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;display:block}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:10px;font-family:var(--font-body);font-size:.938rem;font-weight:500;cursor:pointer;border:none;transition:all .2s var(--transition-ease);line-height:1.4}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-accent);color:var(--color-accent-foreground)}.btn-primary:hover:not(:disabled){filter:brightness(.9);transform:translateY(-1px);box-shadow:0 4px 12px #0eafc74d}.btn-outline{background:transparent;color:var(--color-accent);border:1.5px solid var(--color-accent)}.btn-outline:hover:not(:disabled){background:var(--color-accent);color:var(--color-accent-foreground)}.btn-ghost{background:transparent;color:var(--color-text-secondary);padding:8px}.btn-ghost:hover{background:var(--color-surface-alt);color:var(--color-text-primary)}.btn-danger{color:var(--color-danger)}.btn-danger:hover{background:var(--color-danger-soft);color:var(--color-danger)}.btn-full{width:100%}.input{width:100%;padding:10px 14px;border:1.5px solid var(--color-border);border-radius:10px;font-family:var(--font-body);font-size:.938rem;color:var(--color-text-primary);background:var(--color-surface);transition:border-color .2s var(--transition-ease),box-shadow .2s var(--transition-ease);outline:none}.input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #0eafc726}.input::placeholder{color:var(--color-text-secondary)}.input-group{display:flex;flex-direction:column;gap:6px}.input-group label{font-size:.875rem;font-weight:500;color:var(--color-text-primary)}.auth-layout{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}.auth-brand{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--color-primary);color:var(--color-primary-foreground);padding:40px;position:relative;overflow:hidden}.auth-brand-logo{width:120px;margin-bottom:24px;position:relative;z-index:1}.auth-brand-title{font-size:2rem;font-weight:700;color:var(--color-accent);margin-bottom:8px;position:relative;z-index:1}.auth-brand-tagline{font-size:1.125rem;opacity:.8;position:relative;z-index:1}.auth-brand-circle{position:absolute;width:400px;height:400px;border-radius:50%;background:var(--color-accent);opacity:.06;bottom:-100px;right:-100px}.auth-form-panel{display:flex;align-items:center;justify-content:center;padding:40px}.auth-form{width:100%;max-width:400px}.auth-form h1{margin-bottom:8px}.auth-form-subtitle{color:var(--color-text-secondary);margin-bottom:32px}.auth-form .input-group{margin-bottom:20px}.auth-form .btn{margin-top:8px}.auth-form-footer{text-align:center;margin-top:24px;font-size:.875rem;color:var(--color-text-secondary)}.auth-form-footer a{font-weight:500}.auth-form-link{display:block;text-align:right;font-size:.875rem;margin-bottom:8px}.auth-error{background:#ef444414;color:var(--color-danger);padding:10px 14px;border-radius:8px;font-size:.875rem;margin-bottom:16px}.auth-success{background:#10b98114;color:var(--color-success);padding:10px 14px;border-radius:8px;font-size:.875rem;margin-bottom:16px}.auth-readonly-email{padding:10px 14px;background:var(--color-surface-alt);border-radius:10px;font-size:.938rem;color:var(--color-text-secondary);margin-bottom:20px}@media (max-width: 768px){.auth-layout{grid-template-columns:1fr}.auth-brand{display:none}}.dashboard-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--color-sidebar);color:var(--color-sidebar-foreground);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:50;transition:transform .3s var(--transition-ease)}.sidebar-header{display:flex;align-items:center;gap:12px;padding:20px 20px 16px}.sidebar-logo{width:48px}.sidebar-title{font-size:1.25rem;font-weight:700;color:var(--color-accent)}.sidebar-close{display:none;margin-left:auto;background:none;border:none;color:var(--color-sidebar-foreground);cursor:pointer;padding:4px;opacity:.7}.sidebar-close:hover{opacity:1}.sidebar-nav{flex:1;padding:8px 12px;overflow-y:auto}.sidebar-divider{height:1px;background:#ffffff1a;margin:12px 8px}.sidebar-link{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;color:var(--color-sidebar-foreground);opacity:.7;font-size:.938rem;font-weight:500;text-decoration:none;transition:all .15s var(--transition-ease)}.sidebar-link:hover{opacity:1;background:#ffffff14;text-decoration:none}.sidebar-link.active{opacity:1;background:var(--color-accent);color:var(--color-accent-foreground)}.sidebar-link svg{width:20px;height:20px;flex-shrink:0}.sidebar-user{padding:16px 20px;border-top:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:12px}.sidebar-avatar{width:36px;height:36px;border-radius:50%;background:var(--color-accent);color:var(--color-accent-foreground);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.sidebar-user-name{font-size:.875rem;font-weight:500}.sidebar-user-role{font-size:.75rem;opacity:.6;text-transform:capitalize}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:40}@media (max-width: 1024px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-close,.sidebar-backdrop.visible{display:block}}.header{height:var(--header-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;padding:0 24px;gap:16px;position:fixed;top:0;right:0;left:var(--sidebar-width);z-index:30}.header-menu-btn{display:none;background:none;border:none;color:var(--color-text-primary);cursor:pointer;padding:4px}.header-search{flex:1;max-width:400px}.header-search .input{background:var(--color-surface-alt);border-color:transparent}.header-search .input:focus{background:var(--color-surface);border-color:var(--color-accent)}.header-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.header-notification{position:relative;background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:8px;border-radius:8px;transition:background .15s}.header-notification:hover{background:var(--color-surface-alt);color:var(--color-text-primary)}.header-notification-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--color-danger)}.header-user-btn{display:flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;padding:4px;border-radius:8px;transition:background .15s}.header-user-btn:hover{background:var(--color-surface-alt)}.header-avatar{width:32px;height:32px;border-radius:50%;background:var(--color-accent);color:var(--color-accent-foreground);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.813rem}.header-dropdown{position:absolute;top:calc(var(--header-height) - 4px);right:24px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;box-shadow:0 8px 24px #0000001f;min-width:180px;padding:6px;z-index:100;animation:dropdown-in .15s var(--transition-ease)}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.header-dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:6px;font-size:.875rem;color:var(--color-text-primary);cursor:pointer;background:none;border:none;width:100%;text-align:left;font-family:var(--font-body);text-decoration:none;transition:background .1s}.header-dropdown-item:hover{background:var(--color-surface-alt);text-decoration:none}.header-dropdown-item.danger{color:var(--color-danger)}@media (max-width: 1024px){.header{left:0}.header-menu-btn{display:block}}.dashboard-content{margin-left:var(--sidebar-width);margin-top:var(--header-height);padding:32px;background:var(--color-surface);min-height:calc(100vh - var(--header-height))}.dashboard-content-inner{max-width:1600px;margin:0 auto}@media (max-width: 1024px){.dashboard-content{margin-left:0}}.metric-card{background:var(--color-surface-alt);border-radius:var(--radius-md);padding:16px 18px}.metric-card-label{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin-bottom:4px}.metric-card-value{font-size:24px;font-weight:500;color:var(--color-text-primary);line-height:1.2}.metric-card-subtitle{font-size:11px;color:var(--color-text-secondary);margin-top:2px}.section-header{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin-bottom:12px}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color .15s var(--transition-ease)}.card:hover{border-color:#cbd5e1}.card-clickable{cursor:pointer}.card-clickable:hover{border-color:var(--color-accent)}.overflow-menu-trigger{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text-secondary)}.overflow-menu-trigger:hover{background:var(--color-surface-alt)}.overflow-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50}.overflow-menu-dropdown{position:absolute;right:0;top:100%;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 8px 24px #0000001f;min-width:160px;padding:4px;z-index:51;animation:dropdown-in .15s var(--transition-ease)}.overflow-menu-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:var(--radius-sm);font-size:13px;color:var(--color-text-primary);cursor:pointer;background:none;border:none;width:100%;text-align:left;font-family:var(--font-body);min-height:44px}.overflow-menu-item:hover{background:var(--color-surface-alt)}.overflow-menu-item.danger{color:var(--color-danger)}.two-column-layout{display:flex;gap:0;min-height:calc(100vh - var(--header-height) - 64px)}.two-column-primary{flex:1;min-width:0}.two-column-panel{width:340px;flex-shrink:0;border-left:1px solid var(--color-border);padding:24px;overflow-y:auto}.two-column-full-width{width:100%}.card-grid-layout{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.add-card{border:1.5px dashed var(--color-border);border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer;background:none;min-height:200px;transition:border-color .15s,background .15s;font-family:var(--font-body);color:var(--color-text-secondary);font-size:13px;font-weight:500}.add-card:hover{border-color:var(--color-accent);background:#0eafc708}.add-card-icon{width:40px;height:40px;border-radius:50%;border:1.5px dashed var(--color-border);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary)}.activity-item{display:flex;gap:10px;align-items:flex-start;padding:8px 0}.activity-avatar{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;flex-shrink:0;color:#fff}.activity-text{font-size:12px;color:var(--color-text-primary);line-height:1.4}.activity-text strong{font-weight:600}.activity-timestamp{font-size:10px;color:var(--color-text-secondary);margin-top:2px}.header-left{flex:1;min-width:0}.header-page-info{display:flex;align-items:center}.header-page-title{font-size:16px;font-weight:500;color:var(--color-text-primary);margin:0}.header-breadcrumb{display:flex;align-items:center;gap:0;font-size:14px}.header-breadcrumb-item{display:flex;align-items:center;gap:4px}.header-breadcrumb-link{color:var(--color-text-secondary);text-decoration:none}.header-breadcrumb-link:hover{color:var(--color-accent);text-decoration:none}.header-breadcrumb-sep{color:var(--color-text-secondary);opacity:.5;margin:0 2px}.header-breadcrumb-current{color:var(--color-text-primary);font-weight:500}@media (max-width: 1024px){.two-column-layout{flex-direction:column}.two-column-panel{width:100%;border-left:none;border-top:1px solid var(--color-border)}.card-grid-layout{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.card-grid-layout{grid-template-columns:1fr}}.spinner-container{display:flex;align-items:center;justify-content:center;min-height:100vh}.spinner{width:36px;height:36px;border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes skeleton-pulse{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.skeleton{background:linear-gradient(90deg,var(--color-surface-alt) 0%,var(--color-border) 50%,var(--color-surface-alt) 100%);background-size:200px 100%;animation:skeleton-pulse 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}.skeleton-text{height:14px;width:100%;margin-bottom:8px}.skeleton-group .skeleton-text:last-child{width:60%}.skeleton-heading{height:24px;width:40%;margin-bottom:16px}.skeleton-card{height:120px;border-radius:var(--radius-lg)}.skeleton-circle{border-radius:50%}.skeleton-badge{height:24px;width:80px;border-radius:var(--radius-pill)}.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column-reverse;gap:8px;z-index:1000;pointer-events:none}.toast{pointer-events:auto;background:var(--color-surface);border:1px solid var(--color-border);border-left:4px solid;border-radius:var(--radius-md);padding:12px 16px;box-shadow:0 8px 24px #0000001f;display:flex;align-items:flex-start;gap:12px;min-width:320px;max-width:420px;animation:toast-in .2s var(--transition-ease)}.toast-error{border-left-color:var(--color-danger)}.toast-success{border-left-color:var(--color-success)}.toast-warning{border-left-color:var(--color-warning)}.toast-info{border-left-color:var(--color-accent)}.toast-icon{flex-shrink:0;width:20px;height:20px}.toast-error .toast-icon{color:var(--color-danger)}.toast-success .toast-icon{color:var(--color-success)}.toast-warning .toast-icon{color:var(--color-warning)}.toast-info .toast-icon{color:var(--color-accent)}.toast-content{flex:1;font-size:var(--text-body)}.toast-title{font-weight:600;font-size:var(--text-body);margin-bottom:2px}.toast-message{color:var(--color-text-secondary);font-size:var(--text-secondary)}.toast-close{flex-shrink:0;background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:4px;border-radius:var(--radius-sm);transition:background .15s}.toast-close:hover{background:var(--color-surface-alt)}@keyframes toast-in{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.toast-exit{animation:toast-out .15s var(--transition-ease) forwards}@keyframes toast-out{to{opacity:0;transform:translate(16px)}}@media (max-width: 768px){.toast-container{left:16px;right:16px;bottom:16px}.toast{min-width:0;max-width:none}}.status-badge{display:inline-flex;align-items:center;height:24px;padding:4px 10px;font-size:12px;font-weight:500;border-radius:var(--radius-pill);white-space:nowrap;line-height:1}.status-badge-draft,.status-badge-not-started{color:var(--color-text-secondary);background:var(--color-surface-alt)}.status-badge-in-progress,.status-badge-open,.status-badge-in-review,.status-badge-pending{color:var(--color-warning);background:var(--color-warning-soft)}.status-badge-revision,.status-badge-overdue{color:var(--color-danger);background:var(--color-danger-soft)}.status-badge-approved,.status-badge-paid,.status-badge-completed{color:var(--color-success);background:var(--color-success-soft)}.status-badge-sent{color:var(--color-accent);background:var(--color-accent-soft)}.status-badge-void{color:var(--color-text-secondary);background:var(--color-surface-alt)}.status-badge-viewed{color:var(--color-accent);background:var(--color-accent-soft)}.status-badge-accepted{color:var(--color-success);background:var(--color-success-soft)}.status-badge-expired{color:var(--color-warning);background:var(--color-warning-soft)}.status-badge-revoked{color:var(--color-danger);background:var(--color-danger-soft)}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:200;display:flex;justify-content:flex-end}.drawer{position:relative;height:100%;background:var(--color-surface);box-shadow:-4px 0 24px #0000001f;display:flex;flex-direction:column;transform:translate(100%);transition:transform .25s var(--transition-ease)}.drawer.open{transform:translate(0)}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);flex-shrink:0}.drawer-title{font-size:var(--text-section-heading);font-weight:var(--weight-section-heading)}.drawer-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-md);transition:all .15s var(--transition-ease)}.drawer-close:hover{background:var(--color-surface-alt);color:var(--color-text-primary)}.drawer-body{flex:1;overflow-y:auto;padding:var(--space-6);transition:opacity .15s var(--transition-ease)}.tabs-bar{display:flex;gap:var(--space-1);border-bottom:1px solid var(--color-border);position:sticky;top:var(--header-height);background:var(--color-surface);z-index:10;transition:box-shadow .2s var(--transition-ease)}.tabs-bar.scrolled{box-shadow:0 1px 3px #00000014}.tab{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border:none;background:transparent;color:var(--color-text-secondary);font-family:var(--font-body);font-size:var(--text-body);font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s var(--transition-ease);white-space:nowrap;min-height:44px}.tab:hover{color:var(--color-text-primary);background:var(--color-surface-alt)}.tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent)}@media (max-width: 768px){.tab-label{display:none}.tab{padding:var(--space-3);justify-content:center;flex:1}}.pagination{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4) 0;flex-wrap:wrap}.pagination-info{font-size:var(--text-secondary);color:var(--color-text-secondary)}.pagination-pages{display:flex;align-items:center;gap:var(--space-1)}.btn-pagination{min-width:36px;min-height:36px;padding:var(--space-1) var(--space-2)!important;font-size:var(--text-body);border-radius:var(--radius-md)}.btn-pagination.active{background:var(--color-accent);color:var(--color-accent-foreground)}.pagination-ellipsis{padding:0 var(--space-2);color:var(--color-text-secondary)}.pagination-size select{padding:var(--space-1) var(--space-2);font-size:var(--text-secondary);max-width:120px}.permission-matrix{width:100%}.permission-matrix-reset{display:inline-block;margin-bottom:var(--space-3);padding:0;border:none;background:none;color:var(--color-accent);font-size:var(--text-body);font-weight:500;cursor:pointer;text-decoration:underline}.permission-matrix-reset:hover{color:var(--color-text-primary)}.permission-matrix-grid{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.permission-matrix-header{display:grid;grid-template-columns:1.5fr repeat(4,1fr);background:var(--color-surface-alt);border-bottom:1px solid var(--color-border)}.permission-matrix-module-header,.permission-matrix-level-header{padding:var(--space-2) var(--space-3);font-size:var(--text-label);font-weight:var(--weight-label);letter-spacing:var(--tracking-label);text-transform:uppercase;color:var(--color-text-secondary)}.permission-matrix-level-header{text-align:center}.permission-matrix-row{display:grid;grid-template-columns:1.5fr repeat(4,1fr);border-bottom:1px solid var(--color-border)}.permission-matrix-row:last-child{border-bottom:none}.permission-matrix-module{padding:var(--space-2) var(--space-3);font-size:var(--text-body);font-weight:500;display:flex;align-items:center}.permission-cell{display:flex;align-items:center;justify-content:center;padding:var(--space-2);border:none;background:transparent;cursor:pointer;font-size:var(--text-body);font-weight:400;min-height:40px;transition:background .15s var(--transition-ease)}.permission-cell:hover:not(:disabled){background:var(--color-surface-alt)}.permission-cell:disabled{cursor:default}.permission-cell.active.level-hidden{color:var(--color-text-secondary)}.permission-cell.active.level-view{color:var(--color-text-secondary);font-weight:500}.permission-cell.active.level-contribute{color:var(--color-text-primary);font-weight:500}.permission-cell.active.level-manage{color:var(--color-accent);font-weight:600}.permission-cell.overridden{border-left:2px solid var(--color-accent)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;display:flex;align-items:center;justify-content:center;animation:fade-in .15s var(--transition-ease)}.modal{background:var(--color-surface);border-radius:var(--radius-lg);width:90%;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:modal-in .15s var(--transition-ease)}.modal:focus{outline:none}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-6);border-bottom:1px solid var(--color-border)}.modal-title{font-size:var(--text-section-heading);font-weight:var(--weight-section-heading);letter-spacing:var(--tracking-section-heading)}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text-secondary);transition:background .15s var(--transition-ease)}.modal-close:hover{background:var(--color-surface-alt)}.modal-body{padding:var(--space-6)}@keyframes modal-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@media (max-width: 768px){.modal{width:100%;max-height:100vh;border-radius:0}}.page-title{font-size:var(--text-page-title);font-weight:var(--weight-page-title);letter-spacing:var(--tracking-page-title)}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-5)}.project-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-6);border:1px solid var(--color-border);text-decoration:none;color:inherit;display:block;transition:all .2s var(--transition-ease)}.project-card:hover{border-color:var(--color-accent);box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.project-card-title{font-size:var(--text-card-title);font-weight:var(--weight-card-title);margin-bottom:var(--space-2)}.project-card-desc{font-size:var(--text-secondary);color:var(--color-text-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:var(--space-4)}.project-card-meta{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-caption);color:var(--color-text-secondary);margin-bottom:var(--space-3)}.project-card-progress{height:4px;background:var(--color-surface-alt);border-radius:var(--radius-pill);overflow:hidden;margin-bottom:var(--space-3)}.project-card-progress-fill{height:100%;background:var(--color-accent);border-radius:var(--radius-pill);transition:width .3s var(--transition-ease)}.project-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:var(--space-2)}.project-card-clients{display:flex;align-items:center}.project-card-avatar{width:24px;height:24px;border-radius:50%;background:var(--color-accent);color:var(--color-accent-foreground);display:inline-flex;align-items:center;justify-content:center;font-size:var(--text-caption);font-weight:600;border:2px solid var(--color-surface);margin-left:-4px}.project-card-avatar-sm{width:28px;height:28px}.project-card-avatar:first-child{margin-left:0}.project-card-overflow{font-size:var(--text-caption);color:var(--color-text-secondary);margin-left:var(--space-2)}.project-card-visibility{color:var(--color-text-secondary)}.project-card-visibility.visible{color:var(--color-accent)}.project-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6)}.project-back-link{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-body);color:var(--color-text-secondary);text-decoration:none;margin-bottom:var(--space-4);transition:color .2s var(--transition-ease)}.project-back-link:hover{color:var(--color-accent)}.project-controls{display:flex;gap:var(--space-4);align-items:center}.visibility-toggle{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:none;background:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text-secondary);font-size:var(--text-secondary);transition:all .15s var(--transition-ease)}.visibility-toggle:hover{background:var(--color-surface-alt)}.visibility-toggle.visible{color:var(--color-accent)}.project-progress-summary{margin-bottom:var(--space-6)}.project-progress-bar{height:6px;background:var(--color-surface-alt);border-radius:var(--radius-pill);overflow:hidden;margin-bottom:var(--space-2)}.project-progress-bar-fill{height:100%;background:var(--color-accent);border-radius:var(--radius-pill);transition:width .3s var(--transition-ease)}.project-progress-text{font-size:var(--text-caption);color:var(--color-text-secondary)}.milestone-section{margin-bottom:var(--space-6)}.milestone-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);background:var(--color-surface-alt);border-radius:var(--radius-md);margin-bottom:var(--space-2)}.milestone-title{font-size:var(--text-section-heading);font-weight:var(--weight-section-heading);letter-spacing:var(--tracking-section-heading)}.milestone-progress-text{font-size:var(--text-caption);color:var(--color-text-secondary)}.milestone-card{overflow:hidden}.milestone-card-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--color-border)}.milestone-card-title{font-size:14px;font-weight:500}.milestone-card-count{font-size:12px;color:var(--color-text-secondary)}.milestone-card-row-border{border-top:1px solid var(--color-border)}.milestone-progress-bar{height:3px;background:var(--color-surface-alt);border-radius:var(--radius-pill);overflow:hidden;margin-bottom:var(--space-2)}.milestone-progress-bar-fill{height:100%;background:var(--color-accent);border-radius:var(--radius-pill);transition:width .3s var(--transition-ease)}.deliverable-row{display:flex;align-items:center;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);gap:var(--space-3);min-height:48px;transition:background .15s var(--transition-ease)}.deliverable-row:hover{background:var(--color-surface-alt)}.deliverable-row:last-child{border-bottom:none}.deliverable-name{flex:1;font-size:var(--text-body);font-weight:var(--weight-body)}.deliverable-checkbox{width:18px;height:18px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;accent-color:var(--color-accent)}.deliverable-status-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;border:none;cursor:pointer;font-family:var(--font-body);height:28px;padding:var(--space-1) var(--space-6) var(--space-1) var(--space-3);border-radius:var(--radius-pill);font-size:var(--text-caption);font-weight:var(--weight-label);background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='currentColor' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.deliverable-status-select:focus-visible{outline:2px solid var(--color-accent);outline-offset:1px}.status-select-not-started{background:var(--color-surface-alt);color:var(--color-text-secondary)}.status-select-in-progress{background:var(--color-accent-soft);color:var(--color-accent)}.status-select-in-review{background:var(--color-warning-soft);color:var(--color-warning)}.status-select-approved{background:var(--color-success-soft);color:var(--color-success)}.bulk-action-bar{position:sticky;bottom:0;display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-6);background:var(--color-surface);border-top:1px solid var(--color-border);box-shadow:0 -4px 12px #0000000d;z-index:10}.template-preview{background:var(--color-surface-alt);padding:var(--space-4);border-radius:var(--radius-md);margin-top:var(--space-4)}.template-preview-milestone{font-size:var(--text-label);font-weight:var(--weight-label);letter-spacing:var(--tracking-label);margin-top:var(--space-3);text-transform:uppercase}.template-preview-deliverable{font-size:var(--text-caption);color:var(--color-text-secondary);padding-left:var(--space-6);padding-top:var(--space-1)}.client-select-list{display:flex;flex-direction:column;gap:var(--space-2);max-height:200px;overflow-y:auto}.client-select-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2);border-radius:var(--radius-md);cursor:pointer;transition:background .15s var(--transition-ease)}.client-select-item:hover{background:var(--color-surface-alt)}.form-group{margin-bottom:var(--space-4)}.form-label{display:block;font-size:var(--text-label);font-weight:var(--weight-label);letter-spacing:var(--tracking-label);color:var(--color-text-secondary);margin-bottom:var(--space-2);text-transform:uppercase}.form-input{width:100%;padding:var(--space-2) var(--space-3);font-family:var(--font-body);font-size:var(--text-body);color:var(--color-text-primary);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color .15s var(--transition-ease)}.form-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent-soft)}.form-input:disabled{opacity:.6;cursor:not-allowed}textarea.form-input{resize:vertical;min-height:80px}select.form-input{cursor:pointer}.form-row{display:flex;gap:var(--space-4)}.form-row .form-group{flex:1}.form-error{display:block;font-size:var(--text-caption);color:var(--color-danger);margin-top:var(--space-1)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-6)}@media (max-width: 768px){.project-grid{grid-template-columns:1fr}.project-header{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.deliverable-row{flex-wrap:wrap;min-height:var(--space-11)}.deliverable-name{width:100%}.bulk-action-bar{padding:var(--space-3) var(--space-4)}.deliverable-status-select{min-height:var(--space-11)}.form-row{flex-direction:column;gap:0}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center}.empty-state-icon{color:var(--color-text-secondary);margin-bottom:16px}.empty-state-title{font-size:var(--text-section-heading);font-weight:600;margin-bottom:8px}.empty-state-text{font-size:var(--text-body);color:var(--color-text-secondary);max-width:360px;margin-bottom:20px}.text-secondary{color:var(--color-text-secondary)}.text-danger{color:var(--color-danger)}.text-success{color:var(--color-success)}.error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center;padding:40px}.error-screen h1{margin-bottom:8px}.error-screen p{color:var(--color-text-secondary)}.client-group-header{font-size:var(--text-secondary);font-weight:var(--weight-secondary);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.project-card-group-name{font-size:var(--text-caption);font-weight:var(--weight-caption);color:var(--color-text-secondary)}.comment-thread{margin-top:var(--space-8);padding-top:var(--space-6);border-top:1px solid var(--color-border)}.comment-thread-title{font-size:var(--text-section-heading);font-weight:var(--weight-section-heading);letter-spacing:var(--tracking-section-heading);color:var(--color-text-primary);display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-4)}.comment-form{margin-bottom:var(--space-6)}.comment-form textarea{min-height:80px;width:100%;resize:vertical}.comment-form-footer{display:flex;align-items:center;justify-content:space-between;margin-top:var(--space-3);gap:var(--space-3)}.comment-internal-toggle{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-secondary);color:var(--color-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.comment-internal-toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer}.comment-empty{font-size:var(--text-secondary);color:var(--color-text-secondary);padding:var(--space-4) 0}.comment-list{display:flex;flex-direction:column;gap:var(--space-3)}.comment-item{padding:var(--space-4);background:var(--color-surface-alt);border-radius:var(--radius-md);border-left:3px solid transparent}.comment-item.internal{border-left-color:var(--color-warning)}.comment-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2);flex-wrap:wrap;gap:var(--space-2)}.comment-author{display:flex;align-items:center;gap:var(--space-2)}.comment-author-name{font-size:var(--text-body);font-weight:600;color:var(--color-text-primary)}.comment-role-badge{font-size:var(--text-caption);font-weight:var(--weight-caption);color:var(--color-text-secondary);text-transform:capitalize}.comment-internal-badge{font-size:var(--text-label);font-weight:var(--weight-label);letter-spacing:var(--tracking-label);background:var(--color-warning-soft);color:var(--color-warning);padding:2px var(--space-2);border-radius:var(--radius-sm);text-transform:uppercase}.comment-timestamp{font-size:var(--text-caption);font-weight:var(--weight-caption);color:var(--color-text-secondary)}.comment-content{font-size:var(--text-body);font-weight:var(--weight-body);line-height:var(--leading-body);color:var(--color-text-primary);white-space:pre-wrap}@media (max-width: 768px){.comment-header{flex-direction:column;align-items:flex-start}.comment-form-footer{flex-direction:column;align-items:stretch}.comment-form-footer .btn{width:100%}}.template-editor{max-width:720px;margin:0 auto}.template-editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6)}.template-editor-actions{display:flex;gap:var(--space-3)}.milestone-card{border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--space-4);overflow:hidden}.milestone-card-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);background:var(--color-surface-alt);cursor:pointer}.milestone-card-header:hover{background:var(--color-surface-hover)}.milestone-card-body{padding:var(--space-4);border-top:1px solid var(--color-border)}.milestone-name-input{flex:1;font-weight:600;border:none;background:transparent;font-size:var(--text-card-title);color:var(--color-text-primary);outline:none;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.milestone-name-input:focus{background:var(--color-surface);box-shadow:0 0 0 2px var(--color-accent)}.milestone-name-input.input-error{box-shadow:0 0 0 2px var(--color-danger)}.milestone-actions{display:flex;gap:var(--space-2);align-items:center}.deliverable-row-editor{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border)}.deliverable-row-editor:last-of-type{border-bottom:none}.deliverable-name-input{flex:1;border:none;background:transparent;font-size:var(--text-body);color:var(--color-text-primary);outline:none;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.deliverable-name-input:focus{background:var(--color-surface-alt);box-shadow:0 0 0 2px var(--color-accent)}.deliverable-name-input.input-error{box-shadow:0 0 0 2px var(--color-danger)}.reorder-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition-default)}.reorder-btn:hover{background:var(--color-surface-alt)}.reorder-btn:disabled{opacity:.3;cursor:not-allowed}.reorder-btn.danger:hover{background:#ef44441a;color:var(--color-danger)}.add-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:1px dashed var(--color-border);border-radius:var(--radius-md);background:transparent;color:var(--color-text-secondary);cursor:pointer;width:100%;font-size:var(--text-body);transition:var(--transition-default);margin-top:var(--space-3)}.add-btn:hover{border-color:var(--color-accent);color:var(--color-accent);background:#0eafc70d}.add-btn:disabled{opacity:.5;cursor:not-allowed}.icon-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition-default)}.icon-btn:hover{background:var(--color-surface-alt);color:var(--color-text-primary)}.icon-btn.danger:hover{background:#ef44441a;color:var(--color-danger)}@media (max-width: 768px){.template-editor-header{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.template-editor-actions{width:100%}.template-editor-actions .btn{flex:1}.deliverable-row-editor{flex-wrap:wrap}.deliverable-name-input{min-width:0}}.billing-summary{display:flex;gap:var(--space-4);margin-bottom:var(--space-6)}.billing-summary-card{flex:1;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-2)}.billing-summary-card-overdue{border-color:var(--color-danger)}.billing-summary-label{font-size:var(--text-label);font-weight:var(--weight-label);letter-spacing:var(--tracking-label);color:var(--color-text-secondary);text-transform:uppercase}.billing-summary-amount{font-size:var(--text-page-title);font-weight:var(--weight-page-title);letter-spacing:var(--tracking-page-title);color:var(--color-text-primary)}.billing-filters{display:flex;gap:var(--space-3);margin-bottom:var(--space-6);flex-wrap:wrap}.billing-filters .form-input{width:auto;min-width:160px}.invoice-table{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.invoice-table-header{display:grid;grid-template-columns:1.2fr 1fr 1.5fr 1fr 1fr .8fr .8fr;padding:var(--space-3) var(--space-4);background:var(--color-surface-alt);font-size:var(--text-label);font-weight:var(--weight-label);letter-spacing:var(--tracking-label);color:var(--color-text-secondary);text-transform:uppercase;border-bottom:1px solid var(--color-border)}.invoice-row{display:grid;grid-template-columns:1.2fr 1fr 1.5fr 1fr 1fr .8fr .8fr;padding:var(--space-3) var(--space-4);align-items:center;font-size:var(--text-body);cursor:pointer;transition:background .2s var(--transition-ease);border-bottom:1px solid var(--color-border)}.invoice-row:last-child{border-bottom:none}.invoice-row:hover{background:var(--color-surface-alt)}.invoice-row-number{font-family:var(--font-mono);font-size:var(--text-caption)}.invoice-row-desc{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.invoice-row-amount{font-weight:600}.invoice-row-actions{display:flex;gap:var(--space-1);justify-content:flex-end}.text-right{text-align:right}.invoice-detail-section{margin-top:var(--space-6);margin-bottom:var(--space-6)}.invoice-detail-row{display:flex;gap:var(--space-4);padding:var(--space-3) 0;border-bottom:1px solid var(--color-border);font-size:var(--text-body)}.invoice-detail-label{min-width:140px;color:var(--color-text-secondary);font-weight:var(--weight-label);font-size:var(--text-secondary)}.invoice-line-items{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.invoice-line-items-header{display:grid;grid-template-columns:2fr .5fr 1fr 1fr;padding:var(--space-3) var(--space-4);background:var(--color-surface-alt);font-size:var(--text-label);font-weight:var(--weight-label);letter-spacing:var(--tracking-label);color:var(--color-text-secondary);text-transform:uppercase;border-bottom:1px solid var(--color-border)}.invoice-line-items-row{display:grid;grid-template-columns:2fr .5fr 1fr 1fr;padding:var(--space-3) var(--space-4);font-size:var(--text-body);border-bottom:1px solid var(--color-border)}.invoice-line-items-row:last-child{border-bottom:none}.invoice-line-items-footer{display:grid;grid-template-columns:3.5fr 1fr;padding:var(--space-3) var(--space-4);font-size:var(--text-body);background:var(--color-surface-alt);border-top:1px solid var(--color-border)}.line-item-editor{margin-bottom:var(--space-2)}.line-item-editor-fields{display:flex;gap:var(--space-2);align-items:center}.line-item-desc{flex:2}.line-item-amount{flex:1;max-width:140px}.line-item-qty{flex:0 0 70px;max-width:70px}.line-item-total{display:flex;justify-content:space-between;padding:var(--space-4) 0;margin-top:var(--space-4);border-top:2px solid var(--color-border);font-size:var(--text-card-title);font-weight:var(--weight-card-title)}.pay-now-btn{display:inline-flex;align-items:center;gap:var(--space-2);width:100%;justify-content:center;padding:var(--space-4);font-size:var(--text-card-title);font-weight:var(--weight-card-title);margin-top:var(--space-4);margin-bottom:var(--space-4);text-decoration:none}@media (max-width: 768px){.billing-summary,.billing-filters{flex-direction:column}.billing-filters .form-input{width:100%;min-width:0}.invoice-table-header{display:none}.invoice-row{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4)}.invoice-row-actions{width:100%;justify-content:flex-start}.invoice-line-items-header{display:none}.invoice-line-items-row{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-3) var(--space-4)}.invoice-line-items-footer{display:flex;justify-content:space-between}.line-item-editor-fields{flex-wrap:wrap}.line-item-desc{flex:1 1 100%}.line-item-amount,.line-item-qty{flex:1;max-width:none}.invoice-detail-row{flex-direction:column;gap:var(--space-1)}.invoice-detail-label{min-width:0}.pay-now-btn{width:100%}}.toggle-switch{position:relative;width:44px;height:24px;padding:0;background:var(--color-border);border:none;border-radius:12px;cursor:pointer;transition:background .15s ease;flex-shrink:0}.toggle-switch:before{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .15s ease;box-shadow:0 1px 3px #00000026}.toggle-switch[aria-checked=true]{background:var(--color-accent)}.toggle-switch[aria-checked=true]:before{transform:translate(20px)}.toggle-switch:disabled{opacity:.5;cursor:not-allowed}.toggle-switch.muted{background:var(--color-surface-alt)}.toggle-switch.muted[aria-checked=true]{background:#0eafc766}.segmented-control{display:inline-flex;border:1px solid var(--color-border);border-radius:6px;overflow:hidden}.segmented-control-btn{padding:var(--space-2) var(--space-3);font-family:var(--font-body);font-size:var(--text-secondary);font-weight:var(--weight-body);color:var(--color-text-secondary);background:transparent;border:none;cursor:pointer;transition:background .15s,color .15s;height:36px;display:flex;align-items:center;white-space:nowrap}.segmented-control-btn:not(:last-child){border-right:1px solid var(--color-border)}.segmented-control-btn:hover{background:var(--color-surface-alt)}.segmented-control-btn.active{background:var(--color-accent);color:var(--color-accent-foreground);font-weight:500}.segmented-control-btn:disabled{opacity:.5;cursor:not-allowed}.tag-input{display:flex;flex-wrap:wrap;gap:var(--space-1);padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);min-height:40px;align-items:center;cursor:text;transition:border-color .15s var(--transition-ease)}.tag-input:focus-within{border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent-soft)}.tag-input.disabled{opacity:.6;cursor:not-allowed}.tag-pill{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-2);background:var(--color-surface-alt);border-radius:var(--radius-sm);font-size:12px;color:var(--color-text-primary)}.tag-pill-remove{display:flex;align-items:center;padding:0;background:none;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:14px;line-height:1}.tag-pill-remove:hover{color:var(--color-danger)}.tag-input-field{border:none;outline:none;background:transparent;font-family:var(--font-body);font-size:var(--text-body);color:var(--color-text-primary);flex:1;min-width:80px}.pill-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.02em;white-space:nowrap}.pill-badge--active{background:var(--color-success-soft);color:var(--color-success)}.pill-badge--inactive{background:var(--color-surface-alt);color:var(--color-text-secondary)}.pill-badge--role{background:var(--color-accent-soft);color:var(--color-accent)}.pill-badge--group{background:var(--color-surface-alt);color:var(--color-text-primary)}.avatar-upload{position:relative;border-radius:50%;overflow:hidden;cursor:pointer;flex-shrink:0}.avatar-upload-img{width:100%;height:100%;object-fit:cover;display:block}.avatar-upload-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--color-accent);color:var(--color-accent-foreground);font-family:var(--font-heading);font-size:24px;font-weight:600}.avatar-upload-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0006;color:#fff;opacity:0;transition:opacity .2s var(--transition-ease)}.avatar-upload:hover .avatar-upload-overlay{opacity:1}.avatar-upload-spinner{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#ffffffb3}.avatar-upload-spinner:after{content:"";width:24px;height:24px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.color-picker-controls{display:flex;align-items:center;gap:var(--space-2)}.color-picker-swatch{width:32px;height:32px;border-radius:var(--radius-sm);border:1px solid var(--color-border);flex-shrink:0}.color-picker-native{width:0;height:0;padding:0;border:none;visibility:hidden;position:absolute}.color-picker-hex{width:90px;font-family:var(--font-mono)}.color-picker-value{font-family:var(--font-mono);font-size:var(--text-body);color:var(--color-text-secondary)}
