*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #2563eb;--primary-hover: #1d4ed8;--primary-light: #eff6ff;--primary-ring: rgba(37, 99, 235, .2);--success: #16a34a;--success-bg: #dcfce7;--success-text: #166534;--warning: #d97706;--warning-bg: #fef3c7;--warning-text: #92400e;--danger: #dc2626;--danger-bg: #fee2e2;--danger-text: #991b1b;--neutral-50: #f9fafb;--neutral-100: #f3f4f6;--neutral-200: #e5e7eb;--neutral-300: #d1d5db;--neutral-400: #9ca3af;--neutral-500: #6b7280;--neutral-600: #4b5563;--neutral-700: #374151;--neutral-800: #1f2937;--neutral-900: #111827;--radius-sm: 6px;--radius: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07), 0 2px 4px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1), 0 4px 6px rgba(0, 0, 0, .05)}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--neutral-50);color:var(--neutral-900);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-container{max-width:960px;margin:0 auto;padding:1.5rem 1rem}.app-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.app-header h1{margin:0;font-size:1.5rem;font-weight:700;color:var(--neutral-900);letter-spacing:-.025em}.app-header .spacer{flex:1}.tabs{display:flex;gap:.25rem;margin-bottom:1.5rem;border-bottom:2px solid var(--neutral-200)}.tab-btn{padding:.6rem 1.25rem;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;background:transparent;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--neutral-500);transition:color .15s,border-color .15s;white-space:nowrap}.tab-btn:hover{color:var(--neutral-700)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;font-family:inherit;border:1px solid var(--neutral-300);border-radius:var(--radius-sm);background:#fff;color:var(--neutral-700);cursor:pointer;transition:all .15s;text-decoration:none;line-height:1.4}.btn:hover{background:var(--neutral-50);border-color:var(--neutral-400)}.btn:active{background:var(--neutral-100)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn-ghost{background:transparent;border-color:transparent;color:var(--neutral-500)}.btn-ghost:hover{background:var(--neutral-100);color:var(--neutral-700)}.btn-sm{padding:.3rem .6rem;font-size:.75rem;border-radius:var(--radius-sm)}.btn-xs{padding:.2rem .5rem;font-size:.7rem;border-radius:4px}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border-radius:50%;border:1px solid var(--neutral-300);background:#fff;cursor:pointer;font-size:1rem;line-height:1;transition:all .15s}.btn-icon:hover{background:var(--neutral-100);border-color:var(--neutral-400)}.btn-icon:active{background:var(--neutral-200)}.btn-icon-sm{width:24px;height:24px;font-size:.875rem}.close-btn{background:none;border:none;cursor:pointer;font-size:1.25rem;color:var(--neutral-400);line-height:1;padding:.25rem;border-radius:4px;transition:color .15s,background .15s}.close-btn:hover{color:var(--neutral-700);background:var(--neutral-100)}.card{background:#fff;border:1px solid var(--neutral-200);border-radius:var(--radius-lg);padding:1rem;box-shadow:var(--shadow-sm)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.card-title{font-size:.95rem;font-weight:600;color:var(--neutral-800)}.card-subtitle{font-size:.75rem;color:var(--neutral-400)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.page-title{font-size:1.25rem;font-weight:700;color:var(--neutral-800);margin:0}.page-actions{display:flex;gap:.5rem}.table-wrap{background:#fff;border:1px solid var(--neutral-200);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:.75rem 1rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--neutral-500);background:var(--neutral-50);border-bottom:1px solid var(--neutral-200)}.data-table td{padding:.75rem 1rem;font-size:.875rem;color:var(--neutral-700);border-bottom:1px solid var(--neutral-100);vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--neutral-50)}.badge{display:inline-flex;align-items:center;padding:.15rem .55rem;border-radius:100px;font-size:.75rem;font-weight:600;line-height:1.5;white-space:nowrap}.badge--success{background:var(--success-bg);color:var(--success-text)}.badge--warning{background:var(--warning-bg);color:var(--warning-text)}.badge--danger{background:var(--danger-bg);color:var(--danger-text)}.badge--neutral{background:var(--neutral-100);color:var(--neutral-500)}.form-group{margin-bottom:1rem}.form-label{display:block;margin-bottom:.35rem;font-size:.875rem;font-weight:600;color:var(--neutral-700)}.form-input{width:100%;padding:.55rem .75rem;font-size:.925rem;font-family:inherit;border:1px solid var(--neutral-300);border-radius:var(--radius-sm);background:#fff;color:var(--neutral-900);transition:border-color .15s,box-shadow .15s;line-height:1.5}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ring)}.form-input::placeholder{color:var(--neutral-400)}.pantry-textarea{resize:vertical;min-height:100px;font-size:.925rem;line-height:1.6}.pantry-previews{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.pantry-preview-wrap{position:relative;width:100px;height:80px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--neutral-200);flex-shrink:0}.pantry-preview{width:100%;height:100%;object-fit:cover;display:block}.pantry-preview-remove{position:absolute;top:2px;right:2px;width:20px;height:20px;border-radius:50%;border:none;background:#0009;color:#fff;font-size:.85rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .15s}.pantry-preview-remove:hover{background:#dc2626cc}.pantry-actions{display:flex;justify-content:space-between;align-items:center;margin-top:.75rem;flex-wrap:wrap;gap:.5rem}.pantry-actions-left{display:flex;align-items:center}.form-select{padding:.4rem .6rem;font-size:.875rem;font-family:inherit;border:1px solid var(--neutral-300);border-radius:var(--radius-sm);background:#fff;color:var(--neutral-700);cursor:pointer}.form-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ring)}.error-text{color:var(--danger);font-size:.875rem;margin-bottom:.75rem}.login-container{max-width:380px;margin:6rem auto;padding:2rem;background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.login-title{font-size:1.75rem;font-weight:700;text-align:center;margin-bottom:1.5rem;letter-spacing:-.025em}.chips{display:flex;flex-wrap:wrap;gap:.5rem}.chip{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .65rem;border-radius:100px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none;border:1px solid transparent}.chip:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.chip:active{transform:translateY(0)}.chip--yes{background:var(--success-bg);color:var(--success-text);border-color:var(--success)}.chip--no{background:var(--neutral-100);color:var(--neutral-500);border-color:var(--neutral-200)}.chip--low{background:var(--warning-bg);color:var(--warning-text);border-color:var(--warning)}.chip--unknown{background:var(--neutral-100);color:var(--neutral-500);border-color:var(--neutral-200)}.chip--disabled{opacity:.6;cursor:wait}.chip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.chip-dot--yes{background:var(--success)}.chip-dot--no{background:var(--neutral-300)}.chip-dot--low{background:var(--warning)}.chip-dot--unknown{background:var(--neutral-300)}.chip-label{font-size:.75rem;color:inherit;opacity:.7}.hint{font-size:.75rem;color:var(--neutral-400);margin-top:.5rem}.ideas-layout{display:flex;gap:1.5rem}.ideas-list{flex:1;min-width:0}.ideas-list--with-panel{flex:0 0 50%;max-width:50%}.idea-card{background:#fff;border:1px solid var(--neutral-200);border-radius:var(--radius-lg);padding:.85rem 1rem;margin-bottom:.5rem;cursor:pointer;transition:all .15s;box-shadow:var(--shadow-sm)}.idea-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-1px)}.idea-card--selected{border-color:var(--primary);background:var(--primary-light);box-shadow:0 0 0 2px var(--primary-ring)}.idea-content{display:flex;justify-content:space-between;align-items:center;gap:1rem}.idea-info{flex:1;min-width:0}.idea-title{font-weight:600;font-size:.925rem;color:var(--neutral-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.idea-meta{font-size:.8rem;color:var(--neutral-500);margin-top:.2rem}.idea-missing{font-size:.8rem;color:var(--danger-text);margin-top:.2rem}.score-circle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;color:#fff;font-weight:700;font-size:.8rem;flex-shrink:0}.missing-chips{display:flex;flex-wrap:wrap;gap:.35rem}.missing-chip{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .55rem .2rem .4rem;border-radius:100px;font-size:.78rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none;border:1px solid var(--danger);background:var(--danger-bg);color:var(--danger-text);line-height:1.5}.missing-chip:hover{background:var(--success-bg);border-color:var(--success);color:var(--success-text);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.missing-chip:active{transform:translateY(0)}.missing-chip--loading{opacity:.6;cursor:wait;pointer-events:none}.missing-chip-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--danger);color:#fff;font-size:.7rem;font-weight:700;line-height:1;flex-shrink:0;transition:background .15s}.missing-chip:hover .missing-chip-icon{background:var(--success)}.empty-state{text-align:center;padding:2rem;color:var(--neutral-400);font-size:.9rem}.recipe-panel{flex:0 0 50%;max-width:50%;background:#fff;border:1px solid var(--neutral-200);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow-md);align-self:flex-start;max-height:calc(100vh - 140px);overflow-y:auto;position:sticky;top:1rem}.recipe-panel-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.recipe-panel-title{font-size:1.15rem;font-weight:700;color:var(--neutral-800);flex:1;margin-right:.5rem}.recipe-image{width:100%;max-height:200px;object-fit:cover;border-radius:var(--radius);margin-bottom:.75rem}.tags{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:.75rem}.tag{display:inline-block;background:var(--neutral-100);color:var(--neutral-600);border-radius:100px;padding:.15rem .55rem;font-size:.75rem;font-weight:500}.section-title{font-size:1rem;font-weight:700;color:var(--neutral-800);margin:0 0 .5rem}.servings-control{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--neutral-600)}.servings-value{font-weight:600;color:var(--neutral-800);min-width:24px;text-align:center}.ingredients-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.sub-notice{padding:.4rem .6rem;background:var(--warning-bg);border-radius:var(--radius-sm);font-size:.8rem;color:var(--warning-text);margin-bottom:.5rem}.ingredient-list{list-style:none;margin:0;padding:0}.ingredient-item{display:flex;justify-content:space-between;align-items:center;padding:.4rem 0;border-bottom:1px solid var(--neutral-100);font-size:.875rem;gap:.5rem}.ingredient-item:last-child{border-bottom:none}.ingredient-text{flex:1;min-width:0}.ingredient-actions{display:flex;gap:.25rem;flex-shrink:0}.sub-picker{margin-top:.35rem;padding:.5rem;background:var(--primary-light);border-radius:var(--radius);font-size:.85rem}.sub-picker-label{font-weight:500;margin-bottom:.3rem}.appliances-list{margin:0;padding-left:1.25rem;font-size:.875rem;line-height:1.6}.instructions-list{margin:0;padding-left:1.25rem;font-size:.875rem;line-height:1.7}.instructions-list li{margin-bottom:.35rem}.meal-plan-selector{display:flex;gap:.5rem;align-items:center;margin-bottom:1rem;flex-wrap:wrap}.meal-plan-label{font-size:.875rem;font-weight:500;color:var(--neutral-600)}.meal-plan-table-wrap{background:#fff;border:1px solid var(--neutral-200);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.meal-plan-table{width:100%;border-collapse:collapse}.meal-plan-table th{text-align:left;padding:.65rem .75rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--neutral-500);background:var(--neutral-50);border-bottom:1px solid var(--neutral-200)}.meal-plan-table td{padding:.65rem .75rem;font-size:.85rem;color:var(--neutral-700);border-bottom:1px solid var(--neutral-100);vertical-align:top}.meal-plan-table tr:last-child td{border-bottom:none}.meal-plan-table tr:hover td{background:var(--neutral-50)}.day-name{font-weight:600;color:var(--neutral-800)}.meal-name{font-weight:500;margin-bottom:.15rem}.meal-servings{font-size:.725rem;color:var(--neutral-400)}.meal-empty{color:var(--neutral-300)}@media(max-width:768px){.ideas-layout{flex-direction:column}.ideas-list--with-panel{flex:1;max-width:100%}.recipe-panel{flex:1;max-width:100%;max-height:none;position:static}.app-container{padding:1rem .75rem}.login-container{margin:3rem 1rem;padding:1.5rem}.data-table th,.data-table td{padding:.5rem .65rem}.meal-plan-table th,.meal-plan-table td{padding:.5rem}.tab-btn{padding:.5rem .85rem;font-size:.8rem}.page-header{flex-direction:column;align-items:flex-start;gap:.5rem}}.recipe-panel::-webkit-scrollbar{width:6px}.recipe-panel::-webkit-scrollbar-track{background:transparent}.recipe-panel::-webkit-scrollbar-thumb{background:var(--neutral-300);border-radius:3px}.recipe-panel::-webkit-scrollbar-thumb:hover{background:var(--neutral-400)}
