*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f0f2f5;--surface: #ffffff;--surface-2: #f8f9fb;--border: #e4e7ec;--border-2: #d0d5dd;--text: #101828;--text-2: #344054;--text-3: #667085;--text-4: #98a2b3;--accent: #2563eb;--accent-h: #1d4ed8;--accent-bg: #eff6ff;--success: #16a34a;--success-bg:#dcfce7;--warn: #d97706;--warn-bg: #fef3c7;--danger: #dc2626;--danger-bg: #fee2e2;--purple: #7c3aed;--purple-bg: #ede9fe;--radius-sm: 6px;--radius: 10px;--radius-lg: 14px;--shadow-sm: 0 1px 2px rgba(16,24,40,.05);--shadow: 0 1px 3px rgba(16,24,40,.1), 0 1px 2px rgba(16,24,40,.06);--shadow-md: 0 4px 8px -2px rgba(16,24,40,.1), 0 2px 4px -2px rgba(16,24,40,.06);--shadow-lg: 0 12px 24px -4px rgba(16,24,40,.12), 0 4px 8px -2px rgba(16,24,40,.06);--sidebar-w: 240px}html,body,#root{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-size:14px;color:var(--text);background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased}.app-layout{display:flex;height:100%;overflow:hidden}.sidebar{width:var(--sidebar-w);background:var(--text);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;transition:transform .25s ease;z-index:50}.sidebar-brand{padding:20px 20px 16px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:10px}.sidebar-brand-icon{width:36px;height:36px;background:var(--accent);border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-brand-icon svg{color:#fff}.sidebar-brand-text{color:#fff;font-weight:700;font-size:16px;line-height:1}.sidebar-brand-sub{color:#fff6;font-size:10px;margin-top:2px;text-transform:uppercase;letter-spacing:.6px}.sidebar-nav{padding:12px 10px;flex:1}.sidebar-footer{padding:12px 10px;border-top:1px solid rgba(255,255,255,.08)}.nav-section-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.7px;color:#ffffff4d;padding:12px 10px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;cursor:pointer;color:#fff9;font-size:13.5px;font-weight:500;transition:background .15s,color .15s;border:none;background:none;width:100%;text-align:left;margin-bottom:2px;font-family:inherit}.nav-item:hover{background:#ffffff12;color:#ffffffe6}.nav-item.active{background:#ffffff1a;color:#fff}.nav-badge{margin-left:auto;background:var(--accent);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px;min-width:20px;text-align:center}.main-content{flex:1;overflow-y:auto;display:flex;flex-direction:column}.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;position:sticky;top:0;z-index:40}.topbar-left{display:flex;align-items:center;gap:12px}.topbar-title{font-size:17px;font-weight:700;color:var(--text)}.topbar-sub{font-size:12px;color:var(--text-3);margin-top:1px}.topbar-right{display:flex;align-items:center;gap:8px}.hamburger{display:none;background:none;border:none;cursor:pointer;padding:6px;color:var(--text-2);border-radius:6px}.hamburger:hover{background:var(--bg)}.hamburger svg{width:20px;height:20px;display:block}.page-body{padding:28px 32px;flex:1}.top-ad-wrap{padding:14px 32px 0}.sidebar-ad-wrap{padding:6px 10px 12px}.content-ad-wrap{margin-bottom:20px}.ad-slot{border:1px dashed #cbd5e1;border-radius:var(--radius);background:linear-gradient(180deg,#fff,#f8fafc),repeating-linear-gradient(45deg,#2563eb0a 0,#2563eb0a 8px,#2563eb05 8px,#2563eb05 16px);padding:8px}.ad-slot-label{font-size:10px;text-transform:uppercase;letter-spacing:.7px;font-weight:700;color:var(--text-3);margin-bottom:6px}.ad-slot-box{width:100%;border:1px solid var(--border);border-radius:8px;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden}.ad-slot-banner .ad-slot-box{min-height:90px}.ad-slot-rectangle .ad-slot-box{min-height:250px}.ad-slot-image{width:100%;height:100%;object-fit:cover;display:block}.ad-slot-ins{width:100%}.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:500;cursor:pointer;border:none;transition:background .15s,box-shadow .15s,transform .1s,opacity .15s;font-family:inherit;white-space:nowrap;text-decoration:none}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.55;pointer-events:none}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 1px 2px #2563eb4d}.btn-primary:hover{background:var(--accent-h)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#15803d}.btn-ghost{background:transparent;color:var(--text-2);border:1px solid var(--border)}.btn-ghost:hover{background:var(--surface-2);border-color:var(--border-2)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-danger-ghost{background:transparent;color:var(--danger);border:1px solid #fecaca}.btn-danger-ghost:hover{background:var(--danger-bg)}.btn-sm{padding:6px 11px;font-size:12.5px}.btn-xs{padding:4px 9px;font-size:12px}.btn-icon{padding:7px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.card-header-left{display:flex;align-items:center;gap:8px}.card-icon{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px}.card-title{font-size:13px;font-weight:600;color:var(--text)}.card-subtitle{font-size:11px;color:var(--text-3);margin-top:1px}.card-body{padding:18px}.field{display:flex;flex-direction:column;gap:5px}.field label{font-size:12px;font-weight:600;color:var(--text-2)}input[type=text],input[type=number],input[type=date],textarea,select{border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 11px;font-size:13.5px;color:var(--text);background:var(--surface);outline:none;transition:border-color .15s,box-shadow .15s;width:100%;font-family:inherit;line-height:1.4}input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1a}textarea{resize:vertical}input[type=number]{-moz-appearance:textfield}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}.form-stack{display:flex;flex-direction:column;gap:14px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600}.badge-blue{background:var(--accent-bg);color:var(--accent)}.badge-green{background:var(--success-bg);color:var(--success)}.badge-yellow{background:var(--warn-bg);color:var(--warn)}.badge-red{background:var(--danger-bg);color:var(--danger)}.badge-purple{background:var(--purple-bg);color:var(--purple)}.badge-gray{background:var(--surface-2);color:var(--text-3);border:1px solid var(--border)}.logo-dropzone{border:2px dashed var(--border-2);border-radius:var(--radius);padding:20px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s}.logo-dropzone:hover,.logo-dropzone.drag-over{border-color:var(--accent);background:var(--accent-bg)}.logo-dropzone input{display:none}.logo-dropzone-icon{font-size:28px;line-height:1;margin-bottom:8px}.logo-dropzone-title{font-weight:600;font-size:13px;color:var(--text);margin-bottom:3px}.logo-dropzone-hint{font-size:11.5px;color:var(--text-3)}.logo-preview{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm)}.logo-preview img{height:48px;max-width:130px;object-fit:contain;border-radius:4px}.logo-preview-info{flex:1}.logo-preview-label{font-size:11px;color:var(--text-3);margin-bottom:6px}.logo-preview-actions{display:flex;gap:6px}.currency-wrapper{position:relative}.currency-trigger{display:flex;align-items:center;gap:8px;width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 11px;background:var(--surface);cursor:pointer;transition:border-color .15s,box-shadow .15s;font-family:inherit;font-size:13.5px}.currency-trigger:hover{border-color:var(--border-2)}.currency-trigger:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1a;outline:none}.currency-trigger-sym{font-weight:700;color:var(--text-3);min-width:22px;font-size:13px}.currency-trigger-code{font-weight:600;color:var(--text)}.currency-trigger-name{color:var(--text-3);font-size:12px;flex:1}.currency-trigger-chevron{margin-left:auto;color:var(--text-4);font-size:11px}.currency-dropdown{position:absolute;top:calc(100% + 5px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:300;overflow:hidden}.currency-search-wrap{padding:8px;border-bottom:1px solid var(--border)}.currency-list{max-height:210px;overflow-y:auto}.currency-opt{display:flex;align-items:center;gap:10px;padding:9px 13px;cursor:pointer;font-size:13px;transition:background .1s}.currency-opt:hover{background:var(--surface-2)}.currency-opt.active{background:var(--accent-bg);color:var(--accent)}.currency-opt-sym{font-weight:700;min-width:26px;font-size:12px;color:var(--text-3)}.currency-opt.active .currency-opt-sym{color:var(--accent)}.currency-opt-code{font-weight:600}.currency-opt-name{color:var(--text-3);font-size:12px}.li-table{width:100%;overflow-x:auto}.li-grid{display:grid;grid-template-columns:1fr 80px 100px 100px 34px;min-width:480px}.li-head>div{padding:8px 10px;background:var(--surface-2);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--text-3);border-bottom:1px solid var(--border)}.li-row>*{border-bottom:1px solid var(--border)}.li-row input{border:1px solid transparent;border-radius:4px;padding:8px 9px;font-size:13px;background:transparent;width:100%}.li-row input:focus{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px #2563eb14;z-index:1;position:relative}.li-row input:hover:not(:focus){background:var(--surface-2)}.li-amount-cell{display:flex;align-items:center;padding:8px 10px;font-size:13px;font-weight:500;font-variant-numeric:tabular-nums}.li-action-cell{display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border)}.li-delete-btn{background:none;border:none;cursor:pointer;width:26px;height:26px;border-radius:5px;color:var(--text-4);display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s;font-size:14px}.li-delete-btn:hover{color:var(--danger);background:var(--danger-bg)}.li-add-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:9px;border:1.5px dashed #bfdbfe;border-radius:0 0 var(--radius-sm) var(--radius-sm);background:var(--accent-bg);color:var(--accent);font-size:12.5px;font-weight:500;cursor:pointer;transition:background .15s;font-family:inherit}.li-add-btn:hover{background:#dbeafe}.totals-panel{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.totals-row{display:flex;justify-content:space-between;align-items:center;padding:9px 14px;border-bottom:1px solid var(--border);font-size:13px}.totals-row:last-child{border-bottom:none}.totals-row-label{color:var(--text-3)}.totals-row-val{font-weight:500;font-variant-numeric:tabular-nums}.totals-grand{background:var(--text);color:#fff;display:flex;justify-content:space-between;align-items:center;padding:12px 16px;font-weight:700}.totals-grand-label{font-size:13px;text-transform:uppercase;letter-spacing:.5px}.totals-grand-val{font-size:18px;font-variant-numeric:tabular-nums}.history-table{width:100%;border-collapse:collapse}.history-table th{text-align:left;padding:10px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);background:var(--surface-2);border-bottom:1px solid var(--border)}.history-table td{padding:13px 16px;font-size:13.5px;border-bottom:1px solid var(--border);vertical-align:middle}.history-table tr:last-child td{border-bottom:none}.history-table tbody tr:hover td{background:var(--surface-2)}.history-client-name{font-weight:600;color:var(--text)}.history-client-email{font-size:12px;color:var(--text-3);margin-top:1px}.history-amount{font-weight:600;font-variant-numeric:tabular-nums}.history-actions{display:flex;gap:6px;align-items:center;justify-content:flex-end}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card{padding:18px 20px}.stat-label{font-size:11.5px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.4px;margin-bottom:8px}.stat-value{font-size:24px;font-weight:800;color:var(--text);font-variant-numeric:tabular-nums}.stat-sub{font-size:11.5px;color:var(--text-3);margin-top:2px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;text-align:center}.empty-icon{font-size:48px;line-height:1;margin-bottom:16px}.empty-title{font-size:17px;font-weight:700;color:var(--text);margin-bottom:6px}.empty-desc{font-size:13.5px;color:var(--text-3);max-width:320px;line-height:1.6}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:500;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:420px;animation:slideUp .18s ease}@keyframes slideUp{0%{transform:translateY(10px);opacity:.5}to{transform:translateY(0);opacity:1}}.modal-header{padding:18px 20px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-weight:700;font-size:15px}.modal-body{padding:18px 20px}.modal-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:1000}.toast{background:var(--text);color:#fff;padding:11px 16px;border-radius:8px;font-size:13px;font-weight:500;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:8px;animation:toastIn .2s ease;max-width:320px}@keyframes toastIn{0%{transform:translateY(10px);opacity:0}to{transform:none;opacity:1}}.toast-success{background:var(--success)}.toast-error{background:var(--danger)}#pdf-render-target{position:fixed;left:-9999px;top:0;width:794px;background:#fff;pointer-events:none;z-index:-1}#invoice-doc{width:794px;min-height:1000px;background:#fff;padding:52px 60px;font-size:13px;color:#111827;line-height:1.55;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.doc-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:36px}.doc-logo img{max-height:72px;max-width:180px;object-fit:contain}.doc-logo-name{font-size:20px;font-weight:800;color:#111827}.doc-title-block{text-align:right}.doc-title{font-size:30px;font-weight:900;color:#111827;text-transform:uppercase;letter-spacing:3px;margin-bottom:12px}.doc-meta{display:grid;grid-template-columns:auto auto;gap:2px 14px;text-align:right}.doc-meta-lbl{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#9ca3af}.doc-meta-val{font-size:13px;font-weight:500;color:#374151}.doc-parties{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-bottom:32px}.doc-party-lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#9ca3af;margin-bottom:5px}.doc-party-name{font-size:15px;font-weight:700;color:#111827;margin-bottom:2px}.doc-party-info{font-size:12px;color:#6b7280;white-space:pre-wrap}.doc-table{width:100%;border-collapse:collapse;margin-bottom:20px}.doc-table thead tr{background:#111827}.doc-table thead th{padding:10px 12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#fff}.doc-table thead th:nth-child(n+2){text-align:center}.doc-table thead th:last-child{text-align:right}.doc-table tbody tr{border-bottom:1px solid #f3f4f6}.doc-table tbody tr:nth-child(2n){background:#f9fafb}.doc-table tbody td{padding:10px 12px;font-size:13px}.doc-table tbody td:nth-child(n+2){text-align:center}.doc-table tbody td:last-child{text-align:right;font-weight:500}.doc-bottom{display:grid;grid-template-columns:1fr 260px;gap:28px;margin-top:6px}.doc-notes-lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#9ca3af;margin-bottom:5px}.doc-notes-text{font-size:12px;color:#6b7280;white-space:pre-wrap;line-height:1.6}.doc-totals-row{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px solid #f3f4f6;font-size:13px}.doc-totals-row:last-of-type{border-bottom:none}.doc-totals-lbl{color:#6b7280}.doc-totals-val{font-weight:500;font-variant-numeric:tabular-nums}.doc-grand{display:flex;justify-content:space-between;background:#111827;color:#fff;padding:11px 14px;border-radius:6px;margin-top:8px}.doc-grand-lbl{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.doc-grand-val{font-size:17px;font-weight:800;font-variant-numeric:tabular-nums}.doc-footer{margin-top:40px;padding-top:14px;border-top:1px solid #e5e7eb;text-align:center;font-size:11px;color:#9ca3af}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#9ca3af}@media (max-width: 1024px){.stats-row{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.sidebar{position:fixed;top:0;left:0;bottom:0;transform:translate(-100%)}.sidebar.open{transform:translate(0);box-shadow:var(--shadow-lg)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:45}.sidebar-overlay.open{display:block}.hamburger{display:flex}.page-body{padding:20px 16px}.topbar{padding:0 16px}.top-ad-wrap{padding:12px 16px 0}.sidebar-ad-wrap{padding:8px 10px 10px}.content-ad-wrap{margin-bottom:16px}.ad-slot-banner .ad-slot-box{min-height:100px}.stats-row{grid-template-columns:1fr 1fr;gap:10px}.grid-2,.grid-3{grid-template-columns:1fr}.history-table th:nth-child(3),.history-table td:nth-child(3){display:none}.topbar-right .btn-ghost{display:none}}@media (max-width: 480px){.stats-row{grid-template-columns:1fr}.history-table th:nth-child(4),.history-table td:nth-child(4){display:none}.ad-slot-label{font-size:9.5px}}
