:root{--bg: #0c0a09;--surface: #1c1917;--surface-2: #292524;--surface-3: #3c3532;--border: #44403c;--border-focus: #facc15;--text: #fafaf9;--text-dim: #a8a29e;--text-muted: #78716c;--accent: #facc15;--accent-2: #fbbf24;--accent-dark: #ca8a04;--danger: #ef4444;--danger-dim: #7f1d1d;--sidebar-w: 240px;--nav-h: 60px;--radius: 8px;--radius-sm: 4px}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;background:var(--bg);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}#root{height:100%}.app-shell{display:flex;height:100%}.sidebar{display:none;width:var(--sidebar-w);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow-y:auto}.main-content{flex:1;overflow-y:auto;padding-bottom:calc(var(--nav-h) + env(safe-area-inset-bottom,0px) + 16px);min-height:100%}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-h) + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:var(--surface);border-top:1px solid var(--border);display:flex;align-items:stretch;overflow:visible;z-index:100}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:4px;border:none;background:none;color:var(--text-muted);cursor:pointer;transition:color .15s;font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.04em;min-height:44px}.bottom-nav-item.active{color:var(--accent)}.bottom-nav-item svg{width:22px;height:22px}.bottom-nav-agent{flex:1.2;position:relative;top:-14px;gap:0;overflow:visible}.bottom-nav-agent-fab{width:52px;height:52px;border-radius:50%;background:var(--surface-2);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #0006;transition:background .15s,border-color .15s,box-shadow .15s;margin-bottom:3px}.bottom-nav-agent-fab svg{width:24px;height:24px}.bottom-nav-agent-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);transition:color .15s}.bottom-nav-agent.active .bottom-nav-agent-fab{background:var(--accent);border-color:var(--accent);box-shadow:0 4px 20px #facc1559}.bottom-nav-agent.active .bottom-nav-agent-fab svg{stroke:#000}.bottom-nav-agent.active .bottom-nav-agent-label{color:var(--accent)}.bottom-nav-agent:not(.active) .bottom-nav-agent-fab svg{stroke:var(--text-dim)}@media(min-width:768px){.sidebar{display:flex}.bottom-nav{display:none}.main-content{margin-left:var(--sidebar-w);padding-bottom:0}}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:16px 14px;border-bottom:1px solid var(--border);transition:background .12s}.sidebar-logo:hover{background:var(--surface-2)}.sidebar-logo img{width:50px;height:50px;flex-shrink:0;filter:drop-shadow(0 0 6px rgba(250,204,21,.45));transition:filter .2s}.sidebar-logo:hover img{filter:drop-shadow(0 0 10px rgba(250,204,21,.7))}.sidebar-brand{font-size:13px;font-weight:800;line-height:1.2;letter-spacing:-.01em;color:var(--accent)}.sidebar-subbrand{font-size:11px;font-weight:500;color:var(--accent);line-height:1.3;margin-top:2px}.sidebar-nav{padding:8px 0;flex:1}.sidebar-nav-item{display:flex;align-items:center;gap:10px;padding:10px 16px;border:none;background:none;color:var(--text-dim);cursor:pointer;width:100%;text-align:left;font-size:13px;font-weight:500;border-radius:0;transition:color .15s,background .15s;min-height:44px}.sidebar-nav-item:hover{color:var(--text);background:var(--surface-2)}.sidebar-nav-item.active{color:var(--accent);background:#facc1514;border-left:3px solid var(--accent);padding-left:13px}.sidebar-nav-item svg{width:18px;height:18px;flex-shrink:0}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.card+.card{margin-top:12px}.page-header{padding:16px 16px 0}.page-header h1{font-size:20px;font-weight:700;margin:0 0 4px}.page-header p{font-size:13px;color:var(--text-dim);margin:0}.page-body{padding:16px}@media(min-width:768px){.page-header{padding:24px 24px 0}.page-header h1{font-size:24px}.page-body{padding:16px 24px 24px}.card{padding:20px}}.form-group{margin-bottom:14px}.form-group:last-child{margin-bottom:0}label{display:block;font-size:12px;font-weight:600;color:var(--text-dim);margin-bottom:5px;letter-spacing:.02em}input[type=text],input[type=email],input[type=tel],input[type=number],input[type=date],select,textarea{width:100%;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:9px 11px;font-size:14px;font-family:inherit;line-height:1.4;outline:none;transition:border-color .15s,box-shadow .15s;min-height:40px;-webkit-appearance:none}input:focus,select:focus,textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #facc1526}select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%23a8a29e'%3E%3Cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:16px;padding-right:32px;cursor:pointer}select option{background:var(--surface-2)}.form-row{display:grid;gap:12px;grid-template-columns:1fr}@media(min-width:480px){.form-row.cols-2{grid-template-columns:1fr 1fr}.form-row.cols-3{grid-template-columns:1fr 1fr 1fr}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);border:none;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:opacity .15s,background .15s;min-height:40px;white-space:nowrap;text-decoration:none}.btn:active{opacity:.8}.btn svg{width:16px;height:16px}.btn-primary{background:var(--accent);color:#1c1917}.btn-primary:hover{background:var(--accent-2)}.btn-secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--surface-3)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{opacity:.85}.btn-ghost{background:transparent;color:var(--text-dim)}.btn-ghost:hover{color:var(--text);background:var(--surface-2)}.btn-sm{padding:5px 10px;font-size:12px;min-height:32px}.btn-lg{padding:12px 24px;font-size:15px;min-height:48px}.btn-full{width:100%}.btn-icon{padding:7px;min-height:36px;min-width:36px;border-radius:var(--radius-sm)}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:9999px;font-size:11px;font-weight:600}.badge-lynch{background:#60a5fa26;color:#60a5fa}.badge-wilco{background:#fb923c26;color:#fb923c}.badge-raytec{background:#e879f926;color:#e879f9}.catalog-toolbar{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}@media(min-width:540px){.catalog-toolbar{flex-direction:row;align-items:center}}.sup-toggle{display:flex;border:1px solid var(--border);border-radius:var(--radius);overflow-x:auto;overflow-y:hidden;scrollbar-width:none;flex-shrink:0;width:100%}.sup-toggle::-webkit-scrollbar{display:none}@media(min-width:540px){.sup-toggle{width:auto}}.sup-toggle-btn{padding:7px 12px;font-size:12px;font-weight:500;background:var(--surface-2);color:var(--text-muted);border:none;border-right:1px solid var(--border);cursor:pointer;transition:all .12s;white-space:nowrap}.sup-toggle-btn:last-child{border-right:none}.sup-toggle-btn:hover{background:var(--surface-3);color:var(--text)}.sup-toggle-btn.active{background:var(--surface-3);color:var(--text);font-weight:600}.sup-toggle-btn.active.sup-lynch{color:#60a5fa}.sup-toggle-btn.active.sup-wilco{color:#fb923c}.sup-toggle-btn.active.sup-raytec{color:#e879f9}.catalog-layout{display:flex;flex-direction:column;gap:0}.cat-sidebar{display:flex;gap:4px;overflow-x:auto;padding-bottom:12px;scrollbar-width:none;flex-wrap:nowrap;width:100%;margin-bottom:4px}.cat-sidebar::-webkit-scrollbar{display:none}.cat-nav-item{flex-shrink:0;padding:5px 12px;font-size:12px;font-weight:500;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);cursor:pointer;transition:all .12s;white-space:nowrap}.cat-nav-item:hover{color:var(--text)}.cat-nav-item.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.catalog-content{flex:1;min-width:0}.cat-desktop{display:none}.cat-mobile{display:block}@media(min-width:640px){.cat-desktop{display:block}.cat-mobile{display:none}}.cat-list-row{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border)}.cat-list-row:last-child{border-bottom:none}.list-row-hover:hover{background:var(--surface)}.list-row-hover:active{background:var(--surface-2)}.cat-list-desc{flex:1;min-width:0;font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cat-list-price{font-size:13px;font-weight:700;color:var(--accent-2);white-space:nowrap;flex-shrink:0}.cat-list-header{padding:5px 12px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);background:var(--surface-2);border-bottom:1px solid var(--border)}@media(min-width:768px){.catalog-layout{gap:16px;flex-direction:row;align-items:flex-start}.cat-sidebar{flex-direction:column;width:160px;flex-shrink:0;overflow-x:visible;overflow-y:auto;padding-bottom:0;padding-right:0;gap:1px;position:sticky;top:16px;max-height:calc(100vh - 140px)}.cat-nav-item{width:100%;text-align:left;padding:7px 12px;border-bottom:none;border-left:2px solid transparent;border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:13px}.cat-nav-item:hover{background:var(--surface-2);color:var(--text)}.cat-nav-item.active{background:var(--surface-2);border-left-color:var(--accent);color:var(--accent)}}.best-badge{display:inline-block;padding:1px 6px;border-radius:4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;background:#22c55e26;color:#4ade80}.search-bar{position:relative}.search-bar input{padding-left:36px}.search-bar .search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;width:16px;height:16px}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-sm)}table.data-table{width:100%;border-collapse:collapse;min-width:480px}table.data-table thead tr{background:var(--surface-2)}table.data-table th{padding:9px 12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);text-align:left;white-space:nowrap;border-bottom:1px solid var(--border)}table.data-table td{padding:9px 12px;border-bottom:1px solid var(--border);vertical-align:middle}table.data-table tbody tr:last-child td{border-bottom:none}table.data-table tbody tr:hover{background:var(--surface-2)}.cat-row td{background:var(--surface-3)!important;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:6px 12px!important}.line-item-row{display:flex;align-items:center;gap:8px}.line-item-row+.line-item-row{margin-top:8px}.li-supplier{width:70px;flex-shrink:0}.li-desc{flex:1;min-width:0}.li-qty{width:70px;flex-shrink:0}.li-unit{width:90px;flex-shrink:0}.li-ext{width:90px;flex-shrink:0;text-align:right;font-weight:600;color:var(--accent)}.li-actions{flex-shrink:0;display:flex;gap:4px}.line-item-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px}.li-card-total{font-size:15px;font-weight:700;color:var(--accent)}.li-compact-card{padding:10px 12px;border-bottom:1px solid var(--border)}.li-compact-card:last-child{border-bottom:none}.li-compact-main{display:flex;align-items:center;gap:8px}.li-compact-name{flex:1;min-width:0;font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.li-stepper{display:flex;align-items:center;gap:0;border:1px solid var(--border);border-radius:6px;overflow:hidden;flex-shrink:0}.li-step-btn{width:32px;height:32px;background:var(--surface-3);border:none;color:var(--text);font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.li-step-btn:active{background:var(--border)}.li-step-input{width:40px;height:32px;background:var(--surface-2);border:none;border-left:1px solid var(--border);border-right:1px solid var(--border);color:var(--text);font-family:var(--mono, monospace);font-size:13px;font-weight:600;text-align:center;padding:0;-moz-appearance:textfield}.li-step-input::-webkit-inner-spin-button,.li-step-input::-webkit-outer-spin-button{-webkit-appearance:none}.li-compact-sub{font-size:11px;color:var(--text-muted);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.li-sub-sep:before{content:"  ·  "}.totals-bar-grid{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);display:grid;grid-template-columns:repeat(2,1fr);margin-bottom:16px;overflow:hidden}.total-cell{padding:16px 20px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);text-align:center}.total-cell:nth-child(2n){border-right:none}.total-cell-grand{border-right:none;grid-column:1 / -1}.total-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:4px}.total-value{font-family:SF Mono,Fira Code,monospace;font-size:20px;font-weight:700;color:var(--accent-2, #fbbf24)}.total-value.grand{font-size:26px;color:var(--accent)}@media(min-width:640px){.totals-bar-grid{grid-template-columns:repeat(5,1fr)}.total-cell{border-bottom:none}.total-cell:nth-child(2n){border-right:1px solid var(--border)}.total-cell-grand{grid-column:auto;border-right:none}}.card-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);margin-bottom:14px;display:flex;align-items:center;gap:7px}.card-title svg{width:15px;height:15px;color:var(--accent);flex-shrink:0}.li-desktop{display:none}.li-mobile{display:block;padding:8px}@media(min-width:768px){.li-desktop{display:block}.li-mobile{display:none}}.remove-row{width:26px;height:26px;border-radius:50%;border:none;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .15s;flex-shrink:0}.remove-row:hover{background:#ef444426;color:var(--danger)}.remove-row:disabled{opacity:.25;cursor:default}.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}.collapse-card{padding:0;overflow:hidden}.card-collapse-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;width:100%;background:none;border:none;cursor:pointer;text-align:left;gap:12px;color:var(--text)}.card-collapse-header:hover{background:#ffffff08}.card-collapse-body{padding:16px 20px 20px;border-top:1px solid var(--border)}.collapse-label{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);flex-shrink:0;white-space:nowrap}.collapse-label svg{width:13px;height:13px;color:var(--text-muted);flex-shrink:0}.collapse-summary{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.collapse-chevron{width:18px;height:18px;color:var(--text-muted);flex-shrink:0;transition:transform .2s}.collapse-chevron.open{transform:rotate(180deg)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.section-title{font-size:14px;font-weight:700;color:var(--text)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:flex-end;justify-content:center;z-index:1000;padding:0}@media(min-width:480px){.modal-overlay{align-items:center;padding:16px}}.modal{background:var(--surface);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-width:520px;padding:28px 24px 32px;border:1px solid var(--border);position:relative;max-height:90vh;overflow-y:auto}@media(min-width:480px){.modal{border-radius:var(--radius)}}.modal-close{position:absolute;top:12px;right:12px;background:var(--surface-2);border:1px solid var(--border);color:var(--text-dim);border-radius:999px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;line-height:1}.welcome-modal{max-width:480px}.welcome-logo-wrap{display:flex;justify-content:center;margin-bottom:24px}@media(max-width:479px){.welcome-modal{padding:20px 18px 22px;max-height:88vh}.welcome-logo-wrap img{width:56px!important;height:56px!important}.welcome-logo-wrap{margin-bottom:14px}.welcome-step-title{font-size:16px}.welcome-step-body{font-size:13px;margin-top:8px;margin-bottom:12px}.welcome-tip{padding:8px 10px;margin-bottom:16px}.welcome-dots{margin-bottom:14px}}.welcome-icon-wrap{width:48px;height:48px;background:var(--surface-3);border:1px solid var(--border);border-radius:10px;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:var(--accent)}.welcome-icon-wrap svg{width:24px;height:24px}.welcome-step-title{font-size:18px;font-weight:700;text-align:center;margin-bottom:4px;letter-spacing:-.2px}.welcome-step-subtitle{font-size:13px;font-weight:400;color:var(--text-muted);margin-top:2px}.welcome-step-body{font-size:13.5px;color:var(--text-dim);text-align:center;line-height:1.65;margin-bottom:16px;margin-top:12px}.welcome-tip{background:var(--surface-3);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius-sm);padding:10px 14px;font-size:12px;color:var(--text-muted);margin-bottom:24px;line-height:1.6;display:flex;gap:8px;align-items:flex-start}.welcome-tip-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--accent);flex-shrink:0;margin-top:1px}.welcome-dots{display:flex;justify-content:center;gap:5px;margin-bottom:20px}.welcome-dot{width:6px;height:6px;border-radius:50%;background:var(--surface-3);border:1px solid var(--border);transition:background .2s,width .2s;cursor:pointer}.welcome-dot.active{background:var(--accent);border-color:var(--accent);width:18px;border-radius:3px}.welcome-actions{display:flex;gap:8px;align-items:center}.toast-container{position:fixed;bottom:calc(var(--nav-h) + 12px);left:50%;transform:translate(-50%);z-index:2000;pointer-events:none}@media(min-width:768px){.toast-container{bottom:24px}}.offline-banner{position:sticky;top:0;z-index:50;background:#451a03;border-bottom:1px solid #92400e;color:#fef3c7;font-size:12px;font-weight:500;text-align:center;padding:6px 16px;letter-spacing:.01em}.toast{background:var(--surface-2);border:1px solid var(--border);color:var(--text);padding:10px 20px;border-radius:999px;font-size:13px;font-weight:500;box-shadow:0 4px 20px #0006;white-space:nowrap;animation:toast-in .2s ease}.toast.success{border-color:var(--accent);color:var(--accent)}.toast.error{border-color:var(--danger);color:var(--danger)}.toast.warn{border-color:#f59e0b;color:#fbbf24}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.empty-state{text-align:center;padding:40px 20px;color:var(--text-muted)}.empty-state svg{width:40px;height:40px;margin-bottom:12px;opacity:.4}.empty-state p{font-size:13px;margin-top:4px}.compare-best{color:var(--accent);font-weight:700}.compare-cat td{background:var(--surface-3)!important;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:6px 12px!important}.cmp-stats{display:flex;gap:20px;align-items:center;flex-wrap:wrap;padding:10px 16px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;margin-bottom:12px;font-size:12px}.cmp-stats-total{font-weight:600;color:var(--text);margin-right:4px}.cmp-stats-item{display:flex;align-items:center;gap:6px;color:var(--text-muted)}.cmp-cat-header{display:flex;justify-content:space-between;align-items:center;padding:9px 14px;border-bottom:1px solid var(--border);background:var(--surface-2)}.cmp-cat-header-name{font-weight:700;font-size:13px}.cat-desktop table.data-table thead th{padding:5px 12px;font-size:10px;color:var(--text-muted);background:var(--surface-3);border-bottom:1px solid var(--border)}.sortable-th{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.sortable-th:hover{background:var(--surface-3)!important;color:var(--text)}.sortable-th.sort-active{color:var(--accent)}.cmp-savings{font-size:11px;color:#4ade80;font-weight:600}.cmp-best-wrap{display:inline-flex;align-items:center;gap:5px}.cmp-list-item{padding:10px 12px;border-bottom:1px solid var(--border)}.cmp-list-item:last-child{border-bottom:none}.cmp-list-name{font-size:13px;font-weight:600;margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cmp-list-prices{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;margin-top:4px}.cmp-list-price{display:flex;align-items:center;gap:4px;font-size:12px;padding:4px 6px;border-radius:4px;background:var(--surface-2);border:1px solid var(--border)}.cmp-list-price.best{border-color:#4ade80;background:#4ade8014}.upload-extract-status{display:flex;align-items:center;gap:10px;padding:12px 0;font-size:13px;color:var(--text-muted);margin-top:12px}.upload-error{font-size:13px;color:#f87171;background:#f8717114;border:1px solid rgba(248,113,113,.2);border-radius:6px;padding:10px 12px}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:639px){.mob-hide{display:none!important}table.data-table{table-layout:fixed;width:100%}.cat-mobile~.table-wrap,.cat-mobile+.table-wrap{overflow-x:hidden}.table-wrap{overflow-x:hidden}table.data-table .col-price{width:76px}table.data-table .col-action{width:62px}table.data-table th{padding:7px 8px;font-size:10px}table.data-table td{padding:9px 8px;font-size:13px}.data-table .col-action .btn-sm,.data-table td.col-action button{width:100%;padding:8px 4px;font-size:12px}.cat-row td{padding:5px 8px!important;font-size:10px}.cmp-stats{gap:10px;padding:8px 12px;font-size:11px}.cmp-cat-header{padding:8px 10px}.cmp-cat-header-name{font-size:12px}table.data-table.cmp-table .col-price{width:60px}table.data-table .col-desc{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}table.data-table .col-desc>*{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}}@media(max-width:767px){.desktop-only{display:none!important}}@media(min-width:768px){.mobile-only{display:none!important}}@media(max-width:767px){input[type=text],input[type=email],input[type=tel],input[type=number],input[type=search],textarea{font-size:16px}}.agent-header{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-shrink:0}.agent-header-title{margin:0 0 2px;font-size:18px;font-weight:700}.agent-header-controls{display:flex;align-items:center;gap:10px;flex-shrink:0}.agent-header-mobile-only{display:none}.agent-workspace{flex:1;min-width:0;padding:16px;overflow-y:auto;border-right:1px solid var(--border);display:flex;flex-direction:column;gap:8px}.agent-bubble-user{padding:10px 14px;border-radius:18px 18px 4px;background:var(--accent);color:#000;font-size:14px;font-weight:500;align-self:flex-end;max-width:min(500px,85%);line-height:1.5;word-break:break-word}.agent-bubble-assistant{padding:10px 14px;border-radius:4px 18px 18px;background:var(--surface-2);font-size:13px;line-height:1.6;max-width:min(640px,100%);border-left:3px solid var(--border);word-break:break-word}.agent-mobile-total{display:none;padding:8px 12px;border-top:1px solid var(--border);align-items:center;gap:10px;flex-shrink:0;background:var(--surface)}.agent-mic-btn{width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:var(--surface-2);color:var(--text-dim);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,color .15s,border-color .15s}.agent-mic-btn:hover{border-color:var(--border-focus);color:var(--text)}.agent-mic-btn.listening{background:#f8717126;border-color:#f87171;color:#f87171;animation:mic-pulse 1s ease-in-out infinite}.agent-mic-btn.attaching{background:#facc151f;border-color:#facc15;color:#facc15}@keyframes mic-pulse{0%,to{box-shadow:0 0 #f8717166}50%{box-shadow:0 0 0 6px #f8717100}}.agent-input-bar{padding:10px 12px;border-top:1px solid var(--border);display:flex;gap:8px;align-items:center;flex-shrink:0}.agent-input{flex:1;padding:12px 14px;border-radius:24px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-size:14px;font-family:inherit;line-height:1.4;outline:none;transition:border-color .15s,box-shadow .15s;min-height:44px}.agent-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #facc1526}.agent-send-btn{border-radius:24px;min-width:72px;flex-shrink:0}.agent-toolbar-chip{padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--text-dim);font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:border-color .15s,color .15s}.agent-toolbar-chip:active{background:var(--surface-2);color:var(--text)}.agent-offline-bar{padding:6px 16px;background:#1c1205;border-top:1px solid #92400e;color:#fbbf24;font-size:11px;text-align:center;flex-shrink:0}.agent-attachment-strip{display:flex;align-items:center;gap:6px;padding:8px 12px;border-top:1px solid var(--border);background:var(--surface);overflow-x:auto;flex-shrink:0}.agent-attachment-thumb{position:relative;flex-shrink:0}.agent-attachment-thumb img{width:52px;height:52px;object-fit:cover;border-radius:6px;display:block;border:1px solid var(--border)}.agent-attachment-x{position:absolute;top:-5px;right:-5px;width:18px;height:18px;border-radius:50%;background:var(--surface-3);border:1px solid var(--border);color:var(--text);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}.agent-attach-active{border-color:var(--accent);color:var(--accent)}.agent-send-icon{display:none}.agent-send-text{display:inline}@media(max-width:639px){.agent-header{padding:12px 14px}.agent-header-title{font-size:16px!important}.agent-header-controls{display:none}.agent-header-mobile-only{display:inline-flex}.agent-mobile-total{display:flex}.agent-workspace{padding:10px 12px;border-right:none}.agent-quote-sidebar{display:none!important}.agent-input{font-size:16px}.agent-input-bar{padding:8px 10px;padding-bottom:calc(8px + env(safe-area-inset-bottom,0px))}.agent-workspace>*{max-width:100%!important}.agent-send-btn{min-width:44px!important;width:44px;padding:0;border-radius:50%}.agent-send-icon{display:flex;align-items:center;justify-content:center}.agent-send-text{display:none}}.reports-page{padding:20px;max-width:1400px;margin:0 auto}.reports-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:20px}.kpi-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}.kpi-tile{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 16px}.report-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.report-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:18px 20px}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.panel-title{margin:0;font-weight:600;font-size:14px}.panel-sub{margin:2px 0 0;font-size:11px;color:var(--text-dim)}.feed-grid{display:flex;flex-direction:column;gap:8px}.feed-item{display:flex;border-radius:8px;background:var(--surface-2);border:1px solid var(--border);overflow:hidden}.feed-item-accent{width:3px;flex-shrink:0}.feed-item-body{flex:1;padding:10px 12px}.feed-item-meta{display:flex;align-items:center;gap:5px;margin-bottom:4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim)}.feed-item-title{margin:0 0 4px;font-size:13px;font-weight:600;line-height:1.4}.feed-item-summary{margin:0;font-size:12px;color:var(--text-dim);line-height:1.5}.feed-item-action{display:flex;gap:6px;align-items:flex-start;margin-top:7px;font-size:12px;font-weight:500;color:#f59e0b;line-height:1.4}.feed-item-arrow{flex-shrink:0}.insights-recs-grid{display:flex;flex-direction:column;gap:8px}.insights-rec-item{padding:10px 12px;border-radius:8px;background:var(--surface-2);border:1px solid var(--border)}.report-grid-insights{display:grid;grid-template-columns:1fr;gap:20px}@media(min-width:1100px){.feed-grid{display:grid;grid-template-columns:repeat(2,1fr)}}@media(min-width:960px){.insights-recs-grid{display:grid;grid-template-columns:repeat(2,1fr)}}@media(min-width:1280px){.report-grid-insights{grid-template-columns:1fr 1fr;align-items:start}}@media(max-width:900px){.kpi-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:639px){.reports-page{padding:14px}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px}.kpi-tile{padding:12px 14px}.kpi-tile>div:first-child{font-size:20px!important}.report-grid-2{grid-template-columns:1fr}.reports-header{flex-direction:column;align-items:flex-start}}@media print{.sidebar,.bottom-nav,.reports-header button,.btn{display:none!important}.reports-page{padding:0;max-width:100%}.report-card,.kpi-tile{break-inside:avoid}}.divider{border:none;border-top:1px solid var(--border);margin:16px 0}.text-accent{color:var(--accent)}.text-dim{color:var(--text-dim)}.text-muted{color:var(--text-muted)}.text-danger{color:var(--danger)}.font-mono{font-family:SF Mono,Fira Code,monospace}.text-right{text-align:right}.text-center{text-align:center}.flex{display:flex}.flex-1{flex:1}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:99px;border:1px solid transparent;font-size:12px;font-weight:700;font-family:inherit;cursor:pointer;white-space:nowrap;transition:filter .12s;line-height:1.4}.status-badge:hover{filter:brightness(1.15)}.status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.kebab-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;border-radius:var(--radius-sm);background:none;color:var(--text-muted);font-size:20px;line-height:1;cursor:pointer;font-family:inherit;transition:background .12s,color .12s;flex-shrink:0}.kebab-btn:hover{background:var(--surface-3);color:var(--text)}.job-card{background:var(--surface);border:1px solid var(--border);border-left-width:4px;border-radius:var(--radius);padding:12px 14px 10px;display:flex;flex-direction:column;gap:5px}.job-card-top{display:flex;justify-content:space-between;align-items:center}.job-card-amount{font-size:20px;font-weight:800;color:var(--accent);letter-spacing:-.02em}.job-card-name{font-size:17px;font-weight:700;display:flex;align-items:center;gap:6px;margin-top:2px}.job-card-active-dot{font-size:8px;color:var(--accent)}.job-card-addr{font-size:12px;color:var(--text-dim)}.job-card-meta{display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted);margin-top:1px}.job-card-actions{display:flex;gap:8px;align-items:center;margin-top:6px;padding-top:10px;border-top:1px solid var(--border)}.addr-pin-btn{display:inline-flex;align-items:center;justify-content:center;padding:2px 3px;border:none;background:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:color .12s,background .12s;vertical-align:middle;flex-shrink:0}.addr-pin-btn:hover{color:var(--accent);background:#facc151a}.addr-popover-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99}.addr-popover{position:absolute;top:calc(100% + 4px);left:0;z-index:100;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #00000080;min-width:160px;overflow:hidden}.addr-popover-item{display:flex;align-items:center;gap:8px;padding:10px 14px;font-size:13px;color:var(--text);text-decoration:none;cursor:pointer;transition:background .1s}.addr-popover-item:hover{background:var(--surface-3)}.addr-popover-item+.addr-popover-item{border-top:1px solid var(--border)}.map-embed-wrap{width:100%;border-radius:var(--radius);overflow:hidden;background:var(--surface-2);border:1px solid var(--border);position:relative}.map-embed-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;width:100%;height:100%;background:none;border:none;cursor:pointer;color:var(--text-muted);transition:color .15s,background .15s}.map-embed-placeholder:hover{color:var(--text);background:var(--surface-3)}.map-embed-label{font-size:13px;font-weight:600}.map-embed-addr{font-size:11px;color:var(--text-dim);max-width:240px;text-align:center;line-height:1.4}.address-card{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);background:var(--surface)}.address-card-actions{display:flex;gap:8px;padding:10px 12px;border-top:1px solid var(--border);background:var(--surface-2);flex-wrap:wrap}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border)}
