@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--font-sans:"Outfit", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", monospace;--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-tertiary:#f1f5f9;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#64748b;--accent:#6366f1;--accent-hover:#4f46e5;--accent-light:#e0e7ff;--success:#10b981;--success-hover:#059669;--success-light:#d1fae5;--warning:#f59e0b;--error:#ef4444;--error-light:#fee2e2;--border-color:#e2e8f0;--glass-bg:#ffffffb3;--glass-border:#e2e8f0cc;--glass-shadow:0 8px 32px 0 #1f26870a;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--radius-sm:.375rem;--radius-md:.75rem;--radius-lg:1.25rem;--transition-fast:.15s ease;--transition-normal:.25s ease}@media (prefers-color-scheme:dark){:root{--bg-primary:#090d16;--bg-secondary:#111827;--bg-tertiary:#1f2937;--text-primary:#f8fafc;--text-secondary:#cbd5e1;--text-muted:#94a3b8;--accent:#818cf8;--accent-hover:#6366f1;--accent-light:#6366f126;--success:#34d399;--success-hover:#10b981;--success-light:#10b98126;--border-color:#374151;--glass-bg:#111827b3;--glass-border:#374151cc;--glass-shadow:0 8px 32px 0 #0000005e;--shadow-sm:0 1px 2px 0 #00000080;--shadow-md:0 4px 6px -1px #0000004d, 0 2px 4px -2px #0000004d;--shadow-lg:0 10px 15px -3px #00000080, 0 4px 6px -4px #00000080}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--transition-normal), color var(--transition-normal);min-height:100vh;line-height:1.5;overflow-x:hidden}input,button,textarea,select{font-family:inherit;font-size:inherit;color:inherit}a{color:var(--accent);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-hover)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.glass{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow)}h1,h2,h3,h4,h5,h6{letter-spacing:-.02em;font-weight:600;line-height:1.25}h1{font-size:2.25rem}h2{font-size:1.75rem}h3{font-size:1.35rem}@media print{body{color:#000!important;background:#fff!important}.no-print{display:none!important}.print-only{display:block!important}}.login-container{background-color:var(--bg-primary);z-index:1;justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex;position:relative;overflow:hidden}.login-blob{filter:blur(100px);z-index:-1;opacity:.15;border-radius:50%;position:absolute}.login-blob-1{background:var(--accent);width:400px;height:400px;top:-10%;right:-5%}.login-blob-2{background:var(--success);width:350px;height:350px;bottom:-10%;left:-5%}@media (prefers-color-scheme:dark){.login-blob{opacity:.25}}.login-card{border-radius:var(--radius-lg);width:100%;max-width:460px;transition:transform var(--transition-normal), box-shadow var(--transition-normal);flex-direction:column;padding:2.5rem;display:flex}.login-card:hover{transform:translateY(-2px)}.login-header{text-align:center;margin-bottom:2rem}.logo-badge{background:var(--accent-light);width:54px;height:54px;color:var(--accent);border-radius:var(--radius-md);justify-content:center;align-items:center;margin:0 auto 1rem;font-size:1.75rem;display:flex}.login-header h1{color:var(--text-primary);margin-bottom:.5rem;font-size:2rem;font-weight:700}.login-subtitle{color:var(--text-secondary);font-size:.925rem}.login-form{flex-direction:column;gap:1.25rem;display:flex}.input-icon-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-muted);transition:color var(--transition-fast);position:absolute;left:1rem}.input-icon-wrapper input{border-radius:var(--radius-md);border:1px solid var(--border-color);background-color:var(--bg-tertiary);width:100%;color:var(--text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast), background-color var(--transition-fast);outline:none;padding:.75rem 1rem .75rem 2.75rem;font-size:.95rem}.input-icon-wrapper input:focus{border-color:var(--accent);background-color:var(--bg-secondary);box-shadow:0 0 0 4px #6366f11f}.input-icon-wrapper input:focus+.input-icon{color:var(--accent)}.submit-btn{border-radius:var(--radius-md);background-color:var(--accent);color:#fff;cursor:pointer;width:100%;box-shadow:var(--shadow-md);transition:background-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);border:none;justify-content:center;align-items:center;gap:.5rem;padding:.85rem;font-weight:600;display:flex}.submit-btn:hover{background-color:var(--accent-hover);box-shadow:var(--shadow-lg)}.submit-btn:active{transform:scale(.98)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.spinner{border:2.5px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.notification-box{border-radius:var(--radius-md);text-align:left;border:1px solid #0000;align-items:flex-start;gap:.75rem;margin-bottom:1.5rem;padding:1.25rem;font-size:.95rem;display:flex}.success-box{background-color:var(--success-light);color:var(--text-primary);border-color:#10b98133}.error-box{background-color:var(--error-light);color:var(--text-primary);border-color:#ef444433}.notification-icon{font-size:1.25rem;line-height:1}.notification-content p{font-weight:500}.notification-subtext{color:var(--text-secondary);margin-top:.25rem;font-size:.8rem;display:block}.retry-btn{border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--transition-fast);background:0 0;align-self:center;margin-left:auto;padding:.25rem .5rem;font-size:.8rem;font-weight:500}.retry-btn:hover{background-color:#0000000d}.divider{text-align:center;color:var(--text-muted);align-items:center;margin:1.5rem 0;font-size:.85rem;display:flex}.divider:before,.divider:after{content:"";border-bottom:1px solid var(--border-color);flex:1}.divider:not(:empty):before{margin-right:.75em}.divider:not(:empty):after{margin-left:.75em}.demo-btn{border-radius:var(--radius-md);border:1px solid var(--border-color);background-color:var(--bg-tertiary);width:100%;color:var(--text-primary);cursor:pointer;transition:background-color var(--transition-fast), border-color var(--transition-fast);justify-content:center;align-items:center;gap:.5rem;padding:.75rem;font-weight:500;display:flex}.demo-btn:hover{background-color:var(--bg-secondary);border-color:var(--accent)}.demo-notice{background-color:var(--accent-light);color:var(--text-secondary);border-radius:var(--radius-md);text-align:left;align-items:flex-start;gap:.5rem;margin-top:1rem;padding:.75rem 1rem;font-size:.8rem;line-height:1.35;display:flex}.info-icon{color:var(--accent);flex-shrink:0;margin-top:.1rem}.login-footer{border-top:1px solid var(--border-color);color:var(--text-muted);justify-content:space-between;margin-top:2rem;padding-top:1.25rem;font-size:.75rem;font-weight:500;display:flex}.footer-item{align-items:center;gap:.25rem;display:flex}@media (width<=480px){.login-card{padding:1.75rem}}.dashboard-view{flex-direction:column;gap:2rem;display:flex}.create-invoice-btn{background-color:var(--accent);color:#fff;border-radius:var(--radius-md);cursor:pointer;box-shadow:var(--shadow-md);transition:background-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);border:none;align-items:center;gap:.5rem;padding:.7rem 1.25rem;font-weight:600;display:flex}.create-invoice-btn:hover{background-color:var(--accent-hover);box-shadow:var(--shadow-lg)}.create-invoice-btn:active{transform:scale(.98)}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;display:grid}.metric-card{border-radius:var(--radius-lg);text-align:left;transition:transform var(--transition-normal), box-shadow var(--transition-normal);flex-direction:column;gap:1rem;padding:1.5rem;display:flex;position:relative;overflow:hidden}.metric-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-top{color:var(--text-secondary);align-items:center;gap:.75rem;display:flex}.icon-wrapper{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:36px;height:36px;display:flex}.card-total .icon-wrapper{background-color:var(--accent-light);color:var(--accent)}.card-paid .icon-wrapper{background-color:var(--success-light);color:var(--success)}.card-pending .icon-wrapper{color:var(--warning);background-color:#f59e0b26}.metric-label{text-transform:uppercase;letter-spacing:.05em;font-size:.85rem;font-weight:600}.card-middle h2{color:var(--text-primary);letter-spacing:-.03em;font-size:2rem;font-weight:700}.card-bottom{font-size:.8rem;font-weight:500}.trend-neutral{color:var(--text-muted)}.trend-positive{color:var(--success)}.trend-warning{color:var(--warning)}.dashboard-toolbar{justify-content:space-between;align-items:center;gap:1.5rem;display:flex}.filter-pill-group{background-color:var(--bg-tertiary);border-radius:var(--radius-md);flex-shrink:0;gap:.5rem;padding:.3rem;display:flex}.filter-pill{color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0;border:none;padding:.45rem 1rem;font-size:.85rem;font-weight:600}.filter-pill:hover{color:var(--text-primary)}.filter-pill.active{background-color:var(--bg-secondary);color:var(--accent);box-shadow:var(--shadow-sm)}.invoices-list-container{border-radius:var(--radius-lg);overflow:hidden}.table-responsive{width:100%;overflow-x:auto}.invoices-table{border-collapse:collapse;text-align:left;width:100%}.invoices-table th{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border-color);background-color:#ffffff03;padding:1.2rem 1.5rem;font-size:.75rem;font-weight:700}.invoices-table td{border-bottom:1px solid var(--border-color);color:var(--text-secondary);vertical-align:middle;padding:1.2rem 1.5rem;font-size:.925rem}.invoices-table tr:last-child td{border-bottom:none}.invoice-row{transition:background-color var(--transition-fast)}.invoice-row:hover{background-color:#ffffff05}.bold-text{color:var(--text-primary);font-weight:600}.amount-text{font-size:1rem}.client-cell{flex-direction:column;display:flex}.client-name{color:var(--text-primary);font-weight:600}.client-email{color:var(--text-muted);margin-top:.1rem;font-size:.8rem}.date-cell{align-items:center;gap:.5rem;display:flex}.date-icon{color:var(--text-muted)}.status-badge{border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.03em;justify-content:center;align-items:center;padding:.25rem .75rem;font-size:.775rem;font-weight:700;display:inline-flex}.badge-paid{background-color:var(--success-light);color:var(--success-hover)}.badge-sent{background-color:var(--accent-light);color:var(--accent)}.badge-pending{color:#f59e0b;background-color:#f59e0b1f}.badge-overdue{background-color:var(--error-light);color:var(--error)}.actions-cell{justify-content:flex-end;gap:.5rem;display:flex}.action-btn{cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast), background-color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:.45rem;display:inline-flex}.action-btn.text-accent{color:var(--accent)}.action-btn.text-accent:hover{background-color:var(--accent-light)}.action-btn.text-success{color:var(--success)}.action-btn.text-success:hover{background-color:var(--success-light)}.action-btn.text-info{color:var(--text-secondary)}.action-btn.text-info:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.action-btn.text-danger{color:var(--text-muted)}.action-btn.text-danger:hover{background-color:var(--error-light);color:var(--error)}.action-btn.text-muted{color:var(--text-muted)}.action-btn.text-muted:hover{background-color:var(--bg-tertiary);color:var(--text-secondary)}.empty-dashboard-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:5rem 2rem;display:flex}.empty-dashboard-state h3{color:var(--text-primary);font-size:1.3rem}.empty-dashboard-state p{color:var(--text-secondary);max-width:380px;margin-bottom:.5rem;font-size:.95rem;line-height:1.45}.inline-btn{margin:0 auto;display:inline-flex}@media (width<=900px){.dashboard-toolbar{flex-direction:column;align-items:stretch;gap:1rem}.search-wrapper{max-width:100%}.filter-pill-group{width:100%;overflow-x:auto}.filter-pill{text-align:center;white-space:nowrap;flex:1}}@media (width<=600px){.view-header{flex-direction:column;align-items:stretch;gap:1rem}.create-invoice-btn{justify-content:center}}.invoice-template-container{color:#1e293b;border-radius:var(--radius-sm);text-align:left;box-sizing:border-box;background-color:#fff;border:1px solid #e2e8f0;width:100%;max-width:800px;margin:0 auto;padding:3rem;font-family:Outfit,sans-serif;line-height:1.5;box-shadow:0 4px 20px #0000000d}.invoice-sheet-header{justify-content:space-between;align-items:flex-start;gap:2rem;display:flex}.invoice-logo{object-fit:contain;border-radius:var(--radius-sm);background-color:#0000;max-width:140px;max-height:70px;margin-bottom:1.25rem;display:block}.sender-details h2{color:#0f172a;margin-bottom:.5rem;font-size:1.6rem;font-weight:700}.sender-details .meta-text{color:#475569;margin-bottom:.15rem;font-size:.85rem}.gst-number-tag{margin-top:.4rem;font-weight:500}.invoice-meta-right{text-align:right;flex-direction:column;align-items:flex-end;gap:.75rem;display:flex}.invoice-badge{letter-spacing:.05em;color:#6366f1;font-size:2rem;font-weight:800}.meta-grid{grid-template-columns:auto auto;gap:.35rem 1rem;font-size:.875rem;display:grid}.meta-grid .label{color:#64748b;text-align:left}.meta-grid .value{color:#0f172a;text-align:right;font-weight:500}.meta-grid .value.bold{font-weight:700}.invoice-divider{background-color:#f1f5f9;height:2px;margin:2rem 0}.invoice-billing-section{margin-bottom:2rem;display:flex}.billing-box{flex-direction:column;gap:.35rem;display:flex}.billing-title{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:700}.client-billing-details h4{color:#0f172a;margin-bottom:.25rem;font-size:1.15rem;font-weight:700}.client-billing-details p{color:#475569;margin-bottom:.15rem;font-size:.875rem}.pre-wrap-address{white-space:pre-wrap;line-height:1.4}.placeholder-details{color:#94a3b8;font-size:.9rem;font-style:italic}.invoice-items-table{border-collapse:collapse;width:100%;margin-bottom:2.5rem;font-size:.9rem}.invoice-items-table th{color:#475569;text-transform:uppercase;letter-spacing:.05em;text-align:left;border-bottom:2px solid #e2e8f0;padding:.75rem 1rem;font-size:.75rem;font-weight:700}.invoice-items-table td{color:#334155;border-bottom:1px solid #f1f5f9;padding:1rem}.invoice-items-table th.text-right,.invoice-items-table td.text-right{text-align:right}.invoice-items-table td.bold{color:#0f172a;font-weight:600}.desc-cell{word-break:break-word;max-width:300px}.empty-table-placeholder{text-align:center;color:#94a3b8;font-style:italic;padding:2.5rem!important}.invoice-summary-section{grid-template-columns:1.2fr 1fr;gap:3rem;font-size:.9rem;display:grid}.payment-instructions h4{color:#0f172a;margin-bottom:.35rem;font-size:.9rem;font-weight:700}.payment-instructions p{color:#475569;margin-bottom:.15rem;font-size:.825rem}.payment-email{margin:.25rem 0;font-weight:700;color:#6366f1!important;font-size:.9rem!important}.payment-note{line-height:1.4;color:#94a3b8!important;margin-top:.75rem!important;font-size:.75rem!important}.totals-calculations{flex-direction:column;gap:.65rem;display:flex}.totals-row{color:#475569;justify-content:space-between;display:flex}.totals-row.grand-total-row{color:#0f172a;border-top:2px solid #e2e8f0;margin-top:.25rem;padding-top:.75rem;font-size:1.05rem;font-weight:700}.totals-row .total-accent{color:#6366f1;font-size:1.2rem}.invoice-footer-note{text-align:center;color:#94a3b8;border-top:1px solid #f1f5f9;margin-top:4rem;padding-top:1.5rem;font-size:.85rem}@media print{.invoice-template-container{box-shadow:none!important;border:none!important;max-width:100%!important;margin:0!important;padding:0!important}}@media (width<=600px){.invoice-template-container{padding:1.5rem}.invoice-sheet-header{flex-direction:column;align-items:stretch;gap:1.5rem}.invoice-meta-right{text-align:left;align-items:flex-start}.meta-grid{grid-template-columns:auto 1fr}.meta-grid .value{text-align:left}.invoice-summary-section{grid-template-columns:1fr;gap:2rem}}.invoice-editor-workspace{flex-direction:column;gap:1.5rem;height:100%;display:flex}.editor-nav-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding-bottom:1.25rem;display:flex}.back-btn{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast), background-color var(--transition-fast);background:0 0;border:none;align-items:center;gap:.5rem;padding:.5rem .75rem;font-weight:600;display:flex}.back-btn:hover{color:var(--text-primary);background-color:var(--bg-tertiary)}.header-actions{gap:.75rem;display:flex}.action-btn-secondary{background-color:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);align-items:center;gap:.5rem;padding:.65rem 1.25rem;font-weight:600;display:flex}.action-btn-secondary:hover{background-color:var(--bg-tertiary);border-color:var(--text-muted);color:var(--text-primary)}.action-btn-primary{background-color:var(--accent);color:#fff;border-radius:var(--radius-md);cursor:pointer;box-shadow:var(--shadow-md);transition:background-color var(--transition-fast), transform var(--transition-fast);border:none;align-items:center;gap:.5rem;padding:.65rem 1.25rem;font-weight:600;display:flex}.action-btn-primary:hover{background-color:var(--accent-hover)}.action-btn-primary:active{transform:scale(.98)}.editor-tabs-selector{background-color:var(--bg-tertiary);border-radius:var(--radius-md);padding:.3rem;display:none}.tab-toggle{color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:.5rem;padding:.6rem;font-weight:600;display:flex}.tab-toggle.active{background-color:var(--bg-secondary);color:var(--accent);box-shadow:var(--shadow-sm)}.workspace-panes{grid-template-columns:1.1fr .9fr;align-items:start;gap:1.5rem;display:grid}.editor-pane{flex-direction:column;gap:1.5rem;display:flex}.editor-card{border-radius:var(--radius-lg);text-align:left;padding:1.5rem}.editor-card h3{color:var(--text-primary);margin-bottom:1.25rem;font-size:1.15rem;font-weight:700}.metadata-form-grid{grid-template-columns:1fr 1fr;gap:1.25rem;display:grid}.metadata-form-grid .form-group{flex-direction:column;gap:.4rem;display:flex}.metadata-form-grid label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.02em;font-size:.8rem;font-weight:600}.metadata-form-grid input,.metadata-form-grid select{border-radius:var(--radius-md);border:1px solid var(--border-color);background-color:var(--bg-tertiary);color:var(--text-primary);outline:none;width:100%;padding:.65rem .9rem;font-size:.925rem}.metadata-form-grid input:focus,.metadata-form-grid select:focus{border-color:var(--accent);background-color:var(--bg-secondary)}.client-selector-row{gap:.5rem;display:flex}.client-selector-row select{flex-grow:1}.quick-client-add-btn{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;width:40px;height:40px;transition:color var(--transition-fast), border-color var(--transition-fast), background-color var(--transition-fast);justify-content:center;align-items:center;display:flex}.quick-client-add-btn:hover{background-color:var(--accent-light);border-color:var(--accent);color:var(--accent)}.items-editor-card{flex-direction:column;display:flex}.items-header-row{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.items-header-row h3{margin-bottom:0}.add-item-row-btn{background-color:var(--success-light);color:var(--success-hover);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast);border:1px solid #10b98133;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.85rem;font-weight:600;display:flex}.add-item-row-btn:hover{background-color:var(--success);color:#fff}.items-table-container{overflow-x:auto}.interactive-items-table{border-collapse:collapse;width:100%}.interactive-items-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em;text-align:left;border-bottom:1px solid var(--border-color);padding:.5rem;font-size:.8rem;font-weight:600}.interactive-items-table th.text-right{text-align:right}.interactive-items-table td{border-bottom:1px solid var(--border-color);vertical-align:middle;padding:.75rem .5rem}.interactive-items-table input{border-radius:var(--radius-sm);border:1px solid var(--border-color);background-color:var(--bg-tertiary);color:var(--text-primary);outline:none;width:100%;padding:.55rem .75rem;font-size:.9rem}.interactive-items-table input:focus{border-color:var(--accent);background-color:var(--bg-secondary)}.rate-input-wrapper{align-items:center;display:flex;position:relative}.rate-currency{color:var(--text-muted);font-size:.9rem;position:absolute;left:.65rem}.rate-input-wrapper input{padding-left:1.5rem}.bold-total{color:var(--text-primary);text-align:right;font-size:.95rem;font-weight:600}.remove-item-btn{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast), background-color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:.4rem;display:inline-flex}.remove-item-btn:hover{color:var(--error);background-color:var(--error-light)}.remove-item-btn:disabled{opacity:.3;cursor:not-allowed;color:var(--text-muted)!important;background-color:#0000!important}.preview-pane{flex-direction:column;display:flex}.preview-sticky-wrapper{border-radius:var(--radius-sm);max-height:calc(100vh - 8rem);position:sticky;top:1.5rem;overflow-y:auto}@media (width<=1150px){.editor-tabs-selector{display:flex}.workspace-panes{grid-template-columns:1fr}.editor-pane,.preview-pane{display:none}.editor-pane.active{display:flex}.preview-pane.active{display:block}.preview-sticky-wrapper{max-height:none;position:static}}@media (width<=600px){.metadata-form-grid{grid-template-columns:1fr}.editor-nav-header{flex-direction:column;align-items:stretch;gap:1rem}.header-actions{flex-direction:column;gap:.65rem}.header-actions button{justify-content:center;width:100%}}.print-preview-overlay-modal{background-color:var(--bg-primary);z-index:1000;box-sizing:border-box;flex-direction:column;align-items:center;gap:1.5rem;width:100vw;height:100vh;padding:2rem;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.print-preview-modal-header{background-color:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color);width:100%;max-width:800px;box-shadow:var(--shadow-md);justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.preview-modal-title{align-items:center;gap:.5rem;display:flex}.preview-modal-title h3{color:var(--text-primary);font-size:1.25rem;font-weight:700}.preview-modal-actions{gap:.75rem;display:flex}.print-preview-modal-body{justify-content:center;width:100%;padding-bottom:3rem;display:flex}@media print{.app-layout,.no-print,#root>:not(.print-preview-overlay-modal){display:none!important}.print-preview-overlay-modal{z-index:auto!important;background:#fff!important;width:100%!important;height:auto!important;margin:0!important;padding:0!important;display:block!important;position:static!important;overflow:visible!important}.print-preview-modal-body{margin:0!important;padding:0!important;display:block!important}.invoice-editor-workspace,.workspace-panes,.preview-pane,.preview-sticky-wrapper{width:100%!important;height:auto!important;display:block!important;position:static!important;overflow:visible!important}}.workspace-panes.preview-collapsed{grid-template-columns:1fr!important}.workspace-panes.preview-collapsed .preview-pane{display:none!important}@media (width<=1150px){.desktop-only{display:none!important}}.items-header-divider{background-color:var(--border-color);border:0;height:1px;margin:.5rem 0 1.25rem}.editor-pane{position:relative}.vertical-collapse-bar{cursor:pointer;z-index:100;border-left:1px solid var(--border-color);border-right:1px solid var(--border-color);width:28px;transition:background-color var(--transition-fast), border-color var(--transition-fast);background-color:#0f172a73;justify-content:center;align-items:center;display:flex;position:absolute;top:0;bottom:0}.vertical-collapse-bar.left-bar{left:-28px}.vertical-collapse-bar.right-bar{right:-28px}.vertical-collapse-bar:hover{border-color:var(--accent);background-color:#0f172acc}.collapse-handle-badge{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);width:22px;height:48px;color:var(--text-primary);letter-spacing:-1.5px;transition:background-color var(--transition-fast), color var(--transition-fast), transform var(--transition-fast), border-color var(--transition-fast);box-shadow:var(--shadow-sm);-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;display:flex}.vertical-collapse-bar:hover .collapse-handle-badge{background-color:var(--accent);color:#fff;border-color:var(--accent);transform:scale(1.05)}@media (width>=1151px){.invoice-editor-workspace{padding-left:1rem;padding-right:1rem}}.clients-page{flex-direction:column;gap:1.5rem;display:flex}.view-header{border-bottom:1px solid var(--border-color);text-align:left;justify-content:space-between;align-items:center;padding-bottom:1.25rem;display:flex}.add-client-btn{background-color:var(--accent);color:#fff;border-radius:var(--radius-md);cursor:pointer;box-shadow:var(--shadow-md);transition:background-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);border:none;align-items:center;gap:.5rem;padding:.7rem 1.25rem;font-weight:600;display:flex}.add-client-btn:hover{background-color:var(--accent-hover);box-shadow:var(--shadow-lg)}.add-client-btn:active{transform:scale(.98)}.clients-toolbar{justify-content:flex-start;display:flex}.search-wrapper{border-radius:var(--radius-md);align-items:center;width:100%;max-width:400px;padding:.35rem 1rem;display:flex}.search-icon{color:var(--text-muted);margin-right:.75rem}.search-wrapper input{width:100%;color:var(--text-primary);background:0 0;border:none;outline:none;padding:.4rem 0;font-size:.95rem}.search-wrapper input::placeholder{color:var(--text-muted)}.clients-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;display:grid}.client-card{border-radius:var(--radius-md);text-align:left;transition:transform var(--transition-normal), box-shadow var(--transition-normal);flex-direction:column;gap:1.25rem;padding:1.5rem;display:flex}.client-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.client-card-header{border-bottom:1px solid var(--border-color);align-items:center;gap:1rem;padding-bottom:1rem;display:flex}.client-avatar{background-color:var(--accent-light);width:44px;height:44px;color:var(--accent);border-radius:50%;justify-content:center;align-items:center;font-size:1.05rem;font-weight:700;display:flex}.client-card-title h4{color:var(--text-primary);font-size:1.05rem;font-weight:600}.client-date{color:var(--success);font-size:.75rem;font-weight:600}.client-card-body{color:var(--text-secondary);flex-direction:column;flex-grow:1;gap:.75rem;font-size:.9rem;display:flex}.client-info-row{word-break:break-all;align-items:center;gap:.75rem;display:flex}.client-info-row.align-start{align-items:flex-start}.client-info-row span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.client-info-row span.address-text{white-space:normal;line-height:1.4}.client-info-row .info-icon{color:var(--text-muted);flex-shrink:0}.margin-top-xs{margin-top:.15rem}.client-card-actions{border-top:1px solid var(--border-color);grid-template-columns:1fr 1fr;gap:.75rem;padding-top:1rem;display:grid}.card-action-btn{border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);justify-content:center;align-items:center;gap:.4rem;padding:.5rem;font-size:.85rem;font-weight:600;display:flex}.card-action-btn.edit{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary)}.card-action-btn.edit:hover{background-color:var(--accent-light);border-color:var(--accent);color:var(--accent)}.card-action-btn.delete{color:var(--text-muted);background-color:#0000;border:1px solid #0000}.card-action-btn.delete:hover{background-color:var(--error-light);color:var(--error);border-color:#ef44441a}.empty-state{text-align:center;border-radius:var(--radius-lg);flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:4rem 2rem;display:flex}.empty-icon{font-size:3rem}.empty-state h3{color:var(--text-primary);font-size:1.35rem}.empty-state p{color:var(--text-secondary);max-width:320px;margin-bottom:.5rem;font-size:.95rem;line-height:1.45}.modal-backdrop{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:100;background-color:#0006;justify-content:center;align-items:center;width:100vw;height:100vh;padding:1.25rem;display:flex;position:fixed;top:0;left:0}.modal-content{border-radius:var(--radius-lg);width:100%;max-width:500px;box-shadow:var(--shadow-lg);flex-direction:column;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.modal-header h3{color:var(--text-primary);font-size:1.2rem;font-weight:700}.close-modal-btn{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;padding:.25rem;display:flex}.close-modal-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.modal-body{text-align:left;flex-direction:column;gap:1.25rem;padding:1.5rem;display:flex}.modal-error{background-color:var(--error-light);color:var(--error);border-radius:var(--radius-md);border:1px solid #ef444433;padding:.75rem 1rem;font-size:.85rem;font-weight:500}.form-row-split{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.modal-body input,.modal-body textarea{border-radius:var(--radius-md);border:1px solid var(--border-color);background-color:var(--bg-tertiary);width:100%;color:var(--text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast), background-color var(--transition-fast);outline:none;padding:.7rem 1rem;font-size:.95rem}.modal-body input:focus,.modal-body textarea:focus{border-color:var(--accent);background-color:var(--bg-secondary);box-shadow:0 0 0 4px #6366f11a}.modal-footer{border-top:1px solid var(--border-color);background-color:#00000005;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;display:flex}.cancel-btn{border:1px solid var(--border-color);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast);background-color:#0000;padding:.65rem 1.25rem;font-weight:600}.cancel-btn:hover{background-color:var(--bg-tertiary)}.save-btn{background-color:var(--accent);color:#fff;border-radius:var(--radius-md);cursor:pointer;box-shadow:var(--shadow-md);transition:background-color var(--transition-fast), transform var(--transition-fast);border:none;align-items:center;gap:.4rem;padding:.65rem 1.25rem;font-weight:600;display:flex}.save-btn:hover{background-color:var(--accent-hover)}.save-btn:active{transform:scale(.98)}@media (width<=600px){.view-header{flex-direction:column;align-items:stretch;gap:1rem}.add-client-btn{justify-content:center}.form-row-split{grid-template-columns:1fr;gap:1.25rem}}.settings-page{flex-direction:column;gap:2rem;max-width:1000px;margin:0 auto;display:flex}.view-header{text-align:left;border-bottom:1px solid var(--border-color);padding-bottom:1.25rem}.view-header h2{color:var(--text-primary);font-size:1.75rem;font-weight:700}.view-header .subtitle{color:var(--text-secondary);margin-top:.25rem;font-size:.95rem}.settings-form-grid{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}.settings-card{border-radius:var(--radius-lg);flex-direction:column;display:flex;overflow:hidden}.card-header{border-bottom:1px solid var(--border-color);background-color:#ffffff05;align-items:center;gap:.75rem;padding:1.25rem 1.5rem;display:flex}.header-icon{color:var(--accent)}.card-header h3{color:var(--text-primary);font-size:1.1rem;font-weight:600}.card-body{flex-direction:column;gap:1.25rem;padding:1.5rem;display:flex}.form-row{flex-direction:column;gap:1.25rem;display:flex}.form-row.split-2{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-group{text-align:left;flex-direction:column;gap:.5rem;display:flex}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;font-size:.825rem;font-weight:600}.input-wrapper{align-items:center;display:flex;position:relative}.input-wrapper input,.input-wrapper select{border-radius:var(--radius-md);border:1px solid var(--border-color);background-color:var(--bg-tertiary);width:100%;color:var(--text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast), background-color var(--transition-fast);outline:none;padding:.7rem 1rem;font-size:.95rem}.input-wrapper input:focus,.input-wrapper select:focus{border-color:var(--accent);background-color:var(--bg-secondary);box-shadow:0 0 0 4px #6366f11a}.input-wrapper input.with-icon,.input-wrapper select.with-icon{padding-left:2.5rem}.input-wrapper input.with-currency{padding-left:2.25rem}.field-icon{color:var(--text-muted);position:absolute;left:1rem}.currency-symbol{color:var(--text-muted);font-size:.95rem;font-weight:600;position:absolute;left:1rem}.select-field{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 1rem center;background-repeat:no-repeat;background-size:16px;padding-right:2.5rem}.field-hint{color:var(--text-muted);margin-top:.15rem;font-size:.775rem;line-height:1.35}.tax-section{border-top:1px solid var(--border-color);flex-direction:column;gap:1.25rem;margin-top:.5rem;padding-top:1.25rem;display:flex}.toggle-row{justify-content:space-between;align-items:center;gap:1.5rem;display:flex}.toggle-info{text-align:left;flex-direction:column;gap:.15rem;display:flex}.toggle-title{color:var(--text-primary);font-size:.95rem;font-weight:600}.toggle-desc{color:var(--text-muted);font-size:.8rem}.switch{flex-shrink:0;width:50px;height:26px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.slider-switch{cursor:pointer;background-color:var(--border-color);border-radius:34px;transition:all .4s;position:absolute;inset:0}.slider-switch:before{content:"";width:18px;height:18px;box-shadow:var(--shadow-sm);background-color:#fff;border-radius:50%;transition:all .4s;position:absolute;bottom:4px;left:4px}input:checked+.slider-switch{background-color:var(--accent)}input:focus+.slider-switch{box-shadow:0 0 1px var(--accent)}input:checked+.slider-switch:before{transform:translate(24px)}.animate-fade-in{animation:fadeIn var(--transition-normal) forwards}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.settings-footer-action{border-top:1px solid var(--border-color);grid-column:1/-1;justify-content:flex-end;align-items:center;gap:1.5rem;margin-top:.5rem;padding-top:1.5rem;display:flex}.save-toast{color:var(--success);animation:fadeIn var(--transition-fast) forwards;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;display:flex}.save-settings-btn{background-color:var(--accent);color:#fff;border-radius:var(--radius-md);cursor:pointer;box-shadow:var(--shadow-md);transition:background-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);border:none;align-items:center;gap:.5rem;padding:.8rem 1.75rem;font-weight:600;display:flex}.save-settings-btn:hover{background-color:var(--accent-hover);box-shadow:var(--shadow-lg)}.save-settings-btn:active{transform:scale(.98)}.save-settings-btn:disabled{opacity:.7;cursor:not-allowed}@media (width<=768px){.settings-form-grid,.form-row.split-2{grid-template-columns:1fr;gap:1.25rem}.settings-footer-action{flex-direction:column-reverse;align-items:stretch;gap:1rem}.save-toast{justify-content:center}.save-settings-btn{justify-content:center;width:100%;padding:.9rem}}.form-row.split-3{grid-template-columns:1fr 1fr 1fr;gap:1rem;display:grid}.logo-upload-container{margin-top:.25rem}.logo-preview-wrapper{border:1px dashed var(--border-color);border-radius:var(--radius-md);background-color:#ffffff05;align-items:center;gap:1.5rem;padding:1rem;display:flex}.logo-preview-image{object-fit:contain;border-radius:var(--radius-sm);border:1px solid var(--border-color);background-color:#ffffff0d;max-width:120px;max-height:60px;padding:.25rem}.remove-logo-btn{background-color:var(--error-light);color:var(--error);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);border:1px solid #ef444433;padding:.5rem 1rem;font-size:.85rem;font-weight:600}.remove-logo-btn:hover{color:var(--error-hover);background-color:#ef444440}.logo-upload-dropzone{border:2px dashed var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--transition-fast), background-color var(--transition-fast);color:var(--text-secondary);background-color:#ffffff03;flex-direction:column;justify-content:center;align-items:center;padding:1.5rem;display:flex}.logo-upload-dropzone:hover{border-color:var(--accent);color:var(--text-primary);background-color:#6366f10d}.logo-upload-dropzone span{margin-top:.5rem;font-size:.9rem;font-weight:500}.logo-upload-dropzone .upload-hint{color:var(--text-muted);margin-top:.25rem;font-size:.75rem}.logo-upload-dropzone .upload-icon{color:var(--text-muted);transition:color var(--transition-fast)}.logo-upload-dropzone:hover .upload-icon{color:var(--accent)}@media (width<=768px){.form-row.split-3{grid-template-columns:1fr;gap:1.25rem}}.app-layout{background-color:var(--bg-primary);width:100vw;min-height:100vh;color:var(--text-primary);display:flex}.app-loader-container{background-color:var(--bg-primary);min-height:100vh;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex}.app-loader-container .spinner{border:3px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:1s linear infinite spin}.mobile-header{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);z-index:10;justify-content:space-between;align-items:center;width:100%;height:60px;padding:0 1rem;display:none;position:fixed;top:0;left:0}.mobile-header .logo-text{font-size:1.15rem;font-weight:700}.menu-btn,.mobile-add-btn{color:var(--text-primary);cursor:pointer;border-radius:var(--radius-sm);transition:background-color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:.5rem;display:flex}.menu-btn:hover,.mobile-add-btn:hover{background-color:var(--bg-tertiary)}.app-sidebar{background-color:var(--bg-secondary);border-right:1px solid var(--border-color);z-index:20;width:260px;height:100vh;transition:transform var(--transition-normal);flex-direction:column;flex-shrink:0;padding:1.5rem;display:flex;position:sticky;top:0}.sidebar-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.sidebar-header .logo-text{letter-spacing:-.03em;background:linear-gradient(to right, var(--accent), var(--success));-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.35rem;font-weight:700}.close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;display:none}.sidebar-nav{flex-direction:column;flex-grow:1;gap:.5rem;display:flex}.nav-item{border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;text-align:left;transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0;border:none;align-items:center;gap:.75rem;padding:.75rem 1rem;font-weight:500;display:flex}.nav-item:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.nav-item.active{background-color:var(--accent-light);color:var(--accent)}.sidebar-footer{border-top:1px solid var(--border-color);flex-direction:column;gap:1rem;padding-top:1.25rem;display:flex}.user-profile{align-items:center;gap:.75rem;display:flex}.user-avatar{background-color:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:.95rem;font-weight:600;display:flex}.user-details{flex-direction:column;display:flex;overflow:hidden}.user-email{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.user-mode{color:var(--text-muted);font-size:.7rem}.signout-btn{border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);background-color:#0000;align-items:center;gap:.75rem;padding:.65rem 1rem;font-size:.85rem;font-weight:500;display:flex}.signout-btn:hover{background-color:var(--error-light);color:var(--error);border-color:#ef444433}.app-main{box-sizing:border-box;flex-grow:1;height:100vh;padding:2.5rem;overflow-y:auto}@media (width<=1024px){.app-sidebar{width:240px;padding:1.25rem}.app-main{padding:1.75rem}}@media (width<=768px){.mobile-header{display:flex}.app-layout{flex-direction:column;padding-top:60px}.app-sidebar{height:100vh;box-shadow:var(--shadow-lg);position:fixed;top:0;left:0;transform:translate(-100%)}.app-sidebar.open{transform:translate(0)}.close-btn{border-radius:var(--radius-sm);justify-content:center;align-items:center;padding:.25rem;display:flex}.close-btn:hover{background-color:var(--bg-tertiary)}.sidebar-overlay{z-index:15;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#00000080;width:100vw;height:100vh;position:fixed;top:0;left:0}.app-main{height:calc(100vh - 60px);padding:1.25rem}}@media print{.app-layout{display:block!important}.app-main{height:auto!important;padding:0!important;overflow:visible!important}}.sidebar-collapse-toggle-btn{background-color:var(--bg-tertiary);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);box-sizing:border-box;border:none;justify-content:flex-start;align-items:center;gap:.75rem;width:100%;padding:.65rem 1rem;font-size:.85rem;font-weight:600;display:flex}.sidebar-collapse-toggle-btn:hover{background-color:var(--border-color);color:var(--text-primary)}.app-sidebar.collapsed{align-items:center;width:76px;padding:1.5rem .5rem}.app-sidebar.collapsed .sidebar-header{justify-content:center;width:100%;margin-bottom:2rem}.app-sidebar.collapsed .sidebar-nav{align-items:center;width:100%}.app-sidebar.collapsed .nav-item{border-radius:var(--radius-md);justify-content:center;width:44px;height:44px;padding:.7rem 0}.app-sidebar.collapsed .sidebar-collapse-toggle-btn{justify-content:center;width:44px;height:44px;padding:0}.app-sidebar.collapsed .user-profile{justify-content:center}.app-sidebar.collapsed .signout-btn{justify-content:center;width:44px;height:44px;padding:0}.about-btn{border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast);box-sizing:border-box;background-color:#0000;border:none;justify-content:flex-start;align-items:center;gap:.75rem;width:100%;margin-top:.5rem;padding:.65rem 1rem;font-size:.85rem;font-weight:600;display:flex}.about-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.app-sidebar.collapsed .about-btn{justify-content:center;width:44px;height:44px;padding:0}@media (width<=768px){.desktop-only{display:none!important}}
