*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0a0a0a;--bg-secondary: #111111;--bg-card: #151515;--border-color: #333333;--border-subtle: #222222;--text-primary: #ffffff;--text-secondary: #e0e0e0;--text-muted: #888888;--text-label: #aaaaaa;--brand-accent: #F43903;--brand-accent-bg: #2a0d04;--brand-accent-text: #ffcbb8;--green-accent: #4ade80;--green-bg: #14532d;--green-text: #bbf7d0;--yellow-accent: #facc15;--yellow-bg: #422006;--yellow-text: #fde68a;--blue-accent: #60a5fa;--blue-bg: #1e3a5f;--blue-text: #93c5fd;--ease-smooth: cubic-bezier(.4, 0, .2, 1);--node-reveal-ms: .4s}body{font-family:Space Grotesk,system-ui,-apple-system,sans-serif;background:var(--bg-primary);color:var(--text-secondary);height:100vh;overflow:hidden;line-height:1.5}#app{display:flex;height:100vh;overflow:hidden}.sidebar{width:272px;flex-shrink:0;background:#141414;border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;overflow:hidden;transition:width .2s var(--ease-smooth)}.sidebar.collapsed{width:0;border-right:none}.sidebar-top{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 12px;flex-shrink:0}.sidebar-logo{height:22px;width:auto;opacity:.9}.sidebar-collapse-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:color .15s}.sidebar-collapse-btn:hover{color:var(--text-primary)}.new-session-btn{display:flex;align-items:center;gap:8px;margin:0 12px 16px;padding:9px 14px;background:transparent;border:1px solid var(--border-color);border-radius:8px;color:var(--brand-accent);font-family:inherit;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s;flex-shrink:0}.new-session-btn:hover{background:var(--brand-accent-bg);border-color:var(--brand-accent)}.sidebar-chats{flex:1;overflow-y:auto;padding:0 8px;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent}.sidebar-section-label{display:flex;align-items:center;gap:8px;padding:10px 8px 6px;font-size:12px;color:var(--text-muted);letter-spacing:.5px;white-space:nowrap}.sidebar-section-label:after{content:"";flex:1;height:1px;background:var(--border-subtle)}.sidebar-chat-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;font-size:14px;color:var(--text-secondary);cursor:pointer;transition:background .12s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-chat-item:hover{background:#ffffff0d}.sidebar-chat-item.active{background:#ffffff14;color:var(--text-primary)}.sidebar-chat-emoji{font-size:15px;flex-shrink:0}.sidebar-chat-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-footer{flex-shrink:0;border-top:1px solid var(--border-subtle);padding:12px 16px;display:flex;flex-direction:column;gap:4px}.sidebar-footer-item{display:flex;align-items:center;gap:8px;padding:7px 8px;font-size:14px;color:var(--text-muted);border-radius:6px;cursor:default}.sidebar-footer-version{font-size:12px;color:#444;padding-top:4px}.main-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.main-header{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:52px;border-bottom:1px solid var(--border-subtle);background:var(--bg-primary)}.main-header-title{font-size:15px;font-weight:500;color:var(--text-primary)}.main-scroll{flex:1;overflow-y:auto;padding:24px;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent}.loading-screen{position:fixed;inset:0;background:var(--bg-primary);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:100;transition:opacity .3s var(--ease-smooth)}.loading-screen.fade-out{opacity:0;pointer-events:none}.loading-logo{width:160px;height:auto;margin-bottom:24px}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--brand-accent);border-radius:50%;animation:spin 1s var(--ease-smooth) infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:16px;color:var(--text-muted);letter-spacing:2px;text-transform:uppercase}.container{max-width:900px;margin:0 auto;padding-bottom:24px}.container.fade-in{animation:fadeInUp .5s var(--ease-smooth) forwards}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}.recognition-panel{display:flex;gap:24px;margin-bottom:32px}@media(max-width:600px){.recognition-panel{flex-direction:column}.coin-view{flex:none!important;width:100%!important;height:240px!important}}.coin-view{flex:0 0 200px;height:200px;border:1px dashed #444;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-secondary);position:relative;overflow:hidden}#coin-canvas{width:100%;height:calc(100% - 24px);display:block}.coin-label{position:absolute;bottom:8px;font-size:13px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.recognition-info{flex:1;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:16px}.recognition-info h3{font-size:15px;color:var(--text-label);margin-bottom:12px;text-transform:uppercase;letter-spacing:1px;font-weight:500}.info-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border-subtle);font-size:15px}.info-row:last-child{border-bottom:none}.info-label{color:var(--text-muted)}.info-value{color:var(--text-primary);font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace;text-align:right;max-width:60%}.rfq-panel{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:20px;margin-bottom:32px;transform:translate(-20px);opacity:0}.rfq-panel.slide-in{animation:slideInLeft .4s var(--ease-smooth) forwards}@keyframes slideInLeft{to{transform:translate(0);opacity:1}}.rfq-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.rfq-title{font-size:16px;color:var(--text-label);font-weight:500}.rfq-badge{background:var(--bg-secondary);padding:4px 12px;border-radius:12px;font-size:13px;color:var(--text-muted)}.rfq-content{font-size:17px;color:#ddd;line-height:1.6}.rfq-highlight{color:var(--text-primary);font-weight:600}.decision-tree{background:#0d0d0d;border:1px solid var(--border-color);border-radius:8px;padding:24px;position:relative;opacity:0}.decision-tree.fade-in{animation:fadeInUp .4s var(--ease-smooth) forwards}.tree-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.tree-title{font-size:16px;color:var(--text-label);text-transform:uppercase;letter-spacing:1px}.tree-status{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--brand-accent)}.status-dot{width:8px;height:8px;background:var(--brand-accent);border-radius:50%}.tap-to-skip{position:absolute;bottom:12px;right:16px;font-size:13px;color:var(--text-muted);opacity:0;transition:opacity .3s var(--ease-smooth)}.tap-to-skip.visible{opacity:1}@media(prefers-reduced-motion:reduce){.tap-to-skip{display:none}}.tree-nodes{display:flex;flex-direction:column;gap:16px}.tree-node{display:flex;gap:16px;align-items:flex-start;opacity:0;transform:translate3d(0,10px,0);-webkit-backface-visibility:hidden;backface-visibility:hidden;will-change:opacity,transform}.tree-node.visible{opacity:1;transform:translateZ(0)}.tree-node.animate-in{animation:nodeReveal var(--node-reveal-ms) var(--ease-smooth) forwards}.tree-node.animate-in.visible{animation:none;opacity:1;transform:translateZ(0)}@keyframes nodeReveal{to{opacity:1;transform:translateZ(0)}}@media(prefers-reduced-motion:reduce){.tree-node{animation:none!important;opacity:1;transform:none}}.node-connector{width:24px;display:flex;flex-direction:column;align-items:center;padding-top:4px}.node-dot{width:12px;height:12px;border:2px solid;border-radius:50%;background:#0d0d0d}.node-line{width:2px;height:40px;background:var(--border-color)}.node-dot.pass{border-color:var(--green-accent)}.node-dot.warn{border-color:var(--yellow-accent)}.node-dot.info{border-color:var(--blue-accent)}.node-dot.search{border-color:#a855f7}.node-content{flex:1;background:var(--bg-card);border:1px solid #2a2a2a;border-radius:6px;padding:12px 16px}.node-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;flex-wrap:wrap;gap:8px}.node-title{font-size:15px;font-weight:500;color:var(--text-primary)}.node-badge{font-size:14px;padding:2px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.node-badge.pass{background:var(--green-bg);color:var(--green-text)}.node-badge.warn{background:var(--yellow-bg);color:var(--yellow-text)}.node-badge.info{background:var(--blue-bg);color:var(--blue-text)}.node-badge.search{background:#3b1764;color:#d8b4fe}.node-detail{font-size:15px;color:var(--text-label);line-height:1.5}.node-data{display:flex;gap:16px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border-subtle);flex-wrap:wrap}.data-item{font-size:15px}.data-label{color:var(--text-muted)}.data-value{color:#ccc;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace}.similar-parts{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-subtle)}.similar-parts-header{font-size:13px;color:#a855f7;text-transform:uppercase;letter-spacing:1px;margin-bottom:10px}.similar-parts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.similar-part{background:#1a1a24;border:1px solid #2a2a3a;border-radius:8px;padding:10px 12px}.similar-part-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px;flex-wrap:wrap;gap:4px}.similar-part-id{font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace;font-size:15px;color:var(--text-primary)}.similar-part-header-right{display:flex;align-items:center;gap:8px}.similar-part-match{font-size:14px;color:#a855f7;font-weight:500}.similar-part-data{display:flex;gap:16px;font-size:14px;color:var(--text-label);margin-bottom:4px;flex-wrap:wrap}.similar-part-cost{color:var(--green-text);font-weight:500}.similar-part-notes{font-size:14px;color:var(--text-muted);font-style:italic}.similar-part-viewer{margin-top:10px;border-radius:6px;overflow:hidden;background:#111;position:relative;width:100%;aspect-ratio:4 / 3}.similar-part-canvas{display:block;width:100%;height:100%}.similar-part-canvas-label{position:absolute;bottom:6px;left:8px;font-size:11px;color:var(--text-muted);font-family:Space Grotesk,monospace;pointer-events:none}.rfq-source{font-size:14px;color:var(--text-muted);margin-top:4px}.recommendation{margin-top:24px;padding:20px;background:linear-gradient(135deg,var(--green-bg) 0%,#0d2e1a 100%);border:1px solid rgba(74,222,128,.4);border-radius:8px;opacity:0;transform:translate3d(0,10px,0);-webkit-backface-visibility:hidden;backface-visibility:hidden}.recommendation.animate-in{animation:nodeReveal .4s var(--ease-smooth) forwards}.recommendation.visible{opacity:1;transform:translateZ(0)}.recommendation.animate-in.visible{animation:none}.rec-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:8px}.rec-title{font-size:14px;text-transform:uppercase;letter-spacing:1px;color:var(--green-text)}.rec-confidence{font-size:13px;color:var(--green-text)}.rec-verdict{font-size:24px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.rec-summary{font-size:15px;color:var(--green-text);line-height:1.5}.rec-metrics{display:flex;gap:24px;margin-top:16px;padding-top:16px;border-top:1px solid rgba(74,222,128,.25);flex-wrap:wrap}@media(max-width:500px){.rec-metrics{display:grid;grid-template-columns:1fr 1fr;gap:16px}}.metric{text-align:center}.metric-value{font-size:20px;font-weight:600;color:var(--text-primary)}.metric-label{font-size:14px;color:var(--green-text);text-transform:uppercase;letter-spacing:.5px}.rec-alternatives{margin-top:16px;padding-top:16px;border-top:1px solid rgba(74,222,128,.25)}.rec-alternatives-header{font-size:13px;color:var(--green-text);text-transform:uppercase;letter-spacing:1px;margin-bottom:10px}.rec-alternative{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#0003;border-radius:4px;margin-bottom:6px;flex-wrap:wrap;gap:8px}.rec-alternative:last-child{margin-bottom:0}.rec-alt-option{font-size:14px;color:var(--text-primary);font-weight:500}.rec-alt-tradeoff{font-size:13px;color:var(--green-text)}.cta{margin-top:32px;padding:24px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;text-align:center;opacity:0}.cta.fade-in{animation:fadeInUp .4s var(--ease-smooth) forwards}.cta-text{font-size:17px;color:var(--text-secondary);margin-bottom:8px}.cta-text strong{color:var(--text-primary)}.cta-subtext{font-size:15px;color:var(--text-muted);margin-bottom:16px}.cta-link{display:inline-block;padding:12px 24px;background:var(--brand-accent);color:#fff;font-size:16px;font-weight:500;text-decoration:none;border-radius:6px;transition:background .2s var(--ease-smooth)}.cta-link:hover{background:#d43300}.cta-link:focus{outline:2px solid var(--brand-accent);outline-offset:2px}.version-label{margin-top:16px;font-size:13px;color:var(--text-muted);letter-spacing:.5px}.view-drawing-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-label);font-family:inherit;font-size:14px;padding:3px 8px;border-radius:4px;cursor:pointer;letter-spacing:.5px;text-transform:uppercase;transition:border-color .15s,color .15s}.view-drawing-btn:hover{border-color:var(--brand-accent);color:var(--brand-accent)}.coin-view .view-drawing-btn{position:absolute;top:8px;right:8px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.simulated-message{margin:20px 0 8px;cursor:pointer;opacity:0;display:flex;flex-direction:column;align-items:flex-end}.simulated-message.fade-in{animation:fadeInUp .5s ease forwards}.sim-msg-bubble{background:var(--brand-accent);border-radius:16px 16px 4px;padding:10px 14px;max-width:78%;font-size:15px;color:#fff;line-height:1.5;min-height:1.5em}.sim-msg-attachments{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap;justify-content:flex-end}.file-chip{background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:4px;padding:3px 8px;font-size:12px;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace;color:#ffffffb3}.system-reply{margin:16px 0 8px;display:flex;align-items:flex-start;max-width:85%;animation:fadeInUp .35s ease forwards;min-height:40px}.system-reply.thinking{align-items:center;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:4px 16px 16px}.system-reply.thinking:after{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--text-muted);animation:pulse 1s infinite;box-shadow:14px 0 0 var(--text-muted),28px 0 0 var(--text-muted)}.system-reply-text{font-size:15px;color:var(--text-primary);line-height:1.6;background:var(--bg-card);border:1px solid var(--border-color);border-radius:4px 16px 16px;padding:10px 14px}.gate-prompt{margin:12px 0;display:flex;flex-direction:column;align-items:flex-start;animation:fadeInUp .3s ease forwards;max-width:85%}.gate-text{font-size:15px;color:var(--text-primary);margin:0 0 10px;line-height:1.6;background:var(--bg-card);border:1px solid var(--border-color);border-radius:4px 16px 16px;padding:10px 14px}.proceed-btn{background:var(--brand-accent);color:#fff;border:none;border-radius:8px;padding:9px 20px;font-size:14px;font-family:inherit;cursor:pointer;transition:opacity .15s;align-self:flex-start}.proceed-btn:hover{opacity:.85}.gate-thinking .proceed-btn{opacity:.4;pointer-events:none}.gate-thinking:after{content:"";display:inline-block;margin-left:12px;width:6px;height:6px;border-radius:50%;background:var(--text-muted);animation:pulse 1s infinite;box-shadow:14px 0 0 var(--text-muted),28px 0 0 var(--text-muted)}.chat-input-bar{flex-shrink:0;display:flex;align-items:center;gap:10px;padding:10px 24px 14px;background:var(--bg-primary);border-top:1px solid var(--border-color)}.chat-input-placeholder{flex:1;min-width:0;font-size:15px;color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;padding:8px 12px;min-height:36px;display:flex;align-items:center}.chat-input-placeholder:empty:before{content:"Accept suggested action or ask a question...";color:var(--text-muted)}.chat-send-btn{width:32px;height:32px;border-radius:50%;background:var(--brand-accent);border:none;color:#fff;font-size:16px;cursor:default;display:flex;align-items:center;justify-content:center;flex-shrink:0}.start-over-btn{background:transparent;border:1px solid var(--border-subtle);color:var(--text-muted);border-radius:4px;padding:5px 12px;font-size:13px;font-family:inherit;cursor:pointer;transition:color .15s,border-color .15s}.start-over-btn:hover{color:var(--text-primary);border-color:var(--border-color)}.pdf-panel{position:fixed;inset:16px;width:auto;height:auto;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;display:flex;flex-direction:column;z-index:1000;box-shadow:0 24px 64px #000000b3;overflow:hidden}.pdf-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-color);flex-shrink:0}.pdf-panel-title{font-size:14px;color:var(--text-label);text-transform:uppercase;letter-spacing:.5px}.pdf-panel-close{background:transparent;border:none;color:var(--text-muted);font-size:16px;cursor:pointer;padding:4px 8px;border-radius:4px;font-family:inherit;line-height:1}.pdf-panel-close:hover{color:var(--text-primary);background:var(--bg-card)}.pdf-body{flex:1;position:relative;overflow:hidden}.pdf-panel iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.offline-warning{position:fixed;bottom:0;left:0;right:0;background:#422006;color:var(--yellow-text);padding:16px;text-align:center;font-size:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px))}.fallback-image{max-width:150px;height:auto;margin-bottom:8px}.fallback-text{font-size:13px;color:var(--text-muted);text-align:center}:focus-visible{outline:2px solid var(--brand-accent);outline-offset:2px}.skip-link{position:absolute;top:-40px;left:0;background:var(--brand-accent);color:#fff;padding:8px 16px;text-decoration:none;z-index:200}.skip-link:focus{top:0}
