:root{--ink: #0f0e0c;--ink-muted: #5c5a54;--ink-faint: #9b9890;--paper: #faf9f6;--paper-alt: #f2f0eb;--paper-card: #ffffff;--line: #e5e2da;--line-strong: #ccc9bf;--accent: #1a3a5c;--accent-light: #e8eef5;--accent-mid: #4a7aaa;--gold: #b8860b;--gold-light: #fdf6e3;--success: #2d6a4f;--success-bg: #e8f5ee;--danger: #9b1c1c;--danger-bg: #fef2f2;--warning: #92400e;--warning-bg: #fffbeb;--purple: #5b21b6;--purple-bg: #f3f0ff;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);--shadow-lg: 0 20px 40px rgba(0,0,0,.1), 0 8px 16px rgba(0,0,0,.06);--r: 10px;--r-sm: 6px;--r-lg: 16px}*{margin:0;padding:0;box-sizing:border-box}#root{width:100%;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}html{width:100%;height:100%}body{font-family:DM Sans,sans-serif;background:var(--paper);color:var(--ink);font-size:14px;line-height:1.6;min-height:100vh;min-height:100dvh;width:100%;display:flex;flex-direction:column;overflow-x:hidden}#app-shell{width:100%;min-height:100vh;min-height:100dvh;flex:1}.serif{font-family:"DM Serif Display",serif}.sidebar{width:220px;min-height:100vh;background:var(--accent);display:flex;flex-direction:column;position:fixed;top:0;left:0;z-index:100;padding:0 0 24px}.sidebar-logo{padding:24px 20px 20px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:8px}.sidebar-logo .brand-logo-wrap{background:#fff;border-radius:8px;padding:8px 10px;display:inline-block;line-height:0}.sidebar-logo .wordmark{font-family:"DM Serif Display",serif;font-size:20px;color:#fff;letter-spacing:-.3px}.sidebar-logo .tagline{font-size:11px;color:#ffffff80;letter-spacing:.5px;margin-top:2px}.nav-section{padding:6px 12px}.nav-label{font-size:10px;letter-spacing:1.2px;text-transform:uppercase;color:#ffffff59;padding:8px 8px 4px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;cursor:pointer;color:#ffffffa6;font-size:13.5px;font-weight:400;transition:all .15s;margin-bottom:1px;border:none;background:none;width:100%;text-align:left}.nav-item i{width:18px;font-size:15px;text-align:center}.nav-item:hover{background:#ffffff14;color:#fff}.nav-item.active{background:#ffffff26;color:#fff;font-weight:500}.sidebar-footer{margin-top:auto;padding:16px 20px 0;border-top:1px solid rgba(255,255,255,.1)}.agency-badge{display:flex;align-items:center;gap:10px}.agency-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#4a7aaa,#b8860b);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:#fff;flex-shrink:0}.agency-name{font-size:12.5px;color:#fffc;font-weight:500}.agency-role{font-size:11px;color:#fff6}.db-loading{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#faf9f6eb;display:flex;align-items:center;justify-content:center}.db-loading.hidden{display:none}.db-loading-inner{display:flex;align-items:center;gap:12px;font-size:14px;color:var(--accent);font-weight:500}.db-loading-inner i{font-size:18px}.main{margin-left:220px;width:calc(100% - 220px);max-width:calc(100vw - 220px);flex:1;display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}.topbar{background:var(--paper-card);border-bottom:1px solid var(--line);padding:14px 28px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;width:100%}.topbar-title{font-size:17px;font-weight:600;color:var(--ink)}.topbar-sub{font-size:12.5px;color:var(--ink-muted)}.topbar-actions{display:flex;gap:10px;align-items:center}.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:var(--r-sm);font-size:13px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all .15s;font-family:inherit}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:#0f2a44;border-color:#0f2a44}.btn-outline{background:transparent;color:var(--ink);border-color:var(--line-strong)}.btn-outline:hover{background:var(--paper-alt)}.btn-gold{background:var(--gold);color:#fff;border-color:var(--gold)}.btn-gold:hover{background:#9a7209}.btn-danger{background:var(--danger);color:#fff}.btn-sm{padding:5px 11px;font-size:12px}.btn-icon{padding:7px 10px}.content{padding:24px 28px;flex:1;width:100%;max-width:100%}.view{display:none;width:100%}.view.active{display:block}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;width:100%}.stat-card{background:var(--paper-card);border:1px solid var(--line);border-radius:var(--r);padding:18px 20px;box-shadow:var(--shadow-sm)}.stat-label{font-size:12px;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.7px}.stat-value{font-size:26px;font-weight:600;margin:4px 0 6px;letter-spacing:-.5px;color:var(--ink)}.stat-delta{font-size:12px;display:flex;align-items:center;gap:4px}.stat-delta.up{color:var(--success)}.stat-delta.down{color:var(--danger)}.stat-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;float:right;margin-top:-4px}.card{background:var(--paper-card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden;width:100%}.card-header{padding:16px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:15px;font-weight:600}.filter-bar{display:flex;gap:10px;align-items:center;padding:14px 20px;border-bottom:1px solid var(--line);background:var(--paper)}.search-box{display:flex;align-items:center;gap:8px;background:var(--paper-card);border:1px solid var(--line-strong);border-radius:var(--r-sm);padding:7px 12px;flex:1;max-width:300px}.search-box i{color:var(--ink-faint);font-size:13px}.search-box input{border:none;background:none;outline:none;font-size:13px;font-family:inherit;color:var(--ink);width:100%}select.filter-select{background:var(--paper-card);border:1px solid var(--line-strong);border-radius:var(--r-sm);padding:7px 10px;font-size:13px;font-family:inherit;color:var(--ink);cursor:pointer;outline:none}table{width:100%;border-collapse:collapse}thead th{padding:11px 16px;text-align:left;font-size:11.5px;font-weight:600;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.6px;background:var(--paper);border-bottom:1px solid var(--line);white-space:nowrap}tbody tr{border-bottom:1px solid var(--line);transition:background .1s;cursor:pointer}tbody tr:hover{background:var(--paper)}tbody tr:last-child{border-bottom:none}tbody td{padding:13px 16px;font-size:13.5px}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:11.5px;font-weight:500;white-space:nowrap}.badge-dot{width:5px;height:5px;border-radius:50%}.badge-paid{background:var(--success-bg);color:var(--success)}.badge-paid .badge-dot{background:var(--success)}.badge-unpaid{background:var(--warning-bg);color:var(--warning)}.badge-unpaid .badge-dot{background:#f59e0b}.badge-overdue{background:var(--danger-bg);color:var(--danger)}.badge-overdue .badge-dot{background:var(--danger)}.badge-draft{background:var(--paper-alt);color:var(--ink-muted)}.badge-draft .badge-dot{background:var(--ink-faint)}.badge-sent{background:var(--accent-light);color:var(--accent)}.badge-sent .badge-dot{background:var(--accent-mid)}.badge-accepted{background:var(--success-bg);color:var(--success)}.badge-accepted .badge-dot{background:var(--success)}.badge-quote{background:var(--purple-bg);color:var(--purple)}.badge-invoice{background:var(--accent-light);color:var(--accent)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0c1280;z-index:200;display:none;align-items:flex-start;justify-content:center;padding:20px;overflow-y:auto;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-overlay.open{display:flex}.modal{background:var(--paper-card);border-radius:var(--r-lg);width:100%;max-width:860px;box-shadow:var(--shadow-lg);margin:auto;position:relative}.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:17px;font-weight:600}.modal-close{background:none;border:none;cursor:pointer;color:var(--ink-muted);font-size:18px;padding:4px 6px;border-radius:4px}.modal-close:hover{background:var(--paper-alt);color:var(--ink)}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:10px;background:var(--paper);border-radius:0 0 var(--r-lg) var(--r-lg)}.form-grid{display:grid;gap:16px}.form-grid-2{grid-template-columns:1fr 1fr}.form-grid-3{grid-template-columns:1fr 1fr 1fr}.form-group{display:flex;flex-direction:column;gap:5px}.form-label{font-size:12.5px;font-weight:500;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.4px}.form-control{background:var(--paper);border:1px solid var(--line-strong);border-radius:var(--r-sm);padding:8px 12px;font-size:13.5px;font-family:inherit;color:var(--ink);outline:none;transition:border-color .15s;width:100%}.form-control:focus{border-color:var(--accent-mid);box-shadow:0 0 0 3px #4a7aaa1f}textarea.form-control{resize:vertical;min-height:80px}select.form-control{cursor:pointer}.section-divider{margin:20px 0 16px;padding-bottom:8px;border-bottom:1px solid var(--line);font-size:13px;font-weight:600;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.7px}.line-items-table{width:100%;border-collapse:collapse}.line-items-table th{padding:8px 10px;font-size:11.5px;font-weight:600;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.6px;background:var(--paper-alt);border:1px solid var(--line);text-align:left}.line-items-table td{padding:6px;border:1px solid var(--line);vertical-align:middle}.line-items-table input,.line-items-table select{border:none;background:transparent;outline:none;font-size:13px;font-family:inherit;width:100%;padding:4px}.line-items-table input:focus{background:var(--accent-light);border-radius:4px}.line-items-table tr:hover{background:var(--paper)}.li-desc{min-width:200px}.li-num{width:80px;text-align:right}.li-num input{text-align:right}.li-del{width:36px;text-align:center}.del-btn{background:none;border:none;cursor:pointer;color:var(--ink-faint);font-size:14px;padding:4px;border-radius:4px;transition:all .15s}.del-btn:hover{color:var(--danger);background:var(--danger-bg)}.totals-panel{display:flex;justify-content:flex-end;margin-top:12px}.totals-inner{width:280px}.totals-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:13.5px;border-bottom:1px solid var(--line)}.totals-row:last-child{border-bottom:none}.totals-row.total-final{font-weight:600;font-size:16px;border-top:2px solid var(--ink);padding-top:10px;margin-top:4px}.totals-label{color:var(--ink-muted)}.totals-value{font-weight:500}.preview-modal{max-width:720px}.preview-modal.quote-preview-modal{max-width:860px}.preview-modal .modal-body.quote-preview-body{max-height:75vh;overflow-y:auto;padding-top:8px}.invoice-preview{font-family:DM Sans,sans-serif;padding:44px 48px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);border-top:4px solid var(--accent);-webkit-print-color-adjust:exact;print-color-adjust:exact;box-shadow:var(--shadow-md)}.preview-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:36px;padding-bottom:24px;border-bottom:2px solid var(--accent)}.preview-logo{font-family:"DM Serif Display",serif;font-size:24px;color:var(--accent)}.brand-logo{object-fit:contain;display:block;max-width:100%;height:auto}.brand-logo--sidebar{width:168px}.brand-logo--auth{width:min(220px,100%);margin:0 auto 18px;background:var(--accent);padding:18px 26px;border-radius:var(--r-lg);box-shadow:var(--shadow-md);box-sizing:content-box}.brand-logo--preview{width:180px;margin-bottom:14px;background:var(--accent);padding:14px 20px;border-radius:var(--r);box-sizing:content-box}.brand-logo--quote{width:min(260px,100%);margin:0 auto 18px;background:var(--accent);padding:18px 28px;border-radius:var(--r-lg);box-shadow:var(--shadow-sm);box-sizing:content-box}.preview-logo-sub{font-size:11px;color:var(--ink-muted);letter-spacing:.5px}.preview-legal-name{font-size:13px;font-weight:600;color:var(--accent);margin:2px 0;letter-spacing:.2px}.preview-legal-name--sm{font-size:12px;margin:1px 0 3px}.preview-doc-type{font-family:"DM Serif Display",serif;font-size:32px;color:var(--accent);text-align:right;letter-spacing:1px}.preview-doc-num{font-size:13px;color:var(--ink-muted);text-align:right}.preview-meta{display:grid;grid-template-columns:1fr 1fr 1fr;gap:24px;margin-bottom:28px;padding:20px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r)}.preview-meta-label{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--ink-muted);margin-bottom:4px}.preview-meta-val{font-size:13.5px;font-weight:500;color:var(--ink)}.preview-bill-section{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:28px}.preview-section-label{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--ink-muted);margin-bottom:6px}.preview-client-name{font-size:15px;font-weight:600;margin-bottom:2px}.preview-client-detail{font-size:13px;color:var(--ink-muted);line-height:1.6}.preview-table{width:100%;border-collapse:collapse;margin-bottom:20px;border-radius:var(--r-sm);overflow:hidden}.preview-table th{padding:11px 12px;font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:var(--accent);color:#fff;text-align:left}.preview-table td{padding:11px 12px;border-bottom:1px solid var(--line);font-size:13px;vertical-align:top}.preview-table tbody tr:nth-child(2n) td{background:var(--paper)}.preview-table tr:last-child td{border-bottom:none}.preview-table td.num{text-align:right}.preview-totals{display:flex;justify-content:flex-end}.preview-totals-box{width:280px;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm)}.preview-total-row{display:flex;justify-content:space-between;padding:9px 16px;border-bottom:1px solid var(--line);font-size:13px}.preview-total-row:last-child{border-bottom:none;background:var(--accent);color:#fff;font-weight:600}.preview-footer{margin-top:32px;padding-top:20px;border-top:1px solid var(--line)}.preview-terms{font-size:12px;color:var(--ink-muted)}.preview-stamp{display:inline-block;border:3px solid;border-radius:4px;padding:4px 12px;font-size:22px;font-weight:700;transform:rotate(-8deg);letter-spacing:3px;margin-top:16px}.stamp-paid{border-color:var(--success);color:var(--success)}.stamp-overdue{border-color:var(--danger);color:var(--danger)}.quote-document{font-family:DM Sans,sans-serif}.quote-page{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:44px 48px;margin-bottom:20px;min-height:820px;box-sizing:border-box;position:relative;-webkit-print-color-adjust:exact;print-color-adjust:exact;box-shadow:var(--shadow-md)}.quote-page:last-child{margin-bottom:0}.quote-page-footer{position:absolute;bottom:28px;left:48px;right:48px;display:flex;justify-content:space-between;align-items:center;font-size:10px;color:var(--ink-muted);border-top:1px solid var(--line);padding-top:10px}.quote-cover-brand{font-family:"DM Serif Display",serif;font-size:28px;color:var(--accent);margin-bottom:6px}.quote-cover-tagline{font-size:13px;color:var(--ink-muted);letter-spacing:.3px}.quote-cover-legal{font-size:15px;font-weight:600;color:var(--accent);margin-top:4px;letter-spacing:.2px}.quote-cover-legal-gst{font-size:12px;color:var(--ink-muted);margin-top:2px;letter-spacing:.3px}.quote-cover-title{font-family:"DM Serif Display",serif;font-size:44px;color:var(--accent);margin:36px 0 8px;letter-spacing:-.5px}.quote-cover-meta{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:32px 0;padding:24px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r)}.quote-label{font-size:10px;text-transform:uppercase;letter-spacing:.7px;color:var(--ink-muted);margin-bottom:4px}.quote-val{font-size:14px;font-weight:500;color:var(--ink);line-height:1.5}.quote-intro{font-size:13.5px;color:var(--ink-muted);line-height:1.75;margin:28px 0;padding:20px 24px;border-left:3px solid var(--accent);background:var(--paper);border-radius:0 8px 8px 0}.quote-section-title{font-family:"DM Serif Display",serif;font-size:22px;color:var(--ink);margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid var(--accent)}.quote-service-card{border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:var(--r);padding:22px 24px;margin-bottom:18px;page-break-inside:avoid;box-shadow:var(--shadow-sm)}.quote-service-card:last-child{margin-bottom:0}.quote-service-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:12px}.quote-service-name{font-size:17px;font-weight:600;color:var(--ink)}.quote-service-price{font-size:18px;font-weight:700;color:var(--accent);white-space:nowrap}.quote-category-badge{display:inline-block;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:var(--accent);color:#fff;padding:3px 10px;border-radius:4px;margin-bottom:8px}.quote-service-ref{font-size:11px;color:var(--ink-muted);margin-top:6px}.quote-service-price-block{text-align:right;flex-shrink:0}.quote-service-price-sub{font-size:11px;color:var(--ink-muted);margin-top:4px}.quote-detail-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:10px 16px;margin:14px 0 16px;padding:12px 14px;background:var(--paper);border-radius:8px;border:1px solid var(--line)}.quote-detail-meta-item{display:flex;flex-direction:column;gap:2px}.quote-detail-meta-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--ink-muted)}.quote-detail-meta-value{font-size:12px;font-weight:500;color:var(--ink)}.quote-service-overview{margin-bottom:14px}.quote-service-deliverables{margin-bottom:12px}.quote-service-section{margin-bottom:14px}.quote-service-note{margin:12px 0;padding:10px 12px;background:#fff8e6;border-left:3px solid var(--accent);font-size:12.5px;color:var(--ink);line-height:1.5;border-radius:0 6px 6px 0}.quote-service-desc{font-size:13px;color:var(--ink-muted);line-height:1.65}.quote-service-desc p{margin:0 0 8px}.quote-service-desc p:last-child{margin-bottom:0}.quote-pricing-sub{font-size:11px;color:var(--ink-muted);margin-top:4px;line-height:1.45}.quote-features-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--ink-muted);margin-bottom:8px}.quote-features{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:6px 20px}.quote-features--full{grid-template-columns:1fr;gap:8px}.quote-features li{font-size:12.5px;color:var(--ink);padding-left:18px;position:relative;line-height:1.45}.quote-features li:before{content:"✓";position:absolute;left:0;color:var(--success);font-weight:700;font-size:11px}.quote-billing-tag{display:inline-block;font-size:11px;font-weight:500;color:var(--accent);background:#0f284014;padding:3px 10px;border-radius:4px;margin-top:12px}.quote-offer-box{margin-top:24px;padding:18px 20px;background:linear-gradient(135deg,#0f28400f,#0f284005);border:1px dashed var(--accent);border-radius:8px}.quote-offer-box .quote-label{color:var(--accent)}.quote-terms-list{padding-left:18px;margin:0}.quote-terms-list li{font-size:13px;color:var(--ink-muted);line-height:1.7;margin-bottom:8px}.quote-addon-table{width:100%;border-collapse:collapse;margin-top:12px}.quote-addon-table th,.quote-addon-table td{padding:9px 12px;font-size:12.5px;border-bottom:1px solid var(--line);text-align:left}.quote-addon-table th{background:var(--paper);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.4px}.quote-addon-table td:last-child{text-align:right;font-weight:500}.tab-row{display:flex;gap:2px;background:var(--paper-alt);border-radius:var(--r-sm);padding:3px;width:fit-content;margin-bottom:20px}.tab-btn{padding:7px 18px;border-radius:5px;font-size:13px;font-weight:500;cursor:pointer;border:none;background:transparent;color:var(--ink-muted);font-family:inherit;transition:all .15s}.tab-btn.active{background:var(--paper-card);color:var(--ink);box-shadow:var(--shadow-sm)}.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast{background:var(--ink);color:#fff;padding:12px 18px;border-radius:var(--r-sm);font-size:13.5px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:10px;animation:slideUp .3s ease;max-width:340px}.toast.success{background:var(--success)}.toast.warning{background:#d97706}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.client-name{font-weight:500}.client-company{font-size:12px;color:var(--ink-muted)}.amount{font-weight:600;font-variant-numeric:tabular-nums}.text-right{text-align:right}.empty-state{text-align:center;padding:60px 20px;color:var(--ink-muted)}.empty-state i{font-size:40px;opacity:.3;margin-bottom:14px;display:block}.empty-state h3{font-size:16px;font-weight:500;color:var(--ink);margin-bottom:6px}.action-row{display:flex;gap:6px}.sparkline-row{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap}.sparkline-card{background:var(--paper-card);border:1px solid var(--line);border-radius:var(--r);padding:16px 20px;flex:1;min-width:200px;box-shadow:var(--shadow-sm)}.sparkline-title{font-size:12px;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.7px;margin-bottom:6px}.sparkline-val{font-size:20px;font-weight:600;margin-bottom:10px}@media print{.sidebar,.topbar,.modal-footer,.btn,.mobile-menu-btn,.sidebar-backdrop{display:none!important}.main{margin-left:0}.modal-overlay{position:static;padding:0;background:none;display:block!important}.modal{box-shadow:none;max-width:100%}.modal-header{display:none!important}.quote-preview-body{max-height:none!important;overflow:visible!important;padding:0!important}.quote-page{page-break-after:always;border:none;border-radius:0;min-height:auto;margin:0;padding:18mm 16mm;box-shadow:none}.quote-page:last-child{page-break-after:auto}.quote-service-card{break-inside:avoid}.brand-logo{print-color-adjust:exact;-webkit-print-color-adjust:exact}}.hidden{display:none!important}.auth-screen{width:100%;min-height:100vh;min-height:100dvh;flex:1;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(160deg,var(--accent) 0%,#0f2840 55%,var(--paper) 55%)}.auth-card{width:100%;max-width:420px;background:var(--paper-card);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:36px 32px}.auth-brand{text-align:center;margin-bottom:28px}.auth-brand .serif{font-family:"DM Serif Display",serif;font-size:28px;color:var(--accent);letter-spacing:-.5px}.auth-brand p{font-size:13px;color:var(--ink-muted);margin-top:6px}.auth-tabs,.auth-form{display:none}.btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 16px;border:1px solid var(--line-strong);border-radius:var(--r-sm);background:#fff;color:var(--ink);font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .15s;box-shadow:var(--shadow-sm)}.btn-google:hover:not(:disabled){background:var(--paper-alt);box-shadow:var(--shadow-md)}.btn-google:disabled{opacity:.6;cursor:not-allowed}.btn-google svg{width:20px;height:20px;flex-shrink:0}.auth-error{background:var(--danger-bg);color:var(--danger);padding:10px 12px;border-radius:var(--r-sm);font-size:13px;margin-bottom:16px;display:none}.auth-error.visible{display:block}.auth-pending-icon{width:64px;height:64px;margin:0 auto 20px;background:var(--warning-bg);color:var(--warning);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px}.auth-note{font-size:12px;color:var(--ink-faint);text-align:center;margin-top:20px;line-height:1.5}.logout-btn{margin-top:12px;width:100%;padding:8px 10px;border:1px solid rgba(255,255,255,.2);background:#ffffff0f;color:#ffffffbf;border-radius:var(--r-sm);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .15s}.logout-btn:hover{background:#ffffff1f;color:#fff}.welcome-modal{max-width:440px;text-align:center;overflow:hidden}.welcome-modal-header{background:linear-gradient(135deg,var(--accent) 0%,#2a5280 100%);color:#fff;padding:28px 24px 24px}.welcome-avatar{width:64px;height:64px;border-radius:50%;margin:0 auto 14px;background:#ffffff26;border:2px solid rgba(255,255,255,.35);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:600;overflow:hidden}.welcome-avatar img{width:100%;height:100%;object-fit:cover}.welcome-greeting{font-family:"DM Serif Display",serif;font-size:26px;line-height:1.25;margin-bottom:6px}.welcome-sub{font-size:13px;opacity:.85}.welcome-modal-body{padding:24px 28px 8px}.welcome-quote{font-size:15px;line-height:1.65;color:var(--ink-muted);font-style:italic;padding:16px 18px;background:var(--paper-alt);border-radius:var(--r);border-left:3px solid var(--gold);margin-bottom:8px}.welcome-modal .modal-footer{justify-content:center;padding:16px 24px 24px;background:transparent;border-top:none}.dashboard-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:16px;width:100%}.settings-wrap{max-width:600px}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.table-scroll table{min-width:640px}.dashboard-grid .table-scroll table{min-width:420px}.mobile-menu-btn{display:none;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid var(--line-strong);border-radius:var(--r-sm);background:var(--paper-card);color:var(--ink);cursor:pointer;flex-shrink:0;font-size:16px}.mobile-menu-btn:hover{background:var(--paper-alt)}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0c1273;z-index:99;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.sidebar-backdrop.open{display:block}.topbar-left{display:flex;align-items:center;gap:12px;min-width:0;flex:1}.topbar-text{min-width:0}@media(max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr}.content{padding:20px}.topbar{padding:12px 20px}}@media(max-width:768px){.sidebar{width:min(280px,88vw);transform:translate(-100%);transition:transform .25s ease;box-shadow:var(--shadow-lg)}.sidebar.open{transform:translate(0)}.main{margin-left:0;width:100%;max-width:100%}#app-shell{width:100%}.mobile-menu-btn{display:flex}.topbar{flex-wrap:wrap;gap:12px;padding:12px 16px}.topbar-actions{width:100%;justify-content:flex-end}.topbar-title{font-size:16px}.topbar-sub{font-size:12px}.content{padding:16px}.stats-grid{grid-template-columns:1fr 1fr;gap:12px}.stat-card{padding:14px 16px}.stat-value{font-size:22px}.card-header{flex-wrap:wrap;gap:10px;padding:14px 16px}.filter-bar{flex-wrap:wrap;padding:12px 16px}.search-box{max-width:none;flex:1 1 100%}.tab-row{width:100%;max-width:100%;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tab-row::-webkit-scrollbar{display:none}.tab-btn{white-space:nowrap;flex-shrink:0;padding:7px 14px}.form-grid-2,.form-grid-3{grid-template-columns:1fr}.modal-overlay{padding:12px;align-items:flex-end}.modal{max-width:100%;max-height:92vh;display:flex;flex-direction:column;margin:0;border-radius:var(--r-lg) var(--r-lg) 0 0}.modal-body{padding:16px;overflow-y:auto;flex:1}.modal-header,.modal-footer{padding:14px 16px}.modal-footer{flex-wrap:wrap;justify-content:stretch}.modal-footer .btn{flex:1;justify-content:center;min-width:120px}.line-items-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.line-items-table{min-width:720px}.totals-panel{justify-content:stretch}.totals-inner{width:100%}.preview-header{flex-direction:column;gap:16px}.preview-doc-type{text-align:left!important;font-size:26px}.preview-doc-num{text-align:left!important}.preview-meta{grid-template-columns:1fr;gap:12px;padding:14px}.preview-bill-section{grid-template-columns:1fr;gap:16px}.invoice-preview{padding:20px 16px}.preview-totals-box{width:100%}.action-row{flex-wrap:wrap}.toast-container{left:16px;right:16px;bottom:16px;align-items:stretch}.toast{max-width:none}.auth-screen{padding:16px;align-items:center;background:linear-gradient(180deg,var(--accent) 0%,#0f2840 42%,var(--paper) 42%)}.auth-card{padding:28px 22px;max-width:100%;border-radius:var(--r-lg)}.auth-brand .serif{font-size:24px}.auth-brand p{font-size:12px}.auth-note{font-size:11px;padding:0 4px}.btn-google{padding:14px 16px;font-size:15px;min-height:48px}}@media(max-width:480px){.auth-screen{padding:12px;background:linear-gradient(180deg,var(--accent) 0%,#0f2840 38%,var(--paper) 38%)}.auth-card{padding:24px 18px 28px;box-shadow:var(--shadow-md)}.auth-pending-icon{width:56px;height:56px;font-size:24px}.stats-grid{grid-template-columns:1fr}.stat-icon{float:none;margin:0 0 8px}.topbar-actions .btn{flex:1;justify-content:center;padding:8px 10px;font-size:12px}.card-header .btn{width:100%;justify-content:center}tbody td,thead th{padding:10px 12px;font-size:12.5px}.empty-state{padding:40px 16px}.agency-name{font-size:11.5px}.sidebar-logo .wordmark{font-size:18px}}@media(max-width:768px){.topbar-actions .btn-text{display:none}.topbar-actions .btn{padding:8px 12px}.quote-page{padding:28px 20px;min-height:auto}.quote-cover-meta,.quote-features{grid-template-columns:1fr}.quote-detail-meta{grid-template-columns:1fr 1fr}.quote-service-head{flex-direction:column}.quote-service-price-block{text-align:left;margin-top:10px}}</style> </head>{}
