:root{--primary: #2563eb;--primary-hover: #1d4ed8;--primary-light: rgba(37, 99, 235, .08);--bg: #f0f2f5;--card-bg: rgba(255, 255, 255, .92);--text: #111827;--text-secondary: #6b7280;--text-muted: #9ca3af;--border: rgba(229, 231, 235, .8);--glass-shadow: 0 4px 24px rgba(0, 0, 0, .06);--success: #059669;--success-light: rgba(5, 150, 105, .08);--danger: #dc2626;--danger-light: rgba(220, 38, 38, .08);--purple: #7c3aed;--purple-light: rgba(124, 58, 237, .08);--radius: 10px;--radius-lg: 14px}[data-theme=dark]{--primary: #3b82f6;--primary-hover: #2563eb;--primary-light: rgba(59, 130, 246, .12);--bg: #0f172a;--card-bg: rgba(30, 41, 59, .92);--text: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--border: rgba(51, 65, 85, .8);--glass-shadow: 0 4px 24px rgba(0, 0, 0, .2);--success: #34d399;--success-light: rgba(52, 211, 153, .12);--danger: #f87171;--danger-light: rgba(248, 113, 113, .12);--purple: #a78bfa;--purple-light: rgba(167, 139, 250, .12)}[data-theme=dark] .form-input{background-color:#1e293b;border-color:#334155;color:#f1f5f9}[data-theme=dark] .form-input::placeholder{color:#64748b}[data-theme=dark] .form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f633}[data-theme=dark] select.form-input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2394a3b8' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E")}[data-theme=dark] .btn-secondary{background:#1e293b;color:#f1f5f9;border-color:#334155}[data-theme=dark] .btn-secondary:hover:not(:disabled){background:#334155;border-color:#475569}[data-theme=dark] .modal-content{background:#1e293b}[data-theme=dark] .data-table th{background:#1e293b80;color:#94a3b8}[data-theme=dark] .data-table tr:hover td{background:#1e293b80}.row-overdue td{background:#fef2f2}[data-theme=dark] .row-overdue td{background:#dc26261f!important;color:#f1f5f9}.row-warning td{background:#fffbeb}[data-theme=dark] .row-warning td{background:#d977061a!important;color:#f1f5f9}[data-theme=dark] .search-input,[data-theme=dark] .filter-select,[data-theme=dark] .filter-date{background-color:#1e293b;border-color:#334155;color:#f1f5f9}[data-theme=dark] .template-editor,[data-theme=dark] .template-card{background:#1e293b;border-color:#334155}[data-theme=dark] .quick-templates-section{background:#3b82f614;border-color:#334155}[data-theme=dark] .quick-template-btn{background:#0f172a;border-color:#3b82f6;color:#60a5fa}[data-theme=dark] .quick-template-btn:hover{background:#3b82f6;color:#fff}[data-theme=dark] .client-card-header:hover,[data-theme=dark] .payment-history,[data-theme=dark] .upload-preview{background:#1e293b}[data-theme=dark] .payment-row,[data-theme=dark] .upload-area{border-color:#334155}[data-theme=dark] .type-badge{background:#334155;color:#94a3b8}[data-theme=dark] .product-suggestions,[data-theme=dark] .client-picker,[data-theme=dark] .client-suggestions{background:#1e293b;border-color:#334155}[data-theme=dark] .product-suggestion-item,[data-theme=dark] .client-picker-item,[data-theme=dark] .client-suggestion-item{border-color:#334155}[data-theme=dark] .product-suggestion-item:hover{background:#334155}[data-theme=dark] .client-picker-item,[data-theme=dark] .client-suggestion-item{background:#0f172a}[data-theme=dark] .client-picker-item:hover,[data-theme=dark] .client-suggestion-item:hover{background:#3b82f61f}[data-theme=dark] .client-suggestion-save{border-color:#3b82f6;color:#60a5fa}[data-theme=dark] .client-suggestion-save:hover{background:#3b82f61f}[data-theme=dark] .btn-client-edit{background:#3b82f61f;border-color:#3b82f6;color:#60a5fa}[data-theme=dark] .btn-client-edit:hover{background:#3b82f6;color:#fff}[data-theme=dark] .client-suggestion-edit{background:#0f172a;border-color:#334155;color:#64748b}[data-theme=dark] .client-suggestion-edit:hover{background:#3b82f61f;color:#60a5fa}[data-theme=dark] .extra-section-editor{background:#3b82f614;border-color:#334155}[data-theme=dark] .client-actions-bar{background:#1e293b;border-color:#334155}[data-theme=dark] .invoice-preview-container,[data-theme=dark] .invoice-preview-container *{color-scheme:light}[data-theme=dark] .invoice-preview-container{background:#fff!important;color:#1a1a2e!important}[data-theme=dark] .inv-header,[data-theme=dark] .inv-title,[data-theme=dark] .inv-business-name{color:#0f172a!important}[data-theme=dark] .inv-meta-label{color:#94a3b8!important}[data-theme=dark] .inv-meta-value{color:#1e293b!important}[data-theme=dark] .inv-business-details,[data-theme=dark] .inv-business-details p{color:#64748b!important}[data-theme=dark] .inv-business-details strong{color:#334155!important}[data-theme=dark] .inv-parties{background:#f8fafc!important;border-color:#e2e8f0!important}[data-theme=dark] .inv-section-label{color:#94a3b8!important}[data-theme=dark] .inv-party-name{color:#0f172a!important}[data-theme=dark] .inv-party-details,[data-theme=dark] .inv-party-details p{color:#64748b!important}[data-theme=dark] .inv-party-details strong{color:#334155!important}[data-theme=dark] .inv-th{color:#64748b!important;border-color:#e2e8f0!important}[data-theme=dark] .inv-td{color:#1a1a2e!important;border-color:#f1f5f9!important}[data-theme=dark] .inv-td-name{color:#1e293b!important}[data-theme=dark] .inv-td-muted{color:#94a3b8!important}[data-theme=dark] .inv-td-amount{color:#0f172a!important}[data-theme=dark] .inv-total-row:not(.inv-total-modern){color:#64748b!important}[data-theme=dark] .inv-total-row:not(.inv-total-modern) span:last-child{color:#1e293b!important}[data-theme=dark] .inv-total-final:not(.inv-total-modern) span:first-child{color:#0f172a!important}[data-theme=dark] .inv-total-final:not(.inv-total-modern) span:last-child{color:#1e40af!important}[data-theme=dark] .inv-total-final:not(.inv-total-modern){border-color:#1e293b!important}[data-theme=dark] .inv-total-modern,[data-theme=dark] .inv-total-modern span,[data-theme=dark] .inv-total-modern span:first-child,[data-theme=dark] .inv-total-modern span:last-child{color:#fff!important;border-color:transparent!important}[data-theme=dark] .inv-words-text{color:#334155!important}[data-theme=dark] .inv-footer{border-color:#e2e8f0!important}[data-theme=dark] .inv-footer-details,[data-theme=dark] .inv-footer-details p{color:#64748b!important}[data-theme=dark] .inv-detail-label,[data-theme=dark] .inv-terms,[data-theme=dark] .inv-sig-label{color:#94a3b8!important}[data-theme=dark] .inv-sig-line{border-color:#1e293b!important}[data-theme=dark] .inv-sig-name{color:#0f172a!important}[data-theme=dark] .inv-tax-badge{background:#2563eb14!important;color:#2563eb!important}[data-theme=dark] .inv-tax-badge-green{background:#05966914!important;color:#059669!important}[data-theme=dark] .inv-gst-pill{background:#eff6ff!important;color:#3b82f6!important}[data-theme=dark] .inv-tr-even td{background:#fafbfc!important}[data-theme=dark] .inv-extra-page{background:#fff!important;border-color:#e2e8f0!important}[data-theme=dark] .inv-extra-page-header{border-color:#e2e8f0!important}[data-theme=dark] .inv-extra-ref{color:#64748b!important}[data-theme=dark] .inv-extra-page-num{color:#94a3b8!important;background:#f1f5f9!important}[data-theme=dark] .inv-extra-content{color:#334155!important}.preview-pane-label{text-align:center;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600;color:var(--text-muted);margin-bottom:.5rem}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100vh}.auth-overlay{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:var(--bg)}.auth-card{width:100%;max-width:420px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow);padding:1.5rem}.auth-brand{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem}.auth-brand h2{font-size:1.1rem;margin:0}.auth-brand p{margin:0;color:var(--text-muted);font-size:.82rem}.auth-logo{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;background:linear-gradient(135deg,var(--primary),#7c3aed)}.auth-error{color:var(--danger);font-size:.82rem;margin:.25rem 0 .75rem}.auth-submit{width:100%}.app-layout{display:flex;height:100vh;overflow:hidden;position:relative}.pwa-install-banner{position:fixed;top:0;left:260px;right:0;z-index:1000;display:flex;align-items:center;gap:.75rem;padding:.65rem 1.25rem;background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;font-size:.9rem;box-shadow:0 2px 8px #00000026}.pwa-install-banner span{flex:1}.pwa-install-btn{background:#fff;color:#1e40af;border:none;padding:.4rem 1rem;border-radius:6px;font-weight:600;font-size:.85rem;cursor:pointer;white-space:nowrap}.pwa-install-btn:hover{background:#e0e7ff}.pwa-dismiss-btn{background:none;border:none;color:#ffffffb3;cursor:pointer;padding:.25rem;display:flex;align-items:center}.pwa-dismiss-btn:hover{color:#fff}@media(max-width:768px){.pwa-install-banner{left:0}}.server-status{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;margin-top:.5rem;border-radius:8px;font-size:.78rem;font-weight:500;color:#94a3b8;background:#ffffff08}.server-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.server-status-online .server-status-dot{background:#22c55e;box-shadow:0 0 6px #22c55e}.server-status-online{color:#86efac}.server-status-offline .server-status-dot{background:#ef4444;box-shadow:0 0 6px #ef4444;animation:pulse-red 1.5s ease-in-out infinite}.server-status-offline{color:#fca5a5}.server-status-checking .server-status-dot{background:#f59e0b;animation:pulse-red 1s ease-in-out infinite}.server-status-checking{color:#fcd34d}@keyframes pulse-red{0%,to{opacity:1}50%{opacity:.3}}.server-down-overlay{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#f2f0ef;color:#e2e8f0;font-family:Inter,system-ui,sans-serif}.server-down-modal{max-width:480px;width:90%;text-align:center;padding:2.5rem 2rem;background:#1e293b;border-radius:16px;border:1px solid #334155;box-shadow:0 25px 50px #0006}.loading-panel{display:flex;flex-direction:column;align-items:center;gap:.5rem}.loading-panel h2{font-size:1rem;color:#2563eb}.loading-panel p{color:#94a3b8;font-size:.7rem;line-height:1.5;color:#2563eb;margin:0}.inline-loading-state{min-height:260px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.85rem;text-align:center;color:var(--text-secondary)}.inline-loading-state h3{margin:0;font-size:1rem;color:var(--text)}.inline-loading-state p{margin:0;font-size:.88rem}.server-down-modal h2{margin:1rem 0 .5rem;font-size:1.5rem;color:#f8fafc}.server-down-modal p{color:#94a3b8;font-size:.95rem;line-height:1.6;margin-bottom:1.5rem}.server-start-btn{display:inline-block;padding:.85rem 2.5rem;background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;font-size:1.05rem;font-weight:600;border:none;border-radius:10px;cursor:pointer;text-decoration:none;margin-bottom:1.5rem;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 15px #2563eb4d}.server-start-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #2563eb66;color:#fff}.server-down-safe{color:#86efac!important;font-size:.82rem!important;margin:1rem 0 .5rem!important;padding:.6rem 1rem;background:#22c55e14;border-radius:8px;border:1px solid rgba(34,197,94,.15)}.server-down-hint{color:#64748b!important;font-size:.8rem!important;margin-bottom:.5rem!important}.server-down-steps{text-align:left;background:#0f172a;padding:1.25rem 1.5rem;border-radius:10px;margin-bottom:1.5rem}.server-down-steps h3{margin:0 0 .75rem;font-size:.95rem;color:#e2e8f0}.server-down-steps ol{margin:0;padding-left:1.25rem}.server-down-steps li{margin-bottom:.5rem;font-size:.9rem;color:#94a3b8;line-height:1.5}.server-down-steps li strong{color:#e2e8f0}.server-down-waiting{display:flex;align-items:center;justify-content:center;gap:.75rem;color:#64748b;font-size:.85rem;padding-top:.5rem}.server-down-spinner{width:18px;height:18px;border:2px solid #334155;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;flex-shrink:0}.loading-spinner-wrap{display:inline-flex;align-items:center;gap:.55rem}.loading-spinner{border-radius:50%;border:2px solid currentColor;border-right-color:transparent;animation:spin .8s linear infinite;flex-shrink:0}.loading-spinner-sm{width:14px;height:14px;border-width:2px}.loading-spinner-md{width:18px;height:18px}.loading-spinner-lg{width:42px;height:42px;border-width:3px;color:#60a5fa}.loading-spinner-label{font-size:.875rem}.sidebar{width:260px;background:#0f172a;color:#fff;padding:1.75rem 1.25rem;display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,.06)}.sidebar-brand{display:flex;align-items:center;gap:.75rem;margin-bottom:2.5rem;padding:0 .5rem}.sidebar-logo{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--primary),#7c3aed);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-title{font-size:1.15rem;font-weight:700;margin:0;color:#fff;letter-spacing:-.02em}.sidebar-subtitle{font-size:.7rem;color:#64748b;margin:0;text-transform:uppercase;letter-spacing:.05em;font-weight:500}.sidebar-nav{display:flex;flex-direction:column;gap:.25rem;flex:1}.profile-switcher{margin:.5rem .75rem .25rem}.profile-switcher-row{display:flex;align-items:center;gap:.25rem}.profile-switcher-edit{flex-shrink:0;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:.35rem;color:#94a3b8;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.profile-switcher-edit:hover{background:#ffffff1f;color:#60a5fa}.profile-switcher-btn{display:flex;align-items:center;gap:.4rem;flex:1;min-width:0;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.4rem .6rem;color:#cbd5e1;font-size:.78rem;cursor:pointer;text-align:left;transition:background .15s}.profile-switcher-btn:hover{background:#ffffff1a}.profile-switcher-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-switcher-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#1e293b;border:1px solid rgba(255,255,255,.12);border-radius:8px;overflow:hidden;z-index:200;box-shadow:0 8px 24px #0006}.profile-switcher-item{display:block;width:100%;background:none;border:none;padding:.5rem .75rem;color:#cbd5e1;font-size:.8rem;text-align:left;cursor:pointer;transition:background .1s}.profile-switcher-item:hover{background:#ffffff14}.profile-switcher-item.active{color:#60a5fa;font-weight:600}.profile-switcher-manage{border-top:1px solid rgba(255,255,255,.08);color:#64748b;font-size:.75rem}.nav-btn{display:flex;align-items:center;gap:.75rem;padding:.7rem 1rem;border:none;border-radius:8px;background:transparent;color:#94a3b8;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease;text-align:left;font-family:inherit}.nav-btn:hover{background:#ffffff0f;color:#e2e8f0}.nav-btn-active{background:var(--primary)!important;color:#fff!important;box-shadow:0 4px 12px #2563eb59}.privacy-toggle-visible{color:#bfdbfe;background:#2563eb1f}.privacy-toggle-visible:hover{color:#fff;background:#2563eb33}.private-value{display:inline-block;min-width:max-content}.private-value-hidden{letter-spacing:.06em;-webkit-user-select:none;user-select:none}.nav-btn-bottom{margin-top:auto}.main-content{flex:1;overflow-y:auto;padding:2rem 2.5rem;display:flex;flex-direction:column}.glass-panel{background:var(--card-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-title{font-size:1.75rem;font-weight:700;letter-spacing:-.025em;margin-bottom:.25rem}.page-subtitle{color:var(--text-secondary);font-size:.9rem}.section-title{font-size:.95rem;font-weight:600;color:var(--primary);margin-bottom:1.25rem;letter-spacing:-.01em}.update-available-box{margin-top:1rem;padding:.85rem 1rem;background:#22c55e14;border:1px solid rgba(34,197,94,.2);border-radius:8px;font-size:.88rem;color:var(--text)}.update-available-box p{margin:.25rem 0}.form-group{margin-bottom:1rem}.form-group.full-width{grid-column:span 2}.form-label{display:block;font-size:.8rem;font-weight:600;margin-bottom:.4rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.form-input{width:100%;padding:.65rem .9rem;border:1.5px solid var(--border);border-radius:8px;background:#fff;font-family:inherit;font-size:.9rem;transition:all .2s;color:var(--text)}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}select.form-input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%236b7280' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2rem}textarea.form-input{resize:vertical;min-height:60px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.6rem 1.25rem;border-radius:8px;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .15s ease;border:none;gap:.5rem;font-family:inherit}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px #2563eb40}.btn-primary:hover:not(:disabled){background:var(--primary-hover);box-shadow:0 4px 12px #2563eb4d;transform:translateY(-1px)}.btn-secondary{background:#fff;color:var(--text);border:1.5px solid var(--border)}.btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db}.icon-btn{width:28px;height:28px;border-radius:6px;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s}.icon-btn-blue{background:var(--primary-light);color:var(--primary)}.icon-btn-blue:hover{background:#2563eb26}.icon-btn-red{background:var(--danger-light);color:var(--danger)}.icon-btn-red:hover{background:#dc262626}.dashboard-container{max-width:100%;margin:0 auto;width:100%}.settings-container{max-width:800px;margin:0 auto;width:100%}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-bottom:2rem}.stat-card{background:var(--card-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow);padding:1.5rem;display:flex;align-items:center;gap:1rem}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon-blue{background:var(--primary-light);color:var(--primary)}.stat-icon-green{background:var(--success-light);color:var(--success)}.stat-icon-purple{background:var(--purple-light);color:var(--purple)}.stat-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.25rem}.stat-value{font-size:1.5rem;font-weight:700;color:var(--primary);letter-spacing:-.02em;margin:0}.stat-value-green{color:var(--success)}.stat-value-purple{color:var(--purple)}.table-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.table-header h3{margin:0;font-size:1rem}.table-scroll{overflow-x:auto}.data-table{width:100%;border-collapse:separate;border-spacing:0;min-width:900px}.data-table th{text-align:left;padding:.5rem;font-size:.65rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);font-weight:600;border-bottom:1px solid var(--border);background:#f9fafb80;white-space:nowrap}.data-table td{padding:.5rem;border-bottom:1px solid var(--border);vertical-align:middle;font-size:.78rem;white-space:nowrap}.data-table td.td-client{white-space:normal;max-width:160px;overflow:hidden;text-overflow:ellipsis}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#f9fafb80}.invoice-badge{display:inline-block;padding:.15rem .45rem;background:var(--primary-light);color:var(--primary);border-radius:5px;font-size:.72rem;font-weight:600;white-space:nowrap}.table-actions{display:flex;gap:.25rem;flex-wrap:nowrap}.empty-state{padding:4rem 2rem;text-align:center;color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:1rem}.empty-state svg{opacity:.25}.generator-container{display:flex;flex-direction:column;flex:1;height:100%;min-height:0}.generator-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-shrink:0}.split-view{display:flex;flex:1;min-height:0;gap:2rem}.editor-pane{flex:1;overflow-y:auto;padding-right:.5rem}.preview-pane{flex:1;overflow-y:auto;display:flex;flex-direction:column;align-items:center}.preview-scaler{transform:scale(.82);transform-origin:top center}[data-theme=dark] .invoice-preview-container{box-shadow:0 8px 40px #00000059,0 0 0 1px #ffffff0f}.invoice-options{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.options-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.option-toggle{display:flex;align-items:center;gap:.5rem;padding:.45rem .65rem;border-radius:6px;cursor:pointer;font-size:.8rem;color:var(--text-secondary);transition:background .15s;-webkit-user-select:none;user-select:none}.option-toggle:hover{background:#0000000a}.option-toggle input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.option-toggle span{font-weight:500}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:12px;padding:2rem;max-width:560px;width:90%;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.payment-history{display:flex;flex-direction:column;gap:.35rem;background:#f8fafc;border-radius:8px;padding:.75rem;max-height:200px;overflow-y:auto}.payment-row{display:flex;gap:1rem;align-items:center;font-size:.8rem;padding:.35rem 0;border-bottom:1px solid #f1f5f9}.payment-row:last-child{border-bottom:none}.client-card-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;cursor:pointer;transition:background .15s}.client-card-header:hover{background:#f8fafc}.client-card-info{display:flex;align-items:center;gap:1rem}.client-avatar{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--primary),#3b82f6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;flex-shrink:0}.client-card-name{font-size:1rem;font-weight:600;color:var(--text);margin:0}.client-card-meta{font-size:.75rem;color:var(--text-muted);margin:.15rem 0 0}.client-card-stats{display:flex;align-items:center;gap:1.5rem}.client-stat{display:flex;flex-direction:column;align-items:flex-end}.client-stat-label{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;font-weight:600}.client-stat-value{font-size:.9rem;font-weight:700;color:var(--text)}.client-invoices{border-top:1px solid var(--border)}.client-actions-bar{display:flex;justify-content:flex-end;padding:.75rem 1.5rem;border-top:1px solid var(--border);background:#fafbfc}.client-actions-bar .icon-btn{font-size:.75rem;display:flex;align-items:center;gap:.3rem}.icon-btn-green{color:#059669}.icon-btn-green:hover{background:#ecfdf5}.line-item-row{display:flex;gap:.5rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border);align-items:flex-end}.line-item-field{display:flex;flex-direction:column}.line-item-field .form-label{margin-bottom:.3rem;font-size:.7rem}.line-item-delete{justify-content:flex-end;padding-bottom:.35rem}.product-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px #0000001f;z-index:50;max-height:180px;overflow-y:auto}.product-suggestion-item{padding:.5rem .75rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:.82rem;border-bottom:1px solid var(--border)}.product-suggestion-item:last-child{border-bottom:none}.product-suggestion-item:hover{background:#f0f4ff}.product-suggestion-name{font-weight:500;color:var(--text)}.product-suggestion-meta{font-size:.72rem;color:var(--text-secondary)}.invoice-preview-container{background:#fff;min-height:297mm;width:210mm;margin:0 auto;font-family:Inter,sans-serif;font-size:12.5px;line-height:1.45;color:#1a1a2e;position:relative;border:1px solid #e5e7eb;border-radius:4px;box-shadow:0 8px 30px #00000014;padding:0;overflow:hidden}.inv-header{display:flex;justify-content:space-between;align-items:flex-start;padding:2rem 2.5rem 0;margin-bottom:2rem}.inv-title{font-size:2rem;font-weight:800;color:#0f172a;margin-bottom:1rem}.inv-meta{display:flex;flex-direction:column;gap:.2rem}.inv-meta-row{display:flex;gap:.75rem;font-size:.825rem}.inv-meta-label{color:#94a3b8;min-width:75px;font-weight:500}.inv-meta-value{color:#1e293b;font-weight:600}.inv-header-right{text-align:right;max-width:45%}.inv-business-name{font-size:1.1rem;font-weight:700;color:#0f172a;margin-bottom:.4rem}.inv-business-details{font-size:.8rem;color:#64748b;line-height:1.65}.inv-business-details p{margin:0;color:#64748b}.inv-business-details strong{color:#334155;font-weight:600}.inv-parties{display:flex;justify-content:space-between;margin:0 2.5rem 2rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:1.5rem}.inv-section-label{font-size:.65rem;font-weight:700;color:#94a3b8;text-transform:uppercase;margin-bottom:.5rem}.inv-party-name{font-size:1rem;font-weight:700;color:#0f172a;margin-bottom:.3rem}.inv-party-details{font-size:.8rem;color:#64748b;line-height:1.65}.inv-party-details p{margin:0;color:#64748b}.inv-party-details strong{color:#334155}.inv-party-right{text-align:right;display:flex;flex-direction:column;justify-content:center}.inv-tax-badge{display:inline-block;margin-top:.5rem;padding:.2rem .6rem;background:var(--primary-light);color:var(--primary);border-radius:20px;font-size:.7rem;font-weight:600}.inv-tax-badge-green{background:var(--success-light);color:var(--success)}.inv-table{width:calc(100% - 3rem);margin:0 1.5rem 1.5rem;border-collapse:collapse}.inv-th{padding:.45rem .4rem;font-size:.6rem;font-weight:700;text-transform:uppercase;color:#64748b;text-align:left;border-bottom:2px solid #e2e8f0;background:transparent;white-space:nowrap}.inv-th-center{text-align:center}.inv-th-right{text-align:right}.inv-td{padding:.5rem .4rem;font-size:.72rem;border-bottom:1px solid #f1f5f9;white-space:nowrap}.inv-td-name{font-weight:600;color:#1e293b;white-space:normal;word-wrap:break-word;overflow-wrap:break-word}.inv-td-center{text-align:center}.inv-td-right{text-align:right}.inv-td-muted{color:#94a3b8}.inv-td-amount{font-weight:600;color:#0f172a;white-space:nowrap}.inv-tr-even td{background:#fafbfc}.inv-gst-pill{display:inline-block;padding:.1rem .45rem;background:#eff6ff;color:#3b82f6;border-radius:4px;font-size:.7rem;font-weight:600}.inv-totals-section{display:flex;justify-content:space-between;align-items:flex-start;padding:0 2.5rem;margin-bottom:2.5rem}.inv-words{flex:1;padding-right:3rem}.inv-words-text{font-size:.825rem;font-weight:500;color:#334155;font-style:italic;line-height:1.5;text-transform:capitalize}.inv-totals{width:260px}.inv-total-row{display:flex;justify-content:space-between;padding:.4rem 0;font-size:.825rem;color:#64748b}.inv-total-row span:last-child{font-weight:500;color:#1e293b}.inv-total-final{margin-top:.5rem;padding-top:.75rem;border-top:2px solid #1e293b}.inv-total-final span:first-child{font-weight:700;font-size:.95rem;color:#0f172a}.inv-total-final span:last-child{font-weight:800;font-size:1.25rem;color:#1e40af}.inv-total-modern{border-top:none}.inv-total-modern span:first-child,.inv-total-modern span:last-child{color:#fff}.inv-footer{display:flex;justify-content:space-between;align-items:flex-end;padding:1.75rem 2.5rem 2rem;border-top:1px solid #e2e8f0;margin:0 2.5rem}.inv-footer-left{flex:1}.inv-footer-block{margin-bottom:1.25rem}.inv-footer-block:last-child{margin-bottom:0}.inv-footer-details{font-size:.8rem;color:#64748b;line-height:1.7}.inv-footer-details p{margin:0;color:#64748b}.inv-detail-label{color:#94a3b8;font-weight:500;display:inline-block;min-width:55px}.inv-terms{font-size:.6rem;color:#64748b;line-height:1.5;margin:0}.inv-extra-page{page-break-before:always;break-before:page;border-top:3px solid #e2e8f0;padding:2rem;min-height:280mm;background:#fff;width:210mm;box-sizing:border-box}.inv-extra-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:1px solid #e2e8f0}.inv-extra-ref{font-size:.75rem;color:#64748b;font-weight:500}.inv-extra-page-num{font-size:.7rem;color:#94a3b8;font-weight:500;background:#f1f5f9;padding:.2rem .6rem;border-radius:4px}.inv-extra-content{font-size:.78rem;color:#334155;line-height:1.7}.inv-extra-content p{margin-bottom:.5rem}.inv-extra-content ul,.inv-extra-content ol{margin:.5rem 0 .5rem 1.5rem}.inv-extra-content li{margin-bottom:.25rem}.inv-extra-content table{border-collapse:collapse;width:100%;margin:.5rem 0}.inv-extra-content table th,.inv-extra-content table td{border:1px solid #cbd5e1;padding:.35rem .5rem;font-size:.75rem;text-align:left}.inv-extra-content table th{background:#f1f5f9;font-weight:600}.inv-extra-content h1,.inv-extra-content h2,.inv-extra-content h3,.inv-extra-content h4,.inv-extra-content h5{margin:.75rem 0 .35rem;color:#1e293b}.inv-extra-content strong,.inv-extra-content b{font-weight:600}.extra-section-editor{background:var(--primary-light);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-bottom:.75rem}.rich-editor{cursor:text;outline:none;font-size:.85rem;line-height:1.6}.rich-editor:empty:before{content:attr(data-placeholder);color:var(--text-muted);pointer-events:none}.rich-editor:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.rich-editor ul,.rich-editor ol{margin-left:1.5rem}.rich-editor table{border-collapse:collapse;width:100%}.rich-editor table th,.rich-editor table td{border:1px solid var(--border);padding:.35rem .5rem}.inv-signature{text-align:right;min-width:180px}.inv-sig-label{font-size:.75rem;color:#94a3b8;margin-bottom:2.5rem}.inv-sig-line{border-bottom:1.5px solid #1e293b;width:180px;margin-left:auto;margin-bottom:.4rem}.inv-sig-name{font-size:.825rem;font-weight:600;color:#0f172a}.toast-container{position:fixed;top:1.25rem;right:1.25rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem;pointer-events:none}.toast-item{display:flex;align-items:center;gap:.75rem;padding:.85rem 1.25rem;border-radius:10px;box-shadow:0 8px 24px #0000001f;font-size:.875rem;font-weight:500;pointer-events:auto;animation:toast-slide .3s ease;max-width:380px}.toast-message{flex:1}.toast-close{background:none;border:none;cursor:pointer;opacity:.5;padding:2px;display:flex;color:inherit}.toast-close:hover{opacity:1}@keyframes toast-slide{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.flex{display:flex}.flex-col{flex-direction:column}.flex-1{flex:1}.h-full{height:100%}.min-h-0{min-height:0}.shrink-0{flex-shrink:0}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.items-center{align-items:center}.items-end{align-items:flex-end}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.text-muted{color:var(--text-secondary)}.font-medium{font-weight:500}.font-bold{font-weight:600}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.type-selector{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}.type-chip{padding:.45rem 1rem;border-radius:20px;border:1.5px solid var(--border);background:#fff;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit;color:var(--text-secondary)}.type-chip:hover{border-color:var(--primary);color:var(--primary)}.type-chip-active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 8px #2563eb40}.type-desc{font-size:.8rem;color:var(--text-muted);font-style:italic}.filters-bar{display:flex;gap:.5rem;padding:.75rem 1.25rem;border-bottom:1px solid var(--border);align-items:center;flex-wrap:wrap}.search-box{position:relative;flex:1;min-width:200px}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-input{width:100%;padding:.5rem .75rem .5rem 2.25rem;border:1.5px solid var(--border);border-radius:8px;font-size:.85rem;font-family:inherit;background:#fff;color:var(--text);transition:all .15s}.search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.filter-select,.filter-date{padding:.5rem .75rem;border:1.5px solid var(--border);border-radius:8px;font-size:.8rem;font-family:inherit;background:#fff;color:var(--text);cursor:pointer}.filter-select:focus,.filter-date:focus{outline:none;border-color:var(--primary)}.type-badge{font-size:.7rem;padding:.15rem .5rem;border-radius:4px;background:#f3f4f6;color:var(--text-secondary);font-weight:500;white-space:nowrap}.upload-area{border:2px dashed var(--border);border-radius:10px;overflow:hidden;transition:border-color .15s}.upload-area:hover{border-color:#d1d5db}.upload-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:1.5rem;width:100%;background:none;border:none;cursor:pointer;color:var(--text-secondary);font-family:inherit;font-size:.85rem;font-weight:500}.upload-btn:hover{color:var(--primary)}.upload-hint{font-size:.7rem;color:var(--text-muted);font-weight:400}.upload-preview{position:relative;display:flex;align-items:center;justify-content:center;padding:1rem;background:#fafbfc}.upload-img{max-height:64px;max-width:100%;object-fit:contain}.upload-remove{position:absolute;top:.5rem;right:.5rem}.logo-upload-section{display:flex;flex-direction:column;gap:.5rem;width:100%}.logo-preview-box{position:relative;display:flex;align-items:center;justify-content:center;padding:1rem;background:#fafbfc;border-radius:8px;min-height:60px}[data-theme=dark] .logo-preview-box{background:#1e293b}.logo-size-control{display:flex;flex-direction:column;gap:.15rem}.logo-slider{width:100%;height:6px;appearance:none;background:#e2e8f0;border-radius:3px;outline:none;cursor:pointer}.logo-slider::-webkit-slider-thumb{appearance:none;width:16px;height:16px;border-radius:50%;background:var(--primary);cursor:pointer}.logo-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--primary);cursor:pointer;border:none}[data-theme=dark] .logo-slider{background:#334155}.upload-change-btn{background:none;border:1px dashed var(--border);border-radius:6px;padding:.35rem .75rem;font-size:.75rem;color:var(--primary);cursor:pointer;text-align:center}.upload-change-btn:hover{background:#f1f5f9;border-color:var(--primary)}[data-theme=dark] .upload-change-btn:hover{background:#1e293b}.template-editor{background:#f8fafc;border:1px solid var(--border);border-radius:10px;padding:1.25rem;margin-bottom:1rem}.template-list{display:flex;flex-direction:column;gap:.5rem}.template-card{border:1px solid var(--border);border-radius:8px;padding:.75rem 1rem;background:#fff}.template-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.35rem;font-size:.875rem}.template-card-preview{font-size:.75rem;color:var(--text-muted);white-space:pre-line;max-height:60px;overflow:hidden;line-height:1.5}.quick-templates-section{margin-bottom:1rem;padding:1rem;background:var(--primary-light);border:1px dashed var(--primary);border-radius:10px}.quick-templates-grid{display:flex;flex-wrap:wrap;gap:.4rem}.quick-template-btn{display:flex;align-items:center;gap:.3rem;padding:.35rem .7rem;font-size:.78rem;font-family:inherit;font-weight:500;color:var(--primary);background:#fff;border:1px solid var(--primary);border-radius:6px;cursor:pointer;transition:all .15s}.quick-template-btn:hover{background:var(--primary);color:#fff}.status-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .6rem;border-radius:20px;font-size:.7rem;font-weight:600;border:none;cursor:pointer;font-family:inherit;white-space:nowrap;transition:opacity .15s}.status-badge:hover{opacity:.8}.status-select{appearance:auto;padding:.25rem .4rem;border-radius:6px;font-size:.75rem;font-weight:600;border:1px solid;cursor:pointer;font-family:inherit;outline:none}.stats-grid-4{grid-template-columns:repeat(4,1fr)}.stat-icon-amber{background:#f59e0b14;color:#f59e0b}.stat-value-amber{color:#d97706}.client-picker{display:flex;flex-direction:column;gap:.25rem;background:#f8fafc;border:1px solid var(--border);border-radius:10px;padding:.5rem;margin-bottom:1rem}.client-search-input{margin-bottom:.4rem;position:sticky;top:0;z-index:1}.client-picker-list{max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:.25rem}.client-picker-empty{padding:.75rem;text-align:center;color:var(--text-muted);font-size:.85rem}.client-picker-item{display:flex;justify-content:space-between;align-items:center;padding:.6rem .75rem;background:#fff;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .12s;font-family:inherit;font-size:.85rem;text-align:left;color:var(--text)}.client-picker-item:hover{border-color:var(--primary);background:var(--primary-light)}.client-picker-item strong{font-weight:600}.client-picker-item span{font-size:.75rem;color:var(--text-muted)}.client-suggestions{position:absolute;top:100%;left:0;right:0;z-index:50;background:#f8fafc;border:1px solid var(--border);border-radius:10px;padding:.35rem;max-height:220px;overflow-y:auto;box-shadow:0 8px 24px #0000001f;display:flex;flex-direction:column;gap:.2rem}.client-suggestion-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .65rem;background:#fff;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .12s;font-family:inherit;font-size:.85rem;text-align:left;color:var(--text);width:100%}.client-suggestion-item:hover{border-color:var(--primary);background:var(--primary-light)}.client-suggestion-item strong{font-weight:600}.client-suggestion-item span{font-size:.75rem;color:var(--text-muted)}.client-suggestion-save{display:flex;align-items:center;gap:.4rem;padding:.5rem .65rem;background:transparent;border:1px dashed var(--primary);border-radius:8px;cursor:pointer;font-family:inherit;font-size:.8rem;color:var(--primary);width:100%;transition:all .12s}.client-suggestion-save:hover{background:var(--primary-light)}.btn-client-edit{display:flex;align-items:center;justify-content:center;width:36px;height:36px;flex-shrink:0;background:var(--primary-light);color:var(--primary);border:1px solid var(--primary);border-radius:8px;cursor:pointer;transition:all .15s}.btn-client-edit:hover{background:var(--primary);color:#fff}.client-suggestion-row{display:flex;align-items:stretch;gap:.25rem}.client-suggestion-row .client-suggestion-item{flex:1;border-top-right-radius:0;border-bottom-right-radius:0}.client-suggestion-edit{display:flex;align-items:center;justify-content:center;width:32px;flex-shrink:0;background:#fff;border:1px solid var(--border);border-left:none;border-radius:0 8px 8px 0;cursor:pointer;color:var(--text-muted);transition:all .12s}.client-suggestion-edit:hover{background:var(--primary-light);color:var(--primary)}.client-suggestion-main{display:flex;flex-direction:column;align-items:flex-start;gap:.1rem}.client-suggestion-addr{font-size:.7rem;color:var(--text-muted);font-weight:400}.field-hint{font-size:.72rem;color:var(--text-muted);margin-top:.35rem;line-height:1.4}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#9ca3af66;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#6b728099}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
