*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow:hidden;background:#0b0d17;color:#fff;font-family:Inter,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased}#app{width:100%;height:100%;overflow:hidden;position:relative;background:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px),radial-gradient(ellipse at 50% 40%,rgba(0,229,255,.04) 0%,transparent 70%),#0b0d17;background-size:40px 40px,40px 40px,100% 100%,100% 100%}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes screenIn{0%{opacity:0;transform:translateY(12px) scale(.99)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes screenOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.01) translateY(-8px)}}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes pulse-glow{0%,to{box-shadow:0 0 15px #00e5ff33}50%{box-shadow:0 0 35px #00e5ff66}}@keyframes arrowBounce{0%,to{transform:translate(0);opacity:.5}50%{transform:translate(5px);opacity:1}}@keyframes arrowBounceDown{0%,to{transform:rotate(90deg) translate(0);opacity:.5}50%{transform:rotate(90deg) translate(5px);opacity:1}}.screen-enter{animation:screenIn .45s cubic-bezier(.16,1,.3,1) both}.screen-exit{animation:screenOut .3s ease-in forwards;position:absolute;top:0;left:0;width:100%;height:100%;z-index:100;pointer-events:none}.sound-toggle{position:fixed;top:.75rem;right:.75rem;width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:50%;color:#fff6;font-size:.9rem;cursor:pointer;transition:all .2s;z-index:1000;user-select:none;-webkit-tap-highlight-color:transparent}.sound-toggle:hover{background:#ffffff1a;color:#fff}.sound-toggle.on{color:#00e5ff;border-color:#00e5ff4d}.landing{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;overflow-y:auto;padding:2rem 1.5rem}.landing-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:700;text-align:center;margin-bottom:.25rem;background:linear-gradient(135deg,#00e5ff,#7c4dff,#ff4081,#00e5ff);background-size:300% 300%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientShift 8s ease-in-out infinite,fadeSlideUp .6s ease-out both}.landing-subtitle{font-size:1rem;color:#ffffff80;text-align:center;margin-bottom:2rem;animation:fadeSlideUp .6s ease-out .08s both}.cards-row{display:flex;gap:1rem;width:100%;max-width:920px;flex:1;min-height:0;animation:fadeSlideUp .6s ease-out .15s both}.selection-card{flex:1;display:flex;flex-direction:column;background:#ffffff0a;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:1.25rem;min-height:0;transition:border-color .3s,box-shadow .3s}.selection-card:hover{border-color:#ffffff1f;box-shadow:0 4px 30px #0003}.card-label{font-size:1.1rem;font-weight:600;color:#00e5ff;margin-bottom:.75rem}.card-search{width:100%;padding:.6rem 1rem;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-size:.9rem;font-family:inherit;outline:none;transition:border-color .2s,box-shadow .2s;margin-bottom:.75rem}.card-search:focus{border-color:#00e5ff;box-shadow:0 0 0 3px #00e5ff1a}.card-search::placeholder{color:#ffffff4d}.flow-arrow{display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:0 .25rem;color:#00e5ff99}.flow-arrow svg{animation:arrowBounce 2.5s ease-in-out infinite}.object-grid{flex:1;overflow-y:auto;min-height:0;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}.object-grid::-webkit-scrollbar{width:5px}.object-grid::-webkit-scrollbar-track{background:transparent}.object-grid::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:3px}.category-header{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#ffffff4d;padding:.5rem 0 .25rem;position:sticky;top:0;background:#0b0d17eb;backdrop-filter:blur(8px);z-index:2}.object-item{display:flex;align-items:center;gap:.6rem;padding:.45rem .5rem;border-radius:8px;cursor:pointer;transition:all .15s ease;user-select:none;border:1px solid transparent;-webkit-tap-highlight-color:transparent}.object-item:hover{background:#ffffff0f;transform:translate(3px)}.object-item:active{transform:translate(3px) scale(.98)}.object-item.selected{background:#00e5ff1a;border-color:#00e5ff40;box-shadow:0 0 12px #00e5ff14}.object-icon{font-size:1.3rem;width:2rem;text-align:center;flex-shrink:0}.object-info{flex:1;min-width:0}.object-name{font-size:.85rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.object-dims{font-size:.65rem;color:#ffffff59}.card-preview{margin-top:.75rem;padding:.75rem;background:#00e5ff0d;border-radius:10px;border:1px solid rgba(0,229,255,.12);display:flex;align-items:center;gap:.75rem;animation:fadeSlideUp .25s ease-out both}.preview-icon{font-size:2.5rem}.preview-details h3{font-size:1rem;font-weight:600}.preview-details p{font-size:.75rem;color:#ffffff80;margin-top:.15rem}.preview-fun-fact{font-size:.7rem;color:#fff6;font-style:italic;margin-top:.25rem}.landing-controls{display:flex;gap:.75rem;align-items:center;margin-top:1.25rem;flex-wrap:wrap;justify-content:center;animation:fadeSlideUp .6s ease-out .25s both}.btn-calculate{padding:.85rem 2.5rem;font-size:1.15rem;font-weight:700;font-family:inherit;color:#fff;background:linear-gradient(135deg,#00e5ff,#7c4dff);border:none;border-radius:12px;cursor:pointer;transition:transform .15s,box-shadow .15s;animation:pulse-glow 2.5s ease-in-out infinite}.btn-calculate:disabled{opacity:.35;cursor:not-allowed;animation:none}.btn-calculate:not(:disabled):hover{transform:scale(1.05);box-shadow:0 0 40px #00e5ff59}.btn-calculate:not(:disabled):active{transform:scale(.97)}.btn-surprise,.btn-secondary{padding:.6rem 1.5rem;font-size:.9rem;font-weight:500;font-family:inherit;color:#ffffffa6;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}.btn-surprise:hover,.btn-secondary:hover{background:#ffffff1a;color:#fff;border-color:#ffffff26;transform:translateY(-1px)}.btn-surprise:active,.btn-secondary:active{transform:translateY(0) scale(.97)}.popular-combos{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;justify-content:center;margin-top:.75rem;animation:fadeSlideUp .6s ease-out .35s both}.popular-label{font-size:.75rem;color:#ffffff59;font-weight:500;margin-right:.25rem}.combo-chip{padding:.35rem .75rem;font-size:.72rem;font-family:inherit;color:#ffffff8c;background:#ffffff0a;border:1px solid rgba(255,255,255,.07);border-radius:20px;cursor:pointer;transition:all .2s;white-space:nowrap;-webkit-tap-highlight-color:transparent}.combo-chip:hover{background:#00e5ff14;border-color:#00e5ff40;color:#fff;transform:translateY(-1px)}.combo-chip:active{transform:translateY(0) scale(.97)}.results{width:100%;height:100%;display:flex;flex-direction:column;position:relative}.results-top{position:absolute;top:0;left:0;right:0;z-index:10;padding:1.5rem 2rem;text-align:center;pointer-events:none;background:linear-gradient(to bottom,rgba(11,13,23,.85) 0%,transparent 100%)}.results-top>*{pointer-events:auto}.results-counter-wrap{display:flex;justify-content:center;margin-bottom:.5rem}.results-subtitle{font-size:clamp(.9rem,2vw,1.2rem);color:#fff9}.results-subtitle em{color:#00e5ff;font-style:normal;font-weight:600}.results-viz{flex:1;min-height:0;position:relative}.results-viz canvas,.results-viz .vis2d-canvas{width:100%!important;height:100%!important;display:block}.results-bottom{position:absolute;bottom:0;left:0;right:0;z-index:10;padding:1rem 2rem 1.5rem;background:linear-gradient(to top,rgba(11,13,23,.92) 0%,transparent 100%);display:flex;flex-direction:column;align-items:center;gap:.75rem;pointer-events:none}.results-bottom>*{pointer-events:auto}.comparisons{display:flex;flex-direction:column;align-items:center;gap:.35rem;max-width:600px}.comparison-text{font-size:.85rem;color:#ffffff8c;text-align:center;line-height:1.4}.results-actions{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.too-small{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:1.5rem;padding:2rem}.too-small-emoji{font-size:6rem}.too-small-msg{font-size:1.3rem;color:#ffffffb3;max-width:500px;line-height:1.6}.odometer{display:inline-flex;align-items:center;font-family:JetBrains Mono,monospace;font-size:clamp(2.5rem,7vw,5rem);font-weight:700;color:#fff;text-shadow:0 0 20px rgba(0,229,255,.5),0 0 60px rgba(0,229,255,.2);line-height:1}.odometer-digit{display:inline-block;height:1em;overflow:hidden;position:relative}.odometer-column{display:flex;flex-direction:column}.odometer-cell{height:1em;display:flex;align-items:center;justify-content:center}.odometer-sep{display:inline-block;width:.3em;text-align:center;opacity:.5}.vis-counter-wrap{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.vis-counter-silhouette{width:280px;height:350px;position:relative;margin:0 auto;border-radius:20px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);overflow:hidden;display:flex;align-items:center;justify-content:center}.vis-counter-icon{font-size:8rem;position:relative;z-index:2;filter:drop-shadow(0 0 20px rgba(0,0,0,.5))}.vis-counter-fill{position:absolute;bottom:0;left:0;right:0;opacity:.5;transition:height .1s linear}.vis-counter-label{position:absolute;bottom:.75rem;left:0;right:0;text-align:center;font-size:.8rem;color:#ffffff80;z-index:3}.confetti-canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:50}.share-canvas-hidden{position:fixed;top:-9999px;left:-9999px}@media(max-width:700px){.landing{padding:1rem}.cards-row{flex-direction:column;gap:.75rem}.selection-card{max-height:40vh}.flow-arrow{padding:.25rem 0}.flow-arrow svg{animation:arrowBounceDown 2.5s ease-in-out infinite}.landing-controls{margin-top:1rem}.popular-combos{gap:.35rem}.combo-chip{font-size:.68rem;padding:.3rem .6rem}.results-top{padding:1rem}.results-bottom{padding:.75rem 1rem 1rem}.results-actions{gap:.4rem}.btn-secondary{padding:.5rem 1rem;font-size:.8rem}.vis-counter-silhouette{width:200px;height:250px}.vis-counter-icon{font-size:5rem}}
