*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #fafaf9;--surface: #ffffff;--border: #e7e5e4;--text: #1c1917;--text-muted: #78716c;--primary: #2563eb;--primary-hover: #1d4ed8;--danger: #dc2626;--warning-bg: #fef3c7;--warning-text: #92400e;--success: #16a34a;--radius: 8px;--shadow: 0 1px 3px rgba(0,0,0,.08)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}.app{display:flex;flex-direction:column;min-height:100dvh}.main{flex:1;padding:1rem 1rem 5rem;max-width:640px;margin:0 auto;width:100%}.navbar{position:fixed;bottom:0;left:0;right:0;display:flex;background:var(--surface);border-top:1px solid var(--border);box-shadow:0 -1px 4px #0000000f;z-index:100}.nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;padding:.5rem 0;gap:.15rem;color:var(--text-muted);font-size:.65rem;transition:color .15s}.nav-tab.active{color:var(--primary)}.nav-icon{font-size:1.3rem}.nav-label{font-weight:500}.view{display:flex;flex-direction:column;gap:1rem}.view-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.view-header h1{font-size:1.4rem;font-weight:700;flex:1}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s}.btn:hover{background:#f5f5f4}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:var(--primary-hover)}.btn-danger{background:#fff;color:var(--danger);border-color:var(--danger)}.btn-danger:hover{background:#fef2f2}.btn-icon{background:none;border:none;cursor:pointer;font-size:1rem;padding:.25rem;color:var(--text-muted)}.btn-complete{width:100%;margin-top:1rem;padding:.75rem;font-size:1rem}.btn-complete:disabled{opacity:.4;cursor:not-allowed}.search-input{width:100%;padding:.6rem .75rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.9rem;outline:none}.search-input:focus{border-color:var(--primary)}.sort-tabs{display:flex;gap:.25rem}.sort-tab{padding:.35rem .75rem;border:1px solid var(--border);border-radius:999px;background:var(--surface);font-size:.8rem;cursor:pointer}.sort-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.meal-grid{display:flex;flex-direction:column;gap:.5rem}.meal-card{display:block;padding:.75rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);transition:box-shadow .15s}.meal-card:hover{box-shadow:0 2px 8px #0000001a}.meal-card-header{display:flex;align-items:center;gap:.5rem}.meal-name{font-weight:600;font-size:.95rem}.meal-card-meta{font-size:.8rem;color:var(--text-muted);margin-top:.25rem}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-group label{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.form-group input,.form-group select{padding:.5rem .6rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.9rem;outline:none}.form-group input:focus{border-color:var(--primary)}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.stepper{display:flex;align-items:center;gap:.75rem}.stepper button{width:2rem;height:2rem;border:1px solid var(--border);border-radius:50%;background:var(--surface);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.stepper span{font-size:1.1rem;font-weight:600;min-width:1.5rem;text-align:center}.ingredient-list{display:flex;flex-direction:column;gap:.4rem}.ingredient-row{display:flex;gap:.35rem;align-items:center}.ing-name-wrap{flex:3;position:relative}.ing-name{width:100%;padding:.45rem .5rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.85rem;outline:none}.ing-name:focus{border-color:var(--primary)}.ing-qty{flex:1;padding:.45rem .5rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.85rem;outline:none}.ing-qty:focus{border-color:var(--primary)}.ing-unit{flex:1.2;padding:.45rem .5rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.85rem;outline:none}.ing-unit:focus{border-color:var(--primary)}.suggestions{position:absolute;top:100%;left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 12px #0000001a;z-index:50;max-height:150px;overflow-y:auto}.suggestion{padding:.4rem .6rem;font-size:.85rem;cursor:pointer}.suggestion:hover{background:#f5f5f4}.week-nav{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.week-label{text-align:center}.week-dates{display:block;font-size:.8rem;color:var(--text-muted)}.day-column{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem}.day-label{font-size:.95rem;font-weight:600;margin-bottom:.5rem}.planned-slot{display:flex;align-items:center;justify-content:space-between;padding:.4rem 0;border-bottom:1px solid var(--border)}.planned-slot:last-of-type{border-bottom:none}.slot-name{font-size:.9rem}.slot-controls{display:flex;align-items:center;gap:.3rem;font-size:.85rem}.slot-controls button{width:1.6rem;height:1.6rem;border:1px solid var(--border);border-radius:4px;background:var(--surface);cursor:pointer;font-size:.85rem;display:flex;align-items:center;justify-content:center}.btn-add-meal{width:100%;margin-top:.5rem}.meal-picker{margin-top:.5rem}.meal-picker input{width:100%;padding:.5rem;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.4rem;font-size:.85rem;outline:none}.picker-list{max-height:200px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.4rem}.picker-item{padding:.5rem .6rem;cursor:pointer;font-size:.85rem}.picker-item:hover{background:#f5f5f4}.shopping-items{display:flex;flex-direction:column}.shopping-item{display:flex;align-items:flex-start;gap:.6rem;padding:.65rem 0;border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none}.shopping-item.checked .item-name{text-decoration:line-through;color:var(--text-muted)}.checkbox{font-size:1.2rem;line-height:1;flex-shrink:0}.item-info{display:flex;flex-direction:column;gap:.15rem}.item-name{font-size:.95rem}.item-sources{font-size:.75rem;color:var(--text-muted)}.purchase-warning{font-size:.8rem;color:var(--warning-text);background:var(--warning-bg);padding:.15rem .4rem;border-radius:4px;display:inline-block;width:fit-content}.shopping-category{margin-bottom:.5rem}.category-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--primary);padding:.5rem 0 .25rem;border-bottom:2px solid var(--primary);margin-bottom:.25rem}.week-mini h2{font-size:1rem;margin-bottom:.5rem}.mini-days{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem}.mini-day{display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.4rem .2rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);min-height:4rem}.mini-day-label{font-size:.65rem;font-weight:700;text-transform:uppercase;color:var(--text-muted)}.mini-meal{font-size:.6rem;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.mini-empty{font-size:.7rem;color:var(--text-muted)}.stat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.5rem}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;text-align:center;box-shadow:var(--shadow)}.stat-card.clickable{cursor:pointer;transition:box-shadow .15s}.stat-card.clickable:hover{box-shadow:0 2px 8px #0000001a}.stat-value{font-size:1.5rem;font-weight:700}.stat-label{font-size:.8rem;color:var(--text-muted);margin-top:.25rem}.ranked-list{display:flex;flex-direction:column;gap:.25rem}.ranked-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.ranked-item:hover{background:#f5f5f4}.rank{font-weight:700;color:var(--text-muted);min-width:1.5rem}.ranked-name{flex:1;font-weight:500}.ranked-count{color:var(--text-muted);font-size:.85rem}.empty-state{text-align:center;padding:2rem;color:var(--text-muted)}.empty-state .btn{margin-top:1rem}.text-muted{color:var(--text-muted);font-size:.85rem}.toast{position:fixed;bottom:5rem;left:50%;transform:translate(-50%);background:var(--text);color:#fff;padding:.6rem 1.2rem;border-radius:999px;font-size:.85rem;font-weight:500;z-index:200;box-shadow:0 4px 12px #0003;animation:toast-in .2s ease-out}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(8px)}}@media(min-width:768px){.main{padding:2rem}.navbar{position:static;flex-direction:column;width:200px;border-top:none;border-right:1px solid var(--border);box-shadow:none;padding:1rem 0}.app{flex-direction:row}.nav-tab{flex-direction:row;justify-content:flex-start;padding:.6rem 1rem;gap:.5rem}.nav-label{font-size:.85rem}.main{max-width:720px;padding-bottom:2rem}}
