*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#faf9f6;--surface:#fff;--border:#e8e5e0;--text:#2c2c2c;--text-muted:#7a7a7a;--accent:#e07a3a;--accent-hover:#c96a2e;--accent-light:#fdf0e8;--spring:#6abf69;--summer:#e8c840;--fall:#d4793a;--winter:#5b8fc9;--produce:#6abf69;--meat:#d4564a;--dairy:#5b8fc9;--pantry:#b8a060;--frozen:#8ac4d0;--other:#999;--radius:10px;--shadow:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-lg:0 4px 12px #00000014}[data-theme=dark]{--bg:#1a1a1a;--surface:#242424;--border:#3a3a3a;--text:#e8e8e8;--text-muted:#999;--accent:#e8914a;--accent-hover:#f0a060;--accent-light:#3a2a1a;--shadow:0 1px 3px #0000004d, 0 1px 2px #0003;--shadow-lg:0 4px 12px #0006}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;line-height:1.5}button{cursor:pointer;font:inherit;border:none}input,select{font:inherit}.app{max-width:1400px;margin:0 auto;padding:24px 20px 80px}.app-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:20px;display:flex}.app-header h1{letter-spacing:-.02em;font-size:1.5rem;font-weight:700}.season-badge{text-transform:capitalize;border-radius:20px;align-items:center;gap:6px;padding:5px 12px;font-size:.8rem;font-weight:600;display:inline-flex}.season-badge.spring{color:#2d7a2d;background:#e8f5e8}.season-badge.summer{color:#8a7a10;background:#fef9e0}.season-badge.fall{color:#9a5a20;background:#fdf0e8}.season-badge.winter{color:#3a6a9a;background:#e8f0fa}[data-theme=dark] .season-badge.spring{color:#6abf69;background:#1a3a1a}[data-theme=dark] .season-badge.summer{color:#e8c840;background:#3a3510}[data-theme=dark] .season-badge.fall{color:#d4793a;background:#3a2a1a}[data-theme=dark] .season-badge.winter{color:#5b8fc9;background:#1a2a3a}.tabs{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);gap:4px;margin-bottom:28px;padding:4px;display:flex}.tab{color:var(--text-muted);background:0 0;border-radius:7px;flex:1;padding:10px 16px;font-size:.875rem;font-weight:500;transition:all .15s}.tab:hover{color:var(--text);background:var(--bg)}.tab.active{background:var(--accent);color:#fff}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.card+.card{margin-top:12px}.meal-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px;display:grid}.meal-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);cursor:default;padding:16px;transition:box-shadow .15s}.meal-card:hover{box-shadow:var(--shadow-lg)}.meal-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:8px;display:flex}.meal-card h3{font-size:1rem;font-weight:600}.meal-card p{color:var(--text-muted);margin-bottom:10px;font-size:.85rem}.meal-meta{flex-wrap:wrap;gap:6px;display:flex}.tag{background:var(--bg);color:var(--text-muted);border:1px solid var(--border);border-radius:12px;padding:2px 8px;font-size:.72rem;font-weight:500;display:inline-block}.season-dot{border-radius:50%;width:8px;height:8px;margin-right:2px;display:inline-block}.season-dot.spring{background:var(--spring)}.season-dot.summer{background:var(--summer)}.season-dot.fall{background:var(--fall)}.season-dot.winter{background:var(--winter)}.prep-time{color:var(--text-muted);white-space:nowrap;font-size:.8rem}.week-section{margin-bottom:32px}.week-section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.week-section-header h2{font-size:1rem;font-weight:600}.week-grid{grid-template-columns:repeat(7,1fr);gap:8px;display:grid}@media (width<=800px){.week-grid{grid-template-columns:1fr;gap:6px}.day-slot{min-height:0;padding:10px 12px}.day-slot-header{margin-bottom:6px}.day-slot-meal,.day-slot-empty{flex:initial;text-align:left;flex-direction:row;justify-content:space-between;align-items:center;gap:8px;padding:4px 0}.day-slot-meal+.day-slot-meal{border-top:1px solid var(--border)}.day-slot-meal .meal-name{flex:1;min-width:0;margin-bottom:0}.day-slot-meal .prep-time{font-size:.72rem}.day-slot .add-btn{margin-top:6px;padding:6px;font-size:.78rem}.day-slot .remove-btn{flex-shrink:0;margin-top:0}}.day-slot{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);flex-direction:column;min-height:120px;padding:12px;transition:border-color .15s,background .15s;display:flex}.day-slot.drag-over{border-color:var(--accent);background:var(--accent-light)}.day-slot-header{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px;font-size:.75rem;font-weight:600}.day-slot-meal{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex}.day-slot-meal .meal-name{margin-bottom:4px;font-size:.85rem;font-weight:600}.day-slot-empty{flex:1;justify-content:center;align-items:center;display:flex}.day-slot .add-btn{width:100%;color:var(--text-muted);background:var(--bg);border:1px dashed var(--border);border-radius:6px;padding:8px;font-size:.8rem;transition:all .15s}.day-slot .add-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.day-slot .remove-btn{color:var(--text-muted);background:0 0;border-radius:4px;margin-top:4px;padding:2px 6px;font-size:.72rem}.day-slot .remove-btn:hover{color:#d4564a;background:#fde8e8}[data-theme=dark] .day-slot .remove-btn:hover{background:#3a2020}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000004d;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface);width:90%;max-width:500px;max-height:80vh;box-shadow:var(--shadow-lg);border-radius:12px;padding:24px;overflow-y:auto}.modal h2{margin-bottom:16px;font-size:1.1rem}.modal-search{border:1px solid var(--border);border-radius:8px;width:100%;margin-bottom:12px;padding:10px 14px;font-size:.9rem}.modal-search:focus{border-color:var(--accent);outline:none}.modal-meal-list{list-style:none}.modal-meal-item{cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;padding:10px 12px;transition:background .1s;display:flex}.modal-meal-item:hover{background:var(--accent-light)}.modal-meal-item .name{font-size:.9rem;font-weight:500}.modal-meal-item .seasons{gap:3px;display:flex}.modal-close{background:var(--bg);width:100%;color:var(--text-muted);border-radius:8px;margin-top:12px;padding:10px;font-weight:500;display:block}.grocery-section{margin-bottom:20px}.grocery-section h3{text-transform:capitalize;border-bottom:1px solid var(--border);align-items:center;gap:8px;margin-bottom:6px;padding:8px 0 6px;font-size:.85rem;font-weight:600;display:flex}.grocery-section h3 .cat-dot{border-radius:50%;width:10px;height:10px}.cat-dot.produce{background:var(--produce)}.cat-dot.meat{background:var(--meat)}.cat-dot.dairy{background:var(--dairy)}.cat-dot.pantry{background:var(--pantry)}.cat-dot.frozen{background:var(--frozen)}.cat-dot.other{background:var(--other)}.grocery-item{border-radius:6px;align-items:center;gap:10px;padding:6px 8px;font-size:.9rem;display:flex}.grocery-item:hover{background:var(--bg)}.grocery-item input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px}.grocery-item.checked .item-name{color:var(--text-muted);text-decoration:line-through}.grocery-item .item-name{text-transform:capitalize;flex:1}.grocery-item .item-qty{color:var(--text-muted);font-size:.8rem}.grocery-empty{text-align:center;color:var(--text-muted);padding:40px 20px}.btn{border-radius:8px;padding:8px 16px;font-size:.875rem;font-weight:500;transition:all .15s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-danger{color:#d4564a;background:0 0;font-size:.8rem}.btn-danger:hover{background:#fde8e8}[data-theme=dark] .btn-danger:hover{background:#3a2020}[data-theme=dark] .ingredient-row .remove-ing:hover{color:#d4564a;background:#3a2020}[data-theme=dark] .modal-overlay{background:#0009}.suggestions{margin-bottom:24px}.suggestions h2{color:var(--text-muted);margin-bottom:10px;font-size:.9rem;font-weight:600}.suggestion-chips{gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.suggestion-chip{white-space:nowrap;background:var(--accent-light);color:var(--accent);border:1px solid #0000;border-radius:20px;padding:8px 14px;font-size:.82rem;font-weight:500;transition:all .15s}.suggestion-chip:hover{border-color:var(--accent)}.suggestion-chip[draggable]{cursor:grab}.suggestion-chip[draggable]:active{cursor:grabbing}.drag-hint{color:var(--text-muted);margin-top:6px;font-size:.75rem}.meal-form{max-width:600px}.form-group{margin-bottom:16px}.form-group label{color:var(--text-muted);margin-bottom:4px;font-size:.82rem;font-weight:600;display:block}.form-group input,.form-group textarea{border:1px solid var(--border);border-radius:8px;width:100%;padding:10px 12px;font-size:.9rem}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent);outline:none}.season-toggles{gap:6px;display:flex}.season-toggle{text-transform:capitalize;border:1px solid var(--border);background:var(--surface);color:var(--text-muted);border-radius:20px;padding:6px 14px;font-size:.8rem;font-weight:500;transition:all .15s}.season-toggle.selected{border-color:#0000}.season-toggle.spring.selected{color:#2d7a2d;background:#e8f5e8}.season-toggle.summer.selected{color:#8a7a10;background:#fef9e0}.season-toggle.fall.selected{color:#9a5a20;background:#fdf0e8}.season-toggle.winter.selected{color:#3a6a9a;background:#e8f0fa}[data-theme=dark] .season-toggle.spring.selected{color:#6abf69;background:#1a3a1a}[data-theme=dark] .season-toggle.summer.selected{color:#e8c840;background:#3a3510}[data-theme=dark] .season-toggle.fall.selected{color:#d4793a;background:#3a2a1a}[data-theme=dark] .season-toggle.winter.selected{color:#5b8fc9;background:#1a2a3a}.ingredient-row{align-items:center;gap:8px;margin-bottom:6px;display:flex}.ingredient-row input{border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-size:.85rem}.ingredient-row input:focus{border-color:var(--accent);outline:none}.ingredient-row .ing-name{flex:3}.ingredient-row .ing-qty,.ingredient-row .ing-unit{flex:1}.ingredient-row .ing-cat{border:1px solid var(--border);background:var(--surface);border-radius:6px;flex:1.5;padding:8px 6px;font-size:.85rem}.ingredient-row .remove-ing{color:var(--text-muted);background:0 0;border-radius:4px;padding:4px 8px;font-size:1.1rem}.ingredient-row .remove-ing:hover{color:#d4564a;background:#fde8e8}.form-actions{gap:8px;margin-top:20px;display:flex}.filter-bar{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;display:flex}.filter-bar input{border:1px solid var(--border);border-radius:8px;flex:1;min-width:200px;padding:10px 14px;font-size:.9rem}.filter-bar input:focus{border-color:var(--accent);outline:none}.takeout-toggles{background:var(--bg);border:1px solid var(--border);border-radius:8px;gap:4px;padding:3px;display:flex}.takeout-toggle{color:var(--text-muted);background:0 0;border-radius:6px;padding:5px 12px;font-size:.8rem;font-weight:500;transition:all .15s}.takeout-toggle:hover{color:var(--text)}.takeout-toggle.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow)}.clickable{cursor:pointer}.day-slot-meal .meal-name.clickable:hover{color:var(--accent);text-decoration:underline}.meal-card-header.clickable:hover h3{color:var(--accent)}.recipe-modal{max-width:600px}.recipe-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.recipe-header h2{margin-bottom:0}.recipe-description{color:var(--text-muted);margin-bottom:16px;font-size:.9rem}.recipe-section{margin-bottom:16px}.recipe-section h3{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);margin-bottom:8px;padding-bottom:6px;font-size:.85rem;font-weight:600}.recipe-ingredients{grid-template-columns:1fr 1fr;gap:4px 16px;list-style:none;display:grid}.recipe-ingredients li{padding:3px 0;font-size:.88rem}.recipe-ingredients .ing-amount{font-weight:600}.recipe-steps{padding-left:20px}.recipe-steps li{margin-bottom:8px;font-size:.9rem;line-height:1.6}.recipe-steps li::marker{color:var(--accent);font-weight:600}.recipe-empty{color:var(--text-muted);font-size:.9rem;font-style:italic}.theme-toggle{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:8px;padding:6px 10px;font-size:1rem;line-height:1;transition:all .15s}.theme-toggle:hover{background:var(--bg);border-color:var(--accent)}.form-group textarea{resize:vertical;min-height:100px}.planner-layout{align-items:flex-start;gap:20px;display:flex}.planner-main{flex:1;min-width:0}.meal-sidebar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:280px;box-shadow:var(--shadow);flex-direction:column;flex-shrink:0;max-height:calc(100vh - 160px);display:flex;position:sticky;top:20px}.sidebar-section{padding:14px}.sidebar-section+.sidebar-section{border-top:1px solid var(--border)}.sidebar-browse{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.sidebar-heading{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:10px;font-size:.8rem;font-weight:700}.sidebar-empty{color:var(--text-muted);text-align:center;padding:12px 0;font-size:.8rem}.sidebar-picks{flex-direction:column;gap:4px;display:flex}.sidebar-pick-item{background:var(--accent-light);cursor:grab;border:1px solid #0000;border-radius:8px;align-items:center;gap:6px;padding:8px 10px;transition:all .15s;display:flex}.sidebar-pick-item:hover{border-color:var(--accent)}.sidebar-pick-item:active{cursor:grabbing}.pick-name{cursor:pointer;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.82rem;font-weight:600;overflow:hidden}.pick-name:hover{color:var(--accent);text-decoration:underline}.pick-time{color:var(--text-muted);white-space:nowrap;font-size:.72rem}.pick-remove{color:var(--text-muted);background:0 0;border-radius:4px;padding:0 4px;font-size:1rem;line-height:1}.pick-remove:hover{color:#d4564a;background:#fde8e8}[data-theme=dark] .pick-remove:hover{background:#3a2020}.sidebar-search{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);border-radius:6px;margin-bottom:8px;padding:8px 10px;font-size:.82rem}.sidebar-search:focus{border-color:var(--accent);outline:none}.sidebar-meal-list{flex:1;overflow-y:auto}.sidebar-meal-item{border-radius:6px;align-items:center;gap:6px;padding:6px 8px;transition:background .1s;display:flex}.sidebar-meal-item:hover{background:var(--bg)}.sidebar-meal-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.sidebar-meal-name{cursor:pointer;text-overflow:ellipsis;white-space:nowrap;font-size:.82rem;font-weight:500;overflow:hidden}.sidebar-meal-name:hover{color:var(--accent)}.sidebar-meal-meta{align-items:center;gap:4px;display:flex}.sidebar-meal-meta .prep-time{margin-left:2px;font-size:.7rem}.sidebar-add-btn{background:var(--bg);width:26px;height:26px;color:var(--text-muted);border:1px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;font-weight:600;line-height:1;transition:all .15s;display:flex}.sidebar-add-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.sidebar-add-btn.picked{background:var(--accent);color:#fff;border-color:var(--accent)}.sidebar-add-btn.picked:hover{background:var(--accent-hover);color:#fff}@media (width<=900px){.planner-layout{flex-direction:column;align-items:stretch}.planner-main{width:100%}.meal-sidebar{width:100%;max-height:300px;position:static}}
