:root{--color-bg: #f8fafc;--color-bg-elevated: #ffffff;--color-surface: #ffffff;--color-border: #e2e8f0;--color-border-strong: #cbd5e1;--color-text: #0f172a;--color-text-muted: #64748b;--color-text-subtle: #94a3b8;--color-primary: #0ea5e9;--color-primary-hover: #0284c7;--color-primary-light: #e0f2fe;--color-success: #10b981;--color-success-light: #d1fae5;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-error: #ef4444;--color-error-light: #fee2e2;--font-sans: "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08);--header-height: 64px;--sidebar-width: 280px;--content-max: 900px;--ad-banner-height: 90px}[data-theme=dark]{--color-bg: #0f172a;--color-bg-elevated: #1e293b;--color-surface: #1e293b;--color-border: #334155;--color-border-strong: #475569;--color-text: #f1f5f9;--color-text-muted: #94a3b8;--color-text-subtle: #64748b;--color-primary: #38bdf8;--color-primary-hover: #7dd3fc;--color-primary-light: #0c4a6e;--color-success: #34d399;--color-success-light: #064e3b;--color-warning: #fbbf24;--color-warning-light: #451a03;--color-error: #f87171;--color-error-light: #450a0a;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:var(--font-sans);font-size:16px;line-height:1.6;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased}button,input,select,textarea,a.btn{font-family:inherit;font-size:1rem}.ad-zone{min-height:90px;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border:2px dashed var(--color-border-strong);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:.875rem}.ad-zone-banner{height:var(--ad-banner-height)}.ad-zone-sidebar{min-height:250px}.layout{min-height:100vh;display:flex;flex-direction:column}.layout-body{display:flex;flex:1;gap:var(--space-6);padding:var(--space-6);max-width:1400px;margin:0 auto;width:100%}.layout-sidebar{width:var(--sidebar-width);flex-shrink:0;display:flex;flex-direction:column;gap:var(--space-4)}.layout-main{flex:1;min-width:0;max-width:var(--content-max)}.header{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:var(--space-4) var(--space-6)}.header-inner{max-width:1400px;margin:0 auto;display:flex;align-items:center;gap:var(--space-4);flex-wrap:wrap}.header-theme-toggle{margin-left:auto;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);font-size:1.25rem;cursor:pointer;line-height:1}.header-logo{font-size:1.25rem;font-weight:700;color:var(--color-text);text-decoration:none}.header-tagline{margin:var(--space-1) 0 0;font-size:.875rem;color:var(--color-text-muted)}.footer{background:var(--color-surface);border-top:1px solid var(--color-border);padding:var(--space-6);margin-top:auto}.footer-inner{max-width:1400px;margin:0 auto;display:flex;flex-direction:column;gap:var(--space-4)}.footer-links,.footer-meta{display:flex;flex-wrap:wrap;gap:var(--space-3) var(--space-6)}.footer-copy{font-size:.875rem;color:var(--color-text-muted);margin:0;padding-top:var(--space-2);border-top:1px solid var(--color-border)}.footer-link{font-size:.875rem;color:var(--color-primary);text-decoration:none}.footer-link:hover{text-decoration:underline}.nav-sidebar{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-md)}.nav-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin:0 0 var(--space-3);padding:0 var(--space-2)}.nav-list{list-style:none;margin:0;padding:0}.nav-link{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);color:var(--color-text);text-decoration:none;font-size:.9375rem;transition:background .15s}.nav-link:hover{background:var(--color-primary-light);color:var(--color-primary-hover)}.nav-link--active{background:var(--color-primary-light);color:var(--color-primary-hover);font-weight:500}.nav-icon{font-size:1.125rem}.data-disclaimer{font-size:.8125rem;color:var(--color-text-muted);background:var(--color-warning-light);padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);margin:0 0 var(--space-4)}.page{padding-bottom:var(--space-12)}.page-content{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-8);box-shadow:var(--shadow-md)}.page-content--narrow{max-width:720px;margin:0 auto;line-height:1.7}.page-content--narrow h2{font-size:1.25rem;margin:var(--space-8) 0 var(--space-3)}.page-content--narrow ul{margin:var(--space-4) 0;padding-left:var(--space-6)}.page-content--narrow a{color:var(--color-primary);text-decoration:none}.page-content--narrow a:hover{text-decoration:underline}.page-title{font-size:1.75rem;font-weight:700;margin:0 0 var(--space-2)}.page-subtitle{font-size:1rem;color:var(--color-text-muted);margin:0 0 var(--space-8)}.page--home .page-content{padding-top:var(--space-6)}.tool-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--space-4)}.tool-card{display:block;padding:var(--space-5);background:var(--color-bg);border-radius:var(--radius-md);border:1px solid var(--color-border);text-decoration:none;color:inherit;transition:border-color .15s,box-shadow .15s}.tool-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.tool-card-icon{font-size:2rem;display:block;margin-bottom:var(--space-3)}.tool-card-title{font-size:1rem;font-weight:600;margin:0 0 var(--space-1)}.tool-card-desc{font-size:.875rem;color:var(--color-text-muted);margin:0}.invoice-seo-hero{background:linear-gradient(180deg,var(--color-primary-light) 0%,var(--color-bg) 100%);border-radius:var(--radius-lg);padding:var(--space-10) var(--space-8);margin-bottom:var(--space-8);text-align:center}.invoice-seo-hero-value{font-size:1.125rem;font-weight:600;color:var(--color-primary);margin:0 0 var(--space-2)}.invoice-seo-hero-title{font-size:clamp(1.5rem,4vw,2rem);font-weight:700;margin:0 0 var(--space-3);color:var(--color-text)}.invoice-seo-hero-sub{font-size:1rem;color:var(--color-text-muted);max-width:560px;margin:0 auto var(--space-4);line-height:1.6}.invoice-seo-trust{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-2);font-size:.875rem;color:var(--color-text-muted);margin-bottom:var(--space-6)}.invoice-seo-cta{display:inline-block;padding:var(--space-3) var(--space-6);border-radius:var(--radius-md);font-weight:600;text-decoration:none;color:#fff;background:var(--color-primary);transition:background .15s}.invoice-seo-cta:hover{background:var(--color-primary-hover)}.invoice-sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:100;padding:var(--space-3) var(--space-6);background:var(--color-bg);border-top:1px solid var(--color-border);box-shadow:0 -4px 12px #00000014;display:flex;justify-content:center}.invoice-sticky-cta .btn{text-decoration:none}.invoice-seo-content{max-width:720px;margin-top:var(--space-10);padding-top:var(--space-8);border-top:1px solid var(--color-border)}.invoice-seo-section{margin-bottom:var(--space-8)}.invoice-seo-section h2{font-size:1.25rem;font-weight:700;margin:0 0 var(--space-4);color:var(--color-text)}.invoice-seo-list,.invoice-seo-steps{margin:0 0 0 var(--space-6);padding-left:var(--space-4);color:var(--color-text)}.invoice-seo-list li,.invoice-seo-steps li{margin-bottom:var(--space-2);line-height:1.6}.invoice-seo-section p{margin:0 0 var(--space-3);line-height:1.6;color:var(--color-text)}.invoice-seo-faq dl{margin:0}.invoice-seo-faq dt{font-weight:600;margin-top:var(--space-4);margin-bottom:var(--space-1);color:var(--color-text)}.invoice-seo-faq dt:first-of-type{margin-top:0}.invoice-seo-faq dd{margin:0 0 0 var(--space-4);color:var(--color-text-muted);line-height:1.6}.expense-seo-hero{background:linear-gradient(180deg,var(--color-primary-light) 0%,var(--color-bg) 100%);border-radius:var(--radius-lg);padding:var(--space-10) var(--space-8);margin-bottom:var(--space-8);text-align:center}.expense-seo-hero-title{font-size:clamp(1.5rem,4vw,2rem);font-weight:700;margin:0 0 var(--space-3);color:var(--color-text)}.expense-seo-hero-value{font-size:1.125rem;font-weight:600;color:var(--color-primary);margin:0 0 var(--space-2)}.expense-seo-hero-sub{font-size:1rem;color:var(--color-text-muted);max-width:560px;margin:0 auto var(--space-4);line-height:1.6}.expense-seo-trust{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-2);font-size:.875rem;color:var(--color-text-muted);margin-bottom:var(--space-6)}.expense-seo-cta{display:inline-block;padding:var(--space-3) var(--space-6);border-radius:var(--radius-md);font-weight:600;text-decoration:none;color:#fff;background:var(--color-primary);transition:background .15s}.expense-seo-cta:hover{background:var(--color-primary-hover)}.expense-sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:100;padding:var(--space-3) var(--space-6);background:var(--color-bg);border-top:1px solid var(--color-border);box-shadow:0 -4px 12px #00000014;display:flex;justify-content:center}.expense-sticky-cta .btn{text-decoration:none}.expense-seo-content{max-width:720px;margin-top:var(--space-10);padding-top:var(--space-8);border-top:1px solid var(--color-border)}.expense-seo-section{margin-bottom:var(--space-8)}.expense-seo-section h2{font-size:1.25rem;font-weight:700;margin:0 0 var(--space-4);color:var(--color-text)}.expense-seo-section h3{font-size:1rem;font-weight:600;margin:var(--space-4) 0 var(--space-2);color:var(--color-text)}.expense-seo-list,.expense-seo-steps{margin:0 0 0 var(--space-6);padding-left:var(--space-4);color:var(--color-text)}.expense-seo-list li,.expense-seo-steps li{margin-bottom:var(--space-2);line-height:1.6}.expense-seo-section p{margin:0 0 var(--space-3);line-height:1.6;color:var(--color-text)}.expense-seo-faq dl{margin:0}.expense-seo-faq dt{font-weight:600;margin-top:var(--space-4);margin-bottom:var(--space-1);color:var(--color-text)}.expense-seo-faq dt:first-of-type{margin-top:0}.expense-seo-faq dd{margin:0 0 0 var(--space-4);color:var(--color-text-muted);line-height:1.6}.expense-seo-links{margin:0 0 0 var(--space-6);padding-left:var(--space-4);list-style:none;padding-left:0}.expense-seo-links li{margin-bottom:var(--space-2)}.expense-seo-links a{color:var(--color-primary);text-decoration:none}.expense-seo-links a:hover{text-decoration:underline}.tool-seo-hero{background:linear-gradient(180deg,var(--color-primary-light) 0%,var(--color-bg) 100%);border-radius:var(--radius-lg);padding:var(--space-10) var(--space-8);margin-bottom:var(--space-8);text-align:center}.tool-seo-hero-value{font-size:1.125rem;font-weight:600;color:var(--color-primary);margin:0 0 var(--space-2)}.tool-seo-hero-title{font-size:clamp(1.5rem,4vw,2rem);font-weight:700;margin:0 0 var(--space-3);color:var(--color-text)}.tool-seo-hero-sub{font-size:1rem;color:var(--color-text-muted);max-width:560px;margin:0 auto var(--space-4);line-height:1.6}.tool-seo-trust{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-2);font-size:.875rem;color:var(--color-text-muted);margin-bottom:var(--space-6)}.tool-seo-cta{display:inline-block;padding:var(--space-3) var(--space-6);border-radius:var(--radius-md);font-weight:600;text-decoration:none;color:#fff;background:var(--color-primary);transition:background .15s}.tool-seo-cta:hover{background:var(--color-primary-hover)}.tool-sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:100;padding:var(--space-3) var(--space-6);background:var(--color-bg);border-top:1px solid var(--color-border);box-shadow:0 -4px 12px #00000014;display:flex;justify-content:center}.tool-sticky-cta .btn{text-decoration:none}.tool-page{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-8);box-shadow:var(--shadow-md)}.tool-page h1{font-size:1.5rem;font-weight:700;margin:0 0 var(--space-6)}.form-section{margin-bottom:var(--space-8)}.form-section-title{font-size:1rem;font-weight:600;margin:0 0 var(--space-4);padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4);margin-bottom:var(--space-4)}.input-group{margin-bottom:var(--space-4)}.input-label{display:block;font-size:.875rem;font-weight:500;margin-bottom:var(--space-1);color:var(--color-text)}.input{width:100%;padding:var(--space-3) var(--space-4);font-size:1rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);min-height:48px}.input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.input--error{border-color:var(--color-error)}.input-error{font-size:.8125rem;color:var(--color-error);margin-top:var(--space-1);display:block}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-size:1rem;font-weight:500;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s,transform .1s;min-height:48px}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn--primary{background:var(--color-primary);color:#fff}.btn--primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn--secondary{background:var(--color-border);color:var(--color-text)}.btn--secondary:hover:not(:disabled){background:var(--color-border-strong)}.btn--success{background:var(--color-success);color:#fff}.btn--success:hover:not(:disabled){filter:brightness(1.05)}.btn--sm{padding:var(--space-2) var(--space-3);font-size:.875rem;min-height:36px}.btn--lg{padding:var(--space-4) var(--space-6);font-size:1.0625rem}.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999}.toast{padding:12px 20px;border-radius:var(--radius-md);font-size:.9375rem;font-weight:500;box-shadow:var(--shadow-lg);animation:toast-in .3s ease}.toast--success{background:var(--color-success);color:#fff}.toast--info{background:var(--color-primary);color:#fff}.toast--error{background:var(--color-error);color:#fff}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.confirm-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9998;padding:16px;animation:fade-in .2s ease}.confirm-modal{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-6);max-width:400px;width:100%;box-shadow:var(--shadow-lg);animation:modal-in .2s ease}.confirm-modal-title{margin:0 0 var(--space-2);font-size:1.25rem;font-weight:600}.confirm-modal-message{margin:0 0 var(--space-6);color:var(--color-text-muted);font-size:.9375rem;line-height:1.5}.confirm-modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-in{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.invoice-logo-upload{display:flex;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-6)}.invoice-logo-preview{position:relative;width:80px;height:80px;flex-shrink:0}.invoice-logo-preview img{width:100%;height:100%;object-fit:contain;border:1px solid var(--color-border);border-radius:var(--radius-sm)}.invoice-logo-placeholder{width:80px;height:80px;background:var(--color-bg);border:2px dashed var(--color-border-strong);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--color-text-muted)}.invoice-logo-remove{position:absolute;top:-8px;right:-8px;width:24px;height:24px;border-radius:50%;background:var(--color-error);color:#fff;border:none;font-size:1.25rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.invoice-logo-actions{display:flex;flex-direction:column;gap:var(--space-1)}.invoice-logo-hint{font-size:.8125rem;color:var(--color-text-muted)}.invoice-print-logo-img{width:48px;height:48px;object-fit:contain;border-radius:var(--radius-sm)}.btn-group{display:flex;gap:var(--space-3);flex-wrap:wrap}.table-wrap{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:var(--space-3) var(--space-4);text-align:left;border-bottom:1px solid var(--color-border)}.table th.table-num,.table td.table-num{text-align:right}.table th{font-weight:600;font-size:.875rem;color:var(--color-text-muted)}.table tbody tr:hover{background:var(--color-bg)}.expense-receipt-upload{margin-top:var(--space-4);margin-bottom:var(--space-3)}.expense-receipt-upload .input-label{display:block;margin-bottom:var(--space-2)}.expense-receipt-input{font-size:.875rem;max-width:100%}.expense-receipt-preview{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-2)}.expense-receipt-preview img{max-height:60px;width:auto;border-radius:var(--radius-sm);border:1px solid var(--color-border)}.expense-receipt-storage-warning{font-size:.875rem;color:var(--color-warning);margin:0 0 var(--space-3)}.expense-ocr-actions{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.expense-ocr-progress{font-size:.875rem;color:var(--color-text-muted);display:inline-flex;align-items:center;gap:var(--space-2)}.expense-ocr-progress:before{content:"";width:14px;height:14px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:expense-ocr-spin .7s linear infinite}@keyframes expense-ocr-spin{to{transform:rotate(360deg)}}.expense-ocr-error{font-size:.875rem;color:var(--color-error);margin:0;width:100%}.expense-mileage-block{margin-top:var(--space-4);padding:var(--space-4);background:var(--color-bg);border-radius:var(--radius-md);border:1px solid var(--color-border)}.expense-mileage-title{font-size:.875rem;font-weight:600;margin:0 0 var(--space-3);color:var(--color-text)}.expense-mileage-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:var(--space-4);align-items:end}.expense-mileage-summary{font-size:.875rem;color:var(--color-text-muted);margin:var(--space-3) 0 0}.expense-mileage-display{display:block;font-variant-numeric:tabular-nums}.expense-note-extra{display:block;font-size:.8125rem;color:var(--color-text-muted);margin-top:var(--space-1)}.expense-billable-block{margin-top:var(--space-4);margin-bottom:var(--space-3)}.expense-billable-checkbox{display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer;font-size:.9375rem}.expense-billable-checkbox input{width:auto}.expense-billable-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--space-4);margin-top:var(--space-3)}.expense-billable-badge{display:inline-block;padding:var(--space-1) var(--space-2);background:var(--color-primary-light);color:var(--color-primary);border-radius:var(--radius-sm);font-size:.8125rem;font-weight:500}.expense-billable-project{color:var(--color-text-muted);font-weight:400}.expense-totals-currency{margin-bottom:var(--space-2)}.expense-totals-currency-select{max-width:140px}.expense-month-total{font-size:1.5rem;font-weight:700;margin:0;font-variant-numeric:tabular-nums}.expense-amount-cell{font-variant-numeric:tabular-nums}.expense-deductible-block{margin-top:var(--space-4);margin-bottom:var(--space-3)}.expense-deductible-checkbox{display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer;font-size:.9375rem}.expense-deductible-checkbox input{width:auto}.expense-deductible-tag{margin-top:var(--space-2);max-width:200px}.expense-deductible-summary{margin:0;padding-left:var(--space-6);list-style:none;padding-left:0}.expense-deductible-summary li{display:flex;justify-content:space-between;gap:var(--space-4);padding:var(--space-1) 0;border-bottom:1px solid var(--color-border)}.expense-deductible-summary li.expense-deductible-total{font-weight:600;margin-top:var(--space-2);padding-top:var(--space-2);border-bottom:none}.expense-deductible-tag-label{color:var(--color-text)}.expense-deductible-tag-amount{font-variant-numeric:tabular-nums}.expense-deductible-badge{display:inline-block;padding:var(--space-1) var(--space-2);background:var(--color-success-light);color:var(--color-success);border-radius:var(--radius-sm);font-size:.75rem;font-weight:500}.expense-chart-section{overflow:hidden}.expense-chart-wrap{max-width:100%;width:100%;height:280px;position:relative;margin-top:var(--space-4)}@media(min-width:480px){.expense-chart-wrap{max-width:360px;margin-left:auto;margin-right:auto}}.expense-month-over-month{font-size:.875rem;color:var(--color-text-muted);margin:var(--space-1) 0 0}.expense-duplicate-warning{padding:var(--space-4);background:var(--color-warning-light);border:1px solid var(--color-warning);border-radius:var(--radius-md);margin-bottom:var(--space-4);display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3)}.expense-duplicate-warning span{flex:1;min-width:200px}.expense-duplicate-actions{display:flex;gap:var(--space-2)}.expense-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--space-3);margin-bottom:var(--space-4)}.pwa-install-banner{padding:var(--space-3) var(--space-4);background:var(--color-primary-light);border-bottom:1px solid var(--color-border);display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:var(--space-3)}.pwa-install-text{margin:0;font-size:.9375rem;color:var(--color-text)}.pwa-install-actions{display:flex;gap:var(--space-2)}.expense-receipt-thumb-placeholder{display:inline-block;width:40px;color:var(--color-text-subtle);font-size:.75rem}.expense-receipt-thumb{display:inline-block;padding:0;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);cursor:pointer;overflow:hidden;max-width:100px;max-height:100px}.expense-receipt-thumb img{display:block;max-width:100px;max-height:100px;width:auto;height:auto;object-fit:contain}.expense-receipt-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-4)}.expense-receipt-modal{position:relative;max-width:95vw;max-height:90vh;background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-lg)}.expense-receipt-modal-close{position:absolute;top:var(--space-2);right:var(--space-2);width:32px;height:32px;border:none;border-radius:var(--radius-sm);background:var(--color-bg);font-size:1.25rem;line-height:1;cursor:pointer;color:var(--color-text)}.expense-receipt-modal-img{max-width:85vw;max-height:80vh;width:auto;height:auto;object-fit:contain;display:block}.invoice-amount-cell{font-variant-numeric:tabular-nums}.invoice-meta-row{align-items:flex-end}.invoice-meta-value{font-weight:600;color:var(--color-text)}.invoice-status-badge{display:inline-block;margin-left:var(--space-2);padding:var(--space-1) var(--space-2);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;border-radius:var(--radius-sm)}.invoice-status-badge--draft{background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border)}.invoice-status-badge--sent{background:var(--color-primary-light);color:var(--color-primary-hover)}.invoice-status-badge--paid{background:var(--color-success-light);color:var(--color-success)}.invoice-status-badge--overdue{background:var(--color-error-light);color:var(--color-error)}.invoice-totals-box{background:var(--color-bg);padding:var(--space-4);border-radius:var(--radius-md);margin-top:var(--space-4);max-width:320px}.invoice-totals-table{width:100%;border-collapse:collapse}.invoice-totals-table td{padding:var(--space-2) 0;vertical-align:baseline}.invoice-totals-table .invoice-totals-label{font-weight:500;color:var(--color-text)}.invoice-totals-table .invoice-totals-value{text-align:right;font-variant-numeric:tabular-nums}.invoice-totals-table tr.invoice-totals-final .invoice-totals-value,.invoice-totals-table tr.invoice-totals-final .invoice-totals-label{font-weight:700;font-size:1.125rem;padding-top:var(--space-3);border-top:2px solid var(--color-border-strong)}@media(max-width:768px){.layout-body{flex-direction:column;padding:var(--space-4)}.layout-sidebar{width:100%;flex-direction:row;flex-wrap:wrap}.nav-sidebar{flex:1;min-width:200px}.ad-zone-sidebar{min-height:90px}}.invoice-template-selector{display:flex;gap:var(--space-6);flex-wrap:wrap}.invoice-template-card{flex:1;min-width:200px;max-width:280px;display:flex;flex-direction:column;align-items:stretch;padding:var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);cursor:pointer;text-align:left;transition:border-color .2s,box-shadow .2s}.invoice-template-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.invoice-template-card--active{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.invoice-template-preview{width:100%;aspect-ratio:1;max-height:180px;border-radius:var(--radius-sm);padding:10px;margin-bottom:var(--space-3);font-size:8px;overflow:hidden}.invoice-template-preview--classic{background:#f8fafc;border:1px solid #e2e8f0}.invoice-template-preview--modern{background:#fff;border:1px solid #e2e8f0}.invoice-template-preview-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}.invoice-template-preview-logo{width:16px;height:16px;background:#2d3748;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:10px;border-radius:2px}.invoice-template-preview-logo--rounded{border-radius:4px}.invoice-template-preview-logo--classic{background:transparent!important;color:var(--color-text)!important;border:1px solid #e2e8f0}.invoice-template-preview-badge--classic{background:transparent!important;color:#94a3b8!important;font-size:8px}.invoice-template-preview-badge{background:#2d3748;color:#fff;padding:2px 6px;font-weight:700;font-size:7px;letter-spacing:.02em;border-radius:2px}.invoice-template-preview-badge--light{background:transparent;color:#94a3b8;font-size:8px}.invoice-template-preview-table{margin-bottom:6px}.invoice-template-preview-row{height:4px;background:#e2e8f0;margin-bottom:2px;border-radius:1px}.invoice-template-preview-row--head{background:#2d3748;height:6px}.invoice-template-preview-row--head-light{background:#f1f5f9}.invoice-template-preview-totals{display:flex;flex-direction:column;gap:2px}.invoice-template-preview-total{height:4px;background:#f1f5f9;border-radius:1px;border:1px solid #e2e8f0}.invoice-template-preview-total--accent{background:#2d3748;border-color:#2d3748}.invoice-template-card-label{font-weight:600;font-size:1rem;color:var(--color-text);margin-bottom:2px}.invoice-template-card-desc{font-size:.8125rem;color:var(--color-text-muted)}.invoice-print-wrap,.invoice-print{display:none}.invoice-print-hidden{display:none!important}.invoice-print-inner{max-width:800px;margin:0 auto;font-size:12px}.invoice-print-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.invoice-print-brand{display:flex;align-items:center;gap:12px}.invoice-print-logo{width:48px;height:48px;background:#2d3748;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px}.invoice-print-logo-classic{background:transparent!important;color:var(--color-text)!important;border:1px solid #e2e8f0}.invoice-print-title-classic{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:2px}.invoice-print-title-classic-label{font-size:18px;color:#94a3b8;font-weight:700;letter-spacing:.05em}.invoice-print-title-classic span:not(.invoice-print-title-classic-label){font-size:10px;color:var(--color-text);font-weight:600}.invoice-print-table-classic{table-layout:fixed;border:1px solid #e2e8f0}.invoice-print-table-classic th{background:#e6eef4!important;color:#475569!important;border-bottom:1px solid #cbd5e1;border-right:1px solid #e2e8f0;padding:12px 10px!important}.invoice-print-table-classic th:last-child{border-right:none}.invoice-print-table-classic td{padding:12px 10px!important;border-bottom:1px solid #e2e8f0;border-right:1px solid #e2e8f0}.invoice-print-table-classic td:last-child{border-right:none}.invoice-print-table-classic tbody tr:last-child td{border-bottom:none}.invoice-print-table-classic th,.invoice-print-table-classic td{vertical-align:middle}.invoice-print-table-classic th:nth-child(1),.invoice-print-table-classic td:nth-child(1){width:5%;text-align:center!important;border-left:2px solid #94a3b8}.invoice-print-table-classic th:nth-child(2),.invoice-print-table-classic td:nth-child(2){width:48%;text-align:left!important}.invoice-print-table-classic th:nth-child(3),.invoice-print-table-classic td:nth-child(3){width:10%;text-align:center!important}.invoice-print-table-classic th:nth-child(4),.invoice-print-table-classic td:nth-child(4){width:15%;text-align:center!important}.invoice-print-table-classic th:nth-child(5),.invoice-print-table-classic td:nth-child(5){width:22%;text-align:center!important}.invoice-print-table-totals-wrap{width:100%;box-sizing:border-box}.invoice-print-table-totals-wrap .invoice-print-table{box-sizing:border-box;width:100%}.invoice-print-totals-row{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-top:0;margin-bottom:24px}.invoice-print-payment-block{flex:0 0 auto}.invoice-print-totals-align{flex:1;min-width:0;display:flex;justify-content:flex-end;align-items:flex-start}.invoice-print-payment-block strong{display:block;margin-bottom:8px}.invoice-print-payment-block div{margin-bottom:4px}.invoice-print-totals-table{border-collapse:collapse;min-width:0;width:auto;max-width:180px}.invoice-print-totals-table td{padding:8px 10px;border:1px solid #e2e8f0}.invoice-print-totals-table td.invoice-print-tfoot-label{width:1%;white-space:nowrap}.invoice-print-totals-table td.invoice-print-tfoot-value{width:auto}.invoice-print-totals-table-classic td.invoice-print-tfoot-label{background:#e6eef4;color:var(--color-text);text-align:center!important;border-right:2px solid #94a3b8}.invoice-print-totals-table-classic td.invoice-print-tfoot-value{background:transparent;text-align:center!important;padding:8px 10px}.invoice-print-totals-table-modern td.invoice-print-tfoot-label{background:#2d3748;color:#fff;text-align:center!important;border-right:2px solid #94a3b8}.invoice-print-totals-table-modern td.invoice-print-tfoot-value{background:transparent;text-align:center!important;padding:8px 10px}.invoice-print-totals-table tr.invoice-print-tfoot-final td{font-weight:700;font-size:14px;padding:10px}.invoice-print-tagline{font-size:10px;color:#64748b;margin-top:2px}.invoice-print-title{background:#2d3748;color:#fff;padding:8px 24px;font-weight:700;font-size:16px;letter-spacing:.05em;border-radius:0 8px 8px 0}.invoice-print-meta{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.invoice-print-meta-right{text-align:right}.invoice-print-meta-right div{margin-bottom:4px}.invoice-print-meta-row{display:flex;justify-content:space-between;gap:24px;margin-bottom:4px;min-width:160px}.invoice-print-meta-row span:first-child{font-weight:600;flex-shrink:0;text-align:left}.invoice-print-meta-row span:last-child{text-align:right}.invoice-print-num{text-align:right!important;font-variant-numeric:tabular-nums}.invoice-print-notes{margin-bottom:16px;padding:8px 0;font-size:11px;color:var(--color-text);border-top:1px solid #e2e8f0}.invoice-print-system-gen{font-size:9px;color:#64748b;margin-top:4px;font-style:italic}.invoice-print-terms{margin-top:12px;padding-top:12px;border-top:1px solid #e2e8f0;font-size:10px;color:var(--color-text-muted)}.invoice-print-table{width:100%;border-collapse:collapse;margin-bottom:8px}.invoice-print-table th{background:#2d3748;color:#fff;padding:10px 8px;font-size:10px;font-weight:600;letter-spacing:.05em;text-align:left;border-right:1px solid rgba(255,255,255,.2)}.invoice-print-table th:last-child{border-right:none}.invoice-print-table th:nth-child(1){width:5%;text-align:center;border-left:2px solid rgba(148,163,184,.9)}.invoice-print-table th:nth-child(2){width:50%;text-align:left}.invoice-print-table th:nth-child(3),.invoice-print-table th:nth-child(4),.invoice-print-table th:nth-child(5){width:15%;text-align:center}.invoice-print-table td{padding:8px;border-bottom:1px solid #e2e8f0;border-right:1px solid #e2e8f0}.invoice-print-table td:last-child{border-right:none}.invoice-print-table td:nth-child(1){text-align:center;border-left:2px solid #94a3b8}.invoice-print-table td:nth-child(2){text-align:left}.invoice-print-table td:nth-child(3),.invoice-print-table td:nth-child(4),.invoice-print-table td:nth-child(5){text-align:center}.invoice-print-footer{padding-top:56px;margin-top:28px;border-top:1px solid #e2e8f0}.invoice-print-footer strong{display:block;margin-bottom:8px}.invoice-print-contact-block{display:flex;flex-direction:column;gap:4px}.invoice-print-contact{margin-bottom:0;line-height:1.5;min-height:1.5em;display:flex;align-items:baseline}.invoice-print-contact span{font-weight:600;min-width:60px;flex-shrink:0}.invoice-print-contact-last{margin-bottom:0}.invoice-print-website-sign-row{display:flex;justify-content:space-between;align-items:baseline;gap:24px;min-height:1.5em;line-height:1.5}.invoice-print-website-sign-row .invoice-print-contact{margin-bottom:0;flex:1;min-width:0}.invoice-print-sign{text-align:center;flex-shrink:0}.invoice-print-sign-line{width:150px;border-top:1px solid #0f172a;margin-bottom:4px}.invoice-print-page-footer{margin-top:64px;padding-top:16px;border-top:1px solid #e2e8f0;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;font-size:10px;color:#64748b}.invoice-print-footer-date{order:1}.invoice-print-footer-brand{order:2;font-weight:500;color:var(--color-text-muted)}.invoice-print-footer-link{order:3;color:var(--color-primary)}.invoice-print-title-modern{border-radius:8px!important}.invoice-print-logo-modern{border-radius:8px}.invoice-print-modern-inner .invoice-print-table{table-layout:fixed;border:1px solid #e2e8f0}.invoice-print-modern-inner .invoice-print-table th{padding:12px 10px!important;border-bottom:1px solid rgba(255,255,255,.2);border-right:1px solid rgba(255,255,255,.2)}.invoice-print-modern-inner .invoice-print-table th:last-child{border-right:none}.invoice-print-modern-inner .invoice-print-table td{padding:12px 10px!important;border-bottom:1px solid #e2e8f0;border-right:1px solid #e2e8f0}.invoice-print-modern-inner .invoice-print-table td:last-child{border-right:none}.invoice-print-modern-inner .invoice-print-table tbody tr:last-child td{border-bottom:none}.invoice-print-modern-inner .invoice-print-table th,.invoice-print-modern-inner .invoice-print-table td{vertical-align:middle}.invoice-print-modern-inner .invoice-print-table th:nth-child(1),.invoice-print-modern-inner .invoice-print-table td:nth-child(1){width:5%;text-align:center!important;border-left:2px solid rgba(148,163,184,.9)}.invoice-print-modern-inner .invoice-print-table th:nth-child(2),.invoice-print-modern-inner .invoice-print-table td:nth-child(2){width:48%;text-align:left!important}.invoice-print-modern-inner .invoice-print-table th:nth-child(3),.invoice-print-modern-inner .invoice-print-table td:nth-child(3){width:10%;text-align:center!important}.invoice-print-modern-inner .invoice-print-table th:nth-child(4),.invoice-print-modern-inner .invoice-print-table td:nth-child(4){width:15%;text-align:center!important}.invoice-print-modern-inner .invoice-print-table th:nth-child(5),.invoice-print-modern-inner .invoice-print-table td:nth-child(5){width:22%;text-align:center!important}.invoice-print-saas .invoice-print-inner{max-width:800px;margin:0 auto;font-size:13px;color:#1e293b;line-height:1.5}.invoice-saas-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;padding-bottom:20px;border-bottom:1px solid #e2e8f0}.invoice-saas-brand{display:flex;align-items:center;gap:14px}.invoice-saas-logo{width:48px;height:48px;object-fit:contain;border-radius:6px}.invoice-saas-logo-placeholder{width:48px;height:48px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;color:#475569}.invoice-print-saas.invoice-print-modern .invoice-saas-logo-placeholder{background:#2d3748;color:#fff;border-color:#2d3748}.invoice-saas-brand-text{flex:1}.invoice-saas-business-name{font-size:18px;font-weight:600;color:#0f172a;display:block}.invoice-saas-tagline{font-size:12px;color:#64748b;margin-top:2px}.invoice-saas-meta-block{text-align:right}.invoice-saas-title{font-size:24px;font-weight:700;color:#0f172a;letter-spacing:-.02em;margin-bottom:12px;line-height:1.2}.invoice-saas-meta-row{font-size:11px;margin-bottom:2px;line-height:1.4}.invoice-saas-meta-row span:first-child{color:#64748b;margin-right:8px}.invoice-saas-two-col{display:flex;justify-content:space-between;gap:40px;margin-bottom:28px}.invoice-saas-bill-to{flex:1;max-width:55%}.invoice-saas-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#64748b;margin-bottom:8px}.invoice-saas-client-name{font-weight:600;color:#0f172a;margin-bottom:4px}.invoice-saas-bill-to div{font-size:12px;color:#475569}.invoice-saas-table{width:100%;border-collapse:collapse;margin-bottom:24px;font-size:12px}.invoice-saas-table thead th{padding:10px 12px;text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.03em;color:#64748b;background:#f8fafc;border-bottom:1px solid #e2e8f0}.invoice-print-saas.invoice-print-modern .invoice-saas-table thead th{background:#2d3748;color:#fff;border-bottom-color:#fff3}.invoice-saas-th-num{text-align:right!important}.invoice-saas-table tbody td{padding:12px;border-bottom:1px solid #f1f5f9;vertical-align:top}.invoice-saas-table tbody tr:nth-child(2n){background:#fafbfc}.invoice-print-saas.invoice-print-modern .invoice-saas-table tbody tr:nth-child(2n){background:#f8fafc}.invoice-saas-td-num{text-align:right!important;font-variant-numeric:tabular-nums}.invoice-saas-totals-wrap{display:flex;justify-content:flex-end;margin-bottom:28px}.invoice-saas-totals{width:280px;border-collapse:collapse;font-size:12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.invoice-saas-totals td{padding:10px 14px}.invoice-saas-totals-label{color:#475569}.invoice-saas-totals-value{text-align:right!important;font-variant-numeric:tabular-nums}.invoice-saas-totals-final .invoice-saas-totals-label,.invoice-saas-totals-final .invoice-saas-totals-value{font-weight:700;font-size:16px;padding-top:14px;padding-bottom:14px;border-top:2px solid #e2e8f0;background:#e2e8f0;color:#0f172a}.invoice-print-saas.invoice-print-modern .invoice-saas-totals-final .invoice-saas-totals-label,.invoice-print-saas.invoice-print-modern .invoice-saas-totals-final .invoice-saas-totals-value{background:#2d3748;color:#fff;border-top-color:#1e293b}.invoice-saas-notes{margin-bottom:24px;padding:14px 16px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.invoice-saas-notes-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#64748b;margin-bottom:6px}.invoice-saas-notes-text{font-size:12px;color:#475569;line-height:1.5}.invoice-saas-payment{margin-bottom:28px;padding:14px 16px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.invoice-saas-payment-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#64748b;margin-bottom:8px}.invoice-saas-payment-details{font-size:12px;color:#475569}.invoice-saas-payment-details div{margin-bottom:4px}.invoice-saas-footer{padding-top:24px;border-top:1px solid #e2e8f0;margin-top:8px}.invoice-saas-footer-main{margin-bottom:12px}.invoice-saas-authorized{font-weight:600;color:#0f172a;margin-bottom:4px}.invoice-saas-contact{font-size:12px;color:#475569;margin-bottom:10px}.invoice-saas-system-gen{font-size:11px;color:#94a3b8;font-style:italic}.invoice-saas-terms{font-size:10px;color:#64748b;line-height:1.4;margin-top:12px;padding-top:12px;border-top:1px solid #e2e8f0}.invoice-saas-page-footer{margin-top:40px;padding-top:12px;border-top:1px solid #e2e8f0;font-size:8px;color:#94a3b8;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;opacity:.7}.invoice-due-hint{display:block;font-size:.75rem;color:var(--color-text-muted);margin-top:2px}@media print{.header,.footer,.layout-sidebar,.data-disclaimer,.ad-zone,.btn-group,button{display:none!important}.layout-body{padding:0}.layout-main{max-width:none}.tool-page h1,.tool-page .form-section,.tool-page .btn-group,.invoice-template-selector{display:none!important}.invoice-print-wrap{display:block!important}.invoice-print.invoice-print-hidden{display:none!important}.invoice-print:not(.invoice-print-hidden){display:block!important;padding:20px}.invoice-print-inner{max-width:none!important;width:100%!important}}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
