:root{--pink: #2F8A5F;--pink-deep: #236B49;--pink-soft: #F7C5D8;--pink-tint: #FFF1F7;--cream: #FFF7FB;--white: #FFFFFF;--ink: #2B2430;--muted: #8A7F88;--line: #F0E6DE;--shadow: 0 2px 14px rgba(150, 90, 110, .08);--shadow-lg: 0 8px 30px rgba(150, 90, 110, .14);--radius: 18px;--radius-sm: 12px}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0;padding:0}body{background:var(--cream);color:var(--ink);font-family:DM Sans,system-ui,sans-serif;font-size:16px;-webkit-font-smoothing:antialiased}#root{min-height:100vh}.serif{font-family:Fraunces,Georgia,serif}button{font-family:inherit;cursor:pointer;border:none}input,select,textarea{font-family:inherit;font-size:16px}a{color:inherit;text-decoration:none}.app{max-width:920px;margin:0 auto;padding:0 16px 110px}.topbar{position:sticky;top:0;z-index:30;background:#fff8f3eb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin:0 -16px 12px;padding:14px 20px 12px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px}.brand{font-family:Fraunces,serif;font-weight:700;font-size:21px;color:var(--pink-deep);letter-spacing:-.01em}.brand small{display:block;font-family:DM Sans;font-weight:500;font-size:11px;color:var(--muted);letter-spacing:.14em;text-transform:uppercase}.preview-banner{background:#fff;border:1px solid var(--line);border-left:4px solid var(--pink);border-radius:12px;box-shadow:var(--shadow);color:var(--muted);font-size:13px;font-weight:600;line-height:1.35;margin:0 0 14px;padding:10px 12px}.page-title{font-family:Fraunces,serif;font-weight:600;font-size:26px;margin:8px 2px 4px}.page-sub{color:var(--muted);font-size:14px;margin:0 2px 18px}.stock-hero{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.mini-stats{display:flex;gap:8px;margin-top:8px}.mini-stats div{background:#fff;border:1px solid var(--line);border-radius:12px;min-width:58px;padding:8px 10px;text-align:center}.mini-stats b{display:block;color:var(--pink-deep);font-family:Fraunces,serif;font-size:20px;line-height:1}.mini-stats span{color:var(--muted);font-size:10px;font-weight:700;text-transform:uppercase}.chip-row{display:flex;gap:8px;margin:-4px 0 14px;overflow-x:auto;padding-bottom:2px}.chip{background:#fff;border:1.5px solid var(--line);border-radius:999px;color:var(--ink);flex:0 0 auto;font-size:13px;font-weight:800;padding:9px 14px}.chip.active{background:var(--pink);border-color:var(--pink);color:#fff}.nav{position:fixed;left:50%;bottom:14px;transform:translate(-50%);z-index:40;display:flex;gap:2px;background:var(--white);padding:6px;border-radius:22px;box-shadow:var(--shadow-lg);border:1px solid var(--line);max-width:calc(100% - 24px);overflow-x:auto}.nav a{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 13px;border-radius:16px;color:var(--muted);font-size:11px;font-weight:600;white-space:nowrap;transition:all .15s}.nav a .ic{font-size:10px;letter-spacing:.06em}.nav a.active{background:var(--pink);color:#fff}.card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--line)}.cat{margin-bottom:18px}.cat-head{display:flex;align-items:center;gap:10px;padding:4px 4px 10px;cursor:pointer;-webkit-user-select:none;user-select:none}.cat-head h2{font-family:Fraunces,serif;font-weight:600;font-size:19px;margin:0;flex:1}.cat-head .count{font-size:12px;color:var(--muted);background:var(--pink-soft);padding:3px 9px;border-radius:20px;font-weight:600}.cat-head .chev{color:var(--muted);transition:transform .2s}.cat-head .chev.open{transform:rotate(90deg)}.item{padding:13px 15px;border-bottom:1px solid var(--line)}.item:last-child{border-bottom:none}.item-top{display:flex;align-items:center;gap:10px;margin-bottom:10px}.item-name{font-weight:600;font-size:15.5px;flex:1}.item-qty{color:var(--muted);font-size:12.5px;font-weight:600;margin:-4px 0 9px 19px}.dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.pill{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px}.ordered-tag{font-size:10px;font-weight:700;color:var(--pink-deep);background:var(--pink-soft);padding:2px 7px;border-radius:12px;letter-spacing:.04em}.statbtns{display:grid;grid-template-columns:repeat(4,1fr);gap:7px}.statbtns.compact .statbtn{padding:10px 4px}.statbtn{padding:11px 4px;border-radius:var(--radius-sm);font-weight:700;font-size:12.5px;background:var(--cream);color:var(--muted);border:1.5px solid transparent;transition:all .12s;display:flex;flex-direction:column;align-items:center;gap:3px;line-height:1.1}.statbtn .em{font-size:15px}.statbtn:active{transform:scale(.95)}.statbtn.on{color:#fff}.stock-list{overflow:hidden}.stock-section{margin-bottom:14px}.stock-section-head{align-items:center;background:transparent;color:var(--ink);display:flex;font-family:Fraunces,serif;font-size:19px;font-weight:700;justify-content:space-between;padding:2px 4px 9px;text-align:left;width:100%}.stock-section-head .count{background:var(--pink-soft);border-radius:999px;color:var(--muted);font-family:DM Sans,system-ui,sans-serif;font-size:12px;padding:3px 9px}.stock-row{border-bottom:1px solid var(--line)}.stock-row:last-child{border-bottom:none}.stock-main{align-items:center;background:#fff;color:var(--ink);display:flex;gap:10px;padding:13px 14px;text-align:left;width:100%}.stock-main:active{background:var(--pink-tint)}.stock-meta{display:grid;flex:1;gap:2px;min-width:0}.stock-name{font-size:15px;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stock-sub{color:var(--muted);font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stock-actions{background:var(--pink-tint);border-top:1px solid var(--line);padding:10px 14px 13px}.pulled-btn,.backup-alert-btn{margin-bottom:9px}.stock-help{color:var(--muted);font-size:12.5px;font-weight:700;margin:0 0 10px}.counter-actions{display:grid;gap:8px;grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:9px}.counter-action{background:#fff;border:1.5px solid var(--line);border-radius:12px;color:var(--ink);display:grid;gap:3px;min-height:74px;padding:9px 8px;text-align:left}.counter-action span{font-size:13px;font-weight:900;line-height:1.1}.counter-action small{color:var(--muted);font-size:10.5px;font-weight:700;line-height:1.2}.counter-action.on{background:#fff;box-shadow:inset 0 0 0 1px currentColor}.adjust-actions{display:flex;gap:8px}.adjust-actions .btn{flex:1}.need-row{border-bottom:1px solid var(--line)}.need-row:last-child{border-bottom:none}.need-main{align-items:center;background:#fff;color:var(--ink);display:flex;gap:12px;min-height:68px;padding:13px 14px;text-align:left;width:100%}.need-main:active{background:var(--pink-tint)}.need-main:disabled{cursor:default}.need-row.needed .need-main{background:#fffafc}.need-add{background:var(--pink);border-radius:999px;color:#fff;flex:0 0 auto;font-size:13px;font-weight:900;min-width:58px;padding:9px 14px;text-align:center}.need-state{background:var(--pink-soft);border-radius:999px;color:var(--pink-deep);flex:0 0 auto;font-size:12px;font-weight:900;padding:8px 11px;text-align:center}.need-state.ordered{background:#e5f4ec;color:#236b49}.need-actions{align-items:center;background:var(--pink-tint);border-top:1px solid var(--line);color:var(--muted);display:flex;font-size:12.5px;font-weight:800;gap:12px;justify-content:space-between;padding:9px 14px 12px}.note-input{width:100%;margin-top:9px;padding:9px 12px;border-radius:var(--radius-sm);border:1.5px solid var(--line);background:var(--cream);color:var(--ink);resize:none}.note-input:focus{outline:none;border-color:var(--pink);background:#fff}.btn{background:var(--pink);color:#fff;font-weight:700;padding:12px 18px;border-radius:14px;font-size:15px;transition:all .12s}.btn:active{transform:scale(.97)}.btn.ghost{background:var(--pink-soft);color:var(--pink-deep)}.btn.subtle{background:var(--cream);color:var(--ink);border:1.5px solid var(--line)}.btn.danger{background:#fbe0e2;color:#c0303b}.btn.sm{padding:7px 12px;font-size:13px;border-radius:11px}.btn.block{width:100%}.field{margin-bottom:12px}.field label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:5px}.input,select.input,textarea.input{width:100%;padding:11px 13px;border-radius:12px;border:1.5px solid var(--line);background:#fff;color:var(--ink)}.input:focus{outline:none;border-color:var(--pink)}.row{display:flex;gap:10px;flex-wrap:wrap}.row>*{flex:1;min-width:120px}.board-sec{margin-bottom:22px}.board-sec h3{font-family:Fraunces,serif;font-size:17px;margin:0 4px 10px;display:flex;align-items:center;gap:8px}.req{display:flex;align-items:center;gap:12px;padding:12px 15px;border-bottom:1px solid var(--line)}.req:last-child{border-bottom:none}.req .meta{flex:1}.req .meta .nm{font-weight:600}.req .meta .sub{font-size:12.5px;color:var(--muted);margin-top:2px}.req .meta .nt{font-size:13px;color:var(--ink);background:var(--pink-tint);padding:4px 8px;border-radius:8px;margin-top:5px;display:inline-block}.search{width:100%;padding:12px 16px;border-radius:16px;border:1.5px solid var(--line);background:#fff;margin-bottom:14px}.search:focus{outline:none;border-color:var(--pink)}.empty{text-align:center;color:var(--muted);padding:40px 20px}.empty .big{font-size:40px;margin-bottom:8px}.toast{position:fixed;bottom:86px;left:50%;transform:translate(-50%);background:var(--ink);color:#fff;padding:11px 20px;border-radius:30px;font-weight:600;font-size:14px;z-index:60;box-shadow:var(--shadow-lg);animation:pop .25s ease}@keyframes pop{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}.setup{max-width:560px;margin:60px auto;padding:30px}.setup code{background:var(--pink-soft);padding:2px 7px;border-radius:6px;font-size:13px}.setup ol{line-height:1.9}.spinner{text-align:center;padding:60px;color:var(--muted)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:10px;margin-bottom:20px}.stat-box{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;text-align:center}.stat-box .n{font-family:Fraunces,serif;font-size:26px;font-weight:700}.stat-box .l{font-size:11.5px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-top:2px}table.tbl{width:100%;border-collapse:collapse;font-size:14px}table.tbl th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:8px 10px;border-bottom:2px solid var(--line)}table.tbl td{padding:9px 10px;border-bottom:1px solid var(--line)}.pin-wrap{max-width:340px;margin:60px auto;text-align:center}.pin-wrap .pin-in{font-size:26px;text-align:center;letter-spacing:10px;padding:14px}.tag{display:inline-block;font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px;background:var(--pink-soft);color:var(--pink-deep);margin-left:6px}.report-actions{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 18px}.report-actions .btn{text-align:center}.order-actions{align-items:flex-end;display:flex;flex-direction:column;gap:7px}.archive-row{align-items:flex-start}.report-preview{margin-top:18px;padding:16px}.report-preview h3{margin:0 0 10px}.report-preview pre{background:var(--cream);border:1px solid var(--line);border-radius:10px;color:var(--ink);font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:12.5px;line-height:1.5;margin:0;max-height:340px;overflow:auto;padding:12px;white-space:pre-wrap}.recipe-hero{margin-bottom:8px}.recipe-search{font-size:17px;margin-bottom:10px;padding:14px 16px}.recipe-tabs{margin-bottom:16px}.drink-button-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.drink-recipe-button{background:#fff;border:1.5px solid var(--line);border-radius:8px;box-shadow:var(--shadow);color:var(--ink);display:grid;gap:6px;min-height:88px;padding:14px 13px;text-align:left}.drink-recipe-button:active{background:var(--pink-tint);transform:scale(.98)}.drink-recipe-button span{color:var(--pink-deep);font-family:Fraunces,Georgia,serif;font-size:21px;font-weight:800;line-height:1.05}.drink-recipe-button small{color:var(--muted);font-size:12px;font-weight:900;letter-spacing:.06em;text-transform:uppercase}.mobile-recipe-detail{display:grid;gap:12px}.mobile-back{justify-self:start}.mobile-recipe-card{background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow-lg);overflow:hidden}.mobile-recipe-head{background:var(--pink-tint);border-bottom:1px solid var(--line);padding:18px 18px 16px}.mobile-recipe-head span{color:var(--muted);display:block;font-size:12px;font-weight:900;letter-spacing:.08em;margin-bottom:6px;text-transform:uppercase}.mobile-recipe-head h1{color:var(--pink-deep);font-family:Fraunces,Georgia,serif;font-size:34px;line-height:1;margin:0 0 8px}.mobile-recipe-head p{color:var(--ink);font-size:15px;font-weight:800;margin:0}.size-toggle{background:#fff;display:grid;gap:8px;grid-template-columns:repeat(2,minmax(0,1fr));padding:12px}.size-toggle button{background:var(--cream);border:1.5px solid var(--line);border-radius:8px;color:var(--ink);font-size:18px;font-weight:900;min-height:54px}.size-toggle button.active{background:var(--pink);border-color:var(--pink);color:#fff}.mobile-note{background:var(--pink-soft);color:var(--pink-deep);font-size:14px;font-weight:900;margin:0 12px;padding:10px 12px}.recipe-steps{counter-reset:recipe-step;list-style:none;margin:0;padding:4px 16px 16px}.recipe-steps li{align-items:flex-start;border-bottom:1px solid var(--line);display:flex;font-size:19px;font-weight:800;gap:12px;line-height:1.25;padding:15px 0}.recipe-steps li:before{background:var(--pink);border-radius:999px;color:#fff;content:counter(recipe-step);counter-increment:recipe-step;flex:0 0 auto;font-size:14px;font-weight:900;height:28px;line-height:28px;text-align:center;width:28px}.recipe-steps li:last-child{border-bottom:0}.ingredient-summary{background:var(--cream);border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:7px;padding:14px 16px 16px}.ingredient-summary .summary-title{color:var(--muted);flex-basis:100%;font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.ingredient-summary span{background:#fff;border:1px solid var(--line);border-radius:999px;color:var(--ink);font-size:12px;font-weight:800;padding:6px 9px}@media (max-width: 520px){.app{padding-left:12px;padding-right:12px}.drink-button-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.drink-recipe-button{min-height:96px;padding:13px 11px}.drink-recipe-button span{font-size:20px}.mobile-recipe-head h1{font-size:36px}}
