@import"https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,600;0,9..144,800;1,9..144,400&family=JetBrains+Mono:wght@400;600&display=swap";*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:Fraunces,Georgia,serif;background:#f0ebe0;color:#1c1917}button{cursor:pointer;font-family:inherit}input,select{font-family:inherit}:root{--ink:#2a2520;--ink-light:#44403c;--muted:#78716c;--faint:#a8a29e;--cream:#fefdf8;--cream2:#f5f0e1;--border:#d4c9b0;--bg:#f0ebe0;--shadow:0 1px 3px rgba(60,40,20,.07),0 6px 20px rgba(60,40,20,.09);--radius:.625rem;--mono:"JetBrains Mono",monospace}.app-shell{min-height:100vh;background:var(--bg)}.app-header{background:var(--cream);border-bottom:2px solid var(--ink);position:sticky;top:0;z-index:10}.app-header-inner{max-width:680px;margin:0 auto;padding:0 1rem;display:flex;align-items:stretch}.app-title{padding:1rem 1.25rem 0 0;border-right:2px solid var(--ink)}.app-title h1{font-size:1.5rem;font-weight:800;color:var(--ink);letter-spacing:-.02em;margin:0;line-height:1}.app-title p{font-family:var(--mono);font-size:.55rem;text-transform:uppercase;letter-spacing:.18em;color:var(--muted);margin:.3rem 0 .75rem}.tab-strip{display:flex;flex:1;align-items:stretch}.tab-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;padding:.6rem .5rem;background:none;border:none;border-bottom:3px solid transparent;font-family:var(--mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);transition:all .15s;margin-bottom:-2px;cursor:pointer}.tab-btn svg{width:18px;height:18px}.tab-btn:hover{color:var(--ink)}.tab-btn.active{color:var(--ink);border-bottom-color:var(--ink);font-weight:600}.main-content{padding:1.25rem 1rem 5rem;max-width:680px;margin:0 auto}.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.section-head h2{font-size:1.25rem;font-weight:700;color:var(--ink);margin:0}.card{background:linear-gradient(135deg,#fefdf8,#f5f0e1);box-shadow:var(--shadow);border-radius:var(--radius);overflow:hidden;margin-bottom:.875rem}.card-body{padding:1rem}.card-footer{padding:.75rem 1rem;background:#fff6;border-top:1px solid rgba(212,201,176,.5)}.recipe-name-input{flex:1;min-width:0;font-size:1.1rem;font-weight:700;font-family:Fraunces,Georgia,serif;color:var(--ink);background:transparent;border:none;border-bottom:2px solid transparent;padding:.1rem 0;outline:none;transition:border-color .15s}.recipe-name-input:focus{border-bottom-color:var(--ink)}.cost-display{display:flex;gap:1.5rem;margin-top:.875rem;flex-wrap:wrap}.cost-label{font-family:var(--mono);font-size:.55rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-bottom:.15rem}.cost-value{font-family:var(--mono);font-size:1.75rem;font-weight:800;color:var(--ink);line-height:1}.bars-row{display:flex;align-items:center;gap:.5rem;margin-top:.5rem}.bars-row label{font-family:var(--mono);font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.bars-input{width:3.5rem;padding:.25rem .4rem;font-family:var(--mono);font-size:.875rem;text-align:center;background:var(--cream);border:1px solid var(--border);border-radius:.3rem}.made-batch-btn{width:100%;padding:.75rem;background:var(--ink);color:var(--cream);border:none;border-radius:.4rem;font-family:var(--mono);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:background .15s,transform .1s;margin-top:.75rem;cursor:pointer}.made-batch-btn:hover{background:#1a1512;transform:translateY(-1px)}.expand-toggle{display:flex;align-items:center;gap:.35rem;background:none;border:none;font-family:var(--mono);font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);padding:0;transition:color .15s;cursor:pointer}.expand-toggle:hover{color:var(--ink)}.expand-toggle svg{width:14px;height:14px}.lines-section{padding:.875rem 1rem;background:#fefdf899;border-top:1px solid rgba(212,201,176,.4)}.line-row{display:grid;grid-template-columns:1fr 80px 72px 75px 28px;gap:.4rem;align-items:center;margin-bottom:.4rem}.line-cost-cell{font-family:var(--mono);font-size:.8rem;font-weight:600;color:var(--ink);text-align:right}.add-line-btn{background:none;border:none;display:flex;align-items:center;gap:.3rem;font-family:var(--mono);font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-top:.5rem;padding:0;transition:color .15s;cursor:pointer}.add-line-btn:hover{color:var(--ink)}.past-batches{padding:.875rem 1rem;background:#f0ebe080;border-top:1px solid rgba(212,201,176,.4)}.past-batch-item{display:flex;justify-content:space-between;align-items:baseline;padding:.5rem 0;border-bottom:1px solid rgba(212,201,176,.35)}.past-batch-item:last-child{border-bottom:none}.batch-date{font-family:var(--mono);font-size:.7rem;color:var(--muted)}.batch-cost{font-family:var(--mono);font-size:.875rem;font-weight:700;color:var(--ink)}.batch-per-bar{font-family:var(--mono);font-size:.65rem;color:var(--muted);margin-left:.5rem}.no-batches{font-size:.8rem;color:var(--faint);font-style:italic;text-align:center;padding:.5rem 0}.price-history-row{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:.7rem;padding:.3rem 0;gap:.5rem;flex-wrap:wrap}.field{background:var(--cream);border:1px solid var(--border);border-radius:.3rem;padding:.45rem .6rem;font-size:.875rem;color:var(--ink);width:100%;transition:border-color .15s,box-shadow .15s}.field:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px #2a252014}.field.mono{font-family:var(--mono);font-size:.8rem}.field-dollar{position:relative}.field-dollar:before{content:"$";position:absolute;left:.6rem;top:50%;transform:translateY(-50%);color:var(--muted);font-family:var(--mono);font-size:.8rem;pointer-events:none;z-index:1}.field-dollar .field{padding-left:1.4rem}.btn-primary{background:var(--ink);color:var(--cream);border:none;border-radius:.35rem;padding:.5rem .875rem;font-family:var(--mono);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;display:inline-flex;align-items:center;gap:.35rem;transition:background .15s,transform .1s;white-space:nowrap;cursor:pointer}.btn-primary:hover{background:#1a1512;transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--ink);border-radius:.35rem;padding:.4rem .75rem;font-family:var(--mono);font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;display:inline-flex;align-items:center;gap:.35rem;transition:all .15s;white-space:nowrap;cursor:pointer}.btn-ghost:hover{background:var(--ink);color:var(--cream)}.btn-icon{background:none;border:none;color:var(--faint);padding:.2rem;display:flex;align-items:center;transition:color .15s;cursor:pointer}.btn-icon:hover{color:#b91c1c}.btn-icon svg{width:15px;height:15px}.badge{display:inline-block;background:var(--ink);color:var(--cream);font-family:var(--mono);font-size:.5rem;text-transform:uppercase;letter-spacing:.08em;padding:.15rem .4rem;border-radius:.2rem;vertical-align:middle;margin-left:.35rem}.badge-warn{background:#fef3c7;color:#92400e;border:1px solid #fcd34d;font-family:var(--mono);font-size:.7rem;padding:.2rem .5rem;border-radius:.3rem;display:inline-block;margin-top:.5rem}.empty-state{background:linear-gradient(135deg,#fefdf8,#f5f0e1);box-shadow:var(--shadow);border-radius:var(--radius);padding:2.5rem 1.5rem;text-align:center}.empty-state h3{font-size:1.1rem;font-weight:700;color:var(--ink);margin:0 0 .4rem}.empty-state p{font-size:.875rem;color:var(--muted);font-style:italic;margin:0 auto;max-width:26rem}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center}@keyframes spin{to{transform:rotate(360deg)}}.pill-btn{display:inline-flex;align-items:center;gap:.35rem;background:#2a252012;border:1px solid rgba(42,37,32,.15);border-radius:99px;padding:.3rem .75rem;font-family:var(--mono);font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-light);cursor:pointer;transition:all .15s}.pill-btn:hover{background:#2a252021;border-color:#2a25204d;color:var(--ink)}.pill-btn.active{background:var(--ink);border-color:var(--ink);color:var(--cream)}.pill-btn svg{width:12px;height:12px}.spinner{animation:spin 1s linear infinite;color:var(--muted)}.micro-label{font-family:var(--mono);font-size:.55rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:.25rem}@media (max-width:480px){.line-row{grid-template-columns:1fr 68px 60px 52px 24px;gap:.3rem}.cost-value{font-size:1.4rem}}
