:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#414141;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#ffffff26;--accent-border: ;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;box-sizing:border-box;flex-direction:column;width:auto;max-width:100%;min-height:100svh;margin:0 auto;display:flex}html,body{height:100%;margin:0}.app-container{flex:1}.app-container.centered{text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.upload-container{margin-bottom:24px}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.logo-video{width:400px;height:auto;margin:0 auto 40px;display:block}.upload-button{border:1px solid var(--accent-border);height:46px;color:var(--text-h);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;padding:0 18px;font-weight:500;display:inline-flex}.upload-button:hover{opacity:.9;background:var(--accent-bg)}.upload-input{display:none}.input-row{flex-wrap:wrap;justify-content:center;align-items:flex-start;gap:14px;margin-bottom:24px;display:flex}.help-panel{max-height:70vh;overflow-y:auto}.help-section{border-top:1px solid var(--border);margin-top:10px;padding-top:10px}.help-section-toggle{width:100%;color:var(--text-h);font:inherit;cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;padding:2px 0;font-weight:600;display:flex}.help-section-arrow{flex-shrink:0;margin-left:12px;font-size:.95rem}.help-section-content{padding-top:8px}.help-section-content p{margin:0 0 10px}.manual-add{flex-wrap:wrap;justify-content:center;align-items:stretch;gap:10px;display:flex;position:relative}.manual-add-search-wrap{min-width:260px;position:relative}.manual-add-input,.manual-add-quantity{border:1px solid var(--accent-border);background:var(--code-bg);height:46px;color:var(--text-h);font-family:var(--sans);box-sizing:border-box;border-radius:12px;outline:none;padding:0 14px;font-size:.95rem}.manual-add-input{width:100%}.manual-add-quantity{text-align:center;width:90px}.manual-add-input:focus,.manual-add-quantity:focus{box-shadow:0 0 0 3px var(--accent-bg)}.manual-add-button{border:1px solid var(--accent-border);background:var(--accent-bg);height:46px;color:var(--text-h);cursor:pointer;border-radius:12px;padding:0 16px;font-weight:500;transition:transform .2s,opacity .2s,background .2s}.manual-add-button:hover{opacity:.92;transform:scale(1.02)}.manual-add-dropdown{z-index:100;border:1px solid var(--border);background:var(--code-bg);box-shadow:var(--shadow);border-radius:14px;max-height:320px;position:absolute;top:calc(100% + 8px);left:0;right:0;overflow:hidden auto}.manual-add-option{text-align:left;width:100%;color:var(--text-h);cursor:pointer;font:inherit;background:0 0;border:none;align-items:center;gap:10px;padding:12px 14px;display:flex}.manual-add-option:hover{background:var(--accent-bg)}.manual-add-option:not(:last-child){border-bottom:1px solid var(--border)}.manual-add-icon{object-fit:contain;image-rendering:auto;flex-shrink:0;width:22px;height:22px}.manual-add-input-shell{width:100%;position:relative}.manual-add-input-shell.has-icon .manual-add-input{padding-left:46px}.manual-add-input-icon{object-fit:contain;pointer-events:none;width:22px;height:22px;position:absolute;top:50%;left:14px;transform:translateY(-50%)}@media (width<=700px){.manual-add{flex-direction:column;align-items:stretch;width:100%}.manual-add-search-wrap{width:100%;min-width:0}.manual-add-quantity,.manual-add-button{width:100%}}.raw-summary-header{align-items:center;gap:12px;padding:0 12px 0 0;display:flex}.raw-summary-toggle{cursor:pointer;width:100%;color:var(--text-h);text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:16px 20px;font-size:1rem;font-weight:600;display:flex}.raw-summary-export{border:1px solid var(--accent-border);background:var(--accent-bg);color:var(--text-h);cursor:pointer;border-radius:8px;margin-left:8px;padding:6px 10px;font-size:.8rem;transition:transform .2s,opacity .2s}.raw-summary-export:hover{opacity:.9;transform:scale(1.03)}@media (width<=700px){.raw-summary-header{flex-wrap:wrap;padding:0 12px 12px}.raw-summary-toggle,.raw-summary-export{width:100%}}.pdf-export-row{justify-content:center;margin:-4px 0 28px;display:flex}.pdf-export-button{border:1px solid var(--accent-border);background:var(--accent-bg);color:var(--text-h);font:inherit;cursor:pointer;white-space:nowrap;border-radius:12px;padding:10px 18px;font-weight:600;transition:transform .2s,opacity .2s,background .2s}.pdf-export-button:hover{opacity:.92;transform:scale(1.02)}.results-container{flex-direction:column;align-items:center;gap:32px;display:flex}.result-card{background:var(--code-bg);width:fit-content;max-width:90%;box-shadow:var(--shadow);text-align:left;border-radius:18px;padding:20px;transition:transform .22s,opacity .22s,filter .22s;position:relative}.result-check-overlay{z-index:10;border:1px solid var(--border);box-shadow:var(--shadow);cursor:pointer;background:#232323b3;border-radius:10px;justify-content:center;align-items:center;padding:6px;display:flex;position:absolute;top:12px;right:12px}.result-check-overlay input[type=checkbox]{cursor:pointer;width:18px;height:18px}.result-check-overlay:hover{transform:scale(1.05)}.result-card-complete{opacity:.72}.result-card-animating-out{opacity:0;filter:blur(2px);transform:translateY(-10px)scale(.985)}.footer{text-align:center;color:var(--text);background:var(--bg);padding:16px;font-size:14px}.help-button{border:1px solid var(--border);background:var(--code-bg);width:42px;height:42px;color:var(--text-h);box-shadow:var(--shadow);cursor:pointer;z-index:1000;border-radius:12px;font-size:22px;font-weight:600;position:fixed;top:20px;right:20px}.help-panel{border:1px solid var(--border);background:var(--code-bg);width:360px;max-height:70vh;color:var(--text-h);box-shadow:var(--shadow);z-index:1000;border-radius:16px;padding:16px;position:fixed;top:20px;right:82px;overflow-y:auto}.help-panel h3{margin-top:0;margin-bottom:10px}.help-panel p{margin:0 0 10px;line-height:1.4}.top-options{flex-wrap:wrap;justify-content:center;gap:24px;margin:20px 0 10px;display:flex}.checkbox-option{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff14;border-radius:10px;align-items:center;gap:8px;margin-bottom:24px;padding:10px 14px;font-size:.95rem;display:flex}.checkbox-option input[type=checkbox]{cursor:pointer}.mobile-tree-hint{display:none}.raw-summary-dropdown{border:1px solid var(--border);background:var(--code-bg);width:min(600px,92%);box-shadow:var(--shadow);border-radius:16px;margin:0 auto 28px;overflow:hidden}.raw-summary-toggle{cursor:pointer;width:100%;color:var(--text-h);text-align:left;-webkit-user-select:none;user-select:none;background:0 0;border:none;padding:16px 20px;font-size:1rem;font-weight:600}.raw-summary-toggle:after{display:none}.raw-summary-arrow{margin-left:auto;transition:transform .25s}.raw-summary-open .raw-summary-arrow,.raw-summary-open .raw-summary-toggle:after{transform:rotate(180deg)}.raw-summary-list{opacity:0;grid-template-rows:0fr;transition:grid-template-rows .28s,opacity .22s;display:grid}.raw-summary-open .raw-summary-list{opacity:1;grid-template-rows:1fr}.raw-summary-list-inner{border-top:1px solid var(--border);overflow:hidden}.raw-summary-list-content{padding:8px 0;transition:transform .28s;transform:translateY(-8px)}.raw-summary-open .raw-summary-list-content{transform:translateY(0)}.raw-summary-item{color:var(--text-h);text-align:left;white-space:pre-line;justify-content:space-between;align-items:center;gap:16px;padding:12px 20px;transition:transform .22s,opacity .22s,filter .22s;display:flex}.raw-summary-item:not(:last-child){border-bottom:1px solid var(--border)}.raw-summary-check-inline{cursor:pointer;justify-content:center;align-items:center;margin-right:2px;display:flex}.raw-summary-check-inline input[type=checkbox]{cursor:pointer;width:18px;height:18px}.raw-summary-item-complete{opacity:.72}.raw-summary-item-animating-out{opacity:0;filter:blur(2px);transform:translateY(-10px)scale(.985)}.raw-summary-item-left{align-items:center;gap:10px;min-width:0;display:flex}.raw-summary-name{font-weight:500}.raw-summary-quantity{text-align:right;white-space:pre-line}.bmc-link{z-index:1000;color:var(--text-h);background:var(--code-bg);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:999px;padding:8px 14px;font-size:.85rem;font-weight:500;text-decoration:none;transition:all .2s;position:fixed;top:20px;left:20px}.bmc-link:hover{background:var(--accent-bg);transform:scale(1.05)}.contact-button{border:1px solid var(--border);background:var(--code-bg);width:42px;height:42px;color:var(--text-h);box-shadow:var(--shadow);cursor:pointer;z-index:1000;border-radius:12px;justify-content:center;align-items:center;font-size:18px;font-weight:600;display:flex;position:fixed;top:70px;right:20px}.contact-panel{border:1px solid var(--border);background:var(--code-bg);width:320px;color:var(--text-h);box-shadow:var(--shadow);z-index:1000;border-radius:16px;padding:16px;position:fixed;top:120px;right:20px}.contact-form{flex-direction:column;gap:14px;display:flex}.contact-input,.contact-select,.contact-textarea{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text-h);font-family:var(--sans);box-sizing:border-box;border-radius:16px;outline:none;font-size:.9rem;transition:border-color .2s,box-shadow .2s,background .2s}.contact-input,.contact-select{height:58px}.contact-input{padding:0 18px}.contact-select{color:#ffffff8c;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 18px center;background-repeat:no-repeat;background-size:16px;padding:0 48px 0 18px}.contact-select.has-value{color:var(--text-h)}.contact-textarea{resize:none;min-height:140px;padding:16px 18px}.contact-input:focus,.contact-select:focus,.contact-textarea:focus{border-color:var(--accent-border);box-shadow:0 0 0 3px var(--accent-bg)}.contact-input::placeholder,.contact-textarea::placeholder{color:#ffffff8c}.contact-select option{color:var(--text-h);background:#1f2028}.contact-submit{border:1px solid var(--accent-border);background:var(--accent-bg);color:var(--text-h);cursor:pointer;border-radius:16px;margin-top:6px;padding:12px;font-weight:500;transition:transform .2s,opacity .2s,background .25s,border-color .25s,color .25s}.contact-submit:hover:not(:disabled){opacity:.92;transform:scale(1.02)}.contact-submit:disabled{cursor:default}.contact-submit-text{transition:all .25s;display:inline-block}.contact-submit-sending{opacity:.85}.contact-submit-sent{color:#7ee08a;background:#50c8782e;border-color:#50c8788c}@media (width<=700px){.bmc-link,.help-button,.contact-button{z-index:20;position:absolute}.bmc-link{top:20px;left:20px}.help-button{top:20px;right:20px}.contact-button{top:78px;right:20px}.help-panel{z-index:30;width:min(320px,100vw - 110px);max-height:60vh;position:absolute;top:20px;right:74px}.contact-panel{z-index:30;width:min(300px,100vw - 40px);position:absolute;top:128px;right:20px}.app-container{padding-top:120px}.app-container.centered{justify-content:flex-start;padding-top:120px}.results-container{gap:20px;width:100%}.result-card{box-sizing:border-box;width:100%;max-width:100%;padding:12px 8px 10px;overflow:hidden}.manual-add{grid-template-columns:auto auto;justify-content:center;gap:10px;width:100%;max-width:360px;margin:0 auto;display:grid}.manual-add-search-wrap{grid-column:1/-1;width:100%}.manual-add-input-shell,.manual-add-input{width:100%}.manual-add-quantity{justify-self:end;width:72px;min-width:72px}.manual-add-button{justify-self:start;width:auto;min-width:110px;padding:0 14px}.manual-add-dropdown{width:100%;left:0;right:0}.raw-summary-dropdown{border-radius:18px;width:min(72%,420px);margin:0 auto 24px}.raw-summary-header{padding:0}.raw-summary-toggle{grid-template-columns:1fr auto auto;align-items:center;gap:10px;padding:14px 16px;display:grid}.raw-summary-toggle span:first-child{font-size:.95rem;line-height:1.15}.raw-summary-export{white-space:nowrap;border-radius:10px;width:auto;min-width:0;margin-left:0;padding:5px 10px;font-size:.78rem}.raw-summary-arrow{margin-left:0;font-size:.9rem}.raw-summary-item{flex-direction:row;justify-content:space-between;align-items:center;gap:12px;padding:10px 16px;display:flex}.raw-summary-item-left{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.raw-summary-quantity{opacity:.95;text-align:right;white-space:pre-line;flex-shrink:0;margin-left:auto;font-size:.92rem}.raw-summary-name{font-size:.95rem;line-height:1.2}.raw-summary-check-inline input[type=checkbox]{width:17px;height:17px}.mobile-tree-hint{color:var(--text);opacity:.7;text-align:center;letter-spacing:.3px;margin:-6px 0 10px;font-size:.75rem;display:block}.checkbox-option{margin-bottom:-15px}.checkbox-option:last-child{margin-bottom:0}}.tree-wrapper{-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#ffffff38 transparent;padding:16px 0 10px;overflow:auto visible}.tree-wrapper::-webkit-scrollbar{height:8px}.tree-wrapper::-webkit-scrollbar-track{background:0 0;border-radius:999px}.tree-wrapper::-webkit-scrollbar-thumb{background:#ffffff38;border-radius:999px;transition:background .2s}.tree-wrapper::-webkit-scrollbar-thumb:hover{background:#ffffff57}.tree-root,.tree-root ul{margin:0;padding:0;list-style:none}.tree-root{justify-content:center;width:max-content;min-width:100%;display:flex}.tree-root li{text-align:center;padding:24px 12px 0;position:relative}.tree-root li:before,.tree-root li:after{content:"";border-top:1px solid var(--border);width:50%;height:24px;position:absolute;top:0;right:50%}.tree-root li:after{border-left:1px solid var(--border);left:50%;right:auto}.tree-root li:only-child:before,.tree-root li:only-child:after{display:none}.tree-root li:only-child{padding-top:0}.tree-root li:first-child:before,.tree-root li:last-child:after{border:0}.tree-root li:last-child:before{border-right:1px solid var(--border);border-radius:0 8px 0 0}.tree-root li:first-child:after{border-radius:8px 0 0}.tree-root ul:before{content:"";border-left:1px solid var(--border);width:0;height:24px;position:absolute;top:0;left:50%}.tree-root ul{justify-content:center;padding-top:24px;display:flex;position:relative}.tree-node-box{white-space:pre-line;text-align:center;border:1px solid var(--border);background:var(--code-bg);color:var(--text-h);box-shadow:var(--shadow);border-radius:14px;justify-content:center;align-items:center;gap:8px;min-width:140px;padding:10px 16px;display:inline-flex}.tree-node-text{display:inline-block}.tree-icon{object-fit:contain;image-rendering:auto;flex-shrink:0;width:24px;height:24px;display:block}.root-node{border:4px solid #ffffff4d}.clickable-leaf-node{cursor:pointer;transition:transform .18s,border-color .18s,box-shadow .18s,background .18s}.clickable-leaf-node:hover{transform:translateY(-1px)}.manual-raw-node{box-shadow:0 0 0 2px #f3dc8c47, var(--shadow);background:#f3dc8c1f;border-color:#f3dc8c}.recipe-arrow{border:1px solid var(--border);background:var(--bg);width:28px;height:28px;color:var(--text-h);cursor:pointer;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:18px;line-height:1;display:inline-flex}.recipe-arrow:hover{opacity:.9}.recipe-arrow-left{margin-right:2px}.recipe-arrow-right{margin-left:2px}@media (width<=700px){.tree-wrapper{-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#ffffff38 transparent;padding:12px 0 8px;overflow:auto visible}.tree-wrapper::-webkit-scrollbar{height:8px}.tree-wrapper::-webkit-scrollbar-track{background:0 0;border-radius:999px}.tree-wrapper::-webkit-scrollbar-thumb{background:#ffffff38;border-radius:999px}.tree-wrapper::-webkit-scrollbar-thumb:hover{background:#ffffff57}}
