:root{--primary: #4f6ef7;--primary-light: #eef1fe;--primary-dark: #3b54d4;--success: #22c55e;--success-light: #f0fdf4;--warning: #f59e0b;--warning-light: #fffbeb;--danger: #ef4444;--danger-light: #fef2f2;--info: #3b82f6;--purple: #8b5cf6;--purple-light: #f5f3ff;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--sidebar-bg: #0f172a;--sidebar-w: 250px;--header-h: 64px;--radius: 10px;--radius-sm: 6px;--radius-lg: 16px;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.1), 0 2px 4px -1px rgba(0,0,0,.06);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.1), 0 4px 6px -2px rgba(0,0,0,.05)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{-webkit-font-smoothing:antialiased}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--gray-50);color:var(--gray-800);line-height:1.5}a{text-decoration:none;color:inherit}ul,ol{list-style:none}button{font-family:inherit}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar-brand{display:flex;align-items:center;gap:12px;padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.08)}.brand-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--primary),#818cf8);border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.2rem;color:#fff}.brand-name{font-weight:700;font-size:1.1rem;color:#fff}.brand-sub{font-size:.7rem;color:var(--gray-400);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.sidebar-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:8px;font-size:.9rem;font-weight:500;color:var(--gray-400);transition:all .2s}.nav-item:hover{color:#fff;background:#ffffff0f}.nav-item.active{color:#fff;background:var(--primary)}.sidebar-footer{padding:16px 20px;border-top:1px solid rgba(255,255,255,.08)}.sidebar-footer-text{font-size:.7rem;color:var(--gray-500)}.main-content{flex:1;margin-left:var(--sidebar-w);display:flex;flex-direction:column;min-height:100vh}.main-header{height:var(--header-h);background:#fff;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;padding:0 32px;position:sticky;top:0;z-index:50}.page-title{font-size:1.15rem;font-weight:700;color:var(--gray-900)}.main-body{flex:1;padding:32px}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);font-weight:600;font-size:.875rem;border:1.5px solid transparent;cursor:pointer;transition:all .2s;white-space:nowrap;background:none}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark)}.btn-success{background:var(--success);color:#fff;border-color:var(--success)}.btn-success:hover{background:#16a34a;border-color:#16a34a}.btn-warning{background:var(--warning);color:#fff;border-color:var(--warning)}.btn-warning:hover{background:#d97706}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover{background:#dc2626}.btn-outline{background:#fff;color:var(--gray-700);border-color:var(--gray-300)}.btn-outline:hover{border-color:var(--primary);color:var(--primary)}.btn-ghost{background:transparent;color:var(--gray-600)}.btn-ghost:hover{background:var(--gray-100)}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-lg{padding:12px 28px;font-size:.95rem}.btn-icon{padding:8px}.btn:disabled{opacity:.5;cursor:not-allowed}.card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);overflow:hidden}.card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--gray-100)}.card-header h2{font-size:1rem;font-weight:700}.card-body{padding:24px}.card-body.flush{padding:0}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:12px 16px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);background:var(--gray-50);border-bottom:1px solid var(--gray-200)}.data-table td{padding:14px 16px;font-size:.875rem;border-bottom:1px solid var(--gray-100);vertical-align:middle}.data-table tbody tr{transition:background .15s}.data-table tbody tr:hover{background:var(--gray-50)}.data-table tbody tr:last-child td{border-bottom:none}.table-actions{display:flex;gap:6px}.empty-state{text-align:center;padding:48px 24px;color:var(--gray-400)}.empty-state svg{margin-bottom:12px;color:var(--gray-300)}.empty-state p{font-size:.95rem;margin-bottom:16px}.form-group{margin-bottom:20px}.form-label{display:block;font-size:.8rem;font-weight:600;color:var(--gray-600);margin-bottom:6px;text-transform:uppercase;letter-spacing:.03em}.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;border:1.5px solid var(--gray-300);border-radius:var(--radius-sm);font-size:.9rem;font-family:inherit;color:var(--gray-800);background:#fff;transition:border-color .2s,box-shadow .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f6ef71f}.form-textarea{resize:vertical;min-height:80px}.notes-field-header{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:12px 20px;margin-bottom:6px}.notes-field-header>.form-label{margin-bottom:0}.notes-template-picker{display:flex;flex-direction:column;align-items:stretch;min-width:min(100%,240px)}.notes-template-label{margin-bottom:4px;font-size:.72rem}.notes-template-select{max-width:280px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.form-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:16px}.sync-error-banner{display:block;max-width:min(520px,92vw);font-size:.8rem;font-weight:500;line-height:1.35;color:var(--danger);word-break:break-word}.sync-error-banner strong{font-weight:700;display:block;margin-bottom:2px}.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.badge-draft{background:var(--gray-100);color:var(--gray-600)}.badge-sent{background:var(--primary-light);color:var(--primary)}.badge-converted{background:var(--purple-light);color:var(--purple)}.badge-paid{background:var(--success-light);color:var(--success)}.badge-overdue{background:var(--danger-light);color:var(--danger)}.badge-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.page-header h2{font-size:1.1rem;font-weight:700}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:32px}.stat-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);padding:20px 24px}.stat-card-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);margin-bottom:8px}.stat-card-value{font-size:1.75rem;font-weight:800;color:var(--gray-900)}.stat-card-sub{font-size:.8rem;color:var(--gray-400);margin-top:4px}.doc-editor{display:grid;grid-template-columns:1fr 380px;gap:24px;align-items:start}.doc-preview-panel{position:sticky;top:calc(var(--header-h) + 32px)}.doc-top-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:16px}.doc-top-left{display:flex;align-items:center;gap:16px}.back-link{display:inline-flex;align-items:center;gap:6px;font-size:.875rem;font-weight:500;color:var(--gray-500);transition:color .2s;cursor:pointer;background:none;border:none}.back-link:hover{color:var(--primary)}.doc-number{font-size:1.1rem;font-weight:700;color:var(--gray-900)}.doc-top-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:10px}.client-info-card{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-sm);padding:14px 16px;margin-top:8px}.client-info-card .client-name-display{font-weight:600;color:var(--gray-900);margin-bottom:4px}.client-info-card .client-address-display{font-size:.85rem;color:var(--gray-500);line-height:1.5}.line-items-section{margin-top:24px}.line-items-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.line-items-header h3{font-size:.95rem;font-weight:700}.line-items-table{width:100%;border-collapse:collapse}.line-items-table th{text-align:left;padding:10px 12px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--gray-500);background:var(--gray-50);border-bottom:1.5px solid var(--gray-200)}.line-items-table td{padding:8px 12px;vertical-align:middle;border-bottom:1px solid var(--gray-100)}.line-items-table .col-service{width:28%}.line-items-table .col-rate{width:13%}.line-items-table .col-qty{width:10%}.line-items-table .col-markup{width:11%}.line-items-table .col-vat{width:6%;text-align:center}.line-items-table .col-hs{width:8%;text-align:center}.line-items-table .col-total{width:14%;text-align:right}.line-items-table .col-action{width:6%;text-align:center}.line-items-table .form-input,.line-items-table .form-select{padding:8px 10px;font-size:.85rem}.line-total{font-weight:600;text-align:right;color:var(--gray-900);font-size:.9rem}.line-checkbox{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}.remove-btn{background:none;border:none;color:var(--gray-400);cursor:pointer;padding:4px;border-radius:4px;display:flex;transition:all .2s}.remove-btn:hover{color:var(--danger);background:var(--danger-light)}.line-items-empty{text-align:center;padding:32px;color:var(--gray-400);font-size:.9rem}.doc-totals{display:flex;flex-direction:column;align-items:flex-end;gap:6px;padding:16px 12px;border-top:1.5px solid var(--gray-200)}.total-row{display:flex;gap:24px;font-size:.9rem}.total-row .total-label{color:var(--gray-500);min-width:120px;text-align:right}.total-row .total-value{font-weight:600;color:var(--gray-900);min-width:100px;text-align:right}.total-row.grand-total{padding-top:8px;border-top:1.5px solid var(--gray-200);font-size:1rem}.total-row.grand-total .total-value{font-weight:800;font-size:1.1rem}.total-row.markup-row .total-label,.total-row.markup-row .total-value{color:var(--success);font-size:.8rem}.total-row.tax-row .total-label,.total-row.tax-row .total-value{color:var(--info);font-size:.85rem}.tax-section{border-top:1px solid var(--gray-100);padding-top:20px}.tax-list{display:flex;flex-direction:column;gap:10px;margin-top:8px}.tax-row-item{display:grid;grid-template-columns:1fr 140px auto;gap:10px;align-items:center}.tax-rate-input{position:relative}.tax-rate-input .form-input{padding-right:30px}.tax-rate-suffix{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:.85rem;font-weight:600;color:var(--gray-400);pointer-events:none}.preview-total-row.tax .p-label{color:var(--gray-500);font-size:.78rem}.preview-total-row.tax .p-value{font-size:.8rem}.estimate-picker{max-width:900px}.picker-header{text-align:center;margin-bottom:32px;padding:32px 24px 0}.picker-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;background:var(--primary-light);color:var(--primary);border-radius:16px;margin-bottom:16px}.picker-header h2{font-size:1.3rem;font-weight:800;color:var(--gray-900);margin-bottom:8px}.picker-header p{font-size:.9rem;color:var(--gray-500);max-width:480px;margin:0 auto}.picker-empty{text-align:center;padding:48px 24px;color:var(--gray-400)}.picker-empty p{margin-bottom:16px;font-size:.95rem}.doc-preview{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);overflow:hidden}.preview-header{padding:14px 20px;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between}.preview-header h3{font-size:.85rem;font-weight:700;color:var(--gray-600);text-transform:uppercase;letter-spacing:.04em}.preview-body{padding:28px 24px}.preview-brand{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:20px;border-bottom:2px solid var(--primary)}.preview-brand-name{font-size:1.1rem;font-weight:800;color:var(--gray-900)}.preview-doc-type{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--primary)}.preview-meta{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}.preview-meta-group h4{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);margin-bottom:6px}.preview-meta-group p{font-size:.8rem;color:var(--gray-700);line-height:1.6}.preview-meta-group .meta-value{font-weight:600;color:var(--gray-900)}.preview-table{width:100%;border-collapse:collapse;margin-bottom:20px}.preview-table th{text-align:left;padding:8px 10px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--gray-500);border-bottom:1.5px solid var(--gray-200)}.preview-table th:last-child,.preview-table td:last-child{text-align:right}.preview-table td{padding:10px;font-size:.8rem;color:var(--gray-700);border-bottom:1px solid var(--gray-100)}.preview-totals{display:flex;flex-direction:column;align-items:flex-end;gap:4px;padding-top:8px}.preview-total-row{display:flex;gap:16px;font-size:.8rem}.preview-total-row .p-label{color:var(--gray-500);min-width:80px;text-align:right}.preview-total-row .p-value{font-weight:600;min-width:80px;text-align:right}.preview-total-row.grand{padding-top:6px;border-top:1.5px solid var(--gray-200);margin-top:2px}.preview-total-row.grand .p-label{font-weight:700;color:var(--gray-700)}.preview-total-row.grand .p-value{font-weight:800;font-size:.95rem;color:var(--gray-900)}.preview-notes{margin-top:20px;padding-top:16px;border-top:1px solid var(--gray-100)}.preview-notes h4{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);margin-bottom:6px}.preview-notes p{font-size:.8rem;color:var(--gray-600);line-height:1.6}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;animation:fadeIn .15s ease}.modal-panel{background:#fff;border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--gray-100)}.modal-header h3{font-size:1rem;font-weight:700}.modal-close{background:none;border:none;color:var(--gray-400);cursor:pointer;padding:4px;border-radius:6px;display:flex;transition:all .2s}.modal-close:hover{background:var(--gray-100);color:var(--gray-700)}.modal-body{padding:24px}.text-right{text-align:right}.text-center{text-align:center}.text-muted{color:var(--gray-500)}.text-sm{font-size:.85rem}.font-mono{font-family:SF Mono,Fira Code,monospace}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-4{margin-bottom:16px}.gap-row{display:flex;gap:12px;align-items:center}.clickable-row{cursor:pointer}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media print{.sidebar,.main-header,.doc-form-panel,.doc-top-bar,.preview-header,.btn{display:none!important}.main-content{margin-left:0!important}.doc-editor{grid-template-columns:1fr!important}.doc-preview-panel{position:static!important}.doc-preview{border:none!important;box-shadow:none!important}.main-body{padding:0!important}}@media(max-width:1280px){.doc-editor{grid-template-columns:1fr}.doc-preview-panel{position:static}}@media(max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr}}@media(max-width:768px){.sidebar{display:none}.main-content{margin-left:0}.stats-grid,.form-row,.form-row-3{grid-template-columns:1fr}.line-items-table{font-size:.8rem}}
