*,*: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);--header-height: 56px;--touch-target: 44px;--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px)}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;overflow-x:hidden}.app-container{max-width:960px;margin:0 auto;padding:.75rem}@media(min-width:640px){.app-container{padding:1rem 1.5rem}}@media(min-width:1024px){.app-container{padding:1.5rem 2rem}}.app-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;min-height:var(--header-height)}.app-header h1{margin:0;font-size:1.25rem;font-weight:700;color:var(--neutral-900);letter-spacing:-.025em}@media(min-width:640px){.app-header h1{font-size:1.5rem}}.app-logo{width:28px;height:28px;border-radius:6px;flex-shrink:0}@media(min-width:640px){.app-logo{width:32px;height:32px}}.app-header .spacer{flex:1}.tabs{display:flex;gap:.25rem;margin-bottom:1.25rem;border-bottom:2px solid var(--neutral-200);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab-btn{padding:.6rem .85rem;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;background:transparent;cursor:pointer;font-size:.85rem;font-weight:500;color:var(--neutral-500);transition:color .15s,border-color .15s;white-space:nowrap;min-height:var(--touch-target);-webkit-tap-highlight-color:transparent}@media(min-width:640px){.tab-btn{padding:.6rem 1.25rem;font-size:.875rem}}.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 .85rem;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;min-height:var(--touch-target);-webkit-tap-highlight-color:transparent;touch-action:manipulation}.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);min-height:auto}.btn-xs{padding:.25rem .5rem;font-size:.7rem;border-radius:4px;min-height:auto}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border-radius:50%;border:1px solid var(--neutral-300);background:#fff;cursor:pointer;font-size:1.125rem;line-height:1;transition:all .15s;-webkit-tap-highlight-color:transparent}.btn-icon:hover{background:var(--neutral-100);border-color:var(--neutral-400)}.btn-icon:active{background:var(--neutral-200)}.btn-icon-sm{width:28px;height:28px;font-size:.925rem}@media(min-width:640px){.btn-icon-sm{width:24px;height:24px;font-size:.875rem}}.close-btn{background:none;border:none;cursor:pointer;font-size:1.5rem;color:var(--neutral-400);line-height:1;padding:.375rem;border-radius:4px;transition:color .15s,background .15s;min-width:var(--touch-target);min-height:var(--touch-target);display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.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:.85rem;box-shadow:var(--shadow-sm)}@media(min-width:640px){.card{padding:1rem}}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;gap:.5rem}.card-title{font-size:.925rem;font-weight:600;color:var(--neutral-800);overflow-wrap:break-word;word-break:break-word}.card-subtitle{font-size:.75rem;color:var(--neutral-400);white-space:nowrap}.page-header{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem;margin-bottom:.85rem}@media(min-width:640px){.page-header{flex-direction:row;justify-content:space-between;align-items:center;margin-bottom:1rem}}.page-title{font-size:1.125rem;font-weight:700;color:var(--neutral-800);margin:0}.page-actions{display:flex;gap:.5rem;flex-shrink:0;max-width:100%;flex-wrap:wrap}.table-wrap{background:#fff;border:1px solid var(--neutral-200);border-radius:var(--radius-lg);overflow-x:auto;-webkit-overflow-scrolling:touch;box-shadow:var(--shadow-sm)}.data-table{width:100%;table-layout:auto;border-collapse:collapse}.data-table th{text-align:left;padding:.65rem .75rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--neutral-500);background:var(--neutral-50);border-bottom:1px solid var(--neutral-200);white-space:nowrap}.data-table td{padding:.65rem .75rem;font-size:.85rem;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)}@media(min-width:640px){.data-table th{padding:.75rem 1rem;font-size:.75rem}.data-table td{padding:.75rem 1rem;font-size:.875rem}}.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:.6rem .75rem;font-size:1rem;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;-webkit-appearance:none;-moz-appearance:none;appearance:none}@media(min-width:640px){.form-input{font-size:.925rem;padding:.55rem .75rem}}.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)}.form-select{padding:.5rem .6rem;font-size:.925rem;font-family:inherit;border:1px solid var(--neutral-300);border-radius:var(--radius-sm);background:#fff;color:var(--neutral-700);cursor:pointer;min-height:var(--touch-target)}.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}.pantry-textarea{resize:vertical;min-height:100px;font-size:1rem;line-height:1.6}@media(min-width:640px){.pantry-textarea{font-size:.925rem}}.pantry-previews{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.pantry-preview-wrap{position:relative;width:80px;height:64px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--neutral-200);flex-shrink:0}@media(min-width:640px){.pantry-preview-wrap{width:100px;height:80px}}.pantry-preview{width:100%;height:100%;object-fit:cover;display:block}.pantry-preview-remove{position:absolute;top:2px;right:2px;width:22px;height:22px;border-radius:50%;border:none;background:#0009;color:#fff;font-size:.9rem;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;flex-direction:column;gap:.65rem;margin-top:.75rem}@media(min-width:480px){.pantry-actions{flex-direction:row;justify-content:space-between;align-items:center}}.pantry-actions-left{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem}.pantry-actions-left .btn-primary{animation:pulse-recording 1.5s ease-in-out infinite}@keyframes pulse-recording{0%,to{box-shadow:0 0 #2563eb66}50%{box-shadow:0 0 0 6px #2563eb00}}.login-container{max-width:380px;margin:2rem 1rem;padding:1.5rem;background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}@media(min-width:480px){.login-container{margin:6rem auto;padding:2rem}}.login-title{font-size:1.5rem;font-weight:700;text-align:center;margin-bottom:1.25rem;letter-spacing:-.025em}@media(min-width:640px){.login-title{font-size:1.75rem;margin-bottom:1.5rem}}.chips{display:flex;flex-wrap:wrap;gap:.5rem}.chip{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .7rem;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;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.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}.empty-state{text-align:center;padding:2rem 1rem;color:var(--neutral-400);font-size:.9rem}.ideas-layout{display:flex;flex-direction:column;gap:1rem}@media(min-width:768px){.ideas-layout{flex-direction:row;gap:1.5rem}}.ideas-list{flex:1;min-width:0;max-width:100%}.ideas-list--with-panel{flex:1;max-width:100%}@media(min-width:768px){.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;margin-bottom:.5rem;cursor:pointer;transition:all .15s;box-shadow:var(--shadow-sm);-webkit-tap-highlight-color:transparent}.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:.75rem}.idea-info{flex:1;min-width:0;overflow-wrap:break-word;word-break:break-word}.idea-title{font-weight:600;font-size:.9rem;color:var(--neutral-800)}.idea-meta{font-size:.78rem;color:var(--neutral-500);margin-top:.2rem}.idea-missing{font-size:.78rem;color:var(--danger-text);margin-top:.2rem}.score-circle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;color:#fff;font-weight:700;font-size:.75rem;flex-shrink:0}@media(min-width:640px){.score-circle{width:40px;height:40px;font-size:.8rem}}.missing-chips{display:flex;flex-wrap:wrap;gap:.35rem}.missing-chip{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .55rem .25rem .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;min-height:var(--touch-target);-webkit-tap-highlight-color:transparent}.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)}.recipe-panel{width:100%;background:#fff;border:1px solid var(--neutral-200);border-radius:var(--radius-lg);padding:1rem;box-shadow:var(--shadow-md);align-self:flex-start}@media(min-width:768px){.recipe-panel{flex:0 0 50%;max-width:50%;max-height:calc(100vh - 140px);overflow-y:auto;position:sticky;top:1rem;padding:1.25rem}.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)}}.recipe-panel-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;gap:.5rem}.recipe-panel-title{font-size:1.1rem;font-weight:700;color:var(--neutral-800);flex:1}.recipe-image{width:100%;max-height:180px;object-fit:cover;border-radius:var(--radius);margin-bottom:.75rem}@media(min-width:640px){.recipe-image{max-height:200px}}.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:.95rem;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;gap:.5rem;flex-wrap:wrap}.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;font-size:.85rem;overflow-wrap:break-word;word-break:break-word}@media(min-width:640px){.ingredient-text{font-size:.875rem}}.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-x:auto;-webkit-overflow-scrolling:touch;box-shadow:var(--shadow-sm)}.meal-plan-table{width:100%;table-layout:auto;border-collapse:collapse}@media(min-width:640px){.meal-plan-table{min-width:600px}}.meal-plan-table th{text-align:left;padding:.6rem .65rem;font-size:.7rem;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:.6rem .65rem;font-size:.82rem;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)}@media(min-width:640px){.meal-plan-table th{padding:.65rem .75rem;font-size:.75rem}.meal-plan-table td{padding:.65rem .75rem;font-size:.85rem}}.day-name{font-weight:600;color:var(--neutral-800);white-space:nowrap}.meal-name{font-weight:500;margin-bottom:.15rem}.meal-servings{font-size:.725rem;color:var(--neutral-400)}.meal-empty{color:var(--neutral-300)}.show-mobile{display:none}@media(max-width:639px){.hide-mobile{display:none}.show-mobile{display:block}}@media(max-width:767px){.tabs{gap:0}.tabs .tab-btn{flex:1 1 0;min-width:0;padding:.6rem .25rem;font-size:.8rem;text-align:center;white-space:normal;word-break:break-word}}@media(max-width:639px){.app-header{margin-bottom:.75rem}.app-header h1{font-size:1.1rem}}.recipe-page-header{margin-bottom:1rem}.recipe-page .recipe-panel{width:100%;max-width:100%;border:none;border-radius:0;padding:0;box-shadow:none;align-self:auto;max-height:none}@media(min-width:768px){.recipe-page .recipe-panel{padding:0}}.recipe-page .recipe-panel-header{position:sticky;top:0;background:#fff;z-index:1;padding-top:.25rem}@media(max-width:639px){.stock-cards{display:flex;flex-direction:column;gap:.5rem}.stock-card{background:#fff;border:1px solid var(--neutral-200);border-radius:var(--radius);padding:.75rem;display:flex;flex-direction:column;gap:.5rem}.stock-card-row{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.stock-card-name{font-weight:600;font-size:.9rem;color:var(--neutral-800)}.stock-card-unit{font-size:.8rem;color:var(--neutral-400)}.stock-card-actions{display:flex;gap:.25rem;flex-wrap:wrap}}@media(max-width:639px){.meal-plan-cards{display:flex;flex-direction:column;gap:.75rem}.meal-plan-day-card{background:#fff;border:1px solid var(--neutral-200);border-radius:var(--radius-lg);padding:.75rem;box-shadow:var(--shadow-sm)}.meal-plan-day-header{font-weight:700;font-size:.95rem;color:var(--neutral-800);margin-bottom:.5rem;padding-bottom:.4rem;border-bottom:1px solid var(--neutral-100)}.meal-plan-meal{display:flex;justify-content:space-between;align-items:center;padding:.3rem 0;gap:.5rem}.meal-plan-meal-label{font-size:.8rem;font-weight:600;color:var(--neutral-500);min-width:68px;flex-shrink:0}.meal-plan-meal-name{font-size:.85rem;color:var(--neutral-800);flex:1;text-align:right;overflow-wrap:break-word;word-break:break-word}.meal-plan-meal-empty{color:var(--neutral-300);font-size:.8rem}}
