:root{--bg: #f4f6f8;--card: #ffffff;--ink: #1f2933;--muted: #6b7280;--line: #e2e8f0;--primary: #2f855a;--primary-dark: #276749;--primary-soft: #e6f4ec;--danger: #c53030;--accent: #3182ce;--over: #dd6b20;--radius: 12px;--shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .04)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:16px;line-height:1.45;-webkit-font-smoothing:antialiased}h1{font-size:1.4rem;margin:0}h2{font-size:1.1rem;margin:0 0 .75rem}h3{font-size:1rem;margin:0}.app-shell{min-height:100%;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:20;background:var(--card);border-bottom:1px solid var(--line);box-shadow:var(--shadow)}.topbar-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;flex-wrap:wrap}.brand{font-weight:700;font-size:1.05rem;white-space:nowrap}.nav{display:flex;gap:.25rem;flex:1;overflow-x:auto}.nav-link{text-decoration:none;color:var(--muted);padding:.4rem .7rem;border-radius:999px;font-weight:600;font-size:.9rem;white-space:nowrap}.nav-link.active{color:var(--primary-dark);background:var(--primary-soft)}.logout{white-space:nowrap}.content{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:1rem}.screen{display:flex;flex-direction:column;gap:1rem}.screen-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:wrap}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow)}.empty{color:var(--muted);text-align:center}.muted{color:var(--muted);font-size:.9rem}.alert{background:#fff5f5;border:1px solid #feb2b2;color:var(--danger);padding:.6rem .8rem;border-radius:var(--radius);font-size:.9rem}button{font-family:inherit;cursor:pointer}.btn-primary{background:var(--primary);color:#fff;border:none;padding:.55rem 1rem;border-radius:999px;font-weight:600;font-size:.9rem}.btn-primary:hover{background:var(--primary-dark)}.btn-primary:disabled{opacity:.6;cursor:default}.btn-primary.full{width:100%}.btn-secondary{background:transparent;color:var(--primary);border:1px solid var(--primary);padding:.55rem 1rem;border-radius:999px;font-weight:600;font-size:.9rem;cursor:pointer}.btn-secondary:hover{background:var(--primary);color:#fff}.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--ink);padding:.45rem .8rem;border-radius:999px;font-weight:600;font-size:.85rem}.btn-ghost:hover{border-color:var(--muted)}.btn-ghost.danger{color:var(--danger);border-color:#feb2b2}.btn-ghost.icon{padding:.45rem .6rem}.btn-link{background:none;border:none;color:var(--accent);font-weight:600;padding:.5rem 0;font-size:.9rem}.field{display:flex;flex-direction:column;gap:.25rem;font-size:.85rem;font-weight:600;color:var(--muted)}.field.inline{flex-direction:row;align-items:center;gap:.5rem}.field.inline select{flex:1}.field input,.field select,.field textarea,.search-bar input{font-family:inherit;font-size:.95rem;font-weight:400;color:var(--ink);padding:.5rem .6rem;border:1px solid var(--line);border-radius:8px;background:#fff;width:100%}.field input:focus,.field select:focus,.field textarea:focus,.search-bar input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-soft)}.form-row{display:flex;gap:.75rem;flex-wrap:wrap}.form-row .field{flex:1;min-width:130px}.form-actions{display:flex;align-items:center;gap:.75rem;margin-top:.75rem;flex-wrap:wrap}.saved-msg{color:var(--primary);font-weight:600;font-size:.9rem}.search-bar{display:flex;gap:.5rem;align-items:center}.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.auth-card{width:100%;max-width:360px;display:flex;flex-direction:column;gap:.85rem}.auth-title{text-align:center;margin:0}.auth-sub{text-align:center;color:var(--muted);margin:-.4rem 0 .4rem}.plan-select-card{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.plan-select-card .field{flex:1;min-width:220px}.create-plan{display:flex;flex-direction:column;gap:.75rem}.grid-scroll{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--line);background:var(--card);box-shadow:var(--shadow)}.plan-grid{border-collapse:collapse;width:100%;min-width:640px}.plan-grid th,.plan-grid td{border:1px solid var(--line);padding:.5rem;vertical-align:top;text-align:left}.plan-grid thead th{background:var(--primary-soft);color:var(--primary-dark);position:sticky;top:0;font-size:.85rem}.plan-grid .corner{left:0;z-index:2}.plan-grid .daycell{background:#f8fafc;font-size:.8rem;white-space:nowrap;position:sticky;left:0;z-index:1}.slotcell{min-width:150px}.portions{margin-top:.4rem;display:flex;align-items:center;justify-content:space-between;gap:.3rem}.portions-label{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.stepper{display:flex;align-items:center;gap:.35rem}.stepper button{width:26px;height:26px;border-radius:6px;border:1px solid var(--line);background:#fff;font-size:1rem;line-height:1}.stepper button:disabled{opacity:.4;cursor:default}.stepper-val{min-width:18px;text-align:center;font-weight:700;font-size:.9rem}.saving{display:block;margin-top:.25rem;font-size:.7rem;color:var(--accent)}.picker{position:relative}.picker-btn{width:100%;text-align:left;border:1px dashed var(--line);background:#fff;border-radius:8px;padding:.45rem .5rem;font-size:.85rem;color:var(--muted)}.picker-btn.filled{border-style:solid;border-color:var(--primary);background:var(--primary-soft);color:var(--primary-dark);font-weight:600}.picker-pop{position:absolute;z-index:30;top:calc(100% + 4px);left:0;width:240px;max-width:80vw;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 6px 24px #00000026;padding:.5rem}.picker-search{width:100%;padding:.4rem .5rem;border:1px solid var(--line);border-radius:6px;font-size:.85rem;margin-bottom:.4rem}.picker-list{list-style:none;margin:0;padding:0;max-height:220px;overflow-y:auto}.picker-item{width:100%;display:flex;justify-content:space-between;gap:.5rem;align-items:center;border:none;background:none;text-align:left;padding:.4rem .5rem;border-radius:6px;font-size:.85rem}.picker-item:hover{background:var(--bg)}.picker-item.selected{background:var(--primary-soft);font-weight:600}.picker-item.clear{color:var(--danger)}.picker-kcal{font-size:.75rem;color:var(--muted);white-space:nowrap}.picker-empty{padding:.4rem .5rem;color:var(--muted);font-size:.85rem}.day-card{display:flex;flex-direction:column;gap:.6rem}.day-title{margin:0;font-size:1rem}.meter-head{display:flex;justify-content:space-between;font-size:.82rem;color:var(--muted);margin-bottom:.2rem}.meter-num.over{color:var(--over);font-weight:700}.meter-track{height:12px;background:var(--line);border-radius:999px;overflow:hidden}.meter-fill{height:100%;border-radius:999px;transition:width .2s ease}.meter-fill.good{background:var(--primary)}.meter-fill.over{background:var(--over)}.meter-fill.protein{background:var(--accent)}.recipe-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.recipe-card{padding:0;overflow:hidden;display:flex;flex-direction:column}.recipe-thumb{width:100%;height:140px;object-fit:cover;display:block}.recipe-body{padding:.85rem;display:flex;flex-direction:column;gap:.5rem}.recipe-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.badge{font-size:.68rem;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);background:var(--bg);border-radius:999px;padding:.1rem .5rem;white-space:nowrap}.macro-row{display:flex;flex-wrap:wrap;gap:.4rem;font-size:.8rem}.macro{background:var(--bg);border-radius:6px;padding:.15rem .45rem;font-weight:600;color:var(--ink)}.macro.kcal{background:var(--primary-soft);color:var(--primary-dark)}.macro.muted{background:none;color:var(--muted);font-weight:400}.recipe-actions{display:flex;gap:.5rem;margin-top:.25rem}.recipe-form{display:flex;flex-direction:column;gap:.75rem}.ingredients-block{display:flex;flex-direction:column;gap:.5rem}.ingredients-head{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;font-weight:600;color:var(--muted)}.ingredient-row{display:flex;gap:.4rem}.ing-name{flex:2}.ing-qty{flex:1;min-width:60px}.ing-unit{flex:1;min-width:70px}.ingredient-row input{font-size:.9rem;padding:.45rem .5rem;border:1px solid var(--line);border-radius:8px}.targets-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem}.mealdb{display:flex;flex-direction:column;gap:.75rem}.mealdb-toggle{align-self:flex-start}.mealdb-results{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.6rem}.mealdb-item{display:flex;align-items:center;gap:.5rem;border:1px solid var(--line);border-radius:10px;padding:.4rem}.mealdb-item img,.mealdb-thumb{width:44px;height:44px;border-radius:8px;object-fit:cover;flex-shrink:0}.mealdb-thumb.placeholder{font-size:.55rem;padding:.15rem}.mealdb-name{flex:1;font-size:.85rem;font-weight:600}.shop-head{font-size:.85rem;color:var(--muted);margin-bottom:.5rem}.shop-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.shop-item:last-child{border-bottom:none}.shop-item label{display:flex;align-items:center;gap:.6rem;padding:.6rem .2rem;cursor:pointer}.shop-item input[type=checkbox]{width:20px;height:20px;accent-color:var(--primary)}.shop-name{flex:1;font-weight:600}.shop-qty{color:var(--muted);font-size:.9rem;white-space:nowrap}.shop-item.done .shop-name,.shop-item.done .shop-qty{text-decoration:line-through;color:var(--muted);font-weight:400}.placeholder{display:flex;align-items:center;justify-content:center;text-align:center;background:linear-gradient(135deg,var(--primary-soft),var(--bg));color:var(--primary-dark);font-weight:700;overflow:hidden}.placeholder span{padding:.4rem .6rem;font-size:.85rem;line-height:1.2;word-break:break-word}.recipe-card.clickable{cursor:pointer;transition:box-shadow .15s ease,transform .15s ease}.recipe-card.clickable:hover{box-shadow:0 4px 14px #0000001f}.recipe-card.clickable:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.recipe-thumb.placeholder{height:140px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0f172099;display:flex;align-items:flex-start;justify-content:center;padding:1.5rem 1rem;overflow-y:auto}.modal{position:relative;width:100%;max-width:620px;background:var(--card);border-radius:var(--radius);box-shadow:0 12px 40px #00000040;overflow:hidden;margin:auto}.modal-close{position:absolute;top:.6rem;right:.6rem;z-index:2;width:34px;height:34px;border-radius:999px;border:none;background:#ffffffe6;color:var(--ink);font-size:1rem;line-height:1;box-shadow:var(--shadow)}.modal-close:hover{background:#fff}.detail-loading{padding:2rem;text-align:center}.detail-hero{width:100%;height:240px;object-fit:cover;display:block}.detail-hero.placeholder{height:240px}.detail-hero.placeholder span{font-size:1.1rem}.detail-body{padding:1.1rem;display:flex;flex-direction:column;gap:.75rem}.detail-note{margin:0}.detail-section{display:flex;flex-direction:column;gap:.35rem;border-top:1px solid var(--line);padding-top:.75rem}.detail-ingredients{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.detail-ingredients li{padding:.4rem 0;border-bottom:1px solid var(--line);font-size:.92rem}.detail-ingredients li:last-child{border-bottom:none}.ing-qty-unit{font-weight:700;color:var(--primary-dark)}.detail-steps{margin:0;padding-left:1.3rem;display:flex;flex-direction:column;gap:.5rem}.detail-steps li{padding-left:.25rem;line-height:1.5}.detail-prose{margin:0;line-height:1.6;white-space:pre-wrap}.detail-actions{border-top:1px solid var(--line);padding-top:.85rem}@media (max-width: 600px){.content{padding:.75rem}h1{font-size:1.2rem}.brand{font-size:1rem}.form-row{flex-direction:column}.modal-overlay{padding:0;align-items:stretch}.modal{max-width:none;min-height:100%;border-radius:0}.detail-hero,.detail-hero.placeholder{height:200px}}*{-webkit-tap-highlight-color:transparent}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}button:active,.nav-link:active,.tab:active,.picker-btn:active{transform:scale(.98)}.stepper button{width:40px;height:40px;font-size:1.25rem}.modal-close{width:44px;height:44px;font-size:1.1rem}.auth-wrap{min-height:100dvh}.shop-progress{position:sticky;top:0;z-index:5;background:var(--card);padding:.25rem 0 .7rem;margin:-.25rem 0 .5rem;border-bottom:1px solid var(--line)}.shop-progress-top{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem;font-size:1rem}.shop-progress-actions{display:flex;gap:.75rem;flex-wrap:wrap}.shop-progress .meter-fill{background:var(--primary)}.shop-list{list-style:none;margin:0;padding:0}.shop-item{border-bottom:1px solid var(--line)}.shop-item label{display:flex;align-items:center;gap:.75rem;padding:.9rem .4rem;min-height:56px;cursor:pointer}.shop-item label:active{background:var(--primary-soft)}.shop-item input[type=checkbox]{width:26px;height:26px;accent-color:var(--primary);flex-shrink:0;margin:0}.shop-check{display:none}.shop-name{flex:1;font-weight:600;font-size:1.1rem;color:var(--ink)}.shop-qty{font-size:1rem;font-weight:700;color:var(--ink);white-space:nowrap}.shop-item.done .shop-name{text-decoration:line-through;color:var(--muted);font-weight:500}.shop-item.done .shop-qty{color:var(--muted);font-weight:500}.shop-alldone{list-style:none;text-align:center;color:var(--primary);font-weight:600;padding:1.5rem 0}.day-cards{display:flex;flex-direction:column;gap:.85rem}.day-card-title{margin:0 0 .6rem;font-size:1.05rem;color:var(--primary-dark);border-bottom:1px solid var(--line);padding-bottom:.4rem}.slot-row{display:flex;flex-direction:column;gap:.4rem;padding:.6rem 0;border-bottom:1px dashed var(--line)}.slot-row:last-child{border-bottom:none;padding-bottom:0}.slot-label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}.slot-controls .picker-btn{width:100%}.picker-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:60;display:flex;align-items:flex-end}.picker-sheet{background:var(--card);width:100%;max-height:85dvh;border-radius:16px 16px 0 0;padding:.85rem 1rem calc(1rem + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:.6rem}.picker-sheet-head{display:flex;align-items:center;justify-content:space-between;font-weight:700}.picker-sheet .picker-search{font-size:1rem;padding:.7rem;border:1px solid var(--line);border-radius:8px;width:100%}.picker-sheet .picker-list{overflow-y:auto;max-height:60dvh;margin:0;padding:0;list-style:none}.picker-sheet .picker-item{min-height:48px;font-size:1rem}.tabbar{display:none}@media (max-width: 600px){.nav-top{display:none}.content{padding-bottom:calc(72px + env(safe-area-inset-bottom))}.tabbar{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:40;background:var(--card);border-top:1px solid var(--line);box-shadow:0 -1px 4px #0000000f;padding-bottom:env(safe-area-inset-bottom)}.tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-height:56px;text-decoration:none;color:var(--muted);font-size:.7rem;font-weight:600}.tab.active{color:var(--primary-dark)}.tab-icon{font-size:1.35rem;line-height:1}.btn-primary,.btn-secondary,.btn-ghost,.picker-btn,.field select,.field input,.field textarea{min-height:44px}.ingredient-row{flex-wrap:wrap}.ingredient-row .ing-name{flex:1 1 100%}.ingredient-row .ing-qty,.ingredient-row .ing-unit{flex:1 1 40%}.recipe-actions .btn-ver{display:none}}.shop-group{margin-top:.5rem}.shop-group-title{font-size:.85rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;padding:.6rem .2rem .3rem;position:sticky;top:64px;background:var(--card);z-index:4}.shop-mode-btn{width:100%;margin-top:.7rem;min-height:48px}body.shopping-mode .tabbar{display:none}@media (max-width: 600px){body.shopping-mode .content{padding-bottom:.75rem}body.shopping-mode .topbar{display:none}}.tag-row{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.4rem}.tag-chip{font-size:.72rem;font-weight:700;padding:.15rem .5rem;border-radius:999px;background:var(--primary-soft);color:var(--primary-dark);white-space:nowrap}.tag-picker{display:flex;flex-wrap:wrap;gap:.4rem}.tag-chip.selectable{cursor:pointer;border:1px solid var(--line);background:#fff;color:var(--muted);padding:.4rem .7rem;font-size:.8rem;min-height:40px}.tag-chip.selectable.on{background:var(--primary);color:#fff;border-color:var(--primary)}.picker-tag-toggle{align-self:flex-start;padding:.2rem 0;font-size:.8rem}.meal-macros{font-size:.72rem;color:var(--muted);margin-top:.35rem;font-weight:600}.slot-controls .picker+.picker{margin-top:.35rem}.day-card-head{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem;flex-wrap:wrap;border-bottom:1px solid var(--line);padding-bottom:.4rem;margin-bottom:.6rem}.day-card-head .day-card-title{border:none;padding:0;margin:0}.day-total{font-size:.8rem;color:var(--primary-dark);font-weight:600}.day-total.over{color:var(--danger)}.day-total-macros{color:var(--muted);font-weight:500}.plan-grid tfoot .total-cell{background:var(--primary-soft)}
