@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--primary-color: #6366F1;--primary-hover: #4F46E5;--primary-light: #EEF2FF;--secondary-color: #6366F1;--accent-color: #0d9488;--bg-color: #F9FAFB;--surface-color: #FFFFFF;--surface-solid: #FFFFFF;--text-primary: #111827;--text-secondary: #6B7280;--border-color: #E5E7EB;--error-color: #EF4444;--error-bg: #FEF2F2;--success-color: #10B981;--success-bg: #ECFDF5;--warning-color: #F59E0B;--warning-bg: #FFFBEB;--error-text: #991B1B;--success-text: #065F46;--neutral-100: #F3F4F6;--bg-light: #F3F4F6;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 1px 3px 0 rgb(0 0 0 / .08), 0 1px 2px -1px rgb(0 0 0 / .08);--shadow-lg: 0 4px 6px -1px rgb(0 0 0 / .07), 0 2px 4px -2px rgb(0 0 0 / .07);--shadow-xl: 0 10px 15px -3px rgb(0 0 0 / .08), 0 4px 6px -4px rgb(0 0 0 / .08);--shadow-glow: none;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 10px;--radius-2xl: 12px;--radius-pill: 9999px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}.glass{background:var(--surface-solid);border:1px solid var(--border-color)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}a{color:inherit;text-decoration:none}.container{max-width:1300px;margin:0 auto;padding:0 1.5rem;width:100%}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;height:36px;padding:0 14px;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease;border:none;font-size:.875rem;letter-spacing:0;line-height:1;white-space:nowrap}.btn-primary{background:var(--primary-color);color:#fff;box-shadow:none}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{background-color:var(--surface-solid);color:var(--text-primary);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background-color:var(--bg-color);border-color:#d1d5db}.card{background:var(--surface-solid);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:1.25rem;transition:border-color .15s ease}.auth-layout{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-color)}.auth-container{display:flex;align-items:flex-start;justify-content:center;flex:1;padding:4rem 1rem 1rem}.auth-card{width:100%;max-width:420px;background:var(--surface-solid);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:2.5rem}.auth-title{font-size:1.5rem;font-weight:700;text-align:center;margin-bottom:.5rem}.auth-subtitle{color:var(--text-secondary);text-align:center;margin-bottom:2rem;font-size:.875rem}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem;color:var(--text-primary)}.form-input{width:100%;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.875rem;background:var(--surface-solid);transition:border-color .15s ease,box-shadow .15s ease;height:36px}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11f;background:#fff}.form-input:disabled{background-color:var(--bg-color);border-color:transparent;color:var(--text-secondary);cursor:not-allowed;opacity:.8;background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="%2394a3b8" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><rect width="18" height="11" x="3" y="11" rx="2" ry="2"/><path d="M7 11V7a5 5 0 0 1 10 0v4"/></svg>');background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.25rem}.auth-banner{text-align:center;margin-top:1.5rem;font-size:.875rem;color:var(--text-secondary)}.auth-link{color:var(--primary-color);font-weight:500}.auth-link:hover{text-decoration:underline}.hero{text-align:center;padding:6rem 1rem;background:var(--bg-color)}.hero h1{font-size:3.5rem;font-weight:800;line-height:1.1;letter-spacing:-.03em;margin-bottom:1.5rem;color:var(--text-primary)}.hero p{font-size:1.125rem;color:var(--text-secondary);max-width:560px;margin:0 auto 2rem;line-height:1.6}.hero-buttons{display:flex;gap:.75rem;justify-content:center}.hero .btn{height:40px;padding:0 1.25rem;font-size:.9rem}.navbar{height:3.5rem;border-bottom:1px solid var(--border-color);background:var(--surface-solid);position:sticky;top:0;z-index:50}.navbar-content{display:flex;justify-content:space-between;align-items:center;height:100%}.brand{font-size:1.35rem;font-weight:800;display:flex;align-items:center;gap:.5rem;color:var(--primary-color);letter-spacing:-.02em}.spinner{border:3px solid rgba(0,0,0,.1);border-radius:50%;border-top-color:var(--primary-color);width:24px;height:24px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dashboard-layout{min-height:100vh;display:flex;flex-direction:column}.dashboard-content{flex:1;padding:2rem 1rem}.grid-projects{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:1024px){.grid-projects{grid-template-columns:1fr}}.grid-expenses{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}@media(max-width:1024px){.grid-expenses{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.grid-expenses{grid-template-columns:1fr}}.grid-project-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}@media(max-width:640px){.grid-project-kpis{grid-template-columns:1fr;gap:1rem}}.grid-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:1.5rem}@media(max-width:1280px){.grid-kpis{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.grid-kpis{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.grid-kpis{grid-template-columns:1fr}}.grid-charts{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-top:2rem}@media(max-width:1024px){.grid-charts{grid-template-columns:1fr}}.table-container{width:100%;overflow-x:auto;background:var(--surface-solid);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.data-table{width:100%;border-collapse:collapse;text-align:left}.data-table th{background:var(--bg-color);padding:.75rem 1rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);border-bottom:1px solid var(--border-color);white-space:nowrap}.data-table td{padding:.75rem 1rem;font-size:.875rem;color:var(--text-primary);border-bottom:1px solid var(--border-color);vertical-align:middle}.data-table tbody tr{transition:background .2s ease;cursor:pointer;background:transparent}.data-table tbody tr:hover{background:#6366f108}.data-table tfoot th{background:var(--bg-color);padding:.75rem 1rem;font-size:.875rem;font-weight:700;color:var(--text-primary);border-top:1px solid var(--border-color)}.data-table .currency{font-size:.95rem}.note-popover-overlay{position:fixed;inset:0;z-index:99}.note-popover{position:absolute;z-index:100;width:320px;background:var(--surface-solid);border-radius:var(--radius-lg);box-shadow:0 12px 40px #0f172a1f,0 4px 12px #0f172a0f;border:1px solid var(--border-color);padding:1rem;animation:notePopIn .2s cubic-bezier(.34,1.56,.64,1);right:0;top:calc(100% + .5rem)}@keyframes notePopIn{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.note-popover-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.note-popover-header h4{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin:0}.note-textarea{width:100%;min-height:80px;padding:.75rem;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.85rem;font-family:inherit;line-height:1.5;color:var(--text-primary);background:var(--bg-color);resize:vertical;transition:border-color .2s ease,box-shadow .2s ease}.note-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a;background:#fff}.note-textarea::placeholder{color:var(--text-secondary);opacity:.6}.note-popover-actions{display:flex;gap:.5rem;margin-top:.75rem;justify-content:flex-end}.note-popover-actions .btn{padding:.4rem .875rem;font-size:.8rem;border-radius:var(--radius-md)}.note-indicator{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;border:none;cursor:pointer;transition:all .2s ease;padding:0;flex-shrink:0}.note-indicator.has-note{background:#6366f11a;color:var(--primary-color)}.note-indicator.has-note:hover{background:#6366f133;transform:scale(1.1)}.note-indicator.no-note{background:transparent;color:var(--text-secondary);opacity:0}tr:hover .note-indicator.no-note{opacity:.5}.note-indicator.no-note:hover{opacity:1!important;background:#0000000a;transform:scale(1.1)}.note-badge{position:absolute;top:-2px;right:-2px;width:8px;height:8px;background:var(--primary-color);border-radius:50%;border:1.5px solid var(--surface-solid)}.note-preview{display:none;position:absolute;bottom:calc(100% + 6px);right:50%;transform:translate(50%);background:var(--text-primary);color:#fff;padding:.5rem .75rem;border-radius:var(--radius-md);font-size:.75rem;line-height:1.4;max-width:240px;white-space:pre-wrap;word-break:break-word;box-shadow:0 4px 12px #00000026;z-index:90;pointer-events:none}.note-preview:after{content:"";position:absolute;top:100%;right:50%;transform:translate(50%);border:5px solid transparent;border-top-color:var(--text-primary)}.note-indicator.has-note:hover .note-preview{display:block}.project-tabs{display:flex;gap:0;border-bottom:2px solid var(--border-color);margin-top:1.5rem;margin-bottom:0}.project-tab{position:relative;padding:.75rem 1.5rem;font-size:.9rem;font-weight:600;color:var(--text-secondary);background:none;border:none;cursor:pointer;transition:color .2s ease;white-space:nowrap}.project-tab:hover{color:var(--text-primary)}.project-tab.active{color:var(--primary-color)}.project-tab.active:after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--primary-color);border-radius:2px 2px 0 0}.project-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:var(--radius-pill);font-size:.7rem;font-weight:700;margin-left:.5rem;background:#6366f11a;color:var(--primary-color)}.project-tab-close{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;margin-left:.4rem;border:none;border-radius:50%;background:transparent;color:var(--text-secondary);cursor:pointer;font-size:.7rem;padding:0;opacity:0;transition:all .15s ease;flex-shrink:0}.project-tab:hover .project-tab-close{opacity:.6}.project-tab-close:hover{opacity:1!important;background:#ef44441a;color:#ef4444}.project-tab-add{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;margin-left:.25rem;border:1.5px dashed var(--border-color);border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);cursor:pointer;font-size:1rem;padding:0;transition:all .2s ease;align-self:center;flex-shrink:0}.project-tab-add:hover{border-color:var(--primary-color);color:var(--primary-color);background:#6366f10d}.add-tab-dropdown{position:absolute;top:calc(100% + 6px);right:0;background:var(--surface-solid);border-radius:var(--radius-lg);box-shadow:0 8px 30px #0f172a1f,0 2px 8px #0f172a0f;border:1px solid var(--border-color);padding:.5rem;min-width:180px;z-index:50;animation:notePopIn .15s ease}.add-tab-dropdown button{width:100%;text-align:left;padding:.6rem .75rem;border:none;border-radius:var(--radius-md);background:none;font-size:.85rem;font-weight:500;color:var(--text-primary);cursor:pointer;transition:background .15s ease;display:flex;align-items:center;gap:.5rem}.add-tab-dropdown button:hover{background:#6366f10f;color:var(--primary-color)}.tab-chip-toggle{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .85rem;border-radius:2rem;font-size:.8rem;font-weight:600;border:2px solid var(--border-color);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.tab-chip-toggle.selected{border-color:var(--primary-color);background:#6366f114;color:var(--primary-color)}.tab-chip-toggle:hover{border-color:var(--primary-color);color:var(--primary-color)}.status-card{position:relative;background:var(--surface-solid);border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden;transition:border-color .15s ease}.status-card:hover{border-color:#6366f133}.status-card-accent{position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--primary-color)}.status-card-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.25rem 1.5rem .75rem 1.75rem}.status-card-month{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.status-card-meta{font-size:.78rem;color:var(--text-secondary);margin-top:.2rem}.status-card-description{padding:0 1.5rem 1rem 1.75rem;font-size:.9rem;line-height:1.6;color:var(--text-primary)}.status-card-snapshot{padding:0 1.5rem 1.5rem 1.75rem}.status-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1rem}@media(max-width:768px){.status-kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.status-kpi-grid{grid-template-columns:1fr}}.status-kpi-grid.status-kpi-grid--preview{grid-template-columns:repeat(2,1fr)}.status-kpi-mini{background:#6366f10a;border:1px solid rgba(99,102,241,.08);border-radius:var(--radius-lg);padding:.75rem 1rem}.status-kpi-mini-label{font-size:.72rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.25rem}.status-kpi-mini-value{font-size:1rem;font-weight:700;color:var(--text-primary)}.status-charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}@media(max-width:768px){.status-charts-grid{grid-template-columns:1fr}}.status-chart-card{border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1rem;background:var(--bg-color)}.status-chart-title{font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:.75rem}.status-card-delete{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.35rem;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:all .2s ease;opacity:0}.status-card:hover .status-card-delete{opacity:1}.status-card-delete:hover{color:#ef4444;background:#ef444414}.status-card-action-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.35rem;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:all .2s ease;opacity:0}.status-card:hover .status-card-action-btn{opacity:1}.status-card-action-btn:hover{color:var(--primary-color);background:#6366f114}.status-card-edit{padding:0 1.5rem 1rem}.rte-wrapper{border:none;border-radius:0;overflow:visible}.rte-wrapper:focus-within{border-color:transparent;box-shadow:none}.rte-toolbar{display:flex;align-items:center;gap:2px;padding:.25rem 0;background:transparent;border-bottom:none}.rte-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;border:none;border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.rte-btn:hover{background:#0000000f;color:var(--text-primary)}.rte-btn.active{background:#6366f11a;color:var(--primary-color)}.rte-divider{width:1px;height:20px;background:var(--border-color);margin:0 4px;flex-shrink:0}.rte-content{min-height:100px;padding:.75rem 1rem;font-size:.9rem;line-height:1.6;color:var(--text-primary);outline:none}.rte-content p{margin:0 0 .5em}.rte-content p:last-child{margin-bottom:0}.rte-content p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--text-secondary);opacity:.5;pointer-events:none;height:0}.rte-content ul,.rte-content ol{padding-left:1.5rem;margin:.5em 0}.rte-content li{margin-bottom:.25em}.rte-content a{color:var(--primary-color);text-decoration:underline;cursor:pointer}.rte-content strong{font-weight:700}.rte-rendered{font-size:.925rem;line-height:1.6}.rte-rendered p{margin:0 0 .5em}.rte-rendered p:last-child{margin-bottom:0}.rte-rendered ul,.rte-rendered ol{padding-left:1.5rem;margin:.5em 0}.rte-rendered li{margin-bottom:.25em}.rte-rendered a{color:var(--primary-color);text-decoration:underline}.rte-rendered strong{font-weight:700}.status-create-modal{width:100%;max-width:560px;max-height:85dvh;overflow-y:auto;padding:1.5rem}.status-preview-section{margin-top:1rem;padding:1rem;background:var(--bg-color);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.status-preview-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:.75rem}.status-empty{text-align:center;padding:4rem 2rem}.status-empty-icon{width:56px;height:56px;border-radius:50%;background:#6366f11a;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;color:var(--primary-color)}.status-list{display:flex;flex-direction:column;gap:1.25rem;margin-top:1.5rem}.file-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:1.5rem 1rem;border:2px dashed var(--border-color);border-radius:var(--radius-lg);background:var(--bg-color);cursor:pointer;transition:all .25s ease;text-align:center}.file-dropzone:hover{border-color:var(--primary-color);background:#6366f10a}.file-dropzone.drag-over{border-color:var(--primary-color);background:#6366f114;box-shadow:0 0 0 4px #6366f11a}.file-dropzone-icon{width:40px;height:40px;border-radius:50%;background:#6366f11a;display:flex;align-items:center;justify-content:center;color:var(--primary-color)}.file-dropzone-text{font-size:.85rem;color:var(--text-secondary);line-height:1.4}.file-dropzone-text strong{color:var(--primary-color);font-weight:600}.file-dropzone-hint{font-size:.75rem;color:var(--text-secondary);opacity:.7}.file-selected{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--bg-color)}.file-selected-icon{width:36px;height:36px;border-radius:var(--radius-md);background:#6366f114;display:flex;align-items:center;justify-content:center;color:var(--primary-color);flex-shrink:0}.file-selected-info{flex:1;min-width:0}.file-selected-name{font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-selected-size{font-size:.75rem;color:var(--text-secondary)}.file-selected-remove{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.file-selected-remove:hover{color:#ef4444;background:#ef444414}.upload-progress{width:100%;height:4px;background:var(--border-color);border-radius:2px;overflow:hidden;margin-top:.5rem}.upload-progress-bar{height:100%;background:var(--primary-color);border-radius:2px;transition:width .3s ease}.attachment-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border-radius:1rem;font-size:.75rem;font-weight:600;background:#fef3c7;color:#92400e;text-decoration:none;transition:all .2s ease;max-width:200px;cursor:pointer;border:none}.attachment-badge:hover{background:#fde68a;transform:translateY(-1px)}.attachment-badge-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.expense-description{font-size:.85rem;line-height:1.5;color:var(--text-secondary);margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.activity-timeline{display:flex;flex-direction:column;gap:.75rem}.activity-event-card{position:relative;display:flex;align-items:center;gap:1rem;padding:1.15rem 1.5rem;background:var(--surface-solid);border-radius:var(--radius-xl);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);transition:all .25s cubic-bezier(.4,0,.2,1);overflow:hidden}.activity-event-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px);border-color:#6366f12e}.activity-event-accent{position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--primary-color);border-radius:0 3px 3px 0;opacity:0;transition:opacity .25s ease}.activity-event-card:hover .activity-event-accent{opacity:1}.activity-event-icon{width:40px;height:40px;min-width:40px;border-radius:50%;background:#6366f114;display:flex;align-items:center;justify-content:center;color:var(--primary-color);transition:transform .2s ease}.activity-event-card:hover .activity-event-icon{transform:scale(1.05)}.activity-event-body{flex:1;min-width:0}.activity-event-message{font-size:.92rem;font-weight:500;color:var(--text-primary);line-height:1.45;word-break:break-word}.activity-event-meta{display:flex;align-items:center;gap:.4rem;margin-top:.3rem;font-size:.78rem;color:var(--text-secondary)}.activity-event-time{font-weight:600;color:var(--primary-color);opacity:.8}.activity-event-dot{opacity:.4}.activity-event-date{opacity:.7}.activity-event-avatar{flex-shrink:0}.activity-event-avatar img{width:34px;height:34px;border-radius:50%;object-fit:cover;border:2px solid var(--border-color)}.activity-event-avatar-fallback{width:34px;height:34px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.desktop-nav{display:none!important}.mobile-menu-btn{display:flex!important}}.mobile-menu-btn{display:none;background:none;border:none;color:var(--text-primary);cursor:pointer;padding:.5rem;align-items:center;justify-content:center;border-radius:var(--radius-md)}.mobile-menu-btn:focus{outline:2px solid var(--primary-color);outline-offset:2px}.mobile-menu-btn:focus:not(:focus-visible){outline:none}.mobile-menu-btn:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.mobile-nav-menu{position:absolute;top:100%;left:0;right:0;background:var(--surface-solid);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-md);padding:1rem 1.5rem;display:flex;flex-direction:column;gap:1rem;z-index:40}.data-table input.form-input{min-width:110px}.project-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1.5rem}.project-detail-actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}@media(max-width:768px){.project-detail-header{flex-direction:column;align-items:stretch}.project-detail-actions{margin-top:1rem;justify-content:flex-start}}.expenses-header{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:.75rem;margin-bottom:2rem}@media(max-width:640px){.expenses-header{grid-template-columns:1fr auto;align-items:flex-start}.expenses-add-wrapper{grid-column:1 / -1;margin-top:.5rem}.expenses-add-wrapper .btn{width:100%;justify-content:center}}.expense-modal-card{width:100%;max-width:500px;max-height:85dvh;overflow-y:auto;padding:1.5rem}@media(max-width:640px){.expense-modal-card{padding:1.25rem 1rem;max-height:90dvh}.expense-modal-card .form-group{margin-bottom:1rem}.expense-modal-card .form-label{margin-bottom:.35rem}.expense-modal-card .form-input{padding:.6rem .85rem}}.admin-toolbar{background:var(--primary-color);color:#fff;padding:.5rem 1rem;display:flex;align-items:center;justify-content:space-between;font-size:.85rem;font-weight:600;z-index:100;box-shadow:var(--shadow-md);position:relative;gap:.75rem}.admin-toolbar-left{display:flex;align-items:center;gap:.75rem;flex:1}.admin-toolbar-label{letter-spacing:.05em;white-space:nowrap}.admin-toolbar-viewing{opacity:.8;font-weight:400;margin-left:.5rem;white-space:nowrap}.admin-toolbar-select{background:#fff3;border:1px solid rgba(255,255,255,.5);color:#fff;padding:.3rem .75rem;border-radius:var(--radius-md);font-size:.8rem;font-weight:600;outline:none;cursor:pointer;max-width:250px}.admin-toolbar-select option{color:var(--text-primary)}.admin-toolbar-right{display:flex;align-items:center;gap:1rem}.admin-toolbar-btn{background:#00000026;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.35rem .85rem;border-radius:var(--radius-md);font-size:.75rem;font-weight:700;cursor:pointer;transition:all .2s ease;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center}.admin-toolbar-btn.stop{gap:.35rem;background:#fff;color:var(--secondary-color);border:none;box-shadow:var(--shadow-sm)}@media(max-width:768px){.admin-toolbar{flex-wrap:wrap;padding:.5rem}.admin-toolbar-left{width:100%;flex-wrap:wrap;gap:.5rem}.admin-toolbar-select{flex:1;min-width:100%;margin-left:0;margin-top:.25rem}.admin-toolbar-viewing{display:none}.admin-toolbar-right{width:100%;justify-content:flex-start;margin-top:.25rem;gap:.5rem;flex-wrap:wrap}.admin-toolbar-btn{flex:1;text-align:center;justify-content:center}}.editable-planned-amount{position:relative;display:inline-block;width:100%;max-width:150px}.editable-planned-amount-input:disabled{background-image:none!important;padding-right:2.25rem;transition:all .2s ease;cursor:pointer!important}.editable-planned-amount-input.is-closed:disabled{cursor:not-allowed!important}.editable-planned-amount:hover .editable-planned-amount-input:disabled:not(.is-closed){border-color:var(--primary-color);background-color:var(--surface-solid);box-shadow:0 0 0 2px #6366f11a}.editable-icon-wrapper{position:absolute;right:.6rem;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;pointer-events:none;transition:all .2s ease}.editable-planned-amount:hover .editable-icon-wrapper:not(.is-closed){transform:translateY(-50%) scale(1.15)}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.gantt-container{overflow-x:auto;min-width:0}.gantt-axis{position:relative;height:28px;border-bottom:1px solid var(--border-color);margin-bottom:.25rem}.gantt-axis-label{position:absolute;font-size:.7rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;transform:translate(-50%);white-space:nowrap;top:6px}.gantt-tracks{position:relative;min-height:60px}.gantt-grid-line{position:absolute;top:0;bottom:0;width:1px;background:var(--border-color);opacity:.5}.gantt-today{position:absolute;top:0;bottom:0;width:1px;background:transparent;border-left:1px dashed var(--text-secondary);opacity:.35;z-index:5;pointer-events:none}.gantt-today-label{position:absolute;bottom:-20px;left:50%;transform:translate(-50%);font-size:.6rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;opacity:1}.gantt-track{display:flex;align-items:center;height:44px;gap:0}.gantt-track-label{width:120px;min-width:120px;font-size:.78rem;font-weight:600;color:var(--text-primary);padding-right:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gantt-track-bar-area{position:relative;flex:1;height:28px}.gantt-bar{position:absolute;top:2px;height:24px;background:#6366f11f;border-radius:var(--radius-md);overflow:hidden;display:flex;align-items:center;cursor:default;transition:box-shadow .2s ease;border:1px solid rgba(99,102,241,.15)}.gantt-bar:hover{box-shadow:0 2px 10px #6366f133}.gantt-bar-fill{position:absolute;left:0;top:0;bottom:0;background:var(--primary-color);border-radius:var(--radius-md);transition:width .5s cubic-bezier(.4,0,.2,1);opacity:.85}.gantt-bar-label{position:relative;z-index:2;font-size:.68rem;font-weight:700;color:#fff;padding:0 8px;white-space:nowrap;text-shadow:0 1px 3px rgba(0,0,0,.3)}.gantt-scroll-wrapper{scrollbar-width:thin;scrollbar-color:rgba(99,102,241,.2) transparent}.gantt-scroll-wrapper::-webkit-scrollbar{width:6px;height:6px}.gantt-scroll-wrapper::-webkit-scrollbar-track{background:transparent}.gantt-scroll-wrapper::-webkit-scrollbar-thumb{background:#6366f12e;border-radius:3px}.gantt-scroll-wrapper::-webkit-scrollbar-thumb:hover{background:#6366f159}.gantt-drag-handle{display:flex;align-items:center;color:var(--text-secondary);cursor:grab;padding:.1rem;margin-right:.3rem;border-radius:var(--radius-md);opacity:0;transition:all .15s ease;flex-shrink:0}.gantt-track-label:hover .gantt-drag-handle{opacity:.5}.gantt-drag-handle:hover{opacity:1!important;color:var(--primary-color)}.gantt-drag-handle:active{cursor:grabbing}.gantt-row-drop-target{border-top:2px solid var(--primary-color)!important}.gantt-zoom-controls{display:inline-flex;align-items:center;gap:.15rem;background:var(--surface-solid);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:.2rem .35rem;box-shadow:var(--shadow-sm)}.gantt-zoom-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.3rem;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:all .15s ease}.gantt-zoom-btn:hover:not(:disabled){color:var(--primary-color);background:#6366f114}.gantt-zoom-btn:disabled{opacity:.3;cursor:not-allowed}.gantt-zoom-label{font-size:.72rem;font-weight:700;color:var(--text-secondary);min-width:36px;text-align:center;-webkit-user-select:none;user-select:none}.gantt-zoom-reset{margin-left:.15rem;border-left:1px solid var(--border-color);padding-left:.35rem}.milestone-list-cards{display:flex;flex-direction:column;gap:.75rem}.milestone-card{position:relative;background:var(--surface-solid);border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden;transition:border-color .15s ease}.milestone-card:hover{border-color:#6366f133}.milestone-card-accent{position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--primary-color)}.milestone-card-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem 1rem 1.5rem;gap:1rem}.milestone-expand-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;border-radius:var(--radius-md);display:flex;align-items:center;transition:all .15s ease;flex-shrink:0}.milestone-expand-btn:hover{background:#0000000d;color:var(--text-primary)}.milestone-progress-wrap{display:flex;align-items:center;gap:.5rem;min-width:120px}.milestone-progress-bar{flex:1;height:6px;background:#6366f11a;border-radius:var(--radius-pill);overflow:hidden}.milestone-progress-fill{height:100%;background:var(--primary-color);border-radius:var(--radius-pill);transition:width .5s cubic-bezier(.4,0,.2,1)}.milestone-progress-label{font-size:.78rem;font-weight:700;color:var(--primary-color);min-width:36px;text-align:right}.milestone-actions{display:flex;align-items:center;gap:.25rem;opacity:0;transition:opacity .2s ease}.milestone-card:hover .milestone-actions{opacity:1}.milestone-action-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.35rem;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:all .2s ease}.milestone-action-btn:hover{color:var(--primary-color);background:#6366f114}.milestone-action-btn--danger:hover{color:#ef4444;background:#ef444414}.milestone-action-btn--done{color:#10b981!important;background:#10b9811a;border-radius:var(--radius-md);animation:doneBtnPulse 2s ease-in-out infinite}.milestone-action-btn--done:hover{color:#059669!important;background:#10b98133}@keyframes doneBtnPulse{0%,to{box-shadow:0 0 #10b9814d}50%{box-shadow:0 0 0 4px #10b98100}}.milestone-action-btn--done-subtle{color:var(--text-secondary);opacity:.5}.milestone-action-btn--done-subtle:hover{color:#10b981!important;background:#10b98114;opacity:1}.milestone-menu-trigger{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.3rem;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:all .15s ease;opacity:0}.milestone-card:hover .milestone-menu-trigger{opacity:1}.milestone-menu-trigger:hover{color:var(--primary-color);background:#6366f114}.milestone-menu-dropdown{transform:translate(-100%)}.milestone-name-editable{border-radius:var(--radius-md);padding:.1rem .35rem;margin:-.1rem -.35rem;transition:all .15s ease}.milestone-name-editable:hover{background:#6366f10d;box-shadow:inset 0 0 0 1px #6366f11f}.milestone-name-edit-input{border:1.5px solid var(--primary-color)!important;border-radius:var(--radius-md)!important;background:var(--surface-solid)!important;box-shadow:0 0 0 3px #6366f11a}.milestone-completed-toggle{display:flex;align-items:center;gap:.5rem;background:none;border:none;cursor:pointer;font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);padding:.5rem 0;transition:color .15s ease;width:100%}.milestone-completed-toggle:hover{color:var(--text-primary)}.milestone-completed-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;border-radius:var(--radius-pill);background:#10b9811f;color:#10b981;font-size:.7rem;font-weight:700;padding:0 6px}.milestone-completed-list{margin-top:.5rem;animation:milestoneAccordionOpen .25s ease}.milestone-completed-card{background:var(--surface-solid);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:.75rem 1rem;margin-bottom:.5rem;opacity:.75;transition:all .2s ease}.milestone-completed-card:hover{opacity:1;border-color:#10b98140}.milestone-completed-card-content{display:flex;align-items:center;gap:.75rem}.milestone-completed-icon{color:#10b981;flex-shrink:0}.milestone-completion-prompt{max-width:360px;text-align:center}.milestone-accordion{padding:0 1.25rem 1rem 1.5rem;border-top:1px solid var(--border-color);margin-top:0;animation:milestoneAccordionOpen .25s ease}@keyframes milestoneAccordionOpen{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.milestone-task{display:flex;align-items:center;gap:.6rem;padding:.5rem 0;border-bottom:1px solid rgba(226,232,240,.5);transition:opacity .2s ease}.milestone-task:last-of-type{border-bottom:none}.milestone-task--done .milestone-task-text{text-decoration:line-through;color:var(--text-secondary);opacity:.65}.milestone-task-check{position:relative;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.milestone-task-check input{position:absolute;opacity:0;width:0;height:0}.milestone-task-checkmark{width:18px;height:18px;border:2px solid var(--border-color);border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.milestone-task-check input:checked+.milestone-task-checkmark{background:var(--primary-color);border-color:var(--primary-color)}.milestone-task-check input:checked+.milestone-task-checkmark:after{content:"";width:5px;height:9px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg);margin-top:-1px}.milestone-task-text{flex:1;font-size:.85rem;color:var(--text-primary);line-height:1.4}.milestone-task-delete{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;border-radius:var(--radius-md);display:flex;align-items:center;opacity:0;transition:all .15s ease}.milestone-task:hover .milestone-task-delete{opacity:1}.milestone-task-delete:hover{color:#ef4444;background:#ef444414}.milestone-add-task{display:flex;gap:.5rem;padding-top:.75rem;margin-top:.25rem;border-top:1px dashed rgba(226,232,240,.6)}.milestone-add-task .form-input{flex:1}.milestone-quick-add{display:flex;gap:.5rem;padding:.5rem 0;margin-top:.75rem}.milestone-quick-add .form-input{flex:1;border:1.5px solid var(--border-color);border-radius:var(--radius-lg);transition:all .2s ease;background:#6366f108}.milestone-quick-add .form-input:focus{border-color:var(--primary-color);background:var(--surface-solid);box-shadow:0 0 0 3px #6366f11f}.milestone-quick-add .form-input::placeholder{color:var(--text-secondary);opacity:.8}.milestone-quick-add-btn{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:38px;height:38px;border:1.5px solid rgba(99,102,241,.25);border-radius:var(--radius-lg);background:#6366f114;color:var(--primary-color);cursor:pointer;transition:all .2s ease}.milestone-quick-add-btn:hover:not(:disabled){background:#6366f12e;border-color:var(--primary-color)}.milestone-quick-add-btn:disabled{opacity:.3;cursor:not-allowed}.milestone-empty .milestone-quick-add{max-width:400px;margin:0 auto}.milestone-empty{text-align:center;padding:3rem 1.5rem}@media(max-width:640px){.milestone-card-header{flex-direction:column;align-items:flex-start;gap:.75rem}.milestone-progress-wrap{width:100%}.milestone-actions{opacity:1}.gantt-track-label{width:80px;min-width:80px;font-size:.7rem}.milestone-drag-handle{display:none}}.milestone-drag-handle{display:flex;align-items:center;color:var(--text-secondary);cursor:grab;padding:.15rem;border-radius:var(--radius-md);opacity:.35;transition:all .15s ease;flex-shrink:0}.milestone-card:hover .milestone-drag-handle{opacity:.7}.milestone-drag-handle:hover{opacity:1!important;color:var(--primary-color)}.milestone-drag-handle:active{cursor:grabbing}.milestone-task-drag-handle{display:flex;align-items:center;color:var(--text-secondary);cursor:grab;padding:.1rem;opacity:0;transition:opacity .15s ease;flex-shrink:0}.milestone-task:hover .milestone-task-drag-handle{opacity:.5}.milestone-task-drag-handle:hover{opacity:1!important;color:var(--primary-color)}.milestone-task-drag-handle:active{cursor:grabbing}.milestone-progress-clickable{cursor:pointer;border-radius:var(--radius-md);padding:.2rem .35rem;margin:-.2rem -.35rem;transition:background .15s ease}.milestone-progress-clickable:hover{background:#6366f10f}.milestone-progress-input,.milestone-task-edit-input{border:1.5px solid var(--primary-color)!important;border-radius:var(--radius-md)!important;background:var(--surface-solid)!important}.gantt-compact .gantt-axis-label{font-size:.6rem}.gantt-compact .gantt-track{height:32px}.gantt-compact .gantt-track-label{width:80px;min-width:80px;font-size:.65rem}.gantt-compact .gantt-bar{height:18px;border-radius:9px}.gantt-compact .gantt-bar-fill{border-radius:9px}.gantt-compact .gantt-bar-label{font-size:.55rem}.milestone-card{position:relative;overflow:hidden}.milestone-celebration{position:absolute;inset:0;z-index:10;pointer-events:none;overflow:hidden}.milestone-confetti{position:absolute;top:-10px;border-radius:50%;opacity:0;animation:confettiFall ease-out forwards}@keyframes confettiFall{0%{opacity:1;transform:translateY(0) rotate(0) scale(1)}40%{opacity:1}to{opacity:0;transform:translateY(120px) rotate(720deg) scale(.3)}}.milestone-celebration-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.5rem;font-weight:800;color:var(--primary-color);animation:celebrationPop .6s cubic-bezier(.175,.885,.32,1.275) forwards;text-shadow:0 2px 8px rgba(99,102,241,.3);white-space:nowrap}@keyframes celebrationPop{0%{opacity:0;transform:translate(-50%,-50%) scale(.3)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.15)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.apm-container{width:100%;max-width:500px;margin:0 auto}.apm-container--full{max-width:700px}.apm-svg{width:100%;height:auto}.apm-quadrant{fill:transparent}.apm-quadrant-label{font-size:13px;font-weight:600;fill:var(--text-secondary);text-anchor:middle;opacity:.35;text-transform:uppercase;letter-spacing:.06em}.apm-axis{stroke:var(--border-color);stroke-width:1.5}.apm-divider{stroke:var(--border-color);stroke-width:1;stroke-dasharray:4 3;opacity:.4}.apm-axis-title{font-size:11px;font-weight:700;fill:var(--text-secondary);text-anchor:middle;letter-spacing:.08em}.apm-axis-title--y{text-anchor:middle}.apm-tick{font-size:9px;fill:var(--text-secondary);opacity:.7}.apm-dot{cursor:default;transition:transform .2s ease,stroke-opacity .2s ease,fill-opacity .2s ease}.apm-dot-group{cursor:pointer}.apm-dot-label{font-size:10px;font-weight:600;fill:var(--text-primary);text-anchor:middle;pointer-events:none}.apm-dot-progress{font-size:8px;font-weight:700;fill:#fff;text-anchor:middle;pointer-events:none}.apm-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--border-color)}.apm-legend-item{display:flex;align-items:center;gap:.35rem;font-size:.78rem;font-weight:500;color:var(--text-secondary)}.apm-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.apm-inline-badge{display:inline-flex;align-items:center;gap:.2rem;padding:.1rem .45rem;border-radius:var(--radius-md);font-size:.7rem;font-weight:600;line-height:1.4;white-space:nowrap}.apm-inline-badge--impact{background:#10b9811a;color:#10b981;border:1px solid rgba(16,185,129,.2)}.apm-inline-badge--effort{background:#f59e0b1a;color:#d97706;border:1px solid rgba(245,158,11,.2)}.apm-inline-badge--clickable{cursor:pointer;transition:background .15s ease,box-shadow .15s ease}.apm-inline-badge--clickable:hover{box-shadow:0 0 0 2px currentColor;background:#6366f10f}.apm-badge-label{opacity:.7;font-weight:500}.apm-badge-value{font-weight:700}.apm-inline-input{width:36px;border:none;background:transparent;color:inherit;font-size:.7rem;font-weight:700;text-align:center;outline:none;-moz-appearance:textfield}.apm-inline-input::-webkit-outer-spin-button,.apm-inline-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideOutRight{0%{transform:translate(0)}to{transform:translate(100%)}}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}@keyframes fadeOutOverlay{0%{opacity:1}to{opacity:0}}.drawer-overlay{position:fixed;inset:0;background-color:#00000080;z-index:50;animation:fadeInOverlay .3s ease forwards}.drawer-overlay.closing{animation:fadeOutOverlay .3s ease forwards}.drawer-container{position:fixed;top:0;right:0;bottom:0;width:100%;max-width:480px;background:var(--surface-solid);box-shadow:-4px 0 24px #00000026;border-left:1px solid var(--border-color);z-index:51;overflow-y:auto;animation:slideInRight .3s cubic-bezier(.16,1,.3,1) forwards;display:flex;flex-direction:column}.drawer-container.closing{animation:slideOutRight .3s cubic-bezier(.16,1,.3,1) forwards}.drawer-header{padding:1.5rem 2rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:var(--surface-solid);z-index:10}.drawer-body{padding:2rem;flex:1}.task-drawer-backdrop{position:fixed;inset:0;background:#00000073;z-index:100;animation:fadeInOverlay .3s ease forwards}.task-drawer-backdrop--closing{animation:fadeOutOverlay .3s ease forwards}.task-drawer{position:fixed;top:0;right:0;bottom:0;width:100%;max-width:520px;background:var(--surface-solid);box-shadow:-6px 0 32px #0000002e;border-left:1px solid var(--border-color);z-index:101;display:flex;flex-direction:column;animation:slideInRight .3s cubic-bezier(.16,1,.3,1) forwards}.task-drawer--closing{animation:slideOutRight .3s cubic-bezier(.16,1,.3,1) forwards}.task-drawer-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);flex-shrink:0}.task-drawer-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.4rem;border-radius:var(--radius-md);display:flex;align-items:center;transition:all .15s ease}.task-drawer-close:hover{background:#0000000d;color:var(--text-primary)}.task-drawer-delete{background:none;border:1px solid rgba(239,68,68,.2);color:#ef4444;cursor:pointer;padding:.35rem .75rem;border-radius:var(--radius-md);display:flex;align-items:center;gap:.35rem;font-size:.78rem;font-weight:500;transition:all .15s ease}.task-drawer-delete:hover{background:#ef444414;border-color:#ef444466}.task-drawer-body{flex:1;overflow-y:auto;padding:1.5rem}.task-drawer-title{font-size:1.3rem;font-weight:700;color:var(--text-primary);margin:0 0 1.25rem;line-height:1.35}.task-drawer-title-input{font-size:1.3rem;font-weight:700;color:var(--text-primary);width:100%;border:1.5px solid var(--primary-color);border-radius:var(--radius-md);padding:.4rem .6rem;background:var(--surface-solid);margin-bottom:1.25rem}.task-drawer-meta{display:flex;flex-direction:column;gap:.85rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.task-drawer-meta-item{display:flex;align-items:center;gap:.75rem}.task-drawer-meta-label{display:flex;align-items:center;gap:.35rem;font-size:.78rem;font-weight:600;color:var(--text-secondary);min-width:90px;flex-shrink:0}.task-drawer-meta-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.task-pill{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .6rem;border-radius:var(--radius-pill);border:none;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s ease}.task-pill:hover{filter:brightness(.95)}.task-pill:disabled{cursor:default;opacity:.7}.task-pill--add{color:var(--text-secondary);background:#0000000a;font-weight:500}.task-pill--add:hover{background:#00000014}.task-dropdown{position:absolute;top:100%;left:90px;z-index:20;min-width:160px;background:var(--surface-solid);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:.35rem;margin-top:.25rem}.task-dropdown--wide{min-width:220px}.task-dropdown-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.45rem .6rem;border:none;background:none;color:var(--text-primary);font-size:.82rem;cursor:pointer;border-radius:var(--radius-md);transition:background .12s ease}.task-dropdown-item:hover{background:#6366f10f}.task-dropdown-item.active{background:#6366f11a;font-weight:600}.task-date-input{border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.3rem .5rem;font-size:.82rem;color:var(--text-primary);background:var(--surface-solid)}.task-date-input:disabled{opacity:.6}.task-due-badge{font-size:.7rem;font-weight:600;padding:.15rem .45rem;border-radius:var(--radius-pill)}.task-due-overdue{background:#ef44441f;color:#ef4444}.task-due-today{background:#f59e0b1f;color:#d97706}.task-due-soon{background:#3b82f61f;color:#3b82f6}.task-assignee-chip{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .55rem .2rem .25rem;background:#6366f114;border-radius:var(--radius-pill);font-size:.78rem;font-weight:500;color:var(--text-primary)}.task-assignee-avatar{width:22px;height:22px;border-radius:50%;background:var(--primary-color);color:#fff;font-size:.6rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.task-assignee-remove{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:0;display:flex;align-items:center;transition:color .15s ease}.task-assignee-remove:hover{color:#ef4444}.task-drawer-section{margin-bottom:1.5rem}.task-drawer-section-title{display:flex;align-items:center;gap:.4rem;font-size:.82rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.75rem}.task-drawer-desc{font-size:.9rem;color:var(--text-primary);line-height:1.6;padding:.6rem .75rem;border:1px solid transparent;border-radius:var(--radius-md);min-height:60px;white-space:pre-wrap;transition:border-color .15s ease}.task-drawer-desc:hover{border-color:var(--border-color)}.task-drawer-desc-input{width:100%;font-size:.9rem;color:var(--text-primary);line-height:1.6;padding:.6rem .75rem;border:1.5px solid var(--primary-color);border-radius:var(--radius-md);background:var(--surface-solid);resize:vertical;min-height:80px}.task-comments-list{max-height:300px;overflow-y:auto;margin-bottom:.75rem}.task-comment{padding:.65rem 0;border-bottom:1px solid rgba(226,232,240,.5)}.task-comment:last-child{border-bottom:none}.task-comment-header{display:flex;align-items:center;gap:.4rem;margin-bottom:.3rem}.task-comment-author{font-size:.82rem;font-weight:600;color:var(--text-primary)}.task-comment-time{font-size:.72rem;color:var(--text-secondary);margin-left:auto}.task-comment-delete{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.2rem;border-radius:var(--radius-md);opacity:0;transition:all .15s ease}.task-comment:hover .task-comment-delete{opacity:1}.task-comment-delete:hover{color:#ef4444}.task-comment-body{font-size:.85rem;color:var(--text-primary);line-height:1.5;padding-left:32px}.task-update-input-wrap{display:flex;flex-direction:column;gap:.5rem}.task-update-input-wrap .rte-wrapper{border-radius:var(--radius-md)}.task-update-input-wrap .rte-content{min-height:60px;max-height:120px;overflow-y:auto}.task-comment-send{background:var(--primary-color);border:none;color:#fff;cursor:pointer;padding:.5rem 1rem;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;gap:.35rem;transition:opacity .15s ease;align-self:flex-end;font-size:.82rem;font-weight:600}.task-comment-send:disabled{opacity:.4;cursor:default}.task-comment-send:not(:disabled):hover{filter:brightness(1.1)}.task-mini-avatar{width:20px;height:20px;border-radius:50%;background:var(--primary-color);color:#fff;font-size:.5rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;margin-left:-4px;border:1.5px solid var(--surface-solid);flex-shrink:0}.task-mini-avatar:first-child{margin-left:0}@media(max-width:640px){.task-drawer{max-width:100%}}.task-update-composer{border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:1.25rem;transition:border-color .2s ease,box-shadow .2s ease;cursor:pointer}.task-update-composer--expanded{border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a;padding:.5rem .75rem;cursor:default}.task-update-composer-placeholder{padding:.7rem 1rem;font-size:.88rem;color:var(--text-secondary)}.task-update-composer-placeholder:hover{color:var(--text-primary)}.task-update-composer-inner{position:relative}.task-update-composer .rte-content{min-height:50px;max-height:180px;overflow-y:auto;padding:.5rem .25rem;font-size:.88rem}.task-update-composer .rte-toolbar{border-bottom:1px solid var(--border-color);padding-bottom:.35rem;margin-bottom:0}.task-update-inline-send{position:absolute;bottom:.35rem;right:.25rem;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;border-radius:50%;background:var(--primary-color);color:#fff;cursor:pointer;transition:all .15s ease}.task-update-inline-send:hover:not(:disabled){filter:brightness(1.1);transform:scale(1.05)}.task-update-inline-send:disabled{opacity:.35;cursor:not-allowed}.task-update-inline-send--reply{width:28px;height:28px;bottom:.3rem;right:.3rem}.task-update-card{border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:1rem;background:var(--surface-solid);transition:box-shadow .2s ease}.task-update-card:hover{box-shadow:0 2px 8px #0000000f}@keyframes updateCardEnter{0%{opacity:0;transform:translateY(-16px) scale(.97);max-height:0;margin-bottom:0;padding:0;overflow:hidden}40%{max-height:400px;margin-bottom:1rem;overflow:hidden}to{opacity:1;transform:translateY(0) scale(1);max-height:400px;margin-bottom:1rem}}.task-update-card--entering{animation:updateCardEnter .5s cubic-bezier(.34,1.56,.64,1) forwards}.task-update-card-inner{padding:1rem 1.25rem}.task-update-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.task-update-card-author{font-size:.88rem;font-weight:700;color:var(--text-primary)}.task-update-card-time{font-size:.75rem;color:var(--text-secondary)}.task-update-menu-wrap{position:relative;margin-left:auto;opacity:0;transition:opacity .15s ease}.task-update-card:hover .task-update-menu-wrap,.task-update-reply:hover .task-update-menu-wrap--reply,.task-update-menu-wrap:focus-within{opacity:1}.task-update-menu-trigger{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.task-update-menu-trigger:hover{background:#0000000f;color:var(--text-primary)}.task-update-menu-dropdown{position:absolute;top:100%;right:0;z-index:50;min-width:130px;background:var(--surface-solid);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 4px 16px #0000001f;padding:.25rem 0;animation:menuFadeIn .12s ease}@keyframes menuFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.task-update-menu-dropdown button{display:flex;align-items:center;gap:.5rem;width:100%;padding:.45rem .75rem;font-size:.82rem;border:none;background:transparent;color:var(--text-primary);cursor:pointer;transition:background .12s ease}.task-update-menu-dropdown button:hover{background:#0000000a}.task-update-menu-danger{color:#ef4444!important}.task-update-menu-danger:hover{background:#ef44440f!important}.task-update-edit-wrap{position:relative;border:1px solid var(--primary-color);border-radius:var(--radius-md);padding:.4rem .6rem;margin-top:.5rem;box-shadow:0 0 0 3px #6366f114}.task-update-edit-wrap .rte-toolbar{border-bottom:1px solid var(--border-color);padding-bottom:.3rem}.task-update-edit-wrap .rte-content{min-height:36px;max-height:160px;overflow-y:auto;padding:.4rem .25rem;font-size:.88rem}.task-update-card-body{font-size:.9rem;color:var(--text-primary);line-height:1.6;padding-bottom:.5rem}.task-update-actions{display:flex;align-items:center;gap:.75rem;padding:.5rem 1.25rem;border-top:1px solid var(--border-color)}.task-update-action-btn{display:inline-flex;align-items:center;gap:.3rem;background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:.8rem;font-weight:500;padding:.3rem .5rem;border-radius:var(--radius-md);transition:all .15s ease}.task-update-action-btn:hover{background:#0000000a;color:var(--text-primary)}.task-update-action-btn--liked{color:var(--primary-color);font-weight:600}.task-update-action-btn--liked:hover{background:#6366f114}.task-update-like-count{font-size:.75rem;font-weight:600;min-width:14px;text-align:center}.task-update-replies{border-top:1px solid var(--border-color);padding:.75rem 1.25rem;display:flex;flex-direction:column;gap:.5rem}.task-update-reply{display:flex;gap:.5rem;align-items:flex-start}.task-update-reply-content{flex:1;min-width:0;background:#00000006;border-radius:var(--radius-md);padding:.5rem .75rem}.task-update-reply-header{display:flex;align-items:center;gap:.4rem;margin-bottom:.15rem}.task-update-reply-author{font-size:.82rem;font-weight:700;color:var(--text-primary)}.task-update-reply-time{font-size:.7rem;color:var(--text-secondary)}.task-update-reply-body{font-size:.85rem;color:var(--text-primary);line-height:1.5}.task-update-reply-actions{display:flex;align-items:center;gap:.5rem;margin-top:.25rem;padding-left:2.5rem}.task-update-reply-composer{display:flex;gap:.5rem;align-items:flex-start;padding-top:.75rem;margin-top:.25rem;cursor:pointer}.task-update-reply-composer--expanded{cursor:default}.task-update-reply-placeholder{flex:1;min-width:0;border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:.55rem .85rem;font-size:.85rem;color:var(--text-secondary);transition:border-color .2s ease;background:var(--surface-solid)}.task-update-reply-placeholder:hover{border-color:var(--primary-color)}.task-update-reply-input-wrap{flex:1;min-width:0;position:relative;border:1px solid var(--primary-color);border-radius:var(--radius-lg);padding:.4rem .6rem;transition:border-color .2s ease;box-shadow:0 0 0 3px #6366f114}.task-update-reply-input-wrap--expanded{min-height:60px}.task-update-reply-input-wrap .rte-content{min-height:24px;max-height:120px;overflow-y:auto;font-size:.85rem;padding:.25rem 0}.task-update-reply-input-wrap--expanded .rte-content{min-height:36px}.task-update-reply-input-wrap .rte-toolbar{border-bottom:1px solid var(--border-color);padding-bottom:.3rem;margin-bottom:0}.task-comment-count-badge{display:inline-flex;align-items:center;gap:.2rem;font-size:.7rem;color:var(--text-secondary);cursor:pointer;padding:.1rem .25rem;border-radius:var(--radius-md);transition:all .15s ease}.task-comment-count-badge:hover{color:var(--primary-color);background:#6366f10f}.task-estimate-badge{display:inline-flex;align-items:center;gap:.2rem;font-size:.7rem;color:var(--text-secondary);padding:.1rem .35rem;border-radius:var(--radius-md);transition:all .15s ease;font-variant-numeric:tabular-nums}.task-estimate-badge:hover{color:#0891b2;background:#0891b20f}.milestone-not-planned-link{color:var(--primary-color);font-size:.78rem;font-weight:500;cursor:pointer;text-decoration:none;transition:all .15s ease;border-bottom:1px dashed var(--primary-color);padding-bottom:1px}.milestone-not-planned-link:hover{color:var(--primary-hover);border-bottom-style:solid}.milestone-planned-date-link{cursor:pointer;transition:all .15s ease;border-radius:var(--radius-sm);padding:.1rem .3rem;margin:-.1rem -.3rem}.milestone-planned-date-link:hover{color:var(--primary-color);background:#6366f10f}.milestone-date-overlay{position:fixed;inset:0;z-index:9999;background:#00000059;display:flex;align-items:center;justify-content:center;animation:milestoneOverlayIn .15s ease-out}@keyframes milestoneOverlayIn{0%{opacity:0}to{opacity:1}}.milestone-date-popover{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:0 20px 60px #00000026,0 4px 16px #00000014;padding:1.25rem;min-width:340px;max-width:90vw;animation:milestonePopoverIn .2s ease-out}@keyframes milestonePopoverIn{0%{opacity:0;transform:translateY(-10px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.milestone-date-popover-title{font-size:.9rem;font-weight:600;color:var(--text-primary);margin:0 0 .85rem}.milestone-date-popover-row{display:flex;gap:.75rem;margin-bottom:.85rem}.milestone-date-popover-field{flex:1;display:flex;flex-direction:column;gap:.35rem}.milestone-date-popover-field label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.milestone-date-popover-field .form-input{font-size:.85rem;padding:.5rem .6rem}.milestone-date-popover-actions{display:flex;gap:.5rem;justify-content:flex-end}.milestone-date-popover-actions .btn{font-size:.8rem;padding:.4rem 1rem}.daterange-picker{margin-bottom:.85rem}.daterange-label{display:block;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:.5rem}.daterange-inputs{display:flex;gap:0;margin-bottom:.85rem;border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;transition:border-color .15s ease}.daterange-input-box{flex:1;padding:.6rem .75rem;cursor:pointer;display:flex;align-items:center;transition:all .15s ease;background:var(--surface-solid, #fff);position:relative;-webkit-user-select:none;user-select:none}.daterange-input-box:first-child{border-right:1px solid var(--border-color)}.daterange-input-box:hover{background:#6366f108}.daterange-input-box--active{background:#6366f10f;box-shadow:inset 0 -2px 0 0 var(--primary-color)}.daterange-input-placeholder{font-size:.85rem;color:var(--text-secondary);opacity:.6}.daterange-input-value{font-size:.85rem;font-weight:500;color:var(--text-primary)}.daterange-calendar{border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.75rem;background:var(--surface-solid, #fff)}.daterange-calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.daterange-calendar-month-selectors{display:flex;align-items:center;gap:.35rem}.daterange-month-select,.daterange-year-select{background:none;border:none;font-size:.88rem;font-weight:600;color:var(--text-primary);cursor:pointer;padding:.15rem .1rem;outline:none;-webkit-appearance:auto;appearance:auto}.daterange-calendar-nav{display:flex;align-items:center;gap:.15rem}.daterange-nav-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);font-size:1.25rem;cursor:pointer;transition:all .12s ease;line-height:1}.daterange-nav-btn:hover{background:#0000000d;color:var(--text-primary)}.daterange-weekdays{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:.25rem}.daterange-weekday{text-align:center;font-size:.72rem;font-weight:600;color:var(--text-secondary);padding:.35rem 0;text-transform:uppercase;letter-spacing:.03em}.daterange-grid{display:grid;grid-template-columns:repeat(7,1fr)}.daterange-day{display:flex;align-items:center;justify-content:center;width:100%;aspect-ratio:1;border:none;background:transparent;font-size:.82rem;font-weight:500;color:var(--text-primary);cursor:pointer;border-radius:0;transition:background .1s ease,color .1s ease;position:relative}.daterange-day:hover{background:#6366f114;border-radius:50%}.daterange-day--outside{color:var(--text-secondary);opacity:.4}.daterange-day--outside:hover{opacity:.7}.daterange-day--today{color:var(--primary-color);font-weight:700}.daterange-day--in-range{background:#6366f114;border-radius:0}.daterange-day--in-range:hover{background:#6366f126;border-radius:0}.daterange-day--selected{background:var(--primary-color);color:#fff;font-weight:600;border-radius:50%;z-index:1}.daterange-day--selected:hover{background:var(--primary-hover);border-radius:50%}.daterange-day--start{border-radius:50% 0 0 50%}.daterange-day--start.daterange-day--selected{border-radius:50%}.daterange-day--end{border-radius:0 50% 50% 0}.daterange-day--end.daterange-day--selected{border-radius:50%}.daterange-day--start:after,.daterange-day--end:before{content:"";position:absolute;top:0;bottom:0;width:50%;background:#6366f114;z-index:-1;display:none}.daterange-day--start:after{right:0}.daterange-day--end:before{left:0}.daterange-day--start.daterange-day--has-range:after{display:block}.daterange-day--end.daterange-day--has-range:before{display:block}.task-attachments-grid{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.task-attachment-card{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;background:var(--bg-color);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all .15s ease}.task-attachment-card:hover{border-color:#6366f14d;box-shadow:0 1px 4px #0000000a}.task-attachment-icon{flex-shrink:0;width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;overflow:hidden}.task-attachment-thumb{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-md)}.task-attachment-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem}.task-attachment-name{font-size:.85rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-attachment-size{font-size:.72rem;color:var(--text-secondary)}.task-attachment-actions{display:flex;align-items:center;gap:.25rem;flex-shrink:0;opacity:0;transition:opacity .15s ease}.task-attachment-card:hover .task-attachment-actions{opacity:1}.task-attachment-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-md);border:none;background:none;cursor:pointer;color:var(--text-secondary);transition:all .12s ease;text-decoration:none}.task-attachment-btn:hover{background:#0000000f;color:var(--primary-color)}.task-attachment-btn--delete:hover{color:#ef4444;background:#ef444414}.task-attachment-dropzone{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border:2px dashed var(--border-color);border-radius:var(--radius-lg);cursor:pointer;color:var(--text-secondary);font-size:.82rem;transition:all .18s ease;background:transparent}.task-attachment-dropzone:hover{border-color:var(--primary-color);color:var(--primary-color);background:#6366f108}.task-attachment-dropzone--active{border-color:var(--primary-color);background:#6366f10f;color:var(--primary-color)}.task-attachment-uploading{display:flex;flex-direction:column;align-items:center;gap:.4rem;width:100%}.task-attachment-uploading span{font-size:.82rem;font-weight:500;color:var(--primary-color)}.task-attachment-progress-bar{width:100%;max-width:240px;height:4px;background:#6366f11f;border-radius:2px;overflow:hidden}.task-attachment-progress-fill{height:100%;background:linear-gradient(135deg,var(--primary-color),var(--primary-hover));border-radius:2px;transition:width .2s ease-out}.milestone-desc-indicator{display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:.15rem .3rem;border-radius:var(--radius-sm);transition:all .15s ease}.milestone-desc-indicator.has-description{color:var(--primary-color)}.milestone-desc-indicator.has-description:hover{background:#6366f11a;color:var(--primary-hover)}.milestone-desc-indicator.no-description{color:var(--text-secondary);opacity:.45}.milestone-desc-indicator.no-description:hover{opacity:1;color:var(--primary-color);background:#6366f10f}.milestone-desc-save-status{display:inline-flex;align-items:center;gap:.25rem;font-size:.78rem;font-weight:500}.milestone-desc-save-status.saving{color:var(--text-secondary)}.milestone-desc-save-status.saved{color:var(--success-color, #22c55e)}.milestone-desc-editor,.milestone-desc-editor .tiptap-editor{min-height:200px}.milestone-desc-readonly{padding:.5rem 0;line-height:1.65;font-size:.92rem;color:var(--text-primary)}.milestone-desc-content p{margin-bottom:.5em}.milestone-desc-content ul,.milestone-desc-content ol{padding-left:1.5em;margin-bottom:.5em}.milestone-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-color);margin-bottom:.75rem}.milestone-tab{background:none;border:none;padding:.5rem 1rem;font-size:.82rem;font-weight:600;color:var(--text-secondary);cursor:pointer;position:relative;transition:color .15s ease;display:inline-flex;align-items:center;gap:.35rem}.milestone-tab:hover{color:var(--text-primary)}.milestone-tab.active{color:var(--primary-color)}.milestone-tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--primary-color);border-radius:1px 1px 0 0}.milestone-tab-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--primary-color)}.milestone-desc-tab{padding:.25rem 0 .5rem}.milestone-desc-status{margin-top:.5rem;min-height:1.2rem}.milestone-sort-selector{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .15rem .35rem .5rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.78rem;color:var(--text-secondary);transition:border-color .15s ease}.milestone-sort-selector:hover{border-color:var(--primary-color)}.milestone-sort-selector select{background:none;border:none;font-size:.78rem;font-weight:500;color:var(--text-primary);cursor:pointer;padding:0;padding-right:.25rem;outline:none;-webkit-appearance:auto;appearance:auto}.task-menu-wrapper{position:relative;display:inline-flex;align-items:center}.task-menu-trigger{background:none;border:none;cursor:pointer;padding:.2rem;border-radius:var(--radius-sm);color:var(--text-secondary);opacity:0;transition:all .15s ease;display:inline-flex;align-items:center}.milestone-task:hover .task-menu-trigger{opacity:1}.task-menu-trigger:hover{color:var(--text-primary);background:#0000000d}.task-menu-backdrop{position:fixed;inset:0;z-index:9999}.task-menu-dropdown{position:fixed;z-index:10000;min-width:200px;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 8px 24px #0000001f,0 2px 8px #00000014;padding:.35rem 0;animation:taskMenuFadeIn .12s ease-out;transform:translate(-100%)}@keyframes taskMenuFadeIn{0%{opacity:0;transform:translateY(-4px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.task-menu-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .85rem;font-size:.82rem;font-weight:500;color:var(--text-primary);background:none;border:none;cursor:pointer;transition:background .1s ease;white-space:nowrap}.task-menu-item:hover{background:#6366f10f}.task-menu-item--danger{color:#ef4444}.task-menu-item--danger:hover{background:#ef44440f}.task-menu-divider{height:1px;background:var(--border-color);margin:.3rem 0}.task-move-popover{max-width:400px}.task-move-list{max-height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:.15rem}.task-move-item{display:flex;align-items:center;gap:.6rem;width:100%;padding:.6rem .75rem;font-size:.85rem;font-weight:500;color:var(--text-primary);background:none;border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease}.task-move-item:hover{background:#6366f10f;border-color:var(--primary-color);color:var(--primary-color)}.milestone-time-badge{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;font-weight:600;color:var(--primary-color);background:#6366f114;padding:.15rem .5rem;border-radius:999px;white-space:nowrap;cursor:pointer;transition:all .15s ease}.milestone-time-badge:hover{background:#6366f124}.milestone-time-tab{padding:.25rem 0 .5rem}.time-log-form{display:flex;flex-wrap:wrap;gap:.5rem;align-items:flex-end;padding:.75rem 0;margin-bottom:.5rem;border-bottom:1px solid var(--border-color)}.time-log-submit{align-self:flex-end;white-space:nowrap;font-size:.8rem;padding:.45rem 1rem}.time-table-wrapper{overflow-x:auto}.time-table{width:100%;border-collapse:collapse;font-size:.82rem}.time-table thead th{font-size:.72rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;text-align:left;padding:.5rem .6rem;border-bottom:1px solid var(--border-color);white-space:nowrap}.time-table tbody td{padding:.55rem .6rem;color:var(--text-primary);border-bottom:1px solid rgba(0,0,0,.04);vertical-align:middle}.time-table-row:hover td{background:#00000004}.time-table-date{font-weight:500;white-space:nowrap;color:var(--text-secondary)}.time-table-duration{font-weight:600;font-variant-numeric:tabular-nums;white-space:nowrap}.time-table-user{font-weight:500;color:var(--text-secondary);white-space:nowrap}.time-table-note{color:var(--text-secondary);font-style:italic;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.time-table-actions{width:28px;padding-right:.25rem}.time-entry-delete{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:none;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);opacity:0;transition:all .12s ease;flex-shrink:0}.time-table-row:hover .time-entry-delete{opacity:1}.time-entry-delete:hover{color:#ef4444;background:#ef444414}.time-table tfoot td{padding:.6rem;border-top:1px solid var(--border-color);font-size:.82rem;font-weight:600;color:var(--text-primary)}.time-table-total .time-table-duration{color:var(--primary-color);font-weight:700}.time-empty-state{text-align:center;padding:1.5rem .75rem;color:var(--text-secondary);font-size:.85rem;font-style:italic}.dashboard-tabs{display:flex;gap:0;border-bottom:2px solid var(--border-color);margin-bottom:2rem}.dashboard-tab{background:none;border:none;padding:.75rem 1.25rem;font-size:.92rem;font-weight:600;color:var(--text-secondary);cursor:pointer;position:relative;transition:color .15s ease;display:inline-flex;align-items:center;gap:.4rem}.dashboard-tab:hover{color:var(--text-primary)}.dashboard-tab.active{color:var(--primary-color)}.dashboard-tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--primary-color);border-radius:1px 1px 0 0}.time-overview-card{background:var(--surface-solid);border-radius:var(--radius-xl);border:1px solid var(--border-color);box-shadow:var(--shadow-md);overflow:hidden}.time-overview-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:.75rem}.time-overview-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.time-overview-filter{display:flex;align-items:center;gap:.5rem}.time-overview-filter label{font-size:.78rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.time-overview-filter select{font-size:.85rem;padding:.45rem .75rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--surface-solid);color:var(--text-primary);min-width:200px;cursor:pointer;transition:border-color .15s ease}.time-overview-filter select:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #6366f11a}.time-grid-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.time-grid{width:100%;border-collapse:collapse;font-size:.85rem}.time-grid thead th{padding:.65rem .75rem;text-align:center;font-weight:600;font-size:.72rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color);white-space:nowrap;position:sticky;top:0;z-index:2;background:var(--surface-solid)}.time-grid thead th:first-child{text-align:left;position:sticky;left:0;z-index:3;background:var(--surface-solid);min-width:180px}.time-grid thead th:last-child{color:var(--text-secondary)}.time-grid tbody td{padding:.6rem .75rem;text-align:center;border-bottom:1px solid rgba(0,0,0,.04);font-variant-numeric:tabular-nums;transition:background .1s ease}.time-grid tbody td:first-child{text-align:left;font-weight:600;color:var(--text-primary);position:sticky;left:0;z-index:1;background:var(--surface-solid)}.time-grid tbody tr:hover td{background:#00000004}.time-grid tbody tr:hover td:first-child{background:#00000005}.time-grid-cell{font-weight:500;color:var(--text-primary)}.time-grid-cell--zero{color:var(--text-secondary);opacity:.35}.time-grid-cell--total{font-weight:700;color:var(--primary-color)}.time-grid tfoot td{padding:.65rem .75rem;text-align:center;font-weight:600;border-top:1px solid var(--border-color);color:var(--text-primary);background:var(--surface-solid)}.time-grid tfoot td:first-child{text-align:left;position:sticky;left:0;z-index:1;background:var(--surface-solid)}.time-grid tfoot td:last-child{color:var(--primary-color);font-weight:700}.time-grid-user{display:flex;align-items:center;gap:.5rem}.time-grid-avatar{width:26px;height:26px;border-radius:50%;object-fit:cover;flex-shrink:0}.time-grid-avatar--initials{display:flex;align-items:center;justify-content:center;background:var(--primary-color);color:#fff;font-size:.68rem;font-weight:700}.time-grid-user-name{font-weight:600;color:var(--text-primary);font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.time-overview-empty{text-align:center;padding:3rem 1.5rem;color:var(--text-secondary)}.time-overview-empty-icon{font-size:2.5rem;margin-bottom:.75rem;opacity:.5}.time-overview-empty-text{font-size:.95rem;font-style:italic}.dash-overview-layout{display:flex;flex-direction:column;gap:1.5rem}.dash-section-heading{font-size:.92rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:.5rem;margin-bottom:-.5rem}.dash-overview-bottom-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}@media(max-width:900px){.dash-overview-bottom-grid{grid-template-columns:1fr}}.dash-panel{background:var(--surface-solid);border-radius:var(--radius-xl);border:1px solid var(--border-color);box-shadow:var(--shadow-md);overflow:hidden;display:flex;flex-direction:column}.dash-panel-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}.dash-panel-title{font-size:.88rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:.45rem}.dash-panel-title-icon{color:var(--primary-color)}.dash-panel-link{font-size:.78rem;font-weight:600;color:var(--primary-color);text-decoration:none;display:inline-flex;align-items:center;gap:.25rem;opacity:.85;transition:opacity .15s}.dash-panel-link:hover{opacity:1;text-decoration:underline}.dash-panel-body{display:flex;flex-direction:column;gap:0}.dash-panel-empty{text-align:center;padding:2.5rem 1.5rem;color:var(--text-secondary);font-size:.88rem;font-style:italic}.dash-status-full{display:flex;flex-direction:column;gap:1.25rem}.dash-status-full-card{background:var(--surface-solid);border-radius:var(--radius-xl);border:1px solid var(--border-color);box-shadow:var(--shadow-md);overflow:hidden}.dash-status-full-header{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1.25rem;background:#6366f10a;border-bottom:1px solid var(--border-color)}.dash-status-full-project{font-size:.88rem;font-weight:700;color:var(--primary-color);text-decoration:none;transition:opacity .15s;display:flex;align-items:center;gap:.4rem}.dash-status-full-project:hover{opacity:.75}.dash-status-full-meta{display:flex;align-items:center;gap:.6rem;font-size:.75rem;color:var(--text-secondary)}.dash-status-full-meta .dash-status-by-avatar{width:20px;height:20px;font-size:.65rem}.dash-status-full-card .status-card{border:none;box-shadow:none;margin:0;border-radius:0}.dash-status-full-card .status-card-header{padding-top:.5rem}.dash-status-full-card .status-card-delete,.dash-status-full-card .status-card-action-btn{display:none}.dash-activity-row{display:flex;align-items:flex-start;gap:.65rem;padding:.75rem 1.25rem;border-bottom:1px solid var(--border-color);transition:background .1s}.dash-activity-row:last-child{border-bottom:none}.dash-activity-row:hover{background:#6366f106}.dash-activity-icon{width:30px;height:30px;border-radius:50%;background:#6366f114;color:var(--primary-color);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.dash-activity-content{flex:1;min-width:0}.dash-activity-message{font-size:.82rem;color:var(--text-primary);line-height:1.45}.dash-activity-time{font-size:.72rem;color:var(--text-secondary);margin-top:.2rem}.dash-project-row{display:flex;align-items:center;gap:.65rem;padding:.7rem 1.25rem;border-bottom:1px solid var(--border-color);transition:background .1s;text-decoration:none;color:inherit}.dash-project-row:last-child{border-bottom:none}.dash-project-row:hover{background:#6366f106}.dash-project-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dash-project-dot--on-track{background:#10b981}.dash-project-dot--warning{background:#f59e0b}.dash-project-dot--overspending{background:#ef4444}.dash-project-dot--closed{background:var(--text-secondary);opacity:.5}.dash-project-name{flex:1;min-width:0;font-size:.82rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-project-role-badge{font-size:.68rem;font-weight:600;padding:.15rem .55rem;border-radius:2rem;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}.dash-project-role-badge--responsible{background:#6366f11a;color:var(--primary-color)}.dash-project-role-badge--observer{background:#64748b1a;color:var(--text-secondary)}.dash-status-by-avatar{width:18px;height:18px;border-radius:50%;background:var(--primary-color);color:#fff;font-size:.6rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}*:focus{outline:none}*:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px;border-radius:var(--radius-sm)}.btn:focus-visible,button:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.form-input:focus-visible{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11f}.auth-link:focus-visible,.nav-link:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px;border-radius:var(--radius-sm)}@media(pointer:coarse){.btn,button,.nav-link,.project-tab{min-height:44px}.form-input,select{min-height:44px;font-size:1rem}.project-tab-close,.project-tab-add{min-width:36px;min-height:36px}}@media(max-width:480px){.auth-container{padding:2rem 1rem 1rem}.auth-card{padding:1.5rem;border-radius:var(--radius-lg);box-shadow:none;border:none;background:transparent}.auth-title{font-size:1.25rem}}@media(max-width:640px){.dashboard-content{padding-left:var(--space-4);padding-right:var(--space-4)}.dashboard-content h1{font-size:1.375rem!important}.data-table{font-size:.8rem}.data-table th,.data-table td{padding:.5rem .625rem}.project-detail-header{flex-direction:column;gap:1rem}.project-detail-actions{flex-wrap:wrap;gap:.5rem}.filter-bar{flex-direction:column;gap:.5rem}}@media(max-width:640px){.project-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.project-tabs::-webkit-scrollbar{display:none}.project-tab{white-space:nowrap;flex-shrink:0;font-size:.8125rem;padding:.625rem .875rem}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
