*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:#f4f2ee;color:#1e1e1e;min-height:100vh}#root{min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:#1c1c1c;color:#f0ece4;padding:1.5rem 1.25rem 1.25rem;text-align:center}.app-title{margin:0 0 .25rem;font-size:1.75rem;font-weight:700;letter-spacing:-.01em}.app-subtitle{margin:0;font-size:.875rem;color:#a09880}.app-main{max-width:860px;width:100%;margin:0 auto;padding:1.5rem 1rem 4rem;display:flex;flex-direction:column;gap:2rem}.step{display:flex;flex-direction:column;gap:.75rem}.step-label{font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#888}.step-header{display:flex;align-items:center;justify-content:space-between}.step-hint{margin:0;font-size:.85rem;color:#666}.ratio-group{display:flex;gap:.75rem;flex-wrap:wrap}.ratio-btn{flex:1;min-width:140px;display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:1rem 1.25rem;border:2px solid #d8d4cc;border-radius:10px;background:#fff;cursor:pointer;transition:border-color .15s,background .15s,box-shadow .15s}.ratio-btn:hover{border-color:#b8960c;background:#fffbf0}.ratio-btn--active{border-color:#b8960c;background:#fffbe8;box-shadow:0 0 0 3px #b8960c2e}.ratio-value{font-size:1.35rem;font-weight:700;color:#1c1c1c}.ratio-desc{font-size:.78rem;color:#888}.diameter-group{display:flex;flex-direction:column;gap:.5rem}.diameter-label{font-size:.8rem;font-weight:600;color:#555;padding:.2rem 0;border-bottom:1px solid #e0dbd2}.flask-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.6rem}.flask-card{display:flex;flex-direction:column;gap:.35rem;padding:.65rem .75rem .6rem;border:1.5px solid #ddd9d0;border-radius:8px;background:#fff;transition:border-color .12s,background .12s,box-shadow .12s}.flask-card:hover{border-color:#c8a812;background:#fffdf5}.flask-card--on{border-color:#b8960c;background:#fffbe8;box-shadow:0 1px 6px #b8960c26}.flask-size{font-size:1rem;font-weight:700;color:#1c1c1c;white-space:nowrap}.flask-amounts{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:#666;white-space:nowrap}.flask-sep{color:#bbb}.qty-row{display:flex;align-items:center;gap:0;margin-top:.2rem}.qty-btn{width:28px;height:28px;border:1.5px solid #ccc;border-radius:6px;background:#f7f5f0;font-size:1rem;line-height:1;cursor:pointer;color:#333;display:flex;align-items:center;justify-content:center;transition:background .1s,border-color .1s;padding:0}.qty-btn:hover:not(:disabled){background:#e8e2d4;border-color:#aaa}.qty-btn:disabled{opacity:.3;cursor:default}.qty-val{min-width:28px;text-align:center;font-size:1rem;font-weight:600;color:#1c1c1c}.clear-btn{font-size:.78rem;padding:.25rem .65rem;border:1.5px solid #d44;border-radius:6px;background:transparent;color:#c33;cursor:pointer;transition:background .1s}.clear-btn:hover{background:#fff0f0}.results{background:#fff;border:1.5px solid #d8d4cc;border-radius:12px;padding:1.25rem 1.25rem 1rem}.breakdown{display:flex;flex-direction:column;gap:.3rem;margin-bottom:1rem}.breakdown-row{display:flex;justify-content:space-between;align-items:baseline;font-size:.875rem;gap:.5rem}.breakdown-label{color:#555}.breakdown-amounts{color:#333;white-space:nowrap}.totals-box{background:#1c1c1c;border-radius:10px;padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.5rem}.total-row{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem}.total-label{font-size:.8rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:#a09880}.total-value{font-size:1.4rem;font-weight:700;color:#f5e9b8;white-space:nowrap}.total-divider{height:1px;background:#333;margin:.15rem 0}.mix-note{margin:.9rem 0 0;font-size:.78rem;color:#888;text-align:center;font-style:italic}@media (max-width: 480px){.app-title{font-size:1.4rem}.flask-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.total-value{font-size:1.15rem}}
