*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-tap-highlight-color:transparent;-webkit-text-size-adjust:100%}:root{--bg: #f5f4f0;--surface: #ffffff;--surface2: #faf9f6;--border: #e4e2da;--border-h: #c8c6be;--text: #1a1917;--muted: #6b6860;--hint: #9c9a92;--brand: #e28401;--blue: #2563eb;--blue-bg: #e8f0fe;--blue-tx: #1a56a0;--amber-bg: #fef3e2;--amber-tx: #92530a;--green-bg: #e8f5e9;--green-tx: #2e7d32;--red-bg: #fdecea;--red-tx: #b71c1c;--radius: 10px;--radius-s: 6px;--radius-l: 14px}body{font-family:DM Sans,-apple-system,BlinkMacSystemFont,sans-serif;font-size:15px;line-height:1.5;color:var(--text);background:var(--bg);min-height:100dvh;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;border:none;background:none}input,textarea,select{font:inherit}#app{display:flex;flex-direction:column;min-height:100dvh}.topbar{background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:21}.topbar-inner{max-width:900px;margin:0 auto;padding:10px 16px;display:flex;align-items:center}.brand-logo{height:40px;width:auto;display:block}.brand-text{font-size:16px;font-weight:700;color:var(--text);letter-spacing:-.01em}.nav{background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:61px;z-index:20}.nav-inner{display:flex;align-items:center;gap:0;overflow-x:auto;scrollbar-width:none;max-width:900px;margin:0 auto;padding:0 8px}.nav-inner::-webkit-scrollbar{display:none}.nav-tab{padding:12px 16px;font-size:14px;font-weight:500;color:var(--muted);white-space:nowrap;border-bottom:2px solid transparent;transition:color .15s,border-color .15s;-webkit-tap-highlight-color:transparent}.nav-tab.active{color:var(--text);border-bottom-color:var(--text)}.nav-tab:hover{color:var(--text)}.content{flex:1;max-width:900px;width:100%;margin:0 auto;padding:16px}.view{display:none}.view.active{display:block}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px}.page-title{font-size:18px;font-weight:700}.toggle-archived{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-archived input{cursor:pointer}.dash-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.stat-clickable{cursor:pointer;transition:border-color .15s,box-shadow .15s}.stat-clickable:hover{border-color:var(--border-h);box-shadow:0 1px 4px #0000000d}.stat-value{font-size:20px;font-weight:700;line-height:1.1;color:var(--text)}.stat-label{font-size:13px;font-weight:600;color:var(--text);margin-top:6px}.stat-sub{font-size:12px;color:var(--muted);margin-top:2px}.stat-danger .stat-value{color:var(--red-tx)}.stat-warn .stat-value{color:var(--amber-tx)}.dash-recent-row{cursor:pointer}.dash-recent-row:hover{background:var(--surface2)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-s);font-size:14px;font-weight:600;transition:background .15s,opacity .15s,border-color .15s;white-space:nowrap;border:1px solid transparent}.btn:disabled{opacity:.45;pointer-events:none}.btn-primary{background:var(--text);color:#fff;border-color:var(--text)}.btn-primary:hover{opacity:.88}.btn-secondary{background:var(--surface);color:var(--text);border-color:var(--border)}.btn-secondary:hover{border-color:var(--border-h)}.btn-danger{background:var(--red-bg);color:var(--red-tx);border-color:var(--red-bg)}.btn-danger:hover{opacity:.88}.btn-ghost{background:transparent;color:var(--muted);padding:4px 8px}.btn-ghost:hover{background:var(--bg);color:var(--text)}.btn-sm{padding:5px 10px;font-size:13px}.btn-brand{background:var(--brand);color:#fff;border-color:var(--brand)}.btn-brand:hover{opacity:.88}.search-wrap{position:relative;margin-bottom:12px}.search-wrap input{width:100%;padding:10px 12px 10px 38px;border:1px solid var(--border);border-radius:var(--radius-s);background:var(--surface);font-size:14px;color:var(--text);outline:none;transition:border-color .15s}.search-wrap input:focus{border-color:var(--border-h)}.search-wrap:before{content:"🔍";position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:14px;opacity:.4;pointer-events:none}.card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden}.card+.card{margin-top:10px}.card-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);font-weight:600;font-size:15px}.card-body{padding:16px}.list-row{display:flex;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);gap:12px;transition:background .1s}.list-row:last-child{border-bottom:none}.list-row:hover{background:var(--surface2)}.list-row-main{flex:1;min-width:0}.list-row-title{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-row-sub{font-size:12px;color:var(--muted)}.list-row-actions{display:flex;gap:6px;align-items:center;flex-shrink:0}.list-row-amount{font-weight:700;font-size:15px;white-space:nowrap;flex-shrink:0}@media(max-width:430px){.list-row{flex-wrap:wrap;gap:8px 12px}.list-row-main{width:100%}.list-row-amount{font-size:14px}.list-row-actions{margin-left:auto}.list-row-actions .btn-sm{padding:5px 8px;font-size:12px}}.group-heading{padding:8px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--hint);background:var(--surface2);border-bottom:1px solid var(--border)}.badge{display:inline-flex;align-items:center;vertical-align:middle;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.badge-sent{background:var(--green-bg);color:var(--green-tx)}.badge-notsent{background:var(--amber-bg);color:var(--amber-tx)}.badge-job{background:var(--blue-bg);color:var(--blue-tx)}.form-group{margin-bottom:14px}.form-label{display:block;font-size:13px;font-weight:500;color:var(--muted);margin-bottom:5px}.form-control{display:block;width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-s);background:var(--bg);color:var(--text);font-size:14px;transition:border-color .15s,box-shadow .15s;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-control:focus{border-color:var(--border-h);box-shadow:0 0 0 3px #0000000a}textarea.form-control{resize:vertical;min-height:80px}select.form-control{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239c9a92' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;cursor:pointer}.form-row{display:grid;gap:12px}.form-row-2{grid-template-columns:1fr 1fr}.form-row-3{grid-template-columns:1fr 1fr 1fr}@media(max-width:480px){.form-row-2,.form-row-3{grid-template-columns:1fr}}.form-hint{font-size:12px;color:var(--hint);margin-top:4px}.form-section-title{font-weight:600;font-size:15px;margin:20px 0 12px;color:var(--text)}.segment{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.segment-btn{padding:6px 14px;border-radius:20px;border:1px solid var(--border);font-size:13px;font-weight:500;background:var(--bg);color:var(--muted);transition:all .15s;-webkit-tap-highlight-color:transparent}.segment-btn.active{background:var(--text);border-color:var(--text);color:#fff}.segment-btn:hover:not(.active){border-color:var(--border-h);color:var(--text)}.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.chip{padding:10px 12px;border-radius:var(--radius-s);border:1px solid var(--border);background:var(--bg);font-size:13px;font-weight:500;text-align:left;transition:border-color .12s,background .12s;-webkit-tap-highlight-color:transparent}.chip:hover{border-color:var(--border-h);background:var(--surface)}.chip-name{display:block;color:var(--text)}.chip-price{font-size:12px;color:var(--hint);display:block;margin-top:1px;font-weight:400}.line-items{width:100%;margin-bottom:12px}.line-items-header{display:grid;grid-template-columns:1fr 70px 90px 80px 32px;gap:6px;padding:6px 0;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--hint);border-bottom:1px solid var(--border)}.line-item-row{display:grid;grid-template-columns:1fr 70px 90px 80px 32px;gap:6px;padding:6px 0;align-items:center;border-bottom:1px solid var(--border)}.line-item-row input{padding:6px 8px;border:1px solid var(--border);border-radius:var(--radius-s);font-size:13px;width:100%;background:var(--surface);color:var(--text);outline:none}.line-item-row input:focus{border-color:var(--border-h)}.line-total{font-size:13px;font-weight:600;text-align:right}.line-remove{color:var(--hint);font-size:18px;line-height:1;padding:0}.line-remove:hover{color:var(--red-tx)}@media(max-width:560px){.line-items-header{display:none}.line-item-row{grid-template-columns:1fr 1fr;gap:4px}.line-item-row .line-total{text-align:left}}.totals-summary{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;margin-bottom:16px}.totals-row{display:flex;justify-content:space-between;padding:3px 0;font-size:14px;color:var(--muted)}.totals-row .totals-val{font-weight:500;color:var(--text)}.totals-row.total-final{font-size:16px;font-weight:700;color:var(--text);border-top:2px solid var(--border);margin-top:6px;padding-top:8px}.totals-row.discount-row{color:var(--green-tx)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a191773;display:flex;align-items:flex-end;justify-content:center;z-index:200;padding:16px}@media(min-width:560px){.modal-overlay{align-items:center}}.modal{background:var(--surface);border-radius:var(--radius-l);width:100%;max-width:560px;max-height:90dvh;overflow-y:auto;box-shadow:0 20px 60px #00000026}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:1}.modal-title{font-size:17px;font-weight:700}.modal-close{font-size:24px;color:var(--hint);padding:0 4px}.modal-close:hover{color:var(--text)}.modal-body{padding:20px}.modal-footer{padding:16px 20px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;position:sticky;bottom:0;background:var(--surface)}.email-preview{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-s);padding:12px 16px;margin-bottom:16px}.email-preview-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--hint);margin-bottom:4px}.pdf-link{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-s);font-size:13px;font-weight:500;color:var(--text);margin-bottom:16px;transition:border-color .15s}.pdf-link:hover{border-color:var(--border-h)}.sub-tabs{display:flex;gap:4px;margin-bottom:16px;overflow-x:auto;scrollbar-width:none}.sub-tabs::-webkit-scrollbar{display:none}.sub-tab{padding:6px 14px;border-radius:20px;font-size:13px;font-weight:500;color:var(--muted);background:var(--bg);border:1px solid var(--border);white-space:nowrap;transition:all .15s;-webkit-tap-highlight-color:transparent}.sub-tab.active{background:var(--text);color:#fff;border-color:var(--text)}.sub-tab:hover:not(.active){border-color:var(--border-h);color:var(--text)}.parts-list{list-style:none}.parts-list li{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}.parts-list li:last-child{border-bottom:none}.parts-list input{padding:5px 8px;border:1px solid var(--border);border-radius:var(--radius-s);font-size:13px;background:var(--surface);color:var(--text);outline:none}.parts-list input:focus{border-color:var(--border-h)}.parts-list .part-name{flex:1}.parts-list .part-qty{width:70px}.spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--text);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:48px 16px;color:var(--hint)}.empty-state-icon{font-size:40px;margin-bottom:8px}.empty-state-text{font-size:15px}#toast-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{background:var(--text);color:#fff;padding:10px 20px;border-radius:999px;font-size:14px;font-weight:500;box-shadow:0 4px 16px #0003;animation:toast-in .25s ease;pointer-events:all;white-space:nowrap}.toast.error{background:var(--red-tx)}.toast.success{background:var(--green-tx)}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.login-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg)}.login-card{background:var(--surface);border-radius:var(--radius-l);padding:32px;width:100%;max-width:360px;box-shadow:0 4px 24px #00000012;border:1px solid var(--border)}.login-logo-img{max-width:180px;height:auto;display:block;margin-bottom:8px}.login-logo-text{font-size:22px;font-weight:700;color:var(--text);margin-bottom:4px}.login-sub{font-size:14px;color:var(--muted);margin-bottom:24px}@media(max-width:480px){.content{padding:12px}.nav-tab{padding:10px 12px;font-size:13px}.btn{padding:8px 12px}.brand-logo{height:32px}}@media print{.topbar,.nav,.btn,.modal-overlay{display:none!important}.content{max-width:100%;padding:0}}
