.sidebar{width:var(--sidebar-width);height:100vh;background-color:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;transition:width .3s ease;position:sticky;top:0;z-index:50}.sidebar.collapsed{width:72px}.sidebar-header{height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-md);border-bottom:1px solid var(--color-border)}.logo-container{display:flex;align-items:center;gap:var(--space-sm);overflow:hidden;white-space:nowrap}.logo-icon{color:var(--color-text-main);min-width:24px}.logo-text{font-weight:700;font-size:1.1rem;color:var(--color-text-main);opacity:1;transition:opacity .2s}.sidebar.collapsed .logo-text{opacity:0;width:0;display:none}.collapse-btn{background:transparent;border:none;cursor:pointer;color:var(--color-text-muted);padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.collapse-btn:hover{background-color:var(--color-bg);color:var(--color-text-main)}.sidebar-nav{flex:1;padding:var(--space-md) var(--space-sm);display:flex;flex-direction:column;gap:var(--space-xs);overflow-y:auto}.nav-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-sm);text-decoration:none;color:var(--color-text-muted);border-radius:var(--radius-md);transition:all .2s;white-space:nowrap;overflow:hidden}.nav-item:hover{background-color:var(--color-bg);color:var(--color-text-main)}.nav-item.active{background-color:var(--color-bg);color:var(--color-accent);font-weight:600}.nav-item.active .nav-icon{color:var(--color-accent)}.nav-icon{min-width:20px}.nav-label{opacity:1;transition:opacity .2s}.sidebar.collapsed .nav-label{opacity:0;width:0;display:none}.sidebar.collapsed .nav-item{justify-content:center;padding:var(--space-sm)}.sidebar-footer{padding:var(--space-md);border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;transition:all .3s ease}.sidebar.collapsed .sidebar-footer{flex-direction:column;gap:var(--space-md);padding:var(--space-sm)}.logout-btn{background:transparent;border:none;cursor:pointer;color:var(--color-text-muted);padding:8px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all .2s}.logout-btn:hover{background-color:var(--color-bg);color:var(--color-danger)}.user-profile{display:flex;align-items:center;gap:var(--space-sm);overflow:hidden}.avatar{width:36px;height:36px;border-radius:50%;background-color:var(--color-text-main);color:var(--color-surface);display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:600;flex-shrink:0}.user-info{display:flex;flex-direction:column;white-space:nowrap;opacity:1;transition:opacity .2s}.sidebar.collapsed .user-info{opacity:0;display:none}.user-name{font-size:.9rem;font-weight:600;color:var(--color-text-main)}.user-role{font-size:.75rem;color:var(--color-text-muted)}.top-header{height:var(--header-height);width:100%;display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-xl);background-color:var(--color-bg)}.header-title h1{font-size:1.5rem;font-weight:600;color:var(--color-text-main);margin:0;letter-spacing:-.5px}.header-actions{display:flex;align-items:center;gap:var(--space-lg)}.search-bar{display:flex;align-items:center;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:6px 12px;width:240px;transition:border-color .2s}.search-bar:focus-within{border-color:var(--color-accent)}.search-icon{color:var(--color-text-muted);margin-right:8px}.search-bar input{border:none;background:transparent;outline:none;font-size:.9rem;color:var(--color-text-main);width:100%}.search-bar input::placeholder{color:#a0a0a0}.icon-btn{background:transparent;border:none;cursor:pointer;color:var(--color-text-muted);position:relative;display:flex;padding:4px}.icon-btn:hover{color:var(--color-text-main)}.badge{position:absolute;top:0;right:0;background-color:var(--color-warning);color:#fff;font-size:10px;font-weight:700;width:14px;height:14px;border-radius:50%;display:flex;align-items:center;justify-content:center;transform:translate(25%,-25%)}.main-layout{display:flex;min-height:100vh;width:100%}.main-content-wrapper{flex:1;display:flex;flex-direction:column;min-width:0}.page-content{flex:1;padding:var(--space-xl);overflow-y:auto;max-width:1600px;width:100%;margin:0 auto}@media (max-width: 768px){.page-content{padding:var(--space-md)}}.date-input-container{position:relative;display:flex;align-items:center;width:100%}.date-input-text{width:100%;padding:8px 36px 8px 12px!important;border:1px solid #cbd5e1;border-radius:4px;font-size:14px;background-color:#fff}.date-input-text:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.date-input-icon-btn{position:absolute;right:8px;background:none;border:none;cursor:pointer;color:#64748b;display:flex;align-items:center;padding:4px;z-index:10}.date-input-icon-btn:hover{color:#334155;background-color:#f1f5f9;border-radius:4px}.date-input-hidden{position:absolute;opacity:0;pointer-events:none;bottom:0;left:0;width:100%;height:100%;z-index:-1}.invoice-form-page{padding:2rem}.expense-form-page{padding:2rem}.income-form-page{padding:2rem}.form-field input,.form-field select{padding:.75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text-main)}.drawer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:1000;display:flex;justify-content:flex-end;animation:fadeIn .2s ease-out}.drawer-content{background-color:var(--color-surface);height:100%;box-shadow:-4px 0 16px #0000001a;display:flex;flex-direction:column;animation:slideIn .3s cubic-bezier(.16,1,.3,1);max-width:100vw}.drawer-header{padding:1.5rem 2rem;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center}.drawer-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-text-main)}.close-btn{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background .2s}.close-btn:hover{background-color:var(--color-bg);color:var(--color-text-main)}.drawer-body{flex:1;overflow-y:auto;padding:2rem}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.finance-page{display:flex;flex-direction:column;gap:var(--space-lg)}.finance-table-container{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.finance-table{width:100%;border-collapse:collapse}.finance-table th{text-align:left;padding:var(--space-md);color:var(--color-text-muted);font-weight:500;border-bottom:1px solid var(--color-border);font-size:.85rem;background-color:#fafafa}.finance-table td{padding:var(--space-md);border-bottom:1px solid var(--color-border);color:var(--color-text-main);font-size:.9rem}.finance-table tr:last-child td{border-bottom:none}.finance-table tr:hover td{background-color:#fafafa}.name-cell{display:flex;align-items:center;gap:var(--space-md)}.status-badge{padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:capitalize;display:inline-block}.status-badge.active,.status-badge.paid,.status-badge.approved{background-color:#e8f5e9;color:#2e7d32}.status-badge.inactive,.status-badge.unpaid,.status-badge.pending{background-color:#fff3e0;color:#ef6c00}.status-badge.archived,.status-badge.cancelled{background-color:#f5f5f5;color:#616161}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg);padding:var(--space-md)}.login-card{background:var(--color-surface);width:100%;max-width:400px;padding:var(--space-2xl) var(--space-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--space-xl)}.login-header{text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-sm)}.login-header h1{margin:0;font-size:1.5rem;font-weight:600;letter-spacing:-.02em}.login-header p{margin:0;color:var(--color-text-muted);font-size:.9rem}.login-error{background-color:#d32f2f1a;color:var(--color-danger);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:.9rem;text-align:center}.login-form{display:flex;flex-direction:column;gap:var(--space-lg)}.form-group{display:flex;flex-direction:column;gap:var(--space-xs)}.form-group label{font-size:.85rem;font-weight:500;color:var(--color-text-muted)}.form-group input{padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--color-border);font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--color-text-main)}.login-btn{background-color:var(--color-text-main);color:var(--color-surface);border:none;padding:12px;border-radius:var(--radius-sm);font-weight:600;cursor:pointer;transition:opacity .2s;margin-top:var(--space-sm)}.login-btn:hover{opacity:.9}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-footer{text-align:center;font-size:.8rem;color:var(--color-text-muted);border-top:1px solid var(--color-border);padding-top:var(--space-lg)}.kpi-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md);transition:box-shadow .2s,transform .2s,border-color .2s}.kpi-card.clickable:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--color-primary)}.kpi-header{display:flex;justify-content:space-between;align-items:flex-start}.kpi-label{color:var(--color-text-muted);font-size:.85rem;font-weight:500;letter-spacing:.02em}.kpi-icon{color:var(--color-text-muted);opacity:.7}.kpi-value{font-size:1.75rem;font-weight:600;color:var(--color-text-main);letter-spacing:-.02em}.kpi-sub{font-size:.8rem;color:var(--color-text-muted);margin-top:4px}.status-badge.pending{background-color:#ffa0001a;color:var(--color-warning)}.profitability-section,.invoices-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-lg);display:flex;flex-direction:column}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.section-header h3{margin:0;font-size:1rem;color:var(--color-text-main);font-weight:600}.view-all-btn{background:none;border:none;font-size:.85rem;color:var(--color-text-muted);cursor:pointer}.view-all-btn:hover{text-decoration:underline;color:var(--color-text-main)}.table-wrapper{overflow-x:auto}.invoices-table{width:100%;border-collapse:collapse;font-size:.9rem}.invoices-table th{text-align:left;color:var(--color-text-muted);font-weight:500;padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border)}.invoices-table td{padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border);color:var(--color-text-main)}.invoices-table tr:last-child td{border-bottom:none}.invoices-table tbody tr{transition:background-color .2s}.invoices-table tbody tr:hover{background-color:var(--color-bg)}.text-right{text-align:right}.text-center{text-align:center}.text-muted{color:var(--color-text-muted)}.font-medium{font-weight:500}.status-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:.75rem;text-transform:capitalize}.status-badge.overdue{background-color:#d32f2f1a;color:var(--color-danger)}.status-badge.sent{background-color:#2196f31a;color:#1976d2}.status-badge.draft{background-color:#9e9e9e1a;color:#616161}.status-badge.paid{background-color:#4caf501a;color:#388e3c}.client-detail-page{max-width:1000px;margin:0 auto}.header-content{display:flex;align-items:center;gap:var(--space-lg);margin-top:var(--space-lg)}.avatar-lg{width:64px;height:64px;background-color:var(--color-text-main);color:var(--color-surface);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:600}.title-info{display:flex;flex-direction:column;gap:4px}.title-info h1{margin:0;font-size:1.75rem}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg)}.info-card,.section-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg)}.info-card h3,.section-card h3{margin:0 0 var(--space-md) 0;font-size:1rem;color:var(--color-text-main)}.info-list{display:flex;flex-direction:column;gap:var(--space-md)}.info-item{display:flex;align-items:center;gap:var(--space-md);color:var(--color-text-muted)}.divider{height:1px;background-color:var(--color-border);margin:var(--space-lg) 0}.budget-display{display:flex;align-items:baseline;gap:4px}.budget-display .amount{font-size:1.5rem;font-weight:600}.notes-text{color:var(--color-text-muted);line-height:1.6}.related-lists{display:flex;flex-direction:column;gap:var(--space-lg)}.card-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md)}.simple-list{display:flex;flex-direction:column;gap:var(--space-sm)}.list-item{display:flex;justify-content:space-between;align-items:center;padding:8px;background-color:var(--color-bg);border-radius:var(--radius-sm);font-size:.9rem}.status-badge.overdue{background-color:var(--color-danger-light);color:var(--color-danger)}.header-actions-right{margin-left:auto;display:flex;gap:8px;align-items:center}.item-meta{color:var(--color-text-muted);font-size:.8rem}.invoice-detail-page{padding:2rem}.invoice-detail-page.drawer-mode{padding:1rem}.detail-header{margin-bottom:2rem}.back-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:transparent;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;color:#6b7280;font-size:.875rem;transition:all .2s;margin-bottom:1.5rem}.back-btn:hover{background:#f9fafb;border-color:#d1d5db}.header-content{display:flex;align-items:center;gap:1rem}.invoice-icon-lg{width:64px;height:64px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;display:flex;align-items:center;justify-content:center;color:#fff}.title-info{display:flex;flex-direction:column;gap:.5rem}.title-info h1{margin:0;font-size:1.75rem;color:#111827}.status-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:capitalize;width:fit-content}.status-badge.draft{background:#f3f4f6;color:#6b7280}.status-badge.sent{background:#dbeafe;color:#1e40af}.status-badge.overdue{background:#fee2e2;color:#991b1b}.status-badge.paid{background:#d1fae5;color:#065f46}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.drawer-mode .detail-grid{grid-template-columns:1fr}.info-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem}.info-card h3{font-size:.875rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem}.info-list{display:flex;flex-direction:column;gap:1rem}.info-item{display:flex;align-items:flex-start;gap:.75rem;color:#6b7280}.info-item svg{flex-shrink:0;margin-top:2px}.info-item>div{flex:1}.info-label{font-size:.75rem;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.info-value{font-size:.875rem;color:#111827;font-weight:500}.divider{height:1px;background:#e5e7eb;margin:1.5rem 0}.amount-display{display:flex;align-items:baseline;gap:.5rem;margin-top:1rem}.amount-display .currency{font-size:1.5rem;color:#6b7280}.amount-display .amount{font-size:2.5rem;font-weight:700;color:#111827}.related-lists{display:flex;flex-direction:column;gap:1.5rem}.section-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem}.card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.card-header h3{font-size:.875rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin:0}.card-header svg{color:#9ca3af}.simple-list{display:flex;flex-direction:column;gap:.75rem}.list-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background:#f9fafb;border-radius:8px}.item-name{font-size:.875rem;color:#111827;font-weight:500}.item-amount{font-size:.875rem;color:#6b7280;font-family:Monaco,Courier New,monospace}.empty-text{color:#9ca3af;font-size:.875rem;font-style:italic;text-align:center;padding:1rem}.loading-state,.error-state{display:flex;align-items:center;justify-content:center;padding:3rem;color:#6b7280;font-size:.875rem}.error-state{color:#dc2626}.project-detail-page{max-width:1200px;margin:0 auto}.detail-header{margin-bottom:var(--space-xl)}.header-main{display:flex;justify-content:space-between;align-items:flex-start;margin-top:var(--space-lg)}.back-btn-nested{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--color-border);padding:8px 16px;border-radius:var(--radius-sm);color:var(--color-text);font-size:.9rem;cursor:pointer;margin-bottom:var(--space-md);transition:all .2s}.back-btn-nested:hover{background:#f4f4f5}.header-main h1{margin:0;font-size:2rem;letter-spacing:-.03em}.subtitle{color:var(--color-text-muted);margin:4px 0 0}.status-badge-lg{padding:6px 16px;border-radius:20px;font-weight:600;text-transform:uppercase;font-size:.85rem;letter-spacing:.05em}.status-badge-lg.Ongoing{background:#e3f2fd;color:#1565c0}.project-grid{display:flex;flex-direction:column;gap:var(--space-lg)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-lg)}.card h3{margin:0 0 var(--space-md);font-size:1rem}.desc{color:var(--color-text-muted);line-height:1.6}.detail-header{background-color:var(--color-surface);padding:var(--space-xl);border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--space-md)}.header-container-flex{display:flex;width:100%;justify-content:space-between}.header-actions-right{display:flex;gap:8px}.icon-btn{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:6px;cursor:pointer;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center}.icon-btn:hover{background:var(--color-bg);color:var(--color-text-main)}.meta-row{display:flex;gap:var(--space-lg);margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border)}.meta-item{display:flex;align-items:center;gap:8px;color:var(--color-text-muted);font-size:.9rem}.financial-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md)}.fin-stat{display:flex;flex-direction:column}.fin-stat .label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.fin-stat .val{font-size:1.25rem;font-weight:600;margin-top:4px}.val.success{color:var(--color-success)}.val.danger{color:var(--color-danger)}.team-list{display:flex;flex-direction:column;gap:var(--space-sm)}.team-member{display:flex;align-items:center;gap:12px}.avatar-xs{width:28px;height:28px;background:var(--color-bg);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600}.lists-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg)}@media (max-width: 1024px){.lists-row{grid-template-columns:1fr}}.mini-table{width:100%;border-collapse:collapse}.mini-table th{text-align:left;padding:var(--space-sm);color:var(--color-text-muted);font-weight:500;border-bottom:1px solid var(--color-border);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}.mini-table td{padding:var(--space-sm);border-bottom:1px solid var(--color-border);font-size:.85rem}.mini-table tr:last-child td{border-bottom:none}.mini-table tr:hover{background-color:#fafafa}.status-badge-sm{padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:capitalize;display:inline-block}.status-badge-sm.paid{background:#dcfce7;color:#166534}.status-badge-sm.sent{background:#dbeafe;color:#1e40af}.status-badge-sm.draft{background:#f3f4f6;color:#4b5563}.status-badge-sm.overdue{background:#fee2e2;color:#991b1b}.project-form-page{padding:2rem}.client-form-page{padding:2rem}.page-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.back-btn{display:flex;align-items:center;gap:.5rem;background:none;border:none;cursor:pointer;font-size:.9rem;color:var(--color-text-muted)}.form-container{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:2rem;max-width:800px}.form-container.drawer-form{border:none;background:transparent;padding:0;max-width:none}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:2rem}.full-width{grid-column:1 / -1}.form-field{display:flex;flex-direction:column;gap:.5rem}.form-field label{font-size:.9rem;font-weight:500;color:var(--color-text-muted)}.form-field input,.form-field select,.form-field textarea{padding:.75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text-main)}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--color-primary)}.form-actions{display:flex;justify-content:flex-end;gap:1rem;padding-top:1.5rem;border-top:1px solid var(--color-border)}.btn-cancel{padding:.75rem 1.5rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:transparent;color:var(--color-text-main);cursor:pointer}.btn-save{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:var(--radius-md);background:var(--color-primary);color:#fff;cursor:pointer}.dashboard-container{display:flex;flex-direction:column;gap:var(--space-xl)}.dashboard-loading{display:flex;align-items:center;justify-content:center;height:50vh;color:var(--color-text-muted)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-lg)}.analytics-grid{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-lg)}@media (max-width: 1024px){.analytics-grid{grid-template-columns:1fr}}.highlight-card{border-color:var(--color-warning)}.dashboard-projects-section{background:#fff;border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm)}.projects-filter-tabs{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg);border-bottom:1px solid var(--color-border);padding-bottom:var(--space-sm)}.filter-tab{padding:var(--space-sm) var(--space-md);background:none;border:none;border-bottom:2px solid transparent;color:var(--color-text-muted);font-weight:500;cursor:pointer;transition:all .2s}.filter-tab:hover{color:var(--color-text)}.filter-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.dashboard-projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-lg)}.dashboard-project-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);transition:all .2s;cursor:pointer}.dashboard-project-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.dashboard-project-card .card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.dashboard-project-card .project-client{font-size:.875rem;color:var(--color-text-muted)}.dashboard-project-card .project-name{font-size:1.125rem;font-weight:600;margin-bottom:var(--space-sm);color:var(--color-text)}.dashboard-project-card .project-dates{display:flex;align-items:center;gap:var(--space-xs);font-size:.875rem;color:var(--color-text-muted);margin-bottom:var(--space-md)}.dashboard-project-card .project-progress{margin-bottom:var(--space-md)}.dashboard-project-card .progress-bar{height:8px;background:var(--color-border);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--space-xs)}.dashboard-project-card .progress-bar .fill{height:100%;background:var(--color-primary);transition:width .3s}.dashboard-project-card .progress-text{font-size:.75rem;color:var(--color-text-muted)}.dashboard-project-card .card-footer{border-top:1px solid var(--color-border);padding-top:var(--space-sm)}.dashboard-project-card .financial-mini{display:flex;flex-direction:column;gap:var(--space-xs)}.dashboard-project-card .financial-mini .label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.dashboard-project-card .financial-mini .value{font-size:1.25rem;font-weight:600;color:var(--color-text)}.no-projects{grid-column:1 / -1;text-align:center;padding:var(--space-xl);color:var(--color-text-muted)}.status-badge{padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:capitalize}.status-badge.blue{background:#dbeafe;color:#1e40af}.status-badge.orange{background:#fed7aa;color:#c2410c}.status-badge.green{background:#d1fae5;color:#065f46}.status-badge.red{background:#fee2e2;color:#991b1b}.status-badge.gray{background:#f3f4f6;color:#4b5563}.client-list-page{display:flex;flex-direction:column;gap:var(--space-lg)}.page-actions{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-md)}.search-box{display:flex;align-items:center;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:8px 12px;width:320px}.search-box input{border:none;background:transparent;width:100%;outline:none;margin-left:8px;font-size:.9rem}.action-buttons{display:flex;gap:var(--space-md)}.btn-primary,.btn-secondary{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--radius-md);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background-color:var(--color-text-main);color:var(--color-surface);border:1px solid var(--color-text-main)}.btn-primary:hover{background-color:#000}.btn-secondary{background-color:var(--color-surface);color:var(--color-text-main);border:1px solid var(--color-border)}.btn-secondary:hover{background-color:var(--color-bg)}.clients-table-container{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.clients-table{width:100%;border-collapse:collapse}.clients-table th{text-align:left;padding:var(--space-md);color:var(--color-text-muted);font-weight:500;border-bottom:1px solid var(--color-border);font-size:.85rem;background-color:#fafafa}.clients-table td{padding:var(--space-md);border-bottom:1px solid var(--color-border);color:var(--color-text-main);font-size:.9rem}.clients-table tr:last-child td{border-bottom:none}.clients-table tr:hover td{background-color:#fafafa}.client-name-cell{display:flex;align-items:center;gap:var(--space-md)}.avatar-sm{width:32px;height:32px;background-color:var(--color-border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--color-text-muted);font-size:.85rem}.client-contact{display:flex;flex-direction:column;gap:4px}.contact-item{display:flex;align-items:center;gap:6px;color:var(--color-text-muted);font-size:.8rem}.font-mono{font-family:var(--font-mono);color:var(--color-text-main)}.action-col{width:48px;text-align:right}.icon-btn-sm{background:none;border:none;cursor:pointer;color:var(--color-text-muted);padding:4px;border-radius:var(--radius-sm)}.icon-btn-sm:hover{color:var(--color-text-main);background-color:var(--color-border)}.loading-state{padding:var(--space-2xl);text-align:center;color:var(--color-text-muted)}.action-flex{display:flex;align-items:center;justify-content:flex-end;gap:8px}.project-list-page{display:flex;flex-direction:column;gap:var(--space-lg)}.tabs{display:flex;background:var(--color-surface);padding:4px;border-radius:var(--radius-md);border:1px solid var(--color-border)}.tab-btn{background:none;border:none;padding:8px 16px;border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text-muted);font-size:.9rem;font-weight:500;transition:all .2s}.tab-btn.active{background-color:var(--color-bg);color:var(--color-text-main);font-weight:600}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-lg)}.project-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:var(--space-md)}.project-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-text-muted)}.card-top{display:flex;justify-content:space-between;align-items:center}.project-client{font-size:.8rem;color:var(--color-text-muted);font-weight:500}.project-name{margin:0;font-size:1.1rem;font-weight:600}.project-dates{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--color-text-muted)}.project-progress{display:flex;flex-direction:column;gap:6px}.progress-bar{height:6px;background-color:var(--color-bg);border-radius:3px;overflow:hidden}.progress-bar .fill{height:100%;background-color:var(--color-text-main)}.progress-text{font-size:.75rem;color:var(--color-text-muted);text-align:right}.card-footer{display:flex;justify-content:space-between;padding-top:var(--space-md);border-top:1px solid var(--color-border)}.financial-mini{display:flex;flex-direction:column}.financial-mini .label{font-size:.7rem;text-transform:uppercase;color:var(--color-text-muted);letter-spacing:.05em}.financial-mini .value{font-weight:600;font-size:.9rem}.status-badge.blue{background:#2196f31a;color:#1976d2}.status-badge.orange{background:#ff98001a;color:#f57c00}.status-badge.green{background:#4caf501a;color:#388e3c}.status-badge.red{background:#f443361a;color:#d32f2f}.action-flex-proj{display:flex;gap:4px;align-items:center}.dropdown-menu{position:absolute;right:0;top:100%;margin-top:4px;background:#fff;border:1px solid var(--color-border);box-shadow:0 4px 6px -1px #0000001a;border-radius:var(--radius-sm);z-index:50;min-width:120px}.modal-body p{margin-top:0;margin-bottom:16px;color:var(--color-text-muted)}.printable-invoice{display:none;background:#fff;padding:40px;font-family:Inter,sans-serif;color:#333}@media print{body *{visibility:hidden}.printable-invoice,.printable-invoice *{visibility:visible}.printable-invoice{display:block;position:absolute;left:0;top:0;width:100%;margin:0;padding:40px;box-sizing:border-box}@page{size:A4;margin:0}}.invoice-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:60px}.company-logo{flex:1}.invoice-header h1{font-size:42px;font-weight:400;letter-spacing:4px;text-transform:uppercase;color:#333;margin:0}.separator{width:100%;height:1px;background:#ccc;margin-top:10px;display:none}.company-info{text-align:right;flex:1}.company-info h3{font-size:16px;font-weight:600;color:#333;margin:0 0 8px}.company-info p{margin:4px 0;font-size:12px;color:#666;line-height:1.5}.invoice-meta-grid{display:flex;justify-content:space-between;margin-bottom:60px}.billed-to h4{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:#888;margin-bottom:15px}.billed-to p{margin:4px 0;font-size:14px}.client-name{font-weight:600;font-size:16px;color:#000}.invoice-details{text-align:right}.meta-row{margin-bottom:8px}.meta-row .label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#888;display:inline-block;width:120px}.meta-row .value{font-size:14px;font-weight:500;color:#333}.invoice-items-table{margin-bottom:40px}.invoice-items-table table{width:100%;border-collapse:collapse}.invoice-items-table th{text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#888;padding:15px 0;border-bottom:1px solid #ddd}.invoice-items-table td{padding:20px 0;border-bottom:1px solid #eee;font-size:14px;vertical-align:top}.item-desc{width:50%}.main-desc{font-weight:500;margin-bottom:4px}.sub-desc{font-size:12px;color:#666}.invoice-footer{margin-top:40px}.totals{width:300px;margin-left:auto}.total-row{display:flex;justify-content:space-between;padding:8px 0;font-size:14px}.total-row.grand-total{border-top:2px solid #333;margin-top:10px;padding-top:15px;font-weight:700;font-size:16px}.signature-section{margin-top:80px;text-align:right}.signature-line{width:200px;border-top:1px solid #333;display:inline-block}.signature-section p{font-size:12px;color:#666;margin-top:10px}.footer-company-info{position:fixed;bottom:40px;left:40px;right:40px;text-align:center;font-size:10px;color:#999}.invoice-list-page{display:flex;flex-direction:column;gap:var(--space-lg)}.page-header-actions{display:flex;justify-content:space-between;align-items:center}.page-header-actions h2{margin:0;font-size:1.5rem}.actions{display:flex;gap:var(--space-md)}.search-box-simple{display:flex;align-items:center;gap:8px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:6px 12px;color:var(--color-text-muted)}.search-box-simple input{border:none;outline:none;font-size:.9rem;background:transparent}.table-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;min-height:400px}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:var(--space-md);color:var(--color-text-muted);font-weight:500;border-bottom:1px solid var(--color-border);background:#fafafa;font-size:.85rem}.data-table td{padding:var(--space-md);border-bottom:1px solid var(--color-border);font-size:.9rem}.data-table tr:last-child td{border-bottom:none}.action-col{min-width:120px}.action-flex{display:flex;align-items:center;justify-content:center;gap:8px}.menu-wrapper{position:relative}.icon-btn-sm{background:transparent;border:none;cursor:pointer;padding:6px;border-radius:4px;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;transition:all .2s}.icon-btn-sm:hover{background:#f4f4f5;color:var(--color-text)}.dropdown-menu{position:absolute;right:0;top:100%;margin-top:4px;background:#fff;border:1px solid var(--color-border);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border-radius:var(--radius-sm);z-index:50;min-width:120px;overflow:hidden}.dropdown-menu button{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;text-align:left;background:none;border:none;font-size:.9rem;cursor:pointer;color:var(--color-text)}.dropdown-menu button:hover{background:#f9fafb}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000}.modal-content{background:#fff;border-radius:var(--radius-lg);width:400px;box-shadow:0 20px 25px -5px #0000001a;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--color-border)}.modal-header h3{margin:0;font-size:1.1rem}.modal-header button{background:none;border:none;cursor:pointer;color:var(--color-text-muted)}.modal-body{padding:24px}.modal-body p{margin-top:0;margin-bottom:16px;font-size:.95rem;color:var(--color-text-muted)}.status-select{width:100%;padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:1rem;outline:none}.status-select:focus{border-color:var(--color-primary)}.modal-actions{padding:16px 24px;background:#f9fafb;display:flex;justify-content:flex-end;gap:12px;border-top:1px solid var(--color-border)}.btn-cancel{padding:8px 16px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer}.btn-primary{padding:8px 16px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer}.reports-page{display:flex;flex-direction:column;gap:var(--space-lg)}.reports-header{display:flex;justify-content:space-between;align-items:center}.reports-header h2{font-size:1.5rem;margin:0}.reports-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg)}.report-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg)}.report-card.full-width{grid-column:span 2}.report-card h3{margin:0 0 var(--space-lg);font-size:1rem;color:var(--color-text-main)}.chart-container-lg{width:100%}.legend{display:flex;justify-content:center;gap:var(--space-md);margin-top:var(--space-md)}.legend-item{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--color-text-muted)}.legend-item .dot{width:8px;height:8px;border-radius:50%}.metrics-list{display:flex;flex-direction:column;gap:var(--space-md)}.metric-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border)}.metric-item:last-child{border-bottom:none}.metric-item .label{color:var(--color-text-muted);font-size:.9rem}.metric-item .value{font-weight:600;color:var(--color-text-main)}.value.success{color:var(--color-success)}:root{--color-bg: #F8F8F8;--color-surface: #FFFFFF;--color-text-main: #1A1A1A;--color-text-muted: #666666;--color-primary: #1A1A1A;--color-accent: #000000;--color-border: #E5E5E5;--color-success: #2E8B57;--color-danger: #D32F2F;--color-warning: #FFA000;--color-overlay: rgba(0, 0, 0, .4);--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", monospace;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--sidebar-width: 260px;--header-height: 64px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .05)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--color-bg);color:var(--color-text-main);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}input,button,select,textarea{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d4d4d4;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a3a3a3}
