*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0f0f1a;--card: #1a1a2e;--card-hover: #22223a;--border: #2a2a40;--text: #e4e4e7;--text-dim: #9ca3af;--accent: #3b82f6;--accent-hover: #2563eb;--success: #22c55e;--warning: #eab308;--danger: #ef4444;--scheduled: #3b82f6;--in-progress: #eab308;--completed: #22c55e;--cancelled: #6b7280;--radius: 12px;--radius-sm: 8px}html,body,#root{height:100%;font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}.app{display:flex;flex-direction:column;min-height:100vh}.page{flex:1;padding:16px 16px 80px;max-width:600px;margin:0 auto;width:100%}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--card);border-top:1px solid var(--border);display:flex;justify-content:space-around;align-items:center;padding:8px 0;padding-bottom:max(8px,env(safe-area-inset-bottom));z-index:100}.bottom-nav a{display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--text-dim);font-size:11px;padding:4px 12px;min-width:60px;text-decoration:none}.bottom-nav a.active{color:var(--accent)}.bottom-nav a svg{width:24px;height:24px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:12px}.page-header h1{font-size:24px;font-weight:700}.page-header h2{font-size:20px;font-weight:600}.card{background:var(--card);border-radius:var(--radius);padding:16px;margin-bottom:12px;border:1px solid var(--border);transition:background .15s}.card:hover{background:var(--card-hover)}.card-link{display:block;text-decoration:none;color:inherit}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:var(--radius-sm);font-size:15px;font-weight:600;border:none;cursor:pointer;min-height:44px;min-width:44px;transition:all .15s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-success{background:var(--success);color:#fff}.btn-warning{background:var(--warning);color:#000}.btn-danger{background:var(--danger);color:#fff}.btn-outline{background:transparent;color:var(--text);border:1px solid var(--border)}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.btn-block{width:100%}.btn-sm{padding:8px 14px;font-size:13px;min-height:36px}.btn:disabled{opacity:.5;cursor:not-allowed}.badge{display:inline-block;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600;text-transform:capitalize}.badge-scheduled{background:#3b82f626;color:var(--scheduled)}.badge-estimate_sent{background:#a855f726;color:#a855f7}.badge-in_progress{background:#eab30826;color:var(--in-progress)}.badge-completed{background:#22c55e26;color:var(--completed)}.badge-cancelled,.badge-draft{background:#6b728026;color:var(--cancelled)}.badge-sent{background:#3b82f626;color:var(--scheduled)}.badge-approved{background:#22c55e26;color:var(--completed)}.badge-declined,.badge-rejected{background:#ef444426;color:var(--danger)}.badge-expired{background:#6b728026;color:var(--cancelled)}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-dim);margin-bottom:6px}.form-control{width:100%;padding:12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:15px;outline:none;transition:border-color .15s}.form-control:focus{border-color:var(--accent)}select.form-control{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%239ca3af' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}textarea.form-control{resize:vertical;min-height:80px}.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}.stat{background:var(--card);border-radius:var(--radius-sm);padding:12px;text-align:center;border:1px solid var(--border)}.stat-value{font-size:24px;font-weight:700}.stat-label{font-size:11px;color:var(--text-dim);margin-top:2px}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.photo-grid img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border)}.category-toggle{display:flex;gap:8px;margin-bottom:12px}.category-toggle button{flex:1;padding:8px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);color:var(--text-dim);font-size:13px;cursor:pointer}.category-toggle button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.tabs{display:flex;gap:4px;margin-bottom:16px;overflow-x:auto}.tabs button{padding:8px 16px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);color:var(--text-dim);font-size:13px;cursor:pointer;white-space:nowrap}.tabs button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.job-item{display:flex;align-items:flex-start;gap:12px}.job-time{font-size:13px;color:var(--text-dim);min-width:50px;padding-top:2px}.job-info{flex:1}.job-title{font-weight:600;font-size:15px;margin-bottom:4px}.job-address{font-size:13px;color:var(--text-dim)}.job-client{font-size:12px;color:var(--accent);margin-top:2px}.signature-canvas{border:2px dashed var(--border);border-radius:var(--radius-sm);background:#fff;touch-action:none;cursor:crosshair;width:100%;height:200px}.list-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border)}.list-item:last-child{border-bottom:none}.empty{text-align:center;padding:40px 20px;color:var(--text-dim)}.empty svg{width:48px;height:48px;opacity:.3;margin-bottom:12px}.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}.search-input{width:100%;padding:10px 12px 10px 36px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;outline:none;margin-bottom:16px}.search-wrap{position:relative}.search-wrap svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--text-dim);pointer-events:none}.estimate-totals{border-top:2px solid var(--border);padding-top:12px;margin-top:12px}.estimate-row{display:flex;justify-content:space-between;padding:4px 0;font-size:14px}.estimate-row.total{font-size:18px;font-weight:700;padding-top:8px;border-top:1px solid var(--border);margin-top:4px}.week-cal{display:flex;gap:6px;margin-bottom:20px;overflow-x:auto;padding:4px 0}.week-day{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px;border-radius:var(--radius-sm);background:var(--card);border:1px solid var(--border);min-width:48px;cursor:pointer;font-size:12px}.week-day.active{background:var(--accent);border-color:var(--accent);color:#fff}.week-day .day-name{font-size:10px;text-transform:uppercase;color:var(--text-dim)}.week-day.active .day-name{color:#fffc}.week-day .day-num{font-size:16px;font-weight:600}.week-day .dot{width:4px;height:4px;border-radius:50%;background:var(--accent)}.week-day.active .dot{background:#fff}.approval-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.approval-card{background:var(--card);border-radius:var(--radius);padding:24px;max-width:500px;width:100%;border:1px solid var(--border)}.approval-header{text-align:center;margin-bottom:24px}.approval-actions{display:flex;gap:12px;margin-top:20px}.approval-actions .btn{flex:1}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;margin-top:20px}.section-header h3{font-size:16px;font-weight:600}.inline-add{display:flex;gap:8px;margin-bottom:12px}.inline-add .form-control{flex:1;padding:8px 10px;font-size:14px}.loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--text-dim)}.toast{position:fixed;top:20px;left:50%;transform:translate(-50%);background:var(--success);color:#fff;padding:12px 24px;border-radius:var(--radius-sm);font-weight:600;z-index:999;animation:fadeInOut 2.5s forwards}.toast-error{background:var(--danger)}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%) translateY(-10px)}15%{opacity:1;transform:translate(-50%) translateY(0)}85%{opacity:1}to{opacity:0}}.ve-hero{text-align:center;padding:12px 0 20px}.ve-tagline{font-size:16px;color:var(--text-dim)}.ai-action-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;text-align:center;font-size:13px;font-weight:500}.ai-action-card svg{flex-shrink:0}.ai-analysis .card{margin-bottom:10px}.analysis-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}.analysis-header h3{font-size:15px;font-weight:600;flex:1}.dimension-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.dimension-item{text-align:center}.dimension-label{font-size:11px;color:var(--text-dim);text-transform:capitalize;margin-bottom:2px}.dimension-value{font-size:18px;font-weight:700;color:var(--warning)}.cost-predictor{margin-top:16px;margin-bottom:16px;border-left:3px solid var(--warning)}.predict-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:13px}.proposal-preview .card{margin-bottom:10px}.proposal-header-card{border-top:3px solid var(--warning)}.voice-recorder{display:flex;flex-direction:column;align-items:center;padding:24px 0}.mic-btn{width:88px;height:88px;border-radius:50%;border:3px solid var(--border);background:var(--card);color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.mic-btn:hover{border-color:#f59e0b;color:#f59e0b}.mic-btn.mic-recording{background:#ef4444;border-color:#ef4444;color:#fff;animation:mic-pulse 1.5s ease-in-out infinite}.mic-btn svg{width:36px;height:36px}@keyframes mic-pulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 16px #ef444400}}.rec-timer{font-size:24px;font-weight:700;margin-top:12px;font-variant-numeric:tabular-nums;color:#ef4444}.rec-hint{font-size:13px;color:var(--text-dim);margin-top:8px}.ve-divider{display:flex;align-items:center;gap:12px;margin:24px 0;color:var(--text-dim);font-size:13px}.ve-divider:before,.ve-divider:after{content:"";flex:1;height:1px;background:var(--border)}.ve-loading{text-align:center;padding:48px 0}.ve-spinner{width:48px;height:48px;border:4px solid var(--border);border-top-color:#f59e0b;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(360deg)}}.ve-loading p{color:var(--text-dim);font-size:15px}.ve-transcript{background:var(--card);border-radius:var(--radius);padding:14px;margin-bottom:16px;border-left:3px solid #f59e0b}.ve-transcript-label{font-size:11px;color:var(--text-dim);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.ve-transcript p{font-size:14px;color:var(--text);font-style:italic;margin:0}.ve-items-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.ve-items-header h3{font-size:16px;font-weight:600}.ve-line-item{background:var(--card);border-radius:var(--radius-sm);padding:12px;margin-bottom:8px;border:1px solid var(--border)}.ve-li-top{display:flex;gap:8px;margin-bottom:8px}.ve-li-desc{flex:1;font-weight:500}.ve-li-remove{padding:4px 10px;min-height:unset;min-width:unset;font-size:18px;line-height:1}.ve-li-fields{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:8px}.ve-li-field label{display:block;font-size:11px;color:var(--text-dim);margin-bottom:4px}.ve-li-field .form-control{padding:8px;font-size:14px}.ve-li-total{display:flex;flex-direction:column}.ve-li-total div{padding:8px;font-size:14px;font-weight:600;color:var(--success)}.ve-refine{padding-top:12px;border-top:1px solid var(--border)}.bottom-nav a[href="/voice-estimate"].active{color:#f59e0b}.install-prompt{position:fixed;top:16px;left:16px;right:16px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;z-index:200;box-shadow:0 8px 32px #0000004d}.install-prompt-content{display:flex;align-items:center;gap:12px}.install-prompt-icon{width:40px;height:40px;background:var(--accent);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.install-prompt-icon svg{width:20px;height:20px;color:#fff}.install-prompt-text{flex:1}.install-prompt-text h3{font-size:16px;font-weight:600;margin:0 0 4px;color:var(--text)}.install-prompt-text p{font-size:13px;color:var(--text-dim);margin:0}.install-prompt-actions{display:flex;gap:8px}.install-prompt-actions button{padding:8px 16px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;min-height:unset}.offline-indicator{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:var(--warning);color:var(--bg);padding:8px 16px;border-radius:var(--radius);font-size:13px;font-weight:500;z-index:150;box-shadow:0 4px 12px #0003}.badge-pending{background:#eab30826;color:var(--in-progress)}.badge-accepted{background:#3b82f626;color:var(--scheduled)}.booking-page{min-height:100vh;background:var(--bg);display:flex;align-items:flex-start;justify-content:center;padding:20px}.booking-container{max-width:500px;width:100%;padding-bottom:40px}.booking-header{text-align:center;margin-bottom:24px;padding:24px 0}.booking-avatar{width:72px;height:72px;border-radius:50%;background:var(--accent);color:#fff;font-size:28px;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}.booking-header h1{font-size:22px;font-weight:700}.booking-company{font-size:14px;color:var(--text-dim);margin-top:4px}.booking-bio{font-size:14px;color:var(--text-dim);margin-top:8px}.booking-success{text-align:center;padding:40px 0}.booking-success .success-icon{width:64px;height:64px;border-radius:50%;background:var(--success);color:#fff;font-size:28px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.booking-error{text-align:center;padding:40px 0;color:var(--text-dim)}.page-header h1,.page-header h2{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 480px){.form-row-2{flex-direction:column!important}.li-amount-row{flex-wrap:wrap!important}.li-amount-row>.li-total{flex:1 1 auto}.ve-li-fields{grid-template-columns:1fr 1fr!important}.inline-add{flex-wrap:wrap}.inline-add .form-control{min-width:80px}.inline-add button[type=submit]{flex-shrink:0}.install-prompt-content{flex-wrap:wrap}.install-prompt-actions{width:100%;justify-content:flex-end}.stat-label{font-size:10px}.ai-action-card{padding:12px 6px;font-size:12px}.booking-page{padding:12px}.approval-actions{flex-direction:column}.page-header{gap:8px}}@media (max-height: 500px) and (orientation: landscape){.bottom-nav{padding:4px 0}.bottom-nav a{padding:2px 8px;font-size:10px}.bottom-nav a svg{width:20px;height:20px}.page{padding-bottom:60px}}
