@import "https://fonts.googleapis.com/css2?family=Source+Sans+3:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap";@import "https://fonts.googleapis.com/css2?family=Ubuntu:ital,wght@0,300;0,400;0,500;0,700;1,300;1,400;1,500;1,700&display=swap";:root{--bb-font-display:"Source Sans 3", system-ui, sans-serif;--bb-font-body:"Source Sans 3", system-ui, sans-serif;--bb-sage:#3d6b50;--bb-sage-mid:#5a8f6e;--bb-sage-light:#c8e6d4;--bb-sage-pale:#eef7f1;--bb-cream:#faf8f3;--bb-cream-dark:#f0ece3;--bb-parchment:#e4dfd5;--bb-terra:#b85c38;--bb-terra-pale:#fceee8;--bb-amber:#c47b1a;--bb-amber-pale:#fdf3e1;--bb-ink:#1a1714;--bb-ink-soft:#3a3330;--bb-ink-muted:#7a7068;--bb-border:#ddd8cf;--bb-border-light:#eae6df;--bb-white:#fff;--bb-r-sm:8px;--bb-r-md:12px;--bb-r-lg:16px;--bb-r-xl:22px;--bb-r-full:999px;--bb-shadow-sm:0 1px 4px #1a171412;--bb-shadow-md:0 4px 16px #1a17141a;--bb-shadow-lg:0 8px 32px #1a171426;--bb-font-base:17px;--bb-font-lg:1.125rem;--bb-font-xl:1.35rem;--bb-font-title:1.65rem;--bb-font-hero:clamp(2rem, 5vw, 3rem);--bb-text-primary:#1a1714;--bb-text-secondary:#3a3a38;--bb-text-tertiary:#7a7068;--bb-text-light:#a8a39a;--bb-surface-primary:#fff;--bb-surface-secondary:#faf8f3;--bb-surface-tertiary:#f5f3f0;--bb-surface:#faf8f3;--bb-surface-soft:#f5f3f0;--bb-surface-muted:#eeece9;--bb-muted:#7a7068;--bb-input-bg:#fff;--bb-input-text:#1a1714;--bb-danger:#c1635d;--bb-danger-pale:#fceee8;--bb-danger-border:#e5c4c0;--amber:#fdf3e1;--sage:#eef7f1;--creamDark:#f0ece3}[data-theme=dark]{--bb-cream:#0a0e11;--bb-cream-dark:#0f131a;--bb-parchment:#13181e;--bb-ink:#e8e3d9;--bb-ink-soft:#d4cec3;--bb-ink-muted:#a0978b;--bb-border:#2b3137;--bb-border-light:#1f2329;--bb-sage:#3f634d;--bb-sage-mid:#7aaf8d;--bb-sage-light:#4a7a5c;--bb-sage-pale:#1d3a28;--bb-terra:#d97a52;--bb-terra-pale:#3d2419;--bb-amber:#e5a84f;--bb-amber-pale:#3a2f0e;--bb-white:#1a2030;--bb-shadow-sm:0 1px 4px #00000080;--bb-shadow-md:0 4px 16px #0009;--bb-shadow-lg:0 8px 32px #000000b3;--bb-text-primary:#f0ebe0;--bb-text-secondary:#e8e3d9;--bb-text-tertiary:#b8aca0;--bb-text-light:#888077;--bb-surface-primary:#141820;--bb-surface-secondary:#0f131a;--bb-surface-tertiary:#0a0e11;--bb-surface:#0f131a;--bb-surface-soft:#141820;--bb-surface-muted:#0a0e11;--bb-muted:#b8aca0;--bb-input-bg:#1a2030;--bb-input-text:#f0ebe0;--bb-danger:#d97a52;--bb-danger-pale:#3d2419;--bb-danger-border:#6b3020;--amber:#4a2f15;--sage:#1f3328;--creamDark:#3a352b}[data-theme=dark] .bb-meal-saved{color:#86efac;background:#14532d}[data-theme=dark] .bb-badge--restaurant{color:#a5b4fc;background:#1e1b4b}[data-theme=dark] .bb-badge--delivery{background:var(--bb-amber-pale);color:var(--bb-amber)}[data-theme=dark] .bb-type-pill--ordered.bb-type-pill--on{border-color:var(--bb-amber);background:var(--bb-amber-pale);color:var(--bb-amber)}[data-theme=dark] .bb-drag-chip--restaurant{color:#a5b4fc;background:#1e1b4b;border-color:#4338ca}[data-theme=dark] .bb-btn--danger:hover:not(:disabled){background:var(--bb-danger-pale);border-color:var(--bb-danger)}*,:before,:after{box-sizing:border-box}html{font-size:var(--bb-font-base);-webkit-font-smoothing:antialiased;transition:color .3s}body{font-family:var(--bb-font-body);background:var(--bb-cream);color:var(--bb-ink);min-height:100vh;margin:0;transition:background-color .3s,color .3s}#root{width:100%;max-width:100%;text-align:initial;border:none;min-height:100svh;margin:0}input,select,button{font-family:inherit;font-size:1rem}@keyframes bb-fade-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes bb-fade-in{0%{opacity:0}to{opacity:1}}@keyframes bb-scale-in{0%{opacity:0;transform:scale(.96)translateY(5px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes bb-toast-in{0%{opacity:0;transform:translate(-50%,50px)}to{opacity:1;transform:translate(-50%)}}.bb-main{max-width:960px;margin:0 auto;padding:1.25rem 1rem 3rem}.bb-view-animate{animation:.25s both bb-fade-up}.bb-header{background:var(--bb-sage);z-index:100;position:sticky;top:0;box-shadow:0 2px 18px #0000002e}.bb-header-inner{max-width:960px;margin:0 auto;padding:1rem 1.25rem 0}.bb-header-top{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:.875rem;display:flex}.bb-header-logo{border-radius:var(--bb-r-md);background:#ffffff24;flex-shrink:0;justify-content:center;align-items:center;width:2.75rem;height:2.75rem;font-size:1.5rem;display:flex}.bb-header-titles{flex:1;min-width:200px}.bb-header-title{font-family:var(--bb-font-display);font-size:var(--bb-font-hero);color:#fff;letter-spacing:-.03em;font-weight:700;line-height:1.05}.bb-header-tagline{color:#ffffff9e;letter-spacing:.12em;text-transform:uppercase;margin-top:.2rem;font-size:1rem}.bb-header-stats{flex-wrap:wrap;gap:.45rem;margin-left:auto;display:flex}.bb-header-stat{color:#fff;border-radius:var(--bb-r-full);background:#ffffff29;border:1px solid #ffffff3d;padding:.25rem .75rem;font-size:1rem;font-weight:600}.bb-tabs{scrollbar-width:none;gap:2px;display:flex;overflow-x:auto}.bb-tab{color:#ffffffd9;border-radius:var(--bb-r-md) var(--bb-r-md) 0 0;font-family:var(--bb-font-body);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:.55rem 1rem;font-size:1rem;font-weight:500;transition:background .14s,color .14s}.bb-tab:hover{color:#fff;background:#ffffff14}.bb-tab--active{background:var(--bb-white);color:var(--bb-sage);font-weight:600}.bb-tab-icon{margin-right:.35rem}.bb-card{background:var(--bb-white);border:1px solid var(--bb-border);border-radius:var(--bb-r-xl);box-shadow:var(--bb-shadow-sm);margin-bottom:1rem;padding:1.35rem 1.5rem;animation:.28s both bb-fade-up}.bb-section-heading{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.65rem;margin-bottom:1.1rem;display:flex}.bb-section-head-left{align-items:center;gap:.65rem;display:flex}.bb-section-icon{border-radius:var(--bb-r-md);flex-shrink:0;justify-content:center;align-items:center;width:2.15rem;height:2.15rem;font-size:1.25rem;display:flex}.bb-section-title{font-family:var(--bb-font-display);font-size:var(--bb-font-title);color:var(--bb-ink);letter-spacing:-.02em;font-weight:700}.bb-btn{border-radius:var(--bb-r-md);cursor:pointer;font-size:1rem;font-weight:500;font-family:var(--bb-font-body);border:1.5px solid var(--bb-border);background:var(--bb-white);color:var(--bb-ink-soft);justify-content:center;align-items:center;gap:.35rem;padding:.5rem 1rem;transition:background .14s,border-color .14s,opacity .14s;display:inline-flex}.bb-btn:disabled{cursor:not-allowed;opacity:.5}.bb-btn--sm{padding:.3rem .7rem;font-size:1rem}.bb-btn--lg{padding:.65rem 1.35rem}.bb-btn--full{width:100%}.bb-btn--default:hover:not(:disabled){background:var(--bb-cream-dark)}.bb-btn--primary{background:var(--bb-sage);border-color:var(--bb-sage);color:#fff}.bb-btn--primary:hover:not(:disabled){background:var(--bb-sage-mid);border-color:var(--bb-sage-mid)}.bb-btn--ghost{color:var(--bb-ink-muted);background:0 0;border-color:#0000}.bb-btn--ghost:hover:not(:disabled){background:var(--bb-sage-pale)}.bb-btn--danger{background:var(--bb-terra-pale);border-color:var(--bb-danger-border);color:var(--bb-danger)}.bb-btn--danger:hover:not(:disabled){background:color-mix(in srgb, var(--bb-terra-pale) 70%, var(--bb-terra) 30%)}.bb-input{border:1.5px solid var(--bb-border);border-radius:var(--bb-r-md);background:var(--bb-cream);width:100%;color:var(--bb-ink);outline:none;padding:.55rem .75rem;font-size:1rem;transition:border-color .15s,box-shadow .15s,background .15s}.bb-input:focus{border-color:var(--bb-sage);background:var(--bb-white);box-shadow:0 0 0 3px #c8e6d473}.bb-input--date-narrow{width:9.2rem}.bb-select{border:1.5px solid var(--bb-border);border-radius:var(--bb-r-md);appearance:none;cursor:pointer;background-color:var(--bb-cream);width:100%;color:var(--bb-ink);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7'%3E%3Cpath d='M.5 1l5 5 5-5' stroke='%237a7068' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-position:right .7rem center;background-repeat:no-repeat;outline:none;padding:.55rem 2rem .55rem .75rem;font-size:1rem;transition:border-color .15s,background .15s}.bb-select:focus{border-color:var(--bb-sage);background-color:var(--bb-white)}.bb-field{margin-bottom:.75rem}.bb-field--inline-0{margin-bottom:0}.bb-field-label{letter-spacing:.06em;text-transform:uppercase;color:var(--bb-ink-muted);margin-bottom:.3rem;font-size:1rem;font-weight:600;display:block}.bb-badge{border-radius:var(--bb-r-full);align-items:center;gap:.2rem;padding:.2rem .65rem;font-size:1rem;font-weight:600;display:inline-flex}.bb-badge--home{background:var(--bb-sage-pale);color:var(--bb-sage)}.bb-badge--ordered{background:var(--bb-amber-pale);color:var(--bb-amber)}.bb-badge--skipped{background:var(--bb-cream-dark);color:var(--bb-ink-muted)}.bb-badge--person{background:var(--bb-sage-pale);color:var(--bb-sage);font-weight:600}.bb-badge--dine-in{background:var(--bb-cream-dark);color:var(--bb-ink-soft)}.bb-badge--restaurant{color:#5b52c2;background:#eeedf9;font-weight:600}.bb-badge--delivery{background:var(--bb-amber-pale);color:#92400e}.bb-type-pills{flex-wrap:wrap;gap:.35rem;display:flex}.bb-type-pill{border-radius:var(--bb-r-full);border:1.5px solid var(--bb-border);background:var(--bb-white);color:var(--bb-ink-muted);cursor:pointer;padding:.25rem .75rem;font-size:1rem;font-weight:600;transition:all .14s}.bb-type-pill--home.bb-type-pill--on{border-color:var(--bb-sage-mid);background:var(--bb-sage-pale);color:var(--bb-sage)}.bb-type-pill--ordered.bb-type-pill--on{background:var(--bb-amber-pale);color:#92400e;border-color:#f5c842}.bb-type-pill--skipped.bb-type-pill--on{border-color:var(--bb-parchment);background:var(--bb-cream-dark);color:var(--bb-ink-muted)}.bb-mini-pills{flex-wrap:wrap;gap:.35rem;display:flex}.bb-mini-pill{border-radius:var(--bb-r-full);border:1.5px solid var(--bb-border);background:var(--bb-white);color:var(--bb-ink-muted);cursor:pointer;padding:.25rem .65rem;font-size:.95rem;font-weight:600;transition:all .14s}.bb-mini-pill--on{border-color:var(--bb-sage-mid);background:var(--bb-sage-pale);color:var(--bb-sage)}.bb-modal-backdrop{z-index:9999;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#1a17148c;justify-content:center;align-items:center;padding:1rem;animation:.2s bb-fade-in;display:flex;position:fixed;inset:0}.bb-modal-panel{background:var(--bb-white);border:1px solid var(--bb-border);border-radius:var(--bb-r-xl);width:100%;max-width:460px;box-shadow:var(--bb-shadow-lg);padding:1.35rem 1.5rem;animation:.2s bb-scale-in}.bb-modal-head{justify-content:space-between;align-items:center;margin-bottom:1.1rem;display:flex}.bb-modal-title{font-family:var(--bb-font-display);color:var(--bb-ink);font-size:1.5rem;font-weight:700}.bb-modal-close{background:var(--bb-cream-dark);border-radius:var(--bb-r-sm);cursor:pointer;width:2rem;height:2rem;color:var(--bb-ink-muted);border:none;justify-content:center;align-items:center;font-size:1.1rem;line-height:1;display:flex}.bb-modal-actions{flex-wrap:wrap;gap:.5rem;display:flex}.bb-toast{border-radius:var(--bb-r-full);box-shadow:var(--bb-shadow-lg);z-index:99999;pointer-events:none;max-width:92vw;padding:.6rem 1.35rem;font-size:1rem;font-weight:500;animation:.3s bb-toast-in;position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%)}.bb-toast--ok{background:var(--bb-sage);color:#fff}.bb-toast--err{background:var(--bb-terra);color:#fff}.bb-empty{text-align:center;color:var(--bb-ink-muted);padding:3rem 1.5rem}.bb-empty-icon{margin-bottom:.75rem;font-size:2.25rem}.bb-empty-msg{font-size:1rem;font-style:italic}.bb-divider{background:var(--bb-border-light);height:1px;margin:1rem 0}.bb-log-date-row{align-items:center;gap:.5rem;margin-bottom:1.1rem;display:flex}.bb-log-date-label{color:var(--bb-ink-muted);font-size:1rem}.bb-date-nav{align-items:center;gap:.35rem;display:flex}.bb-grid-meals{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.75rem;display:grid}.bb-meal-card{background:var(--bb-white);border:1.5px solid var(--bb-border);border-radius:var(--bb-r-lg);box-shadow:var(--bb-shadow-sm);flex-direction:column;gap:.65rem;padding:1rem;transition:border-color .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden}.bb-meal-card--saved{box-shadow:0 0 0 3px color-mix(in srgb, var(--bb-meal,var(--bb-sage)) 12%, transparent)}.bb-meal-card--context{outline:3px solid color-mix(in srgb, var(--bb-meal,var(--bb-sage)) 45%, transparent);outline-offset:2px}.bb-meal-card--context-muted{opacity:.72}.bb-meal-accent{background:var(--bb-meal-bar,var(--bb-sage));height:3px;position:absolute;top:0;left:0;right:0}.bb-btn-meal-save{margin-top:.15rem;background:var(--bb-meal,var(--bb-sage))!important;border:1.5px solid var(--bb-meal,var(--bb-sage))!important;color:#fff!important}.bb-btn.bb-btn-meal-save:hover:not(:disabled){filter:brightness(1.07);background:var(--bb-meal,var(--bb-sage))!important;border-color:var(--bb-meal,var(--bb-sage))!important;color:#fff!important}.bb-meal-head{align-items:center;gap:.5rem;margin-top:.25rem;display:flex}.bb-meal-emoji{font-size:1.25rem}.bb-meal-name{font-family:var(--bb-font-display);color:var(--bb-ink);font-size:1.15rem;font-weight:700}.bb-meal-saved{color:#15803d;border-radius:var(--bb-r-full);background:#bbf7d0;margin-left:auto;padding:.15rem .55rem;font-size:1rem;font-weight:700;transition:background .3s,color .3s}.bb-meal-logged{color:var(--bb-ink-muted);margin-left:auto;font-size:1rem}.bb-meal-fields{grid-template-columns:1fr;gap:.5rem;display:grid}.bb-drop-field{border-radius:var(--bb-r-md);transition:box-shadow .15s,background .15s}.bb-drop-field--over{box-shadow:0 0 0 2px var(--bb-sage-mid);background:var(--bb-sage-pale)}.bb-log-context{background:var(--bb-sage-pale);border:1px solid var(--bb-border);border-radius:var(--bb-r-lg);margin-bottom:1rem;padding:1rem}.bb-log-context-title{color:var(--bb-ink);margin-bottom:.5rem;font-size:1.05rem;font-weight:700}.bb-log-context-row{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.65rem;display:flex}.bb-log-context-hint{color:var(--bb-ink-muted);margin-top:.35rem;font-size:.95rem;line-height:1.45}.bb-chip-bank{margin-top:.35rem}.bb-chip-bank-label{text-transform:uppercase;letter-spacing:.06em;color:var(--bb-ink-muted);margin:.5rem 0 .35rem;font-size:.85rem;font-weight:700}.bb-drag-chip{border-radius:var(--bb-r-full);border:1.5px solid var(--bb-border);background:var(--bb-white);color:var(--bb-ink-soft);cursor:grab;-webkit-user-select:none;user-select:none;align-items:center;gap:.25rem;padding:.35rem .65rem;font-size:.95rem;font-weight:600;transition:transform .12s,box-shadow .12s,background .3s,border-color .3s;display:inline-flex}.bb-drag-chip:active{cursor:grabbing;transform:scale(.98)}.bb-drag-chip--dish{border-color:color-mix(in srgb, var(--bb-sage) 35%, var(--bb-border))}.bb-drag-chip--person{border-color:color-mix(in srgb, var(--bb-sage-mid) 40%, var(--bb-border))}.bb-drag-chip--restaurant{background:#faf9ff;border-color:#c4bfe8}.bb-table-wrap{border-radius:var(--bb-r-md);border:1px solid var(--bb-border);overflow-x:auto}.bb-table-wrap--scroll{max-height:30rem;overflow-y:auto}.bb-table{border-collapse:collapse;width:100%;min-width:32rem;font-size:1rem}.bb-table--narrow{min-width:44rem}.bb-th{background:var(--bb-cream);color:var(--bb-ink-muted);text-transform:uppercase;letter-spacing:.04em;text-align:left;border-bottom:1px solid var(--bb-border);white-space:nowrap;padding:.55rem .75rem;font-size:1rem;font-weight:600}.bb-th--sticky{z-index:1;position:sticky;top:0}.bb-td{border-bottom:1px solid var(--bb-border-light);vertical-align:top;padding:.6rem .75rem;font-size:1rem}.bb-tr:nth-child(2n){background:var(--bb-cream)}.bb-tr:hover{background:var(--bb-cream-dark)}.bb-tr--today{background:var(--bb-sage-pale)}.bb-td-date{white-space:nowrap;color:var(--bb-ink-soft)}.bb-td-date--today{color:var(--bb-sage);font-weight:600}.bb-today-dot{background:var(--bb-sage);vertical-align:middle;border-radius:50%;width:6px;height:6px;margin-left:.35rem;display:inline-block}.bb-ellipsis{text-overflow:ellipsis;white-space:nowrap;max-width:8rem;overflow:hidden}.bb-muted{color:var(--bb-ink-muted)}.bb-parchment{color:var(--bb-parchment)}.bb-icon-btn{cursor:pointer;opacity:.45;background:0 0;border:none;border-radius:6px;padding:.15rem .35rem;font-size:1rem;transition:opacity .15s}.bb-icon-btn:hover{opacity:1}.bb-insight-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.65rem;margin-bottom:1.25rem;display:grid}.bb-insight-chip{border-radius:var(--bb-r-lg);border:1px solid #0000;padding:.85rem 1rem}.bb-insight-chip-label{text-transform:uppercase;letter-spacing:.05em;margin-bottom:.3rem;font-size:1rem;font-weight:600}.bb-insight-chip-value{font-family:var(--bb-font-display);font-size:1.45rem;font-weight:700}.bb-insight-chip-sub{opacity:.75;margin-top:.15rem;font-size:.9rem}.bb-chart-box{background:var(--bb-white);border:1px solid var(--bb-border);border-radius:var(--bb-r-lg);padding:1rem 1.1rem}.bb-chart-title{text-transform:uppercase;letter-spacing:.05em;color:var(--bb-ink-muted);margin-bottom:.65rem;font-size:1rem;font-weight:600}.bb-file-drop{border:2px dashed var(--bb-border);border-radius:var(--bb-r-lg);text-align:center;cursor:pointer;padding:2rem;transition:border-color .15s,background .15s}.bb-file-drop:hover,.bb-file-drop--over{border-color:var(--bb-sage-mid);background:var(--bb-sage-pale)}.bb-file-drop-icon{margin-bottom:.5rem;font-size:2.5rem}.bb-file-drop-text{margin-bottom:.25rem;font-size:1.05rem;font-weight:600}.bb-file-drop-sub{color:var(--bb-sage);font-size:1rem}.bb-help-box{background:var(--bb-cream-dark);border-radius:var(--bb-r-md);border:1px solid var(--bb-border);padding:1rem 1.1rem}.bb-help-title{font-family:var(--bb-font-display);margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.bb-help-list{color:var(--bb-ink-muted);padding-left:1.2rem;font-size:1rem;line-height:1.85}.bb-help-strong{color:var(--bb-sage);font-weight:600}.bb-count-pill{color:var(--bb-ink-muted);background:var(--bb-cream-dark);border-radius:var(--bb-r-full);padding:.2rem .65rem;font-size:1rem}.bb-hidden{display:none!important}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;font-size:16px}body{background:var(--bb-cream,#faf8f3);color:var(--bb-ink,#1a1714);min-height:100vh;font-family:Ubuntu,sans-serif;transition:background-color .3s,color .3s}input,select,button{font-family:inherit}input[type=date]::-webkit-calendar-picker-indicator{opacity:.5;cursor:pointer}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--bb-cream-dark,#f0ece3)}::-webkit-scrollbar-thumb{background:var(--bb-border,#ddd8cf);border-radius:3px}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)translateY(5px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,50px)}to{opacity:1;transform:translate(-50%)}}.card{background:var(--bb-surface-primary);border:1px solid var(--bb-border);box-shadow:var(--bb-shadow-sm);border-radius:22px;margin-bottom:16px;padding:12px;animation:.28s both fadeUp}.btn{cursor:pointer;white-space:nowrap;border:1.5px solid;border-radius:12px;justify-content:center;align-items:center;gap:6px;font-family:Ubuntu,sans-serif;font-size:16px;font-weight:500;transition:all .14s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-size-sm{padding:5px 11px;font-size:14px}.btn-size-md{padding:8px 16px;font-size:16px}.btn-size-lg{padding:11px 22px;font-size:16px}.btn-full{width:100%}.inp{border:1.5px solid var(--bb-border);background:var(--bb-surface-secondary);width:100%;color:var(--bb-text-primary);border-radius:12px;outline:none;padding:9px 12px;font-family:Ubuntu,sans-serif;font-size:16px;transition:all .15s}.inp-focused{background:var(--bb-surface-primary);border-color:var(--bb-sage)}.sel{border:1.5px solid var(--bb-border);appearance:none;cursor:pointer;width:100%;color:var(--bb-text-primary);background-color:var(--bb-surface-primary);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7'%3E%3Cpath d='M.5 1l5 5 5-5' stroke='%237a7068' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-position:right 11px center;background-repeat:no-repeat;background-size:11px 7px;border-radius:12px;outline:none;padding:9px 32px 9px 12px;font-family:Ubuntu,sans-serif;font-size:16px;transition:all .15s}.sel-focused{background-color:var(--bb-surface-primary);border-color:var(--bb-sage)}.field-label{letter-spacing:.7px;text-transform:uppercase;color:var(--bb-text-tertiary);margin-bottom:5px;font-size:16px;font-weight:600;display:block}.field{margin-bottom:12px}.badge{background:var(--bb-surface-tertiary);color:var(--bb-text-tertiary);border:1px solid var(--bb-border);border-radius:999px;align-items:center;gap:3px;padding:4px 10px;font-size:14px;font-weight:500;display:inline-flex}.modal-overlay{z-index:9999;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#1a17148c;justify-content:center;align-items:center;padding:16px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bb-surface-primary);border:1px solid var(--bb-border);width:100%;max-width:440px;box-shadow:var(--bb-shadow-lg);border-radius:22px;padding:22px 24px;animation:.2s scaleIn}.modal-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.modal-title{color:var(--bb-text-primary);font-family:Ubuntu,serif;font-size:24px;font-weight:700}.modal-close{background:var(--bb-surface-secondary);cursor:pointer;width:30px;height:30px;color:var(--bb-text-light);border:none;border-radius:8px;justify-content:center;align-items:center;font-size:18px;transition:color .15s,background .15s;display:flex}.modal-close:hover{color:var(--bb-text-tertiary);background:var(--bb-surface-tertiary)}.toast{color:#fff;background:var(--bb-sage);box-shadow:var(--bb-shadow-lg);z-index:99999;white-space:nowrap;pointer-events:none;border-radius:999px;padding:10px 22px;font-size:16px;font-weight:500;animation:.3s toastIn;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.divider{background:var(--bb-border);height:1px;margin:16px 0}.section-heading{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:18px;display:flex}.section-heading-left{align-items:center;gap:10px;display:flex}.section-heading-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:20px;display:flex}.section-heading-text{color:var(--bb-text-primary);letter-spacing:-.3px;font-family:Ubuntu,serif;font-size:22px;font-weight:700}.empty-state{text-align:center;color:var(--bb-text-tertiary);padding:48px 24px}.empty-state-icon{margin-bottom:12px;font-size:36px}.empty-state-msg{font-size:16px;font-style:italic}.type-pills{flex-wrap:wrap;gap:5px;display:flex}.type-pill{border:1.5px solid var(--bb-border);cursor:pointer;background:var(--bb-surface-primary);color:var(--bb-text-secondary);border-radius:999px;padding:4px 12px;font-family:Ubuntu,sans-serif;font-size:16px;font-weight:600;transition:all .14s}.type-pill-active{background:var(--bb-sage);color:#fff;border-color:var(--bb-sage)}.header{background:var(--bb-sage);z-index:100;position:sticky;top:0;box-shadow:0 2px 18px #0000002e}.header-content{max-width:960px;margin:0 auto;padding:8px 12px 0}.header-top{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:8px;display:flex}.header-logo{background:#ffffff24;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;display:flex}.header-title-section{flex-direction:column;display:flex}.header-title{color:#fff;letter-spacing:-.5px;font-family:Ubuntu,serif;font-size:36px;font-weight:700;line-height:1}.header-subtitle{color:#ffffffd9;letter-spacing:1.3px;text-transform:uppercase;margin-top:2px;font-size:16px}.header-stats{flex-wrap:wrap;gap:7px;margin-left:auto;display:flex}.header-stat{color:#fff;background:#ffffff29;border:1px solid #ffffff3d;border-radius:999px;padding:3px 8px;font-size:12px;font-weight:600}.header-tabs{scrollbar-width:none;scroll-behavior:smooth;gap:2px;display:flex;position:relative;overflow-x:auto}.header-tabs::-webkit-scrollbar{display:none}.header-tabs:before{content:"";pointer-events:none;z-index:1;background:linear-gradient(90deg,#0000001f,#0000);width:20px;position:absolute;top:0;bottom:0;left:0}.header-tabs:after{content:"";pointer-events:none;z-index:1;background:linear-gradient(270deg,#0000001f,#0000);width:20px;position:absolute;top:0;bottom:0;right:0}.header-tab{color:#fffffff2;cursor:pointer;white-space:nowrap;z-index:2;background:0 0;border:none;border-radius:10px 10px 0 0;padding:7px 12px;font-family:Ubuntu,sans-serif;font-size:14px;font-weight:400;transition:all .14s;position:relative}.header-tab-active{background:var(--bb-surface-primary);color:var(--bb-sage);font-weight:600}.header-tab:hover:not(.header-tab-active){color:#fff;background:#ffffff1a}.header-actions{align-items:center;display:flex}.header-theme-btn{color:#fffffff2;cursor:pointer;background:#ffffff1f;border:1px solid #ffffff29;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;transition:all .14s;display:flex}.header-theme-btn:hover{background:#ffffff2e;border-color:#ffffff3d}.header-auth{align-items:center;gap:10px;display:flex}.user-info{color:#fffffff2;align-items:center;gap:10px;font-size:16px;display:flex}.auth-button{color:#fffffff2;cursor:pointer;background:#ffffff29;border:1px solid #ffffff29;border-radius:8px;padding:8px 16px;font-size:14px;transition:background .14s}.auth-button:hover{background:#ffffff3d}@media (width<=375px){.header-title{font-size:28px}.header-logo{width:26px;height:26px;font-size:14px}.header-subtitle{font-size:12px}}.meal-card{background:var(--bb-surface-primary);border:1.5px solid var(--bb-border);border-radius:16px;flex-direction:column;gap:10px;padding:16px;transition:border-color .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden}.meal-card-accent{height:3px;position:absolute;top:0;left:0;right:0}.meal-card-header{align-items:center;gap:8px;margin-top:4px;display:flex}.meal-card-icon{font-size:20px}.meal-card-title{color:var(--bb-text-primary);font-family:Ubuntu,serif;font-size:18px;font-weight:700}.meal-card-saved{color:#15803d;background:#bbf7d0;border-radius:999px;margin-left:auto;padding:2px 9px;font-size:16px;font-weight:700;transition:background .3s,color .3s}[data-theme=dark] .meal-card-saved{color:#86efac;background:#14532d}.meal-card-logged{color:var(--bb-text-tertiary);margin-left:auto;font-size:16px}.meal-card-fields{grid-template-columns:1fr;gap:8px;display:grid}.insight-chip{border:1px solid;border-radius:16px;padding:14px 16px}.insight-chip-label{text-transform:uppercase;letter-spacing:.6px;color:inherit;margin-bottom:5px;font-size:16px;font-weight:600}.insight-chip-value{color:var(--bb-text-primary);margin-bottom:3px;font-family:Ubuntu,serif;font-size:24px;font-weight:700;line-height:1.2}.insight-chip-sub{color:var(--bb-text-tertiary);font-size:16px}.recent-meals-panel{background:var(--bb-surface-secondary);border:1px solid var(--bb-border);border-radius:16px;margin-bottom:20px;padding:16px}.recent-meals-header{flex-wrap:wrap;justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.recent-meals-title{color:var(--bb-text-secondary);font-size:16px;font-weight:600}.recent-meals-count{background:var(--bb-surface-tertiary);color:var(--bb-text-tertiary);border-radius:12px;padding:2px 8px;font-size:14px}.recent-meals-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;max-height:220px;display:grid;overflow-y:auto}.recent-meal-card{background:var(--bb-surface-primary);border:1.5px solid var(--bb-border);cursor:grab;-webkit-user-select:none;user-select:none;border-radius:12px;padding:10px;transition:border-color .15s,box-shadow .15s,transform .15s;position:relative}.recent-meal-card:hover{border-color:var(--bb-sage-mid);box-shadow:0 2px 8px color-mix(in srgb, var(--bb-sage) 20%, transparent);transform:translateY(-2px)}.recent-meal-card:active{cursor:grabbing;opacity:.7}.recent-meal-label{color:var(--bb-text-secondary);margin-bottom:4px;font-size:14px;font-weight:600}.recent-meal-dish{color:var(--bb-text-primary);word-break:break-word;margin-bottom:2px;font-size:13px;font-weight:500}.recent-meal-by{color:var(--bb-text-tertiary);margin-bottom:4px;font-size:12px}.recent-meal-badges{gap:2px;font-size:12px;display:flex}.badge-small{background:var(--bb-surface-tertiary);color:var(--bb-text-tertiary);border-radius:4px;padding:2px 4px;font-size:11px;display:inline-block}.recent-meals-footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-top:14px;display:flex}.recent-meals-page-btn{background:var(--bb-sage);color:#fff;cursor:pointer;border:none;border-radius:999px;padding:8px 14px;font-size:13px;transition:background .15s}.recent-meals-page-btn:disabled{background:var(--bb-sage-light);cursor:not-allowed;opacity:.6}.recent-meals-page-btn:not(:disabled):hover{background:var(--bb-sage-mid)}.recent-meals-page-info{color:var(--bb-sage);font-size:14px;font-weight:600}.filter-sort-modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;position:fixed;inset:0}.filter-sort-modal{background:var(--bb-surface-primary);z-index:1001;border:1px solid var(--bb-border);border-radius:16px 16px 0 0;flex-direction:column;max-height:85vh;animation:.2s ease-out slideUp;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 24px #0000002e}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media (width>=640px){.filter-sort-modal{border-radius:16px;width:calc(100% - 48px);max-width:500px;max-height:85vh;animation:.2s ease-out slideIn;inset:50% auto auto 50%;transform:translate(-50%,-50%)}@keyframes slideIn{0%{opacity:0;transform:translate(-50%,calc(14px - 50%))scale(.97)}to{opacity:1;transform:translate(-50%,-50%)scale(1)}}}.filter-sort-modal-header{border-bottom:1px solid var(--bb-border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px;display:flex}.filter-sort-modal-header h2{color:var(--bb-text-primary);margin:0;font-size:18px;font-weight:600}.filter-sort-close-btn{cursor:pointer;color:var(--bb-text-light);background:0 0;border:none;padding:4px 8px;font-size:20px;transition:color .15s}.filter-sort-close-btn:hover{color:var(--bb-text-tertiary)}.filter-sort-modal-content{flex-direction:column;flex:1;gap:20px;padding:16px;display:flex;overflow-y:auto}.filter-sort-section{flex-direction:column;gap:12px;display:flex}.filter-sort-section-title{text-transform:uppercase;letter-spacing:.5px;color:var(--bb-text-tertiary);margin:0;font-size:14px;font-weight:600}.filter-sort-group{flex-direction:column;gap:8px;display:flex}.filter-sort-label{color:var(--bb-text-secondary);font-size:13px;font-weight:500}.filter-sort-button-group{flex-wrap:wrap;gap:8px;display:flex}.filter-sort-pill{background:var(--bb-surface-tertiary);border:1px solid var(--bb-border);color:var(--bb-text-secondary);cursor:pointer;border-radius:20px;min-height:36px;padding:8px 12px;font-size:13px;font-weight:500;transition:all .15s}.filter-sort-pill:hover{background:var(--bb-surface-secondary);border-color:var(--bb-sage)}.filter-sort-pill-active{background:var(--bb-sage);color:#fff;border-color:var(--bb-sage)}.filter-sort-search-input{align-items:center;display:flex;position:relative}.filter-sort-input{border:1px solid var(--bb-border);background:var(--bb-surface-primary);width:100%;color:var(--bb-text-primary);border-radius:8px;padding:10px 32px 10px 12px;font-family:inherit;font-size:13px;transition:all .15s}.filter-sort-input:focus{border-color:var(--bb-sage);box-shadow:0 0 0 3px color-mix(in srgb, var(--bb-sage) 15%, transparent);outline:none}.filter-sort-clear-input{color:var(--bb-text-light);cursor:pointer;background:0 0;border:none;padding:4px 6px;font-size:16px;transition:color .15s;position:absolute;right:8px}.filter-sort-clear-input:hover{color:var(--bb-text-tertiary)}.filter-sort-suggestions{background:var(--bb-surface-primary);border:1px solid var(--bb-border);z-index:10;max-height:150px;box-shadow:var(--bb-shadow-md);border-top:none;border-radius:0 0 8px 8px;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.filter-sort-suggestion-item{color:var(--bb-text-secondary);cursor:pointer;border-bottom:1px solid var(--bb-border);padding:10px 12px;font-size:13px;transition:background .15s}.filter-sort-suggestion-item:last-child{border-bottom:none}.filter-sort-suggestion-item:hover{background:var(--bb-surface-tertiary)}.filter-sort-modal-actions{border-top:1px solid var(--bb-border);flex-shrink:0;gap:10px;padding:16px;display:flex}.filter-sort-btn{border:1px solid var(--bb-border);cursor:pointer;border-radius:8px;flex:1;justify-content:center;align-items:center;min-height:44px;padding:12px 16px;font-size:14px;font-weight:600;transition:all .15s;display:flex}.filter-sort-btn-clear{background:var(--bb-surface-secondary);color:var(--bb-text-tertiary)}.filter-sort-btn-clear:hover{background:var(--bb-surface-tertiary);border-color:var(--bb-text-tertiary)}.filter-sort-btn-apply{background:var(--bb-sage);color:#fff;border-color:var(--bb-sage)}.filter-sort-btn-apply:hover{background:var(--bb-sage-mid);border-color:var(--bb-sage-mid)}@media (width<=375px){.filter-sort-modal-header{padding:12px}.filter-sort-modal-content{gap:16px;padding:12px}.filter-sort-modal-actions{gap:8px;padding:12px}.filter-sort-pill{min-height:32px;padding:6px 10px;font-size:12px}.filter-sort-btn{min-height:40px;padding:10px 12px;font-size:13px}}.log-view-meal-cards{grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:8px;display:grid}.log-view-drop-zone{transition:all .2s}.log-view-drop-zone.drag-over{transform:scale(1.02)}.log-view-drop-zone.drag-over .meal-card{border-color:var(--bb-sage)!important;box-shadow:0 0 12px #5a8f6e40!important}.log-view-context-banner{background:var(--bb-surface-secondary);border:1px solid var(--bb-border);border-radius:12px;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;padding:8px 12px;display:flex}.log-view-context-label{color:var(--bb-text-secondary);text-transform:uppercase;font-size:14px;font-weight:600}.log-view-context-value{color:var(--bb-text-primary);background:var(--bb-surface-primary);border:1px solid var(--bb-border);border-radius:8px;padding:3px 10px;font-size:16px;font-weight:500}.history-list{flex-direction:column;gap:16px;padding:12px 0;display:flex}.history-date-group{margin-bottom:12px}.history-date-header{background:var(--bb-surface-soft);border-left:3px solid var(--bb-sage);border-radius:6px;justify-content:space-between;align-items:center;margin-bottom:8px;padding:6px 8px;display:flex}.history-date-label{color:var(--bb-text-secondary);font-size:15px;font-weight:600}.history-date-count{color:var(--bb-muted);background:var(--bb-surface);border-radius:999px;padding:2px 8px;font-size:13px}.history-entries{flex-direction:column;gap:4px;display:flex}.history-entry-card{border:1px solid var(--bb-border);background:var(--bb-surface);border-radius:8px;transition:box-shadow .2s;overflow:hidden}.history-entry-card:hover{box-shadow:0 2px 8px #00000014}.history-entry-header{cursor:pointer;background:var(--bb-surface-soft);-webkit-user-select:none;user-select:none;align-items:center;gap:8px;min-height:44px;padding:6px 8px;transition:background .15s;display:flex}.history-entry-header:hover{background:var(--bb-surface-muted)}.history-entry-icon{flex-shrink:0;font-size:18px}.history-entry-name{color:var(--bb-text-secondary);flex-shrink:0;font-size:15px;font-weight:500}.history-entry-dish{color:var(--bb-text-tertiary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:14px;overflow:hidden}.history-expand-btn{color:var(--bb-text-light);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:4px 6px;font-size:12px;transition:color .15s}.history-expand-btn:hover{color:var(--bb-text-tertiary)}.history-entry-details{border-top:1px solid var(--bb-border);background:var(--bb-surface-soft);flex-direction:column;gap:8px;padding:8px;display:flex}.history-detail-row{align-items:center;gap:8px;font-size:14px;display:flex}.history-detail-label{color:var(--bb-text-tertiary);flex-shrink:0;min-width:70px;font-weight:500}.history-detail-value{color:var(--bb-text-primary);flex:1}.history-detail-select{border:1px solid var(--bb-border);background:var(--bb-input-bg);color:var(--bb-input-text);cursor:pointer;border-radius:6px;flex:1;padding:5px 8px;font-family:Ubuntu,sans-serif;font-size:13px;transition:all .15s}.history-detail-select:hover{border-color:var(--bb-sage)}.history-detail-select:focus{border-color:var(--bb-sage);box-shadow:0 0 0 2px color-mix(in srgb, var(--bb-sage) 18%, transparent);outline:none}.history-detail-actions{border-top:1px solid var(--bb-border);gap:8px;margin-top:4px;padding-top:8px;display:flex}.history-detail-btn{border:1px solid var(--bb-border);background:var(--bb-surface-secondary);cursor:pointer;color:var(--bb-text-secondary);border-radius:6px;flex:1;padding:7px 12px;font-size:13px;font-weight:500;transition:all .15s}.history-detail-btn:hover{background:var(--bb-surface-tertiary);border-color:var(--bb-sage)}.history-detail-btn-delete{color:var(--bb-danger);border-color:var(--bb-danger-border)}.history-detail-btn-delete:hover{background:var(--bb-danger-pale);border-color:var(--bb-danger)}.history-filter-btn{cursor:pointer;color:var(--bb-text-tertiary);background:0 0;border:none;padding:4px 8px;font-size:18px;transition:opacity .15s}.history-filter-btn:hover{opacity:.7}.history-active-filters{border-bottom:1px solid var(--bb-border);flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;padding:8px 0;display:flex}.history-filter-badge{background:var(--bb-surface-tertiary);color:var(--bb-text-secondary);border-radius:14px;padding:4px 10px;font-size:12px;font-weight:500}.history-clear-filters-btn{border:1px solid var(--bb-border);color:var(--bb-text-tertiary);cursor:pointer;background:0 0;border-radius:6px;padding:4px 8px;font-size:12px;font-weight:500;transition:all .15s}.history-clear-filters-btn:hover{border-color:var(--bb-text-tertiary);background:var(--bb-surface-tertiary)}.history-entry-count{color:var(--bb-text-tertiary);background:var(--bb-surface-tertiary);border-radius:999px;padding:3px 10px;font-size:16px}@media (width<=640px){.history-entry-header{flex-wrap:wrap}.history-entry-name{order:2}.history-entry-icon{order:1}.history-entry-dish{flex-basis:100%;order:4;margin-top:4px}.history-expand-btn{order:3}}.insights-date-range{flex-wrap:wrap;align-items:flex-end;gap:10px;margin-bottom:20px;display:flex}.insights-meal-count{color:var(--bb-text-tertiary);padding-bottom:2px;font-size:16px}.insights-chips{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px;margin-bottom:20px;display:grid}.insights-charts{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:8px;display:grid}.insights-chart-box{background:var(--bb-surface-secondary);border:1px solid var(--bb-border);border-radius:16px;padding:10px 12px}.insights-chart-title{text-transform:uppercase;letter-spacing:.5px;color:var(--bb-text-tertiary);margin-bottom:10px;font-size:16px;font-weight:600}.insights-suggestions{background:var(--bb-surface-secondary);border:1px solid var(--bb-border);border-radius:14px;margin-bottom:20px;padding:16px}.insights-suggestions-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;display:flex}.insights-suggestions-title{color:var(--bb-text-primary);font-size:16px;font-weight:700}.insights-suggestions-note{color:var(--bb-text-tertiary);max-width:520px;font-size:13px}.insights-suggestion-list{gap:10px;margin:0;padding:0;list-style:none;display:grid}.insights-suggestion-item{background:var(--bb-surface-primary);border:1px solid var(--bb-border);color:var(--bb-text-primary);border-radius:10px;align-items:center;gap:10px;padding:10px 12px;font-weight:500;display:flex}.insights-suggestion-dot{background:var(--bb-amber);border-radius:50%;flex-shrink:0;width:10px;height:10px}.insights-suggestion-empty{color:var(--bb-text-tertiary);background:var(--bb-surface-secondary);border:1px dashed var(--bb-border);border-radius:10px;padding:10px 12px}.data-view-dropzone{border:2px dashed var(--bb-sage);text-align:center;background:var(--bb-surface-secondary);cursor:pointer;border-radius:16px;padding:32px 20px;transition:all .2s}.data-view-dropzone.dragging{border-color:var(--bb-sage);background:var(--bb-surface-tertiary)}.data-view-dropzone-title{color:var(--bb-text-secondary);margin-bottom:4px;font-size:16px;font-weight:600}.data-view-dropzone-subtitle{color:var(--bb-text-secondary);font-size:16px}.data-view-info{background:var(--bb-surface-secondary);border:1px solid var(--bb-border);border-radius:16px;padding:16px 18px}.data-view-info-title{color:var(--bb-text-primary);margin-bottom:10px;font-family:Ubuntu,serif;font-size:20px;font-weight:600}.data-view-info-list{color:var(--bb-text-tertiary);padding-left:18px;font-size:16px;line-height:2}.data-view-info-list strong{color:var(--bb-text-secondary)}
