.field-login-screen{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(ellipse at 30% 20%,rgba(13,148,136,.15) 0%,transparent 60%),radial-gradient(ellipse at 70% 80%,rgba(15,23,42,1) 0%,transparent 60%),#0f172a}.field-login-card{width:100%;max-width:360px;padding:36px;display:flex;flex-direction:column;align-items:center}.field-login-logo{margin-bottom:16px}.field-login-logo-mark{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,#0d9488,#0f766e);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:900;color:#fff;letter-spacing:-.02em;box-shadow:0 8px 24px #0d94884d}.field-login-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:#fff;letter-spacing:-.03em;margin-bottom:4px}.field-login-subtitle{font-size:.875rem;color:#ffffff80;font-weight:500;letter-spacing:.02em}.field-login-form{width:100%;margin-top:36px}.field-login-field{margin-bottom:20px}.field-login-label{display:block;font-size:.6875rem;font-weight:600;color:#fff9;text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.field-login-input{width:100%;height:52px;background:#ffffff14;border:1.5px solid rgba(255,255,255,.12);border-radius:12px;color:#fff;font-family:inherit;font-size:1rem;padding:0 16px;outline:none;transition:border-color .2s,background .2s}.field-login-input::placeholder{color:#ffffff4d}.field-login-input:focus{border-color:#0d9488;background:#ffffff1f}.field-login-btn{width:100%;height:52px;margin-top:24px;background:linear-gradient(135deg,#0d9488,#0f766e);color:#fff;font-family:inherit;font-size:1rem;font-weight:700;letter-spacing:.01em;border:none;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:filter .2s,transform .1s;-webkit-tap-highlight-color:transparent}.field-login-btn:hover:not(:disabled){filter:brightness(1.08);transform:translateY(-1px)}.field-login-btn:active:not(:disabled){transform:translateY(0)}.field-login-btn:disabled{opacity:.7;cursor:not-allowed}.field-login-spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:fieldLoginSpin .6s linear infinite}@keyframes fieldLoginSpin{to{transform:rotate(360deg)}}.field-login-error{margin-top:16px;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:10px 14px;color:#fca5a5;font-size:.875rem;line-height:1.4}.field-login-footer{margin-top:32px;font-size:.75rem;color:#ffffff4d;text-align:center}.queue-page{display:flex;flex-direction:column;height:100dvh;padding-bottom:calc(64px + var(--safe-bottom));background:var(--surface-0)}.queue-header{padding:calc(16px + var(--safe-top)) 16px 12px;background:var(--surface-0)}.queue-title{font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--text-primary);letter-spacing:-.5px}.queue-date{font-size:13px;color:var(--text-secondary);margin-top:2px}.queue-tabs{display:flex;gap:4px;padding:0 16px 12px}.queue-tab{padding:8px 16px;border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;border:none;background:transparent;color:var(--text-muted);font-family:var(--font-body);-webkit-tap-highlight-color:transparent}.queue-tab.active{background:var(--accent);color:#fff}.tab-count{font-size:11px;font-weight:700;margin-left:4px;opacity:.7}.queue-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.ptr-indicator{display:flex;align-items:center;justify-content:center;overflow:hidden;transition:height .2s ease-out;color:var(--text-secondary)}.ptr-indicator svg{transition:transform .1s ease-out,opacity .1s ease-out}@keyframes ptr-spin{to{transform:rotate(360deg)}}.ptr-spinning svg{animation:ptr-spin 1s linear infinite}.job-list{display:flex;flex-direction:column;gap:8px;padding:0 16px 16px}.job-card{background:var(--surface-1);border-radius:var(--radius-md);padding:14px 16px;border:1px solid var(--border-default);cursor:pointer;position:relative;overflow:hidden;-webkit-tap-highlight-color:transparent;box-shadow:var(--shadow-sm)}.job-card:active{transform:scale(.98);background:var(--surface-2)}.job-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px}.job-card.dispatched:before{background:var(--warning)}.job-card.on_the_way:before{background:var(--info)}.job-card.in_progress:before{background:var(--info);animation:pulse 2s infinite}.job-card.scheduled:before{background:var(--text-muted)}.job-card.completed:before{background:var(--success)}.job-card.cancelled:before{background:var(--error)}.job-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.job-card-time{font-family:var(--font-mono);font-size:13px;font-weight:500;color:var(--text-primary)}.job-card-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:3px 8px;border-radius:12px}.job-card-badge.dispatched{background:#f59e0b26;color:var(--warning)}.job-card-badge.on-way,.job-card-badge.in-progress{background:#3b82f626;color:var(--info)}.job-card-badge.scheduled{background:var(--surface-2);color:var(--text-muted)}.job-card-badge.completed{background:#10b98126;color:var(--success)}.job-card-badge.cancelled{background:#ef444426;color:var(--error)}.job-card-helper-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:3px 8px;border-radius:12px;background:#6366f126;color:var(--accent, #6366f1);margin-right:auto}.job-card-name{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.job-card-desc{font-size:13px;color:var(--text-secondary);margin-bottom:8px}.job-card-footer{display:flex;justify-content:space-between;align-items:center}.job-card-address{font-size:12px;color:var(--text-muted);display:flex;align-items:center;gap:4px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.job-card-id{font-family:var(--font-mono);font-size:11px;color:var(--accent);opacity:.7;flex-shrink:0}.swipe-hint{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px;color:var(--text-muted);font-size:12px}.queue-empty{padding:80px 40px;text-align:center;color:var(--text-muted)}.eq-page{padding:16px 16px 96px;max-width:720px;margin:0 auto}.eq-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.eq-back{width:40px;height:40px;border-radius:10px;background:var(--surface-2);border:1px solid var(--border-default);color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent;transition:background .12s ease}.eq-back:active{background:var(--surface-3)}.eq-header-info{display:flex;flex-direction:column;min-width:0}.eq-title{font-family:var(--font-display, inherit);font-size:20px;font-weight:700;color:var(--text-primary);line-height:1.2;overflow:hidden;text-overflow:ellipsis}.eq-id{font-family:var(--font-mono, monospace);font-size:12px;color:var(--text-muted);margin-top:2px}.eq-section{background:var(--surface-1);border:1px solid var(--border-default);border-radius:12px;padding:14px 16px;margin-bottom:12px}.eq-section .section-label{font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--text-muted);margin-bottom:10px}.eq-row{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px solid var(--border-default)}.eq-row:last-child{border-bottom:none}.eq-row-label{font-size:13px;color:var(--text-secondary);flex-shrink:0}.eq-row-value{font-size:14px;font-weight:500;color:var(--text-primary);text-align:right;word-break:break-word}.eq-row-value.eq-mono{font-family:var(--font-mono, monospace);font-size:13px}.eq-loading{display:flex;align-items:center;justify-content:center;padding:80px 0}.eq-error{text-align:center;padding:48px 24px;color:var(--text-secondary)}.eq-error p{margin:0 0 16px;font-size:14px}.eq-retry{font-size:14px;font-weight:600;padding:10px 20px;border-radius:10px;background:var(--accent, #0d9488);color:#fff;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent}.eq-retry:active{opacity:.85}.contact-page{display:flex;flex-direction:column;min-height:100dvh;padding:calc(16px + var(--safe-top)) 16px calc(80px + var(--safe-bottom));background:var(--surface-0);gap:14px}.contact-loading,.contact-error{display:flex;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-secondary);font-size:14px}.contact-back{width:40px;height:40px;border-radius:50%;background:var(--surface-2);border:none;color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent;flex-shrink:0}.contact-back:active{background:var(--surface-3, var(--surface-2))}.contact-header{display:flex;align-items:center;gap:12px}.contact-header-info{flex:1;min-width:0}.contact-name{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.contact-label{font-size:13px;color:var(--text-secondary);margin-top:2px}.contact-actions{display:flex;flex-direction:column;gap:8px;margin-top:4px}.contact-action{display:flex;align-items:center;gap:12px;padding:14px 16px;width:100%;background:var(--surface-1);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);text-decoration:none;text-align:left;font:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .12s ease-out}.contact-action:active{background:var(--surface-2)}.contact-action:disabled{opacity:.5;cursor:default}.ca-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;flex-shrink:0}.ca-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);flex-shrink:0;width:48px}.ca-value{flex:1;min-width:0;font-size:15px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-empty{padding:20px 16px;text-align:center;color:var(--text-muted);font-size:13px}.pu-root{display:flex;flex-direction:column;gap:var(--text-sm, .75rem)}.pu-actions{display:grid;grid-template-columns:1fr 1fr;gap:var(--text-sm, .75rem)}.pu-action-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;font-family:var(--font-body, "DM Sans", sans-serif);font-size:var(--text-sm, .875rem);font-weight:var(--weight-semibold, 600);color:var(--text-primary);background:var(--surface-1);border:1px solid var(--border-default);border-radius:var(--radius-md, .5rem);cursor:pointer;transition:background var(--duration-fast, .12s) var(--ease-default, ease),border-color var(--duration-fast, .12s) var(--ease-default, ease)}.pu-action-btn:active{background:var(--surface-2)}.pu-action-icon{width:1.25rem;height:1.25rem;flex-shrink:0}.pu-hidden-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.pu-counter-bar{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0}.pu-counter-text{font-family:var(--font-body, "DM Sans", sans-serif);font-size:var(--text-xs, .75rem);color:var(--text-secondary)}.pu-retry-link{font-family:var(--font-body, "DM Sans", sans-serif);font-size:var(--text-xs, .75rem);font-weight:var(--weight-semibold, 600);color:var(--error);background:none;border:none;cursor:pointer;text-decoration:underline;padding:0}.pu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(88px,1fr));gap:.5rem}.pu-thumb{position:relative;aspect-ratio:1;border-radius:var(--radius-sm, .375rem);overflow:hidden;background:var(--surface-2)}.pu-thumb-img{width:100%;height:100%;object-fit:cover;display:block}.pu-thumb-remove{position:absolute;top:2px;right:2px;width:1.25rem;height:1.25rem;display:flex;align-items:center;justify-content:center;font-size:.875rem;line-height:1;color:var(--text-inverse);background:var(--surface-4);border:none;border-radius:50%;cursor:pointer;opacity:.85;z-index:2}.pu-thumb-remove:active{opacity:1}.pu-thumb-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1}.pu-thumb-overlay--compressing{background:color-mix(in srgb,var(--surface-0) 60%,transparent)}.pu-thumb-overlay--uploading{background:color-mix(in srgb,var(--surface-0) 50%,transparent)}.pu-thumb-overlay--done{background:color-mix(in srgb,var(--success) 25%,transparent)}.pu-thumb-overlay--error{background:color-mix(in srgb,var(--error) 35%,transparent)}.pu-progress-ring{width:40px;height:40px;transform:rotate(-90deg)}.pu-progress-ring-bg{fill:none;stroke:var(--border-subtle);stroke-width:3}.pu-progress-ring-fill{fill:none;stroke:var(--accent);stroke-width:3;stroke-linecap:round;transition:stroke-dasharray var(--duration-fast, .12s) var(--ease-default, ease)}.pu-progress-pct{font-family:var(--font-mono, "DM Mono", monospace);font-size:var(--text-xs, .75rem);color:var(--text-primary);margin-top:.125rem}.pu-compress-label{font-family:var(--font-body, "DM Sans", sans-serif);font-size:var(--text-xs, .75rem);color:var(--text-secondary)}.pu-check-icon{width:28px;height:28px;color:var(--success)}.pu-error-label{font-family:var(--font-body, "DM Sans", sans-serif);font-size:var(--text-xs, .75rem);font-weight:var(--weight-semibold, 600);color:var(--text-inverse);background:var(--error);padding:.125rem .375rem;border-radius:var(--radius-sm, .375rem)}.pu-upload-btn{width:100%;padding:.75rem;font-family:var(--font-body, "DM Sans", sans-serif);font-size:var(--text-sm, .875rem);font-weight:var(--weight-bold, 700);color:var(--text-inverse);background:var(--accent);border:none;border-radius:var(--radius-md, .5rem);cursor:pointer;transition:background var(--duration-fast, .12s) var(--ease-default, ease)}.pu-upload-btn:active{background:var(--accent-hover)}[data-theme=dark] .pu-action-btn{background:var(--surface-2);border-color:var(--border-subtle);color:var(--text-primary)}[data-theme=dark] .pu-action-btn:active,[data-theme=dark] .pu-thumb-remove{background:var(--surface-3)}[data-theme=dark] .pu-thumb-overlay--compressing{background:color-mix(in srgb,var(--surface-0) 70%,transparent)}[data-theme=dark] .pu-thumb-overlay--uploading{background:color-mix(in srgb,var(--surface-0) 65%,transparent)}.lightbox-overlay{position:fixed;inset:0;z-index:9999;background:#000000eb;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.lightbox-content{position:relative;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center}.lightbox-close{position:absolute;top:max(12px,env(safe-area-inset-top,0px));right:16px;z-index:1001;width:44px;height:44px;border-radius:50%;background:#0009;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;-webkit-tap-highlight-color:transparent}.lightbox-close:active{background:#000000d9}.lightbox-image{max-width:92vw;max-height:75vh;object-fit:contain;border-radius:8px;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.lightbox-info{display:flex;align-items:center;gap:12px;margin-top:14px}.lightbox-label{font-size:13px;font-weight:700;color:#fff;background:#ffffff26;padding:3px 10px;border-radius:6px;text-transform:uppercase;letter-spacing:.5px}.lightbox-counter{font-family:var(--font-mono, monospace);font-size:12px;color:#ffffff8c}.lightbox-arrow{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;background:#ffffff1f;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent}.lightbox-arrow:active{background:#ffffff40}.lightbox-arrow-left{left:10px}.lightbox-arrow-right{right:10px}.materials-tab{padding-bottom:8px}.materials-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.materials-title-row{display:flex;align-items:center;gap:8px}.materials-title{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--text-primary);letter-spacing:-.2px}.materials-count{font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--accent);background:var(--accent-glow, rgba(13, 148, 136, .12));padding:2px 8px;border-radius:10px}.materials-add-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:10px;background:var(--accent);color:#fff;font-family:var(--font-body);font-size:13px;font-weight:600;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent}.materials-add-btn:active{transform:scale(.97)}.materials-locked-banner{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#d977061a;border:1px solid rgba(217,119,6,.25);border-radius:8px;font-size:12px;font-weight:500;color:#d97706}.materials-search-panel{background:var(--surface-1);border:1px solid var(--border-default);border-radius:var(--radius-md);overflow:hidden}.materials-search-input-wrap{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border-subtle)}.materials-search-icon{flex-shrink:0;color:var(--text-muted)}.materials-search-input{flex:1;border:none;background:transparent;font-family:var(--font-body);font-size:14px;color:var(--text-primary);outline:none}.materials-search-input::placeholder{color:var(--text-muted)}.materials-search-results{max-height:240px;overflow-y:auto;-webkit-overflow-scrolling:touch}.materials-search-loading,.materials-search-empty{padding:16px;text-align:center;font-size:13px;color:var(--text-muted)}.materials-search-result{display:flex;justify-content:space-between;align-items:center;width:100%;padding:10px 14px;background:none;border:none;border-bottom:1px solid var(--border-subtle);cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent}.materials-search-result:last-child{border-bottom:none}.materials-search-result:active{background:var(--surface-2)}.materials-search-result:disabled{opacity:.5}.materials-result-info{flex:1;min-width:0}.materials-result-name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.materials-result-category{font-size:11px;color:var(--text-muted);margin-top:1px}.materials-result-sku{font-family:var(--font-mono);font-size:10px;opacity:.6;margin-left:6px}.materials-result-source{font-size:10px;font-weight:600;color:var(--accent);background:var(--accent-glow, rgba(13, 148, 136, .12));padding:1px 6px;border-radius:4px;margin-left:6px}.materials-result-price{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--accent);flex-shrink:0;margin-left:12px}.materials-custom-add{padding-bottom:4px}.materials-custom-form{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:8px 14px 12px}.materials-custom-input{height:36px;padding:0 10px;border:1px solid var(--border-default);border-radius:8px;background:var(--surface-2);font-family:var(--font-body);font-size:13px;color:var(--text-primary);outline:none}.materials-custom-input:focus{border-color:var(--accent)}.materials-custom-input::placeholder{color:var(--text-muted)}.materials-custom-name{flex:1;min-width:0}.materials-custom-price{width:80px;flex-shrink:0;font-family:var(--font-mono);text-align:right}.materials-custom-add-btn{height:36px;padding:0 14px;border:none;border-radius:8px;background:var(--accent);color:#fff;font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent}.materials-custom-add-btn:active{transform:scale(.97)}.materials-custom-add-btn:disabled{opacity:.4;cursor:not-allowed}.materials-empty{display:flex;flex-direction:column;align-items:center;gap:6px;padding:32px 16px;color:var(--text-muted);font-size:14px}.materials-empty-hint{font-size:12px;opacity:.6}.materials-list{display:flex;flex-direction:column;background:var(--surface-1);border:1px solid var(--border-default);border-radius:var(--radius-md);overflow:hidden}.materials-item{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;padding:10px 14px;gap:10px;border-bottom:1px solid var(--border-subtle)}.materials-item:last-child{border-bottom:none}.materials-item-info{flex:1;min-width:0}.materials-item-name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.materials-item-unit-price{font-size:11px;color:var(--text-muted);margin-top:1px}.materials-item-controls{display:flex;align-items:center;gap:10px;flex-shrink:0}.materials-qty-stepper{display:flex;align-items:center;gap:0;background:var(--surface-2);border:1px solid var(--border-default);border-radius:8px;overflow:hidden}.materials-qty-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;font-size:16px;font-weight:600;color:var(--text-primary);cursor:pointer;-webkit-tap-highlight-color:transparent}.materials-qty-btn:active{background:var(--surface-3)}.materials-qty-btn:disabled{color:var(--text-muted);opacity:.4}.materials-qty-value{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--text-primary);min-width:24px;text-align:center}.materials-item-total{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--text-primary);min-width:60px;text-align:right}.materials-remove-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:none;border-radius:6px;color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent}.materials-remove-btn:active{background:#ef44441f;color:var(--error)}.materials-totals{background:var(--surface-1);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:10px 14px}.materials-total-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:13px;color:var(--text-secondary)}.materials-total-value{font-family:var(--font-mono);font-weight:600}.materials-grand-total{border-top:2px solid var(--border-default);margin-top:4px;padding-top:8px;font-weight:700;color:var(--text-primary);font-size:15px}.materials-grand-total .materials-total-value{font-size:18px;font-weight:700;color:var(--text-primary)}.materials-item-tax-row{width:100%;display:flex;align-items:center;gap:10px;padding-top:4px}.materials-tax-row{width:100%;display:flex;align-items:center;gap:10px}.materials-tax-toggle{display:flex;align-items:center;gap:6px;cursor:pointer;-webkit-tap-highlight-color:transparent}.materials-tax-toggle input{display:none}.materials-tax-switch{width:32px;height:18px;border-radius:9px;background:var(--surface-3, #555);position:relative;transition:background .2s;flex-shrink:0}.materials-tax-switch:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform .2s}.materials-tax-toggle input:checked+.materials-tax-switch{background:var(--accent, #0d9488)}.materials-tax-toggle input:checked+.materials-tax-switch:after{transform:translate(14px)}.materials-tax-label{font-size:11px;font-weight:600;color:var(--text-secondary)}.materials-tax-rate-wrap{display:flex;align-items:center;gap:2px}.materials-tax-rate-input{width:72px;min-width:72px;height:28px;padding:4px 6px;border:1px solid var(--border-default);border-radius:6px;background:var(--surface-2);font-family:var(--font-mono);font-size:13px;color:var(--text-primary);text-align:right;outline:none}.materials-tax-rate-input:focus{border-color:var(--accent)}.materials-tax-pct{font-size:11px;color:var(--text-muted);font-weight:600;margin-left:4px}.materials-tax-amount{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);margin-left:auto}.job-sheet-overlay{position:fixed;inset:0;z-index:9000;background:#0006;display:flex;justify-content:flex-end}.job-sheet-panel{position:relative;width:min(85vw,480px);max-width:100vw;height:100dvh;background:var(--surface-1);overflow-y:auto;-webkit-overflow-scrolling:touch;padding:calc(20px + env(safe-area-inset-top,0px)) 20px calc(28px + env(safe-area-inset-bottom,0px));animation:jobSheetSlideIn .25s ease-out;box-shadow:-2px 0 16px #0000002e;display:flex;flex-direction:column;gap:14px}@keyframes jobSheetSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.job-sheet-close{position:absolute;top:max(12px,env(safe-area-inset-top,0px));right:12px;width:40px;height:40px;border-radius:50%;background:var(--surface-2);border:none;color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent;z-index:1}.job-sheet-close:active{background:var(--surface-3, var(--surface-2))}.job-sheet-loading,.job-sheet-empty{padding:40px 12px;text-align:center;color:var(--text-secondary);font-size:14px}.job-sheet-header{display:flex;align-items:center;gap:10px;padding-right:52px;margin-bottom:4px}.job-sheet-jobnum{font-family:var(--font-mono);font-size:14px;font-weight:700;color:var(--text-primary);letter-spacing:-.2px}.job-sheet-status{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;padding:3px 10px;border-radius:12px;border:1px solid var(--border-default);color:var(--text-secondary);background:var(--surface-2)}.job-sheet-status-completed{color:var(--success);border-color:var(--success)}.job-sheet-status-in_progress{color:var(--info);border-color:var(--info)}.job-sheet-status-cancelled{color:var(--error);border-color:var(--error)}.job-sheet-row{display:flex;flex-direction:column;gap:2px;padding:8px 0;border-bottom:1px solid var(--border-default)}.job-sheet-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted)}.job-sheet-value{font-size:14px;color:var(--text-primary);word-break:break-word}.job-sheet-section{display:flex;flex-direction:column;gap:6px;padding-top:6px}.job-sheet-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted)}.job-sheet-section-body{font-size:14px;color:var(--text-primary);line-height:1.45;white-space:pre-wrap;word-break:break-word}.job-sheet-photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.job-sheet-photo-tile{aspect-ratio:1;border-radius:var(--radius-sm, 6px);overflow:hidden;border:1px solid var(--border-default);background:var(--surface-2);padding:0;cursor:pointer;-webkit-tap-highlight-color:transparent}.job-sheet-photo-tile img{width:100%;height:100%;object-fit:cover;display:block}.job-sheet-materials{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.job-sheet-materials li{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border-default);font-size:13px;color:var(--text-primary)}.job-sheet-materials li:last-child{border-bottom:none}.job-sheet-material-desc{flex:1;min-width:0;word-break:break-word}.job-sheet-material-qty{flex-shrink:0;color:var(--text-secondary);font-size:12px}.customer-history{padding-bottom:16px}.ch-back-btn{display:flex;align-items:center;gap:4px;background:none;border:none;color:var(--accent);font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer;padding:4px 6px 4px 2px;border-radius:6px;-webkit-tap-highlight-color:transparent;margin-bottom:4px}.ch-back-btn:active{background:#0d94881a}.ch-customer-card{display:flex;align-items:center;gap:12px;background:var(--surface-1);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:14px 16px}.ch-customer-avatar{width:42px;height:42px;border-radius:12px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:18px;font-weight:700;flex-shrink:0}.ch-customer-info{flex:1;min-width:0}.ch-customer-name{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--text-primary);letter-spacing:-.2px}.ch-customer-detail{font-size:12px;color:var(--text-secondary);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ch-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);margin-top:4px}.ch-empty{display:flex;flex-direction:column;align-items:center;gap:6px;padding:32px 16px;color:var(--text-muted);font-size:13px}.ch-jobs-list{display:flex;flex-direction:column;gap:8px}.ch-job-card{background:var(--surface-1);border:1px solid var(--border-default);border-radius:var(--radius-md);overflow:hidden}.ch-job-card-button{display:block;width:100%;padding:0;text-align:left;font:inherit;color:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent}.ch-job-card-button:active{background:var(--surface-2)}.ch-job-address{font-size:12px;color:var(--text-secondary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ch-job-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:12px 14px;background:none;border:none;cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent;gap:10px}.ch-job-header:active{background:var(--surface-2)}.ch-job-main{flex:1;min-width:0}.ch-job-date{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);font-weight:500}.ch-job-type{font-size:13px;font-weight:600;color:var(--text-primary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ch-job-tech{font-size:11px;color:var(--text-secondary);margin-top:1px}.ch-job-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.ch-status-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:3px 8px;border-radius:12px;border:1px solid;background:transparent}.ch-job-expanded{border-top:1px solid var(--border-subtle);padding:10px 14px;display:flex;flex-direction:column;gap:8px}.ch-expand-row{display:flex;flex-direction:column;gap:2px}.ch-expand-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted)}.ch-expand-value{font-size:13px;color:var(--text-secondary);line-height:1.4;white-space:pre-wrap}.ch-photo-scroll{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}.ch-photo-scroll::-webkit-scrollbar{display:none}.ch-photo-thumb{position:relative;width:80px;height:80px;flex-shrink:0;border-radius:6px;overflow:hidden;background:var(--surface-3);border:1px solid var(--border-default);cursor:pointer;-webkit-tap-highlight-color:transparent}.ch-photo-thumb:active{opacity:.8}.ch-photo-thumb img{width:100%;height:100%;object-fit:cover}.ch-photo-label{position:absolute;bottom:3px;left:3px;font-size:8px;font-weight:700;color:#fff;background:#0009;padding:1px 4px;border-radius:3px;text-transform:uppercase;letter-spacing:.3px}.ch-no-photos{font-size:12px;color:var(--text-muted);padding:6px 0}.signature-section{display:flex;flex-direction:column;gap:12px}.signature-label{font-size:13px;color:var(--text-secondary)}.canvas-wrapper{position:relative;background:#f8fafc;border:2px solid var(--border-default);border-radius:var(--radius-md);height:200px}.signature-canvas{width:100%;height:100%;display:block;touch-action:none}.canvas-placeholder{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--text-muted);font-size:14px;pointer-events:none}.signature-saved{padding:16px;text-align:center;color:var(--success);font-weight:600;font-size:15px}[data-theme=dark] .canvas-wrapper{background:#f8fafc}.signature-section.embedded{gap:6px}.sig-label-row{display:flex;justify-content:space-between;align-items:center}.sig-label{font-size:12px;font-weight:600;color:var(--text-secondary)}.sig-clear{font-size:12px;font-weight:600;color:var(--error);background:none;border:none;cursor:pointer}.sig-canvas-wrap{position:relative;width:100%;height:100px;border-radius:var(--radius-md);background:#f8fafc;border:2px solid var(--border-default);overflow:hidden}.sig-canvas{width:100%;height:100%;display:block;touch-action:none}.sig-baseline{position:absolute;bottom:24px;left:20px;right:20px;height:1px;background:#80808033;pointer-events:none}.sig-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:13px;color:var(--text-muted);pointer-events:none}.completion-split{display:flex;flex-direction:column;height:100%;overflow:hidden}.completion-scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px 16px 0}.completion-title{font-family:var(--font-display);font-size:18px;font-weight:700;letter-spacing:-.3px;color:var(--text-primary);margin-bottom:12px}.invoice-card{border-radius:var(--radius-md);overflow:hidden;background:var(--surface-1);border:1px solid var(--border-default)}.invoice-header{font-family:var(--font-display);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:1px;padding:10px 14px;color:var(--text-secondary);border-bottom:1px solid var(--border-default)}.line-item{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid var(--border-subtle)}.line-item:last-of-type{border-bottom:none}.line-item-left{flex:1}.line-item-name{font-size:13px;font-weight:600;color:var(--text-primary)}.line-item-detail{font-size:11px;color:var(--text-muted);margin-top:1px}.line-item-price{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--text-primary)}.invoice-total{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-top:2px solid var(--border-default)}.total-label{font-size:14px;font-weight:700;color:var(--text-secondary)}.total-value{font-family:var(--font-mono);font-size:20px;font-weight:700;color:var(--text-primary)}.scroll-fade{height:20px;background:linear-gradient(transparent,var(--surface-0));pointer-events:none;flex-shrink:0}.sig-fixed{flex-shrink:0;padding:12px 16px 16px;display:flex;flex-direction:column;gap:10px}.name-field{display:flex;flex-direction:column;gap:4px}.name-input{width:100%;padding:10px 14px;border-radius:10px;font-family:var(--font-body);font-size:14px;outline:none;background:var(--surface-1);border:1px solid var(--border-default);color:var(--text-primary)}.name-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.name-input::placeholder{color:var(--text-muted)}.complete-button{width:100%;padding:14px;border-radius:14px;background:#059669;color:#fff;font-family:var(--font-display);font-size:16px;font-weight:700;border:none;cursor:pointer;letter-spacing:.3px;box-shadow:0 4px 16px #0596694d;display:flex;align-items:center;justify-content:center;gap:8px;-webkit-tap-highlight-color:transparent}.complete-button:active{transform:scale(.98)}.complete-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.completion-confirm-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:12px;animation:completionFadeIn .4s ease}@keyframes completionFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.completion-confirm-check{width:72px;height:72px;margin-bottom:8px}.completion-checkmark{width:72px;height:72px}.completion-checkmark-circle{stroke-dasharray:166;stroke-dashoffset:166;stroke-width:2;stroke-miterlimit:10;stroke:#059669;animation:completionStroke .6s cubic-bezier(.65,0,.45,1) forwards}.completion-checkmark-path{stroke-dasharray:48;stroke-dashoffset:48;stroke:#059669;stroke-width:3;stroke-linecap:round;animation:completionStroke .3s cubic-bezier(.65,0,.45,1) .4s forwards}@keyframes completionStroke{to{stroke-dashoffset:0}}.completion-confirm-title{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.completion-confirm-line{font-size:14px;color:var(--text-secondary)}.completion-confirm-amount{font-family:var(--font-mono);font-size:28px;font-weight:700;color:#059669;margin-top:4px}.checklist-overlay{position:fixed;inset:0;z-index:1000;background:#0009;display:flex;align-items:center;justify-content:center;padding:24px;animation:completionFadeIn .2s ease}.checklist-modal{background:var(--surface-1);border-radius:16px;padding:24px;width:100%;max-width:340px;box-shadow:0 8px 32px #0000004d}.checklist-title{font-family:var(--font-display);font-size:17px;font-weight:700;color:var(--text-primary);margin-bottom:16px;letter-spacing:-.2px}.checklist-items{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.checklist-item{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text-secondary)}.checklist-icon{width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:13px;font-weight:700;flex-shrink:0}.checklist-item.done .checklist-icon{background:#05966926;color:#059669}.checklist-item.missing .checklist-icon{background:#ef44441f;color:#ef4444}.checklist-item.done{color:var(--text-primary)}.checklist-item.missing{color:var(--text-muted)}.checklist-back-btn{width:100%;padding:12px;border-radius:12px;background:var(--surface-2);color:var(--text-primary);font-family:var(--font-display);font-size:14px;font-weight:600;border:1px solid var(--border-default);cursor:pointer;-webkit-tap-highlight-color:transparent}.checklist-back-btn:active{transform:scale(.98)}.payment-banner{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--radius-md);margin-bottom:12px;font-size:13px;font-weight:600;color:var(--text-primary)}.payment-banner.paid{background:#0596691f;border:1px solid rgba(5,150,105,.3);color:#059669}.payment-banner.pending{background:#d977061f;border:1px solid rgba(217,119,6,.3);color:#d97706}.payment-banner-detail{display:flex;flex-direction:column;gap:2px}.payment-banner-meta{font-family:var(--font-mono);font-size:11px;opacity:.8;font-weight:500}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}:root{--font-display: "Outfit", "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-body: "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "DM Mono", "SF Mono", monospace;--text-xs: .6875rem;--text-sm: .8125rem;--text-base: .875rem;--text-md: .9375rem;--text-lg: 1.0625rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--weight-normal: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--leading-tight: 1.2;--leading-normal: 1.5;--surface-0: #F8FAFC;--surface-1: #FFFFFF;--surface-2: #F1F5F9;--surface-3: #F1F5F9;--surface-4: #E2E8F0;--border-subtle: #F1F5F9;--border-default: #E2E8F0;--border-strong: #CBD5E1;--border-focus: #0D9488;--shadow-sm: 0 1px 3px rgba(15, 23, 42, .06);--shadow-md: 0 4px 6px rgba(15, 23, 42, .05);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--primary: #0F172A;--accent: #0D9488;--accent-hover: #0F766E;--text-primary: #0F172A;--text-secondary: #64748B;--text-muted: #94A3B8;--text-inverse: #FFFFFF;--success: #10B981;--warning: #F59E0B;--error: #EF4444;--info: #3B82F6;--red: #EF4444;--green: #10B981;--yellow: #F59E0B;--blue: #3B82F6;--ease-default: cubic-bezier(.4, 0, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--duration-fast: .15s;--duration-base: .2s;--duration-slow: .3s;--accent-glow: rgba(13, 148, 136, .25);--accent-light: #0F766E;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}[data-theme=dark],.dark{color-scheme:dark;--surface-0: #060B14;--surface-1: #0C1523;--surface-2: #142035;--surface-3: #1E2D45;--surface-4: #2A3D5C;--text-primary: #F0F4F8;--text-secondary: #8FA3BF;--text-muted: #5A7395;--text-inverse: #0F172A;--border-subtle: #142035;--border-default: #1E2D45;--border-strong: #2A3D5C;--border-focus: #0D9488;--shadow-sm: 0 1px 3px rgba(0,0,0,.3);--shadow-md: 0 4px 6px rgba(0,0,0,.35);--primary: #0C1523;--accent: #0D9488;--accent-hover: #14B8A6;--success: #34D399;--warning: #FBBF24;--error: #F87171;--info: #60A5FA;--red: #F87171;--green: #34D399;--yellow: #FBBF24;--blue: #60A5FA}[data-theme=dark] .field-job-card,.dark .field-job-card{background:var(--surface-1);border-color:var(--border-default)}[data-theme=dark] .field-job-customer,.dark .field-job-customer{color:var(--text-primary)}[data-theme=dark] .field-job-type,.dark .field-job-type,[data-theme=dark] .field-job-meta-item,.dark .field-job-meta-item{color:var(--text-secondary)}[data-theme=dark] .field-navigate-btn,.dark .field-navigate-btn{background:var(--accent)}[data-theme=dark] .field-navigate-btn:hover,.dark .field-navigate-btn:hover{background:var(--accent-hover)}[data-theme=dark] .field-status-btn.dispatch,.dark .field-status-btn.dispatch{background:var(--surface-3);color:var(--text-primary)}[data-theme=dark] .field-sms-btn,.dark .field-sms-btn{background:#0d94881f;border-color:#0d94884d;color:#5eead4}[data-theme=dark] .field-sms-btn:hover,.dark .field-sms-btn:hover{background:#0d948833}[data-theme=dark] .field-timer-display,.dark .field-timer-display{color:var(--text-primary)}[data-theme=dark] .badge-success,.dark .badge-success{background:#10b98126;color:#6ee7b7}[data-theme=dark] .badge-warning,.dark .badge-warning{background:#f59e0b26;color:#fcd34d}[data-theme=dark] .badge-error,.dark .badge-error{background:#ef444426;color:#fca5a5}[data-theme=dark] .badge-info,.dark .badge-info{background:#3b82f626;color:#93c5fd}html,body{height:100%;font-family:var(--font-display);font-size:16px;line-height:var(--leading-normal);background-color:var(--surface-0);color:var(--text-primary);-webkit-font-smoothing:antialiased;overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column}h1{font-size:var(--text-2xl);font-weight:var(--weight-bold);letter-spacing:-.025em}h2{font-size:var(--text-xl);font-weight:var(--weight-semibold);letter-spacing:-.02em}h3{font-size:var(--text-lg);font-weight:var(--weight-semibold)}.app-wrapper{flex:1;display:flex;flex-direction:column;height:100vh}.page{flex:1;display:flex;flex-direction:column;overflow:hidden;padding-bottom:calc(env(safe-area-inset-bottom) + 64px)}.page-header{padding:calc(var(--safe-top) + 16px) 20px 16px;background:var(--surface-1);border-bottom:1px solid var(--border-default)}.page-title{font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--text-primary)}.page-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin-top:2px}.page-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:48px;padding:0 20px;border-radius:var(--radius-md);font-family:var(--font-display);font-size:var(--text-md);font-weight:var(--weight-medium);border:none;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.btn:active{transform:scale(.98);opacity:.9}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:var(--text-inverse)}[data-theme=dark] .btn-primary,.dark .btn-primary{background:var(--accent)}.btn-accent{background:var(--accent);color:var(--text-inverse)}.btn-accent:hover{background:var(--accent-hover)}.btn-secondary{background:var(--surface-3);color:var(--text-primary);border:1px solid var(--border-default)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-sm{min-height:36px;padding:0 12px;font-size:var(--text-sm)}.btn-lg{min-height:56px;font-size:var(--text-lg);font-weight:var(--weight-bold)}.btn-full{width:100%}.card{background:var(--surface-1);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:var(--text-xs);font-weight:var(--weight-bold);text-transform:uppercase;letter-spacing:.05em}.badge-success{background:#ecfdf5;color:#10b981}.badge-warning{background:#fffbeb;color:#f59e0b}.badge-error{background:#fef2f2;color:#ef4444}.badge-info{background:#eff6ff;color:#3b82f6}.filter-tabs{display:flex;gap:4px;background:var(--surface-3);padding:4px;border-radius:var(--radius-lg);margin-bottom:16px}.filter-tab{flex:1;padding:8px 12px;font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-secondary);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s;text-align:center}.filter-tab.active{background:var(--surface-1);color:var(--text-primary);box-shadow:var(--shadow-sm)}.bottom-nav{display:none}.offline-banner{background:var(--error);color:#fff;text-align:center;padding:8px;font-size:var(--text-sm);font-weight:var(--weight-bold);position:sticky;top:0;z-index:1100}.divider{height:1px;background:var(--border-default);margin:16px 0}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .3s ease-out forwards}.field-btn-primary{position:fixed;bottom:0;left:0;right:0;padding:16px;background:var(--surface-1);border-top:1px solid var(--border-default);z-index:100;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px))}.field-btn-primary .btn{width:100%;height:52px;font-size:1rem;font-weight:600;border-radius:12px}.field-content-area{padding-bottom:90px}.spinner{width:32px;height:32px;border:3px solid var(--border-default);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.field-app-root{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}.field-job-card{background:#fff;border:1px solid #E2E8F0;border-radius:16px;padding:18px;margin-bottom:12px;cursor:pointer;position:relative;overflow:hidden;-webkit-tap-highlight-color:rgba(13,148,136,.1);transition:transform .1s,box-shadow .1s}.field-job-card:active{transform:scale(.99)}.field-job-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px}.field-job-card.dispatched:before{background:#f59e0b}.field-job-card.on_the_way:before{background:#3b82f6}.field-job-card.in_progress:before{background:#10b981;animation:shimmerBar 2s ease infinite}.field-job-card.scheduled:before{background:#94a3b8}@keyframes shimmerBar{0%,to{opacity:1}50%{opacity:.5}}.field-job-customer{font-size:1.0625rem;font-weight:700;color:#0f172a;margin-bottom:4px;letter-spacing:-.01em}.field-job-type{font-size:.875rem;color:#475569;margin-bottom:12px}.field-job-meta{display:flex;gap:14px;align-items:center}.field-job-meta-item{display:flex;align-items:center;gap:5px;font-size:.8125rem;color:#64748b}.field-job-meta-item svg{width:14px;height:14px}.field-navigate-btn{position:absolute;bottom:14px;right:14px;height:36px;width:36px;background:#0f172a;border:none;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:background .15s}.field-navigate-btn:hover{background:#1e293b}.field-navigate-btn svg{width:18px;height:18px}.field-status-btn{width:100%;height:60px;border:none;border-radius:14px;font-family:DM Sans,sans-serif;font-size:1.0625rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;letter-spacing:-.01em;transition:transform .1s,box-shadow .1s;-webkit-tap-highlight-color:transparent}.field-status-btn:active{transform:scale(.98)}.field-status-btn svg{width:22px;height:22px}.field-status-btn.dispatch{background:#0f172a;color:#fff}.field-status-btn.on-way{background:#3b82f6;color:#fff;box-shadow:0 4px 14px #3b82f64d}.field-status-btn.arrived{background:#f97316;color:#fff}.field-status-btn.complete{background:#059669;color:#fff;box-shadow:0 4px 14px #05966959}.field-sms-btn{width:100%;height:46px;background:#f0fdfa;border:1.5px solid #99F6E4;border-radius:12px;font-family:DM Sans,sans-serif;font-size:.9375rem;font-weight:600;color:#0f766e;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:10px;transition:background .15s}.field-sms-btn:hover{background:#ccfbf1}.field-timer-display{font-family:DM Mono,monospace;font-size:3.5rem;font-weight:500;color:#0f172a;letter-spacing:-.02em;text-align:center;padding:24px 0;line-height:1}.field-timer-running{color:#059669}.field-timer-paused{color:#94a3b8}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;background:var(--surface-1);border-top:1px solid var(--border-default);padding:8px 8px calc(8px + var(--safe-bottom));z-index:100}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:7px 2px;border-radius:var(--radius-sm);cursor:pointer;position:relative;background:none;border:none;color:var(--text-muted);transition:color var(--duration-fast) var(--ease-default);-webkit-tap-highlight-color:transparent;text-decoration:none}.nav-item:active{opacity:.7}.nav-item.active{color:var(--accent)}.nav-dot{position:absolute;top:2px;width:4px;height:4px;border-radius:50%;background:var(--accent)}.nav-label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;font-family:var(--font-body)}.normal-nav .nav-item{padding:10px 4px}.normal-nav .nav-item svg{width:24px;height:24px}.normal-nav .nav-label{font-size:10px;letter-spacing:.5px}.cockpit-nav .nav-item svg{width:20px;height:20px}.cockpit-nav .nav-item.complete-btn{background:var(--success);border-radius:var(--radius-md);color:#fff}.cockpit-nav .nav-item.complete-btn .nav-label{color:#fff}.cockpit-nav .nav-item.complete-btn:active{opacity:.85}[data-theme=dark] .bottom-nav,.dark .bottom-nav{background:#0c1523;border-color:#ffffff0f}.field-header{position:sticky;top:0;z-index:50;background:#0f172a;border-bottom:1px solid rgba(255,255,255,.08);height:calc(56px + env(safe-area-inset-top,0px));display:flex;align-items:center;padding:0 16px;padding-top:env(safe-area-inset-top,0px);gap:12px;flex-shrink:0}.field-header-back{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#ffffff14;border:none;border-radius:10px;color:#fff;cursor:pointer;flex-shrink:0}.field-header-back:active{background:#ffffff26}.profile-page{padding:calc(16px + var(--safe-top)) 16px calc(80px + var(--safe-bottom));background:var(--surface-0);min-height:100dvh}.profile-header{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px 0}.profile-avatar{width:64px;height:64px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:24px;font-weight:700}.profile-name{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--text-primary)}.profile-role{font-size:13px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.profile-section{padding:16px 0;border-top:1px solid var(--border-default)}.theme-toggle{display:flex;gap:8px;margin-top:8px}.theme-btn{flex:1;padding:10px;border-radius:var(--radius-sm);border:1px solid var(--border-default);background:var(--surface-1);color:var(--text-secondary);font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent}.theme-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.logout-btn{width:100%;padding:14px;border-radius:var(--radius-md);border:1px solid var(--error);background:transparent;color:var(--error);font-family:var(--font-display);font-size:15px;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent}.profile-version{text-align:center;padding:24px;font-size:12px;color:var(--text-muted)}.field-header-title{flex:1;font-size:1rem;font-weight:700;color:#fff;margin:0}.field-header-right{display:flex;align-items:center;gap:8px}.cockpit-layout{display:flex;flex-direction:column;height:100dvh;padding-bottom:calc(64px + var(--safe-bottom))}.cockpit-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.cockpit-loading{display:flex;align-items:center;justify-content:center;height:100dvh}.job-header{background:linear-gradient(135deg,var(--surface-1),var(--surface-2));border-bottom:1px solid var(--border-default);padding:calc(12px + var(--safe-top)) 16px 14px;flex-shrink:0}.job-header-top{display:flex;align-items:center;gap:8px;margin-bottom:8px}.job-header-back{display:flex;align-items:center;gap:2px;background:none;border:none;color:var(--accent);font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer;padding:4px 6px 4px 2px;border-radius:6px;-webkit-tap-highlight-color:transparent;margin-right:auto}.job-header-back:active{background:var(--accent-glow)}.job-id{font-family:var(--font-mono);font-size:12px;color:var(--accent);background:var(--accent-glow);padding:3px 8px;border-radius:6px;font-weight:500}.job-status-badge{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;padding:4px 10px;border-radius:20px;background:#f59e0b26;color:var(--warning)}.job-status-badge.working{background:#3b82f626;color:var(--info)}.job-status-badge.completed{background:#10b98126;color:var(--success)}.job-header-helper-badge{font-size:12px;font-weight:600;color:var(--accent, #6366f1);background:#6366f11a;border:1px solid rgba(99,102,241,.25);border-radius:8px;padding:6px 10px;margin-bottom:8px}.customer-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.customer-info{flex:1;min-width:0}.customer-name{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--text-primary);letter-spacing:-.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.customer-address{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.navigate-btn{flex-shrink:0;width:48px;height:48px;border-radius:14px;background:var(--accent);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 16px var(--accent-glow);-webkit-tap-highlight-color:transparent}.navigate-btn svg{width:22px;height:22px}.navigate-btn:active{transform:scale(.95)}.timer-bar{display:flex;align-items:center;justify-content:space-between;background:var(--surface-1);border-radius:var(--radius-md);padding:12px 16px;border:1px solid var(--border-default)}.timer-left{display:flex;align-items:center;gap:10px}.timer-dot{width:10px;height:10px;border-radius:50%;background:var(--success);animation:pulse 2s infinite}.timer-dot.paused,.timer-dot.idle{background:var(--text-muted);animation:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.timer-label{font-size:12px;color:var(--text-secondary)}.timer-value{font-family:var(--font-mono);font-size:22px;font-weight:500;color:var(--text-primary);letter-spacing:1px}.timer-controls{display:flex;gap:8px}.timer-btn{width:36px;height:36px;border-radius:10px;background:var(--surface-2);border:1px solid var(--border-default);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);-webkit-tap-highlight-color:transparent}.timer-btn:active{background:var(--surface-3)}.section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);margin-bottom:10px}.status-track{display:flex;gap:6px}.status-step{flex:1;padding:10px 6px;border-radius:var(--radius-sm);text-align:center;font-size:11px;font-weight:600;border:1px solid transparent;cursor:pointer;transition:all var(--duration-fast) var(--ease-default);-webkit-tap-highlight-color:transparent}.status-step.completed{background:#10b9811f;color:var(--success);border-color:#10b98133}.status-step.active{background:#3b82f626;color:var(--info);border-color:#3b82f64d;box-shadow:0 0 12px #3b82f626}.status-step.upcoming{background:var(--surface-1);color:var(--text-muted);border-color:var(--border-default)}.status-step-icon{margin-bottom:2px}.detail-card{background:var(--surface-1);border-radius:var(--radius-md);padding:14px 16px;border:1px solid var(--border-default)}.detail-card-title{font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0}.detail-row+.detail-row{border-top:1px solid var(--border-subtle)}.detail-label{font-size:13px;color:var(--text-secondary)}.detail-value{font-size:13px;font-weight:600;color:var(--text-primary)}.detail-value.mono{font-family:var(--font-mono);font-size:12px;color:var(--accent)}.equipment-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.equipment-pill{font-size:11px;font-weight:500;padding:7px 12px;border-radius:20px;background:var(--surface-2);color:var(--text-secondary);border:1px solid var(--border-default);cursor:pointer;font-family:inherit;transition:background .12s ease,border-color .12s ease,color .12s ease;-webkit-tap-highlight-color:transparent}.equipment-pill:hover{background:var(--surface-3);border-color:var(--border-strong, var(--border-default));color:var(--text-primary)}.equipment-pill:active{background:var(--accent-bg, var(--surface-3));border-color:var(--accent, var(--border-default));color:var(--accent, var(--text-primary))}.contact-row .detail-value{gap:6px}.contact-action-btn{width:30px;height:30px;border-radius:8px;background:var(--accent-glow, rgba(99, 102, 241, .12));border:1px solid rgba(99,102,241,.2);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:var(--accent);flex-shrink:0;-webkit-tap-highlight-color:transparent;transition:background .15s}.contact-action-btn:active{background:#6366f140;transform:scale(.93)}.contact-action-btn:disabled{opacity:.4;pointer-events:none}.customer-secondary-contacts{display:flex;flex-direction:column;border-top:1px solid var(--border-subtle)}.customer-secondary-row{display:flex;align-items:center;gap:6px;width:100%;padding:10px 16px;background:none;border:none;border-bottom:1px solid var(--border-subtle);text-align:left;font:inherit;color:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent}.customer-secondary-row:last-child{border-bottom:none}.customer-secondary-row:active{background:var(--surface-2)}.cs-name{font-size:13px;font-weight:600;color:var(--text-primary)}.cs-label{font-size:12px;color:var(--text-muted)}.cs-chevron{margin-left:auto;color:var(--accent);flex-shrink:0}.sms-sheet-overlay{position:fixed;inset:0;z-index:1000;background:#0000008c;display:flex;align-items:flex-end;justify-content:center}.sms-sheet{width:100%;max-width:480px;background:var(--surface-1);border-radius:20px 20px 0 0;padding:20px 20px calc(20px + env(safe-area-inset-bottom,16px));box-shadow:0 -8px 32px #0000004d;margin-bottom:70px}.sms-sheet-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.sms-sheet-title{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--text-primary)}.sms-sheet-close{width:32px;height:32px;border-radius:50%;background:var(--surface-2);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);-webkit-tap-highlight-color:transparent}.sms-sheet-close:active{background:var(--surface-3)}.sms-sheet-input{width:100%;min-height:80px;padding:12px;border-radius:var(--radius-md);border:1px solid var(--border-default);background:var(--surface-2);color:var(--text-primary);font-family:var(--font-body);font-size:14px;line-height:1.5;resize:none;outline:none;box-sizing:border-box}.sms-sheet-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.sms-sheet-send{width:100%;margin-top:12px;padding:14px;border-radius:8px;background:#1d9e75;color:#fff;font-family:var(--font-display);font-size:15px;font-weight:500;border:none;min-height:48px;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-appearance:none;appearance:none}.sms-sheet-send:active{opacity:.85}.sms-sheet-send:disabled{opacity:.4;pointer-events:none}.cockpit-tab{padding:16px;display:flex;flex-direction:column;gap:12px}.notes-textarea{width:100%;min-height:280px;padding:14px;border-radius:var(--radius-md);border:1px solid var(--border-default);background:var(--surface-1);color:var(--text-primary);font-family:var(--font-body);font-size:14px;line-height:1.6;resize:vertical;outline:none}.notes-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.vn-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;min-height:44px;padding:10px 16px;border-radius:var(--radius-md);border:1px solid var(--border-default);background:var(--surface-1);color:var(--text-secondary);font-family:var(--font-body);font-size:14px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,color .15s;-webkit-tap-highlight-color:transparent}.vn-btn:hover{background:var(--surface-2);color:var(--text-primary)}.vn-btn:disabled{cursor:not-allowed;opacity:.7}.vn-icon{flex-shrink:0}.vn-btn-recording{border-color:var(--color-danger, #ef4444);color:var(--color-danger, #ef4444);background:var(--surface-1)}.vn-pulse{display:inline-block;width:12px;height:12px;border-radius:50%;background:var(--color-danger, #ef4444);flex-shrink:0;animation:vn-pulse-anim 1.2s ease-in-out infinite}@keyframes vn-pulse-anim{0%,to{opacity:1;box-shadow:0 0 #ef444466}50%{opacity:.6;box-shadow:0 0 0 8px #ef444400}}.vn-btn-processing{color:var(--accent);border-color:var(--accent)}.vn-spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--border-default);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;animation:vn-spin .7s linear infinite}@keyframes vn-spin{to{transform:rotate(360deg)}}[data-theme=dark] .vn-btn-recording{background:color-mix(in srgb,var(--color-danger, #ef4444) 8%,transparent)}[data-theme=dark] .vn-btn-processing{background:color-mix(in srgb,var(--accent) 8%,transparent)}.photo-capture{display:flex;flex-direction:column;gap:16px}.category-tabs{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding:4px 0}.category-tabs::-webkit-scrollbar{display:none}.category-tab{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-lg);border:1px solid var(--border-default);background:var(--surface-1);font-size:13px;font-weight:700;color:var(--text-secondary);cursor:pointer;white-space:nowrap}.category-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.cat-count{background:#0000001a;border-radius:6px;padding:0 6px;font-size:11px}.category-tab.active .cat-count{background:#fff3}.photo-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.photo-thumb{position:relative;aspect-ratio:4/3;border-radius:var(--radius-md);overflow:hidden;background:var(--surface-3);border:1px solid var(--border-default)}.photo-thumb img{width:100%;height:100%;object-fit:cover}.photo-remove{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:#ef4444e6;color:#fff;border:none;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003}.photo-thumb--failed{border-color:var(--yellow, #f59e0b);box-shadow:0 0 0 1px var(--yellow, #f59e0b)}.photo-thumb--failed img{opacity:.6}.photo-retry{position:absolute;bottom:8px;right:8px;width:36px;height:36px;border-radius:50%;background:var(--yellow, #f59e0b);color:#000;border:none;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #0000004d;transition:transform .15s ease}.photo-retry:active{transform:scale(.9)}.photo-retry:disabled{opacity:.6;cursor:default}.photo-upload-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;border:2px dashed var(--border-strong);border-radius:var(--radius-md);aspect-ratio:4/3;color:var(--text-muted);cursor:pointer}.photo-upload-placeholder:active{background:var(--surface-3)}.photo-grid-readonly{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.photo-grid-thumb{position:relative;width:100%;height:100px;border-radius:8px;overflow:hidden;background:var(--surface-3);border:1px solid var(--border-default);cursor:pointer;-webkit-tap-highlight-color:transparent}.photo-grid-thumb:active{opacity:.8}.photo-grid-thumb img{width:100%;height:100%;object-fit:cover}.photo-grid-label{position:absolute;bottom:4px;left:4px;font-size:9px;font-weight:700;color:#fff;background:#0009;padding:1px 5px;border-radius:3px;text-transform:uppercase;letter-spacing:.4px}.ai-chat-root{display:flex;flex-direction:column;height:100vh;background:var(--surface-0);padding-bottom:calc(64px + env(safe-area-inset-bottom,0px))}.ai-chat-header{padding:calc(env(safe-area-inset-top,0px) + 14px) 20px 12px;background:var(--surface-1);border-bottom:1px solid var(--border-default);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.ai-chat-header-left{display:flex;align-items:center;gap:10px}.ai-chat-avatar{width:36px;height:36px;border-radius:18px;background:linear-gradient(135deg,#0d9488,#0891b2);display:flex;align-items:center;justify-content:center;flex-shrink:0}.ai-chat-name{font-weight:700;font-size:1rem;color:var(--text-primary)}.ai-chat-status{font-size:.6875rem;color:var(--text-muted)}.ai-chat-clear{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;-webkit-tap-highlight-color:transparent}.ai-chat-clear:active{opacity:.5}.ai-chat-messages{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px;display:flex;flex-direction:column;gap:12px}.ai-chat-welcome{text-align:center;padding:24px 0 16px}.ai-chat-welcome-icon{width:56px;height:56px;border-radius:28px;background:linear-gradient(135deg,#0d9488,#0891b2);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.ai-chat-welcome-title{color:var(--text-primary);font-weight:800;font-size:1.125rem;margin-bottom:8px}.ai-chat-welcome-sub{color:var(--text-muted);font-size:.875rem;line-height:1.5;max-width:260px;margin:0 auto}.ai-chat-prompts{display:flex;flex-direction:column;gap:8px}.ai-chat-prompt-btn{background:var(--surface-1);border:1px solid var(--border-default);border-radius:12px;padding:12px 16px;cursor:pointer;text-align:left;color:var(--text-primary);font-size:.875rem;font-family:inherit;font-weight:500;transition:all .15s;display:flex;align-items:center;justify-content:space-between;gap:8px;-webkit-tap-highlight-color:transparent}.ai-chat-prompt-btn:active{background:var(--surface-3);transform:scale(.99)}.ai-chat-row{display:flex;animation:ai-chat-fadeIn .2s ease}@keyframes ai-chat-fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.ai-chat-row-user{justify-content:flex-end}.ai-chat-row-ai{justify-content:flex-start;align-items:flex-end;gap:8px}.ai-chat-bubble-avatar{width:28px;height:28px;border-radius:14px;background:linear-gradient(135deg,#0d9488,#0891b2);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-bottom:4px}.ai-chat-bubble{max-width:78%;padding:12px 16px}.ai-chat-bubble-user{background:#0d9488;border-radius:18px 18px 4px}.ai-chat-bubble-ai{background:var(--surface-1);border:1px solid var(--border-default);border-radius:18px 18px 18px 4px}.ai-chat-bubble-error{background:#ef444414!important;border-color:#ef444433!important}.ai-chat-text{color:#fff;font-size:.9375rem;line-height:1.55;margin:0;white-space:pre-wrap}.ai-chat-bubble-error .ai-chat-text,.ai-chat-bubble-error .ai-chat-answer{color:var(--error)}.ai-chat-time{font-size:.625rem;color:var(--text-muted);margin-top:4px}.ai-chat-time-right{text-align:right;color:#ffffff80}.ai-chat-answer{color:var(--text-primary);font-size:.9375rem;line-height:1.55;word-break:break-word}.ai-chat-answer h4{font-size:.875rem;font-weight:700;margin:10px 0 4px;color:var(--text-primary)}.ai-chat-answer h5{font-size:.8125rem;font-weight:700;margin:8px 0 2px}.ai-chat-answer ul{margin:4px 0;padding-left:18px;list-style:none}.ai-chat-answer li{margin-bottom:3px;position:relative;padding-left:4px}.ai-chat-answer li:before{content:"";position:absolute;left:-12px;top:8px;width:5px;height:5px;border-radius:50%;background:#0d9488}.ai-chat-answer strong{color:var(--text-primary);font-weight:700}.ai-chat-typing{display:flex;gap:4px;align-items:center;padding:2px 0}.ai-chat-typing span{width:6px;height:6px;border-radius:3px;background:var(--text-muted);animation:ai-chat-bounce 1.2s infinite}.ai-chat-typing span:nth-child(2){animation-delay:.2s}.ai-chat-typing span:nth-child(3){animation-delay:.4s}@keyframes ai-chat-bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}.ai-chat-input-bar{padding:12px 16px;background:var(--surface-1);border-top:1px solid var(--border-default);flex-shrink:0}.ai-chat-input-wrap{display:flex;gap:8px;align-items:flex-end;background:var(--surface-2);border-radius:24px;padding:6px 6px 6px 14px;border:1px solid var(--border-default)}.ai-chat-input-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #0d948814}.ai-chat-textarea{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-size:.9375rem;font-family:inherit;resize:none;line-height:1.5;max-height:120px;padding:6px 0}.ai-chat-textarea::placeholder{color:var(--text-muted)}.ai-chat-voice-btn{width:36px;height:36px;border-radius:18px;border:none;background:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;-webkit-tap-highlight-color:transparent;transition:all .15s}.ai-chat-voice-btn:active{opacity:.6}.ai-chat-voice-active{background:#ef4444!important;color:#fff!important;animation:ai-chat-pulse 1.2s ease-in-out infinite}@keyframes ai-chat-pulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 8px #ef444400}}.ai-chat-send-btn{width:36px;height:36px;border-radius:18px;border:none;background:var(--surface-3);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;-webkit-tap-highlight-color:transparent}.ai-chat-send-active{background:#0d9488;color:#fff}.ai-chat-send-btn:disabled{cursor:default}.ai-chat-spin{animation:spin 1s linear infinite}.ai-fab{position:fixed;bottom:80px;right:16px;width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#0d9488,#0891b2);border:none;font-size:22px;color:#fff;cursor:pointer;box-shadow:0 4px 16px #0d948866;z-index:1000;display:flex;align-items:center;justify-content:center;transition:transform .2s;-webkit-tap-highlight-color:transparent}.ai-fab:active{transform:scale(.9)}.ai-fab-active{background:linear-gradient(135deg,#64748b,#475569);box-shadow:0 4px 12px #47556966;font-size:18px}.ai-panel{position:fixed;bottom:0;left:0;right:0;height:70vh;max-height:600px;background:var(--surface-1, #fff);border-radius:20px 20px 0 0;box-shadow:0 -8px 40px #0000002e;z-index:999;display:flex;flex-direction:column;animation:slideUp .25s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.ai-panel-header{display:flex;align-items:center;gap:8px;padding:16px 20px;border-bottom:1px solid var(--border-default, #e5e7eb);flex-shrink:0}.ai-panel-title{font-size:17px;font-weight:700;color:var(--text-primary)}.ai-panel-subtitle{font-size:13px;color:var(--text-muted);font-weight:500}.ai-quick-prompts{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:16px 20px;flex-shrink:0}.ai-quick-btn{background:var(--surface-3);border:1px solid var(--border-default);border-radius:10px;padding:12px;font-size:13px;font-weight:600;color:var(--text-primary);cursor:pointer;text-align:left;transition:background .15s;-webkit-tap-highlight-color:transparent}.ai-quick-btn:active{background:#0d9488;color:#fff;border-color:transparent}.ai-messages{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:12px;-webkit-overflow-scrolling:touch}.ai-msg{max-width:88%;animation:ai-chat-fadeIn .2s ease}.ai-msg-user{align-self:flex-end}.ai-msg-ai{align-self:flex-start}.ai-msg-content{border-radius:14px;padding:10px 14px;font-size:14px;line-height:1.55}.ai-msg-user .ai-msg-content{background:#0d9488;color:#fff;border-bottom-right-radius:4px}.ai-msg-ai .ai-msg-content{background:var(--surface-3);color:var(--text-primary);border-bottom-left-radius:4px}.ai-msg-error .ai-msg-content{background:#ef444414;color:var(--error)}.ai-question{white-space:pre-wrap}.ai-answer{word-break:break-word}.ai-answer h4{font-size:14px;font-weight:700;margin:8px 0 4px;color:var(--text-primary)}.ai-answer h5{font-size:13px;font-weight:700;margin:6px 0 2px}.ai-answer ul{margin:4px 0;padding-left:18px;list-style:none}.ai-answer li{margin-bottom:3px;position:relative;padding-left:4px}.ai-answer li:before{content:"";position:absolute;left:-12px;top:8px;width:5px;height:5px;border-radius:50%;background:#0d9488}.ai-answer strong{color:var(--text-primary)}.ai-feedback{display:flex;align-items:center;gap:6px;margin-top:4px;padding-left:4px}.ai-feedback-label{font-size:11px;color:var(--text-muted)}.ai-fb-btn{background:none;border:1px solid var(--border-default);border-radius:6px;padding:2px 8px;font-size:14px;cursor:pointer;transition:background .15s}.ai-fb-btn:active{background:var(--surface-3)}.ai-feedback-done{font-size:12px;color:var(--text-muted)}.ai-feedback-thanks{font-size:12px;color:#10b981;font-weight:600}.ai-response-time{font-size:11px;color:var(--text-muted);margin-left:auto}.ai-thinking{display:flex;align-items:center;gap:8px;color:var(--text-muted);font-size:13px}.ai-dots{display:flex;gap:4px}.ai-dots span{width:6px;height:6px;border-radius:50%;background:var(--text-muted);animation:ai-chat-bounce 1.2s infinite}.ai-dots span:nth-child(2){animation-delay:.2s}.ai-dots span:nth-child(3){animation-delay:.4s}.ai-input-bar{display:flex;align-items:flex-end;gap:8px;padding:12px 16px;border-top:1px solid var(--border-default);background:var(--surface-1);flex-shrink:0;padding-bottom:max(12px,env(safe-area-inset-bottom))}.ai-input{flex:1;border:1px solid var(--border-default);border-radius:12px;padding:10px 14px;font-size:15px;resize:none;background:var(--surface-2);color:var(--text-primary);font-family:inherit;line-height:1.4;max-height:100px;outline:none}.ai-input:focus{border-color:#0d9488;box-shadow:0 0 0 3px #0d948814}.ai-voice-btn,.ai-send-btn{width:40px;height:40px;border-radius:50%;border:none;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s;-webkit-tap-highlight-color:transparent}.ai-voice-btn{background:var(--surface-3);color:var(--text-secondary)}.ai-voice-active{background:#ef4444!important;color:#fff!important;animation:ai-chat-pulse 1.2s ease-in-out infinite}.ai-send-btn{background:#0d9488;color:#fff}.ai-send-btn:disabled{opacity:.4;cursor:default}.ai-cockpit{display:flex;flex-direction:column;height:100%;overflow:hidden}.ai-cockpit-context{display:flex;align-items:center;gap:6px;padding:10px 16px;font-size:12px;color:var(--accent);background:var(--accent-glow);border-bottom:1px solid var(--border-default)}.ai-cockpit-messages{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px;display:flex;flex-direction:column;gap:12px}.ai-cockpit-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:14px;text-align:center;padding:24px}.ai-msg-row{display:flex}.ai-msg-row.user{justify-content:flex-end}.ai-msg-row.assistant{justify-content:flex-start}.ai-msg-bubble{max-width:80%;padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.5;white-space:pre-wrap;word-wrap:break-word}.ai-msg-bubble.user{background:var(--accent);color:#fff;border-bottom-right-radius:4px}.ai-msg-bubble.assistant{background:var(--surface-1);color:var(--text-primary);border:1px solid var(--border-default);border-bottom-left-radius:4px}.ai-msg-bubble.error{background:#ef44441a;color:var(--error);border-color:#ef444433}.typing-dots{display:flex;gap:4px;padding:4px 0}.typing-dots span{width:6px;height:6px;border-radius:50%;background:var(--text-muted);animation:bounce 1.2s infinite}.typing-dots span:nth-child(2){animation-delay:.15s}.typing-dots span:nth-child(3){animation-delay:.3s}@keyframes bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-6px)}}.ai-cockpit-input{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border-default);background:var(--surface-1);align-items:flex-end}.ai-cockpit-input textarea{flex:1;border:none;background:var(--surface-2);color:var(--text-primary);font-family:var(--font-body);font-size:14px;padding:10px 14px;border-radius:20px;resize:none;outline:none;max-height:100px}.ai-cockpit-input textarea:focus{box-shadow:0 0 0 2px var(--accent-glow)}.ai-send{width:40px;height:40px;border-radius:50%;border:none;background:var(--surface-3);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent}.ai-send.active{background:var(--accent);color:#fff}.ai-send:disabled{opacity:.4;cursor:default}
