:root{--bg: #f7f8fa;--surface: #ffffff;--line: #e3e6eb;--line-strong: #d2d6dd;--text: #1f2329;--muted: #6b7280;--accent: #2f6fb3;--accent-soft: #eaf1f9;--danger: #c0392b;--radius: 12px;--shadow: 0 1px 2px rgba(20, 24, 30, .04), 0 4px 16px rgba(20, 24, 30, .05)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font:inherit;cursor:pointer}.app{display:flex;flex-direction:column;height:100%}.topbar{display:flex;align-items:center;gap:16px;padding:10px 18px;background:var(--surface);border-bottom:1px solid var(--line)}.brand{font-weight:600;font-size:15px}.topbar .base-menu{margin-left:auto}.bom-toggle{display:none;background:var(--accent);color:#fff;border:none;border-radius:8px;padding:8px 14px}.back-btn{border:1px solid var(--line);background:var(--surface);color:var(--muted);border-radius:8px;padding:7px 12px;font-size:13px;transition:border-color .12s,color .12s}.back-btn:hover{border-color:var(--line-strong);color:var(--text)}.done-btn{margin-left:auto;background:var(--accent);color:#fff;border:none;border-radius:10px;padding:14px 32px;font-weight:600;font-size:17px}.done-btn:hover{filter:brightness(.96)}.base-menu{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}.base-menu select,.need select{font:inherit;padding:6px 10px;border:1px solid var(--line-strong);border-radius:8px;background:var(--surface);color:var(--text)}.workspace{flex:1;display:grid;grid-template-columns:248px 1fr 312px;min-height:0}.palette-panel,.bom-panel{background:var(--surface);overflow-y:auto}.palette-panel{border-right:1px solid var(--line)}.bom-panel{border-left:1px solid var(--line)}.panel-title{font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:0 0 8px}.palette{padding:16px}.base-menu-panel{padding:16px;border-bottom:1px solid var(--line)}.hint{font-size:12px;color:var(--muted);margin:0 0 14px;line-height:1.4}.palette-list,.base-list{display:flex;flex-direction:column;gap:8px}.palette-item,.base-item{display:flex;flex-direction:column;align-items:flex-start;gap:2px;text-align:left;padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:var(--surface);transition:border-color .12s,background .12s}.palette-item:hover,.base-item:hover{border-color:var(--line-strong)}.palette-item.active,.base-item.active{border-color:var(--accent);background:var(--accent-soft)}.palette-name,.base-name{font-weight:550;font-size:14px}.palette-meta,.base-meta{font-size:12px;color:var(--muted)}.canvas-wrap{position:relative;min-height:0;background:var(--bg)}.canvas-wrap canvas{display:block;width:100%!important;height:100%!important;touch-action:none}.camera-buttons{position:absolute;top:14px;left:14px;display:flex;gap:6px;background:#ffffffd9;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:5px;border-radius:10px;border:1px solid var(--line)}.cam-btn{border:none;background:transparent;color:var(--muted);padding:6px 12px;border-radius:7px;font-size:13px}.cam-btn.active{background:var(--accent);color:#fff}.warning-banner{position:absolute;top:14px;left:50%;transform:translate(-50%);max-width:420px;background:#fdecea;color:var(--danger);border:1px solid #f4c7c2;padding:8px 14px;border-radius:10px;font-size:12.5px;line-height:1.4;text-align:center}.inspector{position:absolute;bottom:16px;left:50%;transform:translate(-50%);width:min(360px,calc(100% - 28px));background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px 16px}.inspector-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.inspector-name{font-weight:600}.close-x{border:none;background:transparent;font-size:20px;line-height:1;color:var(--muted)}.color-row{margin-bottom:12px}.color-label{font-size:12px;color:var(--muted);display:block;margin-bottom:6px}.swatches{display:flex;gap:8px}.swatch{width:30px;height:30px;border-radius:8px;border:2px solid transparent;box-shadow:inset 0 0 0 1px #00000014}.swatch.selected{border-color:var(--text)}.remove-btn{width:100%;padding:9px;border:1px solid #f4c7c2;background:#fdecea;color:var(--danger);border-radius:8px;font-weight:550}.bom{padding:16px}.bom-head{display:flex;align-items:center;justify-content:space-between}.bom-head .close-x{display:none}.bom-table{width:100%;border-collapse:collapse;font-size:13px}.bom-table th{text-align:left;font-weight:550;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.03em;padding:6px 4px;border-bottom:1px solid var(--line)}.bom-table td{padding:9px 4px;border-bottom:1px solid var(--line);vertical-align:top}.bom-table .num{text-align:right;white-space:nowrap}.sku{display:block;font-size:11px;color:var(--muted)}.bom-table tfoot td{border:none;padding-top:12px;font-weight:600}.total{color:var(--accent);font-size:15px}.module-remove-pop{display:inline-flex;align-items:center;gap:6px;padding:6px 12px 6px 8px;background:var(--surface);color:var(--danger);border:1px solid #f4c7c2;border-radius:999px;box-shadow:var(--shadow);font-size:13px;font-weight:600;white-space:nowrap;-webkit-user-select:none;user-select:none;transition:background .12s}.module-remove-pop:hover{background:#fdecea}.module-remove-x{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:#fdecea;font-size:16px;line-height:1}.module-remove-label{letter-spacing:.01em}.inventory-desktop{border-top:1px solid var(--line);margin-top:4px}.inventory-mobile{display:none;border-top:1px solid var(--line)}.inventory{padding:16px}.inventory-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:10px}.inventory-head .panel-title{margin:0}.inventory-count{font-size:12px;color:var(--muted)}.inventory-empty{font-size:12.5px;color:var(--muted);line-height:1.45;margin:0}.inventory-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.inventory-item{display:flex;align-items:stretch;gap:4px;border:1px solid var(--line);border-radius:10px;background:var(--surface);overflow:hidden;transition:border-color .12s,background .12s}.inventory-item:hover{border-color:var(--line-strong)}.inventory-item.active{border-color:var(--accent);background:var(--accent-soft)}.inventory-info{flex:1;display:flex;align-items:center;gap:10px;text-align:left;background:transparent;border:none;padding:10px 12px;min-width:0}.inventory-dot{flex:0 0 auto;width:12px;height:12px;border-radius:50%;box-shadow:inset 0 0 0 1px #0000001f}.inventory-dot.empty{background:#d2d6dd}.inventory-text{display:flex;flex-direction:column;gap:1px;min-width:0}.inventory-name{font-size:13px;font-weight:550;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inventory-meta{font-size:11px;color:var(--muted)}.inventory-remove{flex:0 0 auto;border:none;border-left:1px solid var(--line);background:transparent;color:var(--muted);font-size:18px;line-height:1;width:38px;transition:background .12s,color .12s}.inventory-remove:hover{background:#fdecea;color:var(--danger)}.start{min-height:100%;display:grid;place-items:center;padding:32px 24px;background:linear-gradient(180deg,#fbfcfd 0%,var(--bg) 100%)}.start-card{width:min(520px,100%);background:var(--surface);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);padding:40px}.start-card.wide{width:min(680px,100%)}.start-card h1{margin:0 0 8px;font-size:26px;font-weight:700;letter-spacing:-.02em;color:var(--text)}.start-sub{margin:0 0 28px;color:var(--muted);font-size:15px;line-height:1.5}.start-options{display:flex;flex-direction:column;gap:14px}.start-options-secondary{display:grid;grid-template-columns:1fr 1fr;gap:14px}.start-option{position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:4px;text-align:left;padding:18px 20px;border:1px solid var(--line);border-radius:14px;background:var(--surface);transition:border-color .14s,background .14s,box-shadow .14s,transform .14s}.start-option:hover{border-color:var(--line-strong);box-shadow:var(--shadow);transform:translateY(-1px)}.start-option.primary{border:1.5px solid var(--accent);background:linear-gradient(180deg,#f6faff 0%,var(--surface) 100%);padding:24px 24px 22px;gap:6px}.start-option.primary:hover{background:var(--accent-soft)}.start-option.primary .opt-title{font-size:18px}.opt-badge{align-self:flex-start;display:inline-flex;align-items:center;background:var(--accent);color:#fff;font-size:11px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;padding:4px 10px;border-radius:999px;margin-bottom:2px}.opt-cta{margin-top:8px;font-size:14px;font-weight:600;color:var(--accent)}.opt-title{font-weight:600;font-size:15px;color:var(--text)}.opt-desc{font-size:13px;color:var(--muted);line-height:1.45}.back-link{border:none;background:transparent;color:var(--muted);padding:0 0 14px;font-size:13px}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px}.template-card{display:flex;flex-direction:column;gap:6px;text-align:left;padding:18px;border:1px solid var(--line);border-radius:14px;background:var(--surface);transition:border-color .14s,box-shadow .14s,transform .14s}.template-card:hover{border-color:var(--line-strong);box-shadow:var(--shadow);transform:translateY(-1px)}.template-name{font-weight:600}.template-desc{font-size:12.5px;color:var(--muted);line-height:1.4}.template-desc.muted{color:#57606a}.template-count{font-size:12px;color:var(--accent)}.needs{display:flex;flex-direction:column;gap:4px;margin-bottom:22px}.need{display:flex;align-items:center;gap:10px;padding:10px 4px;border-bottom:1px solid var(--line);font-size:14px}.need.indented{padding-left:28px;justify-content:space-between}.need input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent)}.onboard-actions{display:flex;gap:10px;flex-wrap:wrap}.primary-btn{background:var(--accent);color:#fff;border:none;border-radius:9px;padding:11px 20px;font-weight:550}.ghost-btn{background:var(--surface);color:var(--accent);border:1px solid var(--accent);border-radius:9px;padding:11px 20px;font-weight:550}.ghost-btn:disabled{opacity:.6;cursor:default}.ai-note{margin-top:14px;font-size:13px;color:var(--muted)}.suggestions{margin-top:22px}.scrim{display:none}.modal-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#14181e52;display:grid;place-items:center;padding:24px;z-index:50}.modal{width:min(380px,100%);background:var(--surface);border:1px solid var(--line);border-radius:16px;box-shadow:0 8px 40px #14181e29;padding:24px}.modal-title{margin:0 0 6px;font-size:17px;font-weight:600}.modal-body{margin:0 0 20px;color:var(--muted);font-size:14px;line-height:1.5}.modal-actions{display:flex;justify-content:flex-end;gap:10px}.danger-btn{background:var(--danger);color:#fff;border:none;border-radius:9px;padding:10px 18px;font-weight:600}.danger-btn:hover{filter:brightness(.96)}.invoice-page{min-height:100%;background:var(--bg);padding:28px 24px 56px}.invoice-actions{width:min(760px,100%);margin:0 auto 18px;display:flex;justify-content:space-between;gap:12px}.invoice-sheet{width:min(760px,100%);margin:0 auto;background:var(--surface);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:40px}.invoice-header{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;padding-bottom:24px;margin-bottom:24px;border-bottom:1px solid var(--line)}.invoice-brand{display:flex;align-items:center;gap:14px}.invoice-logo{width:48px;height:48px;border-radius:12px;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:700;font-size:18px;letter-spacing:.02em}.invoice-company{font-weight:600;font-size:16px}.invoice-tagline{font-size:13px;color:var(--muted)}.invoice-meta{text-align:right;min-width:160px}.invoice-meta h1{margin:0 0 10px;font-size:24px;font-weight:700;letter-spacing:-.01em}.invoice-meta-row{display:flex;justify-content:space-between;gap:16px;font-size:13px;padding:2px 0}.invoice-meta-row span{color:var(--muted)}.invoice-table{width:100%;border-collapse:collapse;font-size:14px}.invoice-table th{text-align:left;font-weight:600;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.03em;padding:8px 10px;border-bottom:1px solid var(--line-strong)}.invoice-table td{padding:12px 10px;border-bottom:1px solid var(--line)}.invoice-table .num{text-align:right;white-space:nowrap}.invoice-sku{color:var(--muted);font-size:12.5px}.invoice-table tfoot td{border-bottom:none;padding-top:18px}.invoice-total-label{text-align:right;font-weight:600;font-size:15px}.invoice-total{font-weight:700;font-size:18px;color:var(--accent)}.invoice-note{margin:24px 0 0;font-size:12px;color:var(--muted);line-height:1.5}@media print{.no-print{display:none!important}.invoice-page{padding:0;background:#fff}.invoice-sheet{border:none;box-shadow:none;border-radius:0;width:100%;padding:0}}@media(max-width:860px){.topbar{gap:8px;padding:8px 12px}.brand{font-size:13px;line-height:1.1}.base-menu-label{display:none}.base-menu select{max-width:150px;text-overflow:ellipsis}.bom-toggle{padding:8px 10px;white-space:nowrap}.workspace{display:flex;flex-direction:column;position:relative}.canvas-wrap{order:1;flex:1 1 auto;min-height:0}.palette-panel{order:2;flex:0 0 96px;border-right:none;border-top:1px solid var(--line);overflow-x:auto;overflow-y:hidden}.palette,.base-menu-panel{padding:10px 12px}.base-menu-panel .panel-title,.palette h2,.palette .hint{display:none}.palette-list,.base-list{flex-direction:row;gap:8px;height:100%}.palette-item,.base-item{flex:0 0 auto;width:150px;justify-content:center}.start-card,.start-card.wide{padding:28px 22px}.start-options-secondary{grid-template-columns:1fr}.inventory-desktop{display:none}.inventory-mobile{display:block}.bom-toggle{display:inline-block}.bom-panel{position:fixed;top:0;right:0;height:100%;width:min(360px,86%);transform:translate(100%);transition:transform .22s ease;z-index:30;box-shadow:var(--shadow)}.bom-panel.open{transform:translate(0)}.bom-head .close-x{display:block}.scrim{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#14181e4d;z-index:20}}
