*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #2563eb;--primary-hover: #1d4ed8;--danger: #dc2626;--danger-hover: #b91c1c;--bg: #f8fafc;--surface: #ffffff;--border: #e2e8f0;--text: #1e293b;--muted: #64748b;--radius: 8px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}.app{min-height:100vh;display:flex;flex-direction:column}.navbar{background:var(--surface);border-bottom:1px solid var(--border);padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between}.nav-brand{font-size:1.25rem;font-weight:700;color:var(--primary);text-decoration:none}.nav-links{display:flex;align-items:center;gap:1rem}.nav-links a{color:var(--text);text-decoration:none}.nav-links a:hover{color:var(--primary)}.nav-user{color:var(--muted);font-size:.875rem}.content{flex:1;max-width:960px;width:100%;margin:0 auto;padding:1.5rem}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.page-header h1{font-size:1.5rem}.btn{display:inline-block;padding:.5rem 1rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;text-decoration:none;font-size:.875rem;line-height:1.5}.btn:hover{background:var(--bg)}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:var(--primary-hover)}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover{background:var(--danger-hover)}.btn-small{padding:.25rem .5rem;font-size:.8rem}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-group{display:flex;gap:.5rem}.search-bar{display:flex;gap:.5rem;margin-bottom:1.5rem}.search-bar input{flex:1;padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;text-decoration:none;color:var(--text);transition:box-shadow .15s}.card:hover{box-shadow:0 2px 8px #00000014}.card h3{margin-bottom:.25rem}.auth-page{max-width:400px;margin:3rem auto}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-form label{display:flex;flex-direction:column;gap:.25rem;font-weight:500;font-size:.875rem}.auth-form input{padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem}.auth-form button{margin-top:.5rem}.auth-link{margin-top:1rem;text-align:center;font-size:.875rem;color:var(--muted)}.auth-link a{color:var(--primary)}.error{background:#fef2f2;border:1px solid #fecaca;color:var(--danger);padding:.75rem;border-radius:var(--radius);font-size:.875rem}.success{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a;padding:.75rem;border-radius:var(--radius);font-size:.875rem}.section{margin-bottom:1.5rem}.section h2{font-size:1.125rem;margin-bottom:.75rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.section-header h2{margin-bottom:0}.serving-scaler{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:.75rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.serving-scaler button{width:2rem;height:2rem;border-radius:50%;border:1px solid var(--border);background:var(--bg);cursor:pointer;font-size:1rem}.serving-count{font-size:1.25rem;font-weight:600;min-width:2rem;text-align:center}.ingredients-table{width:100%;border-collapse:collapse}.ingredients-table th,.ingredients-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--border)}.ingredients-table th{font-size:.8rem;text-transform:uppercase;color:var(--muted)}.recipe-form{display:flex;flex-direction:column;gap:1rem}.recipe-form label{display:flex;flex-direction:column;gap:.25rem;font-weight:500;font-size:.875rem}.recipe-form input,.recipe-form textarea,.recipe-form select{padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;font-family:inherit}.ingredient-row{display:flex;gap:.5rem;margin-bottom:.5rem;align-items:center}.ingredient-row select{flex:2}.ingredient-row input[type=number]{flex:1}.ingredient-row select:last-of-type{flex:1}.instructions{white-space:pre-wrap}.muted{color:var(--muted);font-size:.875rem}.empty{color:var(--muted);text-align:center;padding:3rem}.tag-grid{display:flex;flex-wrap:wrap;gap:.5rem}.tag-checkbox{display:flex;align-items:center;gap:.3rem;font-size:.85rem;font-weight:400;cursor:pointer;padding:.25rem .5rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.tag-checkbox:has(input:checked){border-color:var(--primary);background:#eff6ff}.tag-checkbox input{margin:0}.review-badge{display:inline-block;margin-left:.5rem;font-size:.65rem;font-weight:600;padding:.1rem .4rem;border-radius:3px;background:#fef3c7;color:#92400e;text-transform:uppercase}.calendar-page{display:flex;flex-direction:column;gap:1rem}.calendar-nav{display:flex;align-items:center;gap:.5rem}.calendar-title{font-weight:600;font-size:1rem;flex:1;text-align:center}.calendar-layout{display:flex;gap:1rem;min-height:500px}.calendar-grid-area{flex:1;min-width:0}.recipe-sidebar{width:200px;flex-shrink:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;display:flex;flex-direction:column;gap:.5rem;max-height:70vh;overflow:hidden}.recipe-sidebar h3{font-size:.9rem}.sidebar-search{padding:.35rem .5rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.8rem;width:100%}.sidebar-list{overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:.25rem}.sidebar-recipe{padding:.4rem .5rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.8rem;cursor:grab;background:var(--surface);transition:box-shadow .1s}.sidebar-recipe:active{cursor:grabbing}.sidebar-recipe:hover{box-shadow:0 1px 4px #0000001a}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.month-view{display:flex;flex-direction:column;gap:2px}.month-header-row{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.month-dow{text-align:center;font-size:.75rem;font-weight:600;color:var(--muted);padding:.25rem;text-transform:uppercase}.month-week-row{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.day-cell{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.5rem;min-height:80px;display:flex;flex-direction:column;gap:.25rem;transition:border-color .15s,background .15s}.day-cell.day-empty{background:var(--bg);border-color:transparent}.day-cell.day-today{border-color:var(--primary);background:#eff6ff}.day-cell.day-dragover{border-color:var(--primary);background:#dbeafe;border-style:dashed}.day-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.25rem}.day-number{font-weight:600;font-size:.85rem}.day-name{font-size:.7rem;color:var(--muted);text-transform:uppercase}.day-entries{display:flex;flex-direction:column;gap:.25rem;flex:1}.meal-entry{border-radius:4px;padding:.35rem .5rem;font-size:.8rem;border-left:3px solid var(--border);background:var(--bg);cursor:grab}.meal-entry:active{cursor:grabbing}.meal-entry-compact{padding:.2rem .4rem;font-size:.7rem}.meal-entry-header{display:flex;justify-content:space-between;align-items:center}.meal-entry-type{font-size:.65rem;text-transform:uppercase;color:var(--muted);font-weight:600}.meal-entry-name{display:block;font-weight:500}.meal-entry-servings{font-size:.7rem;color:var(--muted)}.meal-entry-actions{display:flex;gap:.2rem}.status-planned{border-left-color:var(--primary)}.status-confirmed{border-left-color:#16a34a;background:#f0fdf4}.status-skipped{border-left-color:#9ca3af;opacity:.7}.btn-icon{background:none;border:none;cursor:pointer;font-size:.9rem;padding:0 .2rem;color:var(--muted);line-height:1}.btn-icon:hover{color:var(--primary)}.btn-icon-danger:hover{color:var(--danger)}.dietary-badges{display:flex;flex-wrap:wrap;gap:.2rem;margin-top:.2rem}.dietary-badge{font-size:.6rem;padding:.1rem .3rem;border-radius:3px;background:#fef3c7;color:#92400e;font-weight:500}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--surface);border-radius:var(--radius);padding:1.5rem;min-width:300px;max-width:400px;box-shadow:0 8px 30px #00000026}.modal h3{margin-bottom:1rem;font-size:1rem}.modal-form{display:flex;flex-direction:column;gap:.75rem}.modal-form label{display:flex;flex-direction:column;gap:.25rem;font-weight:500;font-size:.875rem}.modal-form select,.modal-form input{padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem}.shopping-controls{display:flex;align-items:flex-end;gap:1rem;margin-bottom:1.5rem;padding:.75rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.shopping-controls label{display:flex;flex-direction:column;gap:.25rem;font-weight:500;font-size:.875rem}.shopping-controls input[type=date],.shopping-controls select{padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;height:2.375rem;box-sizing:border-box}.shopping-controls .btn{height:2.375rem;box-sizing:border-box;align-self:flex-end}.aisle-header-row td{padding-top:1.25rem;font-size:1.05rem;border-bottom:2px solid var(--border)}.shopping-summary{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-top:.5rem}.shopping-summary-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;cursor:pointer;font-weight:600;font-size:.875rem}.shopping-summary-body{padding:0 .75rem .75rem}.shopping-aisle-header{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500;font-size:.85rem;padding:.25rem 0}.shopping-aisle-items{padding-left:1rem;font-size:.85rem;color:var(--text-secondary);list-style:none}.shopping-aisle-items li{padding:.1rem 0}.stock-high{color:#16a34a;font-weight:500}.stock-low{color:#ca8a04;font-weight:500}.stock-out{color:var(--danger);font-weight:500}.price-promo{color:#16a34a;font-weight:600}.price-regular-struck{text-decoration:line-through;color:var(--muted);font-size:.8rem;margin-left:.25rem}.shopping-total td{padding-top:1rem;font-weight:700;font-size:1.05rem;border-top:2px solid var(--border)}.bulk-edit-table td{vertical-align:middle}.bulk-input{width:100%;padding:.3rem .5rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.85rem}.bulk-select{width:100%;padding:.3rem .4rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.8rem}.row-dirty{background:#fffbeb}@media(max-width:640px){.content{padding:1rem}.card-grid{grid-template-columns:1fr}.ingredient-row{flex-wrap:wrap}.page-header{flex-direction:column;align-items:flex-start;gap:.75rem}.calendar-layout{flex-direction:column}.recipe-sidebar{width:100%;max-height:200px;flex-direction:row;flex-wrap:wrap}.sidebar-list{flex-direction:row;flex-wrap:wrap}.week-grid{grid-template-columns:1fr}.month-view{display:none}}
