@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";
:root{--bg-primary:#0a0e17;--bg-secondary:#111827;--bg-card:#1a2235;--bg-card-hover:#222d42;--bg-glass:#1a2235bf;--bg-input:#0d1321;--text-primary:#f0f2f5;--text-secondary:#94a3b8;--text-muted:#64748b;--accent-primary:#6366f1;--accent-primary-hover:#818cf8;--accent-secondary:#06b6d4;--accent-warm:#f59e0b;--accent-success:#10b981;--accent-danger:#ef4444;--border-subtle:#94a3b81f;--border-accent:#6366f14d;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:20px;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 20px #6366f126;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--transition-fast:.15s ease;--transition-base:.25s ease;--aldi-color:#00539b;--coles-color:#e01a22;--woolies-color:#009543}*{box-sizing:border-box;margin:0;padding:0}html,body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;line-height:1.6}a{color:var(--accent-primary-hover);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-secondary)}.app-layout{min-height:100vh;display:flex}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-subtle);z-index:100;flex-direction:column;width:240px;padding:1.5rem 0;display:flex;position:fixed;top:0;bottom:0}.sidebar-brand{border-bottom:1px solid var(--border-subtle);margin-bottom:1rem;padding:0 1.25rem 1.5rem}.sidebar-brand h1{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.25rem;font-weight:700}.sidebar-brand span{color:var(--text-muted);font-size:.75rem}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;padding:0 .75rem;display:flex}.sidebar-link{border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast);align-items:center;gap:.75rem;padding:.7rem 1rem;font-size:.875rem;font-weight:500;display:flex}.sidebar-link:hover{background:var(--bg-card);color:var(--text-primary)}.sidebar-link.active{color:var(--accent-primary-hover);border:1px solid var(--border-accent);background:#6366f126}.sidebar-link .icon{text-align:center;width:24px;font-size:1.2rem}.main-content{flex:1;max-width:1400px;margin-left:240px;padding:2rem 2.5rem}.page-header{margin-bottom:2rem}.page-header h2{margin-bottom:.25rem;font-size:1.75rem;font-weight:700}.page-header p{color:var(--text-secondary);font-size:.9rem}.modal-card,.modal-content{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:1.5rem}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--transition-base);padding:1.25rem}.card:hover{background:var(--bg-card-hover);border-color:var(--border-accent);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.card-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;display:grid}.btn{border-radius:var(--radius-md);font-size:.875rem;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000;align-items:center;gap:.5rem;padding:.6rem 1.25rem;display:inline-flex}.btn-primary{background:var(--accent-primary);color:#fff}.btn-primary:hover{background:var(--accent-primary-hover);box-shadow:var(--shadow-glow)}.btn-secondary{color:var(--text-secondary);border-color:var(--border-subtle);background:0 0}.btn-secondary:hover{border-color:var(--accent-primary);color:var(--text-primary)}.btn-danger{color:var(--accent-danger);background:0 0;border-color:#ef44444d}.btn-danger:hover{background:#ef44441a}.btn-sm{padding:.4rem .75rem;font-size:.8rem}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.4rem;font-size:.8rem;font-weight:600;display:block}.form-input,.form-select,.form-textarea{background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-family:var(--font-sans);transition:border-color var(--transition-fast);padding:.7rem 1rem;font-size:.9rem}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent-primary);outline:none;box-shadow:0 0 0 3px #6366f11a}.form-textarea{resize:vertical;min-height:120px}.badge{text-transform:uppercase;letter-spacing:.04em;border-radius:999px;align-items:center;padding:.15rem .6rem;font-size:.7rem;font-weight:600;display:inline-flex}.badge-health{color:var(--accent-success);background:#10b98126;border:1px solid #10b98140}.badge-ease{color:var(--accent-warm);background:#f59e0b26;border:1px solid #f59e0b40}.badge-fav{color:#f87171;background:#ef44441f;border:1px solid #ef444433}.planner-layout{align-items:flex-start;gap:1.5rem;display:flex}.planner-calendar{flex:1;min-width:0;position:relative;overflow-x:auto}.planner-sidebar{flex-shrink:0;width:280px;max-height:calc(100vh - 8rem);position:sticky;top:2rem;overflow-y:auto}.planner-sidebar .sidebar-search{margin-bottom:1rem}.calendar-grid{background:var(--border-subtle);border-radius:var(--radius-lg);grid-template-columns:100px repeat(7,minmax(120px,1fr));gap:2px;width:100%;min-width:max-content;display:grid;overflow:hidden}.calendar-header{background:var(--bg-secondary);text-align:center;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;padding:.75rem .5rem;font-size:.75rem;font-weight:700}.calendar-row-label{background:var(--bg-secondary);color:var(--text-muted);text-align:center;writing-mode:horizontal-tb;justify-content:center;align-items:center;padding:.75rem .5rem;font-size:.7rem;font-weight:600;display:flex}.meal-cell{background:var(--bg-primary);min-height:80px;transition:all var(--transition-fast);flex-direction:column;padding:.25rem;display:flex}.meal-cell-stack{flex-direction:column;gap:4px;width:100%;height:100%;display:flex}.meal-cell.drag-over{box-shadow:inset 0 0 0 2px var(--accent-primary);background:#6366f114}.meal-cell-content{border-radius:var(--radius-sm);text-align:center;cursor:default;width:100%;padding:.4rem .5rem;font-size:.72rem;font-weight:500;line-height:1.3}.meal-cell-content.has-recipe{border:1px solid var(--border-accent);color:var(--accent-primary-hover);background:#6366f11f}.meal-cell-content.has-custom{color:var(--accent-warm);background:#f59e0b1a;border:1px solid #f59e0b40}.meal-cell-content.empty{color:var(--text-muted);border:1px dashed var(--border-subtle);opacity:.5}.meal-cell-content .clear-btn{background:var(--accent-danger);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;display:none;position:absolute;top:-6px;right:-6px}.meal-cell-content:hover .clear-btn{display:flex}.meal-cell-content{position:relative}.recipe-mini-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:grab;transition:all var(--transition-fast);margin-bottom:.4rem;padding:.6rem .75rem;font-size:.8rem;font-weight:500}.recipe-mini-card:hover{border-color:var(--accent-primary);background:var(--bg-card-hover)}.recipe-mini-card:active{cursor:grabbing}.recipe-mini-card.dragging{opacity:.5;box-shadow:var(--shadow-lg)}.inventory-panel{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);margin-bottom:1.5rem;padding:1.25rem}.inventory-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.inventory-title{align-items:center;gap:.75rem;font-size:.95rem;font-weight:600;display:flex}.inventory-badge{color:var(--accent-primary-hover);border:1px solid var(--border-accent);background:#6366f126;border-radius:999px;padding:.15rem .6rem;font-size:.7rem;font-weight:600}.inventory-badge-sm{color:var(--accent-primary-hover);background:#6366f133;border-radius:999px;margin-left:.25rem;padding:.1rem .45rem;font-size:.65rem;font-weight:700}.inventory-actions{align-items:center;gap:.5rem;display:flex}.btn-record{color:#fff;background:linear-gradient(135deg,#ef4444,#dc2626);border:none}.btn-record:hover{background:linear-gradient(135deg,#f87171,#ef4444);box-shadow:0 0 16px #ef44444d}.record-dot{background:#fff;border-radius:50%;width:10px;height:10px;animation:1.2s ease-in-out infinite pulse-dot;display:inline-block}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.btn-stop{color:var(--accent-danger);background:#ef444426;border:1px solid #ef44444d;animation:1.5s ease-in-out infinite pulse-border}.btn-stop:hover{background:#ef444440}@keyframes pulse-border{0%,to{border-color:#ef44444d}50%{border-color:#ef4444b3}}.processing-indicator{color:var(--accent-secondary);align-items:center;gap:.5rem;font-size:.85rem;font-weight:500;display:flex}.spinner{border:2px solid var(--border-subtle);border-top-color:var(--accent-secondary);border-radius:50%;width:16px;height:16px;animation:.7s linear infinite spin;display:inline-block}.inventory-review{border-top:1px solid var(--border-subtle);margin-top:1rem;padding-top:1rem}.inventory-table{border-collapse:collapse;width:100%}.inventory-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-subtle);padding:.4rem .5rem;font-size:.7rem;font-weight:600}.inventory-table td{padding:.3rem .35rem}.table-row-hover:hover{background:var(--bg-card-hover);transition:background var(--transition-fast)}.inv-input{background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font-sans);padding:.35rem .5rem;font-size:.82rem}.inv-input:focus{border-color:var(--accent-primary);outline:none}.inv-name{min-width:140px}.inv-qty{width:70px}.inv-unit{width:60px}.inv-location{background:var(--bg-input);width:110px;color:var(--text-primary)}.inventory-buttons{justify-content:flex-end;gap:.5rem;margin-top:.75rem;display:flex}.deduct-toggle{color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.4rem;font-size:.82rem;display:flex}.deduct-toggle input[type=checkbox]{width:15px;height:15px;accent-color:var(--accent-primary);cursor:pointer}.shopping-controls{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.retailer-section{margin-bottom:1.5rem}.retailer-header{border-bottom:2px solid;align-items:center;gap:.5rem;margin-bottom:.75rem;padding:.5rem 0;font-size:1rem;font-weight:700;display:flex}.retailer-header.aldi{border-color:var(--aldi-color);color:#4da6d9}.retailer-header.coles{border-color:var(--coles-color);color:#f87171}.retailer-header.woolies{border-color:var(--woolies-color);color:#34d399}.shopping-item{border-radius:var(--radius-sm);transition:background var(--transition-fast);align-items:center;gap:.75rem;padding:.5rem .75rem;display:flex}.shopping-item:hover{background:var(--bg-card)}.shopping-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent-primary);cursor:pointer}.shopping-item.checked .item-name{color:var(--text-muted);text-decoration:line-through}.item-name{flex:1;font-size:.9rem}.item-qty{color:var(--text-muted);font-size:.8rem;font-weight:500}.recipe-form{max-width:800px}.recipe-form .form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.ingredients-table{border-collapse:collapse;width:100%;margin-top:.5rem}.ingredients-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;border-bottom:1px solid var(--border-subtle);padding:.5rem;font-size:.75rem;font-weight:600}.ingredients-table td{padding:.35rem .5rem}.ingredients-table input{background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font-sans);padding:.4rem .6rem;font-size:.85rem}.ingredients-table input:focus{border-color:var(--accent-primary);outline:none}.import-section{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);margin-bottom:2rem;padding:1.5rem}.import-section h3{color:var(--accent-secondary);margin-bottom:1rem;font-size:1rem}.import-toggle{gap:.5rem;margin-bottom:1rem;display:flex}.import-toggle .btn{flex:1}.import-toggle .btn.active{background:var(--accent-primary);color:#fff}.loading{color:var(--text-muted);justify-content:center;align-items:center;padding:3rem;display:flex}.loading:after{content:"";border:2px solid var(--border-subtle);border-top-color:var(--accent-primary);border-radius:50%;width:24px;height:24px;margin-left:.75rem;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--text-muted);padding:3rem}.empty-state .icon{margin-bottom:.75rem;font-size:2.5rem}.toast{border-radius:var(--radius-lg);z-index:2000;box-shadow:var(--shadow-lg),0 0 20px #0003;-webkit-backdrop-filter:blur(12px);align-items:center;gap:.75rem;max-width:400px;padding:1rem 1.5rem;font-size:.9rem;font-weight:500;animation:.4s cubic-bezier(.16,1,.3,1) toast-in;display:flex;position:fixed;bottom:2rem;right:2rem}.toast-success{color:#fff;background:#10b981e6;border:1px solid #10b98133}.toast-error{color:#fff;background:#ef4444f2;border:1px solid #ef444433;box-shadow:0 0 30px #ef444440}@keyframes toast-in{0%{opacity:0;transform:translate(100%)scale(.9)}to{opacity:1;transform:translate(0)scale(1)}}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}}@media (max-width:1024px){.sidebar{width:200px}.main-content{margin-left:200px;padding:1.5rem}.planner-layout{flex-direction:column}.planner-sidebar{width:100%;max-height:none;position:static}}@media (max-width:768px){.sidebar{display:none}.main-content{margin-left:0}.card-grid,.recipe-form .form-row{grid-template-columns:1fr}}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1500;background:#000000b3;justify-content:center;align-items:center;padding:1rem;animation:.2s fade-in;display:flex;position:fixed;inset:0}.modal-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);width:100%;max-width:450px;box-shadow:var(--shadow-lg),0 0 40px #6366f11a;padding:2rem;animation:.3s cubic-bezier(.16,1,.3,1) modal-up}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-up{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.template-recipe-pill{background:var(--bg-hover);border:1px solid var(--border-subtle);border-radius:var(--radius-md);align-items:center;gap:8px;width:100%;padding:6px 10px;display:flex}.template-recipe-pill .idx{background:var(--accent-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;min-width:18px;height:18px;font-size:.65rem;font-weight:700;display:flex}.template-recipe-pill .name-box{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.template-recipe-pill .name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:600;overflow:hidden}.template-recipe-pill .servings-ctrl{color:var(--text-secondary);align-items:center;gap:6px;font-size:.7rem;display:flex}.template-recipe-pill .servings-ctrl button{background:var(--bg-card);border:1px solid var(--border-subtle);color:var(--text-primary);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;width:18px;height:18px;padding-bottom:2px;font-size:.8rem;display:flex}.template-recipe-pill .servings-ctrl button:hover{border-color:var(--accent-primary);color:var(--accent-primary-hover)}.week-label{color:var(--accent-secondary);margin-bottom:.75rem;font-size:1rem;font-weight:700}.planner-nav{align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.nav-date-range{color:var(--text-primary);text-align:center;min-width:250px;font-weight:600}.override-indicator{vertical-align:middle;background:#f59e0b;border-radius:50%;width:6px;height:6px;margin-left:4px;display:inline-block}.opt-panel{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);margin-bottom:1.5rem;overflow:hidden;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008}.opt-panel-header{background:var(--bg-hover);border-bottom:1px solid var(--border-subtle);-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.opt-panel-header:hover{background:var(--bg-secondary)}.opt-suggestions{flex-direction:column;gap:1rem;padding:1.25rem;display:flex}.opt-totals{border-radius:var(--radius-md);background:#10b9810d;border:1px dashed #10b9814d;justify-content:space-between;align-items:center;padding:.75rem 1rem;font-size:.95rem;display:flex}.opt-card{border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-primary);box-shadow:var(--shadow-sm);transition:transform var(--transition-fast),box-shadow var(--transition-fast);flex-direction:column;gap:.75rem;padding:1rem;display:flex}.opt-card:hover{box-shadow:var(--shadow-md);border-color:#10b9814d;transform:translateY(-2px)}.opt-card-header{align-items:center;gap:.75rem;width:100%;display:flex}.opt-type-badge{text-transform:uppercase;background:var(--bg-secondary);color:var(--text-secondary);border-radius:999px;padding:.15rem .5rem;font-size:.65rem;font-weight:700}.opt-type-badge.retailer_switch{color:#3b82f6;background:#3b82f61a;border:1px solid #3b82f633}.opt-type-badge.product_switch{color:#d97706;background:#f59e0b1a;border:1px solid #f59e0b33}.opt-item-name{color:var(--text-primary);font-size:.95rem;font-weight:600}.savings-badge{color:#fff;background:linear-gradient(135deg,#10b981,#059669);border-radius:999px;padding:.2rem .6rem;font-size:.75rem;font-weight:700;box-shadow:0 2px 4px #10b98133}.savings-badge-sm{color:#059669;background:#10b9811a;border:1px solid #10b98133;border-radius:999px;margin-left:auto;padding:.15rem .5rem;font-size:.7rem;font-weight:700}.opt-card-body{background:var(--bg-secondary);border-radius:var(--radius-sm);grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem;padding:.75rem;font-size:.85rem;display:grid}.opt-current,.opt-suggested{flex-direction:column;gap:.25rem;display:flex}.opt-label{text-transform:uppercase;color:var(--text-muted);font-size:.7rem;font-weight:600}.opt-price{color:var(--text-secondary);font-weight:700}.opt-price-better{color:#059669;font-size:1.1em}.opt-arrow{color:var(--text-muted);font-size:1.25rem}.opt-card-actions{justify-content:flex-end;gap:.5rem;margin-top:.25rem;display:flex}.swap-panel{border-color:#8b5cf64d}.swap-badge{color:#fff;letter-spacing:.05em;background:linear-gradient(135deg,#a855f7,#7c3aed);border-radius:4px;padding:.1rem .4rem;font-size:.65rem;font-weight:800}.swap-card{border-left:3px solid #8b5cf6}.swap-arrow{text-align:center;color:var(--text-muted);text-transform:uppercase;margin:.25rem 0;font-size:.75rem;font-weight:600;position:relative}.swap-arrow:before,.swap-arrow:after{content:"";background:var(--border-subtle);width:calc(50% - 40px);height:1px;position:absolute;top:50%}.swap-arrow:before{left:0}.swap-arrow:after{right:0}.swap-reasoning{color:var(--text-secondary);background:var(--bg-hover);border-radius:var(--radius-sm);border-left:2px solid var(--border-accent);margin-top:.25rem;padding:.75rem;font-size:.85rem;line-height:1.4}
