:root{--bg: #f8fafc;--bg-card: #ffffff;--bg-sidebar: #1e293b;--text: #0f172a;--text-muted: #64748b;--text-sidebar: #e2e8f0;--border: #e2e8f0;--primary: #2563eb;--primary-hover: #1d4ed8;--primary-tint: rgba(37, 99, 235, .1);--success: #16a34a;--warning: #d97706;--danger: #dc2626;--radius: 8px;--shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.1), 0 4px 6px -2px rgba(0,0,0,.05)}*{box-sizing:border-box;margin:0;padding:0}html,body{overflow-x:hidden;max-width:100vw}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit;font-size:inherit}input,select,textarea{font-family:inherit;font-size:inherit}.app-layout{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--bg-sidebar);color:var(--text-sidebar);padding:20px 0;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar-logo{padding:0 20px 20px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:12px}.sidebar-logo h1{font-size:18px;font-weight:700;color:#fff}.sidebar-logo p{font-size:11px;color:#94a3b8;margin-top:2px}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:2px;padding:0 8px}.sidebar-nav a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:6px;color:var(--text-sidebar);font-size:14px;font-weight:500;transition:background .15s}.sidebar-nav a:hover{background:#ffffff14;text-decoration:none}.sidebar-nav a.active{background:#ffffff1f;color:#fff}.main-content{margin-left:240px;flex:1;padding:24px 32px;max-width:1200px}@media(max-width:767px){.sidebar{display:none}.main-content{margin-left:0;padding:16px 16px 80px;max-width:100%}}.mobile-bottom-nav{display:none}@media(max-width:767px){.mobile-bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--border);z-index:1000;padding-bottom:env(safe-area-inset-bottom);transform:translateZ(0);will-change:transform;-webkit-backface-visibility:hidden;backface-visibility:hidden}.mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;min-height:56px;padding:8px 4px;text-decoration:none;color:var(--text-muted);font-size:10px;font-weight:600;transition:color .15s}.mobile-nav-item:hover{text-decoration:none}.mobile-nav-item.active{color:var(--primary)}}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.page-header h2{font-size:22px;font-weight:700}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;border:1px solid transparent;transition:all .15s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{background:#fff;color:var(--text);border-color:var(--border)}.btn-secondary:hover{background:#f1f5f9}.btn-danger{background:#fff;color:var(--danger);border-color:#fecaca}.btn-danger:hover{background:#fef2f2}.btn-sm{padding:5px 10px;font-size:12px}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}.badge-green{background:#dcfce7;color:#166534}.badge-yellow{background:#fef3c7;color:#92400e}.badge-red{background:#fef2f2;color:#991b1b}.badge-blue{background:#dbeafe;color:#1e40af}.badge-gray{background:#f1f5f9;color:#475569}.badge-purple{background:#f3e8ff;color:#6b21a8}.table-container{overflow-x:auto;overflow-y:hidden}table{width:100%;border-collapse:collapse}th{text-align:left;padding:10px 12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:2px solid var(--border)}td{padding:10px 12px;font-size:14px;border-bottom:1px solid var(--border)}tr:hover{background:#f8fafc}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-muted);margin-bottom:4px}.form-input{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:6px;font-size:14px;transition:border-color .15s}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:20px}.tab{padding:10px 20px;font-size:14px;font-weight:500;color:var(--text-muted);border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}.tab:hover{color:var(--text)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:12px;box-shadow:var(--shadow-lg);max-width:600px;width:90%;max-height:85vh;overflow-y:auto;padding:24px}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-header h3{font-size:18px;font-weight:700}.text-muted{color:var(--text-muted)}.text-right{text-align:right}.text-sm{font-size:13px}.font-mono{font-family:SF Mono,Consolas,monospace}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.flex{display:flex}.gap-2{gap:8px}.gap-3{gap:12px}.items-center{align-items:center}.justify-between{justify-content:space-between}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.search-bar-wrapper{position:relative;display:flex;align-items:center;margin-bottom:16px}.search-bar-icon{position:absolute;left:12px;color:var(--text-muted);pointer-events:none;flex-shrink:0}.search-bar-input{width:100%;padding:10px 40px 10px 38px;border:1px solid var(--border);border-radius:8px;font-size:14px;background:var(--bg-card);color:var(--text);transition:border-color .15s,box-shadow .15s}.search-bar-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.search-bar-input::placeholder{color:var(--text-muted)}.search-bar-clear{position:absolute;right:10px;display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;border:none;background:#e2e8f0;color:var(--text-muted);padding:0;transition:background .15s,color .15s}.search-bar-clear:hover{background:#cbd5e1;color:var(--text)}.btn{min-height:44px}.btn-sm{min-height:36px}.form-input{min-height:44px}.mobile-stack{display:flex;flex-direction:column;gap:12px}@media(min-width:640px){.mobile-stack.sm-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}}.full-on-mobile{width:100%}@media(min-width:640px){.full-on-mobile{width:auto}}.template-line-items-table{display:none}.template-line-items-cards{display:flex;flex-direction:column;gap:8px}@media(min-width:768px){.template-line-items-table{display:table;width:100%}.template-line-items-cards{display:none}}.jobs-table-desktop{display:none}.jobs-cards-mobile{display:flex}@media(min-width:768px){.jobs-table-desktop{display:block}.jobs-cards-mobile{display:none!important}}.estimate-items-table{display:none}.estimate-items-cards{display:flex}.budget-pricing-summary>div:first-child{flex:1 1 220px}.budget-pricing-summary>div:nth-child(2),.budget-pricing-summary>div:nth-child(3){flex:0 0 auto}@media(min-width:768px){.estimate-items-table{display:table;width:100%}.estimate-items-cards{display:none!important}}@media(max-width:767px){.budget-pricing-summary{align-items:stretch!important}.budget-pricing-summary>div:first-child{flex:1 1 100%;justify-content:space-between}.budget-pricing-summary>div:nth-child(2),.budget-pricing-summary>div:nth-child(3){flex:1 1 calc(50% - 8px);align-items:flex-start!important}.budget-pricing-summary>div:nth-child(3){align-items:flex-end!important}}.scope-matched-cards{display:flex}.job-tabs .tab{padding:10px 24px}.tab-label-full{display:inline}.tab-label-short{display:none}@media(max-width:767px){.tabs.job-tabs{overflow-x:visible;gap:2px}.job-tabs .tab{flex:1 1 0;min-width:0;padding:0 2px;min-height:44px;font-size:12px;font-weight:600;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;gap:2px;overflow:hidden;text-overflow:ellipsis}.job-tabs .tab svg{display:none}.tab-label-full{display:none}.tab-label-short{display:inline}}.job-title-responsive{font-size:22px;word-break:break-word}@media(max-width:767px){.job-title-responsive{font-size:17px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;cursor:pointer}.job-title-responsive.expanded{white-space:normal;overflow:visible;text-overflow:clip}}.save-template-label{display:inline;margin-left:6px}@media(max-width:767px){.save-template-label{display:none}.save-template-btn{min-width:44px;width:44px!important;padding:10px!important;justify-content:center}}@media(max-width:767px){.estimate-pricing-header{flex-direction:column;gap:12px;align-items:stretch!important;text-align:left}.estimate-pricing-header>div{text-align:left!important}.estimate-pricing-header .pricing-num{font-size:22px!important}}.mobile-only{display:block}.desktop-only{display:none}@media(min-width:768px){.mobile-only{display:none}.desktop-only{display:block}}.job-header-actions{display:flex;flex-direction:column;gap:8px;width:100%}.job-header-actions .save-template-btn{width:100%}@media(min-width:768px){.job-header-actions{flex-direction:row;align-items:center;width:auto}.job-header-actions .save-template-btn{width:auto}}@media(max-width:767px){.page-header{flex-direction:column;align-items:flex-start;gap:12px}.page-header h2{font-size:18px;word-break:break-word}.table-container{max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.card{max-width:100%;overflow-x:hidden;padding:14px}.tabs{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{flex-shrink:0}.modal{width:95%;max-width:95%;max-height:90vh;padding:16px}select.form-input,input.form-input,textarea.form-input{min-height:44px;font-size:16px}textarea.form-input{min-height:80px}}.wylie-chat-fab{position:fixed;right:20px;bottom:20px;width:56px;height:56px;border-radius:50%;background:#1e3a5f;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00000026,0 2px 4px #0000001a;z-index:500;transition:transform .15s,box-shadow .15s}.wylie-chat-fab:hover{transform:scale(1.05);box-shadow:0 6px 16px #0003,0 3px 6px #0000001f}.wylie-chat-fab:active{transform:scale(.95)}@media(max-width:767px){.wylie-chat-fab{bottom:calc(72px + env(safe-area-inset-bottom));right:16px}}.wylie-new-job-fab{position:fixed;left:20px;bottom:20px;width:56px;height:56px;border-radius:50%;background:#1e3a5f;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00000026,0 2px 4px #0000001a;z-index:500;transition:transform .15s}.wylie-new-job-fab:hover{transform:scale(1.05);box-shadow:0 6px 16px #0003,0 3px 6px #0000001f}.wylie-new-job-fab:active{transform:scale(.95)}@media(max-width:767px){.wylie-new-job-fab{bottom:calc(72px + env(safe-area-inset-bottom));left:16px}}@media(max-width:767px){.modal{width:100%;max-width:100%;max-height:100dvh;height:100dvh;border-radius:0;padding:16px}.modal-overlay{align-items:stretch}}@media(max-width:767px){.proposal-action-toolbar{flex-direction:column;align-items:stretch!important}.proposal-action-buttons{justify-content:stretch!important}.proposal-action-buttons .btn,.proposal-action-buttons>button{flex:1 1 150px;justify-content:center}.proposal-preview-card{border-radius:0;margin-left:-16px!important;margin-right:-16px!important;border-left:0;border-right:0}}.wylie-listening-btn{animation:wylie-listening-pulse 1.2s infinite}@keyframes wylie-listening-pulse{0%{box-shadow:0 0 #dc2626b3}70%{box-shadow:0 0 0 12px #dc262600}to{box-shadow:0 0 #dc262600}}.wylie-mic-hero{animation:wylie-pulse 2s infinite;transition:transform .15s}.wylie-mic-hero:active{transform:scale(.95)}@keyframes wylie-pulse{0%{box-shadow:0 0 #1e3a5f80}70%{box-shadow:0 0 0 16px #1e3a5f00}to{box-shadow:0 0 #1e3a5f00}}.cockpit-theme{--bg: #11161d;--bg-card: #19212b;--bg-sidebar: #141b23;--text: #f1f5f9;--text-muted: #7e8a99;--text-sidebar: #cfe0db;--border: #232e3a;--primary: #2f9e8b;--primary-hover: #3bb6a0;--primary-tint: rgba(47, 158, 139, .14);--success: #2f9e8b;--warning: #e0b04a;--danger: #e06a5a;--radius: 14px;--shadow: 0 1px 3px rgba(0, 0, 0, .45);--shadow-lg: 0 12px 26px rgba(0, 0, 0, .55);background:var(--bg);color:var(--text);min-height:100vh}.cockpit-theme .btn-secondary{background:var(--bg-card);color:var(--text);border-color:var(--border)}.cockpit-theme .btn-secondary:hover{background:#202a36}.cockpit-theme .btn-danger{background:var(--bg-card);color:var(--danger);border-color:#e06a5a80}.cockpit-theme .btn-danger:hover{background:#e06a5a1f}.cockpit-theme .badge-green{background:#2f9e8b2e;color:#6fd0bd}.cockpit-theme .badge-yellow{background:#e0b04a29;color:#e0b04a}.cockpit-theme .badge-red{background:#e06a5a29;color:#e8917f}.cockpit-theme .badge-blue{background:#60a5fa29;color:#8fbdf5}.cockpit-theme .badge-gray{background:#7e8a9929;color:#aab6c4}.cockpit-theme .badge-purple{background:#a882f029;color:#c3a4f0}.cockpit-theme tr:hover{background:#1c2530}.cockpit-theme .form-input,.cockpit-theme input,.cockpit-theme select,.cockpit-theme textarea{background:#141b23;color:var(--text);border-color:var(--border)}.cockpit-theme .form-input:focus,.cockpit-theme input:focus,.cockpit-theme select:focus,.cockpit-theme textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2f9e8b2e}.cockpit-theme select option{background:#19212b;color:var(--text)}.cockpit-theme .proposal-preview-card{--bg: #f8fafc;--bg-card: #ffffff;--text: #0f172a;--text-muted: #64748b;--border: #e2e8f0;--primary: #2563eb;--primary-hover: #1d4ed8;--radius: 8px;--shadow: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06);background:#fff;color:#0f172a}.cockpit-theme .modal{background:var(--bg-card);color:var(--text)}.cockpit-theme .mobile-bottom-nav{background:var(--bg-sidebar)}
